1 /* SPDX-License-Identifier: LGPL-2.1+ */
4 typedef struct Service Service
;
5 typedef struct ServiceFDStore ServiceFDStore
;
7 #include "exit-status.h"
10 #include "ratelimit.h"
14 typedef enum ServiceRestart
{
16 SERVICE_RESTART_ON_SUCCESS
,
17 SERVICE_RESTART_ON_FAILURE
,
18 SERVICE_RESTART_ON_ABNORMAL
,
19 SERVICE_RESTART_ON_WATCHDOG
,
20 SERVICE_RESTART_ON_ABORT
,
21 SERVICE_RESTART_ALWAYS
,
23 _SERVICE_RESTART_INVALID
= -1
26 typedef enum ServiceType
{
27 SERVICE_SIMPLE
, /* we fork and go on right-away (i.e. modern socket activated daemons) */
28 SERVICE_FORKING
, /* forks by itself (i.e. traditional daemons) */
29 SERVICE_ONESHOT
, /* we fork and wait until the program finishes (i.e. programs like fsck which run and need to finish before we continue) */
30 SERVICE_DBUS
, /* we fork and wait until a specific D-Bus name appears on the bus */
31 SERVICE_NOTIFY
, /* we fork and wait until a daemon sends us a ready message with sd_notify() */
32 SERVICE_IDLE
, /* much like simple, but delay exec() until all jobs are dispatched. */
33 SERVICE_EXEC
, /* we fork and wait until we execute exec() (this means our own setup is waited for) */
35 _SERVICE_TYPE_INVALID
= -1
38 typedef enum ServiceExecCommand
{
39 SERVICE_EXEC_START_PRE
,
41 SERVICE_EXEC_START_POST
,
44 SERVICE_EXEC_STOP_POST
,
45 _SERVICE_EXEC_COMMAND_MAX
,
46 _SERVICE_EXEC_COMMAND_INVALID
= -1
49 typedef enum NotifyState
{
55 _NOTIFY_STATE_INVALID
= -1
58 /* The values of this enum are referenced in man/systemd.exec.xml and src/shared/bus-unit-util.c.
59 * Update those sources for each change to this enum. */
60 typedef enum ServiceResult
{
62 SERVICE_FAILURE_RESOURCES
, /* a bit of a misnomer, just our catch-all error for errnos we didn't expect */
63 SERVICE_FAILURE_PROTOCOL
,
64 SERVICE_FAILURE_TIMEOUT
,
65 SERVICE_FAILURE_EXIT_CODE
,
66 SERVICE_FAILURE_SIGNAL
,
67 SERVICE_FAILURE_CORE_DUMP
,
68 SERVICE_FAILURE_WATCHDOG
,
69 SERVICE_FAILURE_START_LIMIT_HIT
,
70 SERVICE_FAILURE_OOM_KILL
,
72 _SERVICE_RESULT_INVALID
= -1
75 struct ServiceFDStore
{
80 sd_event_source
*event_source
;
82 LIST_FIELDS(ServiceFDStore
, fd_store
);
89 ServiceRestart restart
;
90 ExitStatusSet restart_prevent_status
;
91 ExitStatusSet restart_force_status
;
92 ExitStatusSet success_status
;
94 /* If set we'll read the main daemon PID from this file */
98 usec_t timeout_start_usec
;
99 usec_t timeout_stop_usec
;
100 usec_t runtime_max_usec
;
102 dual_timestamp watchdog_timestamp
;
103 usec_t watchdog_usec
; /* the requested watchdog timeout in the unit file */
104 usec_t watchdog_original_usec
; /* the watchdog timeout that was in effect when the unit was started, i.e. the timeout the forked off processes currently see */
105 usec_t watchdog_override_usec
; /* the watchdog timeout requested by the service itself through sd_notify() */
106 bool watchdog_override_enable
;
107 sd_event_source
*watchdog_event_source
;
109 ExecCommand
* exec_command
[_SERVICE_EXEC_COMMAND_MAX
];
111 ExecContext exec_context
;
112 KillContext kill_context
;
113 CGroupContext cgroup_context
;
115 ServiceState state
, deserialized_state
;
117 /* The exit status of the real main process */
118 ExecStatus main_exec_status
;
120 /* The currently executed control process */
121 ExecCommand
*control_command
;
123 /* The currently executed main process, which may be NULL if
124 * the main process got started via forking mode and not by
126 ExecCommand
*main_command
;
128 /* The ID of the control command currently being executed */
129 ServiceExecCommand control_command_id
;
131 /* Runtime data of the execution context */
132 ExecRuntime
*exec_runtime
;
133 DynamicCreds dynamic_creds
;
135 pid_t main_pid
, control_pid
;
138 bool socket_fd_selinux_context_net
;
140 bool permissions_start_only
;
141 bool root_directory_start_only
;
142 bool remain_after_exit
;
145 /* If we shut down, remember why */
146 ServiceResult result
;
147 ServiceResult reload_result
;
149 bool main_pid_known
:1;
150 bool main_pid_alien
:1;
151 bool bus_name_good
:1;
152 bool forbid_restart
:1;
153 /* Keep restart intention between UNIT_FAILED and UNIT_ACTIVATING */
154 bool will_auto_restart
:1;
155 bool start_timeout_defined
:1;
159 char *bus_name_owner
; /* unique name of the current owner */
164 UnitRef accept_socket
;
166 sd_event_source
*timer_event_source
;
167 PathSpec
*pid_file_pathspec
;
169 NotifyAccess notify_access
;
170 NotifyState notify_state
;
172 sd_event_source
*exec_fd_event_source
;
174 ServiceFDStore
*fd_store
;
176 unsigned n_fd_store_max
;
177 unsigned n_keep_fd_store
;
179 char *usb_function_descriptors
;
180 char *usb_function_strings
;
187 bool flush_n_restarts
;
189 OOMPolicy oom_policy
;
192 extern const UnitVTable service_vtable
;
194 int service_set_socket_fd(Service
*s
, int fd
, struct Socket
*socket
, bool selinux_context_net
);
195 void service_close_socket_fd(Service
*s
);
197 const char* service_restart_to_string(ServiceRestart i
) _const_
;
198 ServiceRestart
service_restart_from_string(const char *s
) _pure_
;
200 const char* service_type_to_string(ServiceType i
) _const_
;
201 ServiceType
service_type_from_string(const char *s
) _pure_
;
203 const char* service_exec_command_to_string(ServiceExecCommand i
) _const_
;
204 ServiceExecCommand
service_exec_command_from_string(const char *s
) _pure_
;
206 const char* notify_state_to_string(NotifyState i
) _const_
;
207 NotifyState
notify_state_from_string(const char *s
) _pure_
;
209 const char* service_result_to_string(ServiceResult i
) _const_
;
210 ServiceResult
service_result_from_string(const char *s
) _pure_
;
212 DEFINE_CAST(SERVICE
, Service
);
214 #define STATUS_TEXT_MAX (16U*1024U)