| ;%HEADER% | |
| ;/** @file | |
| ; Macros to work around lack of Apple support for LDR register, =expr | |
| ; | |
| ; Copyright (c) 2009, Apple Inc. All rights reserved.<BR> | |
| ; Copyright (c) 2011-2012, ARM Ltd. All rights reserved.<BR> | |
| ; | |
| ; SPDX-License-Identifier: BSD-2-Clause-Patent | |
| ; | |
| ;**/ | |
| MACRO | |
| adrll $Reg, $Symbol | |
| add $Reg, pc, #-8 | |
| RELOC R_ARM_ALU_PC_G0_NC, $Symbol | |
| add $Reg, $Reg, #-4 | |
| RELOC R_ARM_ALU_PC_G1_NC, $Symbol | |
| add $Reg, $Reg, #0 | |
| RELOC R_ARM_ALU_PC_G2, $Symbol | |
| MEND | |
| MACRO | |
| ldrl $Reg, $Symbol | |
| add $Reg, pc, #-8 | |
| RELOC R_ARM_ALU_PC_G0_NC, $Symbol | |
| add $Reg, $Reg, #-4 | |
| RELOC R_ARM_ALU_PC_G1_NC, $Symbol | |
| ldr $Reg, [$Reg, #0] | |
| RELOC R_ARM_LDR_PC_G2, $Symbol | |
| MEND | |
| END |