Blame SOURCES/0024-tests-check-tracing-of-orphaned-process-group.patch

4d44fe
From 96dc1aa20237b80087f6c9ee29147bb85a5594d9 Mon Sep 17 00:00:00 2001
4d44fe
From: "Dmitry V. Levin" <ldv@altlinux.org>
4d44fe
Date: Wed, 6 Mar 2019 16:02:38 +0000
4d44fe
Subject: [PATCH 24/27] tests: check tracing of orphaned process group
4d44fe
4d44fe
* tests/orphaned_process_group.c: New file.
4d44fe
* tests/.gitignore: Add orphaned_process_group.
4d44fe
* tests/Makefile.am (check_PROGRAMS): Likewise.
4d44fe
* tests/gen_tests.in (orphaned_process_group): New test.
4d44fe
4d44fe
Skipped files (not present in the tarball):
4d44fe
	tests/.gitignore
4d44fe
4d44fe
Additional changes:
4d44fe
	tests/Makefile.in (generated from tests/Makefile.am)
4d44fe
	tests/tests/orphaned_process_group.gen.test (generated from tests/gen_tests.in)
4d44fe
	tests-m32/Makefile.in (generated from tests-m32/Makefile.am)
4d44fe
	tests-m32/gen_tests.in (copy of tests/gen_tests.in)
4d44fe
	tests-m32/orphaned_process_group.c (copy of tests/orphaned_process_group.c)
4d44fe
	tests-m32/tests/orphaned_process_group.gen.test (generated from tests-m32/gen_tests.in)
4d44fe
	tests-mx32/Makefile.in (generated from tests-mx32/Makefile.am)
4d44fe
	tests-mx32/gen_tests.in (copy of tests/gen_tests.in)
4d44fe
	tests-mx32/orphaned_process_group.c (copy of tests/orphaned_process_group.c)
4d44fe
	tests-mx32/tests/orphaned_process_group.gen.test (generated from tests-mx32/gen_tests.in)
4d44fe
4d44fe
---
4d44fe
 tests/.gitignore               |   1 +
4d44fe
 tests/Makefile.am              |   1 +
4d44fe
 tests/gen_tests.in             |   1 +
4d44fe
 tests/orphaned_process_group.c | 155 +++++++++++++++++++++++++++++++++++++++++
4d44fe
 4 files changed, 158 insertions(+)
4d44fe
 create mode 100644 tests/orphaned_process_group.c
4d44fe
4d44fe
Index: strace-4.24/tests/Makefile.am
4d44fe
===================================================================
4d44fe
--- strace-4.24.orig/tests/Makefile.am	2019-03-10 05:47:36.446486219 +0100
4d44fe
+++ strace-4.24/tests/Makefile.am	2019-03-10 05:50:05.488993755 +0100
4d44fe
@@ -120,6 +120,7 @@
4d44fe
 	nsyscalls-d \
4d44fe
 	oldselect-P \
4d44fe
 	oldselect-efault-P \
4d44fe
+	orphaned_process_group \
4d44fe
 	pc \
4d44fe
 	perf_event_open_nonverbose \
4d44fe
 	perf_event_open_unabbrev \
4d44fe
Index: strace-4.24/tests/gen_tests.in
4d44fe
===================================================================
4d44fe
--- strace-4.24.orig/tests/gen_tests.in	2019-03-10 05:19:26.185411954 +0100
4d44fe
+++ strace-4.24/tests/gen_tests.in	2019-03-10 05:50:05.488993755 +0100
4d44fe
@@ -287,6 +287,7 @@
4d44fe
 oldstat	-a32 -v -P stat.sample -P /dev/full
4d44fe
 open	-a30 -P $NAME.sample
4d44fe
 openat	-a36 -P $NAME.sample
4d44fe
+orphaned_process_group	. "${srcdir=.}/PTRACE_SEIZE.sh"; run_strace_match_diff -f -e trace=none -e signal='!chld'
4d44fe
 osf_utimes	-a21
4d44fe
 pause	-a8 -esignal=none
4d44fe
 perf_event_open	-a1
