2020-01-03 00:27:05 +08:00
|
|
|
# REQUIRES: hexagon
|
|
|
|
# RUN: llvm-mc -filetype=obj -triple=hexagon-unknown-elf %s -o %t.o
|
2020-01-03 01:52:59 +08:00
|
|
|
# RUN: llvm-readobj -r %t.o | FileCheck --check-prefix=RELOC %s
|
2020-01-03 00:27:05 +08:00
|
|
|
# RUN: ld.lld %t.o -o %t
|
|
|
|
# RUN: llvm-objdump -d --print-imm-hex %t | FileCheck %s
|
|
|
|
|
|
|
|
.globl _start
|
|
|
|
.type _start, @function
|
|
|
|
_start:
|
|
|
|
r0 = ugp
|
|
|
|
|
2020-01-03 01:52:59 +08:00
|
|
|
# RELOC: 0x4 R_HEX_TPREL_32_6_X a 0x0
|
|
|
|
# RELOC-NEXT: 0x8 R_HEX_TPREL_16_X a 0x0
|
2020-01-03 00:27:05 +08:00
|
|
|
# CHECK: { immext(#0xffffffc0)
|
|
|
|
# CHECK-NEXT: r1 = add(r0,##-0x10) }
|
|
|
|
r1 = add(r0,##a@TPREL)
|
|
|
|
|
2020-01-03 01:52:59 +08:00
|
|
|
# RELOC-NEXT: 0xC R_HEX_TPREL_32_6_X a 0x0
|
|
|
|
# RELOC-NEXT: 0x10 R_HEX_TPREL_11_X a 0x0
|
2020-01-03 00:27:05 +08:00
|
|
|
# CHECK: { immext(#0xffffffc0)
|
|
|
|
# CHECK-NEXT: r2 = memw(r0+##-0x10) }
|
|
|
|
r2 = memw(r0+##a@TPREL)
|
|
|
|
|
2020-01-03 01:52:59 +08:00
|
|
|
# RELOC-NEXT: 0x14 R_HEX_TPREL_HI16 a 0x0
|
2020-01-03 00:27:05 +08:00
|
|
|
# R_HEX_TPREL_HI16
|
|
|
|
# CHECK: { r3.h = #0xffff }
|
|
|
|
r3.h = #a@TPREL
|
|
|
|
|
2020-01-03 01:52:59 +08:00
|
|
|
# RELOC-NEXT: 0x18 R_HEX_TPREL_LO16 a 0x0
|
2020-01-03 00:27:05 +08:00
|
|
|
# R_HEX_TPREL_LO16
|
|
|
|
# CHECK: { r3.l = #0xfff0 }
|
|
|
|
r3.l = #a@TPREL
|
|
|
|
|
2020-01-03 01:52:59 +08:00
|
|
|
# RELOC-NEXT: 0x1C R_HEX_TPREL_16 a 0x0
|
2020-01-03 00:27:05 +08:00
|
|
|
# CHECK: { r4 = #-0x10 }
|
|
|
|
r4 = #a@TPREL
|
|
|
|
|
|
|
|
.section .tdata,"awT",@progbits
|
|
|
|
.globl a
|
|
|
|
.p2align 2
|
|
|
|
a:
|
|
|
|
.word 1
|
|
|
|
.size a, 4
|
|
|
|
|
|
|
|
.globl b
|
|
|
|
.p2align 2
|
|
|
|
b:
|
|
|
|
.word 2
|
|
|
|
.size b, 4
|
|
|
|
|
|
|
|
.globl c
|
|
|
|
.p2align 2
|
|
|
|
c:
|
|
|
|
.word 3
|
|
|
|
.size c, 4
|
|
|
|
|
|
|
|
.globl d
|
|
|
|
.p2align 2
|
|
|
|
d:
|
|
|
|
.word 4
|
|
|
|
.size d, 4
|