/* SPDX-License-Identifier: GPL-2.0-only */ /* * Copyright (C) 2017 Linaro, Ltd. <ard.biesheuvel@linaro.org> */ #include <linux/linkage.h> ENTRY(absolute_data64) ldr x0, 0f ret 0: .quad sym64_abs ENDPROC(absolute_data64) ENTRY(absolute_data32) ldr w0, 0f ret 0: .long sym32_abs ENDPROC(absolute_data32) ENTRY(absolute_data16) adr x0, 0f ldrh w0, [x0] ret 0: .short sym16_abs, 0 ENDPROC(absolute_data16) ENTRY(signed_movw) movz x0, #:abs_g2_s:sym64_abs movk x0, #:abs_g1_nc:sym64_abs movk x0, #:abs_g0_nc:sym64_abs ret ENDPROC(signed_movw) ENTRY(unsigned_movw) movz x0, #:abs_g3:sym64_abs movk x0, #:abs_g2_nc:sym64_abs movk x0, #:abs_g1_nc:sym64_abs movk x0, #:abs_g0_nc:sym64_abs ret ENDPROC(unsigned_movw) .align 12 .space 0xff8 ENTRY(relative_adrp) adrp x0, sym64_rel add x0, x0, #:lo12:sym64_rel ret ENDPROC(relative_adrp) .align 12 .space 0xffc ENTRY(relative_adrp_far) adrp x0, memstart_addr add x0, x0, #:lo12:memstart_addr ret ENDPROC(relative_adrp_far) ENTRY(relative_adr) adr x0, sym64_rel ret ENDPROC(relative_adr) ENTRY(relative_data64) adr x1, 0f ldr x0, [x1] add x0, x0, x1 ret 0: .quad sym64_rel - . ENDPROC(relative_data64) ENTRY(relative_data32) adr x1, 0f ldr w0, [x1] add x0, x0, x1 ret 0: .long sym64_rel - . ENDPROC(relative_data32) ENTRY(relative_data16) adr x1, 0f ldrsh w0, [x1] add x0, x0, x1 ret 0: .short sym64_rel - ., 0 ENDPROC(relative_data16) |