4d44fe
Index: strace-4.24/tests/orphaned_process_group.c
4d44fe
===================================================================
4d44fe
--- /dev/null	1970-01-01 00:00:00.000000000 +0000
4d44fe
+++ strace-4.24/tests/orphaned_process_group.c	2019-03-10 05:50:05.488993755 +0100
4d44fe
@@ -0,0 +1,155 @@
4d44fe
+/*
4d44fe
+ * Check tracing of orphaned process group.
4d44fe
+ *
4d44fe
+ * Copyright (c) 2019 The strace developers.
4d44fe
+ * All rights reserved.
4d44fe
+ *
4d44fe
+ * SPDX-License-Identifier: GPL-2.0-or-later
4d44fe
+ */
4d44fe
+
4d44fe
+#include "tests.h"
4d44fe
+#include <signal.h>
4d44fe
+#include <stdio.h>
4d44fe
+#include <stdlib.h>
4d44fe
+#include <string.h>
4d44fe
+#include <unistd.h>
4d44fe
+#include <sys/wait.h>
4d44fe
+
4d44fe
+#define TIMEOUT 5
4d44fe
+
4d44fe
+static void
4d44fe
+alarm_handler(const int no)
4d44fe
+{
4d44fe
+	error_msg_and_skip("Orphaned process group semantics"
4d44fe
+			   " is not supported by the kernel");
4d44fe
+}
4d44fe
+
4d44fe
+int
4d44fe
+main(void)
4d44fe
+{
4d44fe
+	int status;
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Unblock all signals.
4d44fe
+	 */
4d44fe
+	static sigset_t mask;
4d44fe
+	if (sigprocmask(SIG_SETMASK, &mask, NULL))
4d44fe
+		perror_msg_and_fail("sigprocmask");
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Create a pipe to track termination of processes.
4d44fe
+	 */
4d44fe
+	int pipe_fds[2];
4d44fe
+	if (pipe(pipe_fds))
4d44fe
+		perror_msg_and_fail("pipe");
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Create a leader for its own new process group.
4d44fe
+	 */
4d44fe
+	pid_t leader = fork();
4d44fe
+	if (leader < 0)
4d44fe
+		perror_msg_and_fail("fork");
4d44fe
+
4d44fe
+	if (leader) {
4d44fe
+		/*
4d44fe
+		 * Close the writing end of the pipe.
4d44fe
+		 */
4d44fe
+		close(pipe_fds[1]);
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Install the SIGALRM signal handler.
4d44fe
+		 */
4d44fe
+		static const struct sigaction sa = {
4d44fe
+			.sa_handler = alarm_handler
4d44fe
+		};
4d44fe
+		if (sigaction(SIGALRM, &sa, NULL))
4d44fe
+			perror_msg_and_fail("sigaction");
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Set an alarm clock.
4d44fe
+		 */
4d44fe
+		alarm(TIMEOUT);
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Wait for termination of the child process.
4d44fe
+		 */
4d44fe
+		if (waitpid(leader, &status, 0) != leader)
4d44fe
+			perror_msg_and_fail("waitpid leader");
4d44fe
+		if (!WIFEXITED(status) || WEXITSTATUS(status) != 0)
4d44fe
+			error_msg_and_fail("waitpid leader: "
4d44fe
+					   "unexpected wait status %d",
4d44fe
+					   status);
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Wait for termination of all processes
4d44fe
+		 * in the process group of the child process.
4d44fe
+		 */
4d44fe
+		if (read(pipe_fds[0], &status, sizeof(status)) != 0)
4d44fe
+			perror_msg_and_fail("read");
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * At this point all processes are gone.
4d44fe
+		 * Let the tracer time to catch up.
4d44fe
+		 */
4d44fe
+		alarm(0);
4d44fe
+		sleep(1);
4d44fe
+		return 0;
4d44fe
+	}
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Close the reading end of the pipe.
4d44fe
+	 */
4d44fe
+	close(pipe_fds[0]);
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Create a new process group.
4d44fe
+	 */
4d44fe
+	if (setpgid(0, 0))
4d44fe
+		perror_msg_and_fail("setpgid");
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * When the leader process terminates, the process group becomes orphaned.
4d44fe
+	 * If any member of the orphaned process group is stopped, then
4d44fe
+	 * a SIGHUP signal followed by a SIGCONT signal is sent to each process
4d44fe
+	 * in the orphaned process group.
4d44fe
+	 * Create a process in a stopped state to activate this behaviour.
4d44fe
+	 */
4d44fe
+	const pid_t stopped = fork();
4d44fe
+	if (stopped < 0)
4d44fe
+		perror_msg_and_fail("fork");
4d44fe
+	if (!stopped) {
4d44fe
+		static const struct sigaction sa = { .sa_handler = SIG_DFL };
4d44fe
+		if (sigaction(SIGHUP, &sa, NULL))
4d44fe
+			perror_msg_and_fail("sigaction");
4d44fe
+
4d44fe
+		raise(SIGSTOP);
4d44fe
+		_exit(0);
4d44fe
+	}
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Wait for the process to stop.
4d44fe
+	 */
4d44fe
+	if (waitpid(stopped, &status, WUNTRACED) != stopped)
4d44fe
+		perror_msg_and_fail("waitpid WUNTRACED");
4d44fe
+	if (!WIFSTOPPED(status) || WSTOPSIG(status) != SIGSTOP)
4d44fe
+                error_msg_and_fail("unexpected wait status %d", status);
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Print the expected output.
4d44fe
+	 */
4d44fe
+	leader = getpid();
4d44fe
+	printf("%-5d --- %s {si_signo=%s, si_code=SI_TKILL"
4d44fe
+	       ", si_pid=%d, si_uid=%u} ---\n",
4d44fe
+	       stopped, "SIGSTOP", "SIGSTOP", stopped, geteuid());
4d44fe
+	printf("%-5d --- stopped by SIGSTOP ---\n", stopped);
4d44fe
+	printf("%-5d +++ exited with 0 +++\n", leader);
4d44fe
+	printf("%-5d --- %s {si_signo=%s, si_code=SI_KERNEL} ---\n",
4d44fe
+	       stopped, "SIGHUP", "SIGHUP");
4d44fe
+	printf("%-5d +++ killed by %s +++\n", stopped, "SIGHUP");
4d44fe
+	printf("%-5d +++ exited with 0 +++\n", getppid());
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Make the process group orphaned.
4d44fe
+	 */
4d44fe
+	return 0;
4d44fe
+}
4d44fe
Index: strace-4.24/tests-m32/orphaned_process_group.c
4d44fe
===================================================================
4d44fe
--- /dev/null	1970-01-01 00:00:00.000000000 +0000
4d44fe
+++ strace-4.24/tests-m32/orphaned_process_group.c	2019-03-10 05:51:47.527971970 +0100
4d44fe
@@ -0,0 +1,155 @@
4d44fe
+/*
4d44fe
+ * Check tracing of orphaned process group.
4d44fe
+ *
4d44fe
+ * Copyright (c) 2019 The strace developers.
4d44fe
+ * All rights reserved.
4d44fe
+ *
4d44fe
+ * SPDX-License-Identifier: GPL-2.0-or-later
4d44fe
+ */
4d44fe
+
4d44fe
+#include "tests.h"
4d44fe
+#include <signal.h>
4d44fe
+#include <stdio.h>
4d44fe
+#include <stdlib.h>
4d44fe
+#include <string.h>
4d44fe
+#include <unistd.h>
4d44fe
+#include <sys/wait.h>
4d44fe
+
4d44fe
+#define TIMEOUT 5
4d44fe
+
4d44fe
+static void
4d44fe
+alarm_handler(const int no)
4d44fe
+{
4d44fe
+	error_msg_and_skip("Orphaned process group semantics"
4d44fe
+			   " is not supported by the kernel");
4d44fe
+}
4d44fe
+
4d44fe
+int
4d44fe
+main(void)
4d44fe
+{
4d44fe
+	int status;
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Unblock all signals.
4d44fe
+	 */
4d44fe
+	static sigset_t mask;
4d44fe
+	if (sigprocmask(SIG_SETMASK, &mask, NULL))
4d44fe
+		perror_msg_and_fail("sigprocmask");
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Create a pipe to track termination of processes.
4d44fe
+	 */
4d44fe
+	int pipe_fds[2];
4d44fe
+	if (pipe(pipe_fds))
4d44fe
+		perror_msg_and_fail("pipe");
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Create a leader for its own new process group.
4d44fe
+	 */
4d44fe
+	pid_t leader = fork();
4d44fe
+	if (leader < 0)
4d44fe
+		perror_msg_and_fail("fork");
4d44fe
+
4d44fe
+	if (leader) {
4d44fe
+		/*
4d44fe
+		 * Close the writing end of the pipe.
4d44fe
+		 */
4d44fe
+		close(pipe_fds[1]);
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Install the SIGALRM signal handler.
4d44fe
+		 */
4d44fe
+		static const struct sigaction sa = {
4d44fe
+			.sa_handler = alarm_handler
4d44fe
+		};
4d44fe
+		if (sigaction(SIGALRM, &sa, NULL))
4d44fe
+			perror_msg_and_fail("sigaction");
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Set an alarm clock.
4d44fe
+		 */
4d44fe
+		alarm(TIMEOUT);
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Wait for termination of the child process.
4d44fe
+		 */
4d44fe
+		if (waitpid(leader, &status, 0) != leader)
4d44fe
+			perror_msg_and_fail("waitpid leader");
4d44fe
+		if (!WIFEXITED(status) || WEXITSTATUS(status) != 0)
4d44fe
+			error_msg_and_fail("waitpid leader: "
4d44fe
+					   "unexpected wait status %d",
4d44fe
+					   status);
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Wait for termination of all processes
4d44fe
+		 * in the process group of the child process.
4d44fe
+		 */
4d44fe
+		if (read(pipe_fds[0], &status, sizeof(status)) != 0)
4d44fe
+			perror_msg_and_fail("read");
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * At this point all processes are gone.
4d44fe
+		 * Let the tracer time to catch up.
4d44fe
+		 */
4d44fe
+		alarm(0);
4d44fe
+		sleep(1);
4d44fe
+		return 0;
4d44fe
+	}
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Close the reading end of the pipe.
4d44fe
+	 */
4d44fe
+	close(pipe_fds[0]);
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Create a new process group.
4d44fe
+	 */
4d44fe
+	if (setpgid(0, 0))
4d44fe
+		perror_msg_and_fail("setpgid");
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * When the leader process terminates, the process group becomes orphaned.
4d44fe
+	 * If any member of the orphaned process group is stopped, then
4d44fe
+	 * a SIGHUP signal followed by a SIGCONT signal is sent to each process
4d44fe
+	 * in the orphaned process group.
4d44fe
+	 * Create a process in a stopped state to activate this behaviour.
4d44fe
+	 */
4d44fe
+	const pid_t stopped = fork();
4d44fe
+	if (stopped < 0)
4d44fe
+		perror_msg_and_fail("fork");
4d44fe
+	if (!stopped) {
4d44fe
+		static const struct sigaction sa = { .sa_handler = SIG_DFL };
4d44fe
+		if (sigaction(SIGHUP, &sa, NULL))
4d44fe
+			perror_msg_and_fail("sigaction");
4d44fe
+
4d44fe
+		raise(SIGSTOP);
4d44fe
+		_exit(0);
4d44fe
+	}
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Wait for the process to stop.
4d44fe
+	 */
4d44fe
+	if (waitpid(stopped, &status, WUNTRACED) != stopped)
4d44fe
+		perror_msg_and_fail("waitpid WUNTRACED");
4d44fe
+	if (!WIFSTOPPED(status) || WSTOPSIG(status) != SIGSTOP)
4d44fe
+                error_msg_and_fail("unexpected wait status %d", status);
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Print the expected output.
4d44fe
+	 */
4d44fe
+	leader = getpid();
4d44fe
+	printf("%-5d --- %s {si_signo=%s, si_code=SI_TKILL"
4d44fe
+	       ", si_pid=%d, si_uid=%u} ---\n",
4d44fe
+	       stopped, "SIGSTOP", "SIGSTOP", stopped, geteuid());
4d44fe
+	printf("%-5d --- stopped by SIGSTOP ---\n", stopped);
4d44fe
+	printf("%-5d +++ exited with 0 +++\n", leader);
4d44fe
+	printf("%-5d --- %s {si_signo=%s, si_code=SI_KERNEL} ---\n",
4d44fe
+	       stopped, "SIGHUP", "SIGHUP");
4d44fe
+	printf("%-5d +++ killed by %s +++\n", stopped, "SIGHUP");
4d44fe
+	printf("%-5d +++ exited with 0 +++\n", getppid());
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Make the process group orphaned.
4d44fe
+	 */
4d44fe
+	return 0;
4d44fe
+}
4d44fe
Index: strace-4.24/tests-mx32/orphaned_process_group.c
4d44fe
===================================================================
4d44fe
--- /dev/null	1970-01-01 00:00:00.000000000 +0000
4d44fe
+++ strace-4.24/tests-mx32/orphaned_process_group.c	2019-03-10 05:51:50.259944613 +0100
4d44fe
@@ -0,0 +1,155 @@
4d44fe
+/*
4d44fe
+ * Check tracing of orphaned process group.
4d44fe
+ *
4d44fe
+ * Copyright (c) 2019 The strace developers.
4d44fe
+ * All rights reserved.
4d44fe
+ *
4d44fe
+ * SPDX-License-Identifier: GPL-2.0-or-later
4d44fe
+ */
4d44fe
+
4d44fe
+#include "tests.h"
4d44fe
+#include <signal.h>
4d44fe
+#include <stdio.h>
4d44fe
+#include <stdlib.h>
4d44fe
+#include <string.h>
4d44fe
+#include <unistd.h>
4d44fe
+#include <sys/wait.h>
4d44fe
+
4d44fe
+#define TIMEOUT 5
4d44fe
+
4d44fe
+static void
4d44fe
+alarm_handler(const int no)
4d44fe
+{
4d44fe
+	error_msg_and_skip("Orphaned process group semantics"
4d44fe
+			   " is not supported by the kernel");
4d44fe
+}
4d44fe
+
4d44fe
+int
4d44fe
+main(void)
4d44fe
+{
4d44fe
+	int status;
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Unblock all signals.
4d44fe
+	 */
4d44fe
+	static sigset_t mask;
4d44fe
+	if (sigprocmask(SIG_SETMASK, &mask, NULL))
4d44fe
+		perror_msg_and_fail("sigprocmask");
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Create a pipe to track termination of processes.
4d44fe
+	 */
4d44fe
+	int pipe_fds[2];
4d44fe
+	if (pipe(pipe_fds))
4d44fe
+		perror_msg_and_fail("pipe");
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Create a leader for its own new process group.
4d44fe
+	 */
4d44fe
+	pid_t leader = fork();
4d44fe
+	if (leader < 0)
4d44fe
+		perror_msg_and_fail("fork");
4d44fe
+
4d44fe
+	if (leader) {
4d44fe
+		/*
4d44fe
+		 * Close the writing end of the pipe.
4d44fe
+		 */
4d44fe
+		close(pipe_fds[1]);
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Install the SIGALRM signal handler.
4d44fe
+		 */
4d44fe
+		static const struct sigaction sa = {
4d44fe
+			.sa_handler = alarm_handler
4d44fe
+		};
4d44fe
+		if (sigaction(SIGALRM, &sa, NULL))
4d44fe
+			perror_msg_and_fail("sigaction");
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Set an alarm clock.
4d44fe
+		 */
4d44fe
+		alarm(TIMEOUT);
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Wait for termination of the child process.
4d44fe
+		 */
4d44fe
+		if (waitpid(leader, &status, 0) != leader)
4d44fe
+			perror_msg_and_fail("waitpid leader");
4d44fe
+		if (!WIFEXITED(status) || WEXITSTATUS(status) != 0)
4d44fe
+			error_msg_and_fail("waitpid leader: "
4d44fe
+					   "unexpected wait status %d",
4d44fe
+					   status);
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * Wait for termination of all processes
4d44fe
+		 * in the process group of the child process.
4d44fe
+		 */
4d44fe
+		if (read(pipe_fds[0], &status, sizeof(status)) != 0)
4d44fe
+			perror_msg_and_fail("read");
4d44fe
+
4d44fe
+		/*
4d44fe
+		 * At this point all processes are gone.
4d44fe
+		 * Let the tracer time to catch up.
4d44fe
+		 */
4d44fe
+		alarm(0);
4d44fe
+		sleep(1);
4d44fe
+		return 0;
4d44fe
+	}
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Close the reading end of the pipe.
4d44fe
+	 */
4d44fe
+	close(pipe_fds[0]);
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Create a new process group.
4d44fe
+	 */
4d44fe
+	if (setpgid(0, 0))
4d44fe
+		perror_msg_and_fail("setpgid");
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * When the leader process terminates, the process group becomes orphaned.
4d44fe
+	 * If any member of the orphaned process group is stopped, then
4d44fe
+	 * a SIGHUP signal followed by a SIGCONT signal is sent to each process
4d44fe
+	 * in the orphaned process group.
4d44fe
+	 * Create a process in a stopped state to activate this behaviour.
4d44fe
+	 */
4d44fe
+	const pid_t stopped = fork();
4d44fe
+	if (stopped < 0)
4d44fe
+		perror_msg_and_fail("fork");
4d44fe
+	if (!stopped) {
4d44fe
+		static const struct sigaction sa = { .sa_handler = SIG_DFL };
4d44fe
+		if (sigaction(SIGHUP, &sa, NULL))
4d44fe
+			perror_msg_and_fail("sigaction");
4d44fe
+
4d44fe
+		raise(SIGSTOP);
4d44fe
+		_exit(0);
4d44fe
+	}
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Wait for the process to stop.
4d44fe
+	 */
4d44fe
+	if (waitpid(stopped, &status, WUNTRACED) != stopped)
4d44fe
+		perror_msg_and_fail("waitpid WUNTRACED");
4d44fe
+	if (!WIFSTOPPED(status) || WSTOPSIG(status) != SIGSTOP)
4d44fe
+                error_msg_and_fail("unexpected wait status %d", status);
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Print the expected output.
4d44fe
+	 */
4d44fe
+	leader = getpid();
4d44fe
+	printf("%-5d --- %s {si_signo=%s, si_code=SI_TKILL"
4d44fe
+	       ", si_pid=%d, si_uid=%u} ---\n",
4d44fe
+	       stopped, "SIGSTOP", "SIGSTOP", stopped, geteuid());
4d44fe
+	printf("%-5d --- stopped by SIGSTOP ---\n", stopped);
4d44fe
+	printf("%-5d +++ exited with 0 +++\n", leader);
4d44fe
+	printf("%-5d --- %s {si_signo=%s, si_code=SI_KERNEL} ---\n",
4d44fe
+	       stopped, "SIGHUP", "SIGHUP");
4d44fe
+	printf("%-5d +++ killed by %s +++\n", stopped, "SIGHUP");
4d44fe
+	printf("%-5d +++ exited with 0 +++\n", getppid());
4d44fe
+
4d44fe
+	/*
4d44fe
+	 * Make the process group orphaned.
4d44fe
+	 */
4d44fe
+	return 0;
4d44fe
+}
4d44fe
Index: strace-4.24/tests/Makefile.in
4d44fe
===================================================================
4d44fe
--- strace-4.24.orig/tests/Makefile.in	2019-03-10 05:40:37.973676673 +0100
4d44fe
+++ strace-4.24/tests/Makefile.in	2019-03-10 05:56:10.763336015 +0100
4d44fe
@@ -161,8 +161,8 @@
4d44fe
 	net-tpacket_stats-success$(EXEEXT) netlink_inet_diag$(EXEEXT) \
