| ;%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> | |
| ; | |
| ; This program and the accompanying materials | |
| ; are licensed and made available under the terms and conditions of the BSD License | |
| ; which accompanies this distribution. The full text of the license may be found at | |
| ; http://opensource.org/licenses/bsd-license.php | |
| ; | |
| ; THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | |
| ; WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |
| ; | |
| ;**/ | |
| 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 |