From ea595ba2a05a33882c4e8319a836eb0cec40a811 Mon Sep 17 00:00:00 2001 From: Bart Van Assche Date: Fri, 21 Oct 2022 12:44:02 -0700 Subject: [PATCH] init: Log more information if stopping times out The newly logged information includes the pending signals bitmask (SigPnd). That information allows to determine whether kill() did not deliver a signal or whether SIGCHLD has not been processed in time. This patch is expected to help with root-causing b/254878413. Bug: 254878413 Change-Id: Id33d1fb724163f8e5d4b3edfeb6c4be5321c0d95 Signed-off-by: Bart Van Assche --- init/sigchld_handler.cpp | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/init/sigchld_handler.cpp b/init/sigchld_handler.cpp index 6fc64df33..6a6050b2a 100644 --- a/init/sigchld_handler.cpp +++ b/init/sigchld_handler.cpp @@ -24,6 +24,7 @@ #include #include +#include #include #include #include @@ -36,6 +37,7 @@ using android::base::boot_clock; using android::base::make_scope_guard; +using android::base::ReadFileToString; using android::base::StringPrintf; using android::base::Timer; @@ -132,6 +134,11 @@ void WaitToBeReaped(const std::vector& pids, std::chrono::milliseconds ti } LOG(INFO) << "Waiting for " << pids.size() << " pids to be reaped took " << t << " with " << alive_pids.size() << " of them still running"; + for (pid_t pid : pids) { + std::string status = "(no-such-pid)"; + ReadFileToString(StringPrintf("/proc/%d/status", pid), &status); + LOG(INFO) << "Still running: " << pid << ' ' << status; + } } } // namespace init