4d44fe
 	netlink_netlink_diag$(EXEEXT) netlink_unix_diag$(EXEEXT) \
4d44fe
 	nsyscalls$(EXEEXT) nsyscalls-d$(EXEEXT) oldselect-P$(EXEEXT) \
4d44fe
-	oldselect-efault-P$(EXEEXT) pc$(EXEEXT) \
4d44fe
-	perf_event_open_nonverbose$(EXEEXT) \
4d44fe
+	oldselect-efault-P$(EXEEXT) orphaned_process_group$(EXEEXT) \
4d44fe
+	pc$(EXEEXT) perf_event_open_nonverbose$(EXEEXT) \
4d44fe
 	perf_event_open_unabbrev$(EXEEXT) ppoll-v$(EXEEXT) \
4d44fe
 	prctl-seccomp-filter-v$(EXEEXT) prctl-seccomp-strict$(EXEEXT) \
4d44fe
 	prctl-spec-inject$(EXEEXT) print_maxfd$(EXEEXT) \
4d44fe
@@ -1743,6 +1743,10 @@
4d44fe
 openat_OBJECTS = openat.$(OBJEXT)
4d44fe
 openat_LDADD = $(LDADD)
4d44fe
 openat_DEPENDENCIES = libtests.a
4d44fe
+orphaned_process_group_SOURCES = orphaned_process_group.c
4d44fe
+orphaned_process_group_OBJECTS = orphaned_process_group.$(OBJEXT)
4d44fe
+orphaned_process_group_LDADD = $(LDADD)
4d44fe
+orphaned_process_group_DEPENDENCIES = libtests.a
4d44fe
 osf_utimes_SOURCES = osf_utimes.c
