diff options
author | David Teigland <teigland@redhat.com> | 2014-12-02 14:08:58 -0600 |
---|---|---|
committer | David Teigland <teigland@redhat.com> | 2015-02-27 13:44:55 -0600 |
commit | 2a7d297f60ae026d743663904839093aa693b961 (patch) | |
tree | 929134ff67e22b707275075dba401f3aab3c366f | |
parent | beb68da635bfc28ab87b7cf45fe2873e07a6c980 (diff) | |
download | lvm2-2a7d297f60ae026d743663904839093aa693b961.tar.gz |
libdaemon: allow main processing function to be specified
-rw-r--r-- | libdaemon/server/daemon-server.c | 8 | ||||
-rw-r--r-- | libdaemon/server/daemon-server.h | 1 |
2 files changed, 8 insertions, 1 deletions
diff --git a/libdaemon/server/daemon-server.c b/libdaemon/server/daemon-server.c index 5ccf4e98c..1491102bb 100644 --- a/libdaemon/server/daemon-server.c +++ b/libdaemon/server/daemon-server.c @@ -578,6 +578,12 @@ void daemon_start(daemon_state s) if (!s.foreground) kill(getppid(), SIGTERM); + if (s.daemon_main) { + if (!s.daemon_main(&s)) + failed = 1; + goto out; + } + if (s.daemon_init) if (!s.daemon_init(&s)) failed = 1; @@ -596,7 +602,7 @@ void daemon_start(daemon_state s) INFO(&s, "%s waiting for client threads to finish", s.name); reap(s, 1); - +out: /* If activated by systemd, do not unlink the socket - systemd takes care of that! */ if (!_systemd_activation && s.socket_fd >= 0) if (unlink(s.socket_path)) diff --git a/libdaemon/server/daemon-server.h b/libdaemon/server/daemon-server.h index a7673d455..2e82627e0 100644 --- a/libdaemon/server/daemon-server.h +++ b/libdaemon/server/daemon-server.h @@ -92,6 +92,7 @@ typedef struct daemon_state { handle_request handler; int (*daemon_init)(struct daemon_state *st); int (*daemon_fini)(struct daemon_state *st); + int (*daemon_main)(struct daemon_state *st); /* Global runtime info maintained by the framework. */ int socket_fd; |