2 # RUN: llvm-mc -filetype=obj -triple=hexagon-unknown-elf %s -o %t.o
3 # RUN: llvm-readobj -r %t.o | FileCheck -check-prefix=RELOC %s
4 # RUN: ld.lld %t.o -o %t
5 # RUN: ld.lld -shared %t.o -o %t.so
6 # RUN: llvm-objdump -d --no-show-raw-insn --print-imm-hex %t | FileCheck %s
7 # RUN: llvm-objdump -d --no-show-raw-insn --print-imm-hex %t.so | FileCheck %s
8 # RUN: llvm-readobj -x .got %t | FileCheck -check-prefix=GOT %s
9 # RUN: llvm-readobj -x .got %t.so | FileCheck -check-prefix=GOT-SHARED %s
10 # RUN: llvm-readobj -x .tdata %t | FileCheck -check-prefix=TDATA %s
11 # RUN: llvm-readobj -x .tdata %t.so | FileCheck -check-prefix=TDATA %s
12 # RUN: llvm-readobj -r %t | FileCheck -check-prefix=RELA %s
13 # RUN: llvm-readobj -r %t.so | FileCheck -check-prefix=RELA-SHARED %s
16 .type _start, @function
19 # RELOC: 0x0 R_HEX_GD_GOT_32_6_X a 0x0
20 # RELOC-NEXT: 0x4 R_HEX_GD_GOT_16_X a 0x0
21 # CHECK: { immext(#0xfffeffc0)
22 # CHECK-NEXT: r0 = add(r1,##-0x10008) }
23 r0 = add(r1, ##a@GDGOT)
25 # RELOC: 0x8 R_HEX_GD_GOT_32_6_X a 0x0
26 # RELOC-NEXT: 0xC R_HEX_GD_GOT_11_X a 0x0
27 # CHECK-NEXT: { immext(#0xfffeffc0)
28 # CHECK-NEXT: r0 = memw(r1+##-0x10008) }
29 r0 = memw
(r1+
##a@GDGOT)
31 # GOT: Hex dump of section '.got':
32 # GOT-NEXT: 0x{{[0-9a-f]+}} 01000000 00000000
34 # GOT-SHARED: Hex dump of section '.got':
35 # GOT-SHARED-NEXT: 0x{{[0-9a-f]+}} 00000000 00000000
37 # TDATA: Hex dump of section '.tdata':
38 # TDATA-NEXT: 01000000
43 # RELA-SHARED: .rela.dyn {
44 # RELA-SHARED-NEXT: 0x2024C R_HEX_DTPMOD_32 a 0x0
45 # RELA-SHARED-NEXT: 0x20250 R_HEX_DTPREL_32 a 0x0
48 .section .tdata,"awT",@progbits