From 7ee3e5b2d6dbb9c279011b59ec132d27d04f843e Mon Sep 17 00:00:00 2001 From: William Hubbs Date: Sat, 6 Oct 2018 12:49:44 -0500 Subject: [PATCH] openrc-init: convert sleep() call to nanosleep() Nanosleep is the safer call to use in case we need to use alarms eventually. --- src/rc/openrc-init.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/rc/openrc-init.c b/src/rc/openrc-init.c index d8038637..e02fa5ee 100644 --- a/src/rc/openrc-init.c +++ b/src/rc/openrc-init.c @@ -24,6 +24,7 @@ #include #include #include +#include #include #include #include @@ -96,12 +97,15 @@ static void handle_reexec(char *my_name) static void handle_shutdown(const char *runlevel, int cmd) { pid_t pid; + struct timespec ts; pid = do_openrc(runlevel); while (waitpid(pid, NULL, 0) != pid); printf("Sending the final term signal\n"); kill(-1, SIGTERM); - sleep(3); + ts.tv_sec = 3; + ts.tv_nsec = 0; + nanosleep(&ts, NULL); printf("Sending the final kill signal\n"); kill(-1, SIGKILL); sync();