diff options
author | Jakub Jelinek <jakub@redhat.com> | 2003-01-16 21:31:18 +0000 |
---|---|---|
committer | Jakub Jelinek <jakub@redhat.com> | 2003-01-16 21:31:18 +0000 |
commit | b3dfd7fe24f18648d4cc8e044219a734c9a82fc1 (patch) | |
tree | 08c43a53da426285393a789b044d9e65577ab41b /ld/testsuite/ld-ia64/tlsbinpic.s | |
parent | 837fd61c26f79a84459b9d12ad1e8838c048cd33 (diff) | |
download | binutils-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.s | 96 |
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# |