[PATCH] Discard notification signals when a tracer exits

From: Petr Tesarik
Date: Tue Mar 25 2008 - 10:32:16 EST


When a tracer exits without detaching from the traced process, the
tracee may be at a tracer notification stop and will thus interpret
the value in task->exit_code (SIGTRAP | 0x80) as the signal to be
delivered.

This patch fixes the problem by clearing exit_code when detaching
the traced process from a dying tracer.

Signed-off-by: Petr Tesarik <ptesarik@xxxxxxx>

---
exit.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)

--- a/kernel/exit.c
+++ b/kernel/exit.c
@@ -642,8 +642,10 @@ reparent_thread(struct task_struct *p, s
/*
* If it was at a trace stop, turn it into
* a normal stop since it's no longer being
- * traced.
+ * traced. Cancel the notification signal,
+ * or the tracee may get a SIGTRAP.
*/
+ p->exit_code = 0;
ptrace_untrace(p);
}
}
@@ -713,6 +715,10 @@ static void forget_original_parent(struc
p->real_parent = reaper;
reparent_thread(p, father, 0);
} else {
+ /* cancel the notification signal at a trace stop */
+ if (p->state == TASK_TRACED)
+ p->exit_code = 0;
+
/* reparent ptraced task to its real parent */
__ptrace_unlink (p);
if (p->exit_state == EXIT_ZOMBIE && p->exit_signal != -1 &&

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/