summaryrefslogtreecommitdiff
path: root/lib/libc
diff options
context:
space:
mode:
authorDale Rahn <drahn@cvs.openbsd.org>2017-03-08 06:28:13 +0000
committerDale Rahn <drahn@cvs.openbsd.org>2017-03-08 06:28:13 +0000
commit8e3d289c268504fc77c67b47c7efab70553ad53f (patch)
tree30fb62f031f40265d3f4fc17362772e8a11b94c6 /lib/libc
parentb94f66c87ec101aedb35a31a60dd66d027b9d72c (diff)
Correct arm64 sigprocmask parameter passing in setjmp/longjmp calls.
Always return nonzero as the return code from longjmp. ok guenther@ patrick@
Diffstat (limited to 'lib/libc')
-rw-r--r--lib/libc/arch/aarch64/gen/setjmp.S25
1 files changed, 11 insertions, 14 deletions
diff --git a/lib/libc/arch/aarch64/gen/setjmp.S b/lib/libc/arch/aarch64/gen/setjmp.S
index ba4010be7ff..40fba144a1b 100644
--- a/lib/libc/arch/aarch64/gen/setjmp.S
+++ b/lib/libc/arch/aarch64/gen/setjmp.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: setjmp.S,v 1.1 2017/01/11 18:09:24 patrick Exp $ */
+/* $OpenBSD: setjmp.S,v 1.2 2017/03/08 06:28:12 drahn Exp $ */
/*-
* Copyright (c) 2014 Andrew Turner
* Copyright (c) 2014 The FreeBSD Foundation
@@ -34,16 +34,15 @@
#include <machine/setjmp.h>
ENTRY(setjmp)
- stp x0, x30, [sp, #-16]!
+ mov x2, x0 /* save jmpbuf in x2 */
/* Store the signal mask */
- add x2, x0, #(_JB_SIGMASK * 8) /* oset */
- mov x1, #0 /* set */
+ mov w1, #0 /* set */
mov x0, #1 /* SIG_BLOCK */
SYSTRAP(sigprocmask)
+ str w0, [x2, #(_JB_SIGMASK * 8)] /* oset */
- ldp x0, x30, [sp], #16
-
+ mov x0, x2
/* Store the magic value and stack pointer */
ldr x8, .Lmagic
mov x9, sp
@@ -73,18 +72,15 @@ ENTRY(setjmp)
END_STRONG(setjmp)
ENTRY(longjmp)
- stp x0, x1, [sp, #-32]!
- str x30, [sp, #24]
+ mov x2, x0 /* move jmpbuf */
+ mov x3, x1 /* final return value */
/* Restore the signal mask */
- mov x2, #0 /* oset */
- add x1, x0, #(_JB_SIGMASK * 8) /* set */
+ ldr w1, [x2, #(_JB_SIGMASK * 8)] /* set */
mov x0, #3 /* SIG_SETMASK */
SYSTRAP(sigprocmask)
- ldr x30, [sp, #24]
- ldp x0, x1, [sp], #32
-
+ mov x0, x2
/* Check the magic value */
ldr x8, [x0], #8
ldr x9, .Lmagic
@@ -110,7 +106,8 @@ ENTRY(longjmp)
ldp d14, d15, [x0]
/* Load the return value */
- mov x0, x1
+ cmp w3, #0
+ csinc w0, w3, wzr, ne
ret
botch: