chiark / gitweb /
service: don't wait for any child unless we no its pid
[elogind.git] / service.c
index 40a02c16e9a99d7211131db103a3667134514ded..83a11e94f9356cf88813fb027bfbbfd89f1abb3c 100644 (file)
--- a/service.c
+++ b/service.c
@@ -1413,7 +1413,7 @@ static void service_enter_signal(Service *s, ServiceState state, bool success) {
                 }
         }
 
-        if (sent) {
+        if (sent && (s->main_pid > 0 || s->control_pid > 0)) {
                 if (s->timeout_usec > 0)
                         if ((r = unit_watch_timer(UNIT(s), s->timeout_usec, &s->timer_watch)) < 0)
                                 goto fail;