aboutsummaryrefslogtreecommitdiff
path: root/lib/include
diff options
context:
space:
mode:
authorDavid Oberhollenzer <goliath@infraroot.at>2020-05-14 01:41:30 +0200
committerDavid Oberhollenzer <goliath@infraroot.at>2020-05-14 01:41:30 +0200
commit8ce7d986283f5ef63377a0a447850c970c5cc493 (patch)
tree2a8bcf66f3d42104dfdaf1e71e9a11710245a936 /lib/include
parent32c3ad35b4985718e2b92c979292f6b0f6816587 (diff)
Move service rt data to libinit, try to improve memory packing
Signed-off-by: David Oberhollenzer <goliath@infraroot.at>
Diffstat (limited to 'lib/include')
-rw-r--r--lib/include/service.h33
1 files changed, 26 insertions, 7 deletions
diff --git a/lib/include/service.h b/lib/include/service.h
index 05ab8de..f388f87 100644
--- a/lib/include/service.h
+++ b/lib/include/service.h
@@ -3,6 +3,7 @@
#define SERVICE_H
#include <sys/types.h>
+#include <stdint.h>
typedef struct exec_t {
struct exec_t *next;
@@ -11,6 +12,14 @@ typedef struct exec_t {
} exec_t;
enum {
+ STATE_OFF,
+ STATE_RUNNING,
+ STATE_QUEUED,
+ STATE_COMPLETED,
+ STATE_FAILED,
+};
+
+enum {
/*
Start the service in the background and continue with
other services. The service will eventually terminate.
@@ -44,17 +53,13 @@ enum {
SVC_FLAG_HAS_EXEC = 0x10,
};
+/* persistent service configuration read from disk */
typedef struct service_t {
struct service_t *next;
char *fname; /* source file name */
-
- int type; /* SVC_* service type */
- int target; /* TGT_* service target */
char *desc; /* description string */
char *ctty; /* controlling tty or log file */
- int rspwn_limit; /* maximum respawn count */
- unsigned int flags; /* SVC_FLAG_* bit field */
/* linked list of command lines to execute */
exec_t *exec;
@@ -62,8 +67,13 @@ typedef struct service_t {
char *before; /* services that must be executed later */
char *after; /* services that must be executed first */
- int num_before;
- int num_after;
+ uint32_t num_before;
+ uint32_t num_after;
+
+ uint16_t rspwn_limit; /* maximum respawn count */
+ uint16_t flags; /* SVC_FLAG_* bit field */
+ uint8_t type; /* SVC_* service type */
+ uint8_t target; /* TGT_* service target */
char name[]; /* canonical service name */
} service_t;
@@ -72,6 +82,15 @@ typedef struct {
service_t *targets[TGT_MAX];
} service_list_t;
+/* run time configuration in-memory for managing services */
+typedef struct {
+ service_t *svc; /* the underlying service description */
+ pid_t pid; /* if still running, the pid */
+ uint16_t rspwn_count; /* services respawn counter */
+ uint8_t state; /* what STATE_* the service is currently in */
+ uint8_t status; /* if exited, process exit status */
+} svc_run_data_t;
+
/*
Read a service from a file.
*/