1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
|
# RUN: rm -rf %t && mkdir -p %t
# RUN: llvm-mc --triple=loongarch64 --filetype=obj -o %t/reloc.o %s
# RUN: llvm-rtdyld --triple=loongarch64 --verify --check=%s %t/reloc.o \
# RUN: --map-section reloc.o,.got=0x21f00 \
# RUN: --dummy-extern abs=0x0123456789abcdef \
# RUN: --dummy-extern external_data=0x1234
.text
.globl main
.p2align 2
.type main,@function
main:
## Check R_LARCH_ABS_HI20
# rtdyld-check: *{4}(main) = 0x1513578c
lu12i.w $t0, %abs_hi20(abs)
## Check R_LARCH_ABS_LO12
# rtdyld-check: *{4}(main + 4) = 0x03b7bd8c
ori $t0, $t0, %abs_lo12(abs)
## Check R_LARCH_ABS64_LO20
# rtdyld-check: *{4}(main + 8) = 0x1668acec
lu32i.d $t0, %abs64_lo20(abs)
## Check R_LARCH_ABS64_HI12
# rtdyld-check: *{4}(main + 12) = 0x0300498c
lu52i.d $t0, $t0, %abs64_hi12(abs)
ret
.size main, .-main
.globl local_func
.p2align 2
.type local_func,@function
local_func:
ret
.size local_func, .-local_func
.globl local_func_call26
.p2align 2
local_func_call26:
## Check R_LARCH_B26
# rtdyld-check: decode_operand(local_func_call26, 0)[27:0] = \
# rtdyld-check: (local_func - local_func_call26)[27:0]
bl local_func
.size local_func_call26, .-local_func_call26
.globl local_func_call36
.p2align 2
local_func_call36:
## Check R_LARCH_CALL36
# rtdyld-check: decode_operand(local_func_call36, 1)[19:0] = \
# rtdyld-check: ((local_func - local_func_call36) + \
# rtdyld-check: (((local_func - local_func_call36)[17:17]) << 17))[37:18]
# rtdyld-check: decode_operand(local_func_call36 + 4, 2)[17:0] = \
# rtdyld-check: (local_func - local_func_call36)[17:0]
pcaddu18i $ra, %call36(local_func)
jirl $ra, $ra, 0
.size local_func_call36, .-local_func_call36
.globl test_pc_hi20
.p2align 2
test_pc_hi20:
## Check R_LARCH_PCALA_HI20
# rtdyld-check: decode_operand(test_pc_hi20, 1)[19:0] = \
# rtdyld-check: (named_data - test_pc_hi20)[31:12] + \
# rtdyld-check: named_data[11:11]
pcalau12i $a0, %pc_hi20(named_data)
.size test_pc_hi20, .-test_pc_hi20
.globl test_pc_lo12
.p2align 2
test_pc_lo12:
## Check R_LARCH_PCALA_LO12
# rtdyld-check: decode_operand(test_pc_lo12, 2)[11:0] = \
# rtdyld-check: (named_data)[11:0]
addi.d $a0, $a0, %pc_lo12(named_data)
.size test_pc_lo12, .-test_pc_lo12
.globl test_got_pc_hi20
.p2align 2
test_got_pc_hi20:
## Check R_LARCH_GOT_PC_HI20
# rtdyld-check: decode_operand(test_got_pc_hi20, 1)[19:0] = \
# rtdyld-check: (section_addr(reloc.o, .got)[31:12] - \
# rtdyld-check: test_got_pc_hi20[31:12] + \
# rtdyld-check: section_addr(reloc.o, .got)[11:11])
pcalau12i $a0, %got_pc_hi20(external_data)
.size test_got_pc_hi20, .-test_got_pc_hi20
.globl test_got_pc_lo12
.p2align 2
test_got_pc_lo12:
## Check R_LARCH_GOT_PC_LO12
# rtdyld-check: decode_operand(test_got_pc_lo12, 2)[11:0] = \
# rtdyld-check: (section_addr(reloc.o, .got)[11:0])
ld.d $a0, $a0, %got_pc_lo12(external_data)
.size test_gotoffset12_external, .-test_gotoffset12_external
.globl named_data
.p2align 4
.type named_data,@object
named_data:
.quad 0x2222222222222222
.quad 0x3333333333333333
.size named_data, .-named_data
|