blob: 16a34f188f2672d01298b42cc7385da6c78bc14b [file] [log] [blame]
b.liue9582032025-04-17 19:18:16 +08001/* SPDX-License-Identifier: GPL-2.0-only */
2/*
3 * Copyright (C) 2017 Linaro, Ltd. <ard.biesheuvel@linaro.org>
4 */
5
6#include <linux/linkage.h>
7
8ENTRY(absolute_data64)
9 ldr x0, 0f
10 ret
110: .quad sym64_abs
12ENDPROC(absolute_data64)
13
14ENTRY(absolute_data32)
15 ldr w0, 0f
16 ret
170: .long sym32_abs
18ENDPROC(absolute_data32)
19
20ENTRY(absolute_data16)
21 adr x0, 0f
22 ldrh w0, [x0]
23 ret
240: .short sym16_abs, 0
25ENDPROC(absolute_data16)
26
27ENTRY(signed_movw)
28 movz x0, #:abs_g2_s:sym64_abs
29 movk x0, #:abs_g1_nc:sym64_abs
30 movk x0, #:abs_g0_nc:sym64_abs
31 ret
32ENDPROC(signed_movw)
33
34ENTRY(unsigned_movw)
35 movz x0, #:abs_g3:sym64_abs
36 movk x0, #:abs_g2_nc:sym64_abs
37 movk x0, #:abs_g1_nc:sym64_abs
38 movk x0, #:abs_g0_nc:sym64_abs
39 ret
40ENDPROC(unsigned_movw)
41
42 .align 12
43 .space 0xff8
44ENTRY(relative_adrp)
45 adrp x0, sym64_rel
46 add x0, x0, #:lo12:sym64_rel
47 ret
48ENDPROC(relative_adrp)
49
50 .align 12
51 .space 0xffc
52ENTRY(relative_adrp_far)
53 adrp x0, memstart_addr
54 add x0, x0, #:lo12:memstart_addr
55 ret
56ENDPROC(relative_adrp_far)
57
58ENTRY(relative_adr)
59 adr x0, sym64_rel
60 ret
61ENDPROC(relative_adr)
62
63ENTRY(relative_data64)
64 adr x1, 0f
65 ldr x0, [x1]
66 add x0, x0, x1
67 ret
680: .quad sym64_rel - .
69ENDPROC(relative_data64)
70
71ENTRY(relative_data32)
72 adr x1, 0f
73 ldr w0, [x1]
74 add x0, x0, x1
75 ret
760: .long sym64_rel - .
77ENDPROC(relative_data32)
78
79ENTRY(relative_data16)
80 adr x1, 0f
81 ldrsh w0, [x1]
82 add x0, x0, x1
83 ret
840: .short sym64_rel - ., 0
85ENDPROC(relative_data16)