OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-stable/] [binutils-2.20.1/] [ld/] [testsuite/] [ld-ia64/] [tlspic1.s] - Rev 862

Go to most recent revision | Compare with Previous | Blame | View Log

	/* Force .data aligned to 4K, so .got very likely gets at 0x13190
	   (0x60 bytes .tdata and 0x130 bytes .dynamic)  */
	.data
	.balign 4096
	.section ".tdata", "awT", @progbits
	.globl sg1, sg2, sg3, sg4, sg5, sg6, sg7, sg8
	.globl sh1, sh2, sh3, sh4, sh5, sh6, sh7, sh8
	.hidden sh1, sh2, sh3, sh4, sh5, sh6, sh7, sh8
sg1:	.long 17
sg2:	.long 18
sg3:	.long 19
sg4:	.long 20
sg5:	.long 21
sg6:	.long 22
sg7:	.long 23
sg8:	.long 24
sl1:	.long 65
sl2:	.long 66
sl3:	.long 67
sl4:	.long 68
sl5:	.long 69
sl6:	.long 70
sl7:	.long 71
sl8:	.long 72
sh1:	.long 257
sh2:	.long 258
sh3:	.long 259
sh4:	.long 260
sh5:	.long 261
sh6:	.long 262
sh7:	.long 263
sh8:	.long 264
	.explicit
	.pred.safe_across_calls p1-p5,p16-p63
	/* Force .text aligned to 4K, so it very likely gets at 0x1000.  */
	.text
	.balign	4096
	.globl	fn1#
	.proc	fn1#
fn1:
	.prologue 12, 33
	.mib
	.save	ar.pfs, r34
	alloc	r34 = ar.pfs, 0, 3, 2, 0
	.save	rp, r33
	mov	r33 = b0
 
	/* GD */
	addl	r14 = @ltoff(@dtpmod(sg1#)), gp
	addl	r15 = @ltoff(@dtprel(sg1#)), gp
	;;
	ld8	out0 = [r14]
	ld8	out1 = [r15]
	br.call.sptk.many b0 = __tls_get_addr#
	;;
 
	/* GD against hidden symbol */
	addl	r14 = @ltoff(@dtpmod(sh2#)), gp
	addl	r15 = @ltoff(@dtprel(sh2#)), gp
	;;
	ld8	out0 = [r14]
	ld8	out1 = [r15]
	br.call.sptk.many b0 = __tls_get_addr#
	;;
 
	/* LD */
	addl	r14 = @ltoff(@dtpmod(sl1#)), gp
	addl	out1 = @dtprel(sl1#) + 1, r0
	;;
	ld8	out0 = [r14]
	br.call.sptk.many b0 = __tls_get_addr#
	;;
 
	/* LD with 4 variables variables */
	addl	r14 = @ltoff(@dtpmod(sh1#)), gp
	mov	out1 = r0
	;;
	ld8	out0 = [r14]
	br.call.sptk.many b0 = __tls_get_addr#
	;;
	mov	r2 = r8
	;;
	addl	r14 = @dtprel(sh1#), r2
	addl	r15 = @dtprel(sH1#) + 2, r2
	;;
	adds	r14 = @dtprel(sh5#) + 3, r8
	movl	r15 = @dtprel(sH5#) + 1
	;;
	add	r15 = r15, r8
	;;
 
	/* IE against global */
	addl	r14 = @ltoff(@tprel(sg2#)), gp
	;;
	ld8	r15 = [r14]
	;;
	add	r14 = r15, r13
	;;
 
	/* IE against local and hidden */
	addl	r14 = @ltoff(@tprel(sl2#)), gp
	addl	r15 = @ltoff(@tprel(sh2#)), gp
	;;
	ld8	r14 = [r14]
	ld8	r15 = [r15]
	;;
	add	r14 = r14, r13
	add	r15 = r15, r13
	;;
 
	mov	ar.pfs = r34
	mov	b0 = r33
	br.ret.sptk.many b0
	.endp	fn1#
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.