1 /* SPDX-License-Identifier: LGPL-2.1+ */
11 #include "sd-messages.h"
13 #include "all-units.h"
14 #include "alloc-util.h"
15 #include "bpf-firewall.h"
16 #include "bus-common-errors.h"
18 #include "cgroup-util.h"
19 #include "dbus-unit.h"
25 #include "fileio-label.h"
27 #include "format-util.h"
29 #include "id128-util.h"
32 #include "load-dropin.h"
33 #include "load-fragment.h"
38 #include "parse-util.h"
39 #include "path-util.h"
40 #include "process-util.h"
42 #include "serialize.h"
44 #include "signal-util.h"
45 #include "sparse-endian.h"
47 #include "specifier.h"
48 #include "stat-util.h"
49 #include "stdio-util.h"
50 #include "string-table.h"
51 #include "string-util.h"
53 #include "terminal-util.h"
54 #include "tmpfile-util.h"
55 #include "umask-util.h"
56 #include "unit-name.h"
58 #include "user-util.h"
61 /* Thresholds for logging at INFO level about resource consumption */
62 #define MENTIONWORTHY_CPU_NSEC (1 * NSEC_PER_SEC)
63 #define MENTIONWORTHY_IO_BYTES (1024 * 1024ULL)
64 #define MENTIONWORTHY_IP_BYTES (0ULL)
66 /* Thresholds for logging at INFO level about resource consumption */
67 #define NOTICEWORTHY_CPU_NSEC (10*60 * NSEC_PER_SEC) /* 10 minutes */
68 #define NOTICEWORTHY_IO_BYTES (10 * 1024 * 1024ULL) /* 10 MB */
69 #define NOTICEWORTHY_IP_BYTES (128 * 1024 * 1024ULL) /* 128 MB */
71 const UnitVTable
* const unit_vtable
[_UNIT_TYPE_MAX
] = {
72 [UNIT_SERVICE
] = &service_vtable
,
73 [UNIT_SOCKET
] = &socket_vtable
,
74 [UNIT_TARGET
] = &target_vtable
,
75 [UNIT_DEVICE
] = &device_vtable
,
76 [UNIT_MOUNT
] = &mount_vtable
,
77 [UNIT_AUTOMOUNT
] = &automount_vtable
,
78 [UNIT_SWAP
] = &swap_vtable
,
79 [UNIT_TIMER
] = &timer_vtable
,
80 [UNIT_PATH
] = &path_vtable
,
81 [UNIT_SLICE
] = &slice_vtable
,
82 [UNIT_SCOPE
] = &scope_vtable
,
85 static void maybe_warn_about_dependency(Unit
*u
, const char *other
, UnitDependency dependency
);
87 Unit
*unit_new(Manager
*m
, size_t size
) {
91 assert(size
>= sizeof(Unit
));
97 u
->names
= set_new(&string_hash_ops
);
102 u
->type
= _UNIT_TYPE_INVALID
;
103 u
->default_dependencies
= true;
104 u
->unit_file_state
= _UNIT_FILE_STATE_INVALID
;
105 u
->unit_file_preset
= -1;
106 u
->on_failure_job_mode
= JOB_REPLACE
;
107 u
->cgroup_control_inotify_wd
= -1;
108 u
->cgroup_memory_inotify_wd
= -1;
109 u
->job_timeout
= USEC_INFINITY
;
110 u
->job_running_timeout
= USEC_INFINITY
;
111 u
->ref_uid
= UID_INVALID
;
112 u
->ref_gid
= GID_INVALID
;
113 u
->cpu_usage_last
= NSEC_INFINITY
;
114 u
->cgroup_invalidated_mask
|= CGROUP_MASK_BPF_FIREWALL
;
115 u
->failure_action_exit_status
= u
->success_action_exit_status
= -1;
117 u
->ip_accounting_ingress_map_fd
= -1;
118 u
->ip_accounting_egress_map_fd
= -1;
119 u
->ipv4_allow_map_fd
= -1;
120 u
->ipv6_allow_map_fd
= -1;
121 u
->ipv4_deny_map_fd
= -1;
122 u
->ipv6_deny_map_fd
= -1;
124 u
->last_section_private
= -1;
126 u
->start_ratelimit
= (RateLimit
) { m
->default_start_limit_interval
, m
->default_start_limit_burst
};
127 u
->auto_stop_ratelimit
= (RateLimit
) { 10 * USEC_PER_SEC
, 16 };
129 for (CGroupIOAccountingMetric i
= 0; i
< _CGROUP_IO_ACCOUNTING_METRIC_MAX
; i
++)
130 u
->io_accounting_last
[i
] = UINT64_MAX
;
135 int unit_new_for_name(Manager
*m
, size_t size
, const char *name
, Unit
**ret
) {
136 _cleanup_(unit_freep
) Unit
*u
= NULL
;
139 u
= unit_new(m
, size
);
143 r
= unit_add_name(u
, name
);
152 bool unit_has_name(const Unit
*u
, const char *name
) {
156 return set_contains(u
->names
, (char*) name
);
159 static void unit_init(Unit
*u
) {
166 assert(u
->type
>= 0);
168 cc
= unit_get_cgroup_context(u
);
170 cgroup_context_init(cc
);
172 /* Copy in the manager defaults into the cgroup
173 * context, _before_ the rest of the settings have
174 * been initialized */
176 cc
->cpu_accounting
= u
->manager
->default_cpu_accounting
;
177 cc
->io_accounting
= u
->manager
->default_io_accounting
;
178 cc
->blockio_accounting
= u
->manager
->default_blockio_accounting
;
179 cc
->memory_accounting
= u
->manager
->default_memory_accounting
;
180 cc
->tasks_accounting
= u
->manager
->default_tasks_accounting
;
181 cc
->ip_accounting
= u
->manager
->default_ip_accounting
;
183 if (u
->type
!= UNIT_SLICE
)
184 cc
->tasks_max
= u
->manager
->default_tasks_max
;
187 ec
= unit_get_exec_context(u
);
189 exec_context_init(ec
);
191 ec
->keyring_mode
= MANAGER_IS_SYSTEM(u
->manager
) ?
192 EXEC_KEYRING_SHARED
: EXEC_KEYRING_INHERIT
;
195 kc
= unit_get_kill_context(u
);
197 kill_context_init(kc
);
199 if (UNIT_VTABLE(u
)->init
)
200 UNIT_VTABLE(u
)->init(u
);
203 int unit_add_name(Unit
*u
, const char *text
) {
204 _cleanup_free_
char *s
= NULL
, *i
= NULL
;
211 if (unit_name_is_valid(text
, UNIT_NAME_TEMPLATE
)) {
216 r
= unit_name_replace_instance(text
, u
->instance
, &s
);
225 if (set_contains(u
->names
, s
))
227 if (hashmap_contains(u
->manager
->units
, s
))
230 if (!unit_name_is_valid(s
, UNIT_NAME_PLAIN
|UNIT_NAME_INSTANCE
))
233 t
= unit_name_to_type(s
);
237 if (u
->type
!= _UNIT_TYPE_INVALID
&& t
!= u
->type
)
240 r
= unit_name_to_instance(s
, &i
);
244 if (i
&& !unit_type_may_template(t
))
247 /* Ensure that this unit is either instanced or not instanced,
248 * but not both. Note that we do allow names with different
249 * instance names however! */
250 if (u
->type
!= _UNIT_TYPE_INVALID
&& !u
->instance
!= !i
)
253 if (!unit_type_may_alias(t
) && !set_isempty(u
->names
))
256 if (hashmap_size(u
->manager
->units
) >= MANAGER_MAX_NAMES
)
259 r
= set_put(u
->names
, s
);
264 r
= hashmap_put(u
->manager
->units
, s
, u
);
266 (void) set_remove(u
->names
, s
);
270 if (u
->type
== _UNIT_TYPE_INVALID
) {
273 u
->instance
= TAKE_PTR(i
);
275 LIST_PREPEND(units_by_type
, u
->manager
->units_by_type
[t
], u
);
282 unit_add_to_dbus_queue(u
);
286 int unit_choose_id(Unit
*u
, const char *name
) {
287 _cleanup_free_
char *t
= NULL
;
294 if (unit_name_is_valid(name
, UNIT_NAME_TEMPLATE
)) {
299 r
= unit_name_replace_instance(name
, u
->instance
, &t
);
306 /* Selects one of the names of this unit as the id */
307 s
= set_get(u
->names
, (char*) name
);
311 /* Determine the new instance from the new id */
312 r
= unit_name_to_instance(s
, &i
);
321 unit_add_to_dbus_queue(u
);
326 int unit_set_description(Unit
*u
, const char *description
) {
331 r
= free_and_strdup(&u
->description
, empty_to_null(description
));
335 unit_add_to_dbus_queue(u
);
340 bool unit_may_gc(Unit
*u
) {
341 UnitActiveState state
;
346 /* Checks whether the unit is ready to be unloaded for garbage collection.
347 * Returns true when the unit may be collected, and false if there's some
348 * reason to keep it loaded.
350 * References from other units are *not* checked here. Instead, this is done
351 * in unit_gc_sweep(), but using markers to properly collect dependency loops.
360 state
= unit_active_state(u
);
362 /* If the unit is inactive and failed and no job is queued for it, then release its runtime resources */
363 if (UNIT_IS_INACTIVE_OR_FAILED(state
) &&
364 UNIT_VTABLE(u
)->release_resources
)
365 UNIT_VTABLE(u
)->release_resources(u
);
370 if (sd_bus_track_count(u
->bus_track
) > 0)
373 /* But we keep the unit object around for longer when it is referenced or configured to not be gc'ed */
374 switch (u
->collect_mode
) {
376 case COLLECT_INACTIVE
:
377 if (state
!= UNIT_INACTIVE
)
382 case COLLECT_INACTIVE_OR_FAILED
:
383 if (!IN_SET(state
, UNIT_INACTIVE
, UNIT_FAILED
))
389 assert_not_reached("Unknown garbage collection mode");
392 if (u
->cgroup_path
) {
393 /* If the unit has a cgroup, then check whether there's anything in it. If so, we should stay
394 * around. Units with active processes should never be collected. */
396 r
= cg_is_empty_recursive(SYSTEMD_CGROUP_CONTROLLER
, u
->cgroup_path
);
398 log_unit_debug_errno(u
, r
, "Failed to determine whether cgroup %s is empty: %m", u
->cgroup_path
);
403 if (UNIT_VTABLE(u
)->may_gc
&& !UNIT_VTABLE(u
)->may_gc(u
))
409 void unit_add_to_load_queue(Unit
*u
) {
411 assert(u
->type
!= _UNIT_TYPE_INVALID
);
413 if (u
->load_state
!= UNIT_STUB
|| u
->in_load_queue
)
416 LIST_PREPEND(load_queue
, u
->manager
->load_queue
, u
);
417 u
->in_load_queue
= true;
420 void unit_add_to_cleanup_queue(Unit
*u
) {
423 if (u
->in_cleanup_queue
)
426 LIST_PREPEND(cleanup_queue
, u
->manager
->cleanup_queue
, u
);
427 u
->in_cleanup_queue
= true;
430 void unit_add_to_gc_queue(Unit
*u
) {
433 if (u
->in_gc_queue
|| u
->in_cleanup_queue
)
439 LIST_PREPEND(gc_queue
, u
->manager
->gc_unit_queue
, u
);
440 u
->in_gc_queue
= true;
443 void unit_add_to_dbus_queue(Unit
*u
) {
445 assert(u
->type
!= _UNIT_TYPE_INVALID
);
447 if (u
->load_state
== UNIT_STUB
|| u
->in_dbus_queue
)
450 /* Shortcut things if nobody cares */
451 if (sd_bus_track_count(u
->manager
->subscribed
) <= 0 &&
452 sd_bus_track_count(u
->bus_track
) <= 0 &&
453 set_isempty(u
->manager
->private_buses
)) {
454 u
->sent_dbus_new_signal
= true;
458 LIST_PREPEND(dbus_queue
, u
->manager
->dbus_unit_queue
, u
);
459 u
->in_dbus_queue
= true;
462 void unit_submit_to_stop_when_unneeded_queue(Unit
*u
) {
465 if (u
->in_stop_when_unneeded_queue
)
468 if (!u
->stop_when_unneeded
)
471 if (!UNIT_IS_ACTIVE_OR_RELOADING(unit_active_state(u
)))
474 LIST_PREPEND(stop_when_unneeded_queue
, u
->manager
->stop_when_unneeded_queue
, u
);
475 u
->in_stop_when_unneeded_queue
= true;
478 static void bidi_set_free(Unit
*u
, Hashmap
*h
) {
485 /* Frees the hashmap and makes sure we are dropped from the inverse pointers */
487 HASHMAP_FOREACH_KEY(v
, other
, h
, i
) {
490 for (d
= 0; d
< _UNIT_DEPENDENCY_MAX
; d
++)
491 hashmap_remove(other
->dependencies
[d
], u
);
493 unit_add_to_gc_queue(other
);
499 static void unit_remove_transient(Unit
*u
) {
507 if (u
->fragment_path
)
508 (void) unlink(u
->fragment_path
);
510 STRV_FOREACH(i
, u
->dropin_paths
) {
511 _cleanup_free_
char *p
= NULL
, *pp
= NULL
;
513 p
= dirname_malloc(*i
); /* Get the drop-in directory from the drop-in file */
517 pp
= dirname_malloc(p
); /* Get the config directory from the drop-in directory */
521 /* Only drop transient drop-ins */
522 if (!path_equal(u
->manager
->lookup_paths
.transient
, pp
))
530 static void unit_free_requires_mounts_for(Unit
*u
) {
534 _cleanup_free_
char *path
;
536 path
= hashmap_steal_first_key(u
->requires_mounts_for
);
540 char s
[strlen(path
) + 1];
542 PATH_FOREACH_PREFIX_MORE(s
, path
) {
546 x
= hashmap_get2(u
->manager
->units_requiring_mounts_for
, s
, (void**) &y
);
550 (void) set_remove(x
, u
);
552 if (set_isempty(x
)) {
553 (void) hashmap_remove(u
->manager
->units_requiring_mounts_for
, y
);
561 u
->requires_mounts_for
= hashmap_free(u
->requires_mounts_for
);
564 static void unit_done(Unit
*u
) {
573 if (UNIT_VTABLE(u
)->done
)
574 UNIT_VTABLE(u
)->done(u
);
576 ec
= unit_get_exec_context(u
);
578 exec_context_done(ec
);
580 cc
= unit_get_cgroup_context(u
);
582 cgroup_context_done(cc
);
585 void unit_free(Unit
*u
) {
593 if (UNIT_ISSET(u
->slice
)) {
594 /* A unit is being dropped from the tree, make sure our parent slice recalculates the member mask */
595 unit_invalidate_cgroup_members_masks(UNIT_DEREF(u
->slice
));
597 /* And make sure the parent is realized again, updating cgroup memberships */
598 unit_add_to_cgroup_realize_queue(UNIT_DEREF(u
->slice
));
601 u
->transient_file
= safe_fclose(u
->transient_file
);
603 if (!MANAGER_IS_RELOADING(u
->manager
))
604 unit_remove_transient(u
);
606 bus_unit_send_removed_signal(u
);
610 unit_dequeue_rewatch_pids(u
);
612 sd_bus_slot_unref(u
->match_bus_slot
);
613 sd_bus_track_unref(u
->bus_track
);
614 u
->deserialized_refs
= strv_free(u
->deserialized_refs
);
616 unit_free_requires_mounts_for(u
);
618 SET_FOREACH(t
, u
->names
, i
)
619 hashmap_remove_value(u
->manager
->units
, t
, u
);
621 if (!sd_id128_is_null(u
->invocation_id
))
622 hashmap_remove_value(u
->manager
->units_by_invocation_id
, &u
->invocation_id
, u
);
636 for (d
= 0; d
< _UNIT_DEPENDENCY_MAX
; d
++)
637 bidi_set_free(u
, u
->dependencies
[d
]);
640 manager_unref_console(u
->manager
);
642 unit_release_cgroup(u
);
644 if (!MANAGER_IS_RELOADING(u
->manager
))
645 unit_unlink_state_files(u
);
647 unit_unref_uid_gid(u
, false);
649 (void) manager_update_failed_units(u
->manager
, u
, false);
650 set_remove(u
->manager
->startup_units
, u
);
652 unit_unwatch_all_pids(u
);
654 unit_ref_unset(&u
->slice
);
655 while (u
->refs_by_target
)
656 unit_ref_unset(u
->refs_by_target
);
658 if (u
->type
!= _UNIT_TYPE_INVALID
)
659 LIST_REMOVE(units_by_type
, u
->manager
->units_by_type
[u
->type
], u
);
661 if (u
->in_load_queue
)
662 LIST_REMOVE(load_queue
, u
->manager
->load_queue
, u
);
664 if (u
->in_dbus_queue
)
665 LIST_REMOVE(dbus_queue
, u
->manager
->dbus_unit_queue
, u
);
668 LIST_REMOVE(gc_queue
, u
->manager
->gc_unit_queue
, u
);
670 if (u
->in_cgroup_realize_queue
)
671 LIST_REMOVE(cgroup_realize_queue
, u
->manager
->cgroup_realize_queue
, u
);
673 if (u
->in_cgroup_empty_queue
)
674 LIST_REMOVE(cgroup_empty_queue
, u
->manager
->cgroup_empty_queue
, u
);
676 if (u
->in_cleanup_queue
)
677 LIST_REMOVE(cleanup_queue
, u
->manager
->cleanup_queue
, u
);
679 if (u
->in_target_deps_queue
)
680 LIST_REMOVE(target_deps_queue
, u
->manager
->target_deps_queue
, u
);
682 if (u
->in_stop_when_unneeded_queue
)
683 LIST_REMOVE(stop_when_unneeded_queue
, u
->manager
->stop_when_unneeded_queue
, u
);
685 safe_close(u
->ip_accounting_ingress_map_fd
);
686 safe_close(u
->ip_accounting_egress_map_fd
);
688 safe_close(u
->ipv4_allow_map_fd
);
689 safe_close(u
->ipv6_allow_map_fd
);
690 safe_close(u
->ipv4_deny_map_fd
);
691 safe_close(u
->ipv6_deny_map_fd
);
693 bpf_program_unref(u
->ip_bpf_ingress
);
694 bpf_program_unref(u
->ip_bpf_ingress_installed
);
695 bpf_program_unref(u
->ip_bpf_egress
);
696 bpf_program_unref(u
->ip_bpf_egress_installed
);
698 set_free(u
->ip_bpf_custom_ingress
);
699 set_free(u
->ip_bpf_custom_egress
);
700 set_free(u
->ip_bpf_custom_ingress_installed
);
701 set_free(u
->ip_bpf_custom_egress_installed
);
703 bpf_program_unref(u
->bpf_device_control_installed
);
705 condition_free_list(u
->conditions
);
706 condition_free_list(u
->asserts
);
708 free(u
->description
);
709 strv_free(u
->documentation
);
710 free(u
->fragment_path
);
711 free(u
->source_path
);
712 strv_free(u
->dropin_paths
);
715 free(u
->job_timeout_reboot_arg
);
717 set_free_free(u
->names
);
724 UnitActiveState
unit_active_state(Unit
*u
) {
727 if (u
->load_state
== UNIT_MERGED
)
728 return unit_active_state(unit_follow_merge(u
));
730 /* After a reload it might happen that a unit is not correctly
731 * loaded but still has a process around. That's why we won't
732 * shortcut failed loading to UNIT_INACTIVE_FAILED. */
734 return UNIT_VTABLE(u
)->active_state(u
);
737 const char* unit_sub_state_to_string(Unit
*u
) {
740 return UNIT_VTABLE(u
)->sub_state_to_string(u
);
743 static int set_complete_move(Set
**s
, Set
**other
) {
751 return set_move(*s
, *other
);
753 *s
= TAKE_PTR(*other
);
758 static int hashmap_complete_move(Hashmap
**s
, Hashmap
**other
) {
766 return hashmap_move(*s
, *other
);
768 *s
= TAKE_PTR(*other
);
773 static int merge_names(Unit
*u
, Unit
*other
) {
781 r
= set_complete_move(&u
->names
, &other
->names
);
785 set_free_free(other
->names
);
789 SET_FOREACH(t
, u
->names
, i
)
790 assert_se(hashmap_replace(u
->manager
->units
, t
, u
) == 0);
795 static int reserve_dependencies(Unit
*u
, Unit
*other
, UnitDependency d
) {
800 assert(d
< _UNIT_DEPENDENCY_MAX
);
803 * If u does not have this dependency set allocated, there is no need
804 * to reserve anything. In that case other's set will be transferred
805 * as a whole to u by complete_move().
807 if (!u
->dependencies
[d
])
810 /* merge_dependencies() will skip a u-on-u dependency */
811 n_reserve
= hashmap_size(other
->dependencies
[d
]) - !!hashmap_get(other
->dependencies
[d
], u
);
813 return hashmap_reserve(u
->dependencies
[d
], n_reserve
);
816 static void merge_dependencies(Unit
*u
, Unit
*other
, const char *other_id
, UnitDependency d
) {
822 /* Merges all dependencies of type 'd' of the unit 'other' into the deps of the unit 'u' */
826 assert(d
< _UNIT_DEPENDENCY_MAX
);
828 /* Fix backwards pointers. Let's iterate through all dependent units of the other unit. */
829 HASHMAP_FOREACH_KEY(v
, back
, other
->dependencies
[d
], i
) {
832 /* Let's now iterate through the dependencies of that dependencies of the other units, looking for
833 * pointers back, and let's fix them up, to instead point to 'u'. */
835 for (k
= 0; k
< _UNIT_DEPENDENCY_MAX
; k
++) {
837 /* Do not add dependencies between u and itself. */
838 if (hashmap_remove(back
->dependencies
[k
], other
))
839 maybe_warn_about_dependency(u
, other_id
, k
);
841 UnitDependencyInfo di_u
, di_other
, di_merged
;
843 /* Let's drop this dependency between "back" and "other", and let's create it between
844 * "back" and "u" instead. Let's merge the bit masks of the dependency we are moving,
845 * and any such dependency which might already exist */
847 di_other
.data
= hashmap_get(back
->dependencies
[k
], other
);
849 continue; /* dependency isn't set, let's try the next one */
851 di_u
.data
= hashmap_get(back
->dependencies
[k
], u
);
853 di_merged
= (UnitDependencyInfo
) {
854 .origin_mask
= di_u
.origin_mask
| di_other
.origin_mask
,
855 .destination_mask
= di_u
.destination_mask
| di_other
.destination_mask
,
858 r
= hashmap_remove_and_replace(back
->dependencies
[k
], other
, u
, di_merged
.data
);
860 log_warning_errno(r
, "Failed to remove/replace: back=%s other=%s u=%s: %m", back
->id
, other_id
, u
->id
);
863 /* assert_se(hashmap_remove_and_replace(back->dependencies[k], other, u, di_merged.data) >= 0); */
869 /* Also do not move dependencies on u to itself */
870 back
= hashmap_remove(other
->dependencies
[d
], u
);
872 maybe_warn_about_dependency(u
, other_id
, d
);
874 /* The move cannot fail. The caller must have performed a reservation. */
875 assert_se(hashmap_complete_move(&u
->dependencies
[d
], &other
->dependencies
[d
]) == 0);
877 other
->dependencies
[d
] = hashmap_free(other
->dependencies
[d
]);
880 int unit_merge(Unit
*u
, Unit
*other
) {
882 const char *other_id
= NULL
;
887 assert(u
->manager
== other
->manager
);
888 assert(u
->type
!= _UNIT_TYPE_INVALID
);
890 other
= unit_follow_merge(other
);
895 if (u
->type
!= other
->type
)
898 if (!u
->instance
!= !other
->instance
)
901 if (!unit_type_may_alias(u
->type
)) /* Merging only applies to unit names that support aliases */
904 if (!IN_SET(other
->load_state
, UNIT_STUB
, UNIT_NOT_FOUND
))
913 if (!UNIT_IS_INACTIVE_OR_FAILED(unit_active_state(other
)))
917 other_id
= strdupa(other
->id
);
919 /* Make reservations to ensure merge_dependencies() won't fail */
920 for (d
= 0; d
< _UNIT_DEPENDENCY_MAX
; d
++) {
921 r
= reserve_dependencies(u
, other
, d
);
923 * We don't rollback reservations if we fail. We don't have
924 * a way to undo reservations. A reservation is not a leak.
931 r
= merge_names(u
, other
);
935 /* Redirect all references */
936 while (other
->refs_by_target
)
937 unit_ref_set(other
->refs_by_target
, other
->refs_by_target
->source
, u
);
939 /* Merge dependencies */
940 for (d
= 0; d
< _UNIT_DEPENDENCY_MAX
; d
++)
941 merge_dependencies(u
, other
, other_id
, d
);
943 other
->load_state
= UNIT_MERGED
;
944 other
->merged_into
= u
;
946 /* If there is still some data attached to the other node, we
947 * don't need it anymore, and can free it. */
948 if (other
->load_state
!= UNIT_STUB
)
949 if (UNIT_VTABLE(other
)->done
)
950 UNIT_VTABLE(other
)->done(other
);
952 unit_add_to_dbus_queue(u
);
953 unit_add_to_cleanup_queue(other
);
958 int unit_merge_by_name(Unit
*u
, const char *name
) {
959 _cleanup_free_
char *s
= NULL
;
963 /* Either add name to u, or if a unit with name already exists, merge it with u.
964 * If name is a template, do the same for name@instance, where instance is u's instance. */
969 if (unit_name_is_valid(name
, UNIT_NAME_TEMPLATE
)) {
973 r
= unit_name_replace_instance(name
, u
->instance
, &s
);
980 other
= manager_get_unit(u
->manager
, name
);
982 return unit_merge(u
, other
);
984 return unit_add_name(u
, name
);
987 Unit
* unit_follow_merge(Unit
*u
) {
990 while (u
->load_state
== UNIT_MERGED
)
991 assert_se(u
= u
->merged_into
);
996 int unit_add_exec_dependencies(Unit
*u
, ExecContext
*c
) {
997 ExecDirectoryType dt
;
1004 if (c
->working_directory
&& !c
->working_directory_missing_ok
) {
1005 r
= unit_require_mounts_for(u
, c
->working_directory
, UNIT_DEPENDENCY_FILE
);
1010 if (c
->root_directory
) {
1011 r
= unit_require_mounts_for(u
, c
->root_directory
, UNIT_DEPENDENCY_FILE
);
1016 if (c
->root_image
) {
1017 r
= unit_require_mounts_for(u
, c
->root_image
, UNIT_DEPENDENCY_FILE
);
1022 for (dt
= 0; dt
< _EXEC_DIRECTORY_TYPE_MAX
; dt
++) {
1023 if (!u
->manager
->prefix
[dt
])
1026 STRV_FOREACH(dp
, c
->directories
[dt
].paths
) {
1027 _cleanup_free_
char *p
;
1029 p
= path_join(u
->manager
->prefix
[dt
], *dp
);
1033 r
= unit_require_mounts_for(u
, p
, UNIT_DEPENDENCY_FILE
);
1039 if (!MANAGER_IS_SYSTEM(u
->manager
))
1042 if (c
->private_tmp
) {
1045 FOREACH_STRING(p
, "/tmp", "/var/tmp") {
1046 r
= unit_require_mounts_for(u
, p
, UNIT_DEPENDENCY_FILE
);
1051 r
= unit_add_dependency_by_name(u
, UNIT_AFTER
, SPECIAL_TMPFILES_SETUP_SERVICE
, true, UNIT_DEPENDENCY_FILE
);
1056 if (!IN_SET(c
->std_output
,
1057 EXEC_OUTPUT_JOURNAL
, EXEC_OUTPUT_JOURNAL_AND_CONSOLE
,
1058 EXEC_OUTPUT_KMSG
, EXEC_OUTPUT_KMSG_AND_CONSOLE
,
1059 EXEC_OUTPUT_SYSLOG
, EXEC_OUTPUT_SYSLOG_AND_CONSOLE
) &&
1060 !IN_SET(c
->std_error
,
1061 EXEC_OUTPUT_JOURNAL
, EXEC_OUTPUT_JOURNAL_AND_CONSOLE
,
1062 EXEC_OUTPUT_KMSG
, EXEC_OUTPUT_KMSG_AND_CONSOLE
,
1063 EXEC_OUTPUT_SYSLOG
, EXEC_OUTPUT_SYSLOG_AND_CONSOLE
))
1066 /* If syslog or kernel logging is requested, make sure our own
1067 * logging daemon is run first. */
1069 r
= unit_add_dependency_by_name(u
, UNIT_AFTER
, SPECIAL_JOURNALD_SOCKET
, true, UNIT_DEPENDENCY_FILE
);
1076 const char *unit_description(Unit
*u
) {
1080 return u
->description
;
1082 return strna(u
->id
);
1085 const char *unit_status_string(Unit
*u
) {
1088 if (u
->manager
->status_unit_format
== STATUS_UNIT_FORMAT_NAME
&& u
->id
)
1091 return unit_description(u
);
1094 static void print_unit_dependency_mask(FILE *f
, const char *kind
, UnitDependencyMask mask
, bool *space
) {
1096 UnitDependencyMask mask
;
1099 { UNIT_DEPENDENCY_FILE
, "file" },
1100 { UNIT_DEPENDENCY_IMPLICIT
, "implicit" },
1101 { UNIT_DEPENDENCY_DEFAULT
, "default" },
1102 { UNIT_DEPENDENCY_UDEV
, "udev" },
1103 { UNIT_DEPENDENCY_PATH
, "path" },
1104 { UNIT_DEPENDENCY_MOUNTINFO_IMPLICIT
, "mountinfo-implicit" },
1105 { UNIT_DEPENDENCY_MOUNTINFO_DEFAULT
, "mountinfo-default" },
1106 { UNIT_DEPENDENCY_PROC_SWAP
, "proc-swap" },
1114 for (i
= 0; i
< ELEMENTSOF(table
); i
++) {
1119 if (FLAGS_SET(mask
, table
[i
].mask
)) {
1127 fputs(table
[i
].name
, f
);
1129 mask
&= ~table
[i
].mask
;
1136 void unit_dump(Unit
*u
, FILE *f
, const char *prefix
) {
1140 const char *prefix2
;
1141 char timestamp
[5][FORMAT_TIMESTAMP_MAX
], timespan
[FORMAT_TIMESPAN_MAX
];
1143 _cleanup_set_free_ Set
*following_set
= NULL
;
1149 assert(u
->type
>= 0);
1151 prefix
= strempty(prefix
);
1152 prefix2
= strjoina(prefix
, "\t");
1158 SET_FOREACH(t
, u
->names
, i
)
1159 if (!streq(t
, u
->id
))
1160 fprintf(f
, "%s\tAlias: %s\n", prefix
, t
);
1163 "%s\tDescription: %s\n"
1164 "%s\tInstance: %s\n"
1165 "%s\tUnit Load State: %s\n"
1166 "%s\tUnit Active State: %s\n"
1167 "%s\tState Change Timestamp: %s\n"
1168 "%s\tInactive Exit Timestamp: %s\n"
1169 "%s\tActive Enter Timestamp: %s\n"
1170 "%s\tActive Exit Timestamp: %s\n"
1171 "%s\tInactive Enter Timestamp: %s\n"
1173 "%s\tNeed Daemon Reload: %s\n"
1174 "%s\tTransient: %s\n"
1175 "%s\tPerpetual: %s\n"
1176 "%s\tGarbage Collection Mode: %s\n"
1179 "%s\tCGroup realized: %s\n",
1180 prefix
, unit_description(u
),
1181 prefix
, strna(u
->instance
),
1182 prefix
, unit_load_state_to_string(u
->load_state
),
1183 prefix
, unit_active_state_to_string(unit_active_state(u
)),
1184 prefix
, strna(format_timestamp(timestamp
[0], sizeof(timestamp
[0]), u
->state_change_timestamp
.realtime
)),
1185 prefix
, strna(format_timestamp(timestamp
[1], sizeof(timestamp
[1]), u
->inactive_exit_timestamp
.realtime
)),
1186 prefix
, strna(format_timestamp(timestamp
[2], sizeof(timestamp
[2]), u
->active_enter_timestamp
.realtime
)),
1187 prefix
, strna(format_timestamp(timestamp
[3], sizeof(timestamp
[3]), u
->active_exit_timestamp
.realtime
)),
1188 prefix
, strna(format_timestamp(timestamp
[4], sizeof(timestamp
[4]), u
->inactive_enter_timestamp
.realtime
)),
1189 prefix
, yes_no(unit_may_gc(u
)),
1190 prefix
, yes_no(unit_need_daemon_reload(u
)),
1191 prefix
, yes_no(u
->transient
),
1192 prefix
, yes_no(u
->perpetual
),
1193 prefix
, collect_mode_to_string(u
->collect_mode
),
1194 prefix
, strna(unit_slice_name(u
)),
1195 prefix
, strna(u
->cgroup_path
),
1196 prefix
, yes_no(u
->cgroup_realized
));
1198 if (u
->cgroup_realized_mask
!= 0) {
1199 _cleanup_free_
char *s
= NULL
;
1200 (void) cg_mask_to_string(u
->cgroup_realized_mask
, &s
);
1201 fprintf(f
, "%s\tCGroup realized mask: %s\n", prefix
, strnull(s
));
1204 if (u
->cgroup_enabled_mask
!= 0) {
1205 _cleanup_free_
char *s
= NULL
;
1206 (void) cg_mask_to_string(u
->cgroup_enabled_mask
, &s
);
1207 fprintf(f
, "%s\tCGroup enabled mask: %s\n", prefix
, strnull(s
));
1210 m
= unit_get_own_mask(u
);
1212 _cleanup_free_
char *s
= NULL
;
1213 (void) cg_mask_to_string(m
, &s
);
1214 fprintf(f
, "%s\tCGroup own mask: %s\n", prefix
, strnull(s
));
1217 m
= unit_get_members_mask(u
);
1219 _cleanup_free_
char *s
= NULL
;
1220 (void) cg_mask_to_string(m
, &s
);
1221 fprintf(f
, "%s\tCGroup members mask: %s\n", prefix
, strnull(s
));
1224 m
= unit_get_delegate_mask(u
);
1226 _cleanup_free_
char *s
= NULL
;
1227 (void) cg_mask_to_string(m
, &s
);
1228 fprintf(f
, "%s\tCGroup delegate mask: %s\n", prefix
, strnull(s
));
1231 if (!sd_id128_is_null(u
->invocation_id
))
1232 fprintf(f
, "%s\tInvocation ID: " SD_ID128_FORMAT_STR
"\n",
1233 prefix
, SD_ID128_FORMAT_VAL(u
->invocation_id
));
1235 STRV_FOREACH(j
, u
->documentation
)
1236 fprintf(f
, "%s\tDocumentation: %s\n", prefix
, *j
);
1238 following
= unit_following(u
);
1240 fprintf(f
, "%s\tFollowing: %s\n", prefix
, following
->id
);
1242 r
= unit_following_set(u
, &following_set
);
1246 SET_FOREACH(other
, following_set
, i
)
1247 fprintf(f
, "%s\tFollowing Set Member: %s\n", prefix
, other
->id
);
1250 if (u
->fragment_path
)
1251 fprintf(f
, "%s\tFragment Path: %s\n", prefix
, u
->fragment_path
);
1254 fprintf(f
, "%s\tSource Path: %s\n", prefix
, u
->source_path
);
1256 STRV_FOREACH(j
, u
->dropin_paths
)
1257 fprintf(f
, "%s\tDropIn Path: %s\n", prefix
, *j
);
1259 if (u
->failure_action
!= EMERGENCY_ACTION_NONE
)
1260 fprintf(f
, "%s\tFailure Action: %s\n", prefix
, emergency_action_to_string(u
->failure_action
));
1261 if (u
->failure_action_exit_status
>= 0)
1262 fprintf(f
, "%s\tFailure Action Exit Status: %i\n", prefix
, u
->failure_action_exit_status
);
1263 if (u
->success_action
!= EMERGENCY_ACTION_NONE
)
1264 fprintf(f
, "%s\tSuccess Action: %s\n", prefix
, emergency_action_to_string(u
->success_action
));
1265 if (u
->success_action_exit_status
>= 0)
1266 fprintf(f
, "%s\tSuccess Action Exit Status: %i\n", prefix
, u
->success_action_exit_status
);
1268 if (u
->job_timeout
!= USEC_INFINITY
)
1269 fprintf(f
, "%s\tJob Timeout: %s\n", prefix
, format_timespan(timespan
, sizeof(timespan
), u
->job_timeout
, 0));
1271 if (u
->job_timeout_action
!= EMERGENCY_ACTION_NONE
)
1272 fprintf(f
, "%s\tJob Timeout Action: %s\n", prefix
, emergency_action_to_string(u
->job_timeout_action
));
1274 if (u
->job_timeout_reboot_arg
)
1275 fprintf(f
, "%s\tJob Timeout Reboot Argument: %s\n", prefix
, u
->job_timeout_reboot_arg
);
1277 condition_dump_list(u
->conditions
, f
, prefix
, condition_type_to_string
);
1278 condition_dump_list(u
->asserts
, f
, prefix
, assert_type_to_string
);
1280 if (dual_timestamp_is_set(&u
->condition_timestamp
))
1282 "%s\tCondition Timestamp: %s\n"
1283 "%s\tCondition Result: %s\n",
1284 prefix
, strna(format_timestamp(timestamp
[0], sizeof(timestamp
[0]), u
->condition_timestamp
.realtime
)),
1285 prefix
, yes_no(u
->condition_result
));
1287 if (dual_timestamp_is_set(&u
->assert_timestamp
))
1289 "%s\tAssert Timestamp: %s\n"
1290 "%s\tAssert Result: %s\n",
1291 prefix
, strna(format_timestamp(timestamp
[0], sizeof(timestamp
[0]), u
->assert_timestamp
.realtime
)),
1292 prefix
, yes_no(u
->assert_result
));
1294 for (d
= 0; d
< _UNIT_DEPENDENCY_MAX
; d
++) {
1295 UnitDependencyInfo di
;
1298 HASHMAP_FOREACH_KEY(di
.data
, other
, u
->dependencies
[d
], i
) {
1301 fprintf(f
, "%s\t%s: %s (", prefix
, unit_dependency_to_string(d
), other
->id
);
1303 print_unit_dependency_mask(f
, "origin", di
.origin_mask
, &space
);
1304 print_unit_dependency_mask(f
, "destination", di
.destination_mask
, &space
);
1310 if (!hashmap_isempty(u
->requires_mounts_for
)) {
1311 UnitDependencyInfo di
;
1314 HASHMAP_FOREACH_KEY(di
.data
, path
, u
->requires_mounts_for
, i
) {
1317 fprintf(f
, "%s\tRequiresMountsFor: %s (", prefix
, path
);
1319 print_unit_dependency_mask(f
, "origin", di
.origin_mask
, &space
);
1320 print_unit_dependency_mask(f
, "destination", di
.destination_mask
, &space
);
1326 if (u
->load_state
== UNIT_LOADED
) {
1329 "%s\tStopWhenUnneeded: %s\n"
1330 "%s\tRefuseManualStart: %s\n"
1331 "%s\tRefuseManualStop: %s\n"
1332 "%s\tDefaultDependencies: %s\n"
1333 "%s\tOnFailureJobMode: %s\n"
1334 "%s\tIgnoreOnIsolate: %s\n",
1335 prefix
, yes_no(u
->stop_when_unneeded
),
1336 prefix
, yes_no(u
->refuse_manual_start
),
1337 prefix
, yes_no(u
->refuse_manual_stop
),
1338 prefix
, yes_no(u
->default_dependencies
),
1339 prefix
, job_mode_to_string(u
->on_failure_job_mode
),
1340 prefix
, yes_no(u
->ignore_on_isolate
));
1342 if (UNIT_VTABLE(u
)->dump
)
1343 UNIT_VTABLE(u
)->dump(u
, f
, prefix2
);
1345 } else if (u
->load_state
== UNIT_MERGED
)
1347 "%s\tMerged into: %s\n",
1348 prefix
, u
->merged_into
->id
);
1349 else if (u
->load_state
== UNIT_ERROR
)
1350 fprintf(f
, "%s\tLoad Error Code: %s\n", prefix
, strerror_safe(u
->load_error
));
1352 for (n
= sd_bus_track_first(u
->bus_track
); n
; n
= sd_bus_track_next(u
->bus_track
))
1353 fprintf(f
, "%s\tBus Ref: %s\n", prefix
, n
);
1356 job_dump(u
->job
, f
, prefix2
);
1359 job_dump(u
->nop_job
, f
, prefix2
);
1362 /* Common implementation for multiple backends */
1363 int unit_load_fragment_and_dropin(Unit
*u
) {
1368 /* Load a .{service,socket,...} file */
1369 r
= unit_load_fragment(u
);
1373 if (u
->load_state
== UNIT_STUB
)
1376 /* Load drop-in directory data. If u is an alias, we might be reloading the
1377 * target unit needlessly. But we cannot be sure which drops-ins have already
1378 * been loaded and which not, at least without doing complicated book-keeping,
1379 * so let's always reread all drop-ins. */
1380 return unit_load_dropin(unit_follow_merge(u
));
1383 /* Common implementation for multiple backends */
1384 int unit_load_fragment_and_dropin_optional(Unit
*u
) {
1389 /* Same as unit_load_fragment_and_dropin(), but whether
1390 * something can be loaded or not doesn't matter. */
1392 /* Load a .service/.socket/.slice/… file */
1393 r
= unit_load_fragment(u
);
1397 if (u
->load_state
== UNIT_STUB
)
1398 u
->load_state
= UNIT_LOADED
;
1400 /* Load drop-in directory data */
1401 return unit_load_dropin(unit_follow_merge(u
));
1404 void unit_add_to_target_deps_queue(Unit
*u
) {
1405 Manager
*m
= u
->manager
;
1409 if (u
->in_target_deps_queue
)
1412 LIST_PREPEND(target_deps_queue
, m
->target_deps_queue
, u
);
1413 u
->in_target_deps_queue
= true;
1416 int unit_add_default_target_dependency(Unit
*u
, Unit
*target
) {
1420 if (target
->type
!= UNIT_TARGET
)
1423 /* Only add the dependency if both units are loaded, so that
1424 * that loop check below is reliable */
1425 if (u
->load_state
!= UNIT_LOADED
||
1426 target
->load_state
!= UNIT_LOADED
)
1429 /* If either side wants no automatic dependencies, then let's
1431 if (!u
->default_dependencies
||
1432 !target
->default_dependencies
)
1435 /* Don't create loops */
1436 if (hashmap_get(target
->dependencies
[UNIT_BEFORE
], u
))
1439 return unit_add_dependency(target
, UNIT_AFTER
, u
, true, UNIT_DEPENDENCY_DEFAULT
);
1442 static int unit_add_slice_dependencies(Unit
*u
) {
1443 UnitDependencyMask mask
;
1446 if (!UNIT_HAS_CGROUP_CONTEXT(u
))
1449 /* Slice units are implicitly ordered against their parent slices (as this relationship is encoded in the
1450 name), while all other units are ordered based on configuration (as in their case Slice= configures the
1452 mask
= u
->type
== UNIT_SLICE
? UNIT_DEPENDENCY_IMPLICIT
: UNIT_DEPENDENCY_FILE
;
1454 if (UNIT_ISSET(u
->slice
))
1455 return unit_add_two_dependencies(u
, UNIT_AFTER
, UNIT_REQUIRES
, UNIT_DEREF(u
->slice
), true, mask
);
1457 if (unit_has_name(u
, SPECIAL_ROOT_SLICE
))
1460 return unit_add_two_dependencies_by_name(u
, UNIT_AFTER
, UNIT_REQUIRES
, SPECIAL_ROOT_SLICE
, true, mask
);
1463 static int unit_add_mount_dependencies(Unit
*u
) {
1464 UnitDependencyInfo di
;
1471 HASHMAP_FOREACH_KEY(di
.data
, path
, u
->requires_mounts_for
, i
) {
1472 char prefix
[strlen(path
) + 1];
1474 PATH_FOREACH_PREFIX_MORE(prefix
, path
) {
1475 _cleanup_free_
char *p
= NULL
;
1478 r
= unit_name_from_path(prefix
, ".mount", &p
);
1482 m
= manager_get_unit(u
->manager
, p
);
1484 /* Make sure to load the mount unit if
1485 * it exists. If so the dependencies
1486 * on this unit will be added later
1487 * during the loading of the mount
1489 (void) manager_load_unit_prepare(u
->manager
, p
, NULL
, NULL
, &m
);
1495 if (m
->load_state
!= UNIT_LOADED
)
1498 r
= unit_add_dependency(u
, UNIT_AFTER
, m
, true, di
.origin_mask
);
1502 if (m
->fragment_path
) {
1503 r
= unit_add_dependency(u
, UNIT_REQUIRES
, m
, true, di
.origin_mask
);
1513 static int unit_add_startup_units(Unit
*u
) {
1517 c
= unit_get_cgroup_context(u
);
1521 if (c
->startup_cpu_shares
== CGROUP_CPU_SHARES_INVALID
&&
1522 c
->startup_io_weight
== CGROUP_WEIGHT_INVALID
&&
1523 c
->startup_blockio_weight
== CGROUP_BLKIO_WEIGHT_INVALID
)
1526 r
= set_ensure_allocated(&u
->manager
->startup_units
, NULL
);
1530 return set_put(u
->manager
->startup_units
, u
);
1533 int unit_load(Unit
*u
) {
1538 if (u
->in_load_queue
) {
1539 LIST_REMOVE(load_queue
, u
->manager
->load_queue
, u
);
1540 u
->in_load_queue
= false;
1543 if (u
->type
== _UNIT_TYPE_INVALID
)
1546 if (u
->load_state
!= UNIT_STUB
)
1549 if (u
->transient_file
) {
1550 /* Finalize transient file: if this is a transient unit file, as soon as we reach unit_load() the setup
1551 * is complete, hence let's synchronize the unit file we just wrote to disk. */
1553 r
= fflush_and_check(u
->transient_file
);
1557 u
->transient_file
= safe_fclose(u
->transient_file
);
1558 u
->fragment_mtime
= now(CLOCK_REALTIME
);
1561 if (UNIT_VTABLE(u
)->load
) {
1562 r
= UNIT_VTABLE(u
)->load(u
);
1567 if (u
->load_state
== UNIT_STUB
) {
1572 if (u
->load_state
== UNIT_LOADED
) {
1573 unit_add_to_target_deps_queue(u
);
1575 r
= unit_add_slice_dependencies(u
);
1579 r
= unit_add_mount_dependencies(u
);
1583 r
= unit_add_startup_units(u
);
1587 if (u
->on_failure_job_mode
== JOB_ISOLATE
&& hashmap_size(u
->dependencies
[UNIT_ON_FAILURE
]) > 1) {
1588 log_unit_error(u
, "More than one OnFailure= dependencies specified but OnFailureJobMode=isolate set. Refusing.");
1593 if (u
->job_running_timeout
!= USEC_INFINITY
&& u
->job_running_timeout
> u
->job_timeout
)
1594 log_unit_warning(u
, "JobRunningTimeoutSec= is greater than JobTimeoutSec=, it has no effect.");
1596 /* We finished loading, let's ensure our parents recalculate the members mask */
1597 unit_invalidate_cgroup_members_masks(u
);
1600 assert((u
->load_state
!= UNIT_MERGED
) == !u
->merged_into
);
1602 unit_add_to_dbus_queue(unit_follow_merge(u
));
1603 unit_add_to_gc_queue(u
);
1608 /* We convert ENOEXEC errors to the UNIT_BAD_SETTING load state here. Configuration parsing code should hence
1609 * return ENOEXEC to ensure units are placed in this state after loading */
1611 u
->load_state
= u
->load_state
== UNIT_STUB
? UNIT_NOT_FOUND
:
1612 r
== -ENOEXEC
? UNIT_BAD_SETTING
:
1616 unit_add_to_dbus_queue(u
);
1617 unit_add_to_gc_queue(u
);
1619 return log_unit_debug_errno(u
, r
, "Failed to load configuration: %m");
1623 static int log_unit_internal(void *userdata
, int level
, int error
, const char *file
, int line
, const char *func
, const char *format
, ...) {
1628 va_start(ap
, format
);
1630 r
= log_object_internalv(level
, error
, file
, line
, func
,
1631 u
->manager
->unit_log_field
,
1633 u
->manager
->invocation_log_field
,
1634 u
->invocation_id_string
,
1637 r
= log_internalv(level
, error
, file
, line
, func
, format
, ap
);
1643 static bool unit_test_condition(Unit
*u
) {
1646 dual_timestamp_get(&u
->condition_timestamp
);
1647 u
->condition_result
= condition_test_list(u
->conditions
, condition_type_to_string
, log_unit_internal
, u
);
1649 unit_add_to_dbus_queue(u
);
1651 return u
->condition_result
;
1654 static bool unit_test_assert(Unit
*u
) {
1657 dual_timestamp_get(&u
->assert_timestamp
);
1658 u
->assert_result
= condition_test_list(u
->asserts
, assert_type_to_string
, log_unit_internal
, u
);
1660 unit_add_to_dbus_queue(u
);
1662 return u
->assert_result
;
1665 void unit_status_printf(Unit
*u
, const char *status
, const char *unit_status_msg_format
) {
1668 d
= unit_status_string(u
);
1669 if (log_get_show_color())
1670 d
= strjoina(ANSI_HIGHLIGHT
, d
, ANSI_NORMAL
);
1672 DISABLE_WARNING_FORMAT_NONLITERAL
;
1673 manager_status_printf(u
->manager
, STATUS_TYPE_NORMAL
, status
, unit_status_msg_format
, d
);
1677 int unit_test_start_limit(Unit
*u
) {
1682 if (ratelimit_below(&u
->start_ratelimit
)) {
1683 u
->start_limit_hit
= false;
1687 log_unit_warning(u
, "Start request repeated too quickly.");
1688 u
->start_limit_hit
= true;
1690 reason
= strjoina("unit ", u
->id
, " failed");
1692 emergency_action(u
->manager
, u
->start_limit_action
,
1693 EMERGENCY_ACTION_IS_WATCHDOG
|EMERGENCY_ACTION_WARN
,
1694 u
->reboot_arg
, -1, reason
);
1699 bool unit_shall_confirm_spawn(Unit
*u
) {
1702 if (manager_is_confirm_spawn_disabled(u
->manager
))
1705 /* For some reasons units remaining in the same process group
1706 * as PID 1 fail to acquire the console even if it's not used
1707 * by any process. So skip the confirmation question for them. */
1708 return !unit_get_exec_context(u
)->same_pgrp
;
1711 static bool unit_verify_deps(Unit
*u
) {
1718 /* Checks whether all BindsTo= dependencies of this unit are fulfilled — if they are also combined with
1719 * After=. We do not check Requires= or Requisite= here as they only should have an effect on the job
1720 * processing, but do not have any effect afterwards. We don't check BindsTo= dependencies that are not used in
1721 * conjunction with After= as for them any such check would make things entirely racy. */
1723 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[UNIT_BINDS_TO
], j
) {
1725 if (!hashmap_contains(u
->dependencies
[UNIT_AFTER
], other
))
1728 if (!UNIT_IS_ACTIVE_OR_RELOADING(unit_active_state(other
))) {
1729 log_unit_notice(u
, "Bound to unit %s, but unit isn't active.", other
->id
);
1737 /* Errors that aren't really errors:
1738 * -EALREADY: Unit is already started.
1739 * -ECOMM: Condition failed
1740 * -EAGAIN: An operation is already in progress. Retry later.
1742 * Errors that are real errors:
1743 * -EBADR: This unit type does not support starting.
1744 * -ECANCELED: Start limit hit, too many requests for now
1745 * -EPROTO: Assert failed
1746 * -EINVAL: Unit not loaded
1747 * -EOPNOTSUPP: Unit type not supported
1748 * -ENOLINK: The necessary dependencies are not fulfilled.
1749 * -ESTALE: This unit has been started before and can't be started a second time
1750 * -ENOENT: This is a triggering unit and unit to trigger is not loaded
1752 int unit_start(Unit
*u
) {
1753 UnitActiveState state
;
1758 /* If this is already started, then this will succeed. Note that this will even succeed if this unit
1759 * is not startable by the user. This is relied on to detect when we need to wait for units and when
1760 * waiting is finished. */
1761 state
= unit_active_state(u
);
1762 if (UNIT_IS_ACTIVE_OR_RELOADING(state
))
1764 if (state
== UNIT_MAINTENANCE
)
1767 /* Units that aren't loaded cannot be started */
1768 if (u
->load_state
!= UNIT_LOADED
)
1771 /* Refuse starting scope units more than once */
1772 if (UNIT_VTABLE(u
)->once_only
&& dual_timestamp_is_set(&u
->inactive_enter_timestamp
))
1775 /* If the conditions failed, don't do anything at all. If we already are activating this call might
1776 * still be useful to speed up activation in case there is some hold-off time, but we don't want to
1777 * recheck the condition in that case. */
1778 if (state
!= UNIT_ACTIVATING
&&
1779 !unit_test_condition(u
))
1780 return log_unit_debug_errno(u
, SYNTHETIC_ERRNO(ECOMM
), "Starting requested but condition failed. Not starting unit.");
1782 /* If the asserts failed, fail the entire job */
1783 if (state
!= UNIT_ACTIVATING
&&
1784 !unit_test_assert(u
))
1785 return log_unit_notice_errno(u
, SYNTHETIC_ERRNO(EPROTO
), "Starting requested but asserts failed.");
1787 /* Units of types that aren't supported cannot be started. Note that we do this test only after the
1788 * condition checks, so that we rather return condition check errors (which are usually not
1789 * considered a true failure) than "not supported" errors (which are considered a failure).
1791 if (!unit_type_supported(u
->type
))
1794 /* Let's make sure that the deps really are in order before we start this. Normally the job engine
1795 * should have taken care of this already, but let's check this here again. After all, our
1796 * dependencies might not be in effect anymore, due to a reload or due to a failed condition. */
1797 if (!unit_verify_deps(u
))
1800 /* Forward to the main object, if we aren't it. */
1801 following
= unit_following(u
);
1803 log_unit_debug(u
, "Redirecting start request from %s to %s.", u
->id
, following
->id
);
1804 return unit_start(following
);
1807 /* If it is stopped, but we cannot start it, then fail */
1808 if (!UNIT_VTABLE(u
)->start
)
1811 /* We don't suppress calls to ->start() here when we are already starting, to allow this request to
1812 * be used as a "hurry up" call, for example when the unit is in some "auto restart" state where it
1813 * waits for a holdoff timer to elapse before it will start again. */
1815 unit_add_to_dbus_queue(u
);
1817 return UNIT_VTABLE(u
)->start(u
);
1820 bool unit_can_start(Unit
*u
) {
1823 if (u
->load_state
!= UNIT_LOADED
)
1826 if (!unit_type_supported(u
->type
))
1829 /* Scope units may be started only once */
1830 if (UNIT_VTABLE(u
)->once_only
&& dual_timestamp_is_set(&u
->inactive_exit_timestamp
))
1833 return !!UNIT_VTABLE(u
)->start
;
1836 bool unit_can_isolate(Unit
*u
) {
1839 return unit_can_start(u
) &&
1844 * -EBADR: This unit type does not support stopping.
1845 * -EALREADY: Unit is already stopped.
1846 * -EAGAIN: An operation is already in progress. Retry later.
1848 int unit_stop(Unit
*u
) {
1849 UnitActiveState state
;
1854 state
= unit_active_state(u
);
1855 if (UNIT_IS_INACTIVE_OR_FAILED(state
))
1858 following
= unit_following(u
);
1860 log_unit_debug(u
, "Redirecting stop request from %s to %s.", u
->id
, following
->id
);
1861 return unit_stop(following
);
1864 if (!UNIT_VTABLE(u
)->stop
)
1867 unit_add_to_dbus_queue(u
);
1869 return UNIT_VTABLE(u
)->stop(u
);
1872 bool unit_can_stop(Unit
*u
) {
1875 if (!unit_type_supported(u
->type
))
1881 return !!UNIT_VTABLE(u
)->stop
;
1885 * -EBADR: This unit type does not support reloading.
1886 * -ENOEXEC: Unit is not started.
1887 * -EAGAIN: An operation is already in progress. Retry later.
1889 int unit_reload(Unit
*u
) {
1890 UnitActiveState state
;
1895 if (u
->load_state
!= UNIT_LOADED
)
1898 if (!unit_can_reload(u
))
1901 state
= unit_active_state(u
);
1902 if (state
== UNIT_RELOADING
)
1905 if (state
!= UNIT_ACTIVE
) {
1906 log_unit_warning(u
, "Unit cannot be reloaded because it is inactive.");
1910 following
= unit_following(u
);
1912 log_unit_debug(u
, "Redirecting reload request from %s to %s.", u
->id
, following
->id
);
1913 return unit_reload(following
);
1916 unit_add_to_dbus_queue(u
);
1918 if (!UNIT_VTABLE(u
)->reload
) {
1919 /* Unit doesn't have a reload function, but we need to propagate the reload anyway */
1920 unit_notify(u
, unit_active_state(u
), unit_active_state(u
), 0);
1924 return UNIT_VTABLE(u
)->reload(u
);
1927 bool unit_can_reload(Unit
*u
) {
1930 if (UNIT_VTABLE(u
)->can_reload
)
1931 return UNIT_VTABLE(u
)->can_reload(u
);
1933 if (!hashmap_isempty(u
->dependencies
[UNIT_PROPAGATES_RELOAD_TO
]))
1936 return UNIT_VTABLE(u
)->reload
;
1939 bool unit_is_unneeded(Unit
*u
) {
1940 static const UnitDependency deps
[] = {
1950 if (!u
->stop_when_unneeded
)
1953 /* Don't clean up while the unit is transitioning or is even inactive. */
1954 if (!UNIT_IS_ACTIVE_OR_RELOADING(unit_active_state(u
)))
1959 for (j
= 0; j
< ELEMENTSOF(deps
); j
++) {
1964 /* If a dependent unit has a job queued, is active or transitioning, or is marked for
1965 * restart, then don't clean this one up. */
1967 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[deps
[j
]], i
) {
1971 if (!UNIT_IS_INACTIVE_OR_FAILED(unit_active_state(other
)))
1974 if (unit_will_restart(other
))
1982 static void check_unneeded_dependencies(Unit
*u
) {
1984 static const UnitDependency deps
[] = {
1994 /* Add all units this unit depends on to the queue that processes StopWhenUnneeded= behaviour. */
1996 for (j
= 0; j
< ELEMENTSOF(deps
); j
++) {
2001 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[deps
[j
]], i
)
2002 unit_submit_to_stop_when_unneeded_queue(other
);
2006 static void unit_check_binds_to(Unit
*u
) {
2007 _cleanup_(sd_bus_error_free
) sd_bus_error error
= SD_BUS_ERROR_NULL
;
2019 if (unit_active_state(u
) != UNIT_ACTIVE
)
2022 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[UNIT_BINDS_TO
], i
) {
2026 if (!other
->coldplugged
)
2027 /* We might yet create a job for the other unit… */
2030 if (!UNIT_IS_INACTIVE_OR_FAILED(unit_active_state(other
)))
2040 /* If stopping a unit fails continuously we might enter a stop
2041 * loop here, hence stop acting on the service being
2042 * unnecessary after a while. */
2043 if (!ratelimit_below(&u
->auto_stop_ratelimit
)) {
2044 log_unit_warning(u
, "Unit is bound to inactive unit %s, but not stopping since we tried this too often recently.", other
->id
);
2049 log_unit_info(u
, "Unit is bound to inactive unit %s. Stopping, too.", other
->id
);
2051 /* A unit we need to run is gone. Sniff. Let's stop this. */
2052 r
= manager_add_job(u
->manager
, JOB_STOP
, u
, JOB_FAIL
, NULL
, &error
, NULL
);
2054 log_unit_warning_errno(u
, r
, "Failed to enqueue stop job, ignoring: %s", bus_error_message(&error
, r
));
2057 static void retroactively_start_dependencies(Unit
*u
) {
2063 assert(UNIT_IS_ACTIVE_OR_ACTIVATING(unit_active_state(u
)));
2065 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[UNIT_REQUIRES
], i
)
2066 if (!hashmap_get(u
->dependencies
[UNIT_AFTER
], other
) &&
2067 !UNIT_IS_ACTIVE_OR_ACTIVATING(unit_active_state(other
)))
2068 manager_add_job(u
->manager
, JOB_START
, other
, JOB_REPLACE
, NULL
, NULL
, NULL
);
2070 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[UNIT_BINDS_TO
], i
)
2071 if (!hashmap_get(u
->dependencies
[UNIT_AFTER
], other
) &&
2072 !UNIT_IS_ACTIVE_OR_ACTIVATING(unit_active_state(other
)))
2073 manager_add_job(u
->manager
, JOB_START
, other
, JOB_REPLACE
, NULL
, NULL
, NULL
);
2075 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[UNIT_WANTS
], i
)
2076 if (!hashmap_get(u
->dependencies
[UNIT_AFTER
], other
) &&
2077 !UNIT_IS_ACTIVE_OR_ACTIVATING(unit_active_state(other
)))
2078 manager_add_job(u
->manager
, JOB_START
, other
, JOB_FAIL
, NULL
, NULL
, NULL
);
2080 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[UNIT_CONFLICTS
], i
)
2081 if (!UNIT_IS_INACTIVE_OR_DEACTIVATING(unit_active_state(other
)))
2082 manager_add_job(u
->manager
, JOB_STOP
, other
, JOB_REPLACE
, NULL
, NULL
, NULL
);
2084 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[UNIT_CONFLICTED_BY
], i
)
2085 if (!UNIT_IS_INACTIVE_OR_DEACTIVATING(unit_active_state(other
)))
2086 manager_add_job(u
->manager
, JOB_STOP
, other
, JOB_REPLACE
, NULL
, NULL
, NULL
);
2089 static void retroactively_stop_dependencies(Unit
*u
) {
2095 assert(UNIT_IS_INACTIVE_OR_DEACTIVATING(unit_active_state(u
)));
2097 /* Pull down units which are bound to us recursively if enabled */
2098 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[UNIT_BOUND_BY
], i
)
2099 if (!UNIT_IS_INACTIVE_OR_DEACTIVATING(unit_active_state(other
)))
2100 manager_add_job(u
->manager
, JOB_STOP
, other
, JOB_REPLACE
, NULL
, NULL
, NULL
);
2103 void unit_start_on_failure(Unit
*u
) {
2111 if (hashmap_size(u
->dependencies
[UNIT_ON_FAILURE
]) <= 0)
2114 log_unit_info(u
, "Triggering OnFailure= dependencies.");
2116 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[UNIT_ON_FAILURE
], i
) {
2117 _cleanup_(sd_bus_error_free
) sd_bus_error error
= SD_BUS_ERROR_NULL
;
2119 r
= manager_add_job(u
->manager
, JOB_START
, other
, u
->on_failure_job_mode
, NULL
, &error
, NULL
);
2121 log_unit_warning_errno(u
, r
, "Failed to enqueue OnFailure= job, ignoring: %s", bus_error_message(&error
, r
));
2125 void unit_trigger_notify(Unit
*u
) {
2132 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[UNIT_TRIGGERED_BY
], i
)
2133 if (UNIT_VTABLE(other
)->trigger_notify
)
2134 UNIT_VTABLE(other
)->trigger_notify(other
, u
);
2137 static int raise_level(int log_level
, bool condition_info
, bool condition_notice
) {
2138 if (condition_notice
&& log_level
> LOG_NOTICE
)
2140 if (condition_info
&& log_level
> LOG_INFO
)
2145 static int unit_log_resources(Unit
*u
) {
2146 struct iovec iovec
[1 + _CGROUP_IP_ACCOUNTING_METRIC_MAX
+ _CGROUP_IO_ACCOUNTING_METRIC_MAX
+ 4];
2147 bool any_traffic
= false, have_ip_accounting
= false, any_io
= false, have_io_accounting
= false;
2148 _cleanup_free_
char *igress
= NULL
, *egress
= NULL
, *rr
= NULL
, *wr
= NULL
;
2149 int log_level
= LOG_DEBUG
; /* May be raised if resources consumed over a treshold */
2150 size_t n_message_parts
= 0, n_iovec
= 0;
2151 char* message_parts
[1 + 2 + 2 + 1], *t
;
2152 nsec_t nsec
= NSEC_INFINITY
;
2153 CGroupIPAccountingMetric m
;
2156 const char* const ip_fields
[_CGROUP_IP_ACCOUNTING_METRIC_MAX
] = {
2157 [CGROUP_IP_INGRESS_BYTES
] = "IP_METRIC_INGRESS_BYTES",
2158 [CGROUP_IP_INGRESS_PACKETS
] = "IP_METRIC_INGRESS_PACKETS",
2159 [CGROUP_IP_EGRESS_BYTES
] = "IP_METRIC_EGRESS_BYTES",
2160 [CGROUP_IP_EGRESS_PACKETS
] = "IP_METRIC_EGRESS_PACKETS",
2162 const char* const io_fields
[_CGROUP_IO_ACCOUNTING_METRIC_MAX
] = {
2163 [CGROUP_IO_READ_BYTES
] = "IO_METRIC_READ_BYTES",
2164 [CGROUP_IO_WRITE_BYTES
] = "IO_METRIC_WRITE_BYTES",
2165 [CGROUP_IO_READ_OPERATIONS
] = "IO_METRIC_READ_OPERATIONS",
2166 [CGROUP_IO_WRITE_OPERATIONS
] = "IO_METRIC_WRITE_OPERATIONS",
2171 /* Invoked whenever a unit enters failed or dead state. Logs information about consumed resources if resource
2172 * accounting was enabled for a unit. It does this in two ways: a friendly human readable string with reduced
2173 * information and the complete data in structured fields. */
2175 (void) unit_get_cpu_usage(u
, &nsec
);
2176 if (nsec
!= NSEC_INFINITY
) {
2177 char buf
[FORMAT_TIMESPAN_MAX
] = "";
2179 /* Format the CPU time for inclusion in the structured log message */
2180 if (asprintf(&t
, "CPU_USAGE_NSEC=%" PRIu64
, nsec
) < 0) {
2184 iovec
[n_iovec
++] = IOVEC_MAKE_STRING(t
);
2186 /* Format the CPU time for inclusion in the human language message string */
2187 format_timespan(buf
, sizeof(buf
), nsec
/ NSEC_PER_USEC
, USEC_PER_MSEC
);
2188 t
= strjoin("consumed ", buf
, " CPU time");
2194 message_parts
[n_message_parts
++] = t
;
2196 log_level
= raise_level(log_level
,
2197 nsec
> NOTICEWORTHY_CPU_NSEC
,
2198 nsec
> MENTIONWORTHY_CPU_NSEC
);
2201 for (CGroupIOAccountingMetric k
= 0; k
< _CGROUP_IO_ACCOUNTING_METRIC_MAX
; k
++) {
2202 char buf
[FORMAT_BYTES_MAX
] = "";
2203 uint64_t value
= UINT64_MAX
;
2205 assert(io_fields
[k
]);
2207 (void) unit_get_io_accounting(u
, k
, k
> 0, &value
);
2208 if (value
== UINT64_MAX
)
2211 have_io_accounting
= true;
2215 /* Format IO accounting data for inclusion in the structured log message */
2216 if (asprintf(&t
, "%s=%" PRIu64
, io_fields
[k
], value
) < 0) {
2220 iovec
[n_iovec
++] = IOVEC_MAKE_STRING(t
);
2222 /* Format the IO accounting data for inclusion in the human language message string, but only
2223 * for the bytes counters (and not for the operations counters) */
2224 if (k
== CGROUP_IO_READ_BYTES
) {
2226 rr
= strjoin("read ", format_bytes(buf
, sizeof(buf
), value
), " from disk");
2231 } else if (k
== CGROUP_IO_WRITE_BYTES
) {
2233 wr
= strjoin("written ", format_bytes(buf
, sizeof(buf
), value
), " to disk");
2240 if (IN_SET(k
, CGROUP_IO_READ_BYTES
, CGROUP_IO_WRITE_BYTES
))
2241 log_level
= raise_level(log_level
,
2242 value
> MENTIONWORTHY_IO_BYTES
,
2243 value
> NOTICEWORTHY_IO_BYTES
);
2246 if (have_io_accounting
) {
2249 message_parts
[n_message_parts
++] = TAKE_PTR(rr
);
2251 message_parts
[n_message_parts
++] = TAKE_PTR(wr
);
2256 k
= strdup("no IO");
2262 message_parts
[n_message_parts
++] = k
;
2266 for (m
= 0; m
< _CGROUP_IP_ACCOUNTING_METRIC_MAX
; m
++) {
2267 char buf
[FORMAT_BYTES_MAX
] = "";
2268 uint64_t value
= UINT64_MAX
;
2270 assert(ip_fields
[m
]);
2272 (void) unit_get_ip_accounting(u
, m
, &value
);
2273 if (value
== UINT64_MAX
)
2276 have_ip_accounting
= true;
2280 /* Format IP accounting data for inclusion in the structured log message */
2281 if (asprintf(&t
, "%s=%" PRIu64
, ip_fields
[m
], value
) < 0) {
2285 iovec
[n_iovec
++] = IOVEC_MAKE_STRING(t
);
2287 /* Format the IP accounting data for inclusion in the human language message string, but only for the
2288 * bytes counters (and not for the packets counters) */
2289 if (m
== CGROUP_IP_INGRESS_BYTES
) {
2291 igress
= strjoin("received ", format_bytes(buf
, sizeof(buf
), value
), " IP traffic");
2296 } else if (m
== CGROUP_IP_EGRESS_BYTES
) {
2298 egress
= strjoin("sent ", format_bytes(buf
, sizeof(buf
), value
), " IP traffic");
2305 if (IN_SET(m
, CGROUP_IP_INGRESS_BYTES
, CGROUP_IP_EGRESS_BYTES
))
2306 log_level
= raise_level(log_level
,
2307 value
> MENTIONWORTHY_IP_BYTES
,
2308 value
> NOTICEWORTHY_IP_BYTES
);
2311 if (have_ip_accounting
) {
2314 message_parts
[n_message_parts
++] = TAKE_PTR(igress
);
2316 message_parts
[n_message_parts
++] = TAKE_PTR(egress
);
2321 k
= strdup("no IP traffic");
2327 message_parts
[n_message_parts
++] = k
;
2331 /* Is there any accounting data available at all? */
2337 if (n_message_parts
== 0)
2338 t
= strjoina("MESSAGE=", u
->id
, ": Completed.");
2340 _cleanup_free_
char *joined
;
2342 message_parts
[n_message_parts
] = NULL
;
2344 joined
= strv_join(message_parts
, ", ");
2350 joined
[0] = ascii_toupper(joined
[0]);
2351 t
= strjoina("MESSAGE=", u
->id
, ": ", joined
, ".");
2354 /* The following four fields we allocate on the stack or are static strings, we hence don't want to free them,
2355 * and hence don't increase n_iovec for them */
2356 iovec
[n_iovec
] = IOVEC_MAKE_STRING(t
);
2357 iovec
[n_iovec
+ 1] = IOVEC_MAKE_STRING("MESSAGE_ID=" SD_MESSAGE_UNIT_RESOURCES_STR
);
2359 t
= strjoina(u
->manager
->unit_log_field
, u
->id
);
2360 iovec
[n_iovec
+ 2] = IOVEC_MAKE_STRING(t
);
2362 t
= strjoina(u
->manager
->invocation_log_field
, u
->invocation_id_string
);
2363 iovec
[n_iovec
+ 3] = IOVEC_MAKE_STRING(t
);
2365 log_struct_iovec(log_level
, iovec
, n_iovec
+ 4);
2369 for (i
= 0; i
< n_message_parts
; i
++)
2370 free(message_parts
[i
]);
2372 for (i
= 0; i
< n_iovec
; i
++)
2373 free(iovec
[i
].iov_base
);
2379 static void unit_update_on_console(Unit
*u
) {
2384 b
= unit_needs_console(u
);
2385 if (u
->on_console
== b
)
2390 manager_ref_console(u
->manager
);
2392 manager_unref_console(u
->manager
);
2395 static void unit_emit_audit_start(Unit
*u
) {
2398 if (u
->type
!= UNIT_SERVICE
)
2401 /* Write audit record if we have just finished starting up */
2402 manager_send_unit_audit(u
->manager
, u
, AUDIT_SERVICE_START
, true);
2406 static void unit_emit_audit_stop(Unit
*u
, UnitActiveState state
) {
2409 if (u
->type
!= UNIT_SERVICE
)
2413 /* Write audit record if we have just finished shutting down */
2414 manager_send_unit_audit(u
->manager
, u
, AUDIT_SERVICE_STOP
, state
== UNIT_INACTIVE
);
2415 u
->in_audit
= false;
2417 /* Hmm, if there was no start record written write it now, so that we always have a nice pair */
2418 manager_send_unit_audit(u
->manager
, u
, AUDIT_SERVICE_START
, state
== UNIT_INACTIVE
);
2420 if (state
== UNIT_INACTIVE
)
2421 manager_send_unit_audit(u
->manager
, u
, AUDIT_SERVICE_STOP
, true);
2425 static bool unit_process_job(Job
*j
, UnitActiveState ns
, UnitNotifyFlags flags
) {
2426 bool unexpected
= false;
2431 if (j
->state
== JOB_WAITING
)
2433 /* So we reached a different state for this job. Let's see if we can run it now if it failed previously
2435 job_add_to_run_queue(j
);
2437 /* Let's check whether the unit's new state constitutes a finished job, or maybe contradicts a running job and
2438 * hence needs to invalidate jobs. */
2443 case JOB_VERIFY_ACTIVE
:
2445 if (UNIT_IS_ACTIVE_OR_RELOADING(ns
))
2446 job_finish_and_invalidate(j
, JOB_DONE
, true, false);
2447 else if (j
->state
== JOB_RUNNING
&& ns
!= UNIT_ACTIVATING
) {
2450 if (UNIT_IS_INACTIVE_OR_FAILED(ns
)) {
2451 if (ns
== UNIT_FAILED
)
2452 result
= JOB_FAILED
;
2453 else if (FLAGS_SET(flags
, UNIT_NOTIFY_SKIP_CONDITION
))
2454 result
= JOB_SKIPPED
;
2458 job_finish_and_invalidate(j
, result
, true, false);
2465 case JOB_RELOAD_OR_START
:
2466 case JOB_TRY_RELOAD
:
2468 if (j
->state
== JOB_RUNNING
) {
2469 if (ns
== UNIT_ACTIVE
)
2470 job_finish_and_invalidate(j
, (flags
& UNIT_NOTIFY_RELOAD_FAILURE
) ? JOB_FAILED
: JOB_DONE
, true, false);
2471 else if (!IN_SET(ns
, UNIT_ACTIVATING
, UNIT_RELOADING
)) {
2474 if (UNIT_IS_INACTIVE_OR_FAILED(ns
))
2475 job_finish_and_invalidate(j
, ns
== UNIT_FAILED
? JOB_FAILED
: JOB_DONE
, true, false);
2483 case JOB_TRY_RESTART
:
2485 if (UNIT_IS_INACTIVE_OR_FAILED(ns
))
2486 job_finish_and_invalidate(j
, JOB_DONE
, true, false);
2487 else if (j
->state
== JOB_RUNNING
&& ns
!= UNIT_DEACTIVATING
) {
2489 job_finish_and_invalidate(j
, JOB_FAILED
, true, false);
2495 assert_not_reached("Job type unknown");
2501 void unit_notify(Unit
*u
, UnitActiveState os
, UnitActiveState ns
, UnitNotifyFlags flags
) {
2506 assert(os
< _UNIT_ACTIVE_STATE_MAX
);
2507 assert(ns
< _UNIT_ACTIVE_STATE_MAX
);
2509 /* Note that this is called for all low-level state changes, even if they might map to the same high-level
2510 * UnitActiveState! That means that ns == os is an expected behavior here. For example: if a mount point is
2511 * remounted this function will be called too! */
2515 /* Let's enqueue the change signal early. In case this unit has a job associated we want that this unit is in
2516 * the bus queue, so that any job change signal queued will force out the unit change signal first. */
2517 unit_add_to_dbus_queue(u
);
2519 /* Update timestamps for state changes */
2520 if (!MANAGER_IS_RELOADING(m
)) {
2521 dual_timestamp_get(&u
->state_change_timestamp
);
2523 if (UNIT_IS_INACTIVE_OR_FAILED(os
) && !UNIT_IS_INACTIVE_OR_FAILED(ns
))
2524 u
->inactive_exit_timestamp
= u
->state_change_timestamp
;
2525 else if (!UNIT_IS_INACTIVE_OR_FAILED(os
) && UNIT_IS_INACTIVE_OR_FAILED(ns
))
2526 u
->inactive_enter_timestamp
= u
->state_change_timestamp
;
2528 if (!UNIT_IS_ACTIVE_OR_RELOADING(os
) && UNIT_IS_ACTIVE_OR_RELOADING(ns
))
2529 u
->active_enter_timestamp
= u
->state_change_timestamp
;
2530 else if (UNIT_IS_ACTIVE_OR_RELOADING(os
) && !UNIT_IS_ACTIVE_OR_RELOADING(ns
))
2531 u
->active_exit_timestamp
= u
->state_change_timestamp
;
2534 /* Keep track of failed units */
2535 (void) manager_update_failed_units(m
, u
, ns
== UNIT_FAILED
);
2537 /* Make sure the cgroup and state files are always removed when we become inactive */
2538 if (UNIT_IS_INACTIVE_OR_FAILED(ns
)) {
2539 unit_prune_cgroup(u
);
2540 unit_unlink_state_files(u
);
2543 unit_update_on_console(u
);
2545 if (!MANAGER_IS_RELOADING(m
)) {
2548 /* Let's propagate state changes to the job */
2550 unexpected
= unit_process_job(u
->job
, ns
, flags
);
2554 /* If this state change happened without being requested by a job, then let's retroactively start or
2555 * stop dependencies. We skip that step when deserializing, since we don't want to create any
2556 * additional jobs just because something is already activated. */
2559 if (UNIT_IS_INACTIVE_OR_FAILED(os
) && UNIT_IS_ACTIVE_OR_ACTIVATING(ns
))
2560 retroactively_start_dependencies(u
);
2561 else if (UNIT_IS_ACTIVE_OR_ACTIVATING(os
) && UNIT_IS_INACTIVE_OR_DEACTIVATING(ns
))
2562 retroactively_stop_dependencies(u
);
2565 /* stop unneeded units regardless if going down was expected or not */
2566 if (UNIT_IS_INACTIVE_OR_FAILED(ns
))
2567 check_unneeded_dependencies(u
);
2569 if (ns
!= os
&& ns
== UNIT_FAILED
) {
2570 log_unit_debug(u
, "Unit entered failed state.");
2572 if (!(flags
& UNIT_NOTIFY_WILL_AUTO_RESTART
))
2573 unit_start_on_failure(u
);
2576 if (UNIT_IS_ACTIVE_OR_RELOADING(ns
) && !UNIT_IS_ACTIVE_OR_RELOADING(os
)) {
2577 /* This unit just finished starting up */
2579 unit_emit_audit_start(u
);
2580 manager_send_unit_plymouth(m
, u
);
2583 if (UNIT_IS_INACTIVE_OR_FAILED(ns
) && !UNIT_IS_INACTIVE_OR_FAILED(os
)) {
2584 /* This unit just stopped/failed. */
2586 unit_emit_audit_stop(u
, ns
);
2587 unit_log_resources(u
);
2591 manager_recheck_journal(m
);
2592 manager_recheck_dbus(m
);
2594 unit_trigger_notify(u
);
2596 if (!MANAGER_IS_RELOADING(m
)) {
2597 /* Maybe we finished startup and are now ready for being stopped because unneeded? */
2598 unit_submit_to_stop_when_unneeded_queue(u
);
2600 /* Maybe we finished startup, but something we needed has vanished? Let's die then. (This happens when
2601 * something BindsTo= to a Type=oneshot unit, as these units go directly from starting to inactive,
2602 * without ever entering started.) */
2603 unit_check_binds_to(u
);
2605 if (os
!= UNIT_FAILED
&& ns
== UNIT_FAILED
) {
2606 reason
= strjoina("unit ", u
->id
, " failed");
2607 emergency_action(m
, u
->failure_action
, 0, u
->reboot_arg
, unit_failure_action_exit_status(u
), reason
);
2608 } else if (!UNIT_IS_INACTIVE_OR_FAILED(os
) && ns
== UNIT_INACTIVE
) {
2609 reason
= strjoina("unit ", u
->id
, " succeeded");
2610 emergency_action(m
, u
->success_action
, 0, u
->reboot_arg
, unit_success_action_exit_status(u
), reason
);
2614 unit_add_to_gc_queue(u
);
2617 int unit_watch_pid(Unit
*u
, pid_t pid
, bool exclusive
) {
2621 assert(pid_is_valid(pid
));
2623 /* Watch a specific PID */
2625 /* Caller might be sure that this PID belongs to this unit only. Let's take this
2626 * opportunity to remove any stalled references to this PID as they can be created
2627 * easily (when watching a process which is not our direct child). */
2629 manager_unwatch_pid(u
->manager
, pid
);
2631 r
= set_ensure_allocated(&u
->pids
, NULL
);
2635 r
= hashmap_ensure_allocated(&u
->manager
->watch_pids
, NULL
);
2639 /* First try, let's add the unit keyed by "pid". */
2640 r
= hashmap_put(u
->manager
->watch_pids
, PID_TO_PTR(pid
), u
);
2646 /* OK, the "pid" key is already assigned to a different unit. Let's see if the "-pid" key (which points
2647 * to an array of Units rather than just a Unit), lists us already. */
2649 array
= hashmap_get(u
->manager
->watch_pids
, PID_TO_PTR(-pid
));
2651 for (; array
[n
]; n
++)
2655 if (found
) /* Found it already? if so, do nothing */
2660 /* Allocate a new array */
2661 new_array
= new(Unit
*, n
+ 2);
2665 memcpy_safe(new_array
, array
, sizeof(Unit
*) * n
);
2667 new_array
[n
+1] = NULL
;
2669 /* Add or replace the old array */
2670 r
= hashmap_replace(u
->manager
->watch_pids
, PID_TO_PTR(-pid
), new_array
);
2681 r
= set_put(u
->pids
, PID_TO_PTR(pid
));
2688 void unit_unwatch_pid(Unit
*u
, pid_t pid
) {
2692 assert(pid_is_valid(pid
));
2694 /* First let's drop the unit in case it's keyed as "pid". */
2695 (void) hashmap_remove_value(u
->manager
->watch_pids
, PID_TO_PTR(pid
), u
);
2697 /* Then, let's also drop the unit, in case it's in the array keyed by -pid */
2698 array
= hashmap_get(u
->manager
->watch_pids
, PID_TO_PTR(-pid
));
2702 /* Let's iterate through the array, dropping our own entry */
2703 for (n
= 0; array
[n
]; n
++)
2705 array
[m
++] = array
[n
];
2709 /* The array is now empty, remove the entire entry */
2710 assert(hashmap_remove(u
->manager
->watch_pids
, PID_TO_PTR(-pid
)) == array
);
2715 (void) set_remove(u
->pids
, PID_TO_PTR(pid
));
2718 void unit_unwatch_all_pids(Unit
*u
) {
2721 while (!set_isempty(u
->pids
))
2722 unit_unwatch_pid(u
, PTR_TO_PID(set_first(u
->pids
)));
2724 u
->pids
= set_free(u
->pids
);
2727 static void unit_tidy_watch_pids(Unit
*u
) {
2728 pid_t except1
, except2
;
2734 /* Cleans dead PIDs from our list */
2736 except1
= unit_main_pid(u
);
2737 except2
= unit_control_pid(u
);
2739 SET_FOREACH(e
, u
->pids
, i
) {
2740 pid_t pid
= PTR_TO_PID(e
);
2742 if (pid
== except1
|| pid
== except2
)
2745 if (!pid_is_unwaited(pid
))
2746 unit_unwatch_pid(u
, pid
);
2750 static int on_rewatch_pids_event(sd_event_source
*s
, void *userdata
) {
2756 unit_tidy_watch_pids(u
);
2757 unit_watch_all_pids(u
);
2759 /* If the PID set is empty now, then let's finish this off. */
2760 unit_synthesize_cgroup_empty_event(u
);
2765 int unit_enqueue_rewatch_pids(Unit
*u
) {
2770 if (!u
->cgroup_path
)
2773 r
= cg_unified_controller(SYSTEMD_CGROUP_CONTROLLER
);
2776 if (r
> 0) /* On unified we can use proper notifications */
2779 /* Enqueues a low-priority job that will clean up dead PIDs from our list of PIDs to watch and subscribe to new
2780 * PIDs that might have appeared. We do this in a delayed job because the work might be quite slow, as it
2781 * involves issuing kill(pid, 0) on all processes we watch. */
2783 if (!u
->rewatch_pids_event_source
) {
2784 _cleanup_(sd_event_source_unrefp
) sd_event_source
*s
= NULL
;
2786 r
= sd_event_add_defer(u
->manager
->event
, &s
, on_rewatch_pids_event
, u
);
2788 return log_error_errno(r
, "Failed to allocate event source for tidying watched PIDs: %m");
2790 r
= sd_event_source_set_priority(s
, SD_EVENT_PRIORITY_IDLE
);
2792 return log_error_errno(r
, "Failed to adjust priority of event source for tidying watched PIDs: %m");
2794 (void) sd_event_source_set_description(s
, "tidy-watch-pids");
2796 u
->rewatch_pids_event_source
= TAKE_PTR(s
);
2799 r
= sd_event_source_set_enabled(u
->rewatch_pids_event_source
, SD_EVENT_ONESHOT
);
2801 return log_error_errno(r
, "Failed to enable event source for tidying watched PIDs: %m");
2806 void unit_dequeue_rewatch_pids(Unit
*u
) {
2810 if (!u
->rewatch_pids_event_source
)
2813 r
= sd_event_source_set_enabled(u
->rewatch_pids_event_source
, SD_EVENT_OFF
);
2815 log_warning_errno(r
, "Failed to disable event source for tidying watched PIDs, ignoring: %m");
2817 u
->rewatch_pids_event_source
= sd_event_source_unref(u
->rewatch_pids_event_source
);
2820 bool unit_job_is_applicable(Unit
*u
, JobType j
) {
2822 assert(j
>= 0 && j
< _JOB_TYPE_MAX
);
2826 case JOB_VERIFY_ACTIVE
:
2829 /* Note that we don't check unit_can_start() here. That's because .device units and suchlike are not
2830 * startable by us but may appear due to external events, and it thus makes sense to permit enqueing
2835 /* Similar as above. However, perpetual units can never be stopped (neither explicitly nor due to
2836 * external events), hence it makes no sense to permit enqueing such a request either. */
2837 return !u
->perpetual
;
2840 case JOB_TRY_RESTART
:
2841 return unit_can_stop(u
) && unit_can_start(u
);
2844 case JOB_TRY_RELOAD
:
2845 return unit_can_reload(u
);
2847 case JOB_RELOAD_OR_START
:
2848 return unit_can_reload(u
) && unit_can_start(u
);
2851 assert_not_reached("Invalid job type");
2855 static void maybe_warn_about_dependency(Unit
*u
, const char *other
, UnitDependency dependency
) {
2858 /* Only warn about some unit types */
2859 if (!IN_SET(dependency
, UNIT_CONFLICTS
, UNIT_CONFLICTED_BY
, UNIT_BEFORE
, UNIT_AFTER
, UNIT_ON_FAILURE
, UNIT_TRIGGERS
, UNIT_TRIGGERED_BY
))
2862 if (streq_ptr(u
->id
, other
))
2863 log_unit_warning(u
, "Dependency %s=%s dropped", unit_dependency_to_string(dependency
), u
->id
);
2865 log_unit_warning(u
, "Dependency %s=%s dropped, merged into %s", unit_dependency_to_string(dependency
), strna(other
), u
->id
);
2868 static int unit_add_dependency_hashmap(
2871 UnitDependencyMask origin_mask
,
2872 UnitDependencyMask destination_mask
) {
2874 UnitDependencyInfo info
;
2879 assert(origin_mask
< _UNIT_DEPENDENCY_MASK_FULL
);
2880 assert(destination_mask
< _UNIT_DEPENDENCY_MASK_FULL
);
2881 assert(origin_mask
> 0 || destination_mask
> 0);
2883 r
= hashmap_ensure_allocated(h
, NULL
);
2887 assert_cc(sizeof(void*) == sizeof(info
));
2889 info
.data
= hashmap_get(*h
, other
);
2891 /* Entry already exists. Add in our mask. */
2893 if (FLAGS_SET(origin_mask
, info
.origin_mask
) &&
2894 FLAGS_SET(destination_mask
, info
.destination_mask
))
2897 info
.origin_mask
|= origin_mask
;
2898 info
.destination_mask
|= destination_mask
;
2900 r
= hashmap_update(*h
, other
, info
.data
);
2902 info
= (UnitDependencyInfo
) {
2903 .origin_mask
= origin_mask
,
2904 .destination_mask
= destination_mask
,
2907 r
= hashmap_put(*h
, other
, info
.data
);
2915 int unit_add_dependency(
2920 UnitDependencyMask mask
) {
2922 static const UnitDependency inverse_table
[_UNIT_DEPENDENCY_MAX
] = {
2923 [UNIT_REQUIRES
] = UNIT_REQUIRED_BY
,
2924 [UNIT_WANTS
] = UNIT_WANTED_BY
,
2925 [UNIT_REQUISITE
] = UNIT_REQUISITE_OF
,
2926 [UNIT_BINDS_TO
] = UNIT_BOUND_BY
,
2927 [UNIT_PART_OF
] = UNIT_CONSISTS_OF
,
2928 [UNIT_REQUIRED_BY
] = UNIT_REQUIRES
,
2929 [UNIT_REQUISITE_OF
] = UNIT_REQUISITE
,
2930 [UNIT_WANTED_BY
] = UNIT_WANTS
,
2931 [UNIT_BOUND_BY
] = UNIT_BINDS_TO
,
2932 [UNIT_CONSISTS_OF
] = UNIT_PART_OF
,
2933 [UNIT_CONFLICTS
] = UNIT_CONFLICTED_BY
,
2934 [UNIT_CONFLICTED_BY
] = UNIT_CONFLICTS
,
2935 [UNIT_BEFORE
] = UNIT_AFTER
,
2936 [UNIT_AFTER
] = UNIT_BEFORE
,
2937 [UNIT_ON_FAILURE
] = _UNIT_DEPENDENCY_INVALID
,
2938 [UNIT_REFERENCES
] = UNIT_REFERENCED_BY
,
2939 [UNIT_REFERENCED_BY
] = UNIT_REFERENCES
,
2940 [UNIT_TRIGGERS
] = UNIT_TRIGGERED_BY
,
2941 [UNIT_TRIGGERED_BY
] = UNIT_TRIGGERS
,
2942 [UNIT_PROPAGATES_RELOAD_TO
] = UNIT_RELOAD_PROPAGATED_FROM
,
2943 [UNIT_RELOAD_PROPAGATED_FROM
] = UNIT_PROPAGATES_RELOAD_TO
,
2944 [UNIT_JOINS_NAMESPACE_OF
] = UNIT_JOINS_NAMESPACE_OF
,
2946 Unit
*original_u
= u
, *original_other
= other
;
2950 assert(d
>= 0 && d
< _UNIT_DEPENDENCY_MAX
);
2953 u
= unit_follow_merge(u
);
2954 other
= unit_follow_merge(other
);
2956 /* We won't allow dependencies on ourselves. We will not
2957 * consider them an error however. */
2959 maybe_warn_about_dependency(original_u
, original_other
->id
, d
);
2963 if ((d
== UNIT_BEFORE
&& other
->type
== UNIT_DEVICE
) ||
2964 (d
== UNIT_AFTER
&& u
->type
== UNIT_DEVICE
)) {
2965 log_unit_warning(u
, "Dependency Before=%s ignored (.device units cannot be delayed)", other
->id
);
2969 r
= unit_add_dependency_hashmap(u
->dependencies
+ d
, other
, mask
, 0);
2973 if (inverse_table
[d
] != _UNIT_DEPENDENCY_INVALID
&& inverse_table
[d
] != d
) {
2974 r
= unit_add_dependency_hashmap(other
->dependencies
+ inverse_table
[d
], u
, 0, mask
);
2979 if (add_reference
) {
2980 r
= unit_add_dependency_hashmap(u
->dependencies
+ UNIT_REFERENCES
, other
, mask
, 0);
2984 r
= unit_add_dependency_hashmap(other
->dependencies
+ UNIT_REFERENCED_BY
, u
, 0, mask
);
2989 unit_add_to_dbus_queue(u
);
2993 int unit_add_two_dependencies(Unit
*u
, UnitDependency d
, UnitDependency e
, Unit
*other
, bool add_reference
, UnitDependencyMask mask
) {
2998 r
= unit_add_dependency(u
, d
, other
, add_reference
, mask
);
3002 return unit_add_dependency(u
, e
, other
, add_reference
, mask
);
3005 static int resolve_template(Unit
*u
, const char *name
, char **buf
, const char **ret
) {
3013 if (!unit_name_is_valid(name
, UNIT_NAME_TEMPLATE
)) {
3020 r
= unit_name_replace_instance(name
, u
->instance
, buf
);
3022 _cleanup_free_
char *i
= NULL
;
3024 r
= unit_name_to_prefix(u
->id
, &i
);
3028 r
= unit_name_replace_instance(name
, i
, buf
);
3037 int unit_add_dependency_by_name(Unit
*u
, UnitDependency d
, const char *name
, bool add_reference
, UnitDependencyMask mask
) {
3038 _cleanup_free_
char *buf
= NULL
;
3045 r
= resolve_template(u
, name
, &buf
, &name
);
3049 r
= manager_load_unit(u
->manager
, name
, NULL
, NULL
, &other
);
3053 return unit_add_dependency(u
, d
, other
, add_reference
, mask
);
3056 int unit_add_two_dependencies_by_name(Unit
*u
, UnitDependency d
, UnitDependency e
, const char *name
, bool add_reference
, UnitDependencyMask mask
) {
3057 _cleanup_free_
char *buf
= NULL
;
3064 r
= resolve_template(u
, name
, &buf
, &name
);
3068 r
= manager_load_unit(u
->manager
, name
, NULL
, NULL
, &other
);
3072 return unit_add_two_dependencies(u
, d
, e
, other
, add_reference
, mask
);
3075 int set_unit_path(const char *p
) {
3076 /* This is mostly for debug purposes */
3077 if (setenv("SYSTEMD_UNIT_PATH", p
, 1) < 0)
3083 char *unit_dbus_path(Unit
*u
) {
3089 return unit_dbus_path_from_name(u
->id
);
3092 char *unit_dbus_path_invocation_id(Unit
*u
) {
3095 if (sd_id128_is_null(u
->invocation_id
))
3098 return unit_dbus_path_from_name(u
->invocation_id_string
);
3101 int unit_set_slice(Unit
*u
, Unit
*slice
) {
3105 /* Sets the unit slice if it has not been set before. Is extra
3106 * careful, to only allow this for units that actually have a
3107 * cgroup context. Also, we don't allow to set this for slices
3108 * (since the parent slice is derived from the name). Make
3109 * sure the unit we set is actually a slice. */
3111 if (!UNIT_HAS_CGROUP_CONTEXT(u
))
3114 if (u
->type
== UNIT_SLICE
)
3117 if (unit_active_state(u
) != UNIT_INACTIVE
)
3120 if (slice
->type
!= UNIT_SLICE
)
3123 if (unit_has_name(u
, SPECIAL_INIT_SCOPE
) &&
3124 !unit_has_name(slice
, SPECIAL_ROOT_SLICE
))
3127 if (UNIT_DEREF(u
->slice
) == slice
)
3130 /* Disallow slice changes if @u is already bound to cgroups */
3131 if (UNIT_ISSET(u
->slice
) && u
->cgroup_realized
)
3134 unit_ref_set(&u
->slice
, u
, slice
);
3138 int unit_set_default_slice(Unit
*u
) {
3139 const char *slice_name
;
3145 if (UNIT_ISSET(u
->slice
))
3149 _cleanup_free_
char *prefix
= NULL
, *escaped
= NULL
;
3151 /* Implicitly place all instantiated units in their
3152 * own per-template slice */
3154 r
= unit_name_to_prefix(u
->id
, &prefix
);
3158 /* The prefix is already escaped, but it might include
3159 * "-" which has a special meaning for slice units,
3160 * hence escape it here extra. */
3161 escaped
= unit_name_escape(prefix
);
3165 if (MANAGER_IS_SYSTEM(u
->manager
))
3166 slice_name
= strjoina("system-", escaped
, ".slice");
3168 slice_name
= strjoina(escaped
, ".slice");
3171 MANAGER_IS_SYSTEM(u
->manager
) && !unit_has_name(u
, SPECIAL_INIT_SCOPE
)
3172 ? SPECIAL_SYSTEM_SLICE
3173 : SPECIAL_ROOT_SLICE
;
3175 r
= manager_load_unit(u
->manager
, slice_name
, NULL
, NULL
, &slice
);
3179 return unit_set_slice(u
, slice
);
3182 const char *unit_slice_name(Unit
*u
) {
3185 if (!UNIT_ISSET(u
->slice
))
3188 return UNIT_DEREF(u
->slice
)->id
;
3191 int unit_load_related_unit(Unit
*u
, const char *type
, Unit
**_found
) {
3192 _cleanup_free_
char *t
= NULL
;
3199 r
= unit_name_change_suffix(u
->id
, type
, &t
);
3202 if (unit_has_name(u
, t
))
3205 r
= manager_load_unit(u
->manager
, t
, NULL
, NULL
, _found
);
3206 assert(r
< 0 || *_found
!= u
);
3210 static int signal_name_owner_changed(sd_bus_message
*message
, void *userdata
, sd_bus_error
*error
) {
3211 const char *name
, *old_owner
, *new_owner
;
3218 r
= sd_bus_message_read(message
, "sss", &name
, &old_owner
, &new_owner
);
3220 bus_log_parse_error(r
);
3224 old_owner
= empty_to_null(old_owner
);
3225 new_owner
= empty_to_null(new_owner
);
3227 if (UNIT_VTABLE(u
)->bus_name_owner_change
)
3228 UNIT_VTABLE(u
)->bus_name_owner_change(u
, old_owner
, new_owner
);
3233 static int get_name_owner_handler(sd_bus_message
*message
, void *userdata
, sd_bus_error
*error
) {
3234 const sd_bus_error
*e
;
3235 const char *new_owner
;
3242 u
->get_name_owner_slot
= sd_bus_slot_unref(u
->get_name_owner_slot
);
3244 if (sd_bus_error_is_set(error
)) {
3245 log_error("Failed to get name owner from bus: %s", error
->message
);
3249 e
= sd_bus_message_get_error(message
);
3250 if (sd_bus_error_has_name(e
, "org.freedesktop.DBus.Error.NameHasNoOwner"))
3254 log_error("Unexpected error response from GetNameOwner: %s", e
->message
);
3258 r
= sd_bus_message_read(message
, "s", &new_owner
);
3260 bus_log_parse_error(r
);
3264 new_owner
= empty_to_null(new_owner
);
3266 if (UNIT_VTABLE(u
)->bus_name_owner_change
)
3267 UNIT_VTABLE(u
)->bus_name_owner_change(u
, NULL
, new_owner
);
3272 int unit_install_bus_match(Unit
*u
, sd_bus
*bus
, const char *name
) {
3279 if (u
->match_bus_slot
)
3282 match
= strjoina("type='signal',"
3283 "sender='org.freedesktop.DBus',"
3284 "path='/org/freedesktop/DBus',"
3285 "interface='org.freedesktop.DBus',"
3286 "member='NameOwnerChanged',"
3287 "arg0='", name
, "'");
3289 int r
= sd_bus_add_match_async(bus
, &u
->match_bus_slot
, match
, signal_name_owner_changed
, NULL
, u
);
3293 return sd_bus_call_method_async(bus
,
3294 &u
->get_name_owner_slot
,
3295 "org.freedesktop.DBus",
3296 "/org/freedesktop/DBus",
3297 "org.freedesktop.DBus",
3299 get_name_owner_handler
,
3304 int unit_watch_bus_name(Unit
*u
, const char *name
) {
3310 /* Watch a specific name on the bus. We only support one unit
3311 * watching each name for now. */
3313 if (u
->manager
->api_bus
) {
3314 /* If the bus is already available, install the match directly.
3315 * Otherwise, just put the name in the list. bus_setup_api() will take care later. */
3316 r
= unit_install_bus_match(u
, u
->manager
->api_bus
, name
);
3318 return log_warning_errno(r
, "Failed to subscribe to NameOwnerChanged signal for '%s': %m", name
);
3321 r
= hashmap_put(u
->manager
->watch_bus
, name
, u
);
3323 u
->match_bus_slot
= sd_bus_slot_unref(u
->match_bus_slot
);
3324 return log_warning_errno(r
, "Failed to put bus name to hashmap: %m");
3330 void unit_unwatch_bus_name(Unit
*u
, const char *name
) {
3334 (void) hashmap_remove_value(u
->manager
->watch_bus
, name
, u
);
3335 u
->match_bus_slot
= sd_bus_slot_unref(u
->match_bus_slot
);
3336 u
->get_name_owner_slot
= sd_bus_slot_unref(u
->get_name_owner_slot
);
3339 bool unit_can_serialize(Unit
*u
) {
3342 return UNIT_VTABLE(u
)->serialize
&& UNIT_VTABLE(u
)->deserialize_item
;
3345 static int serialize_cgroup_mask(FILE *f
, const char *key
, CGroupMask mask
) {
3346 _cleanup_free_
char *s
= NULL
;
3355 r
= cg_mask_to_string(mask
, &s
);
3357 return log_error_errno(r
, "Failed to format cgroup mask: %m");
3359 return serialize_item(f
, key
, s
);
3362 static const char *const ip_accounting_metric_field
[_CGROUP_IP_ACCOUNTING_METRIC_MAX
] = {
3363 [CGROUP_IP_INGRESS_BYTES
] = "ip-accounting-ingress-bytes",
3364 [CGROUP_IP_INGRESS_PACKETS
] = "ip-accounting-ingress-packets",
3365 [CGROUP_IP_EGRESS_BYTES
] = "ip-accounting-egress-bytes",
3366 [CGROUP_IP_EGRESS_PACKETS
] = "ip-accounting-egress-packets",
3369 static const char *const io_accounting_metric_field_base
[_CGROUP_IO_ACCOUNTING_METRIC_MAX
] = {
3370 [CGROUP_IO_READ_BYTES
] = "io-accounting-read-bytes-base",
3371 [CGROUP_IO_WRITE_BYTES
] = "io-accounting-write-bytes-base",
3372 [CGROUP_IO_READ_OPERATIONS
] = "io-accounting-read-operations-base",
3373 [CGROUP_IO_WRITE_OPERATIONS
] = "io-accounting-write-operations-base",
3376 static const char *const io_accounting_metric_field_last
[_CGROUP_IO_ACCOUNTING_METRIC_MAX
] = {
3377 [CGROUP_IO_READ_BYTES
] = "io-accounting-read-bytes-last",
3378 [CGROUP_IO_WRITE_BYTES
] = "io-accounting-write-bytes-last",
3379 [CGROUP_IO_READ_OPERATIONS
] = "io-accounting-read-operations-last",
3380 [CGROUP_IO_WRITE_OPERATIONS
] = "io-accounting-write-operations-last",
3383 int unit_serialize(Unit
*u
, FILE *f
, FDSet
*fds
, bool serialize_jobs
) {
3384 CGroupIPAccountingMetric m
;
3391 if (unit_can_serialize(u
)) {
3392 r
= UNIT_VTABLE(u
)->serialize(u
, f
, fds
);
3397 (void) serialize_dual_timestamp(f
, "state-change-timestamp", &u
->state_change_timestamp
);
3399 (void) serialize_dual_timestamp(f
, "inactive-exit-timestamp", &u
->inactive_exit_timestamp
);
3400 (void) serialize_dual_timestamp(f
, "active-enter-timestamp", &u
->active_enter_timestamp
);
3401 (void) serialize_dual_timestamp(f
, "active-exit-timestamp", &u
->active_exit_timestamp
);
3402 (void) serialize_dual_timestamp(f
, "inactive-enter-timestamp", &u
->inactive_enter_timestamp
);
3404 (void) serialize_dual_timestamp(f
, "condition-timestamp", &u
->condition_timestamp
);
3405 (void) serialize_dual_timestamp(f
, "assert-timestamp", &u
->assert_timestamp
);
3407 if (dual_timestamp_is_set(&u
->condition_timestamp
))
3408 (void) serialize_bool(f
, "condition-result", u
->condition_result
);
3410 if (dual_timestamp_is_set(&u
->assert_timestamp
))
3411 (void) serialize_bool(f
, "assert-result", u
->assert_result
);
3413 (void) serialize_bool(f
, "transient", u
->transient
);
3414 (void) serialize_bool(f
, "in-audit", u
->in_audit
);
3416 (void) serialize_bool(f
, "exported-invocation-id", u
->exported_invocation_id
);
3417 (void) serialize_bool(f
, "exported-log-level-max", u
->exported_log_level_max
);
3418 (void) serialize_bool(f
, "exported-log-extra-fields", u
->exported_log_extra_fields
);
3419 (void) serialize_bool(f
, "exported-log-rate-limit-interval", u
->exported_log_ratelimit_interval
);
3420 (void) serialize_bool(f
, "exported-log-rate-limit-burst", u
->exported_log_ratelimit_burst
);
3422 (void) serialize_item_format(f
, "cpu-usage-base", "%" PRIu64
, u
->cpu_usage_base
);
3423 if (u
->cpu_usage_last
!= NSEC_INFINITY
)
3424 (void) serialize_item_format(f
, "cpu-usage-last", "%" PRIu64
, u
->cpu_usage_last
);
3426 if (u
->oom_kill_last
> 0)
3427 (void) serialize_item_format(f
, "oom-kill-last", "%" PRIu64
, u
->oom_kill_last
);
3429 for (CGroupIOAccountingMetric im
= 0; im
< _CGROUP_IO_ACCOUNTING_METRIC_MAX
; im
++) {
3430 (void) serialize_item_format(f
, io_accounting_metric_field_base
[im
], "%" PRIu64
, u
->io_accounting_base
[im
]);
3432 if (u
->io_accounting_last
[im
] != UINT64_MAX
)
3433 (void) serialize_item_format(f
, io_accounting_metric_field_last
[im
], "%" PRIu64
, u
->io_accounting_last
[im
]);
3437 (void) serialize_item(f
, "cgroup", u
->cgroup_path
);
3439 (void) serialize_bool(f
, "cgroup-realized", u
->cgroup_realized
);
3440 (void) serialize_cgroup_mask(f
, "cgroup-realized-mask", u
->cgroup_realized_mask
);
3441 (void) serialize_cgroup_mask(f
, "cgroup-enabled-mask", u
->cgroup_enabled_mask
);
3442 (void) serialize_cgroup_mask(f
, "cgroup-invalidated-mask", u
->cgroup_invalidated_mask
);
3444 if (uid_is_valid(u
->ref_uid
))
3445 (void) serialize_item_format(f
, "ref-uid", UID_FMT
, u
->ref_uid
);
3446 if (gid_is_valid(u
->ref_gid
))
3447 (void) serialize_item_format(f
, "ref-gid", GID_FMT
, u
->ref_gid
);
3449 if (!sd_id128_is_null(u
->invocation_id
))
3450 (void) serialize_item_format(f
, "invocation-id", SD_ID128_FORMAT_STR
, SD_ID128_FORMAT_VAL(u
->invocation_id
));
3452 bus_track_serialize(u
->bus_track
, f
, "ref");
3454 for (m
= 0; m
< _CGROUP_IP_ACCOUNTING_METRIC_MAX
; m
++) {
3457 r
= unit_get_ip_accounting(u
, m
, &v
);
3459 (void) serialize_item_format(f
, ip_accounting_metric_field
[m
], "%" PRIu64
, v
);
3462 if (serialize_jobs
) {
3465 job_serialize(u
->job
, f
);
3470 job_serialize(u
->nop_job
, f
);
3479 static int unit_deserialize_job(Unit
*u
, FILE *f
) {
3480 _cleanup_(job_freep
) Job
*j
= NULL
;
3490 r
= job_deserialize(j
, f
);
3494 r
= job_install_deserialized(j
);
3502 int unit_deserialize(Unit
*u
, FILE *f
, FDSet
*fds
) {
3510 _cleanup_free_
char *line
= NULL
;
3515 r
= read_line(f
, LONG_LINE_MAX
, &line
);
3517 return log_error_errno(r
, "Failed to read serialization line: %m");
3518 if (r
== 0) /* eof */
3522 if (isempty(l
)) /* End marker */
3525 k
= strcspn(l
, "=");
3533 if (streq(l
, "job")) {
3535 /* New-style serialized job */
3536 r
= unit_deserialize_job(u
, f
);
3539 } else /* Legacy for pre-44 */
3540 log_unit_warning(u
, "Update from too old systemd versions are unsupported, cannot deserialize job: %s", v
);
3542 } else if (streq(l
, "state-change-timestamp")) {
3543 (void) deserialize_dual_timestamp(v
, &u
->state_change_timestamp
);
3545 } else if (streq(l
, "inactive-exit-timestamp")) {
3546 (void) deserialize_dual_timestamp(v
, &u
->inactive_exit_timestamp
);
3548 } else if (streq(l
, "active-enter-timestamp")) {
3549 (void) deserialize_dual_timestamp(v
, &u
->active_enter_timestamp
);
3551 } else if (streq(l
, "active-exit-timestamp")) {
3552 (void) deserialize_dual_timestamp(v
, &u
->active_exit_timestamp
);
3554 } else if (streq(l
, "inactive-enter-timestamp")) {
3555 (void) deserialize_dual_timestamp(v
, &u
->inactive_enter_timestamp
);
3557 } else if (streq(l
, "condition-timestamp")) {
3558 (void) deserialize_dual_timestamp(v
, &u
->condition_timestamp
);
3560 } else if (streq(l
, "assert-timestamp")) {
3561 (void) deserialize_dual_timestamp(v
, &u
->assert_timestamp
);
3563 } else if (streq(l
, "condition-result")) {
3565 r
= parse_boolean(v
);
3567 log_unit_debug(u
, "Failed to parse condition result value %s, ignoring.", v
);
3569 u
->condition_result
= r
;
3573 } else if (streq(l
, "assert-result")) {
3575 r
= parse_boolean(v
);
3577 log_unit_debug(u
, "Failed to parse assert result value %s, ignoring.", v
);
3579 u
->assert_result
= r
;
3583 } else if (streq(l
, "transient")) {
3585 r
= parse_boolean(v
);
3587 log_unit_debug(u
, "Failed to parse transient bool %s, ignoring.", v
);
3593 } else if (streq(l
, "in-audit")) {
3595 r
= parse_boolean(v
);
3597 log_unit_debug(u
, "Failed to parse in-audit bool %s, ignoring.", v
);
3603 } else if (streq(l
, "exported-invocation-id")) {
3605 r
= parse_boolean(v
);
3607 log_unit_debug(u
, "Failed to parse exported invocation ID bool %s, ignoring.", v
);
3609 u
->exported_invocation_id
= r
;
3613 } else if (streq(l
, "exported-log-level-max")) {
3615 r
= parse_boolean(v
);
3617 log_unit_debug(u
, "Failed to parse exported log level max bool %s, ignoring.", v
);
3619 u
->exported_log_level_max
= r
;
3623 } else if (streq(l
, "exported-log-extra-fields")) {
3625 r
= parse_boolean(v
);
3627 log_unit_debug(u
, "Failed to parse exported log extra fields bool %s, ignoring.", v
);
3629 u
->exported_log_extra_fields
= r
;
3633 } else if (streq(l
, "exported-log-rate-limit-interval")) {
3635 r
= parse_boolean(v
);
3637 log_unit_debug(u
, "Failed to parse exported log rate limit interval %s, ignoring.", v
);
3639 u
->exported_log_ratelimit_interval
= r
;
3643 } else if (streq(l
, "exported-log-rate-limit-burst")) {
3645 r
= parse_boolean(v
);
3647 log_unit_debug(u
, "Failed to parse exported log rate limit burst %s, ignoring.", v
);
3649 u
->exported_log_ratelimit_burst
= r
;
3653 } else if (STR_IN_SET(l
, "cpu-usage-base", "cpuacct-usage-base")) {
3655 r
= safe_atou64(v
, &u
->cpu_usage_base
);
3657 log_unit_debug(u
, "Failed to parse CPU usage base %s, ignoring.", v
);
3661 } else if (streq(l
, "cpu-usage-last")) {
3663 r
= safe_atou64(v
, &u
->cpu_usage_last
);
3665 log_unit_debug(u
, "Failed to read CPU usage last %s, ignoring.", v
);
3669 } else if (streq(l
, "oom-kill-last")) {
3671 r
= safe_atou64(v
, &u
->oom_kill_last
);
3673 log_unit_debug(u
, "Failed to read OOM kill last %s, ignoring.", v
);
3677 } else if (streq(l
, "cgroup")) {
3679 r
= unit_set_cgroup_path(u
, v
);
3681 log_unit_debug_errno(u
, r
, "Failed to set cgroup path %s, ignoring: %m", v
);
3683 (void) unit_watch_cgroup(u
);
3684 (void) unit_watch_cgroup_memory(u
);
3687 } else if (streq(l
, "cgroup-realized")) {
3690 b
= parse_boolean(v
);
3692 log_unit_debug(u
, "Failed to parse cgroup-realized bool %s, ignoring.", v
);
3694 u
->cgroup_realized
= b
;
3698 } else if (streq(l
, "cgroup-realized-mask")) {
3700 r
= cg_mask_from_string(v
, &u
->cgroup_realized_mask
);
3702 log_unit_debug(u
, "Failed to parse cgroup-realized-mask %s, ignoring.", v
);
3705 } else if (streq(l
, "cgroup-enabled-mask")) {
3707 r
= cg_mask_from_string(v
, &u
->cgroup_enabled_mask
);
3709 log_unit_debug(u
, "Failed to parse cgroup-enabled-mask %s, ignoring.", v
);
3712 } else if (streq(l
, "cgroup-invalidated-mask")) {
3714 r
= cg_mask_from_string(v
, &u
->cgroup_invalidated_mask
);
3716 log_unit_debug(u
, "Failed to parse cgroup-invalidated-mask %s, ignoring.", v
);
3719 } else if (streq(l
, "ref-uid")) {
3722 r
= parse_uid(v
, &uid
);
3724 log_unit_debug(u
, "Failed to parse referenced UID %s, ignoring.", v
);
3726 unit_ref_uid_gid(u
, uid
, GID_INVALID
);
3730 } else if (streq(l
, "ref-gid")) {
3733 r
= parse_gid(v
, &gid
);
3735 log_unit_debug(u
, "Failed to parse referenced GID %s, ignoring.", v
);
3737 unit_ref_uid_gid(u
, UID_INVALID
, gid
);
3741 } else if (streq(l
, "ref")) {
3743 r
= strv_extend(&u
->deserialized_refs
, v
);
3748 } else if (streq(l
, "invocation-id")) {
3751 r
= sd_id128_from_string(v
, &id
);
3753 log_unit_debug(u
, "Failed to parse invocation id %s, ignoring.", v
);
3755 r
= unit_set_invocation_id(u
, id
);
3757 log_unit_warning_errno(u
, r
, "Failed to set invocation ID for unit: %m");
3763 /* Check if this is an IP accounting metric serialization field */
3764 m
= string_table_lookup(ip_accounting_metric_field
, ELEMENTSOF(ip_accounting_metric_field
), l
);
3768 r
= safe_atou64(v
, &c
);
3770 log_unit_debug(u
, "Failed to parse IP accounting value %s, ignoring.", v
);
3772 u
->ip_accounting_extra
[m
] = c
;
3776 m
= string_table_lookup(io_accounting_metric_field_base
, ELEMENTSOF(io_accounting_metric_field_base
), l
);
3780 r
= safe_atou64(v
, &c
);
3782 log_unit_debug(u
, "Failed to parse IO accounting base value %s, ignoring.", v
);
3784 u
->io_accounting_base
[m
] = c
;
3788 m
= string_table_lookup(io_accounting_metric_field_last
, ELEMENTSOF(io_accounting_metric_field_last
), l
);
3792 r
= safe_atou64(v
, &c
);
3794 log_unit_debug(u
, "Failed to parse IO accounting last value %s, ignoring.", v
);
3796 u
->io_accounting_last
[m
] = c
;
3800 if (unit_can_serialize(u
)) {
3801 r
= exec_runtime_deserialize_compat(u
, l
, v
, fds
);
3803 log_unit_warning(u
, "Failed to deserialize runtime parameter '%s', ignoring.", l
);
3807 /* Returns positive if key was handled by the call */
3811 r
= UNIT_VTABLE(u
)->deserialize_item(u
, l
, v
, fds
);
3813 log_unit_warning(u
, "Failed to deserialize unit parameter '%s', ignoring.", l
);
3817 /* Versions before 228 did not carry a state change timestamp. In this case, take the current time. This is
3818 * useful, so that timeouts based on this timestamp don't trigger too early, and is in-line with the logic from
3819 * before 228 where the base for timeouts was not persistent across reboots. */
3821 if (!dual_timestamp_is_set(&u
->state_change_timestamp
))
3822 dual_timestamp_get(&u
->state_change_timestamp
);
3824 /* Let's make sure that everything that is deserialized also gets any potential new cgroup settings applied
3825 * after we are done. For that we invalidate anything already realized, so that we can realize it again. */
3826 unit_invalidate_cgroup(u
, _CGROUP_MASK_ALL
);
3827 unit_invalidate_cgroup_bpf(u
);
3832 int unit_deserialize_skip(FILE *f
) {
3836 /* Skip serialized data for this unit. We don't know what it is. */
3839 _cleanup_free_
char *line
= NULL
;
3842 r
= read_line(f
, LONG_LINE_MAX
, &line
);
3844 return log_error_errno(r
, "Failed to read serialization line: %m");
3856 int unit_add_node_dependency(Unit
*u
, const char *what
, bool wants
, UnitDependency dep
, UnitDependencyMask mask
) {
3858 _cleanup_free_
char *e
= NULL
;
3863 /* Adds in links to the device node that this unit is based on */
3867 if (!is_device_path(what
))
3870 /* When device units aren't supported (such as in a
3871 * container), don't create dependencies on them. */
3872 if (!unit_type_supported(UNIT_DEVICE
))
3875 r
= unit_name_from_path(what
, ".device", &e
);
3879 r
= manager_load_unit(u
->manager
, e
, NULL
, NULL
, &device
);
3883 if (dep
== UNIT_REQUIRES
&& device_shall_be_bound_by(device
, u
))
3884 dep
= UNIT_BINDS_TO
;
3886 r
= unit_add_two_dependencies(u
, UNIT_AFTER
,
3887 MANAGER_IS_SYSTEM(u
->manager
) ? dep
: UNIT_WANTS
,
3888 device
, true, mask
);
3893 r
= unit_add_dependency(device
, UNIT_WANTS
, u
, false, mask
);
3901 int unit_coldplug(Unit
*u
) {
3908 /* Make sure we don't enter a loop, when coldplugging recursively. */
3912 u
->coldplugged
= true;
3914 STRV_FOREACH(i
, u
->deserialized_refs
) {
3915 q
= bus_unit_track_add_name(u
, *i
);
3916 if (q
< 0 && r
>= 0)
3919 u
->deserialized_refs
= strv_free(u
->deserialized_refs
);
3921 if (UNIT_VTABLE(u
)->coldplug
) {
3922 q
= UNIT_VTABLE(u
)->coldplug(u
);
3923 if (q
< 0 && r
>= 0)
3927 uj
= u
->job
?: u
->nop_job
;
3929 q
= job_coldplug(uj
);
3930 if (q
< 0 && r
>= 0)
3937 void unit_catchup(Unit
*u
) {
3940 if (UNIT_VTABLE(u
)->catchup
)
3941 UNIT_VTABLE(u
)->catchup(u
);
3944 static bool fragment_mtime_newer(const char *path
, usec_t mtime
, bool path_masked
) {
3950 /* If the source is some virtual kernel file system, then we assume we watch it anyway, and hence pretend we
3951 * are never out-of-date. */
3952 if (PATH_STARTSWITH_SET(path
, "/proc", "/sys"))
3955 if (stat(path
, &st
) < 0)
3956 /* What, cannot access this anymore? */
3960 /* For masked files check if they are still so */
3961 return !null_or_empty(&st
);
3963 /* For non-empty files check the mtime */
3964 return timespec_load(&st
.st_mtim
) > mtime
;
3969 bool unit_need_daemon_reload(Unit
*u
) {
3970 _cleanup_strv_free_
char **t
= NULL
;
3975 /* For unit files, we allow masking… */
3976 if (fragment_mtime_newer(u
->fragment_path
, u
->fragment_mtime
,
3977 u
->load_state
== UNIT_MASKED
))
3980 /* Source paths should not be masked… */
3981 if (fragment_mtime_newer(u
->source_path
, u
->source_mtime
, false))
3984 if (u
->load_state
== UNIT_LOADED
)
3985 (void) unit_find_dropin_paths(u
, &t
);
3986 if (!strv_equal(u
->dropin_paths
, t
))
3989 /* … any drop-ins that are masked are simply omitted from the list. */
3990 STRV_FOREACH(path
, u
->dropin_paths
)
3991 if (fragment_mtime_newer(*path
, u
->dropin_mtime
, false))
3997 void unit_reset_failed(Unit
*u
) {
4000 if (UNIT_VTABLE(u
)->reset_failed
)
4001 UNIT_VTABLE(u
)->reset_failed(u
);
4003 ratelimit_reset(&u
->start_ratelimit
);
4004 u
->start_limit_hit
= false;
4007 Unit
*unit_following(Unit
*u
) {
4010 if (UNIT_VTABLE(u
)->following
)
4011 return UNIT_VTABLE(u
)->following(u
);
4016 bool unit_stop_pending(Unit
*u
) {
4019 /* This call does check the current state of the unit. It's
4020 * hence useful to be called from state change calls of the
4021 * unit itself, where the state isn't updated yet. This is
4022 * different from unit_inactive_or_pending() which checks both
4023 * the current state and for a queued job. */
4025 return u
->job
&& u
->job
->type
== JOB_STOP
;
4028 bool unit_inactive_or_pending(Unit
*u
) {
4031 /* Returns true if the unit is inactive or going down */
4033 if (UNIT_IS_INACTIVE_OR_DEACTIVATING(unit_active_state(u
)))
4036 if (unit_stop_pending(u
))
4042 bool unit_active_or_pending(Unit
*u
) {
4045 /* Returns true if the unit is active or going up */
4047 if (UNIT_IS_ACTIVE_OR_ACTIVATING(unit_active_state(u
)))
4051 IN_SET(u
->job
->type
, JOB_START
, JOB_RELOAD_OR_START
, JOB_RESTART
))
4057 bool unit_will_restart_default(Unit
*u
) {
4062 if (u
->job
->type
== JOB_START
)
4068 bool unit_will_restart(Unit
*u
) {
4071 if (!UNIT_VTABLE(u
)->will_restart
)
4074 return UNIT_VTABLE(u
)->will_restart(u
);
4077 int unit_kill(Unit
*u
, KillWho w
, int signo
, sd_bus_error
*error
) {
4079 assert(w
>= 0 && w
< _KILL_WHO_MAX
);
4080 assert(SIGNAL_VALID(signo
));
4082 if (!UNIT_VTABLE(u
)->kill
)
4085 return UNIT_VTABLE(u
)->kill(u
, w
, signo
, error
);
4088 static Set
*unit_pid_set(pid_t main_pid
, pid_t control_pid
) {
4089 _cleanup_set_free_ Set
*pid_set
= NULL
;
4092 pid_set
= set_new(NULL
);
4096 /* Exclude the main/control pids from being killed via the cgroup */
4098 r
= set_put(pid_set
, PID_TO_PTR(main_pid
));
4103 if (control_pid
> 0) {
4104 r
= set_put(pid_set
, PID_TO_PTR(control_pid
));
4109 return TAKE_PTR(pid_set
);
4112 int unit_kill_common(
4118 sd_bus_error
*error
) {
4121 bool killed
= false;
4123 if (IN_SET(who
, KILL_MAIN
, KILL_MAIN_FAIL
)) {
4125 return sd_bus_error_setf(error
, BUS_ERROR_NO_SUCH_PROCESS
, "%s units have no main processes", unit_type_to_string(u
->type
));
4126 else if (main_pid
== 0)
4127 return sd_bus_error_set_const(error
, BUS_ERROR_NO_SUCH_PROCESS
, "No main process to kill");
4130 if (IN_SET(who
, KILL_CONTROL
, KILL_CONTROL_FAIL
)) {
4131 if (control_pid
< 0)
4132 return sd_bus_error_setf(error
, BUS_ERROR_NO_SUCH_PROCESS
, "%s units have no control processes", unit_type_to_string(u
->type
));
4133 else if (control_pid
== 0)
4134 return sd_bus_error_set_const(error
, BUS_ERROR_NO_SUCH_PROCESS
, "No control process to kill");
4137 if (IN_SET(who
, KILL_CONTROL
, KILL_CONTROL_FAIL
, KILL_ALL
, KILL_ALL_FAIL
))
4138 if (control_pid
> 0) {
4139 if (kill(control_pid
, signo
) < 0)
4145 if (IN_SET(who
, KILL_MAIN
, KILL_MAIN_FAIL
, KILL_ALL
, KILL_ALL_FAIL
))
4147 if (kill(main_pid
, signo
) < 0)
4153 if (IN_SET(who
, KILL_ALL
, KILL_ALL_FAIL
) && u
->cgroup_path
) {
4154 _cleanup_set_free_ Set
*pid_set
= NULL
;
4157 /* Exclude the main/control pids from being killed via the cgroup */
4158 pid_set
= unit_pid_set(main_pid
, control_pid
);
4162 q
= cg_kill_recursive(SYSTEMD_CGROUP_CONTROLLER
, u
->cgroup_path
, signo
, 0, pid_set
, NULL
, NULL
);
4163 if (q
< 0 && !IN_SET(q
, -EAGAIN
, -ESRCH
, -ENOENT
))
4169 if (r
== 0 && !killed
&& IN_SET(who
, KILL_ALL_FAIL
, KILL_CONTROL_FAIL
))
4175 int unit_following_set(Unit
*u
, Set
**s
) {
4179 if (UNIT_VTABLE(u
)->following_set
)
4180 return UNIT_VTABLE(u
)->following_set(u
, s
);
4186 UnitFileState
unit_get_unit_file_state(Unit
*u
) {
4191 if (u
->unit_file_state
< 0 && u
->fragment_path
) {
4192 r
= unit_file_get_state(
4193 u
->manager
->unit_file_scope
,
4196 &u
->unit_file_state
);
4198 u
->unit_file_state
= UNIT_FILE_BAD
;
4201 return u
->unit_file_state
;
4204 int unit_get_unit_file_preset(Unit
*u
) {
4207 if (u
->unit_file_preset
< 0 && u
->fragment_path
)
4208 u
->unit_file_preset
= unit_file_query_preset(
4209 u
->manager
->unit_file_scope
,
4211 basename(u
->fragment_path
));
4213 return u
->unit_file_preset
;
4216 Unit
* unit_ref_set(UnitRef
*ref
, Unit
*source
, Unit
*target
) {
4222 unit_ref_unset(ref
);
4224 ref
->source
= source
;
4225 ref
->target
= target
;
4226 LIST_PREPEND(refs_by_target
, target
->refs_by_target
, ref
);
4230 void unit_ref_unset(UnitRef
*ref
) {
4236 /* We are about to drop a reference to the unit, make sure the garbage collection has a look at it as it might
4237 * be unreferenced now. */
4238 unit_add_to_gc_queue(ref
->target
);
4240 LIST_REMOVE(refs_by_target
, ref
->target
->refs_by_target
, ref
);
4241 ref
->source
= ref
->target
= NULL
;
4244 static int user_from_unit_name(Unit
*u
, char **ret
) {
4246 static const uint8_t hash_key
[] = {
4247 0x58, 0x1a, 0xaf, 0xe6, 0x28, 0x58, 0x4e, 0x96,
4248 0xb4, 0x4e, 0xf5, 0x3b, 0x8c, 0x92, 0x07, 0xec
4251 _cleanup_free_
char *n
= NULL
;
4254 r
= unit_name_to_prefix(u
->id
, &n
);
4258 if (valid_user_group_name(n
)) {
4263 /* If we can't use the unit name as a user name, then let's hash it and use that */
4264 if (asprintf(ret
, "_du%016" PRIx64
, siphash24(n
, strlen(n
), hash_key
)) < 0)
4270 int unit_patch_contexts(Unit
*u
) {
4278 /* Patch in the manager defaults into the exec and cgroup
4279 * contexts, _after_ the rest of the settings have been
4282 ec
= unit_get_exec_context(u
);
4284 /* This only copies in the ones that need memory */
4285 for (i
= 0; i
< _RLIMIT_MAX
; i
++)
4286 if (u
->manager
->rlimit
[i
] && !ec
->rlimit
[i
]) {
4287 ec
->rlimit
[i
] = newdup(struct rlimit
, u
->manager
->rlimit
[i
], 1);
4292 if (MANAGER_IS_USER(u
->manager
) &&
4293 !ec
->working_directory
) {
4295 r
= get_home_dir(&ec
->working_directory
);
4299 /* Allow user services to run, even if the
4300 * home directory is missing */
4301 ec
->working_directory_missing_ok
= true;
4304 if (ec
->private_devices
)
4305 ec
->capability_bounding_set
&= ~((UINT64_C(1) << CAP_MKNOD
) | (UINT64_C(1) << CAP_SYS_RAWIO
));
4307 if (ec
->protect_kernel_modules
)
4308 ec
->capability_bounding_set
&= ~(UINT64_C(1) << CAP_SYS_MODULE
);
4310 if (ec
->dynamic_user
) {
4312 r
= user_from_unit_name(u
, &ec
->user
);
4318 ec
->group
= strdup(ec
->user
);
4323 /* If the dynamic user option is on, let's make sure that the unit can't leave its
4324 * UID/GID around in the file system or on IPC objects. Hence enforce a strict
4327 ec
->private_tmp
= true;
4328 ec
->remove_ipc
= true;
4329 ec
->protect_system
= PROTECT_SYSTEM_STRICT
;
4330 if (ec
->protect_home
== PROTECT_HOME_NO
)
4331 ec
->protect_home
= PROTECT_HOME_READ_ONLY
;
4333 /* Make sure this service can neither benefit from SUID/SGID binaries nor create
4335 ec
->no_new_privileges
= true;
4336 ec
->restrict_suid_sgid
= true;
4340 cc
= unit_get_cgroup_context(u
);
4343 if (ec
->private_devices
&&
4344 cc
->device_policy
== CGROUP_AUTO
)
4345 cc
->device_policy
= CGROUP_CLOSED
;
4347 if (ec
->root_image
&&
4348 (cc
->device_policy
!= CGROUP_AUTO
|| cc
->device_allow
)) {
4350 /* When RootImage= is specified, the following devices are touched. */
4351 r
= cgroup_add_device_allow(cc
, "/dev/loop-control", "rw");
4355 r
= cgroup_add_device_allow(cc
, "block-loop", "rwm");
4359 r
= cgroup_add_device_allow(cc
, "block-blkext", "rwm");
4368 ExecContext
*unit_get_exec_context(Unit
*u
) {
4375 offset
= UNIT_VTABLE(u
)->exec_context_offset
;
4379 return (ExecContext
*) ((uint8_t*) u
+ offset
);
4382 KillContext
*unit_get_kill_context(Unit
*u
) {
4389 offset
= UNIT_VTABLE(u
)->kill_context_offset
;
4393 return (KillContext
*) ((uint8_t*) u
+ offset
);
4396 CGroupContext
*unit_get_cgroup_context(Unit
*u
) {
4402 offset
= UNIT_VTABLE(u
)->cgroup_context_offset
;
4406 return (CGroupContext
*) ((uint8_t*) u
+ offset
);
4409 ExecRuntime
*unit_get_exec_runtime(Unit
*u
) {
4415 offset
= UNIT_VTABLE(u
)->exec_runtime_offset
;
4419 return *(ExecRuntime
**) ((uint8_t*) u
+ offset
);
4422 static const char* unit_drop_in_dir(Unit
*u
, UnitWriteFlags flags
) {
4425 if (UNIT_WRITE_FLAGS_NOOP(flags
))
4428 if (u
->transient
) /* Redirect drop-ins for transient units always into the transient directory. */
4429 return u
->manager
->lookup_paths
.transient
;
4431 if (flags
& UNIT_PERSISTENT
)
4432 return u
->manager
->lookup_paths
.persistent_control
;
4434 if (flags
& UNIT_RUNTIME
)
4435 return u
->manager
->lookup_paths
.runtime_control
;
4440 char* unit_escape_setting(const char *s
, UnitWriteFlags flags
, char **buf
) {
4446 /* Escapes the input string as requested. Returns the escaped string. If 'buf' is specified then the allocated
4447 * return buffer pointer is also written to *buf, except if no escaping was necessary, in which case *buf is
4448 * set to NULL, and the input pointer is returned as-is. This means the return value always contains a properly
4449 * escaped version, but *buf when passed only contains a pointer if an allocation was necessary. If *buf is
4450 * not specified, then the return value always needs to be freed. Callers can use this to optimize memory
4453 if (flags
& UNIT_ESCAPE_SPECIFIERS
) {
4454 ret
= specifier_escape(s
);
4461 if (flags
& UNIT_ESCAPE_C
) {
4474 return ret
?: (char*) s
;
4477 return ret
?: strdup(s
);
4480 char* unit_concat_strv(char **l
, UnitWriteFlags flags
) {
4481 _cleanup_free_
char *result
= NULL
;
4482 size_t n
= 0, allocated
= 0;
4485 /* Takes a list of strings, escapes them, and concatenates them. This may be used to format command lines in a
4486 * way suitable for ExecStart= stanzas */
4488 STRV_FOREACH(i
, l
) {
4489 _cleanup_free_
char *buf
= NULL
;
4494 p
= unit_escape_setting(*i
, flags
, &buf
);
4498 a
= (n
> 0) + 1 + strlen(p
) + 1; /* separating space + " + entry + " */
4499 if (!GREEDY_REALLOC(result
, allocated
, n
+ a
+ 1))
4513 if (!GREEDY_REALLOC(result
, allocated
, n
+ 1))
4518 return TAKE_PTR(result
);
4521 int unit_write_setting(Unit
*u
, UnitWriteFlags flags
, const char *name
, const char *data
) {
4522 _cleanup_free_
char *p
= NULL
, *q
= NULL
, *escaped
= NULL
;
4523 const char *dir
, *wrapped
;
4530 if (UNIT_WRITE_FLAGS_NOOP(flags
))
4533 data
= unit_escape_setting(data
, flags
, &escaped
);
4537 /* Prefix the section header. If we are writing this out as transient file, then let's suppress this if the
4538 * previous section header is the same */
4540 if (flags
& UNIT_PRIVATE
) {
4541 if (!UNIT_VTABLE(u
)->private_section
)
4544 if (!u
->transient_file
|| u
->last_section_private
< 0)
4545 data
= strjoina("[", UNIT_VTABLE(u
)->private_section
, "]\n", data
);
4546 else if (u
->last_section_private
== 0)
4547 data
= strjoina("\n[", UNIT_VTABLE(u
)->private_section
, "]\n", data
);
4549 if (!u
->transient_file
|| u
->last_section_private
< 0)
4550 data
= strjoina("[Unit]\n", data
);
4551 else if (u
->last_section_private
> 0)
4552 data
= strjoina("\n[Unit]\n", data
);
4555 if (u
->transient_file
) {
4556 /* When this is a transient unit file in creation, then let's not create a new drop-in but instead
4557 * write to the transient unit file. */
4558 fputs(data
, u
->transient_file
);
4560 if (!endswith(data
, "\n"))
4561 fputc('\n', u
->transient_file
);
4563 /* Remember which section we wrote this entry to */
4564 u
->last_section_private
= !!(flags
& UNIT_PRIVATE
);
4568 dir
= unit_drop_in_dir(u
, flags
);
4572 wrapped
= strjoina("# This is a drop-in unit file extension, created via \"systemctl set-property\"\n"
4573 "# or an equivalent operation. Do not edit.\n",
4577 r
= drop_in_file(dir
, u
->id
, 50, name
, &p
, &q
);
4581 (void) mkdir_p_label(p
, 0755);
4583 /* Make sure the drop-in dir is registered in our path cache. This way we don't need to stupidly
4584 * recreate the cache after every drop-in we write. */
4585 if (u
->manager
->unit_path_cache
) {
4586 r
= set_put_strdup(u
->manager
->unit_path_cache
, p
);
4591 r
= write_string_file_atomic_label(q
, wrapped
);
4595 r
= strv_push(&u
->dropin_paths
, q
);
4600 strv_uniq(u
->dropin_paths
);
4602 u
->dropin_mtime
= now(CLOCK_REALTIME
);
4607 int unit_write_settingf(Unit
*u
, UnitWriteFlags flags
, const char *name
, const char *format
, ...) {
4608 _cleanup_free_
char *p
= NULL
;
4616 if (UNIT_WRITE_FLAGS_NOOP(flags
))
4619 va_start(ap
, format
);
4620 r
= vasprintf(&p
, format
, ap
);
4626 return unit_write_setting(u
, flags
, name
, p
);
4629 int unit_make_transient(Unit
*u
) {
4630 _cleanup_free_
char *path
= NULL
;
4635 if (!UNIT_VTABLE(u
)->can_transient
)
4638 (void) mkdir_p_label(u
->manager
->lookup_paths
.transient
, 0755);
4640 path
= path_join(u
->manager
->lookup_paths
.transient
, u
->id
);
4644 /* Let's open the file we'll write the transient settings into. This file is kept open as long as we are
4645 * creating the transient, and is closed in unit_load(), as soon as we start loading the file. */
4647 RUN_WITH_UMASK(0022) {
4648 f
= fopen(path
, "we");
4653 safe_fclose(u
->transient_file
);
4654 u
->transient_file
= f
;
4656 free_and_replace(u
->fragment_path
, path
);
4658 u
->source_path
= mfree(u
->source_path
);
4659 u
->dropin_paths
= strv_free(u
->dropin_paths
);
4660 u
->fragment_mtime
= u
->source_mtime
= u
->dropin_mtime
= 0;
4662 u
->load_state
= UNIT_STUB
;
4664 u
->transient
= true;
4666 unit_add_to_dbus_queue(u
);
4667 unit_add_to_gc_queue(u
);
4669 fputs("# This is a transient unit file, created programmatically via the systemd API. Do not edit.\n",
4675 static int log_kill(pid_t pid
, int sig
, void *userdata
) {
4676 _cleanup_free_
char *comm
= NULL
;
4678 (void) get_process_comm(pid
, &comm
);
4680 /* Don't log about processes marked with brackets, under the assumption that these are temporary processes
4681 only, like for example systemd's own PAM stub process. */
4682 if (comm
&& comm
[0] == '(')
4685 log_unit_notice(userdata
,
4686 "Killing process " PID_FMT
" (%s) with signal SIG%s.",
4689 signal_to_string(sig
));
4694 static int operation_to_signal(KillContext
*c
, KillOperation k
) {
4699 case KILL_TERMINATE
:
4700 case KILL_TERMINATE_AND_LOG
:
4701 return c
->kill_signal
;
4704 return c
->final_kill_signal
;
4707 return c
->watchdog_signal
;
4710 assert_not_reached("KillOperation unknown");
4714 int unit_kill_context(
4720 bool main_pid_alien
) {
4722 bool wait_for_exit
= false, send_sighup
;
4723 cg_kill_log_func_t log_func
= NULL
;
4729 /* Kill the processes belonging to this unit, in preparation for shutting the unit down.
4730 * Returns > 0 if we killed something worth waiting for, 0 otherwise. */
4732 if (c
->kill_mode
== KILL_NONE
)
4735 sig
= operation_to_signal(c
, k
);
4739 IN_SET(k
, KILL_TERMINATE
, KILL_TERMINATE_AND_LOG
) &&
4742 if (k
!= KILL_TERMINATE
|| IN_SET(sig
, SIGKILL
, SIGABRT
))
4743 log_func
= log_kill
;
4747 log_func(main_pid
, sig
, u
);
4749 r
= kill_and_sigcont(main_pid
, sig
);
4750 if (r
< 0 && r
!= -ESRCH
) {
4751 _cleanup_free_
char *comm
= NULL
;
4752 (void) get_process_comm(main_pid
, &comm
);
4754 log_unit_warning_errno(u
, r
, "Failed to kill main process " PID_FMT
" (%s), ignoring: %m", main_pid
, strna(comm
));
4756 if (!main_pid_alien
)
4757 wait_for_exit
= true;
4759 if (r
!= -ESRCH
&& send_sighup
)
4760 (void) kill(main_pid
, SIGHUP
);
4764 if (control_pid
> 0) {
4766 log_func(control_pid
, sig
, u
);
4768 r
= kill_and_sigcont(control_pid
, sig
);
4769 if (r
< 0 && r
!= -ESRCH
) {
4770 _cleanup_free_
char *comm
= NULL
;
4771 (void) get_process_comm(control_pid
, &comm
);
4773 log_unit_warning_errno(u
, r
, "Failed to kill control process " PID_FMT
" (%s), ignoring: %m", control_pid
, strna(comm
));
4775 wait_for_exit
= true;
4777 if (r
!= -ESRCH
&& send_sighup
)
4778 (void) kill(control_pid
, SIGHUP
);
4782 if (u
->cgroup_path
&&
4783 (c
->kill_mode
== KILL_CONTROL_GROUP
|| (c
->kill_mode
== KILL_MIXED
&& k
== KILL_KILL
))) {
4784 _cleanup_set_free_ Set
*pid_set
= NULL
;
4786 /* Exclude the main/control pids from being killed via the cgroup */
4787 pid_set
= unit_pid_set(main_pid
, control_pid
);
4791 r
= cg_kill_recursive(SYSTEMD_CGROUP_CONTROLLER
, u
->cgroup_path
,
4793 CGROUP_SIGCONT
|CGROUP_IGNORE_SELF
,
4797 if (!IN_SET(r
, -EAGAIN
, -ESRCH
, -ENOENT
))
4798 log_unit_warning_errno(u
, r
, "Failed to kill control group %s, ignoring: %m", u
->cgroup_path
);
4802 /* FIXME: For now, on the legacy hierarchy, we will not wait for the cgroup members to die if
4803 * we are running in a container or if this is a delegation unit, simply because cgroup
4804 * notification is unreliable in these cases. It doesn't work at all in containers, and outside
4805 * of containers it can be confused easily by left-over directories in the cgroup — which
4806 * however should not exist in non-delegated units. On the unified hierarchy that's different,
4807 * there we get proper events. Hence rely on them. */
4809 if (cg_unified_controller(SYSTEMD_CGROUP_CONTROLLER
) > 0 ||
4810 (detect_container() == 0 && !unit_cgroup_delegate(u
)))
4811 wait_for_exit
= true;
4816 pid_set
= unit_pid_set(main_pid
, control_pid
);
4820 cg_kill_recursive(SYSTEMD_CGROUP_CONTROLLER
, u
->cgroup_path
,
4829 return wait_for_exit
;
4832 int unit_require_mounts_for(Unit
*u
, const char *path
, UnitDependencyMask mask
) {
4833 _cleanup_free_
char *p
= NULL
;
4834 UnitDependencyInfo di
;
4840 /* Registers a unit for requiring a certain path and all its prefixes. We keep a hashtable of these paths in
4841 * the unit (from the path to the UnitDependencyInfo structure indicating how to the dependency came to
4842 * be). However, we build a prefix table for all possible prefixes so that new appearing mount units can easily
4843 * determine which units to make themselves a dependency of. */
4845 if (!path_is_absolute(path
))
4848 r
= hashmap_ensure_allocated(&u
->requires_mounts_for
, &path_hash_ops
);
4856 path
= path_simplify(p
, true);
4858 if (!path_is_normalized(path
))
4861 if (hashmap_contains(u
->requires_mounts_for
, path
))
4864 di
= (UnitDependencyInfo
) {
4868 r
= hashmap_put(u
->requires_mounts_for
, path
, di
.data
);
4873 char prefix
[strlen(path
) + 1];
4874 PATH_FOREACH_PREFIX_MORE(prefix
, path
) {
4877 x
= hashmap_get(u
->manager
->units_requiring_mounts_for
, prefix
);
4879 _cleanup_free_
char *q
= NULL
;
4881 r
= hashmap_ensure_allocated(&u
->manager
->units_requiring_mounts_for
, &path_hash_ops
);
4893 r
= hashmap_put(u
->manager
->units_requiring_mounts_for
, q
, x
);
4909 int unit_setup_exec_runtime(Unit
*u
) {
4917 offset
= UNIT_VTABLE(u
)->exec_runtime_offset
;
4920 /* Check if there already is an ExecRuntime for this unit? */
4921 rt
= (ExecRuntime
**) ((uint8_t*) u
+ offset
);
4925 /* Try to get it from somebody else */
4926 HASHMAP_FOREACH_KEY(v
, other
, u
->dependencies
[UNIT_JOINS_NAMESPACE_OF
], i
) {
4927 r
= exec_runtime_acquire(u
->manager
, NULL
, other
->id
, false, rt
);
4932 return exec_runtime_acquire(u
->manager
, unit_get_exec_context(u
), u
->id
, true, rt
);
4935 int unit_setup_dynamic_creds(Unit
*u
) {
4937 DynamicCreds
*dcreds
;
4942 offset
= UNIT_VTABLE(u
)->dynamic_creds_offset
;
4944 dcreds
= (DynamicCreds
*) ((uint8_t*) u
+ offset
);
4946 ec
= unit_get_exec_context(u
);
4949 if (!ec
->dynamic_user
)
4952 return dynamic_creds_acquire(dcreds
, u
->manager
, ec
->user
, ec
->group
);
4955 bool unit_type_supported(UnitType t
) {
4956 if (_unlikely_(t
< 0))
4958 if (_unlikely_(t
>= _UNIT_TYPE_MAX
))
4961 if (!unit_vtable
[t
]->supported
)
4964 return unit_vtable
[t
]->supported();
4967 void unit_warn_if_dir_nonempty(Unit
*u
, const char* where
) {
4973 r
= dir_is_empty(where
);
4974 if (r
> 0 || r
== -ENOTDIR
)
4977 log_unit_warning_errno(u
, r
, "Failed to check directory %s: %m", where
);
4981 log_struct(LOG_NOTICE
,
4982 "MESSAGE_ID=" SD_MESSAGE_OVERMOUNTING_STR
,
4984 LOG_UNIT_INVOCATION_ID(u
),
4985 LOG_UNIT_MESSAGE(u
, "Directory %s to mount over is not empty, mounting anyway.", where
),
4989 int unit_fail_if_noncanonical(Unit
*u
, const char* where
) {
4990 _cleanup_free_
char *canonical_where
= NULL
;
4996 r
= chase_symlinks(where
, NULL
, CHASE_NONEXISTENT
, &canonical_where
);
4998 log_unit_debug_errno(u
, r
, "Failed to check %s for symlinks, ignoring: %m", where
);
5002 /* We will happily ignore a trailing slash (or any redundant slashes) */
5003 if (path_equal(where
, canonical_where
))
5006 /* No need to mention "." or "..", they would already have been rejected by unit_name_from_path() */
5008 "MESSAGE_ID=" SD_MESSAGE_OVERMOUNTING_STR
,
5010 LOG_UNIT_INVOCATION_ID(u
),
5011 LOG_UNIT_MESSAGE(u
, "Mount path %s is not canonical (contains a symlink).", where
),
5017 bool unit_is_pristine(Unit
*u
) {
5020 /* Check if the unit already exists or is already around,
5021 * in a number of different ways. Note that to cater for unit
5022 * types such as slice, we are generally fine with units that
5023 * are marked UNIT_LOADED even though nothing was actually
5024 * loaded, as those unit types don't require a file on disk. */
5026 return !(!IN_SET(u
->load_state
, UNIT_NOT_FOUND
, UNIT_LOADED
) ||
5029 !strv_isempty(u
->dropin_paths
) ||
5034 pid_t
unit_control_pid(Unit
*u
) {
5037 if (UNIT_VTABLE(u
)->control_pid
)
5038 return UNIT_VTABLE(u
)->control_pid(u
);
5043 pid_t
unit_main_pid(Unit
*u
) {
5046 if (UNIT_VTABLE(u
)->main_pid
)
5047 return UNIT_VTABLE(u
)->main_pid(u
);
5052 static void unit_unref_uid_internal(
5056 void (*_manager_unref_uid
)(Manager
*m
, uid_t uid
, bool destroy_now
)) {
5060 assert(_manager_unref_uid
);
5062 /* Generic implementation of both unit_unref_uid() and unit_unref_gid(), under the assumption that uid_t and
5063 * gid_t are actually the same time, with the same validity rules.
5065 * Drops a reference to UID/GID from a unit. */
5067 assert_cc(sizeof(uid_t
) == sizeof(gid_t
));
5068 assert_cc(UID_INVALID
== (uid_t
) GID_INVALID
);
5070 if (!uid_is_valid(*ref_uid
))
5073 _manager_unref_uid(u
->manager
, *ref_uid
, destroy_now
);
5074 *ref_uid
= UID_INVALID
;
5077 void unit_unref_uid(Unit
*u
, bool destroy_now
) {
5078 unit_unref_uid_internal(u
, &u
->ref_uid
, destroy_now
, manager_unref_uid
);
5081 void unit_unref_gid(Unit
*u
, bool destroy_now
) {
5082 unit_unref_uid_internal(u
, (uid_t
*) &u
->ref_gid
, destroy_now
, manager_unref_gid
);
5085 static int unit_ref_uid_internal(
5090 int (*_manager_ref_uid
)(Manager
*m
, uid_t uid
, bool clean_ipc
)) {
5096 assert(uid_is_valid(uid
));
5097 assert(_manager_ref_uid
);
5099 /* Generic implementation of both unit_ref_uid() and unit_ref_guid(), under the assumption that uid_t and gid_t
5100 * are actually the same type, and have the same validity rules.
5102 * Adds a reference on a specific UID/GID to this unit. Each unit referencing the same UID/GID maintains a
5103 * reference so that we can destroy the UID/GID's IPC resources as soon as this is requested and the counter
5106 assert_cc(sizeof(uid_t
) == sizeof(gid_t
));
5107 assert_cc(UID_INVALID
== (uid_t
) GID_INVALID
);
5109 if (*ref_uid
== uid
)
5112 if (uid_is_valid(*ref_uid
)) /* Already set? */
5115 r
= _manager_ref_uid(u
->manager
, uid
, clean_ipc
);
5123 int unit_ref_uid(Unit
*u
, uid_t uid
, bool clean_ipc
) {
5124 return unit_ref_uid_internal(u
, &u
->ref_uid
, uid
, clean_ipc
, manager_ref_uid
);
5127 int unit_ref_gid(Unit
*u
, gid_t gid
, bool clean_ipc
) {
5128 return unit_ref_uid_internal(u
, (uid_t
*) &u
->ref_gid
, (uid_t
) gid
, clean_ipc
, manager_ref_gid
);
5131 static int unit_ref_uid_gid_internal(Unit
*u
, uid_t uid
, gid_t gid
, bool clean_ipc
) {
5136 /* Reference both a UID and a GID in one go. Either references both, or neither. */
5138 if (uid_is_valid(uid
)) {
5139 r
= unit_ref_uid(u
, uid
, clean_ipc
);
5144 if (gid_is_valid(gid
)) {
5145 q
= unit_ref_gid(u
, gid
, clean_ipc
);
5148 unit_unref_uid(u
, false);
5154 return r
> 0 || q
> 0;
5157 int unit_ref_uid_gid(Unit
*u
, uid_t uid
, gid_t gid
) {
5163 c
= unit_get_exec_context(u
);
5165 r
= unit_ref_uid_gid_internal(u
, uid
, gid
, c
? c
->remove_ipc
: false);
5167 return log_unit_warning_errno(u
, r
, "Couldn't add UID/GID reference to unit, proceeding without: %m");
5172 void unit_unref_uid_gid(Unit
*u
, bool destroy_now
) {
5175 unit_unref_uid(u
, destroy_now
);
5176 unit_unref_gid(u
, destroy_now
);
5179 void unit_notify_user_lookup(Unit
*u
, uid_t uid
, gid_t gid
) {
5184 /* This is invoked whenever one of the forked off processes let's us know the UID/GID its user name/group names
5185 * resolved to. We keep track of which UID/GID is currently assigned in order to be able to destroy its IPC
5186 * objects when no service references the UID/GID anymore. */
5188 r
= unit_ref_uid_gid(u
, uid
, gid
);
5190 unit_add_to_dbus_queue(u
);
5193 int unit_set_invocation_id(Unit
*u
, sd_id128_t id
) {
5198 /* Set the invocation ID for this unit. If we cannot, this will not roll back, but reset the whole thing. */
5200 if (sd_id128_equal(u
->invocation_id
, id
))
5203 if (!sd_id128_is_null(u
->invocation_id
))
5204 (void) hashmap_remove_value(u
->manager
->units_by_invocation_id
, &u
->invocation_id
, u
);
5206 if (sd_id128_is_null(id
)) {
5211 r
= hashmap_ensure_allocated(&u
->manager
->units_by_invocation_id
, &id128_hash_ops
);
5215 u
->invocation_id
= id
;
5216 sd_id128_to_string(id
, u
->invocation_id_string
);
5218 r
= hashmap_put(u
->manager
->units_by_invocation_id
, &u
->invocation_id
, u
);
5225 u
->invocation_id
= SD_ID128_NULL
;
5226 u
->invocation_id_string
[0] = 0;
5230 int unit_acquire_invocation_id(Unit
*u
) {
5236 r
= sd_id128_randomize(&id
);
5238 return log_unit_error_errno(u
, r
, "Failed to generate invocation ID for unit: %m");
5240 r
= unit_set_invocation_id(u
, id
);
5242 return log_unit_error_errno(u
, r
, "Failed to set invocation ID for unit: %m");
5244 unit_add_to_dbus_queue(u
);
5248 int unit_set_exec_params(Unit
*u
, ExecParameters
*p
) {
5254 /* Copy parameters from manager */
5255 r
= manager_get_effective_environment(u
->manager
, &p
->environment
);
5259 p
->confirm_spawn
= manager_get_confirm_spawn(u
->manager
);
5260 p
->cgroup_supported
= u
->manager
->cgroup_supported
;
5261 p
->prefix
= u
->manager
->prefix
;
5262 SET_FLAG(p
->flags
, EXEC_PASS_LOG_UNIT
|EXEC_CHOWN_DIRECTORIES
, MANAGER_IS_SYSTEM(u
->manager
));
5264 /* Copy parameters from unit */
5265 p
->cgroup_path
= u
->cgroup_path
;
5266 SET_FLAG(p
->flags
, EXEC_CGROUP_DELEGATE
, unit_cgroup_delegate(u
));
5271 int unit_fork_helper_process(Unit
*u
, const char *name
, pid_t
*ret
) {
5277 /* Forks off a helper process and makes sure it is a member of the unit's cgroup. Returns == 0 in the child,
5278 * and > 0 in the parent. The pid parameter is always filled in with the child's PID. */
5280 (void) unit_realize_cgroup(u
);
5282 r
= safe_fork(name
, FORK_REOPEN_LOG
, ret
);
5286 (void) default_signals(SIGNALS_CRASH_HANDLER
, SIGNALS_IGNORE
, -1);
5287 (void) ignore_signals(SIGPIPE
, -1);
5289 (void) prctl(PR_SET_PDEATHSIG
, SIGTERM
);
5291 if (u
->cgroup_path
) {
5292 r
= cg_attach_everywhere(u
->manager
->cgroup_supported
, u
->cgroup_path
, 0, NULL
, NULL
);
5294 log_unit_error_errno(u
, r
, "Failed to join unit cgroup %s: %m", u
->cgroup_path
);
5302 int unit_fork_and_watch_rm_rf(Unit
*u
, char **paths
, pid_t
*ret_pid
) {
5309 r
= unit_fork_helper_process(u
, "(sd-rmrf)", &pid
);
5313 int ret
= EXIT_SUCCESS
;
5316 STRV_FOREACH(i
, paths
) {
5317 r
= rm_rf(*i
, REMOVE_ROOT
|REMOVE_PHYSICAL
|REMOVE_MISSING_OK
);
5319 log_error_errno(r
, "Failed to remove '%s': %m", *i
);
5327 r
= unit_watch_pid(u
, pid
, true);
5335 static void unit_update_dependency_mask(Unit
*u
, UnitDependency d
, Unit
*other
, UnitDependencyInfo di
) {
5338 assert(d
< _UNIT_DEPENDENCY_MAX
);
5341 if (di
.origin_mask
== 0 && di
.destination_mask
== 0) {
5342 /* No bit set anymore, let's drop the whole entry */
5343 assert_se(hashmap_remove(u
->dependencies
[d
], other
));
5344 log_unit_debug(u
, "%s lost dependency %s=%s", u
->id
, unit_dependency_to_string(d
), other
->id
);
5346 /* Mask was reduced, let's update the entry */
5347 assert_se(hashmap_update(u
->dependencies
[d
], other
, di
.data
) == 0);
5350 void unit_remove_dependencies(Unit
*u
, UnitDependencyMask mask
) {
5355 /* Removes all dependencies u has on other units marked for ownership by 'mask'. */
5360 for (d
= 0; d
< _UNIT_DEPENDENCY_MAX
; d
++) {
5364 UnitDependencyInfo di
;
5370 HASHMAP_FOREACH_KEY(di
.data
, other
, u
->dependencies
[d
], i
) {
5373 if ((di
.origin_mask
& ~mask
) == di
.origin_mask
)
5375 di
.origin_mask
&= ~mask
;
5376 unit_update_dependency_mask(u
, d
, other
, di
);
5378 /* We updated the dependency from our unit to the other unit now. But most dependencies
5379 * imply a reverse dependency. Hence, let's delete that one too. For that we go through
5380 * all dependency types on the other unit and delete all those which point to us and
5381 * have the right mask set. */
5383 for (q
= 0; q
< _UNIT_DEPENDENCY_MAX
; q
++) {
5384 UnitDependencyInfo dj
;
5386 dj
.data
= hashmap_get(other
->dependencies
[q
], u
);
5387 if ((dj
.destination_mask
& ~mask
) == dj
.destination_mask
)
5389 dj
.destination_mask
&= ~mask
;
5391 unit_update_dependency_mask(other
, q
, u
, dj
);
5394 unit_add_to_gc_queue(other
);
5404 static int unit_export_invocation_id(Unit
*u
) {
5410 if (u
->exported_invocation_id
)
5413 if (sd_id128_is_null(u
->invocation_id
))
5416 p
= strjoina("/run/systemd/units/invocation:", u
->id
);
5417 r
= symlink_atomic(u
->invocation_id_string
, p
);
5419 return log_unit_debug_errno(u
, r
, "Failed to create invocation ID symlink %s: %m", p
);
5421 u
->exported_invocation_id
= true;
5425 static int unit_export_log_level_max(Unit
*u
, const ExecContext
*c
) {
5433 if (u
->exported_log_level_max
)
5436 if (c
->log_level_max
< 0)
5439 assert(c
->log_level_max
<= 7);
5441 buf
[0] = '0' + c
->log_level_max
;
5444 p
= strjoina("/run/systemd/units/log-level-max:", u
->id
);
5445 r
= symlink_atomic(buf
, p
);
5447 return log_unit_debug_errno(u
, r
, "Failed to create maximum log level symlink %s: %m", p
);
5449 u
->exported_log_level_max
= true;
5453 static int unit_export_log_extra_fields(Unit
*u
, const ExecContext
*c
) {
5454 _cleanup_close_
int fd
= -1;
5455 struct iovec
*iovec
;
5463 if (u
->exported_log_extra_fields
)
5466 if (c
->n_log_extra_fields
<= 0)
5469 sizes
= newa(le64_t
, c
->n_log_extra_fields
);
5470 iovec
= newa(struct iovec
, c
->n_log_extra_fields
* 2);
5472 for (i
= 0; i
< c
->n_log_extra_fields
; i
++) {
5473 sizes
[i
] = htole64(c
->log_extra_fields
[i
].iov_len
);
5475 iovec
[i
*2] = IOVEC_MAKE(sizes
+ i
, sizeof(le64_t
));
5476 iovec
[i
*2+1] = c
->log_extra_fields
[i
];
5479 p
= strjoina("/run/systemd/units/log-extra-fields:", u
->id
);
5480 pattern
= strjoina(p
, ".XXXXXX");
5482 fd
= mkostemp_safe(pattern
);
5484 return log_unit_debug_errno(u
, fd
, "Failed to create extra fields file %s: %m", p
);
5486 n
= writev(fd
, iovec
, c
->n_log_extra_fields
*2);
5488 r
= log_unit_debug_errno(u
, errno
, "Failed to write extra fields: %m");
5492 (void) fchmod(fd
, 0644);
5494 if (rename(pattern
, p
) < 0) {
5495 r
= log_unit_debug_errno(u
, errno
, "Failed to rename extra fields file: %m");
5499 u
->exported_log_extra_fields
= true;
5503 (void) unlink(pattern
);
5507 static int unit_export_log_ratelimit_interval(Unit
*u
, const ExecContext
*c
) {
5508 _cleanup_free_
char *buf
= NULL
;
5515 if (u
->exported_log_ratelimit_interval
)
5518 if (c
->log_ratelimit_interval_usec
== 0)
5521 p
= strjoina("/run/systemd/units/log-rate-limit-interval:", u
->id
);
5523 if (asprintf(&buf
, "%" PRIu64
, c
->log_ratelimit_interval_usec
) < 0)
5526 r
= symlink_atomic(buf
, p
);
5528 return log_unit_debug_errno(u
, r
, "Failed to create log rate limit interval symlink %s: %m", p
);
5530 u
->exported_log_ratelimit_interval
= true;
5534 static int unit_export_log_ratelimit_burst(Unit
*u
, const ExecContext
*c
) {
5535 _cleanup_free_
char *buf
= NULL
;
5542 if (u
->exported_log_ratelimit_burst
)
5545 if (c
->log_ratelimit_burst
== 0)
5548 p
= strjoina("/run/systemd/units/log-rate-limit-burst:", u
->id
);
5550 if (asprintf(&buf
, "%u", c
->log_ratelimit_burst
) < 0)
5553 r
= symlink_atomic(buf
, p
);
5555 return log_unit_debug_errno(u
, r
, "Failed to create log rate limit burst symlink %s: %m", p
);
5557 u
->exported_log_ratelimit_burst
= true;
5561 void unit_export_state_files(Unit
*u
) {
5562 const ExecContext
*c
;
5569 if (!MANAGER_IS_SYSTEM(u
->manager
))
5572 if (MANAGER_IS_TEST_RUN(u
->manager
))
5575 /* Exports a couple of unit properties to /run/systemd/units/, so that journald can quickly query this data
5576 * from there. Ideally, journald would use IPC to query this, like everybody else, but that's hard, as long as
5577 * the IPC system itself and PID 1 also log to the journal.
5579 * Note that these files really shouldn't be considered API for anyone else, as use a runtime file system as
5580 * IPC replacement is not compatible with today's world of file system namespaces. However, this doesn't really
5581 * apply to communication between the journal and systemd, as we assume that these two daemons live in the same
5582 * namespace at least.
5584 * Note that some of the "files" exported here are actually symlinks and not regular files. Symlinks work
5585 * better for storing small bits of data, in particular as we can write them with two system calls, and read
5588 (void) unit_export_invocation_id(u
);
5590 c
= unit_get_exec_context(u
);
5592 (void) unit_export_log_level_max(u
, c
);
5593 (void) unit_export_log_extra_fields(u
, c
);
5594 (void) unit_export_log_ratelimit_interval(u
, c
);
5595 (void) unit_export_log_ratelimit_burst(u
, c
);
5599 void unit_unlink_state_files(Unit
*u
) {
5607 if (!MANAGER_IS_SYSTEM(u
->manager
))
5610 /* Undoes the effect of unit_export_state() */
5612 if (u
->exported_invocation_id
) {
5613 p
= strjoina("/run/systemd/units/invocation:", u
->id
);
5616 u
->exported_invocation_id
= false;
5619 if (u
->exported_log_level_max
) {
5620 p
= strjoina("/run/systemd/units/log-level-max:", u
->id
);
5623 u
->exported_log_level_max
= false;
5626 if (u
->exported_log_extra_fields
) {
5627 p
= strjoina("/run/systemd/units/extra-fields:", u
->id
);
5630 u
->exported_log_extra_fields
= false;
5633 if (u
->exported_log_ratelimit_interval
) {
5634 p
= strjoina("/run/systemd/units/log-rate-limit-interval:", u
->id
);
5637 u
->exported_log_ratelimit_interval
= false;
5640 if (u
->exported_log_ratelimit_burst
) {
5641 p
= strjoina("/run/systemd/units/log-rate-limit-burst:", u
->id
);
5644 u
->exported_log_ratelimit_burst
= false;
5648 int unit_prepare_exec(Unit
*u
) {
5653 /* Load any custom firewall BPF programs here once to test if they are existing and actually loadable.
5654 * Fail here early since later errors in the call chain unit_realize_cgroup to cgroup_context_apply are ignored. */
5655 r
= bpf_firewall_load_custom(u
);
5659 /* Prepares everything so that we can fork of a process for this unit */
5661 (void) unit_realize_cgroup(u
);
5663 if (u
->reset_accounting
) {
5664 (void) unit_reset_accounting(u
);
5665 u
->reset_accounting
= false;
5668 unit_export_state_files(u
);
5670 r
= unit_setup_exec_runtime(u
);
5674 r
= unit_setup_dynamic_creds(u
);
5681 static int log_leftover(pid_t pid
, int sig
, void *userdata
) {
5682 _cleanup_free_
char *comm
= NULL
;
5684 (void) get_process_comm(pid
, &comm
);
5686 if (comm
&& comm
[0] == '(') /* Most likely our own helper process (PAM?), ignore */
5689 log_unit_warning(userdata
,
5690 "Found left-over process " PID_FMT
" (%s) in control group while starting unit. Ignoring.\n"
5691 "This usually indicates unclean termination of a previous run, or service implementation deficiencies.",
5697 int unit_warn_leftover_processes(Unit
*u
) {
5700 (void) unit_pick_cgroup_path(u
);
5702 if (!u
->cgroup_path
)
5705 return cg_kill_recursive(SYSTEMD_CGROUP_CONTROLLER
, u
->cgroup_path
, 0, 0, NULL
, log_leftover
, u
);
5708 bool unit_needs_console(Unit
*u
) {
5710 UnitActiveState state
;
5714 state
= unit_active_state(u
);
5716 if (UNIT_IS_INACTIVE_OR_FAILED(state
))
5719 if (UNIT_VTABLE(u
)->needs_console
)
5720 return UNIT_VTABLE(u
)->needs_console(u
);
5722 /* If this unit type doesn't implement this call, let's use a generic fallback implementation: */
5723 ec
= unit_get_exec_context(u
);
5727 return exec_context_may_touch_console(ec
);
5730 const char *unit_label_path(Unit
*u
) {
5733 /* Returns the file system path to use for MAC access decisions, i.e. the file to read the SELinux label off
5734 * when validating access checks. */
5736 p
= u
->source_path
?: u
->fragment_path
;
5740 /* If a unit is masked, then don't read the SELinux label of /dev/null, as that really makes no sense */
5741 if (path_equal(p
, "/dev/null"))
5747 int unit_pid_attachable(Unit
*u
, pid_t pid
, sd_bus_error
*error
) {
5752 /* Checks whether the specified PID is generally good for attaching, i.e. a valid PID, not our manager itself,
5753 * and not a kernel thread either */
5755 /* First, a simple range check */
5756 if (!pid_is_valid(pid
))
5757 return sd_bus_error_setf(error
, SD_BUS_ERROR_INVALID_ARGS
, "Process identifier " PID_FMT
" is not valid.", pid
);
5759 /* Some extra safety check */
5760 if (pid
== 1 || pid
== getpid_cached())
5761 return sd_bus_error_setf(error
, SD_BUS_ERROR_INVALID_ARGS
, "Process " PID_FMT
" is a manager process, refusing.", pid
);
5763 /* Don't even begin to bother with kernel threads */
5764 r
= is_kernel_thread(pid
);
5766 return sd_bus_error_setf(error
, SD_BUS_ERROR_UNIX_PROCESS_ID_UNKNOWN
, "Process with ID " PID_FMT
" does not exist.", pid
);
5768 return sd_bus_error_set_errnof(error
, r
, "Failed to determine whether process " PID_FMT
" is a kernel thread: %m", pid
);
5770 return sd_bus_error_setf(error
, SD_BUS_ERROR_INVALID_ARGS
, "Process " PID_FMT
" is a kernel thread, refusing.", pid
);
5775 void unit_log_success(Unit
*u
) {
5778 log_struct(LOG_INFO
,
5779 "MESSAGE_ID=" SD_MESSAGE_UNIT_SUCCESS_STR
,
5781 LOG_UNIT_INVOCATION_ID(u
),
5782 LOG_UNIT_MESSAGE(u
, "Succeeded."));
5785 void unit_log_failure(Unit
*u
, const char *result
) {
5789 log_struct(LOG_WARNING
,
5790 "MESSAGE_ID=" SD_MESSAGE_UNIT_FAILURE_RESULT_STR
,
5792 LOG_UNIT_INVOCATION_ID(u
),
5793 LOG_UNIT_MESSAGE(u
, "Failed with result '%s'.", result
),
5794 "UNIT_RESULT=%s", result
);
5797 void unit_log_skip(Unit
*u
, const char *result
) {
5801 log_struct(LOG_INFO
,
5802 "MESSAGE_ID=" SD_MESSAGE_UNIT_SKIPPED_STR
,
5804 LOG_UNIT_INVOCATION_ID(u
),
5805 LOG_UNIT_MESSAGE(u
, "Skipped due to '%s'.", result
),
5806 "UNIT_RESULT=%s", result
);
5809 void unit_log_process_exit(
5812 const char *command
,
5822 /* If this is a successful exit, let's log about the exit code on DEBUG level. If this is a failure
5823 * and the process exited on its own via exit(), then let's make this a NOTICE, under the assumption
5824 * that the service already logged the reason at a higher log level on its own. Otherwise, make it a
5828 else if (code
== CLD_EXITED
)
5831 level
= LOG_WARNING
;
5834 "MESSAGE_ID=" SD_MESSAGE_UNIT_PROCESS_EXIT_STR
,
5835 LOG_UNIT_MESSAGE(u
, "%s exited, code=%s, status=%i/%s",
5837 sigchld_code_to_string(code
), status
,
5838 strna(code
== CLD_EXITED
5839 ? exit_status_to_string(status
, EXIT_STATUS_FULL
)
5840 : signal_to_string(status
))),
5841 "EXIT_CODE=%s", sigchld_code_to_string(code
),
5842 "EXIT_STATUS=%i", status
,
5843 "COMMAND=%s", strna(command
),
5845 LOG_UNIT_INVOCATION_ID(u
));
5848 int unit_exit_status(Unit
*u
) {
5851 /* Returns the exit status to propagate for the most recent cycle of this unit. Returns a value in the range
5852 * 0…255 if there's something to propagate. EOPNOTSUPP if the concept does not apply to this unit type, ENODATA
5853 * if no data is currently known (for example because the unit hasn't deactivated yet) and EBADE if the main
5854 * service process has exited abnormally (signal/coredump). */
5856 if (!UNIT_VTABLE(u
)->exit_status
)
5859 return UNIT_VTABLE(u
)->exit_status(u
);
5862 int unit_failure_action_exit_status(Unit
*u
) {
5867 /* Returns the exit status to propagate on failure, or an error if there's nothing to propagate */
5869 if (u
->failure_action_exit_status
>= 0)
5870 return u
->failure_action_exit_status
;
5872 r
= unit_exit_status(u
);
5873 if (r
== -EBADE
) /* Exited, but not cleanly (i.e. by signal or such) */
5879 int unit_success_action_exit_status(Unit
*u
) {
5884 /* Returns the exit status to propagate on success, or an error if there's nothing to propagate */
5886 if (u
->success_action_exit_status
>= 0)
5887 return u
->success_action_exit_status
;
5889 r
= unit_exit_status(u
);
5890 if (r
== -EBADE
) /* Exited, but not cleanly (i.e. by signal or such) */
5896 int unit_test_trigger_loaded(Unit
*u
) {
5899 /* Tests whether the unit to trigger is loaded */
5901 trigger
= UNIT_TRIGGER(u
);
5903 return log_unit_error_errno(u
, SYNTHETIC_ERRNO(ENOENT
),
5904 "Refusing to start, no unit to trigger.");
5905 if (trigger
->load_state
!= UNIT_LOADED
)
5906 return log_unit_error_errno(u
, SYNTHETIC_ERRNO(ENOENT
),
5907 "Refusing to start, unit %s to trigger not loaded.", trigger
->id
);
5912 void unit_destroy_runtime_directory(Unit
*u
, const ExecContext
*context
) {
5913 if (context
->runtime_directory_preserve_mode
== EXEC_PRESERVE_NO
||
5914 (context
->runtime_directory_preserve_mode
== EXEC_PRESERVE_RESTART
&& !unit_will_restart(u
)))
5915 exec_context_destroy_runtime_directory(context
, u
->manager
->prefix
[EXEC_DIRECTORY_RUNTIME
]);
5918 int unit_clean(Unit
*u
, ExecCleanMask mask
) {
5919 UnitActiveState state
;
5923 /* Special return values:
5925 * -EOPNOTSUPP → cleaning not supported for this unit type
5926 * -EUNATCH → cleaning not defined for this resource type
5927 * -EBUSY → unit currently can't be cleaned since it's running or not properly loaded, or has
5928 * a job queued or similar
5931 if (!UNIT_VTABLE(u
)->clean
)
5937 if (u
->load_state
!= UNIT_LOADED
)
5943 state
= unit_active_state(u
);
5944 if (!IN_SET(state
, UNIT_INACTIVE
))
5947 return UNIT_VTABLE(u
)->clean(u
, mask
);
5950 int unit_can_clean(Unit
*u
, ExecCleanMask
*ret
) {
5953 if (!UNIT_VTABLE(u
)->clean
||
5954 u
->load_state
!= UNIT_LOADED
) {
5959 /* When the clean() method is set, can_clean() really should be set too */
5960 assert(UNIT_VTABLE(u
)->can_clean
);
5962 return UNIT_VTABLE(u
)->can_clean(u
, ret
);
5965 static const char* const collect_mode_table
[_COLLECT_MODE_MAX
] = {
5966 [COLLECT_INACTIVE
] = "inactive",
5967 [COLLECT_INACTIVE_OR_FAILED
] = "inactive-or-failed",
5970 DEFINE_STRING_TABLE_LOOKUP(collect_mode
, CollectMode
);