binutils-gdb/ld/testsuite/ld-ia64/tlspic1.s
Jan Beulich f1dab70d1a gas/
2005-02-13  Jan Beulich  <jbeulich@novell.com>

	* config/tc-ia64.c (md_parse_option): Handle -xnone and -xdebugn.
	(md_show_usage): Add -xnone, -xdebugn, and -xdebugx. Relocate default
	indicator.
	(ia64_init): Set md.detect_dv.
	(ia64_start_line): New static variable warned. Warn only once when
	encountering explicit stops in automatic mode.
	* doc/c-ia64.texi: Describe -xnone, -xdebugn, and -xdebugx.
	* NEWS: Mention new default mode.

gas/testsuite/
2005-02-13  Jan Beulich  <jbeulich@novell.com>

	* gas/ia64/label.l: Adjust line numbers.
	* gas/ia64/label.s: Add .explicit.
	* gas/ia64/nop_x.s: Likewise.
	* gas/ia64/opc-a.d: Add assembler option -xnone.
	* gas/ia64/opc-b.d: Likewise.
	* gas/ia64/opc-f.d: Likewise.
	* gas/ia64/opc-i.d: Likewise.
	* gas/ia64/opc-m.d: Likewise.
	* gas/ia64/opc-x.d: Likewise.
	* gas/ia64/pseudo.d: Likewise.
	* gas/ia64/regs.d: Likewise.
	* gas/ia64/tls.d: Likewise.
	* gas/ia64/unwind-err.l: Adjust line numbers.
	* gas/ia64/unwind-err.s: Remove explicit stops.

ld/testsuite/
2005-02-13  Jan Beulich  <jbeulich@novell.com>

	* ld-elfvers/vers.exp (as_options): New. Set to -x for ia64.
	(build_binary): Pass as_options to ld_assemble.
	(test_ldfail): Likewise.
	(build_exec): Likewise.
	Pass as_options to run_ld_link_tests.
	* ld-ia64/tlsbin.s: Add .explicit.
	* ld-ia64/tlsbinpic.s: Likewise.
	* ld-ia64/tlspic1.s: Likewise.
2005-02-14 08:02:51 +00:00

115 lines
2.1 KiB
ArmAsm

/* 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#