summaryrefslogtreecommitdiff
path: root/arch/arm/cpu/armv7
diff options
context:
space:
mode:
authorMark Kettenis <kettenis@openbsd.org>2018-06-16 00:47:11 +0300
committerAlexander Graf <agraf@suse.de>2018-07-25 15:57:43 +0300
commit907ee2945e78c66aaefabaabada4d092fd8e3d58 (patch)
tree10c723b1a3ee86e266d1fc5fbba4777d4742fc55 /arch/arm/cpu/armv7
parentf260bd30e8f5651d81665aa68c090b415ef566e7 (diff)
downloadu-boot-907ee2945e78c66aaefabaabada4d092fd8e3d58.tar.xz
ARM: HYP/non-sec: migrate stack
The current code that switches into HYP mode doesn't bother to set up a stack for HYP mode. This doesn't work for EFI applications as they expect a usable stack. Fix this by migrating the stack pointer from SP_svc to SP_hyp while in Monitor mode. This restores the stack pointer when we drop into HYP mode. Signed-off-by: Mark Kettenis <kettenis@openbsd.org> Signed-off-by: Alexander Graf <agraf@suse.de>
Diffstat (limited to 'arch/arm/cpu/armv7')
-rw-r--r--arch/arm/cpu/armv7/nonsec_virt.S2
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/arm/cpu/armv7/nonsec_virt.S b/arch/arm/cpu/armv7/nonsec_virt.S
index 56bdba1d38..1773fae205 100644
--- a/arch/arm/cpu/armv7/nonsec_virt.S
+++ b/arch/arm/cpu/armv7/nonsec_virt.S
@@ -80,6 +80,8 @@ _secure_monitor:
#ifdef CONFIG_ARMV7_VIRT
orreq r5, r5, #0x100 @ allow HVC instruction
moveq r6, #HYP_MODE @ Enter the kernel as HYP
+ mrseq r3, sp_svc
+ msreq sp_hyp, r3 @ migrate SP
#endif
mcr p15, 0, r5, c1, c1, 0 @ write SCR (with NS bit set)