4d44fe
 osf_utimes_OBJECTS = osf_utimes.$(OBJEXT)
4d44fe
 osf_utimes_LDADD = $(LDADD)
4d44fe
@@ -2786,7 +2790,8 @@
4d44fe
 	old_mmap-P.c old_mmap-Xabbrev.c old_mmap-Xraw.c \
4d44fe
 	old_mmap-Xverbose.c old_mmap-v-none.c oldfstat.c oldlstat.c \
4d44fe
 	oldselect.c oldselect-P.c oldselect-efault.c \
4d44fe
-	oldselect-efault-P.c oldstat.c open.c openat.c osf_utimes.c \
4d44fe
+	oldselect-efault-P.c oldstat.c open.c openat.c \
4d44fe
+	orphaned_process_group.c osf_utimes.c \
4d44fe
 	pause.c pc.c perf_event_open.c perf_event_open_nonverbose.c \
4d44fe
 	perf_event_open_unabbrev.c personality.c personality-Xabbrev.c \
4d44fe
 	personality-Xraw.c personality-Xverbose.c pipe.c pipe2.c \
4d44fe
@@ -2931,7 +2936,8 @@
4d44fe
 	old_mmap-P.c old_mmap-Xabbrev.c old_mmap-Xraw.c \
4d44fe
 	old_mmap-Xverbose.c old_mmap-v-none.c oldfstat.c oldlstat.c \
