summaryrefslogtreecommitdiff
path: root/lib/libc/arch
diff options
context:
space:
mode:
authorPhilip Guenther <guenther@cvs.openbsd.org>2020-10-01 01:05:41 +0000
committerPhilip Guenther <guenther@cvs.openbsd.org>2020-10-01 01:05:41 +0000
commitd90e891a92aa8add7b82f48b1c3c2e15eb47a67d (patch)
tree16701a85391198060dab52f08618393ee7e84b6c /lib/libc/arch
parentf4aa307936fa87d76580027c0c246301d8c56f96 (diff)
Mark top-level frame for new thread in both CFI and with zero
framepointer, so gdb knows to stop. Inspired by glibc ok kettenis@
Diffstat (limited to 'lib/libc/arch')
-rw-r--r--lib/libc/arch/aarch64/sys/tfork_thread.S8
-rw-r--r--lib/libc/arch/amd64/sys/tfork_thread.S10
2 files changed, 16 insertions, 2 deletions
diff --git a/lib/libc/arch/aarch64/sys/tfork_thread.S b/lib/libc/arch/aarch64/sys/tfork_thread.S
index 6e515c32b24..6dca582bd31 100644
--- a/lib/libc/arch/aarch64/sys/tfork_thread.S
+++ b/lib/libc/arch/aarch64/sys/tfork_thread.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: tfork_thread.S,v 1.3 2018/08/12 17:15:10 mortimer Exp $ */
+/* $OpenBSD: tfork_thread.S,v 1.4 2020/10/01 01:05:40 guenther Exp $ */
/*
* Copyright (c) 2005 Dale Rahn <drahn@openbsd.org>
*
@@ -24,8 +24,10 @@
*/
ENTRY(__tfork_thread)
+ .cfi_startproc
RETGUARD_SETUP(__tfork_thread, x15)
SYSTRAP(__tfork)
+ .cfi_endproc
bcs CERROR
/* check if we are parent or child */
@@ -34,8 +36,12 @@ ENTRY(__tfork_thread)
ret
1:
+ .cfi_startproc
+ .cfi_undefined lr
/* child */
+ ldr fp, 0
mov x0, x3
blr x2
SYSTRAP(__threxit)
+ .cfi_endproc
END(__tfork_thread)
diff --git a/lib/libc/arch/amd64/sys/tfork_thread.S b/lib/libc/arch/amd64/sys/tfork_thread.S
index f0d9c494aef..647f070cbcc 100644
--- a/lib/libc/arch/amd64/sys/tfork_thread.S
+++ b/lib/libc/arch/amd64/sys/tfork_thread.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: tfork_thread.S,v 1.8 2019/05/10 01:31:30 guenther Exp $ */
+/* $OpenBSD: tfork_thread.S,v 1.9 2020/10/01 01:05:40 guenther Exp $ */
/*-
* Copyright (c) 2000 Peter Wemm <peter@FreeBSD.org>
* Copyright (c) 2003 Alan L. Cox <alc@cs.rice.edu>
@@ -45,6 +45,7 @@
*/
ENTRY(__tfork_thread)
+ .cfi_startproc
movq %rdx, %r8
movq %rcx, %r9
@@ -52,6 +53,7 @@ ENTRY(__tfork_thread)
* Prepare and execute the thread creation syscall
*/
movl $SYS___tfork, %eax
+ .cfi_endproc
syscall
jb 2f
@@ -64,6 +66,7 @@ ENTRY(__tfork_thread)
/* the retpoline we'll use to call the child's main */
_ALIGN_TRAPS
+ .cfi_startproc
0: JMP_RETPOLINE(r8)
/*
@@ -73,6 +76,10 @@ ENTRY(__tfork_thread)
*/
_ALIGN_TRAPS
1:
+ /* Mark top frame of new thread in CFI and with zero FP */
+ .cfi_undefined rip
+ .cfi_undefined rsp
+ xorl %ebp, %ebp
movq %r9, %rdi
call 0b
@@ -89,4 +96,5 @@ ENTRY(__tfork_thread)
2:
SET_ERRNO
ret
+ .cfi_endproc
END(__tfork_thread)