From e1adb869da0189f51f2f9f6c8d32daa7f9c89f9f Mon Sep 17 00:00:00 2001 From: Keun-young Park Date: Tue, 28 Mar 2017 17:25:24 -0700 Subject: [PATCH] add killProcessGroupOnce - killProcessGroup retries if it fails while killProcessGroupOnce only tries once. - useful for sending signal like SIGTERM once. bug: 36696408 Test: will add usage to init (cherry picked from commit a88e425e0f5502062c7f3088d53b1b0ce8ef803e) Change-Id: Ie8eb338ee919b499948baf2a220e584b54293a89 --- .../include/processgroup/processgroup.h | 2 ++ libprocessgroup/processgroup.cpp | 17 +++++++++++------ 2 files changed, 13 insertions(+), 6 deletions(-) diff --git a/libprocessgroup/include/processgroup/processgroup.h b/libprocessgroup/include/processgroup/processgroup.h index 11bd8ccdf..47f6ff3cd 100644 --- a/libprocessgroup/include/processgroup/processgroup.h +++ b/libprocessgroup/include/processgroup/processgroup.h @@ -24,6 +24,8 @@ __BEGIN_DECLS int killProcessGroup(uid_t uid, int initialPid, int signal); +int killProcessGroupOnce(uid_t uid, int initialPid, int signal); + int createProcessGroup(uid_t uid, int initialPid); void removeAllProcessGroups(void); diff --git a/libprocessgroup/processgroup.cpp b/libprocessgroup/processgroup.cpp index eb6672762..1572cb312 100644 --- a/libprocessgroup/processgroup.cpp +++ b/libprocessgroup/processgroup.cpp @@ -252,8 +252,7 @@ void removeAllProcessGroups() } } -static int killProcessGroupOnce(uid_t uid, int initialPid, int signal) -{ +static int doKillProcessGroupOnce(uid_t uid, int initialPid, int signal) { int processes = 0; struct ctx ctx; pid_t pid; @@ -282,13 +281,11 @@ static int killProcessGroupOnce(uid_t uid, int initialPid, int signal) return processes; } -int killProcessGroup(uid_t uid, int initialPid, int signal) -{ +static int killProcessGroup(uid_t uid, int initialPid, int signal, int retry) { std::chrono::steady_clock::time_point start = std::chrono::steady_clock::now(); - int retry = 40; int processes; - while ((processes = killProcessGroupOnce(uid, initialPid, signal)) > 0) { + while ((processes = doKillProcessGroupOnce(uid, initialPid, signal)) > 0) { LOG(VERBOSE) << "killed " << processes << " processes for processgroup " << initialPid; if (retry > 0) { std::this_thread::sleep_for(5ms); @@ -313,6 +310,14 @@ int killProcessGroup(uid_t uid, int initialPid, int signal) } } +int killProcessGroup(uid_t uid, int initialPid, int signal) { + return killProcessGroup(uid, initialPid, signal, 40 /*maxRetry*/); +} + +int killProcessGroupOnce(uid_t uid, int initialPid, int signal) { + return killProcessGroup(uid, initialPid, signal, 0 /*maxRetry*/); +} + static bool mkdirAndChown(const char *path, mode_t mode, uid_t uid, gid_t gid) { if (mkdir(path, mode) == -1 && errno != EEXIST) {