4d44fe
 	oldselect.c oldselect-P.c oldselect-efault.c \
4d44fe
-	oldselect-efault-P.c oldstat.c open.c openat.c osf_utimes.c \
4d44fe
+	oldselect-efault-P.c oldstat.c open.c openat.c \
4d44fe
+	orphaned_process_group.c osf_utimes.c \
4d44fe
 	pause.c pc.c perf_event_open.c perf_event_open_nonverbose.c \
4d44fe
 	perf_event_open_unabbrev.c personality.c personality-Xabbrev.c \
4d44fe
 	personality-Xraw.c personality-Xverbose.c pipe.c pipe2.c \
4d44fe
@@ -4058,7 +4064,8 @@
4d44fe
 	oldselect.gen.test oldselect-P.gen.test \
4d44fe
 	oldselect-efault.gen.test oldselect-efault-P.gen.test \
4d44fe
 	oldstat.gen.test open.gen.test openat.gen.test \
4d44fe
-	osf_utimes.gen.test pause.gen.test perf_event_open.gen.test \
4d44fe
+	orphaned_process_group.gen.test osf_utimes.gen.test \
4d44fe
+	pause.gen.test perf_event_open.gen.test \
4d44fe
 	perf_event_open_nonverbose.gen.test \
4d44fe
 	perf_event_open_unabbrev.gen.test personality-Xabbrev.gen.test \
4d44fe
 	personality-Xraw.gen.test personality-Xverbose.gen.test \
4d44fe
@@ -5752,6 +5759,10 @@
4d44fe
 	@rm -f openat$(EXEEXT)
4d44fe
 	$(AM_V_CCLD)$(LINK) $(openat_OBJECTS) $(openat_LDADD) $(LIBS)
4d44fe
 
4d44fe
+orphaned_process_group$(EXEEXT): $(orphaned_process_group_OBJECTS) $(orphaned_process_group_DEPENDENCIES) $(EXTRA_orphaned_process_group_DEPENDENCIES) 
4d44fe
+	@rm -f orphaned_process_group$(EXEEXT)
4d44fe
+	$(AM_V_CCLD)$(LINK) $(orphaned_process_group_OBJECTS) $(orphaned_process_group_LDADD) $(LIBS)
4d44fe
+
4d44fe
 osf_utimes$(EXEEXT): $(osf_utimes_OBJECTS) $(osf_utimes_DEPENDENCIES) $(EXTRA_osf_utimes_DEPENDENCIES) 
4d44fe
 	@rm -f osf_utimes$(EXEEXT)
4d44fe
 	$(AM_V_CCLD)$(LINK) $(osf_utimes_OBJECTS) $(osf_utimes_LDADD) $(LIBS)
4d44fe
@@ -7030,6 +7041,7 @@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/oldstat.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/open.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/openat.Po@am__quote@
4d44fe
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/orphaned_process_group.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/osf_utimes.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pause.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pc.Po@am__quote@
4d44fe
@@ -9128,6 +9140,9 @@
4d44fe
 $(srcdir)/openat.gen.test: $(abs_srcdir)/gen_tests.sh $(srcdir)/gen_tests.in
4d44fe
 	$(AM_V_GEN) $^ $@
4d44fe
 
4d44fe
+$(srcdir)/orphaned_process_group.gen.test: $(abs_srcdir)/gen_tests.sh $(srcdir)/gen_tests.in
4d44fe
+	$(AM_V_GEN) $^ $@
4d44fe
+
4d44fe
 $(srcdir)/osf_utimes.gen.test: $(abs_srcdir)/gen_tests.sh $(srcdir)/gen_tests.in
4d44fe
 	$(AM_V_GEN) $^ $@
4d44fe
 
4d44fe
Index: strace-4.24/tests-m32/Makefile.in
4d44fe
===================================================================
4d44fe
--- strace-4.24.orig/tests-m32/Makefile.in	2019-03-10 05:44:56.112091757 +0100
4d44fe
+++ strace-4.24/tests-m32/Makefile.in	2019-03-10 05:57:09.322749620 +0100
4d44fe
@@ -161,8 +161,8 @@
4d44fe
 	net-tpacket_stats-success$(EXEEXT) netlink_inet_diag$(EXEEXT) \
4d44fe
 	netlink_netlink_diag$(EXEEXT) netlink_unix_diag$(EXEEXT) \
4d44fe
 	nsyscalls$(EXEEXT) nsyscalls-d$(EXEEXT) oldselect-P$(EXEEXT) \
4d44fe
-	oldselect-efault-P$(EXEEXT) pc$(EXEEXT) \
4d44fe
-	perf_event_open_nonverbose$(EXEEXT) \
4d44fe
+	oldselect-efault-P$(EXEEXT) orphaned_process_group$(EXEEXT) \
4d44fe
+	pc$(EXEEXT) perf_event_open_nonverbose$(EXEEXT) \
4d44fe
 	perf_event_open_unabbrev$(EXEEXT) ppoll-v$(EXEEXT) \
4d44fe
 	prctl-seccomp-filter-v$(EXEEXT) prctl-seccomp-strict$(EXEEXT) \
4d44fe
 	prctl-spec-inject$(EXEEXT) print_maxfd$(EXEEXT) \
4d44fe
@@ -1743,6 +1743,10 @@
4d44fe
 openat_OBJECTS = openat.$(OBJEXT)
4d44fe
 openat_LDADD = $(LDADD)
4d44fe
 openat_DEPENDENCIES = libtests.a
4d44fe
+orphaned_process_group_SOURCES = orphaned_process_group.c
4d44fe
+orphaned_process_group_OBJECTS = orphaned_process_group.$(OBJEXT)
4d44fe
+orphaned_process_group_LDADD = $(LDADD)
4d44fe
+orphaned_process_group_DEPENDENCIES = libtests.a
4d44fe
 osf_utimes_SOURCES = osf_utimes.c
