aboutsummaryrefslogtreecommitdiff
path: root/ld/testsuite/ld-ia64/tlsbinpic.s
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2003-01-16 21:31:18 +0000
committerJakub Jelinek <jakub@redhat.com>2003-01-16 21:31:18 +0000
commitb3dfd7fe24f18648d4cc8e044219a734c9a82fc1 (patch)
tree08c43a53da426285393a789b044d9e65577ab41b /ld/testsuite/ld-ia64/tlsbinpic.s
parent837fd61c26f79a84459b9d12ad1e8838c048cd33 (diff)
downloadbinutils-b3dfd7fe24f18648d4cc8e044219a734c9a82fc1.zip
binutils-b3dfd7fe24f18648d4cc8e044219a734c9a82fc1.tar.gz
binutils-b3dfd7fe24f18648d4cc8e044219a734c9a82fc1.tar.bz2
* elfxx-ia64.c (struct elfNN_ia64_link_hash_table): Add
self_dtpmod_done and self_dtpmod_offset. (allocate_global_data_got): Only use one got entry for all dtpmod relocs against local symbols. (allocate_dynrel_entries): Only need .rela.got entry for dtpmod against global symbol. (elfNN_ia64_size_dynamic_sections): Initialize self_dtpmod_offset. Reserve space in .rela.got for the local dtpmod entry. (set_got_entry): Initialize the common local dtpmod .got entry. (elfNN_ia64_relocate_section): Handle R_IA_64_DTPREL64LSB and R_IA_64_DTPREL64MSB. * config/tc-ia64.c (ia64_cons_fix_new): Handle @dtprel() in data. * ld-ia64/ia64.exp: New. * ld-ia64/tlsbin.dd: New test. * ld-ia64/tlsbinpic.s: New test. * ld-ia64/tlsbin.rd: New test. * ld-ia64/tlsbin.s: New test. * ld-ia64/tlsbin.sd: New test. * ld-ia64/tlsbin.td: New test. * ld-ia64/tlsg.s: New test. * ld-ia64/tlsg.sd: New test. * ld-ia64/tlslib.s: New test. * ld-ia64/tlspic1.s: New test. * ld-ia64/tlspic2.s: New test. * ld-ia64/tlspic.dd: New test. * ld-ia64/tlspic.rd: New test. * ld-ia64/tlspic.sd: New test. * ld-ia64/tlspic.td: New test.
Diffstat (limited to 'ld/testsuite/ld-ia64/tlsbinpic.s')
-rw-r--r--ld/testsuite/ld-ia64/tlsbinpic.s96
1 files changed, 96 insertions, 0 deletions
diff --git a/ld/testsuite/ld-ia64/tlsbinpic.s b/ld/testsuite/ld-ia64/tlsbinpic.s
new file mode 100644
index 0000000..88a0543
--- /dev/null
+++ b/ld/testsuite/ld-ia64/tlsbinpic.s
@@ -0,0 +1,96 @@
+ /* Force .data aligned to 4K, so that .got very likely gets at
+ 0x60000000000031b0 (0x60 bytes .tdata and 0x150 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
+ /* Force .text aligned to 4K, so it very likely gets at
+ 0x4000000000001000. */
+ .pred.safe_across_calls p1-p5,p16-p63
+ .text
+ .balign 4096
+ .globl fn2#
+ .proc fn2#
+fn2:
+ .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 local symbol */
+ addl r14 = @ltoff(@dtpmod(sl2#)), gp
+ addl r15 = @ltoff(@dtprel(sl2#)), 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(sh2#) + 2, r2
+ ;;
+ adds r14 = @dtprel(sh3#) + 3, r8
+ movl r15 = @dtprel(sh4#) + 1
+ ;;
+ add r15 = r15, r8
+ ;;
+
+ mov ar.pfs = r34
+ mov b0 = r33
+ br.ret.sptk.many b0
+ .endp fn2#