aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Oberhollenzer <goliath@infraroot.at>2019-03-18 14:08:17 +0100
committerDavid Oberhollenzer <goliath@infraroot.at>2019-03-18 18:29:02 +0100
commit40ad83dc6a95791bd20e214d2eb1b135900d47cc (patch)
tree90bd2364af9ce744c0b2bf7a8d58d4415e0d9fa9
parent23b713c3b5345c6df187cd494bac4ef20669c1cf (diff)
initd: implement handling of socket requests
Actually process requests and send an answer to status inquiries. Signed-off-by: David Oberhollenzer <goliath@infraroot.at>
-rw-r--r--initd/init.h3
-rw-r--r--initd/main.c21
-rw-r--r--initd/supervisor.c26
3 files changed, 50 insertions, 0 deletions
diff --git a/initd/init.h b/initd/init.h
index ce0bb1f..39e63a4 100644
--- a/initd/init.h
+++ b/initd/init.h
@@ -67,6 +67,9 @@ void supervisor_init(void);
bool supervisor_process_queues(void);
+void supervisor_answer_status_request(int fd, const void *dest_addr,
+ size_t addrlen);
+
/********** signal_<platform>.c **********/
/*
diff --git a/initd/main.c b/initd/main.c
index db44dc5..9432042 100644
--- a/initd/main.c
+++ b/initd/main.c
@@ -43,6 +43,27 @@ static void handle_signal(void)
static void handle_request(void)
{
+ struct sockaddr_un addr;
+ init_request_t rq;
+ socklen_t addrlen;
+ ssize_t ret;
+retry:
+ memset(&rq, 0, sizeof(rq));
+ addrlen = sizeof(addr);
+ ret = recvfrom(sockfd, &rq, sizeof(rq), MSG_DONTWAIT | MSG_TRUNC,
+ &addr, &addrlen);
+
+ if (ret < 0 && errno == EINTR)
+ goto retry;
+
+ if ((size_t)ret < sizeof(rq))
+ return;
+
+ switch (rq.rq) {
+ case EIR_STATUS:
+ supervisor_answer_status_request(sockfd, &addr, addrlen);
+ break;
+ }
}
void target_completed(int target)
diff --git a/initd/supervisor.c b/initd/supervisor.c
index 3ed0ec7..3743ad6 100644
--- a/initd/supervisor.c
+++ b/initd/supervisor.c
@@ -167,3 +167,29 @@ bool supervisor_process_queues(void)
target_completed(target);
return true;
}
+
+static int send_svc_list(int fd, const void *dst, size_t addrlen,
+ E_SERVICE_STATE state, service_t *list)
+{
+ while (list != NULL) {
+ if (init_socket_send_status(fd, dst, addrlen, state, list))
+ return -1;
+
+ list = list->next;
+ }
+
+ return 0;
+}
+
+void supervisor_answer_status_request(int fd, const void *dst, size_t addrlen)
+{
+ if (send_svc_list(fd, dst, addrlen, ESS_RUNNING, running))
+ return;
+ if (send_svc_list(fd, dst, addrlen, ESS_EXITED, completed))
+ return;
+ if (send_svc_list(fd, dst, addrlen, ESS_ENQUEUED, queue))
+ return;
+ if (send_svc_list(fd, dst, addrlen, ESS_ENQUEUED, terminated))
+ return;
+ init_socket_send_status(fd, dst, addrlen, ESS_NONE, NULL);
+}