4d44fe
 osf_utimes_OBJECTS = osf_utimes.$(OBJEXT)
4d44fe
 osf_utimes_LDADD = $(LDADD)
4d44fe
@@ -2786,7 +2790,8 @@
4d44fe
 	old_mmap-P.c old_mmap-Xabbrev.c old_mmap-Xraw.c \
4d44fe
 	old_mmap-Xverbose.c old_mmap-v-none.c oldfstat.c oldlstat.c \
4d44fe
 	oldselect.c oldselect-P.c oldselect-efault.c \
4d44fe
-	oldselect-efault-P.c oldstat.c open.c openat.c osf_utimes.c \
4d44fe
+	oldselect-efault-P.c oldstat.c open.c openat.c \
4d44fe
+	orphaned_process_group.c osf_utimes.c \
4d44fe
 	pause.c pc.c perf_event_open.c perf_event_open_nonverbose.c \
4d44fe
 	perf_event_open_unabbrev.c personality.c personality-Xabbrev.c \
4d44fe
 	personality-Xraw.c personality-Xverbose.c pipe.c pipe2.c \
4d44fe
@@ -2931,7 +2936,8 @@
4d44fe
 	old_mmap-P.c old_mmap-Xabbrev.c old_mmap-Xraw.c \
4d44fe
 	old_mmap-Xverbose.c old_mmap-v-none.c oldfstat.c oldlstat.c \
4d44fe
 	oldselect.c oldselect-P.c oldselect-efault.c \
4d44fe
-	oldselect-efault-P.c oldstat.c open.c openat.c osf_utimes.c \
4d44fe
+	oldselect-efault-P.c oldstat.c open.c openat.c \
4d44fe
+	orphaned_process_group.c osf_utimes.c \
4d44fe
 	pause.c pc.c perf_event_open.c perf_event_open_nonverbose.c \
4d44fe
 	perf_event_open_unabbrev.c personality.c personality-Xabbrev.c \
4d44fe
 	personality-Xraw.c personality-Xverbose.c pipe.c pipe2.c \
4d44fe
@@ -4058,7 +4064,8 @@
4d44fe
 	oldselect.gen.test oldselect-P.gen.test \
4d44fe
 	oldselect-efault.gen.test oldselect-efault-P.gen.test \
4d44fe
 	oldstat.gen.test open.gen.test openat.gen.test \
4d44fe
-	osf_utimes.gen.test pause.gen.test perf_event_open.gen.test \
4d44fe
+	orphaned_process_group.gen.test osf_utimes.gen.test \
4d44fe
+	pause.gen.test perf_event_open.gen.test \
4d44fe
 	perf_event_open_nonverbose.gen.test \
4d44fe
 	perf_event_open_unabbrev.gen.test personality-Xabbrev.gen.test \
4d44fe
 	personality-Xraw.gen.test personality-Xverbose.gen.test \
4d44fe
@@ -5752,6 +5759,10 @@
4d44fe
 	@rm -f openat$(EXEEXT)
4d44fe
 	$(AM_V_CCLD)$(LINK) $(openat_OBJECTS) $(openat_LDADD) $(LIBS)
4d44fe
 
4d44fe
+orphaned_process_group$(EXEEXT): $(orphaned_process_group_OBJECTS) $(orphaned_process_group_DEPENDENCIES) $(EXTRA_orphaned_process_group_DEPENDENCIES) 
4d44fe
+	@rm -f orphaned_process_group$(EXEEXT)
4d44fe
+	$(AM_V_CCLD)$(LINK) $(orphaned_process_group_OBJECTS) $(orphaned_process_group_LDADD) $(LIBS)
4d44fe
+
4d44fe
 osf_utimes$(EXEEXT): $(osf_utimes_OBJECTS) $(osf_utimes_DEPENDENCIES) $(EXTRA_osf_utimes_DEPENDENCIES) 
4d44fe
 	@rm -f osf_utimes$(EXEEXT)
4d44fe
 	$(AM_V_CCLD)$(LINK) $(osf_utimes_OBJECTS) $(osf_utimes_LDADD) $(LIBS)
4d44fe
@@ -7030,6 +7041,7 @@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/oldstat.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/open.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/openat.Po@am__quote@
4d44fe
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/orphaned_process_group.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/osf_utimes.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pause.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pc.Po@am__quote@
4d44fe
@@ -9128,6 +9140,9 @@
4d44fe
 $(srcdir)/openat.gen.test: $(abs_srcdir)/gen_tests.sh $(srcdir)/gen_tests.in
4d44fe
 	$(AM_V_GEN) $^ $@
4d44fe
 
4d44fe
+$(srcdir)/orphaned_process_group.gen.test: $(abs_srcdir)/gen_tests.sh $(srcdir)/gen_tests.in
4d44fe
+	$(AM_V_GEN) $^ $@
4d44fe
+
4d44fe
 $(srcdir)/osf_utimes.gen.test: $(abs_srcdir)/gen_tests.sh $(srcdir)/gen_tests.in
4d44fe
 	$(AM_V_GEN) $^ $@
4d44fe
 
4d44fe
Index: strace-4.24/tests-mx32/Makefile.in
4d44fe
===================================================================
4d44fe
--- strace-4.24.orig/tests-mx32/Makefile.in	2019-03-10 05:45:49.892553217 +0100
4d44fe
+++ strace-4.24/tests-mx32/Makefile.in	2019-03-10 05:57:19.939643305 +0100
4d44fe
@@ -161,8 +161,8 @@
4d44fe
 	net-tpacket_stats-success$(EXEEXT) netlink_inet_diag$(EXEEXT) \
4d44fe
 	netlink_netlink_diag$(EXEEXT) netlink_unix_diag$(EXEEXT) \
4d44fe
 	nsyscalls$(EXEEXT) nsyscalls-d$(EXEEXT) oldselect-P$(EXEEXT) \
4d44fe
-	oldselect-efault-P$(EXEEXT) pc$(EXEEXT) \
4d44fe
-	perf_event_open_nonverbose$(EXEEXT) \
4d44fe
+	oldselect-efault-P$(EXEEXT) orphaned_process_group$(EXEEXT) \
4d44fe
+	pc$(EXEEXT) perf_event_open_nonverbose$(EXEEXT) \
4d44fe
 	perf_event_open_unabbrev$(EXEEXT) ppoll-v$(EXEEXT) \
4d44fe
 	prctl-seccomp-filter-v$(EXEEXT) prctl-seccomp-strict$(EXEEXT) \
