File: ELF_LoongArch_relocations.s

package info (click to toggle)
llvm-toolchain-20 1%3A20.1.8-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 2,111,696 kB
  • sloc: cpp: 7,438,781; ansic: 1,393,871; asm: 1,012,926; python: 241,771; f90: 86,635; objc: 75,411; lisp: 42,144; pascal: 17,286; sh: 8,596; ml: 5,082; perl: 4,730; makefile: 3,591; awk: 3,523; javascript: 2,251; xml: 892; fortran: 672
file content (102 lines) | stat: -rw-r--r-- 3,225 bytes parent folder | download | duplicates (5)
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