summaryrefslogtreecommitdiff
path: root/stand
diff options
context:
space:
mode:
authorAndrew Turner <andrew@FreeBSD.org>2020-10-13 16:51:05 +0000
committerAndrew Turner <andrew@FreeBSD.org>2020-10-13 16:51:05 +0000
commitb9aa4537b2155a0b0bb419ff05b8da206c02bfbd (patch)
tree0ade48ac98c68640dd4c9b8cd10bbacc133e961d /stand
parentd524c46fb85b7fc28ad15814f01600573e7a6990 (diff)
downloadsrc-test-b9aa4537b2155a0b0bb419ff05b8da206c02bfbd.tar.gz
src-test-b9aa4537b2155a0b0bb419ff05b8da206c02bfbd.zip
Use adrp in the arm64 efi loader
On startup the arm64 efi loaders need to know PC-relative addresses. Previously we used the adr instruction to find this address, however this instruction is limited to +/- 1MiB. Switch to adrp to find the 4k page the address is within and an add to set the bottom 12 bits. This lets us address +/- 4GiB which should be large enough for now. Reported by: imp MFC after: 2 weeks Sponsored by: Innovate UK
Notes
Notes: svn path=/head/; revision=366670
Diffstat (limited to 'stand')
-rw-r--r--stand/efi/loader/arch/arm64/start.S15
1 files changed, 10 insertions, 5 deletions
diff --git a/stand/efi/loader/arch/arm64/start.S b/stand/efi/loader/arch/arm64/start.S
index bddc2d088a645..675d4e153f360 100644
--- a/stand/efi/loader/arch/arm64/start.S
+++ b/stand/efi/loader/arch/arm64/start.S
@@ -142,8 +142,10 @@ _start:
/* Save the boot params to the stack */
stp x0, x1, [sp, #-16]!
- adr x0, __bss_start
- adr x1, __bss_end
+ adrp x0, __bss_start
+ add x0, x0, :lo12:__bss_start
+ adrp x1, __bss_end
+ add x1, x1, :lo12:__bss_end
b 2f
@@ -153,8 +155,10 @@ _start:
cmp x0, x1
b.lo 1b
- adr x0, ImageBase
- adr x1, _DYNAMIC
+ adrp x0, ImageBase
+ add x0, x0, :lo12:ImageBase
+ adrp x1, _DYNAMIC
+ add x1, x1, :lo12:_DYNAMIC
bl self_reloc
@@ -165,7 +169,8 @@ _start:
* Load the stack to use. The default stack may be too small for
* the lua loader.
*/
- adr x2, initstack_end
+ adrp x2, initstack_end
+ add x2, x2, :lo12:initstack_end
mov sp, x2
#endif