summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Teigland <teigland@redhat.com>2014-12-02 14:08:58 -0600
committerDavid Teigland <teigland@redhat.com>2015-02-27 13:44:55 -0600
commit2a7d297f60ae026d743663904839093aa693b961 (patch)
tree929134ff67e22b707275075dba401f3aab3c366f
parentbeb68da635bfc28ab87b7cf45fe2873e07a6c980 (diff)
downloadlvm2-2a7d297f60ae026d743663904839093aa693b961.tar.gz
libdaemon: allow main processing function to be specified
-rw-r--r--libdaemon/server/daemon-server.c8
-rw-r--r--libdaemon/server/daemon-server.h1
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;