Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src Fix and enable traceme_signal_nohandler2 in ATF ptrace(2) tests
details: https://anonhg.NetBSD.org/src/rev/0a93cce549d7
branches: trunk
changeset: 361966:0a93cce549d7
user: kamil <kamil%NetBSD.org@localhost>
date: Sun May 20 03:51:31 2018 +0000
description:
Fix and enable traceme_signal_nohandler2 in ATF ptrace(2) tests
traceme_signal_nohandler2 checks emitting SIGSTOP to a traced process
with the PT_CONTINUE operation.
The expected behavior is to simulate a behavior of receiving SIGSTOP,
generating SIGCHLD to its parent (in this case the debugger) and ability
to call wait(2)-like function receiving the stopped child event.
The previous behavior was unstopping the process and it has been adjusted
in the kernel code.
FreeBSD keeps unstopping a process for emitting SIGSTOP.
Linux handles this scenario in the same way as NetBSD now.
While there, implement the missing bits in the userland ATF test for
traceme_signal_nohandler2: receiving and validating 2nd SIGSTOP event and
continuing the process, followed by its normal termination.
Sponsored by <The NetBSD Foundation>
diffstat:
sys/kern/sys_ptrace_common.c | 15 ++++++++++++---
tests/lib/libc/sys/t_ptrace_wait.c | 33 +++++++++++++++++++++++++++++----
2 files changed, 41 insertions(+), 7 deletions(-)
diffs (111 lines):
diff -r 265ae032a518 -r 0a93cce549d7 sys/kern/sys_ptrace_common.c
--- a/sys/kern/sys_ptrace_common.c Sun May 20 03:09:02 2018 +0000
+++ b/sys/kern/sys_ptrace_common.c Sun May 20 03:51:31 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: sys_ptrace_common.c,v 1.40 2018/05/01 16:37:23 kamil Exp $ */
+/* $NetBSD: sys_ptrace_common.c,v 1.41 2018/05/20 03:51:31 kamil Exp $ */
/*-
* Copyright (c) 2008, 2009 The NetBSD Foundation, Inc.
@@ -118,7 +118,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sys_ptrace_common.c,v 1.40 2018/05/01 16:37:23 kamil Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sys_ptrace_common.c,v 1.41 2018/05/20 03:51:31 kamil Exp $");
#ifdef _KERNEL_OPT
#include "opt_ptrace.h"
@@ -865,7 +865,16 @@
* an LWP runs to see it.
*/
t->p_xsig = signo;
- if (resume_all)
+
+ /*
+ * signo > 0 check precents a potential panic, as
+ * sigismember(&...,0) is invalid check and signo
+ * can be equal to 0 as a special case of no-signal.
+ */
+ if (signo > 0 && sigismember(&stopsigmask, signo)) {
+ t->p_waited = 0;
+ child_psignal(t, 0);
+ } else if (resume_all)
proc_unstop(t);
else
lwp_unstop(lt);
diff -r 265ae032a518 -r 0a93cce549d7 tests/lib/libc/sys/t_ptrace_wait.c
--- a/tests/lib/libc/sys/t_ptrace_wait.c Sun May 20 03:09:02 2018 +0000
+++ b/tests/lib/libc/sys/t_ptrace_wait.c Sun May 20 03:51:31 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: t_ptrace_wait.c,v 1.47 2018/05/19 05:25:21 kamil Exp $ */
+/* $NetBSD: t_ptrace_wait.c,v 1.48 2018/05/20 03:51:31 kamil Exp $ */
/*-
* Copyright (c) 2016 The NetBSD Foundation, Inc.
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: t_ptrace_wait.c,v 1.47 2018/05/19 05:25:21 kamil Exp $");
+__RCSID("$NetBSD: t_ptrace_wait.c,v 1.48 2018/05/20 03:51:31 kamil Exp $");
#include <sys/param.h>
#include <sys/types.h>
@@ -299,6 +299,7 @@
switch (sigsent) {
case SIGCONT:
+ case SIGSTOP:
_exit(exitval);
default:
/* NOTREACHED */
@@ -332,6 +333,30 @@
TWAIT_REQUIRE_SUCCESS(wpid = TWAIT_GENERIC(child, &status, 0), child);
switch (sigsent) {
+ case SIGSTOP:
+ validate_status_stopped(status, sigsent);
+ DPRINTF("Before calling ptrace(2) with PT_GET_SIGINFO for "
+ "child\n");
+ SYSCALL_REQUIRE(ptrace(PT_GET_SIGINFO, child, &info,
+ sizeof(info)) != -1);
+
+ DPRINTF("Signal traced to lwpid=%d\n", info.psi_lwpid);
+ DPRINTF("Signal properties: si_signo=%#x si_code=%#x "
+ "si_errno=%#x\n",
+ info.psi_siginfo.si_signo, info.psi_siginfo.si_code,
+ info.psi_siginfo.si_errno);
+
+ ATF_REQUIRE_EQ(info.psi_siginfo.si_signo, sigval);
+ ATF_REQUIRE_EQ(info.psi_siginfo.si_code, SI_LWP);
+
+ DPRINTF("Before resuming the child process where it left off "
+ "and with signal %s to be sent\n", strsignal(sigsent));
+ SYSCALL_REQUIRE(ptrace(PT_CONTINUE, child, (void *)1, 0) != -1);
+
+ DPRINTF("Before calling %s() for the child\n", TWAIT_FNAME);
+ TWAIT_REQUIRE_SUCCESS(wpid = TWAIT_GENERIC(child, &status, 0),
+ child);
+ /* FALLTHROUGH */
case SIGCONT:
validate_status_exited(status, exitval);
break;
@@ -360,7 +385,7 @@
}
TRACEME_SIGNAL_NOHANDLER(traceme_signal_nohandler1, SIGKILL) /* non-maskable */
-//TRACEME_SIGNAL_NOHANDLER(traceme_signal_nohandler2, SIGSTOP) /* non-maskable */
+TRACEME_SIGNAL_NOHANDLER(traceme_signal_nohandler2, SIGSTOP) /* non-maskable */
TRACEME_SIGNAL_NOHANDLER(traceme_signal_nohandler3, SIGABRT) /* abort trap */
TRACEME_SIGNAL_NOHANDLER(traceme_signal_nohandler4, SIGHUP) /* hangup */
TRACEME_SIGNAL_NOHANDLER(traceme_signal_nohandler5, SIGCONT) /* continued? */
@@ -7113,7 +7138,7 @@
ATF_TP_ADD_TC(tp, traceme_sighandler_catch3);
ATF_TP_ADD_TC(tp, traceme_signal_nohandler1);
-// ATF_TP_ADD_TC(tp, traceme_signal_nohandler2); // not yet
+ ATF_TP_ADD_TC(tp, traceme_signal_nohandler2);
ATF_TP_ADD_TC(tp, traceme_signal_nohandler3);
ATF_TP_ADD_TC(tp, traceme_signal_nohandler4);
ATF_TP_ADD_TC(tp, traceme_signal_nohandler5);
Home |
Main Index |
Thread Index |
Old Index