Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 933da83a authored by Chris Wilson's avatar Chris Wilson Committed by Ingo Molnar
Browse files

perf: Propagate term signal to child



If we launch the child on behalf of the user, ensure that it dies
along with ourselves when we are interrupted.

Signed-off-by: default avatarChris Wilson <chris@chris-wilson.co.uk>
Cc: Chris Wilson <chris@chris-wilson.co.uk>
LKML-Reference: <1254616502-4728-1-git-send-email-chris@chris-wilson.co.uk>
Signed-off-by: default avatarIngo Molnar <mingo@elte.hu>
parent 1ad0560e
Loading
Loading
Loading
Loading
+6 −0
Original line number Diff line number Diff line
@@ -41,6 +41,7 @@ static int raw_samples = 0;
static int			system_wide			= 0;
static int			profile_cpu			= -1;
static pid_t			target_pid			= -1;
static pid_t			child_pid			= -1;
static int			inherit				= 1;
static int			force				= 0;
static int			append_file			= 0;
@@ -184,6 +185,9 @@ static void sig_handler(int sig)

static void sig_atexit(void)
{
	if (child_pid != -1)
		kill(child_pid, SIGTERM);

	if (signr == -1)
		return;

@@ -610,6 +614,8 @@ static int __cmd_record(int argc, const char **argv)
				exit(-1);
			}
		}

		child_pid = pid;
	}

	if (realtime_prio) {
+7 −1
Original line number Diff line number Diff line
@@ -69,7 +69,8 @@ static int run_idx = 0;
static int			run_count			=  1;
static int			inherit				=  1;
static int			scale				=  1;
static int			target_pid			= -1;
static pid_t			target_pid			= -1;
static pid_t			child_pid			= -1;
static int			null_run			=  0;

static int			fd[MAX_NR_CPUS][MAX_COUNTERS];
@@ -285,6 +286,8 @@ static int run_perf_stat(int argc __used, const char **argv)
		exit(-1);
	}

	child_pid = pid;

	/*
	 * Wait for the child to be ready to exec.
	 */
@@ -433,6 +436,9 @@ static void skip_signal(int signo)

static void sig_atexit(void)
{
	if (child_pid != -1)
		kill(child_pid, SIGTERM);

	if (signr == -1)
		return;