4d44fe
 	prctl-spec-inject$(EXEEXT) print_maxfd$(EXEEXT) \
4d44fe
@@ -1743,6 +1743,10 @@
4d44fe
 openat_OBJECTS = openat.$(OBJEXT)
4d44fe
 openat_LDADD = $(LDADD)
4d44fe
 openat_DEPENDENCIES = libtests.a
4d44fe
+orphaned_process_group_SOURCES = orphaned_process_group.c
4d44fe
+orphaned_process_group_OBJECTS = orphaned_process_group.$(OBJEXT)
4d44fe
+orphaned_process_group_LDADD = $(LDADD)
4d44fe
+orphaned_process_group_DEPENDENCIES = libtests.a
4d44fe
 osf_utimes_SOURCES = osf_utimes.c
4d44fe
 osf_utimes_OBJECTS = osf_utimes.$(OBJEXT)
4d44fe
 osf_utimes_LDADD = $(LDADD)
4d44fe
@@ -2786,7 +2790,8 @@
4d44fe
 	old_mmap-P.c old_mmap-Xabbrev.c old_mmap-Xraw.c \
4d44fe
 	old_mmap-Xverbose.c old_mmap-v-none.c oldfstat.c oldlstat.c \
4d44fe
 	oldselect.c oldselect-P.c oldselect-efault.c \
4d44fe
-	oldselect-efault-P.c oldstat.c open.c openat.c osf_utimes.c \
4d44fe
+	oldselect-efault-P.c oldstat.c open.c openat.c \
4d44fe
+	orphaned_process_group.c osf_utimes.c \
4d44fe
 	pause.c pc.c perf_event_open.c perf_event_open_nonverbose.c \
4d44fe
 	perf_event_open_unabbrev.c personality.c personality-Xabbrev.c \
4d44fe
 	personality-Xraw.c personality-Xverbose.c pipe.c pipe2.c \
4d44fe
@@ -2931,7 +2936,8 @@
4d44fe
 	old_mmap-P.c old_mmap-Xabbrev.c old_mmap-Xraw.c \
4d44fe
 	old_mmap-Xverbose.c old_mmap-v-none.c oldfstat.c oldlstat.c \
4d44fe
 	oldselect.c oldselect-P.c oldselect-efault.c \
4d44fe
-	oldselect-efault-P.c oldstat.c open.c openat.c osf_utimes.c \
4d44fe
+	oldselect-efault-P.c oldstat.c open.c openat.c \
4d44fe
+	orphaned_process_group.c osf_utimes.c \
4d44fe
 	pause.c pc.c perf_event_open.c perf_event_open_nonverbose.c \
4d44fe
 	perf_event_open_unabbrev.c personality.c personality-Xabbrev.c \
4d44fe
 	personality-Xraw.c personality-Xverbose.c pipe.c pipe2.c \
4d44fe
@@ -4058,7 +4064,8 @@
4d44fe
 	oldselect.gen.test oldselect-P.gen.test \
4d44fe
 	oldselect-efault.gen.test oldselect-efault-P.gen.test \
4d44fe
 	oldstat.gen.test open.gen.test openat.gen.test \
4d44fe
-	osf_utimes.gen.test pause.gen.test perf_event_open.gen.test \
4d44fe
+	orphaned_process_group.gen.test osf_utimes.gen.test \
4d44fe
+	pause.gen.test perf_event_open.gen.test \
4d44fe
 	perf_event_open_nonverbose.gen.test \
4d44fe
 	perf_event_open_unabbrev.gen.test personality-Xabbrev.gen.test \
4d44fe
 	personality-Xraw.gen.test personality-Xverbose.gen.test \
4d44fe
@@ -5752,6 +5759,10 @@
4d44fe
 	@rm -f openat$(EXEEXT)
4d44fe
 	$(AM_V_CCLD)$(LINK) $(openat_OBJECTS) $(openat_LDADD) $(LIBS)
4d44fe
 
4d44fe
+orphaned_process_group$(EXEEXT): $(orphaned_process_group_OBJECTS) $(orphaned_process_group_DEPENDENCIES) $(EXTRA_orphaned_process_group_DEPENDENCIES) 
4d44fe
+	@rm -f orphaned_process_group$(EXEEXT)
4d44fe
+	$(AM_V_CCLD)$(LINK) $(orphaned_process_group_OBJECTS) $(orphaned_process_group_LDADD) $(LIBS)
4d44fe
+
4d44fe
 osf_utimes$(EXEEXT): $(osf_utimes_OBJECTS) $(osf_utimes_DEPENDENCIES) $(EXTRA_osf_utimes_DEPENDENCIES) 
4d44fe
 	@rm -f osf_utimes$(EXEEXT)
4d44fe
 	$(AM_V_CCLD)$(LINK) $(osf_utimes_OBJECTS) $(osf_utimes_LDADD) $(LIBS)
4d44fe
@@ -7030,6 +7041,7 @@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/oldstat.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/open.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/openat.Po@am__quote@
4d44fe
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/orphaned_process_group.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/osf_utimes.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pause.Po@am__quote@
4d44fe
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pc.Po@am__quote@
4d44fe
@@ -9128,6 +9140,9 @@
4d44fe
 $(srcdir)/openat.gen.test: $(abs_srcdir)/gen_tests.sh $(srcdir)/gen_tests.in
4d44fe
 	$(AM_V_GEN) $^ $@
4d44fe
 
4d44fe
+$(srcdir)/orphaned_process_group.gen.test: $(abs_srcdir)/gen_tests.sh $(srcdir)/gen_tests.in
4d44fe
+	$(AM_V_GEN) $^ $@
4d44fe
+
4d44fe
 $(srcdir)/osf_utimes.gen.test: $(abs_srcdir)/gen_tests.sh $(srcdir)/gen_tests.in
4d44fe
 	$(AM_V_GEN) $^ $@
4d44fe
 
