Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/tests/kernel - Add a 3 way handshake between the tracer and ...
details: https://anonhg.NetBSD.org/src/rev/709f28639dc1
branches: trunk
changeset: 348869:709f28639dc1
user: christos <christos%NetBSD.org@localhost>
date: Sat Nov 12 16:23:36 2016 +0000
description:
- Add a 3 way handshake between the tracer and the tracee to make sure the
tracer got a chance to run before we trace it.
- Unbuffer stdout and stderr, because the tracee ends up with with the tracers
unflushed buffers, and that confuses things.
diffstat:
tests/kernel/t_ptrace_wait.c | 22 ++++++++++++++++++----
1 files changed, 18 insertions(+), 4 deletions(-)
diffs (57 lines):
diff -r 635dc511fd33 -r 709f28639dc1 tests/kernel/t_ptrace_wait.c
--- a/tests/kernel/t_ptrace_wait.c Sat Nov 12 16:06:04 2016 +0000
+++ b/tests/kernel/t_ptrace_wait.c Sat Nov 12 16:23:36 2016 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: t_ptrace_wait.c,v 1.6 2016/11/12 14:48:55 kamil Exp $ */
+/* $NetBSD: t_ptrace_wait.c,v 1.7 2016/11/12 16:23:36 christos Exp $ */
/*-
* Copyright (c) 2016 The NetBSD Foundation, Inc.
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: t_ptrace_wait.c,v 1.6 2016/11/12 14:48:55 kamil Exp $");
+__RCSID("$NetBSD: t_ptrace_wait.c,v 1.7 2016/11/12 16:23:36 christos Exp $");
#include <sys/param.h>
#include <sys/types.h>
@@ -839,7 +839,13 @@
FORKEE_ASSERT(close(fds_totracee[1]) == 0);
FORKEE_ASSERT(close(fds_fromtracee[0]) == 0);
- /* Wait for message from the parent */
+ /* Wait for message 1 from the parent */
+ rv = read(fds_totracee[0], &msg, sizeof(msg));
+ FORKEE_ASSERT(rv == sizeof(msg));
+ /* Send response to parent */
+ rv = write(fds_fromtracee[1], &msg, sizeof(msg));
+ FORKEE_ASSERT(rv == sizeof(msg));
+ /* Wait for message 2 from the parent */
rv = read(fds_totracee[0], &msg, sizeof(msg));
FORKEE_ASSERT(rv == sizeof(msg));
@@ -854,7 +860,13 @@
ATF_REQUIRE(close(fds_totracee[0]) == 0);
ATF_REQUIRE(close(fds_fromtracee[1]) == 0);
- printf("Wait for the tracee to become ready\n");
+ printf("Send message 1 to tracee\n");
+ rv = write(fds_totracee[1], &msg, sizeof(msg));
+ ATF_REQUIRE(rv == sizeof(msg));
+ printf("Wait for response from tracee\n");
+ rv = read(fds_fromtracee[0], &msg, sizeof(msg));
+ ATF_REQUIRE(rv == sizeof(msg));
+ printf("Send message 2 to tracee\n");
rv = write(fds_totracee[1], &msg, sizeof(msg));
ATF_REQUIRE(rv == sizeof(msg));
@@ -1127,6 +1139,8 @@
ATF_TP_ADD_TCS(tp)
{
+ setvbuf(stdout, NULL, _IONBF, 0);
+ setvbuf(stderr, NULL, _IONBF, 0);
ATF_TP_ADD_TC(tp, traceme1);
ATF_TP_ADD_TC(tp, traceme2);
ATF_TP_ADD_TC(tp, traceme3);
Home |
Main Index |
Thread Index |
Old Index