From 6c5ad5c2ced5e2f1dc31448ef3e0c0fb14f9ada8 Mon Sep 17 00:00:00 2001 From: Elliott Hughes Date: Mon, 25 Nov 2013 16:33:53 -0800 Subject: [PATCH] Make init distinguish between orderly exit and being killed by signals. Bug: 11826724 Change-Id: I7c11f602447dbd6862decc51cdfe883003cf7d67 --- init/signal_handler.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/init/signal_handler.c b/init/signal_handler.c index d31ad63c8..7e8e1a70a 100644 --- a/init/signal_handler.c +++ b/init/signal_handler.c @@ -57,7 +57,15 @@ static int wait_for_one_process(int block) svc = service_find_by_pid(pid); if (!svc) { - ERROR("untracked pid %d exited\n", pid); + if (WIFEXITED(status)) { + ERROR("untracked pid %d exited with status %d\n", pid, WEXITSTATUS(status)); + } else if (WIFSIGNALED(status)) { + ERROR("untracked pid %d killed by signal %d\n", pid, WTERMSIG(status)); + } else if (WIFSTOPPED(status)) { + ERROR("untracked pid %d stopped by signal %d\n", pid, WSTOPSIG(status)); + } else { + ERROR("untracked pid %d state changed\n", pid); + } return 0; }