summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorTheo de Raadt <deraadt@cvs.openbsd.org>2020-02-01 23:09:47 +0000
committerTheo de Raadt <deraadt@cvs.openbsd.org>2020-02-01 23:09:47 +0000
commit40b137a4a3fff495d35f924026ea633bb3a017ee (patch)
tree63e05a7cb2d976b88a62909b354894e1e906ee31 /sys/arch
parent2e43e0e92e5f4f4d010a13c58c9fd0764dd80afd (diff)
Also insert two nop instructions after svc instructions for SYS_exit
and SYS_sigreturn in the sigtramp. As these control-flow into a jump or process termination, we never do the +8 dance over the instructions, however the speculation prevention (once these nops are replaced with a speculation barrier) is required. oversight noticed by Anthony Steinhauser.
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/arm64/arm64/locore.S6
1 files changed, 5 insertions, 1 deletions
diff --git a/sys/arch/arm64/arm64/locore.S b/sys/arch/arm64/arm64/locore.S
index a8f92a57826..01917a3de82 100644
--- a/sys/arch/arm64/arm64/locore.S
+++ b/sys/arch/arm64/arm64/locore.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: locore.S,v 1.25 2019/05/28 20:32:30 patrick Exp $ */
+/* $OpenBSD: locore.S,v 1.26 2020/02/01 23:09:46 deraadt Exp $ */
/*-
* Copyright (c) 2012-2014 Andrew Turner
* All rights reserved.
@@ -347,12 +347,16 @@ _C_LABEL(sigcode):
1:
mov x8, #SYS_sigreturn
svc 0
+ nop
+ nop
.globl _C_LABEL(sigcoderet)
_C_LABEL(sigcoderet):
/* sigreturn failed, exit */
mov x8, #SYS_exit
svc 0
+ nop
+ nop
b 1b
END(sigcode)