mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-12-09 04:21:49 +08:00
Allow MOVK for R_AARCH64_TLSLE_MOVW_TPREL_G{0,1}NC
bfd/ PR gas/17843 * elfxx-aarch64.c (_bfd_aarch64_elf_put_addend): Expect R_AARCH64_TLSLE_MOVW_TPREL_G0_NC and R_AARCH64_TLSLE_MOVW_TPREL_G1_NC to be used with MOVK rather than MOVZ. gas/ PR gas/17843 * config/tc-aarch64.c (process_movw_reloc_info): Allow R_AARCH64_TLSLE_MOVW_TPREL_G0_NC and R_AARCH64_TLSLE_MOVW_TPREL_G1_NC for MOVK. gas/testsuite/ PR gas/17843 * gas/aarch64/tls.s, gas/aarch64/tls.d: Add test for R_AARCH64_TLSLE_MOVW_TPREL_G0/R_AARCH64_TLSLE_MOVW_TPREL_G1_NC sequence. ld/testsuite/ PR gas/17843 * ld-aarch64/tlsle.s, ld-aarch64/tlsle.d: New test. * ld-aarch64/aarch64-elf.exp: Run it.
This commit is contained in:
parent
bb3d65e427
commit
e09ab7ac78
@ -1,3 +1,10 @@
|
||||
2015-03-04 Richard Sandiford <richard.sandiford@arm.com>
|
||||
|
||||
PR gas/17843
|
||||
* elfxx-aarch64.c (_bfd_aarch64_elf_put_addend): Expect
|
||||
R_AARCH64_TLSLE_MOVW_TPREL_G0_NC and R_AARCH64_TLSLE_MOVW_TPREL_G1_NC
|
||||
to be used with MOVK rather than MOVZ.
|
||||
|
||||
2015-03-03 DJ Delorie <dj@redhat.com>
|
||||
|
||||
* elf32-rl78.c (rl78_elf_relax_section): Only relax ADDR16's if
|
||||
|
@ -304,9 +304,7 @@ _bfd_aarch64_elf_put_addend (bfd *abfd,
|
||||
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G2:
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1:
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1_NC:
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0:
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0_NC:
|
||||
case BFD_RELOC_AARCH64_MOVW_G0_S:
|
||||
case BFD_RELOC_AARCH64_MOVW_G1_S:
|
||||
case BFD_RELOC_AARCH64_MOVW_G2_S:
|
||||
@ -327,6 +325,8 @@ _bfd_aarch64_elf_put_addend (bfd *abfd,
|
||||
/* Group relocations to create a 16, 32, 48 or 64 bit unsigned
|
||||
data or abs address inline. */
|
||||
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0_NC:
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1_NC:
|
||||
case BFD_RELOC_AARCH64_MOVW_G0:
|
||||
case BFD_RELOC_AARCH64_MOVW_G0_NC:
|
||||
case BFD_RELOC_AARCH64_MOVW_G1:
|
||||
|
@ -1,3 +1,10 @@
|
||||
2015-03-04 Richard Sandiford <richard.sandiford@arm.com>
|
||||
|
||||
PR gas/17843
|
||||
* config/tc-aarch64.c (process_movw_reloc_info): Allow
|
||||
R_AARCH64_TLSLE_MOVW_TPREL_G0_NC and R_AARCH64_TLSLE_MOVW_TPREL_G1_NC
|
||||
for MOVK.
|
||||
|
||||
2015-02-28 Alan Modra <amodra@gmail.com>
|
||||
|
||||
* write.c (SUB_SEGMENT_ALIGN): Don't pad non-code sections at
|
||||
|
@ -4520,9 +4520,7 @@ process_movw_reloc_info (void)
|
||||
case BFD_RELOC_AARCH64_MOVW_G1_S:
|
||||
case BFD_RELOC_AARCH64_MOVW_G2_S:
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0:
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G0_NC:
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1:
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G1_NC:
|
||||
case BFD_RELOC_AARCH64_TLSLE_MOVW_TPREL_G2:
|
||||
set_syntax_error
|
||||
(_("the specified relocation type is not allowed for MOVK"));
|
||||
|
@ -1,3 +1,10 @@
|
||||
2015-03-04 Richard Sandiford <richard.sandiford@arm.com>
|
||||
|
||||
PR gas/17843
|
||||
* gas/aarch64/tls.s, gas/aarch64/tls.d: Add test for
|
||||
R_AARCH64_TLSLE_MOVW_TPREL_G0/R_AARCH64_TLSLE_MOVW_TPREL_G1_NC
|
||||
sequence.
|
||||
|
||||
2015-02-28 Alan Modra <amodra@gmail.com>
|
||||
|
||||
* gas/sparc/pcrel.d: Update for changed padding in data sections.
|
||||
|
@ -31,3 +31,7 @@ Disassembly of section \.text:
|
||||
2c: R_AARCH64_TLSLE_ADD_TPREL_HI12 var
|
||||
30: 91000020 add x0, x1, #0x0
|
||||
30: R_AARCH64_TLSLE_ADD_TPREL_LO12_NC var
|
||||
34: d2a00000 movz x0, #0x0, lsl #16
|
||||
34: R_AARCH64_TLSLE_MOVW_TPREL_G1 var
|
||||
38: f2800000 movk x0, #0x0
|
||||
38: R_AARCH64_TLSLE_MOVW_TPREL_G0_NC var
|
||||
|
@ -51,3 +51,6 @@ func:
|
||||
add x0, x1, #:tprel_hi12:var, lsl #12
|
||||
// R_AARCH64_TLSLE_ADD_TPREL_LO12_NC var
|
||||
add x0, x1, #:tprel_lo12_nc:var
|
||||
|
||||
movz x0, #:tprel_g1:var
|
||||
movk x0, #:tprel_g0_nc:var
|
||||
|
@ -1,3 +1,9 @@
|
||||
2015-03-04 Richard Sandiford <richard.sandiford@arm.com>
|
||||
|
||||
PR gas/17843
|
||||
* ld-aarch64/tlsle.s, ld-aarch64/tlsle.d: New test.
|
||||
* ld-aarch64/aarch64-elf.exp: Run it.
|
||||
|
||||
2015-02-28 Alan Modra <amodra@gmail.com>
|
||||
|
||||
* ld-sparc/gotop32.rd: Update for changed padding in data sections.
|
||||
|
@ -131,6 +131,7 @@ run_dump_test "tls-tiny-desc"
|
||||
run_dump_test "tls-tiny-desc-ie"
|
||||
run_dump_test "tls-tiny-desc-le"
|
||||
run_dump_test "tls-tiny-ie"
|
||||
run_dump_test "tlsle"
|
||||
run_dump_test "tlsle-symbol-offset"
|
||||
run_dump_test "gc-got-relocs"
|
||||
run_dump_test "gc-tls-relocs"
|
||||
|
73
ld/testsuite/ld-aarch64/tlsle.d
Normal file
73
ld/testsuite/ld-aarch64/tlsle.d
Normal file
@ -0,0 +1,73 @@
|
||||
#source: tlsle.s
|
||||
#ld: -shared -T relocs.ld -e0
|
||||
#objdump: -dr
|
||||
|
||||
.*: .*
|
||||
|
||||
Disassembly of section .text:
|
||||
|
||||
0+10000 <.text>:
|
||||
+10000: d2a00000 movz x0, #0x0, lsl #16
|
||||
+10004: f2800200 movk x0, #0x10
|
||||
+10008: d2a00000 movz x0, #0x0, lsl #16
|
||||
+1000c: f28fffe0 movk x0, #0x7fff
|
||||
+10010: d2a00000 movz x0, #0x0, lsl #16
|
||||
+10014: f2900000 movk x0, #0x8000
|
||||
+10018: d2a00000 movz x0, #0x0, lsl #16
|
||||
+1001c: f29fffe0 movk x0, #0xffff
|
||||
+10020: d2a00020 mov x0, #0x10000 // #65536
|
||||
+10024: f2800000 movk x0, #0x0
|
||||
+10028: d2afffe0 mov x0, #0x7fff0000 // #2147418112
|
||||
+1002c: f29fffe0 movk x0, #0xffff
|
||||
+10030: d2b00000 mov x0, #0x80000000 // #2147483648
|
||||
+10034: f2800000 movk x0, #0x0
|
||||
+10038: d2bfffe0 mov x0, #0xffff0000 // #4294901760
|
||||
+1003c: f2800000 movk x0, #0x0
|
||||
+10040: d2bfffe0 mov x0, #0xffff0000 // #4294901760
|
||||
+10044: f29fffe0 movk x0, #0xffff
|
||||
+10048: d2c00000 movz x0, #0x0, lsl #32
|
||||
+1004c: f2a00000 movk x0, #0x0, lsl #16
|
||||
+10050: f2800200 movk x0, #0x10
|
||||
+10054: d2c00000 movz x0, #0x0, lsl #32
|
||||
+10058: f2a00000 movk x0, #0x0, lsl #16
|
||||
+1005c: f28fffe0 movk x0, #0x7fff
|
||||
+10060: d2c00000 movz x0, #0x0, lsl #32
|
||||
+10064: f2a00000 movk x0, #0x0, lsl #16
|
||||
+10068: f2900000 movk x0, #0x8000
|
||||
+1006c: d2c00000 movz x0, #0x0, lsl #32
|
||||
+10070: f2a00000 movk x0, #0x0, lsl #16
|
||||
+10074: f29fffe0 movk x0, #0xffff
|
||||
+10078: d2c00000 movz x0, #0x0, lsl #32
|
||||
+1007c: f2a00020 movk x0, #0x1, lsl #16
|
||||
+10080: f2800000 movk x0, #0x0
|
||||
+10084: d2c00000 movz x0, #0x0, lsl #32
|
||||
+10088: f2afffe0 movk x0, #0x7fff, lsl #16
|
||||
+1008c: f29fffe0 movk x0, #0xffff
|
||||
+10090: d2c00000 movz x0, #0x0, lsl #32
|
||||
+10094: f2b00000 movk x0, #0x8000, lsl #16
|
||||
+10098: f2800000 movk x0, #0x0
|
||||
+1009c: d2c00000 movz x0, #0x0, lsl #32
|
||||
+100a0: f2bfffe0 movk x0, #0xffff, lsl #16
|
||||
+100a4: f2800000 movk x0, #0x0
|
||||
+100a8: d2c00000 movz x0, #0x0, lsl #32
|
||||
+100ac: f2bfffe0 movk x0, #0xffff, lsl #16
|
||||
+100b0: f29fffe0 movk x0, #0xffff
|
||||
+100b4: d2c00020 mov x0, #0x100000000 // #4294967296
|
||||
+100b8: f2a00000 movk x0, #0x0, lsl #16
|
||||
+100bc: f2824660 movk x0, #0x1233
|
||||
+100c0: d2c24680 mov x0, #0x123400000000 // #20014547599360
|
||||
+100c4: f2aacf00 movk x0, #0x5678, lsl #16
|
||||
+100c8: f2921560 movk x0, #0x90ab
|
||||
+100cc: d2c24680 mov x0, #0x123400000000 // #20014547599360
|
||||
+100d0: f2bfffe0 movk x0, #0xffff, lsl #16
|
||||
+100d4: f2800000 movk x0, #0x0
|
||||
+100d8: d2c24680 mov x0, #0x123400000000 // #20014547599360
|
||||
+100dc: f2bfffe0 movk x0, #0xffff, lsl #16
|
||||
+100e0: f29fffc0 movk x0, #0xfffe
|
||||
+100e4: d2d00000 mov x0, #0x800000000000 // #140737488355328
|
||||
+100e8: f2a00000 movk x0, #0x0, lsl #16
|
||||
+100ec: f2800020 movk x0, #0x1
|
||||
+100f0: d2dfffe0 mov x0, #0xffff00000000 // #281470681743360
|
||||
+100f4: f2bfffe0 movk x0, #0xffff, lsl #16
|
||||
+100f8: f29fffe0 movk x0, #0xffff
|
||||
+100fc: d65f03c0 ret
|
98
ld/testsuite/ld-aarch64/tlsle.s
Normal file
98
ld/testsuite/ld-aarch64/tlsle.s
Normal file
@ -0,0 +1,98 @@
|
||||
.section .tbss,"awT",%nobits
|
||||
a10:
|
||||
.zero 0x7fef
|
||||
a7fff:
|
||||
.zero 0x1
|
||||
a8000:
|
||||
.zero 0x7fff
|
||||
affff:
|
||||
.zero 0x1
|
||||
a10000:
|
||||
.zero 0x7ffeffff
|
||||
a7fffffff:
|
||||
.zero 0x1
|
||||
a80000000:
|
||||
.zero 0x7fff0000
|
||||
affff0000:
|
||||
.zero 0x0000ffff
|
||||
affffffff:
|
||||
.zero 0x1234
|
||||
a100001233:
|
||||
.zero 0x123356787e78
|
||||
a1234567890ab:
|
||||
.zero 0xa9866f55
|
||||
a1234ffff0000:
|
||||
.zero 0xfffe
|
||||
a1234fffffffe:
|
||||
.zero 0x6dcb00000003
|
||||
a800000000001:
|
||||
.zero 0x7ffffffffffe
|
||||
affffffffffff:
|
||||
.zero 0x1234
|
||||
|
||||
.text
|
||||
movz x0, #:tprel_g1:a10
|
||||
movk x0, #:tprel_g0_nc:a10
|
||||
movz x0, #:tprel_g1:a7fff
|
||||
movk x0, #:tprel_g0_nc:a7fff
|
||||
movz x0, #:tprel_g1:a8000
|
||||
movk x0, #:tprel_g0_nc:a8000
|
||||
movz x0, #:tprel_g1:affff
|
||||
movk x0, #:tprel_g0_nc:affff
|
||||
movz x0, #:tprel_g1:a10000
|
||||
movk x0, #:tprel_g0_nc:a10000
|
||||
movz x0, #:tprel_g1:a7fffffff
|
||||
movk x0, #:tprel_g0_nc:a7fffffff
|
||||
movz x0, #:tprel_g1:a80000000
|
||||
movk x0, #:tprel_g0_nc:a80000000
|
||||
movz x0, #:tprel_g1:affff0000
|
||||
movk x0, #:tprel_g0_nc:affff0000
|
||||
movz x0, #:tprel_g1:affffffff
|
||||
movk x0, #:tprel_g0_nc:affffffff
|
||||
|
||||
movz x0, #:tprel_g2:a10
|
||||
movk x0, #:tprel_g1_nc:a10
|
||||
movk x0, #:tprel_g0_nc:a10
|
||||
movz x0, #:tprel_g2:a7fff
|
||||
movk x0, #:tprel_g1_nc:a7fff
|
||||
movk x0, #:tprel_g0_nc:a7fff
|
||||
movz x0, #:tprel_g2:a8000
|
||||
movk x0, #:tprel_g1_nc:a8000
|
||||
movk x0, #:tprel_g0_nc:a8000
|
||||
movz x0, #:tprel_g2:affff
|
||||
movk x0, #:tprel_g1_nc:affff
|
||||
movk x0, #:tprel_g0_nc:affff
|
||||
movz x0, #:tprel_g2:a10000
|
||||
movk x0, #:tprel_g1_nc:a10000
|
||||
movk x0, #:tprel_g0_nc:a10000
|
||||
movz x0, #:tprel_g2:a7fffffff
|
||||
movk x0, #:tprel_g1_nc:a7fffffff
|
||||
movk x0, #:tprel_g0_nc:a7fffffff
|
||||
movz x0, #:tprel_g2:a80000000
|
||||
movk x0, #:tprel_g1_nc:a80000000
|
||||
movk x0, #:tprel_g0_nc:a80000000
|
||||
movz x0, #:tprel_g2:affff0000
|
||||
movk x0, #:tprel_g1_nc:affff0000
|
||||
movk x0, #:tprel_g0_nc:affff0000
|
||||
movz x0, #:tprel_g2:affffffff
|
||||
movk x0, #:tprel_g1_nc:affffffff
|
||||
movk x0, #:tprel_g0_nc:affffffff
|
||||
movz x0, #:tprel_g2:a100001233
|
||||
movk x0, #:tprel_g1_nc:a100001233
|
||||
movk x0, #:tprel_g0_nc:a100001233
|
||||
movz x0, #:tprel_g2:a1234567890ab
|
||||
movk x0, #:tprel_g1_nc:a1234567890ab
|
||||
movk x0, #:tprel_g0_nc:a1234567890ab
|
||||
movz x0, #:tprel_g2:a1234ffff0000
|
||||
movk x0, #:tprel_g1_nc:a1234ffff0000
|
||||
movk x0, #:tprel_g0_nc:a1234ffff0000
|
||||
movz x0, #:tprel_g2:a1234fffffffe
|
||||
movk x0, #:tprel_g1_nc:a1234fffffffe
|
||||
movk x0, #:tprel_g0_nc:a1234fffffffe
|
||||
movz x0, #:tprel_g2:a800000000001
|
||||
movk x0, #:tprel_g1_nc:a800000000001
|
||||
movk x0, #:tprel_g0_nc:a800000000001
|
||||
movz x0, #:tprel_g2:affffffffffff
|
||||
movk x0, #:tprel_g1_nc:affffffffffff
|
||||
movk x0, #:tprel_g0_nc:affffffffffff
|
||||
ret
|
Loading…
Reference in New Issue
Block a user