diff options
author | Lennart Poettering <lennart@poettering.net> | 2013-12-11 18:14:52 +0100 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2013-12-11 18:20:09 +0100 |
commit | cde93897cdefdd7c7f66c400a61e42ceee5f6a46 (patch) | |
tree | 2ad9106709282c4f853bdcb3e2ea6446260ee743 /src/timedate/timedated.c | |
parent | 08cd15525450ff2c2ac814a58930f6d82284a1ba (diff) |
event: hook up sd-event with the service watchdog logic
Adds a new call sd_event_set_watchdog() that can be used to hook up the
event loop with the watchdog supervision logic of systemd. If enabled
and $WATCHDOG_USEC is set the event loop will ping the invoking systemd
daemon right after coming back from epoll_wait() but not more often than
$WATCHDOG_USEC/4. The epoll_wait() will sleep no longer than
$WATCHDOG_USEC/4*3, to make sure the service manager is called in time.
This means that setting WatchdogSec= in a .service file and calling
sd_event_set_watchdog() in your daemon is enough to hook it up with the
watchdog logic.
Diffstat (limited to 'src/timedate/timedated.c')
-rw-r--r-- | src/timedate/timedated.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/src/timedate/timedated.c b/src/timedate/timedated.c index 6d4388c70c..af2b0785cf 100644 --- a/src/timedate/timedated.c +++ b/src/timedate/timedated.c @@ -836,6 +836,8 @@ int main(int argc, char *argv[]) { goto finish; } + sd_event_set_watchdog(event, true); + r = connect_bus(&context, event, &bus); if (r < 0) goto finish; |