4d44fe
Index: strace-4.24/tests-m32/orphaned_process_group.gen.test
4d44fe
===================================================================
4d44fe
--- /dev/null	1970-01-01 00:00:00.000000000 +0000
4d44fe
+++ strace-4.24/tests-m32/orphaned_process_group.gen.test	2019-03-10 05:59:50.567134970 +0100
4d44fe
@@ -0,0 +1,4 @@
4d44fe
+#!/bin/sh -efu
4d44fe
+# Generated by ./tests/gen_tests.sh from ./tests/gen_tests.in (orphaned_process_group . "${srcdir=.}/PTRACE_SEIZE.sh"; run_strace_match_diff -f -e trace=none -e signal='!chld'); do not edit.
4d44fe
+. "${srcdir=.}/init.sh"
4d44fe
+. "${srcdir=.}/PTRACE_SEIZE.sh"; run_strace_match_diff -f -e trace=none -e signal='!chld'
4d44fe
Index: strace-4.24/tests-mx32/orphaned_process_group.gen.test
4d44fe
===================================================================
4d44fe
--- /dev/null	1970-01-01 00:00:00.000000000 +0000
4d44fe
+++ strace-4.24/tests-mx32/orphaned_process_group.gen.test	2019-03-10 05:59:51.671123915 +0100
4d44fe
@@ -0,0 +1,4 @@
4d44fe
+#!/bin/sh -efu
4d44fe
+# Generated by ./tests/gen_tests.sh from ./tests/gen_tests.in (orphaned_process_group . "${srcdir=.}/PTRACE_SEIZE.sh"; run_strace_match_diff -f -e trace=none -e signal='!chld'); do not edit.
4d44fe
+. "${srcdir=.}/init.sh"
4d44fe
+. "${srcdir=.}/PTRACE_SEIZE.sh"; run_strace_match_diff -f -e trace=none -e signal='!chld'
4d44fe
Index: strace-4.24/tests/orphaned_process_group.gen.test
4d44fe
===================================================================
4d44fe
--- /dev/null	1970-01-01 00:00:00.000000000 +0000
4d44fe
+++ strace-4.24/tests/orphaned_process_group.gen.test	2019-03-10 05:59:48.722153445 +0100
4d44fe
@@ -0,0 +1,4 @@
4d44fe
+#!/bin/sh -efu
4d44fe
+# Generated by ./tests/gen_tests.sh from ./tests/gen_tests.in (orphaned_process_group . "${srcdir=.}/PTRACE_SEIZE.sh"; run_strace_match_diff -f -e trace=none -e signal='!chld'); do not edit.
4d44fe
+. "${srcdir=.}/init.sh"
4d44fe
+. "${srcdir=.}/PTRACE_SEIZE.sh"; run_strace_match_diff -f -e trace=none -e signal='!chld'
4d44fe
Index: strace-4.24/tests-m32/gen_tests.in
4d44fe
===================================================================
4d44fe
--- strace-4.24.orig/tests-m32/gen_tests.in	2018-08-01 16:57:16.000000000 +0200
4d44fe
+++ strace-4.24/tests-m32/gen_tests.in	2019-03-10 06:00:59.151448188 +0100
4d44fe
@@ -3,27 +3,7 @@
4d44fe
 # Copyright (c) 2017-2018 The strace developers.
4d44fe
 # All rights reserved.
4d44fe
 #
4d44fe
-# Redistribution and use in source and binary forms, with or without
4d44fe
-# modification, are permitted provided that the following conditions
4d44fe
-# are met:
4d44fe
-# 1. Redistributions of source code must retain the above copyright
4d44fe
-#    notice, this list of conditions and the following disclaimer.
4d44fe
-# 2. Redistributions in binary form must reproduce the above copyright
4d44fe
-#    notice, this list of conditions and the following disclaimer in the
4d44fe
-#    documentation and/or other materials provided with the distribution.
4d44fe
-# 3. The name of the author may not be used to endorse or promote products
4d44fe
-#    derived from this software without specific prior written permission.
4d44fe
-#
4d44fe
-# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
4d44fe
-# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
4d44fe
-# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
4d44fe
-# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
4d44fe
-# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
4d44fe
-# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
4d44fe
-# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
4d44fe
-# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
4d44fe
-# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
4d44fe
-# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
4d44fe
+# SPDX-License-Identifier: GPL-2.0-or-later
4d44fe
 
4d44fe
 _newselect
4d44fe
 _newselect-P	 -e trace=_newselect -P /dev/full 9>>/dev/full
4d44fe
@@ -307,6 +287,7 @@
4d44fe
 oldstat	-a32 -v -P stat.sample -P /dev/full
4d44fe
 open	-a30 -P $NAME.sample
4d44fe
 openat	-a36 -P $NAME.sample
4d44fe
+orphaned_process_group	. "${srcdir=.}/PTRACE_SEIZE.sh"; run_strace_match_diff -f -e trace=none -e signal='!chld'
4d44fe
 osf_utimes	-a21
4d44fe
 pause	-a8 -esignal=none
4d44fe
 perf_event_open	-a1
4d44fe
Index: strace-4.24/tests-mx32/gen_tests.in
4d44fe
===================================================================
4d44fe
--- strace-4.24.orig/tests-mx32/gen_tests.in	2018-08-01 16:57:16.000000000 +0200
4d44fe
+++ strace-4.24/tests-mx32/gen_tests.in	2019-03-10 06:01:00.297436713 +0100
4d44fe
@@ -3,27 +3,7 @@
4d44fe
 # Copyright (c) 2017-2018 The strace developers.
4d44fe
 # All rights reserved.
4d44fe
 #
4d44fe
-# Redistribution and use in source and binary forms, with or without
4d44fe
-# modification, are permitted provided that the following conditions
4d44fe
-# are met:
4d44fe
-# 1. Redistributions of source code must retain the above copyright
4d44fe
-#    notice, this list of conditions and the following disclaimer.
4d44fe
-# 2. Redistributions in binary form must reproduce the above copyright
4d44fe
-#    notice, this list of conditions and the following disclaimer in the
4d44fe
-#    documentation and/or other materials provided with the distribution.
4d44fe
-# 3. The name of the author may not be used to endorse or promote products
4d44fe
-#    derived from this software without specific prior written permission.
4d44fe
-#
4d44fe
-# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
4d44fe
-# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
4d44fe
-# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
4d44fe
-# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
4d44fe
-# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
4d44fe
-# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
4d44fe
-# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
4d44fe
-# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
4d44fe
-# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
4d44fe
-# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
4d44fe
+# SPDX-License-Identifier: GPL-2.0-or-later
4d44fe
 
4d44fe
 _newselect
4d44fe
 _newselect-P	 -e trace=_newselect -P /dev/full 9>>/dev/full
4d44fe
@@ -307,6 +287,7 @@
4d44fe
 oldstat	-a32 -v -P stat.sample -P /dev/full
4d44fe
 open	-a30 -P $NAME.sample
4d44fe
 openat	-a36 -P $NAME.sample
4d44fe
+orphaned_process_group	. "${srcdir=.}/PTRACE_SEIZE.sh"; run_strace_match_diff -f -e trace=none -e signal='!chld'
4d44fe
 osf_utimes	-a21
4d44fe
 pause	-a8 -esignal=none
4d44fe
 perf_event_open	-a1