]> git.ipfire.org Git - thirdparty/systemd.git/blob - src/core/unit.c
core: make manager_serialize() a bit easier to read by adding predicate function
[thirdparty/systemd.git] / src / core / unit.c
1 /* SPDX-License-Identifier: LGPL-2.1+ */
2
3 #include <errno.h>
4 #include <stdlib.h>
5 #include <string.h>
6 #include <sys/prctl.h>
7 #include <sys/stat.h>
8 #include <unistd.h>
9
10 #include "sd-id128.h"
11 #include "sd-messages.h"
12
13 #include "alloc-util.h"
14 #include "all-units.h"
15 #include "bus-common-errors.h"
16 #include "bus-util.h"
17 #include "cgroup-util.h"
18 #include "dbus-unit.h"
19 #include "dbus.h"
20 #include "dropin.h"
21 #include "escape.h"
22 #include "execute.h"
23 #include "fd-util.h"
24 #include "fileio-label.h"
25 #include "format-util.h"
26 #include "fs-util.h"
27 #include "id128-util.h"
28 #include "io-util.h"
29 #include "load-dropin.h"
30 #include "load-fragment.h"
31 #include "log.h"
32 #include "macro.h"
33 #include "missing.h"
34 #include "mkdir.h"
35 #include "parse-util.h"
36 #include "path-util.h"
37 #include "process-util.h"
38 #include "set.h"
39 #include "signal-util.h"
40 #include "sparse-endian.h"
41 #include "special.h"
42 #include "specifier.h"
43 #include "stat-util.h"
44 #include "stdio-util.h"
45 #include "string-table.h"
46 #include "string-util.h"
47 #include "strv.h"
48 #include "umask-util.h"
49 #include "unit-name.h"
50 #include "unit.h"
51 #include "user-util.h"
52 #include "virt.h"
53
54 const UnitVTable * const unit_vtable[_UNIT_TYPE_MAX] = {
55 [UNIT_SERVICE] = &service_vtable,
56 [UNIT_SOCKET] = &socket_vtable,
57 [UNIT_TARGET] = &target_vtable,
58 [UNIT_DEVICE] = &device_vtable,
59 [UNIT_MOUNT] = &mount_vtable,
60 [UNIT_AUTOMOUNT] = &automount_vtable,
61 [UNIT_SWAP] = &swap_vtable,
62 [UNIT_TIMER] = &timer_vtable,
63 [UNIT_PATH] = &path_vtable,
64 [UNIT_SLICE] = &slice_vtable,
65 [UNIT_SCOPE] = &scope_vtable,
66 };
67
68 static void maybe_warn_about_dependency(Unit *u, const char *other, UnitDependency dependency);
69
70 Unit *unit_new(Manager *m, size_t size) {
71 Unit *u;
72
73 assert(m);
74 assert(size >= sizeof(Unit));
75
76 u = malloc0(size);
77 if (!u)
78 return NULL;
79
80 u->names = set_new(&string_hash_ops);
81 if (!u->names)
82 return mfree(u);
83
84 u->manager = m;
85 u->type = _UNIT_TYPE_INVALID;
86 u->default_dependencies = true;
87 u->unit_file_state = _UNIT_FILE_STATE_INVALID;
88 u->unit_file_preset = -1;
89 u->on_failure_job_mode = JOB_REPLACE;
90 u->cgroup_inotify_wd = -1;
91 u->job_timeout = USEC_INFINITY;
92 u->job_running_timeout = USEC_INFINITY;
93 u->ref_uid = UID_INVALID;
94 u->ref_gid = GID_INVALID;
95 u->cpu_usage_last = NSEC_INFINITY;
96 u->cgroup_invalidated_mask |= CGROUP_MASK_BPF_FIREWALL;
97
98 u->ip_accounting_ingress_map_fd = -1;
99 u->ip_accounting_egress_map_fd = -1;
100 u->ipv4_allow_map_fd = -1;
101 u->ipv6_allow_map_fd = -1;
102 u->ipv4_deny_map_fd = -1;
103 u->ipv6_deny_map_fd = -1;
104
105 u->last_section_private = -1;
106
107 RATELIMIT_INIT(u->start_limit, m->default_start_limit_interval, m->default_start_limit_burst);
108 RATELIMIT_INIT(u->auto_stop_ratelimit, 10 * USEC_PER_SEC, 16);
109
110 return u;
111 }
112
113 int unit_new_for_name(Manager *m, size_t size, const char *name, Unit **ret) {
114 _cleanup_(unit_freep) Unit *u = NULL;
115 int r;
116
117 u = unit_new(m, size);
118 if (!u)
119 return -ENOMEM;
120
121 r = unit_add_name(u, name);
122 if (r < 0)
123 return r;
124
125 *ret = TAKE_PTR(u);
126
127 return r;
128 }
129
130 bool unit_has_name(Unit *u, const char *name) {
131 assert(u);
132 assert(name);
133
134 return set_contains(u->names, (char*) name);
135 }
136
137 static void unit_init(Unit *u) {
138 CGroupContext *cc;
139 ExecContext *ec;
140 KillContext *kc;
141
142 assert(u);
143 assert(u->manager);
144 assert(u->type >= 0);
145
146 cc = unit_get_cgroup_context(u);
147 if (cc) {
148 cgroup_context_init(cc);
149
150 /* Copy in the manager defaults into the cgroup
151 * context, _before_ the rest of the settings have
152 * been initialized */
153
154 cc->cpu_accounting = u->manager->default_cpu_accounting;
155 cc->io_accounting = u->manager->default_io_accounting;
156 cc->ip_accounting = u->manager->default_ip_accounting;
157 cc->blockio_accounting = u->manager->default_blockio_accounting;
158 cc->memory_accounting = u->manager->default_memory_accounting;
159 cc->tasks_accounting = u->manager->default_tasks_accounting;
160 cc->ip_accounting = u->manager->default_ip_accounting;
161
162 if (u->type != UNIT_SLICE)
163 cc->tasks_max = u->manager->default_tasks_max;
164 }
165
166 ec = unit_get_exec_context(u);
167 if (ec) {
168 exec_context_init(ec);
169
170 ec->keyring_mode = MANAGER_IS_SYSTEM(u->manager) ?
171 EXEC_KEYRING_SHARED : EXEC_KEYRING_INHERIT;
172 }
173
174 kc = unit_get_kill_context(u);
175 if (kc)
176 kill_context_init(kc);
177
178 if (UNIT_VTABLE(u)->init)
179 UNIT_VTABLE(u)->init(u);
180 }
181
182 int unit_add_name(Unit *u, const char *text) {
183 _cleanup_free_ char *s = NULL, *i = NULL;
184 UnitType t;
185 int r;
186
187 assert(u);
188 assert(text);
189
190 if (unit_name_is_valid(text, UNIT_NAME_TEMPLATE)) {
191
192 if (!u->instance)
193 return -EINVAL;
194
195 r = unit_name_replace_instance(text, u->instance, &s);
196 if (r < 0)
197 return r;
198 } else {
199 s = strdup(text);
200 if (!s)
201 return -ENOMEM;
202 }
203
204 if (set_contains(u->names, s))
205 return 0;
206 if (hashmap_contains(u->manager->units, s))
207 return -EEXIST;
208
209 if (!unit_name_is_valid(s, UNIT_NAME_PLAIN|UNIT_NAME_INSTANCE))
210 return -EINVAL;
211
212 t = unit_name_to_type(s);
213 if (t < 0)
214 return -EINVAL;
215
216 if (u->type != _UNIT_TYPE_INVALID && t != u->type)
217 return -EINVAL;
218
219 r = unit_name_to_instance(s, &i);
220 if (r < 0)
221 return r;
222
223 if (i && !unit_type_may_template(t))
224 return -EINVAL;
225
226 /* Ensure that this unit is either instanced or not instanced,
227 * but not both. Note that we do allow names with different
228 * instance names however! */
229 if (u->type != _UNIT_TYPE_INVALID && !u->instance != !i)
230 return -EINVAL;
231
232 if (!unit_type_may_alias(t) && !set_isempty(u->names))
233 return -EEXIST;
234
235 if (hashmap_size(u->manager->units) >= MANAGER_MAX_NAMES)
236 return -E2BIG;
237
238 r = set_put(u->names, s);
239 if (r < 0)
240 return r;
241 assert(r > 0);
242
243 r = hashmap_put(u->manager->units, s, u);
244 if (r < 0) {
245 (void) set_remove(u->names, s);
246 return r;
247 }
248
249 if (u->type == _UNIT_TYPE_INVALID) {
250 u->type = t;
251 u->id = s;
252 u->instance = TAKE_PTR(i);
253
254 LIST_PREPEND(units_by_type, u->manager->units_by_type[t], u);
255
256 unit_init(u);
257 }
258
259 s = NULL;
260
261 unit_add_to_dbus_queue(u);
262 return 0;
263 }
264
265 int unit_choose_id(Unit *u, const char *name) {
266 _cleanup_free_ char *t = NULL;
267 char *s, *i;
268 int r;
269
270 assert(u);
271 assert(name);
272
273 if (unit_name_is_valid(name, UNIT_NAME_TEMPLATE)) {
274
275 if (!u->instance)
276 return -EINVAL;
277
278 r = unit_name_replace_instance(name, u->instance, &t);
279 if (r < 0)
280 return r;
281
282 name = t;
283 }
284
285 /* Selects one of the names of this unit as the id */
286 s = set_get(u->names, (char*) name);
287 if (!s)
288 return -ENOENT;
289
290 /* Determine the new instance from the new id */
291 r = unit_name_to_instance(s, &i);
292 if (r < 0)
293 return r;
294
295 u->id = s;
296
297 free(u->instance);
298 u->instance = i;
299
300 unit_add_to_dbus_queue(u);
301
302 return 0;
303 }
304
305 int unit_set_description(Unit *u, const char *description) {
306 int r;
307
308 assert(u);
309
310 r = free_and_strdup(&u->description, empty_to_null(description));
311 if (r < 0)
312 return r;
313 if (r > 0)
314 unit_add_to_dbus_queue(u);
315
316 return 0;
317 }
318
319 bool unit_may_gc(Unit *u) {
320 UnitActiveState state;
321 int r;
322
323 assert(u);
324
325 /* Checks whether the unit is ready to be unloaded for garbage collection.
326 * Returns true when the unit may be collected, and false if there's some
327 * reason to keep it loaded.
328 *
329 * References from other units are *not* checked here. Instead, this is done
330 * in unit_gc_sweep(), but using markers to properly collect dependency loops.
331 */
332
333 if (u->job)
334 return false;
335
336 if (u->nop_job)
337 return false;
338
339 state = unit_active_state(u);
340
341 /* If the unit is inactive and failed and no job is queued for it, then release its runtime resources */
342 if (UNIT_IS_INACTIVE_OR_FAILED(state) &&
343 UNIT_VTABLE(u)->release_resources)
344 UNIT_VTABLE(u)->release_resources(u);
345
346 if (u->perpetual)
347 return false;
348
349 if (sd_bus_track_count(u->bus_track) > 0)
350 return false;
351
352 /* But we keep the unit object around for longer when it is referenced or configured to not be gc'ed */
353 switch (u->collect_mode) {
354
355 case COLLECT_INACTIVE:
356 if (state != UNIT_INACTIVE)
357 return false;
358
359 break;
360
361 case COLLECT_INACTIVE_OR_FAILED:
362 if (!IN_SET(state, UNIT_INACTIVE, UNIT_FAILED))
363 return false;
364
365 break;
366
367 default:
368 assert_not_reached("Unknown garbage collection mode");
369 }
370
371 if (u->cgroup_path) {
372 /* If the unit has a cgroup, then check whether there's anything in it. If so, we should stay
373 * around. Units with active processes should never be collected. */
374
375 r = cg_is_empty_recursive(SYSTEMD_CGROUP_CONTROLLER, u->cgroup_path);
376 if (r < 0)
377 log_unit_debug_errno(u, r, "Failed to determine whether cgroup %s is empty: %m", u->cgroup_path);
378 if (r <= 0)
379 return false;
380 }
381
382 if (UNIT_VTABLE(u)->may_gc && !UNIT_VTABLE(u)->may_gc(u))
383 return false;
384
385 return true;
386 }
387
388 void unit_add_to_load_queue(Unit *u) {
389 assert(u);
390 assert(u->type != _UNIT_TYPE_INVALID);
391
392 if (u->load_state != UNIT_STUB || u->in_load_queue)
393 return;
394
395 LIST_PREPEND(load_queue, u->manager->load_queue, u);
396 u->in_load_queue = true;
397 }
398
399 void unit_add_to_cleanup_queue(Unit *u) {
400 assert(u);
401
402 if (u->in_cleanup_queue)
403 return;
404
405 LIST_PREPEND(cleanup_queue, u->manager->cleanup_queue, u);
406 u->in_cleanup_queue = true;
407 }
408
409 void unit_add_to_gc_queue(Unit *u) {
410 assert(u);
411
412 if (u->in_gc_queue || u->in_cleanup_queue)
413 return;
414
415 if (!unit_may_gc(u))
416 return;
417
418 LIST_PREPEND(gc_queue, u->manager->gc_unit_queue, u);
419 u->in_gc_queue = true;
420 }
421
422 void unit_add_to_dbus_queue(Unit *u) {
423 assert(u);
424 assert(u->type != _UNIT_TYPE_INVALID);
425
426 if (u->load_state == UNIT_STUB || u->in_dbus_queue)
427 return;
428
429 /* Shortcut things if nobody cares */
430 if (sd_bus_track_count(u->manager->subscribed) <= 0 &&
431 sd_bus_track_count(u->bus_track) <= 0 &&
432 set_isempty(u->manager->private_buses)) {
433 u->sent_dbus_new_signal = true;
434 return;
435 }
436
437 LIST_PREPEND(dbus_queue, u->manager->dbus_unit_queue, u);
438 u->in_dbus_queue = true;
439 }
440
441 void unit_submit_to_stop_when_unneeded_queue(Unit *u) {
442 assert(u);
443
444 if (u->in_stop_when_unneeded_queue)
445 return;
446
447 if (!u->stop_when_unneeded)
448 return;
449
450 if (!UNIT_IS_ACTIVE_OR_RELOADING(unit_active_state(u)))
451 return;
452
453 LIST_PREPEND(stop_when_unneeded_queue, u->manager->stop_when_unneeded_queue, u);
454 u->in_stop_when_unneeded_queue = true;
455 }
456
457 static void bidi_set_free(Unit *u, Hashmap *h) {
458 Unit *other;
459 Iterator i;
460 void *v;
461
462 assert(u);
463
464 /* Frees the hashmap and makes sure we are dropped from the inverse pointers */
465
466 HASHMAP_FOREACH_KEY(v, other, h, i) {
467 UnitDependency d;
468
469 for (d = 0; d < _UNIT_DEPENDENCY_MAX; d++)
470 hashmap_remove(other->dependencies[d], u);
471
472 unit_add_to_gc_queue(other);
473 }
474
475 hashmap_free(h);
476 }
477
478 static void unit_remove_transient(Unit *u) {
479 char **i;
480
481 assert(u);
482
483 if (!u->transient)
484 return;
485
486 if (u->fragment_path)
487 (void) unlink(u->fragment_path);
488
489 STRV_FOREACH(i, u->dropin_paths) {
490 _cleanup_free_ char *p = NULL, *pp = NULL;
491
492 p = dirname_malloc(*i); /* Get the drop-in directory from the drop-in file */
493 if (!p)
494 continue;
495
496 pp = dirname_malloc(p); /* Get the config directory from the drop-in directory */
497 if (!pp)
498 continue;
499
500 /* Only drop transient drop-ins */
501 if (!path_equal(u->manager->lookup_paths.transient, pp))
502 continue;
503
504 (void) unlink(*i);
505 (void) rmdir(p);
506 }
507 }
508
509 static void unit_free_requires_mounts_for(Unit *u) {
510 assert(u);
511
512 for (;;) {
513 _cleanup_free_ char *path;
514
515 path = hashmap_steal_first_key(u->requires_mounts_for);
516 if (!path)
517 break;
518 else {
519 char s[strlen(path) + 1];
520
521 PATH_FOREACH_PREFIX_MORE(s, path) {
522 char *y;
523 Set *x;
524
525 x = hashmap_get2(u->manager->units_requiring_mounts_for, s, (void**) &y);
526 if (!x)
527 continue;
528
529 (void) set_remove(x, u);
530
531 if (set_isempty(x)) {
532 (void) hashmap_remove(u->manager->units_requiring_mounts_for, y);
533 free(y);
534 set_free(x);
535 }
536 }
537 }
538 }
539
540 u->requires_mounts_for = hashmap_free(u->requires_mounts_for);
541 }
542
543 static void unit_done(Unit *u) {
544 ExecContext *ec;
545 CGroupContext *cc;
546
547 assert(u);
548
549 if (u->type < 0)
550 return;
551
552 if (UNIT_VTABLE(u)->done)
553 UNIT_VTABLE(u)->done(u);
554
555 ec = unit_get_exec_context(u);
556 if (ec)
557 exec_context_done(ec);
558
559 cc = unit_get_cgroup_context(u);
560 if (cc)
561 cgroup_context_done(cc);
562 }
563
564 void unit_free(Unit *u) {
565 UnitDependency d;
566 Iterator i;
567 char *t;
568
569 if (!u)
570 return;
571
572 u->transient_file = safe_fclose(u->transient_file);
573
574 if (!MANAGER_IS_RELOADING(u->manager))
575 unit_remove_transient(u);
576
577 bus_unit_send_removed_signal(u);
578
579 unit_done(u);
580
581 unit_dequeue_rewatch_pids(u);
582
583 sd_bus_slot_unref(u->match_bus_slot);
584 sd_bus_track_unref(u->bus_track);
585 u->deserialized_refs = strv_free(u->deserialized_refs);
586
587 unit_free_requires_mounts_for(u);
588
589 SET_FOREACH(t, u->names, i)
590 hashmap_remove_value(u->manager->units, t, u);
591
592 if (!sd_id128_is_null(u->invocation_id))
593 hashmap_remove_value(u->manager->units_by_invocation_id, &u->invocation_id, u);
594
595 if (u->job) {
596 Job *j = u->job;
597 job_uninstall(j);
598 job_free(j);
599 }
600
601 if (u->nop_job) {
602 Job *j = u->nop_job;
603 job_uninstall(j);
604 job_free(j);
605 }
606
607 for (d = 0; d < _UNIT_DEPENDENCY_MAX; d++)
608 bidi_set_free(u, u->dependencies[d]);
609
610 if (u->on_console)
611 manager_unref_console(u->manager);
612
613 unit_release_cgroup(u);
614
615 if (!MANAGER_IS_RELOADING(u->manager))
616 unit_unlink_state_files(u);
617
618 unit_unref_uid_gid(u, false);
619
620 (void) manager_update_failed_units(u->manager, u, false);
621 set_remove(u->manager->startup_units, u);
622
623 unit_unwatch_all_pids(u);
624
625 unit_ref_unset(&u->slice);
626 while (u->refs_by_target)
627 unit_ref_unset(u->refs_by_target);
628
629 if (u->type != _UNIT_TYPE_INVALID)
630 LIST_REMOVE(units_by_type, u->manager->units_by_type[u->type], u);
631
632 if (u->in_load_queue)
633 LIST_REMOVE(load_queue, u->manager->load_queue, u);
634
635 if (u->in_dbus_queue)
636 LIST_REMOVE(dbus_queue, u->manager->dbus_unit_queue, u);
637
638 if (u->in_gc_queue)
639 LIST_REMOVE(gc_queue, u->manager->gc_unit_queue, u);
640
641 if (u->in_cgroup_realize_queue)
642 LIST_REMOVE(cgroup_realize_queue, u->manager->cgroup_realize_queue, u);
643
644 if (u->in_cgroup_empty_queue)
645 LIST_REMOVE(cgroup_empty_queue, u->manager->cgroup_empty_queue, u);
646
647 if (u->in_cleanup_queue)
648 LIST_REMOVE(cleanup_queue, u->manager->cleanup_queue, u);
649
650 if (u->in_target_deps_queue)
651 LIST_REMOVE(target_deps_queue, u->manager->target_deps_queue, u);
652
653 if (u->in_stop_when_unneeded_queue)
654 LIST_REMOVE(stop_when_unneeded_queue, u->manager->stop_when_unneeded_queue, u);
655
656 safe_close(u->ip_accounting_ingress_map_fd);
657 safe_close(u->ip_accounting_egress_map_fd);
658
659 safe_close(u->ipv4_allow_map_fd);
660 safe_close(u->ipv6_allow_map_fd);
661 safe_close(u->ipv4_deny_map_fd);
662 safe_close(u->ipv6_deny_map_fd);
663
664 bpf_program_unref(u->ip_bpf_ingress);
665 bpf_program_unref(u->ip_bpf_ingress_installed);
666 bpf_program_unref(u->ip_bpf_egress);
667 bpf_program_unref(u->ip_bpf_egress_installed);
668
669 bpf_program_unref(u->bpf_device_control_installed);
670
671 condition_free_list(u->conditions);
672 condition_free_list(u->asserts);
673
674 free(u->description);
675 strv_free(u->documentation);
676 free(u->fragment_path);
677 free(u->source_path);
678 strv_free(u->dropin_paths);
679 free(u->instance);
680
681 free(u->job_timeout_reboot_arg);
682
683 set_free_free(u->names);
684
685 free(u->reboot_arg);
686
687 free(u);
688 }
689
690 UnitActiveState unit_active_state(Unit *u) {
691 assert(u);
692
693 if (u->load_state == UNIT_MERGED)
694 return unit_active_state(unit_follow_merge(u));
695
696 /* After a reload it might happen that a unit is not correctly
697 * loaded but still has a process around. That's why we won't
698 * shortcut failed loading to UNIT_INACTIVE_FAILED. */
699
700 return UNIT_VTABLE(u)->active_state(u);
701 }
702
703 const char* unit_sub_state_to_string(Unit *u) {
704 assert(u);
705
706 return UNIT_VTABLE(u)->sub_state_to_string(u);
707 }
708
709 static int set_complete_move(Set **s, Set **other) {
710 assert(s);
711 assert(other);
712
713 if (!other)
714 return 0;
715
716 if (*s)
717 return set_move(*s, *other);
718 else
719 *s = TAKE_PTR(*other);
720
721 return 0;
722 }
723
724 static int hashmap_complete_move(Hashmap **s, Hashmap **other) {
725 assert(s);
726 assert(other);
727
728 if (!*other)
729 return 0;
730
731 if (*s)
732 return hashmap_move(*s, *other);
733 else
734 *s = TAKE_PTR(*other);
735
736 return 0;
737 }
738
739 static int merge_names(Unit *u, Unit *other) {
740 char *t;
741 Iterator i;
742 int r;
743
744 assert(u);
745 assert(other);
746
747 r = set_complete_move(&u->names, &other->names);
748 if (r < 0)
749 return r;
750
751 set_free_free(other->names);
752 other->names = NULL;
753 other->id = NULL;
754
755 SET_FOREACH(t, u->names, i)
756 assert_se(hashmap_replace(u->manager->units, t, u) == 0);
757
758 return 0;
759 }
760
761 static int reserve_dependencies(Unit *u, Unit *other, UnitDependency d) {
762 unsigned n_reserve;
763
764 assert(u);
765 assert(other);
766 assert(d < _UNIT_DEPENDENCY_MAX);
767
768 /*
769 * If u does not have this dependency set allocated, there is no need
770 * to reserve anything. In that case other's set will be transferred
771 * as a whole to u by complete_move().
772 */
773 if (!u->dependencies[d])
774 return 0;
775
776 /* merge_dependencies() will skip a u-on-u dependency */
777 n_reserve = hashmap_size(other->dependencies[d]) - !!hashmap_get(other->dependencies[d], u);
778
779 return hashmap_reserve(u->dependencies[d], n_reserve);
780 }
781
782 static void merge_dependencies(Unit *u, Unit *other, const char *other_id, UnitDependency d) {
783 Iterator i;
784 Unit *back;
785 void *v;
786 int r;
787
788 /* Merges all dependencies of type 'd' of the unit 'other' into the deps of the unit 'u' */
789
790 assert(u);
791 assert(other);
792 assert(d < _UNIT_DEPENDENCY_MAX);
793
794 /* Fix backwards pointers. Let's iterate through all dependendent units of the other unit. */
795 HASHMAP_FOREACH_KEY(v, back, other->dependencies[d], i) {
796 UnitDependency k;
797
798 /* Let's now iterate through the dependencies of that dependencies of the other units, looking for
799 * pointers back, and let's fix them up, to instead point to 'u'. */
800
801 for (k = 0; k < _UNIT_DEPENDENCY_MAX; k++) {
802 if (back == u) {
803 /* Do not add dependencies between u and itself. */
804 if (hashmap_remove(back->dependencies[k], other))
805 maybe_warn_about_dependency(u, other_id, k);
806 } else {
807 UnitDependencyInfo di_u, di_other, di_merged;
808
809 /* Let's drop this dependency between "back" and "other", and let's create it between
810 * "back" and "u" instead. Let's merge the bit masks of the dependency we are moving,
811 * and any such dependency which might already exist */
812
813 di_other.data = hashmap_get(back->dependencies[k], other);
814 if (!di_other.data)
815 continue; /* dependency isn't set, let's try the next one */
816
817 di_u.data = hashmap_get(back->dependencies[k], u);
818
819 di_merged = (UnitDependencyInfo) {
820 .origin_mask = di_u.origin_mask | di_other.origin_mask,
821 .destination_mask = di_u.destination_mask | di_other.destination_mask,
822 };
823
824 r = hashmap_remove_and_replace(back->dependencies[k], other, u, di_merged.data);
825 if (r < 0)
826 log_warning_errno(r, "Failed to remove/replace: back=%s other=%s u=%s: %m", back->id, other_id, u->id);
827 assert(r >= 0);
828
829 /* assert_se(hashmap_remove_and_replace(back->dependencies[k], other, u, di_merged.data) >= 0); */
830 }
831 }
832
833 }
834
835 /* Also do not move dependencies on u to itself */
836 back = hashmap_remove(other->dependencies[d], u);
837 if (back)
838 maybe_warn_about_dependency(u, other_id, d);
839
840 /* The move cannot fail. The caller must have performed a reservation. */
841 assert_se(hashmap_complete_move(&u->dependencies[d], &other->dependencies[d]) == 0);
842
843 other->dependencies[d] = hashmap_free(other->dependencies[d]);
844 }
845
846 int unit_merge(Unit *u, Unit *other) {
847 UnitDependency d;
848 const char *other_id = NULL;
849 int r;
850
851 assert(u);
852 assert(other);
853 assert(u->manager == other->manager);
854 assert(u->type != _UNIT_TYPE_INVALID);
855
856 other = unit_follow_merge(other);
857
858 if (other == u)
859 return 0;
860
861 if (u->type != other->type)
862 return -EINVAL;
863
864 if (!u->instance != !other->instance)
865 return -EINVAL;
866
867 if (!unit_type_may_alias(u->type)) /* Merging only applies to unit names that support aliases */
868 return -EEXIST;
869
870 if (!IN_SET(other->load_state, UNIT_STUB, UNIT_NOT_FOUND))
871 return -EEXIST;
872
873 if (other->job)
874 return -EEXIST;
875
876 if (other->nop_job)
877 return -EEXIST;
878
879 if (!UNIT_IS_INACTIVE_OR_FAILED(unit_active_state(other)))
880 return -EEXIST;
881
882 if (other->id)
883 other_id = strdupa(other->id);
884
885 /* Make reservations to ensure merge_dependencies() won't fail */
886 for (d = 0; d < _UNIT_DEPENDENCY_MAX; d++) {
887 r = reserve_dependencies(u, other, d);
888 /*
889 * We don't rollback reservations if we fail. We don't have
890 * a way to undo reservations. A reservation is not a leak.
891 */
892 if (r < 0)
893 return r;
894 }
895
896 /* Merge names */
897 r = merge_names(u, other);
898 if (r < 0)
899 return r;
900
901 /* Redirect all references */
902 while (other->refs_by_target)
903 unit_ref_set(other->refs_by_target, other->refs_by_target->source, u);
904
905 /* Merge dependencies */
906 for (d = 0; d < _UNIT_DEPENDENCY_MAX; d++)
907 merge_dependencies(u, other, other_id, d);
908
909 other->load_state = UNIT_MERGED;
910 other->merged_into = u;
911
912 /* If there is still some data attached to the other node, we
913 * don't need it anymore, and can free it. */
914 if (other->load_state != UNIT_STUB)
915 if (UNIT_VTABLE(other)->done)
916 UNIT_VTABLE(other)->done(other);
917
918 unit_add_to_dbus_queue(u);
919 unit_add_to_cleanup_queue(other);
920
921 return 0;
922 }
923
924 int unit_merge_by_name(Unit *u, const char *name) {
925 _cleanup_free_ char *s = NULL;
926 Unit *other;
927 int r;
928
929 assert(u);
930 assert(name);
931
932 if (unit_name_is_valid(name, UNIT_NAME_TEMPLATE)) {
933 if (!u->instance)
934 return -EINVAL;
935
936 r = unit_name_replace_instance(name, u->instance, &s);
937 if (r < 0)
938 return r;
939
940 name = s;
941 }
942
943 other = manager_get_unit(u->manager, name);
944 if (other)
945 return unit_merge(u, other);
946
947 return unit_add_name(u, name);
948 }
949
950 Unit* unit_follow_merge(Unit *u) {
951 assert(u);
952
953 while (u->load_state == UNIT_MERGED)
954 assert_se(u = u->merged_into);
955
956 return u;
957 }
958
959 int unit_add_exec_dependencies(Unit *u, ExecContext *c) {
960 ExecDirectoryType dt;
961 char **dp;
962 int r;
963
964 assert(u);
965 assert(c);
966
967 if (c->working_directory && !c->working_directory_missing_ok) {
968 r = unit_require_mounts_for(u, c->working_directory, UNIT_DEPENDENCY_FILE);
969 if (r < 0)
970 return r;
971 }
972
973 if (c->root_directory) {
974 r = unit_require_mounts_for(u, c->root_directory, UNIT_DEPENDENCY_FILE);
975 if (r < 0)
976 return r;
977 }
978
979 if (c->root_image) {
980 r = unit_require_mounts_for(u, c->root_image, UNIT_DEPENDENCY_FILE);
981 if (r < 0)
982 return r;
983 }
984
985 for (dt = 0; dt < _EXEC_DIRECTORY_TYPE_MAX; dt++) {
986 if (!u->manager->prefix[dt])
987 continue;
988
989 STRV_FOREACH(dp, c->directories[dt].paths) {
990 _cleanup_free_ char *p;
991
992 p = strjoin(u->manager->prefix[dt], "/", *dp);
993 if (!p)
994 return -ENOMEM;
995
996 r = unit_require_mounts_for(u, p, UNIT_DEPENDENCY_FILE);
997 if (r < 0)
998 return r;
999 }
1000 }
1001
1002 if (!MANAGER_IS_SYSTEM(u->manager))
1003 return 0;
1004
1005 if (c->private_tmp) {
1006 const char *p;
1007
1008 FOREACH_STRING(p, "/tmp", "/var/tmp") {
1009 r = unit_require_mounts_for(u, p, UNIT_DEPENDENCY_FILE);
1010 if (r < 0)
1011 return r;
1012 }
1013
1014 r = unit_add_dependency_by_name(u, UNIT_AFTER, SPECIAL_TMPFILES_SETUP_SERVICE, true, UNIT_DEPENDENCY_FILE);
1015 if (r < 0)
1016 return r;
1017 }
1018
1019 if (!IN_SET(c->std_output,
1020 EXEC_OUTPUT_JOURNAL, EXEC_OUTPUT_JOURNAL_AND_CONSOLE,
1021 EXEC_OUTPUT_KMSG, EXEC_OUTPUT_KMSG_AND_CONSOLE,
1022 EXEC_OUTPUT_SYSLOG, EXEC_OUTPUT_SYSLOG_AND_CONSOLE) &&
1023 !IN_SET(c->std_error,
1024 EXEC_OUTPUT_JOURNAL, EXEC_OUTPUT_JOURNAL_AND_CONSOLE,
1025 EXEC_OUTPUT_KMSG, EXEC_OUTPUT_KMSG_AND_CONSOLE,
1026 EXEC_OUTPUT_SYSLOG, EXEC_OUTPUT_SYSLOG_AND_CONSOLE))
1027 return 0;
1028
1029 /* If syslog or kernel logging is requested, make sure our own
1030 * logging daemon is run first. */
1031
1032 r = unit_add_dependency_by_name(u, UNIT_AFTER, SPECIAL_JOURNALD_SOCKET, true, UNIT_DEPENDENCY_FILE);
1033 if (r < 0)
1034 return r;
1035
1036 return 0;
1037 }
1038
1039 const char *unit_description(Unit *u) {
1040 assert(u);
1041
1042 if (u->description)
1043 return u->description;
1044
1045 return strna(u->id);
1046 }
1047
1048 static void print_unit_dependency_mask(FILE *f, const char *kind, UnitDependencyMask mask, bool *space) {
1049 const struct {
1050 UnitDependencyMask mask;
1051 const char *name;
1052 } table[] = {
1053 { UNIT_DEPENDENCY_FILE, "file" },
1054 { UNIT_DEPENDENCY_IMPLICIT, "implicit" },
1055 { UNIT_DEPENDENCY_DEFAULT, "default" },
1056 { UNIT_DEPENDENCY_UDEV, "udev" },
1057 { UNIT_DEPENDENCY_PATH, "path" },
1058 { UNIT_DEPENDENCY_MOUNTINFO_IMPLICIT, "mountinfo-implicit" },
1059 { UNIT_DEPENDENCY_MOUNTINFO_DEFAULT, "mountinfo-default" },
1060 { UNIT_DEPENDENCY_PROC_SWAP, "proc-swap" },
1061 };
1062 size_t i;
1063
1064 assert(f);
1065 assert(kind);
1066 assert(space);
1067
1068 for (i = 0; i < ELEMENTSOF(table); i++) {
1069
1070 if (mask == 0)
1071 break;
1072
1073 if (FLAGS_SET(mask, table[i].mask)) {
1074 if (*space)
1075 fputc(' ', f);
1076 else
1077 *space = true;
1078
1079 fputs(kind, f);
1080 fputs("-", f);
1081 fputs(table[i].name, f);
1082
1083 mask &= ~table[i].mask;
1084 }
1085 }
1086
1087 assert(mask == 0);
1088 }
1089
1090 void unit_dump(Unit *u, FILE *f, const char *prefix) {
1091 char *t, **j;
1092 UnitDependency d;
1093 Iterator i;
1094 const char *prefix2;
1095 char
1096 timestamp0[FORMAT_TIMESTAMP_MAX],
1097 timestamp1[FORMAT_TIMESTAMP_MAX],
1098 timestamp2[FORMAT_TIMESTAMP_MAX],
1099 timestamp3[FORMAT_TIMESTAMP_MAX],
1100 timestamp4[FORMAT_TIMESTAMP_MAX],
1101 timespan[FORMAT_TIMESPAN_MAX];
1102 Unit *following;
1103 _cleanup_set_free_ Set *following_set = NULL;
1104 const char *n;
1105 CGroupMask m;
1106 int r;
1107
1108 assert(u);
1109 assert(u->type >= 0);
1110
1111 prefix = strempty(prefix);
1112 prefix2 = strjoina(prefix, "\t");
1113
1114 fprintf(f,
1115 "%s-> Unit %s:\n"
1116 "%s\tDescription: %s\n"
1117 "%s\tInstance: %s\n"
1118 "%s\tUnit Load State: %s\n"
1119 "%s\tUnit Active State: %s\n"
1120 "%s\tState Change Timestamp: %s\n"
1121 "%s\tInactive Exit Timestamp: %s\n"
1122 "%s\tActive Enter Timestamp: %s\n"
1123 "%s\tActive Exit Timestamp: %s\n"
1124 "%s\tInactive Enter Timestamp: %s\n"
1125 "%s\tMay GC: %s\n"
1126 "%s\tNeed Daemon Reload: %s\n"
1127 "%s\tTransient: %s\n"
1128 "%s\tPerpetual: %s\n"
1129 "%s\tGarbage Collection Mode: %s\n"
1130 "%s\tSlice: %s\n"
1131 "%s\tCGroup: %s\n"
1132 "%s\tCGroup realized: %s\n",
1133 prefix, u->id,
1134 prefix, unit_description(u),
1135 prefix, strna(u->instance),
1136 prefix, unit_load_state_to_string(u->load_state),
1137 prefix, unit_active_state_to_string(unit_active_state(u)),
1138 prefix, strna(format_timestamp(timestamp0, sizeof(timestamp0), u->state_change_timestamp.realtime)),
1139 prefix, strna(format_timestamp(timestamp1, sizeof(timestamp1), u->inactive_exit_timestamp.realtime)),
1140 prefix, strna(format_timestamp(timestamp2, sizeof(timestamp2), u->active_enter_timestamp.realtime)),
1141 prefix, strna(format_timestamp(timestamp3, sizeof(timestamp3), u->active_exit_timestamp.realtime)),
1142 prefix, strna(format_timestamp(timestamp4, sizeof(timestamp4), u->inactive_enter_timestamp.realtime)),
1143 prefix, yes_no(unit_may_gc(u)),
1144 prefix, yes_no(unit_need_daemon_reload(u)),
1145 prefix, yes_no(u->transient),
1146 prefix, yes_no(u->perpetual),
1147 prefix, collect_mode_to_string(u->collect_mode),
1148 prefix, strna(unit_slice_name(u)),
1149 prefix, strna(u->cgroup_path),
1150 prefix, yes_no(u->cgroup_realized));
1151
1152 if (u->cgroup_realized_mask != 0) {
1153 _cleanup_free_ char *s = NULL;
1154 (void) cg_mask_to_string(u->cgroup_realized_mask, &s);
1155 fprintf(f, "%s\tCGroup realized mask: %s\n", prefix, strnull(s));
1156 }
1157 if (u->cgroup_enabled_mask != 0) {
1158 _cleanup_free_ char *s = NULL;
1159 (void) cg_mask_to_string(u->cgroup_enabled_mask, &s);
1160 fprintf(f, "%s\tCGroup enabled mask: %s\n", prefix, strnull(s));
1161 }
1162 m = unit_get_own_mask(u);
1163 if (m != 0) {
1164 _cleanup_free_ char *s = NULL;
1165 (void) cg_mask_to_string(m, &s);
1166 fprintf(f, "%s\tCGroup own mask: %s\n", prefix, strnull(s));
1167 }
1168 m = unit_get_members_mask(u);
1169 if (m != 0) {
1170 _cleanup_free_ char *s = NULL;
1171 (void) cg_mask_to_string(m, &s);
1172 fprintf(f, "%s\tCGroup members mask: %s\n", prefix, strnull(s));
1173 }
1174
1175 SET_FOREACH(t, u->names, i)
1176 fprintf(f, "%s\tName: %s\n", prefix, t);
1177
1178 if (!sd_id128_is_null(u->invocation_id))
1179 fprintf(f, "%s\tInvocation ID: " SD_ID128_FORMAT_STR "\n",
1180 prefix, SD_ID128_FORMAT_VAL(u->invocation_id));
1181
1182 STRV_FOREACH(j, u->documentation)
1183 fprintf(f, "%s\tDocumentation: %s\n", prefix, *j);
1184
1185 following = unit_following(u);
1186 if (following)
1187 fprintf(f, "%s\tFollowing: %s\n", prefix, following->id);
1188
1189 r = unit_following_set(u, &following_set);
1190 if (r >= 0) {
1191 Unit *other;
1192
1193 SET_FOREACH(other, following_set, i)
1194 fprintf(f, "%s\tFollowing Set Member: %s\n", prefix, other->id);
1195 }
1196
1197 if (u->fragment_path)
1198 fprintf(f, "%s\tFragment Path: %s\n", prefix, u->fragment_path);
1199
1200 if (u->source_path)
1201 fprintf(f, "%s\tSource Path: %s\n", prefix, u->source_path);
1202
1203 STRV_FOREACH(j, u->dropin_paths)
1204 fprintf(f, "%s\tDropIn Path: %s\n", prefix, *j);
1205
1206 if (u->failure_action != EMERGENCY_ACTION_NONE)
1207 fprintf(f, "%s\tFailure Action: %s\n", prefix, emergency_action_to_string(u->failure_action));
1208 if (u->success_action != EMERGENCY_ACTION_NONE)
1209 fprintf(f, "%s\tSuccess Action: %s\n", prefix, emergency_action_to_string(u->success_action));
1210
1211 if (u->job_timeout != USEC_INFINITY)
1212 fprintf(f, "%s\tJob Timeout: %s\n", prefix, format_timespan(timespan, sizeof(timespan), u->job_timeout, 0));
1213
1214 if (u->job_timeout_action != EMERGENCY_ACTION_NONE)
1215 fprintf(f, "%s\tJob Timeout Action: %s\n", prefix, emergency_action_to_string(u->job_timeout_action));
1216
1217 if (u->job_timeout_reboot_arg)
1218 fprintf(f, "%s\tJob Timeout Reboot Argument: %s\n", prefix, u->job_timeout_reboot_arg);
1219
1220 condition_dump_list(u->conditions, f, prefix, condition_type_to_string);
1221 condition_dump_list(u->asserts, f, prefix, assert_type_to_string);
1222
1223 if (dual_timestamp_is_set(&u->condition_timestamp))
1224 fprintf(f,
1225 "%s\tCondition Timestamp: %s\n"
1226 "%s\tCondition Result: %s\n",
1227 prefix, strna(format_timestamp(timestamp1, sizeof(timestamp1), u->condition_timestamp.realtime)),
1228 prefix, yes_no(u->condition_result));
1229
1230 if (dual_timestamp_is_set(&u->assert_timestamp))
1231 fprintf(f,
1232 "%s\tAssert Timestamp: %s\n"
1233 "%s\tAssert Result: %s\n",
1234 prefix, strna(format_timestamp(timestamp1, sizeof(timestamp1), u->assert_timestamp.realtime)),
1235 prefix, yes_no(u->assert_result));
1236
1237 for (d = 0; d < _UNIT_DEPENDENCY_MAX; d++) {
1238 UnitDependencyInfo di;
1239 Unit *other;
1240
1241 HASHMAP_FOREACH_KEY(di.data, other, u->dependencies[d], i) {
1242 bool space = false;
1243
1244 fprintf(f, "%s\t%s: %s (", prefix, unit_dependency_to_string(d), other->id);
1245
1246 print_unit_dependency_mask(f, "origin", di.origin_mask, &space);
1247 print_unit_dependency_mask(f, "destination", di.destination_mask, &space);
1248
1249 fputs(")\n", f);
1250 }
1251 }
1252
1253 if (!hashmap_isempty(u->requires_mounts_for)) {
1254 UnitDependencyInfo di;
1255 const char *path;
1256
1257 HASHMAP_FOREACH_KEY(di.data, path, u->requires_mounts_for, i) {
1258 bool space = false;
1259
1260 fprintf(f, "%s\tRequiresMountsFor: %s (", prefix, path);
1261
1262 print_unit_dependency_mask(f, "origin", di.origin_mask, &space);
1263 print_unit_dependency_mask(f, "destination", di.destination_mask, &space);
1264
1265 fputs(")\n", f);
1266 }
1267 }
1268
1269 if (u->load_state == UNIT_LOADED) {
1270
1271 fprintf(f,
1272 "%s\tStopWhenUnneeded: %s\n"
1273 "%s\tRefuseManualStart: %s\n"
1274 "%s\tRefuseManualStop: %s\n"
1275 "%s\tDefaultDependencies: %s\n"
1276 "%s\tOnFailureJobMode: %s\n"
1277 "%s\tIgnoreOnIsolate: %s\n",
1278 prefix, yes_no(u->stop_when_unneeded),
1279 prefix, yes_no(u->refuse_manual_start),
1280 prefix, yes_no(u->refuse_manual_stop),
1281 prefix, yes_no(u->default_dependencies),
1282 prefix, job_mode_to_string(u->on_failure_job_mode),
1283 prefix, yes_no(u->ignore_on_isolate));
1284
1285 if (UNIT_VTABLE(u)->dump)
1286 UNIT_VTABLE(u)->dump(u, f, prefix2);
1287
1288 } else if (u->load_state == UNIT_MERGED)
1289 fprintf(f,
1290 "%s\tMerged into: %s\n",
1291 prefix, u->merged_into->id);
1292 else if (u->load_state == UNIT_ERROR)
1293 fprintf(f, "%s\tLoad Error Code: %s\n", prefix, strerror(-u->load_error));
1294
1295 for (n = sd_bus_track_first(u->bus_track); n; n = sd_bus_track_next(u->bus_track))
1296 fprintf(f, "%s\tBus Ref: %s\n", prefix, n);
1297
1298 if (u->job)
1299 job_dump(u->job, f, prefix2);
1300
1301 if (u->nop_job)
1302 job_dump(u->nop_job, f, prefix2);
1303 }
1304
1305 /* Common implementation for multiple backends */
1306 int unit_load_fragment_and_dropin(Unit *u) {
1307 int r;
1308
1309 assert(u);
1310
1311 /* Load a .{service,socket,...} file */
1312 r = unit_load_fragment(u);
1313 if (r < 0)
1314 return r;
1315
1316 if (u->load_state == UNIT_STUB)
1317 return -ENOENT;
1318
1319 /* Load drop-in directory data. If u is an alias, we might be reloading the
1320 * target unit needlessly. But we cannot be sure which drops-ins have already
1321 * been loaded and which not, at least without doing complicated book-keeping,
1322 * so let's always reread all drop-ins. */
1323 return unit_load_dropin(unit_follow_merge(u));
1324 }
1325
1326 /* Common implementation for multiple backends */
1327 int unit_load_fragment_and_dropin_optional(Unit *u) {
1328 int r;
1329
1330 assert(u);
1331
1332 /* Same as unit_load_fragment_and_dropin(), but whether
1333 * something can be loaded or not doesn't matter. */
1334
1335 /* Load a .service/.socket/.slice/… file */
1336 r = unit_load_fragment(u);
1337 if (r < 0)
1338 return r;
1339
1340 if (u->load_state == UNIT_STUB)
1341 u->load_state = UNIT_LOADED;
1342
1343 /* Load drop-in directory data */
1344 return unit_load_dropin(unit_follow_merge(u));
1345 }
1346
1347 void unit_add_to_target_deps_queue(Unit *u) {
1348 Manager *m = u->manager;
1349
1350 assert(u);
1351
1352 if (u->in_target_deps_queue)
1353 return;
1354
1355 LIST_PREPEND(target_deps_queue, m->target_deps_queue, u);
1356 u->in_target_deps_queue = true;
1357 }
1358
1359 int unit_add_default_target_dependency(Unit *u, Unit *target) {
1360 assert(u);
1361 assert(target);
1362
1363 if (target->type != UNIT_TARGET)
1364 return 0;
1365
1366 /* Only add the dependency if both units are loaded, so that
1367 * that loop check below is reliable */
1368 if (u->load_state != UNIT_LOADED ||
1369 target->load_state != UNIT_LOADED)
1370 return 0;
1371
1372 /* If either side wants no automatic dependencies, then let's
1373 * skip this */
1374 if (!u->default_dependencies ||
1375 !target->default_dependencies)
1376 return 0;
1377
1378 /* Don't create loops */
1379 if (hashmap_get(target->dependencies[UNIT_BEFORE], u))
1380 return 0;
1381
1382 return unit_add_dependency(target, UNIT_AFTER, u, true, UNIT_DEPENDENCY_DEFAULT);
1383 }
1384
1385 static int unit_add_slice_dependencies(Unit *u) {
1386 UnitDependencyMask mask;
1387 assert(u);
1388
1389 if (!UNIT_HAS_CGROUP_CONTEXT(u))
1390 return 0;
1391
1392 /* Slice units are implicitly ordered against their parent slices (as this relationship is encoded in the
1393 name), while all other units are ordered based on configuration (as in their case Slice= configures the
1394 relationship). */
1395 mask = u->type == UNIT_SLICE ? UNIT_DEPENDENCY_IMPLICIT : UNIT_DEPENDENCY_FILE;
1396
1397 if (UNIT_ISSET(u->slice))
1398 return unit_add_two_dependencies(u, UNIT_AFTER, UNIT_REQUIRES, UNIT_DEREF(u->slice), true, mask);
1399
1400 if (unit_has_name(u, SPECIAL_ROOT_SLICE))
1401 return 0;
1402
1403 return unit_add_two_dependencies_by_name(u, UNIT_AFTER, UNIT_REQUIRES, SPECIAL_ROOT_SLICE, true, mask);
1404 }
1405
1406 static int unit_add_mount_dependencies(Unit *u) {
1407 UnitDependencyInfo di;
1408 const char *path;
1409 Iterator i;
1410 int r;
1411
1412 assert(u);
1413
1414 HASHMAP_FOREACH_KEY(di.data, path, u->requires_mounts_for, i) {
1415 char prefix[strlen(path) + 1];
1416
1417 PATH_FOREACH_PREFIX_MORE(prefix, path) {
1418 _cleanup_free_ char *p = NULL;
1419 Unit *m;
1420
1421 r = unit_name_from_path(prefix, ".mount", &p);
1422 if (r < 0)
1423 return r;
1424
1425 m = manager_get_unit(u->manager, p);
1426 if (!m) {
1427 /* Make sure to load the mount unit if
1428 * it exists. If so the dependencies
1429 * on this unit will be added later
1430 * during the loading of the mount
1431 * unit. */
1432 (void) manager_load_unit_prepare(u->manager, p, NULL, NULL, &m);
1433 continue;
1434 }
1435 if (m == u)
1436 continue;
1437
1438 if (m->load_state != UNIT_LOADED)
1439 continue;
1440
1441 r = unit_add_dependency(u, UNIT_AFTER, m, true, di.origin_mask);
1442 if (r < 0)
1443 return r;
1444
1445 if (m->fragment_path) {
1446 r = unit_add_dependency(u, UNIT_REQUIRES, m, true, di.origin_mask);
1447 if (r < 0)
1448 return r;
1449 }
1450 }
1451 }
1452
1453 return 0;
1454 }
1455
1456 static int unit_add_startup_units(Unit *u) {
1457 CGroupContext *c;
1458 int r;
1459
1460 c = unit_get_cgroup_context(u);
1461 if (!c)
1462 return 0;
1463
1464 if (c->startup_cpu_shares == CGROUP_CPU_SHARES_INVALID &&
1465 c->startup_io_weight == CGROUP_WEIGHT_INVALID &&
1466 c->startup_blockio_weight == CGROUP_BLKIO_WEIGHT_INVALID)
1467 return 0;
1468
1469 r = set_ensure_allocated(&u->manager->startup_units, NULL);
1470 if (r < 0)
1471 return r;
1472
1473 return set_put(u->manager->startup_units, u);
1474 }
1475
1476 int unit_load(Unit *u) {
1477 int r;
1478
1479 assert(u);
1480
1481 if (u->in_load_queue) {
1482 LIST_REMOVE(load_queue, u->manager->load_queue, u);
1483 u->in_load_queue = false;
1484 }
1485
1486 if (u->type == _UNIT_TYPE_INVALID)
1487 return -EINVAL;
1488
1489 if (u->load_state != UNIT_STUB)
1490 return 0;
1491
1492 if (u->transient_file) {
1493 r = fflush_and_check(u->transient_file);
1494 if (r < 0)
1495 goto fail;
1496
1497 u->transient_file = safe_fclose(u->transient_file);
1498 u->fragment_mtime = now(CLOCK_REALTIME);
1499 }
1500
1501 if (UNIT_VTABLE(u)->load) {
1502 r = UNIT_VTABLE(u)->load(u);
1503 if (r < 0)
1504 goto fail;
1505 }
1506
1507 if (u->load_state == UNIT_STUB) {
1508 r = -ENOENT;
1509 goto fail;
1510 }
1511
1512 if (u->load_state == UNIT_LOADED) {
1513 unit_add_to_target_deps_queue(u);
1514
1515 r = unit_add_slice_dependencies(u);
1516 if (r < 0)
1517 goto fail;
1518
1519 r = unit_add_mount_dependencies(u);
1520 if (r < 0)
1521 goto fail;
1522
1523 r = unit_add_startup_units(u);
1524 if (r < 0)
1525 goto fail;
1526
1527 if (u->on_failure_job_mode == JOB_ISOLATE && hashmap_size(u->dependencies[UNIT_ON_FAILURE]) > 1) {
1528 log_unit_error(u, "More than one OnFailure= dependencies specified but OnFailureJobMode=isolate set. Refusing.");
1529 r = -ENOEXEC;
1530 goto fail;
1531 }
1532
1533 if (u->job_running_timeout != USEC_INFINITY && u->job_running_timeout > u->job_timeout)
1534 log_unit_warning(u, "JobRunningTimeoutSec= is greater than JobTimeoutSec=, it has no effect.");
1535
1536 unit_update_cgroup_members_masks(u);
1537 }
1538
1539 assert((u->load_state != UNIT_MERGED) == !u->merged_into);
1540
1541 unit_add_to_dbus_queue(unit_follow_merge(u));
1542 unit_add_to_gc_queue(u);
1543
1544 return 0;
1545
1546 fail:
1547 /* We convert ENOEXEC errors to the UNIT_BAD_SETTING load state here. Configuration parsing code should hence
1548 * return ENOEXEC to ensure units are placed in this state after loading */
1549
1550 u->load_state = u->load_state == UNIT_STUB ? UNIT_NOT_FOUND :
1551 r == -ENOEXEC ? UNIT_BAD_SETTING :
1552 UNIT_ERROR;
1553 u->load_error = r;
1554
1555 unit_add_to_dbus_queue(u);
1556 unit_add_to_gc_queue(u);
1557
1558 return log_unit_debug_errno(u, r, "Failed to load configuration: %m");
1559 }
1560
1561 static bool unit_condition_test_list(Unit *u, Condition *first, const char *(*to_string)(ConditionType t)) {
1562 Condition *c;
1563 int triggered = -1;
1564
1565 assert(u);
1566 assert(to_string);
1567
1568 /* If the condition list is empty, then it is true */
1569 if (!first)
1570 return true;
1571
1572 /* Otherwise, if all of the non-trigger conditions apply and
1573 * if any of the trigger conditions apply (unless there are
1574 * none) we return true */
1575 LIST_FOREACH(conditions, c, first) {
1576 int r;
1577
1578 r = condition_test(c);
1579 if (r < 0)
1580 log_unit_warning(u,
1581 "Couldn't determine result for %s=%s%s%s, assuming failed: %m",
1582 to_string(c->type),
1583 c->trigger ? "|" : "",
1584 c->negate ? "!" : "",
1585 c->parameter);
1586 else
1587 log_unit_debug(u,
1588 "%s=%s%s%s %s.",
1589 to_string(c->type),
1590 c->trigger ? "|" : "",
1591 c->negate ? "!" : "",
1592 c->parameter,
1593 condition_result_to_string(c->result));
1594
1595 if (!c->trigger && r <= 0)
1596 return false;
1597
1598 if (c->trigger && triggered <= 0)
1599 triggered = r > 0;
1600 }
1601
1602 return triggered != 0;
1603 }
1604
1605 static bool unit_condition_test(Unit *u) {
1606 assert(u);
1607
1608 dual_timestamp_get(&u->condition_timestamp);
1609 u->condition_result = unit_condition_test_list(u, u->conditions, condition_type_to_string);
1610
1611 return u->condition_result;
1612 }
1613
1614 static bool unit_assert_test(Unit *u) {
1615 assert(u);
1616
1617 dual_timestamp_get(&u->assert_timestamp);
1618 u->assert_result = unit_condition_test_list(u, u->asserts, assert_type_to_string);
1619
1620 return u->assert_result;
1621 }
1622
1623 void unit_status_printf(Unit *u, const char *status, const char *unit_status_msg_format) {
1624 DISABLE_WARNING_FORMAT_NONLITERAL;
1625 manager_status_printf(u->manager, STATUS_TYPE_NORMAL, status, unit_status_msg_format, unit_description(u));
1626 REENABLE_WARNING;
1627 }
1628
1629 _pure_ static const char* unit_get_status_message_format(Unit *u, JobType t) {
1630 const char *format;
1631 const UnitStatusMessageFormats *format_table;
1632
1633 assert(u);
1634 assert(IN_SET(t, JOB_START, JOB_STOP, JOB_RELOAD));
1635
1636 if (t != JOB_RELOAD) {
1637 format_table = &UNIT_VTABLE(u)->status_message_formats;
1638 if (format_table) {
1639 format = format_table->starting_stopping[t == JOB_STOP];
1640 if (format)
1641 return format;
1642 }
1643 }
1644
1645 /* Return generic strings */
1646 if (t == JOB_START)
1647 return "Starting %s.";
1648 else if (t == JOB_STOP)
1649 return "Stopping %s.";
1650 else
1651 return "Reloading %s.";
1652 }
1653
1654 static void unit_status_print_starting_stopping(Unit *u, JobType t) {
1655 const char *format;
1656
1657 assert(u);
1658
1659 /* Reload status messages have traditionally not been printed to console. */
1660 if (!IN_SET(t, JOB_START, JOB_STOP))
1661 return;
1662
1663 format = unit_get_status_message_format(u, t);
1664
1665 DISABLE_WARNING_FORMAT_NONLITERAL;
1666 unit_status_printf(u, "", format);
1667 REENABLE_WARNING;
1668 }
1669
1670 static void unit_status_log_starting_stopping_reloading(Unit *u, JobType t) {
1671 const char *format, *mid;
1672 char buf[LINE_MAX];
1673
1674 assert(u);
1675
1676 if (!IN_SET(t, JOB_START, JOB_STOP, JOB_RELOAD))
1677 return;
1678
1679 if (log_on_console())
1680 return;
1681
1682 /* We log status messages for all units and all operations. */
1683
1684 format = unit_get_status_message_format(u, t);
1685
1686 DISABLE_WARNING_FORMAT_NONLITERAL;
1687 (void) snprintf(buf, sizeof buf, format, unit_description(u));
1688 REENABLE_WARNING;
1689
1690 mid = t == JOB_START ? "MESSAGE_ID=" SD_MESSAGE_UNIT_STARTING_STR :
1691 t == JOB_STOP ? "MESSAGE_ID=" SD_MESSAGE_UNIT_STOPPING_STR :
1692 "MESSAGE_ID=" SD_MESSAGE_UNIT_RELOADING_STR;
1693
1694 /* Note that we deliberately use LOG_MESSAGE() instead of
1695 * LOG_UNIT_MESSAGE() here, since this is supposed to mimic
1696 * closely what is written to screen using the status output,
1697 * which is supposed the highest level, friendliest output
1698 * possible, which means we should avoid the low-level unit
1699 * name. */
1700 log_struct(LOG_INFO,
1701 LOG_MESSAGE("%s", buf),
1702 LOG_UNIT_ID(u),
1703 LOG_UNIT_INVOCATION_ID(u),
1704 mid);
1705 }
1706
1707 void unit_status_emit_starting_stopping_reloading(Unit *u, JobType t) {
1708 assert(u);
1709 assert(t >= 0);
1710 assert(t < _JOB_TYPE_MAX);
1711
1712 unit_status_log_starting_stopping_reloading(u, t);
1713 unit_status_print_starting_stopping(u, t);
1714 }
1715
1716 int unit_start_limit_test(Unit *u) {
1717 assert(u);
1718
1719 if (ratelimit_below(&u->start_limit)) {
1720 u->start_limit_hit = false;
1721 return 0;
1722 }
1723
1724 log_unit_warning(u, "Start request repeated too quickly.");
1725 u->start_limit_hit = true;
1726
1727 return emergency_action(u->manager, u->start_limit_action,
1728 EMERGENCY_ACTION_IS_WATCHDOG|EMERGENCY_ACTION_WARN,
1729 u->reboot_arg, "unit failed");
1730 }
1731
1732 bool unit_shall_confirm_spawn(Unit *u) {
1733 assert(u);
1734
1735 if (manager_is_confirm_spawn_disabled(u->manager))
1736 return false;
1737
1738 /* For some reasons units remaining in the same process group
1739 * as PID 1 fail to acquire the console even if it's not used
1740 * by any process. So skip the confirmation question for them. */
1741 return !unit_get_exec_context(u)->same_pgrp;
1742 }
1743
1744 static bool unit_verify_deps(Unit *u) {
1745 Unit *other;
1746 Iterator j;
1747 void *v;
1748
1749 assert(u);
1750
1751 /* Checks whether all BindsTo= dependencies of this unit are fulfilled — if they are also combined with
1752 * After=. We do not check Requires= or Requisite= here as they only should have an effect on the job
1753 * processing, but do not have any effect afterwards. We don't check BindsTo= dependencies that are not used in
1754 * conjunction with After= as for them any such check would make things entirely racy. */
1755
1756 HASHMAP_FOREACH_KEY(v, other, u->dependencies[UNIT_BINDS_TO], j) {
1757
1758 if (!hashmap_contains(u->dependencies[UNIT_AFTER], other))
1759 continue;
1760
1761 if (!UNIT_IS_ACTIVE_OR_RELOADING(unit_active_state(other))) {
1762 log_unit_notice(u, "Bound to unit %s, but unit isn't active.", other->id);
1763 return false;
1764 }
1765 }
1766
1767 return true;
1768 }
1769
1770 /* Errors:
1771 * -EBADR: This unit type does not support starting.
1772 * -EALREADY: Unit is already started.
1773 * -EAGAIN: An operation is already in progress. Retry later.
1774 * -ECANCELED: Too many requests for now.
1775 * -EPROTO: Assert failed
1776 * -EINVAL: Unit not loaded
1777 * -EOPNOTSUPP: Unit type not supported
1778 * -ENOLINK: The necessary dependencies are not fulfilled.
1779 * -ESTALE: This unit has been started before and can't be started a second time
1780 */
1781 int unit_start(Unit *u) {
1782 UnitActiveState state;
1783 Unit *following;
1784
1785 assert(u);
1786
1787 /* If this is already started, then this will succeed. Note
1788 * that this will even succeed if this unit is not startable
1789 * by the user. This is relied on to detect when we need to
1790 * wait for units and when waiting is finished. */
1791 state = unit_active_state(u);
1792 if (UNIT_IS_ACTIVE_OR_RELOADING(state))
1793 return -EALREADY;
1794
1795 /* Units that aren't loaded cannot be started */
1796 if (u->load_state != UNIT_LOADED)
1797 return -EINVAL;
1798
1799 /* Refuse starting scope units more than once */
1800 if (UNIT_VTABLE(u)->once_only && dual_timestamp_is_set(&u->inactive_enter_timestamp))
1801 return -ESTALE;
1802
1803 /* If the conditions failed, don't do anything at all. If we
1804 * already are activating this call might still be useful to
1805 * speed up activation in case there is some hold-off time,
1806 * but we don't want to recheck the condition in that case. */
1807 if (state != UNIT_ACTIVATING &&
1808 !unit_condition_test(u)) {
1809 log_unit_debug(u, "Starting requested but condition failed. Not starting unit.");
1810 return -EALREADY;
1811 }
1812
1813 /* If the asserts failed, fail the entire job */
1814 if (state != UNIT_ACTIVATING &&
1815 !unit_assert_test(u)) {
1816 log_unit_notice(u, "Starting requested but asserts failed.");
1817 return -EPROTO;
1818 }
1819
1820 /* Units of types that aren't supported cannot be
1821 * started. Note that we do this test only after the condition
1822 * checks, so that we rather return condition check errors
1823 * (which are usually not considered a true failure) than "not
1824 * supported" errors (which are considered a failure).
1825 */
1826 if (!unit_supported(u))
1827 return -EOPNOTSUPP;
1828
1829 /* Let's make sure that the deps really are in order before we start this. Normally the job engine should have
1830 * taken care of this already, but let's check this here again. After all, our dependencies might not be in
1831 * effect anymore, due to a reload or due to a failed condition. */
1832 if (!unit_verify_deps(u))
1833 return -ENOLINK;
1834
1835 /* Forward to the main object, if we aren't it. */
1836 following = unit_following(u);
1837 if (following) {
1838 log_unit_debug(u, "Redirecting start request from %s to %s.", u->id, following->id);
1839 return unit_start(following);
1840 }
1841
1842 /* If it is stopped, but we cannot start it, then fail */
1843 if (!UNIT_VTABLE(u)->start)
1844 return -EBADR;
1845
1846 /* We don't suppress calls to ->start() here when we are
1847 * already starting, to allow this request to be used as a
1848 * "hurry up" call, for example when the unit is in some "auto
1849 * restart" state where it waits for a holdoff timer to elapse
1850 * before it will start again. */
1851
1852 unit_add_to_dbus_queue(u);
1853
1854 return UNIT_VTABLE(u)->start(u);
1855 }
1856
1857 bool unit_can_start(Unit *u) {
1858 assert(u);
1859
1860 if (u->load_state != UNIT_LOADED)
1861 return false;
1862
1863 if (!unit_supported(u))
1864 return false;
1865
1866 /* Scope units may be started only once */
1867 if (UNIT_VTABLE(u)->once_only && dual_timestamp_is_set(&u->inactive_exit_timestamp))
1868 return false;
1869
1870 return !!UNIT_VTABLE(u)->start;
1871 }
1872
1873 bool unit_can_isolate(Unit *u) {
1874 assert(u);
1875
1876 return unit_can_start(u) &&
1877 u->allow_isolate;
1878 }
1879
1880 /* Errors:
1881 * -EBADR: This unit type does not support stopping.
1882 * -EALREADY: Unit is already stopped.
1883 * -EAGAIN: An operation is already in progress. Retry later.
1884 */
1885 int unit_stop(Unit *u) {
1886 UnitActiveState state;
1887 Unit *following;
1888
1889 assert(u);
1890
1891 state = unit_active_state(u);
1892 if (UNIT_IS_INACTIVE_OR_FAILED(state))
1893 return -EALREADY;
1894
1895 following = unit_following(u);
1896 if (following) {
1897 log_unit_debug(u, "Redirecting stop request from %s to %s.", u->id, following->id);
1898 return unit_stop(following);
1899 }
1900
1901 if (!UNIT_VTABLE(u)->stop)
1902 return -EBADR;
1903
1904 unit_add_to_dbus_queue(u);
1905
1906 return UNIT_VTABLE(u)->stop(u);
1907 }
1908
1909 bool unit_can_stop(Unit *u) {
1910 assert(u);
1911
1912 if (!unit_supported(u))
1913 return false;
1914
1915 if (u->perpetual)
1916 return false;
1917
1918 return !!UNIT_VTABLE(u)->stop;
1919 }
1920
1921 /* Errors:
1922 * -EBADR: This unit type does not support reloading.
1923 * -ENOEXEC: Unit is not started.
1924 * -EAGAIN: An operation is already in progress. Retry later.
1925 */
1926 int unit_reload(Unit *u) {
1927 UnitActiveState state;
1928 Unit *following;
1929
1930 assert(u);
1931
1932 if (u->load_state != UNIT_LOADED)
1933 return -EINVAL;
1934
1935 if (!unit_can_reload(u))
1936 return -EBADR;
1937
1938 state = unit_active_state(u);
1939 if (state == UNIT_RELOADING)
1940 return -EALREADY;
1941
1942 if (state != UNIT_ACTIVE) {
1943 log_unit_warning(u, "Unit cannot be reloaded because it is inactive.");
1944 return -ENOEXEC;
1945 }
1946
1947 following = unit_following(u);
1948 if (following) {
1949 log_unit_debug(u, "Redirecting reload request from %s to %s.", u->id, following->id);
1950 return unit_reload(following);
1951 }
1952
1953 unit_add_to_dbus_queue(u);
1954
1955 if (!UNIT_VTABLE(u)->reload) {
1956 /* Unit doesn't have a reload function, but we need to propagate the reload anyway */
1957 unit_notify(u, unit_active_state(u), unit_active_state(u), 0);
1958 return 0;
1959 }
1960
1961 return UNIT_VTABLE(u)->reload(u);
1962 }
1963
1964 bool unit_can_reload(Unit *u) {
1965 assert(u);
1966
1967 if (UNIT_VTABLE(u)->can_reload)
1968 return UNIT_VTABLE(u)->can_reload(u);
1969
1970 if (!hashmap_isempty(u->dependencies[UNIT_PROPAGATES_RELOAD_TO]))
1971 return true;
1972
1973 return UNIT_VTABLE(u)->reload;
1974 }
1975
1976 bool unit_is_unneeded(Unit *u) {
1977 static const UnitDependency deps[] = {
1978 UNIT_REQUIRED_BY,
1979 UNIT_REQUISITE_OF,
1980 UNIT_WANTED_BY,
1981 UNIT_BOUND_BY,
1982 };
1983 size_t j;
1984
1985 assert(u);
1986
1987 if (!u->stop_when_unneeded)
1988 return false;
1989
1990 /* Don't clean up while the unit is transitioning or is even inactive. */
1991 if (!UNIT_IS_ACTIVE_OR_RELOADING(unit_active_state(u)))
1992 return false;
1993 if (u->job)
1994 return false;
1995
1996 for (j = 0; j < ELEMENTSOF(deps); j++) {
1997 Unit *other;
1998 Iterator i;
1999 void *v;
2000
2001 /* If a dependent unit has a job queued, is active or transitioning, or is marked for
2002 * restart, then don't clean this one up. */
2003
2004 HASHMAP_FOREACH_KEY(v, other, u->dependencies[deps[j]], i) {
2005 if (other->job)
2006 return false;
2007
2008 if (!UNIT_IS_INACTIVE_OR_FAILED(unit_active_state(other)))
2009 return false;
2010
2011 if (unit_will_restart(other))
2012 return false;
2013 }
2014 }
2015
2016 return true;
2017 }
2018
2019 static void check_unneeded_dependencies(Unit *u) {
2020
2021 static const UnitDependency deps[] = {
2022 UNIT_REQUIRES,
2023 UNIT_REQUISITE,
2024 UNIT_WANTS,
2025 UNIT_BINDS_TO,
2026 };
2027 size_t j;
2028
2029 assert(u);
2030
2031 /* Add all units this unit depends on to the queue that processes StopWhenUnneeded= behaviour. */
2032
2033 for (j = 0; j < ELEMENTSOF(deps); j++) {
2034 Unit *other;
2035 Iterator i;
2036 void *v;
2037
2038 HASHMAP_FOREACH_KEY(v, other, u->dependencies[deps[j]], i)
2039 unit_submit_to_stop_when_unneeded_queue(other);
2040 }
2041 }
2042
2043 static void unit_check_binds_to(Unit *u) {
2044 _cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL;
2045 bool stop = false;
2046 Unit *other;
2047 Iterator i;
2048 void *v;
2049 int r;
2050
2051 assert(u);
2052
2053 if (u->job)
2054 return;
2055
2056 if (unit_active_state(u) != UNIT_ACTIVE)
2057 return;
2058
2059 HASHMAP_FOREACH_KEY(v, other, u->dependencies[UNIT_BINDS_TO], i) {
2060 if (other->job)
2061 continue;
2062
2063 if (!other->coldplugged)
2064 /* We might yet create a job for the other unit… */
2065 continue;
2066
2067 if (!UNIT_IS_INACTIVE_OR_FAILED(unit_active_state(other)))
2068 continue;
2069
2070 stop = true;
2071 break;
2072 }
2073
2074 if (!stop)
2075 return;
2076
2077 /* If stopping a unit fails continuously we might enter a stop
2078 * loop here, hence stop acting on the service being
2079 * unnecessary after a while. */
2080 if (!ratelimit_below(&u->auto_stop_ratelimit)) {
2081 log_unit_warning(u, "Unit is bound to inactive unit %s, but not stopping since we tried this too often recently.", other->id);
2082 return;
2083 }
2084
2085 assert(other);
2086 log_unit_info(u, "Unit is bound to inactive unit %s. Stopping, too.", other->id);
2087
2088 /* A unit we need to run is gone. Sniff. Let's stop this. */
2089 r = manager_add_job(u->manager, JOB_STOP, u, JOB_FAIL, &error, NULL);
2090 if (r < 0)
2091 log_unit_warning_errno(u, r, "Failed to enqueue stop job, ignoring: %s", bus_error_message(&error, r));
2092 }
2093
2094 static void retroactively_start_dependencies(Unit *u) {
2095 Iterator i;
2096 Unit *other;
2097 void *v;
2098
2099 assert(u);
2100 assert(UNIT_IS_ACTIVE_OR_ACTIVATING(unit_active_state(u)));
2101
2102 HASHMAP_FOREACH_KEY(v, other, u->dependencies[UNIT_REQUIRES], i)
2103 if (!hashmap_get(u->dependencies[UNIT_AFTER], other) &&
2104 !UNIT_IS_ACTIVE_OR_ACTIVATING(unit_active_state(other)))
2105 manager_add_job(u->manager, JOB_START, other, JOB_REPLACE, NULL, NULL);
2106
2107 HASHMAP_FOREACH_KEY(v, other, u->dependencies[UNIT_BINDS_TO], i)
2108 if (!hashmap_get(u->dependencies[UNIT_AFTER], other) &&
2109 !UNIT_IS_ACTIVE_OR_ACTIVATING(unit_active_state(other)))
2110 manager_add_job(u->manager, JOB_START, other, JOB_REPLACE, NULL, NULL);
2111
2112 HASHMAP_FOREACH_KEY(v, other, u->dependencies[UNIT_WANTS], i)
2113 if (!hashmap_get(u->dependencies[UNIT_AFTER], other) &&
2114 !UNIT_IS_ACTIVE_OR_ACTIVATING(unit_active_state(other)))
2115 manager_add_job(u->manager, JOB_START, other, JOB_FAIL, NULL, NULL);
2116
2117 HASHMAP_FOREACH_KEY(v, other, u->dependencies[UNIT_CONFLICTS], i)
2118 if (!UNIT_IS_INACTIVE_OR_DEACTIVATING(unit_active_state(other)))
2119 manager_add_job(u->manager, JOB_STOP, other, JOB_REPLACE, NULL, NULL);
2120
2121 HASHMAP_FOREACH_KEY(v, other, u->dependencies[UNIT_CONFLICTED_BY], i)
2122 if (!UNIT_IS_INACTIVE_OR_DEACTIVATING(unit_active_state(other)))
2123 manager_add_job(u->manager, JOB_STOP, other, JOB_REPLACE, NULL, NULL);
2124 }
2125
2126 static void retroactively_stop_dependencies(Unit *u) {
2127 Unit *other;
2128 Iterator i;
2129 void *v;
2130
2131 assert(u);
2132 assert(UNIT_IS_INACTIVE_OR_DEACTIVATING(unit_active_state(u)));
2133
2134 /* Pull down units which are bound to us recursively if enabled */
2135 HASHMAP_FOREACH_KEY(v, other, u->dependencies[UNIT_BOUND_BY], i)
2136 if (!UNIT_IS_INACTIVE_OR_DEACTIVATING(unit_active_state(other)))
2137 manager_add_job(u->manager, JOB_STOP, other, JOB_REPLACE, NULL, NULL);
2138 }
2139
2140 void unit_start_on_failure(Unit *u) {
2141 Unit *other;
2142 Iterator i;
2143 void *v;
2144 int r;
2145
2146 assert(u);
2147
2148 if (hashmap_size(u->dependencies[UNIT_ON_FAILURE]) <= 0)
2149 return;
2150
2151 log_unit_info(u, "Triggering OnFailure= dependencies.");
2152
2153 HASHMAP_FOREACH_KEY(v, other, u->dependencies[UNIT_ON_FAILURE], i) {
2154 _cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL;
2155
2156 r = manager_add_job(u->manager, JOB_START, other, u->on_failure_job_mode, &error, NULL);
2157 if (r < 0)
2158 log_unit_warning_errno(u, r, "Failed to enqueue OnFailure= job, ignoring: %s", bus_error_message(&error, r));
2159 }
2160 }
2161
2162 void unit_trigger_notify(Unit *u) {
2163 Unit *other;
2164 Iterator i;
2165 void *v;
2166
2167 assert(u);
2168
2169 HASHMAP_FOREACH_KEY(v, other, u->dependencies[UNIT_TRIGGERED_BY], i)
2170 if (UNIT_VTABLE(other)->trigger_notify)
2171 UNIT_VTABLE(other)->trigger_notify(other, u);
2172 }
2173
2174 static int unit_log_resources(Unit *u) {
2175 struct iovec iovec[1 + _CGROUP_IP_ACCOUNTING_METRIC_MAX + 4];
2176 _cleanup_free_ char *igress = NULL, *egress = NULL;
2177 size_t n_message_parts = 0, n_iovec = 0;
2178 char* message_parts[3 + 1], *t;
2179 nsec_t nsec = NSEC_INFINITY;
2180 CGroupIPAccountingMetric m;
2181 bool any_traffic = false;
2182 size_t i;
2183 int r;
2184 const char* const ip_fields[_CGROUP_IP_ACCOUNTING_METRIC_MAX] = {
2185 [CGROUP_IP_INGRESS_BYTES] = "IP_METRIC_INGRESS_BYTES",
2186 [CGROUP_IP_INGRESS_PACKETS] = "IP_METRIC_INGRESS_PACKETS",
2187 [CGROUP_IP_EGRESS_BYTES] = "IP_METRIC_EGRESS_BYTES",
2188 [CGROUP_IP_EGRESS_PACKETS] = "IP_METRIC_EGRESS_PACKETS",
2189 };
2190
2191 assert(u);
2192
2193 /* Invoked whenever a unit enters failed or dead state. Logs information about consumed resources if resource
2194 * accounting was enabled for a unit. It does this in two ways: a friendly human readable string with reduced
2195 * information and the complete data in structured fields. */
2196
2197 (void) unit_get_cpu_usage(u, &nsec);
2198 if (nsec != NSEC_INFINITY) {
2199 char buf[FORMAT_TIMESPAN_MAX] = "";
2200
2201 /* Format the CPU time for inclusion in the structured log message */
2202 if (asprintf(&t, "CPU_USAGE_NSEC=%" PRIu64, nsec) < 0) {
2203 r = log_oom();
2204 goto finish;
2205 }
2206 iovec[n_iovec++] = IOVEC_MAKE_STRING(t);
2207
2208 /* Format the CPU time for inclusion in the human language message string */
2209 format_timespan(buf, sizeof(buf), nsec / NSEC_PER_USEC, USEC_PER_MSEC);
2210 t = strjoin("consumed ", buf, " CPU time");
2211 if (!t) {
2212 r = log_oom();
2213 goto finish;
2214 }
2215
2216 message_parts[n_message_parts++] = t;
2217 }
2218
2219 for (m = 0; m < _CGROUP_IP_ACCOUNTING_METRIC_MAX; m++) {
2220 char buf[FORMAT_BYTES_MAX] = "";
2221 uint64_t value = UINT64_MAX;
2222
2223 assert(ip_fields[m]);
2224
2225 (void) unit_get_ip_accounting(u, m, &value);
2226 if (value == UINT64_MAX)
2227 continue;
2228 if (value > 0)
2229 any_traffic = true;
2230
2231 /* Format IP accounting data for inclusion in the structured log message */
2232 if (asprintf(&t, "%s=%" PRIu64, ip_fields[m], value) < 0) {
2233 r = log_oom();
2234 goto finish;
2235 }
2236 iovec[n_iovec++] = IOVEC_MAKE_STRING(t);
2237
2238 /* Format the IP accounting data for inclusion in the human language message string, but only for the
2239 * bytes counters (and not for the packets counters) */
2240 if (m == CGROUP_IP_INGRESS_BYTES) {
2241 assert(!igress);
2242 igress = strjoin("received ", format_bytes(buf, sizeof(buf), value), " IP traffic");
2243 if (!igress) {
2244 r = log_oom();
2245 goto finish;
2246 }
2247 } else if (m == CGROUP_IP_EGRESS_BYTES) {
2248 assert(!egress);
2249 egress = strjoin("sent ", format_bytes(buf, sizeof(buf), value), " IP traffic");
2250 if (!egress) {
2251 r = log_oom();
2252 goto finish;
2253 }
2254 }
2255 }
2256
2257 if (any_traffic) {
2258 if (igress)
2259 message_parts[n_message_parts++] = TAKE_PTR(igress);
2260 if (egress)
2261 message_parts[n_message_parts++] = TAKE_PTR(egress);
2262 } else {
2263 char *k;
2264
2265 k = strdup("no IP traffic");
2266 if (!k) {
2267 r = log_oom();
2268 goto finish;
2269 }
2270
2271 message_parts[n_message_parts++] = k;
2272 }
2273
2274 /* Is there any accounting data available at all? */
2275 if (n_iovec == 0) {
2276 r = 0;
2277 goto finish;
2278 }
2279
2280 if (n_message_parts == 0)
2281 t = strjoina("MESSAGE=", u->id, ": Completed.");
2282 else {
2283 _cleanup_free_ char *joined;
2284
2285 message_parts[n_message_parts] = NULL;
2286
2287 joined = strv_join(message_parts, ", ");
2288 if (!joined) {
2289 r = log_oom();
2290 goto finish;
2291 }
2292
2293 joined[0] = ascii_toupper(joined[0]);
2294 t = strjoina("MESSAGE=", u->id, ": ", joined, ".");
2295 }
2296
2297 /* The following four fields we allocate on the stack or are static strings, we hence don't want to free them,
2298 * and hence don't increase n_iovec for them */
2299 iovec[n_iovec] = IOVEC_MAKE_STRING(t);
2300 iovec[n_iovec + 1] = IOVEC_MAKE_STRING("MESSAGE_ID=" SD_MESSAGE_UNIT_RESOURCES_STR);
2301
2302 t = strjoina(u->manager->unit_log_field, u->id);
2303 iovec[n_iovec + 2] = IOVEC_MAKE_STRING(t);
2304
2305 t = strjoina(u->manager->invocation_log_field, u->invocation_id_string);
2306 iovec[n_iovec + 3] = IOVEC_MAKE_STRING(t);
2307
2308 log_struct_iovec(LOG_INFO, iovec, n_iovec + 4);
2309 r = 0;
2310
2311 finish:
2312 for (i = 0; i < n_message_parts; i++)
2313 free(message_parts[i]);
2314
2315 for (i = 0; i < n_iovec; i++)
2316 free(iovec[i].iov_base);
2317
2318 return r;
2319
2320 }
2321
2322 static void unit_update_on_console(Unit *u) {
2323 bool b;
2324
2325 assert(u);
2326
2327 b = unit_needs_console(u);
2328 if (u->on_console == b)
2329 return;
2330
2331 u->on_console = b;
2332 if (b)
2333 manager_ref_console(u->manager);
2334 else
2335 manager_unref_console(u->manager);
2336 }
2337
2338 void unit_notify(Unit *u, UnitActiveState os, UnitActiveState ns, UnitNotifyFlags flags) {
2339 bool unexpected;
2340 Manager *m;
2341
2342 assert(u);
2343 assert(os < _UNIT_ACTIVE_STATE_MAX);
2344 assert(ns < _UNIT_ACTIVE_STATE_MAX);
2345
2346 /* Note that this is called for all low-level state changes, even if they might map to the same high-level
2347 * UnitActiveState! That means that ns == os is an expected behavior here. For example: if a mount point is
2348 * remounted this function will be called too! */
2349
2350 m = u->manager;
2351
2352 /* Update timestamps for state changes */
2353 if (!MANAGER_IS_RELOADING(m)) {
2354 dual_timestamp_get(&u->state_change_timestamp);
2355
2356 if (UNIT_IS_INACTIVE_OR_FAILED(os) && !UNIT_IS_INACTIVE_OR_FAILED(ns))
2357 u->inactive_exit_timestamp = u->state_change_timestamp;
2358 else if (!UNIT_IS_INACTIVE_OR_FAILED(os) && UNIT_IS_INACTIVE_OR_FAILED(ns))
2359 u->inactive_enter_timestamp = u->state_change_timestamp;
2360
2361 if (!UNIT_IS_ACTIVE_OR_RELOADING(os) && UNIT_IS_ACTIVE_OR_RELOADING(ns))
2362 u->active_enter_timestamp = u->state_change_timestamp;
2363 else if (UNIT_IS_ACTIVE_OR_RELOADING(os) && !UNIT_IS_ACTIVE_OR_RELOADING(ns))
2364 u->active_exit_timestamp = u->state_change_timestamp;
2365 }
2366
2367 /* Keep track of failed units */
2368 (void) manager_update_failed_units(u->manager, u, ns == UNIT_FAILED);
2369
2370 /* Make sure the cgroup and state files are always removed when we become inactive */
2371 if (UNIT_IS_INACTIVE_OR_FAILED(ns)) {
2372 unit_prune_cgroup(u);
2373 unit_unlink_state_files(u);
2374 }
2375
2376 unit_update_on_console(u);
2377
2378 if (u->job) {
2379 unexpected = false;
2380
2381 if (u->job->state == JOB_WAITING)
2382
2383 /* So we reached a different state for this
2384 * job. Let's see if we can run it now if it
2385 * failed previously due to EAGAIN. */
2386 job_add_to_run_queue(u->job);
2387
2388 /* Let's check whether this state change constitutes a
2389 * finished job, or maybe contradicts a running job and
2390 * hence needs to invalidate jobs. */
2391
2392 switch (u->job->type) {
2393
2394 case JOB_START:
2395 case JOB_VERIFY_ACTIVE:
2396
2397 if (UNIT_IS_ACTIVE_OR_RELOADING(ns))
2398 job_finish_and_invalidate(u->job, JOB_DONE, true, false);
2399 else if (u->job->state == JOB_RUNNING && ns != UNIT_ACTIVATING) {
2400 unexpected = true;
2401
2402 if (UNIT_IS_INACTIVE_OR_FAILED(ns))
2403 job_finish_and_invalidate(u->job, ns == UNIT_FAILED ? JOB_FAILED : JOB_DONE, true, false);
2404 }
2405
2406 break;
2407
2408 case JOB_RELOAD:
2409 case JOB_RELOAD_OR_START:
2410 case JOB_TRY_RELOAD:
2411
2412 if (u->job->state == JOB_RUNNING) {
2413 if (ns == UNIT_ACTIVE)
2414 job_finish_and_invalidate(u->job, (flags & UNIT_NOTIFY_RELOAD_FAILURE) ? JOB_FAILED : JOB_DONE, true, false);
2415 else if (!IN_SET(ns, UNIT_ACTIVATING, UNIT_RELOADING)) {
2416 unexpected = true;
2417
2418 if (UNIT_IS_INACTIVE_OR_FAILED(ns))
2419 job_finish_and_invalidate(u->job, ns == UNIT_FAILED ? JOB_FAILED : JOB_DONE, true, false);
2420 }
2421 }
2422
2423 break;
2424
2425 case JOB_STOP:
2426 case JOB_RESTART:
2427 case JOB_TRY_RESTART:
2428
2429 if (UNIT_IS_INACTIVE_OR_FAILED(ns))
2430 job_finish_and_invalidate(u->job, JOB_DONE, true, false);
2431 else if (u->job->state == JOB_RUNNING && ns != UNIT_DEACTIVATING) {
2432 unexpected = true;
2433 job_finish_and_invalidate(u->job, JOB_FAILED, true, false);
2434 }
2435
2436 break;
2437
2438 default:
2439 assert_not_reached("Job type unknown");
2440 }
2441
2442 } else
2443 unexpected = true;
2444
2445 if (!MANAGER_IS_RELOADING(m)) {
2446
2447 /* If this state change happened without being
2448 * requested by a job, then let's retroactively start
2449 * or stop dependencies. We skip that step when
2450 * deserializing, since we don't want to create any
2451 * additional jobs just because something is already
2452 * activated. */
2453
2454 if (unexpected) {
2455 if (UNIT_IS_INACTIVE_OR_FAILED(os) && UNIT_IS_ACTIVE_OR_ACTIVATING(ns))
2456 retroactively_start_dependencies(u);
2457 else if (UNIT_IS_ACTIVE_OR_ACTIVATING(os) && UNIT_IS_INACTIVE_OR_DEACTIVATING(ns))
2458 retroactively_stop_dependencies(u);
2459 }
2460
2461 /* stop unneeded units regardless if going down was expected or not */
2462 if (UNIT_IS_INACTIVE_OR_FAILED(ns))
2463 check_unneeded_dependencies(u);
2464
2465 if (ns != os && ns == UNIT_FAILED) {
2466 log_unit_debug(u, "Unit entered failed state.");
2467
2468 if (!(flags & UNIT_NOTIFY_WILL_AUTO_RESTART))
2469 unit_start_on_failure(u);
2470 }
2471
2472 if (UNIT_IS_ACTIVE_OR_RELOADING(ns) && !UNIT_IS_ACTIVE_OR_RELOADING(os)) {
2473 /* This unit just finished starting up */
2474
2475 if (u->type == UNIT_SERVICE) {
2476 /* Write audit record if we have just finished starting up */
2477 manager_send_unit_audit(m, u, AUDIT_SERVICE_START, true);
2478 u->in_audit = true;
2479 }
2480
2481 manager_send_unit_plymouth(m, u);
2482 }
2483
2484 if (UNIT_IS_INACTIVE_OR_FAILED(ns) && !UNIT_IS_INACTIVE_OR_FAILED(os)) {
2485 /* This unit just stopped/failed. */
2486
2487 if (u->type == UNIT_SERVICE) {
2488
2489 if (u->in_audit) {
2490 /* Write audit record if we have just finished shutting down */
2491 manager_send_unit_audit(m, u, AUDIT_SERVICE_STOP, ns == UNIT_INACTIVE);
2492 u->in_audit = false;
2493 } else {
2494 /* Hmm, if there was no start record written write it now, so that we always
2495 * have a nice pair */
2496 manager_send_unit_audit(m, u, AUDIT_SERVICE_START, ns == UNIT_INACTIVE);
2497
2498 if (ns == UNIT_INACTIVE)
2499 manager_send_unit_audit(m, u, AUDIT_SERVICE_STOP, true);
2500 }
2501 }
2502
2503 /* Write a log message about consumed resources */
2504 unit_log_resources(u);
2505 }
2506 }
2507
2508 manager_recheck_journal(m);
2509 manager_recheck_dbus(m);
2510
2511 unit_trigger_notify(u);
2512
2513 if (!MANAGER_IS_RELOADING(u->manager)) {
2514 /* Maybe we finished startup and are now ready for being stopped because unneeded? */
2515 unit_submit_to_stop_when_unneeded_queue(u);
2516
2517 /* Maybe we finished startup, but something we needed has vanished? Let's die then. (This happens when
2518 * something BindsTo= to a Type=oneshot unit, as these units go directly from starting to inactive,
2519 * without ever entering started.) */
2520 unit_check_binds_to(u);
2521
2522 if (os != UNIT_FAILED && ns == UNIT_FAILED)
2523 (void) emergency_action(u->manager, u->failure_action, 0,
2524 u->reboot_arg, "unit failed");
2525 else if (!UNIT_IS_INACTIVE_OR_FAILED(os) && ns == UNIT_INACTIVE)
2526 (void) emergency_action(u->manager, u->success_action, 0,
2527 u->reboot_arg, "unit succeeded");
2528 }
2529
2530 unit_add_to_dbus_queue(u);
2531 unit_add_to_gc_queue(u);
2532 }
2533
2534 int unit_watch_pid(Unit *u, pid_t pid) {
2535 int r;
2536
2537 assert(u);
2538 assert(pid_is_valid(pid));
2539
2540 /* Watch a specific PID */
2541
2542 r = set_ensure_allocated(&u->pids, NULL);
2543 if (r < 0)
2544 return r;
2545
2546 r = hashmap_ensure_allocated(&u->manager->watch_pids, NULL);
2547 if (r < 0)
2548 return r;
2549
2550 /* First try, let's add the unit keyed by "pid". */
2551 r = hashmap_put(u->manager->watch_pids, PID_TO_PTR(pid), u);
2552 if (r == -EEXIST) {
2553 Unit **array;
2554 bool found = false;
2555 size_t n = 0;
2556
2557 /* OK, the "pid" key is already assigned to a different unit. Let's see if the "-pid" key (which points
2558 * to an array of Units rather than just a Unit), lists us already. */
2559
2560 array = hashmap_get(u->manager->watch_pids, PID_TO_PTR(-pid));
2561 if (array)
2562 for (; array[n]; n++)
2563 if (array[n] == u)
2564 found = true;
2565
2566 if (found) /* Found it already? if so, do nothing */
2567 r = 0;
2568 else {
2569 Unit **new_array;
2570
2571 /* Allocate a new array */
2572 new_array = new(Unit*, n + 2);
2573 if (!new_array)
2574 return -ENOMEM;
2575
2576 memcpy_safe(new_array, array, sizeof(Unit*) * n);
2577 new_array[n] = u;
2578 new_array[n+1] = NULL;
2579
2580 /* Add or replace the old array */
2581 r = hashmap_replace(u->manager->watch_pids, PID_TO_PTR(-pid), new_array);
2582 if (r < 0) {
2583 free(new_array);
2584 return r;
2585 }
2586
2587 free(array);
2588 }
2589 } else if (r < 0)
2590 return r;
2591
2592 r = set_put(u->pids, PID_TO_PTR(pid));
2593 if (r < 0)
2594 return r;
2595
2596 return 0;
2597 }
2598
2599 void unit_unwatch_pid(Unit *u, pid_t pid) {
2600 Unit **array;
2601
2602 assert(u);
2603 assert(pid_is_valid(pid));
2604
2605 /* First let's drop the unit in case it's keyed as "pid". */
2606 (void) hashmap_remove_value(u->manager->watch_pids, PID_TO_PTR(pid), u);
2607
2608 /* Then, let's also drop the unit, in case it's in the array keyed by -pid */
2609 array = hashmap_get(u->manager->watch_pids, PID_TO_PTR(-pid));
2610 if (array) {
2611 size_t n, m = 0;
2612
2613 /* Let's iterate through the array, dropping our own entry */
2614 for (n = 0; array[n]; n++)
2615 if (array[n] != u)
2616 array[m++] = array[n];
2617 array[m] = NULL;
2618
2619 if (m == 0) {
2620 /* The array is now empty, remove the entire entry */
2621 assert(hashmap_remove(u->manager->watch_pids, PID_TO_PTR(-pid)) == array);
2622 free(array);
2623 }
2624 }
2625
2626 (void) set_remove(u->pids, PID_TO_PTR(pid));
2627 }
2628
2629 void unit_unwatch_all_pids(Unit *u) {
2630 assert(u);
2631
2632 while (!set_isempty(u->pids))
2633 unit_unwatch_pid(u, PTR_TO_PID(set_first(u->pids)));
2634
2635 u->pids = set_free(u->pids);
2636 }
2637
2638 static void unit_tidy_watch_pids(Unit *u) {
2639 pid_t except1, except2;
2640 Iterator i;
2641 void *e;
2642
2643 assert(u);
2644
2645 /* Cleans dead PIDs from our list */
2646
2647 except1 = unit_main_pid(u);
2648 except2 = unit_control_pid(u);
2649
2650 SET_FOREACH(e, u->pids, i) {
2651 pid_t pid = PTR_TO_PID(e);
2652
2653 if (pid == except1 || pid == except2)
2654 continue;
2655
2656 if (!pid_is_unwaited(pid))
2657 unit_unwatch_pid(u, pid);
2658 }
2659 }
2660
2661 static int on_rewatch_pids_event(sd_event_source *s, void *userdata) {
2662 Unit *u = userdata;
2663
2664 assert(s);
2665 assert(u);
2666
2667 unit_tidy_watch_pids(u);
2668 unit_watch_all_pids(u);
2669
2670 /* If the PID set is empty now, then let's finish this off. */
2671 unit_synthesize_cgroup_empty_event(u);
2672
2673 return 0;
2674 }
2675
2676 int unit_enqueue_rewatch_pids(Unit *u) {
2677 int r;
2678
2679 assert(u);
2680
2681 if (!u->cgroup_path)
2682 return -ENOENT;
2683
2684 r = cg_unified_controller(SYSTEMD_CGROUP_CONTROLLER);
2685 if (r < 0)
2686 return r;
2687 if (r > 0) /* On unified we can use proper notifications */
2688 return 0;
2689
2690 /* Enqueues a low-priority job that will clean up dead PIDs from our list of PIDs to watch and subscribe to new
2691 * PIDs that might have appeared. We do this in a delayed job because the work might be quite slow, as it
2692 * involves issuing kill(pid, 0) on all processes we watch. */
2693
2694 if (!u->rewatch_pids_event_source) {
2695 _cleanup_(sd_event_source_unrefp) sd_event_source *s = NULL;
2696
2697 r = sd_event_add_defer(u->manager->event, &s, on_rewatch_pids_event, u);
2698 if (r < 0)
2699 return log_error_errno(r, "Failed to allocate event source for tidying watched PIDs: %m");
2700
2701 r = sd_event_source_set_priority(s, SD_EVENT_PRIORITY_IDLE);
2702 if (r < 0)
2703 return log_error_errno(r, "Failed to adjust priority of event source for tidying watched PIDs: m");
2704
2705 (void) sd_event_source_set_description(s, "tidy-watch-pids");
2706
2707 u->rewatch_pids_event_source = TAKE_PTR(s);
2708 }
2709
2710 r = sd_event_source_set_enabled(u->rewatch_pids_event_source, SD_EVENT_ONESHOT);
2711 if (r < 0)
2712 return log_error_errno(r, "Failed to enable event source for tidying watched PIDs: %m");
2713
2714 return 0;
2715 }
2716
2717 void unit_dequeue_rewatch_pids(Unit *u) {
2718 int r;
2719 assert(u);
2720
2721 if (!u->rewatch_pids_event_source)
2722 return;
2723
2724 r = sd_event_source_set_enabled(u->rewatch_pids_event_source, SD_EVENT_OFF);
2725 if (r < 0)
2726 log_warning_errno(r, "Failed to disable event source for tidying watched PIDs, ignoring: %m");
2727
2728 u->rewatch_pids_event_source = sd_event_source_unref(u->rewatch_pids_event_source);
2729 }
2730
2731 bool unit_job_is_applicable(Unit *u, JobType j) {
2732 assert(u);
2733 assert(j >= 0 && j < _JOB_TYPE_MAX);
2734
2735 switch (j) {
2736
2737 case JOB_VERIFY_ACTIVE:
2738 case JOB_START:
2739 case JOB_NOP:
2740 /* Note that we don't check unit_can_start() here. That's because .device units and suchlike are not
2741 * startable by us but may appear due to external events, and it thus makes sense to permit enqueing
2742 * jobs for it. */
2743 return true;
2744
2745 case JOB_STOP:
2746 /* Similar as above. However, perpetual units can never be stopped (neither explicitly nor due to
2747 * external events), hence it makes no sense to permit enqueing such a request either. */
2748 return !u->perpetual;
2749
2750 case JOB_RESTART:
2751 case JOB_TRY_RESTART:
2752 return unit_can_stop(u) && unit_can_start(u);
2753
2754 case JOB_RELOAD:
2755 case JOB_TRY_RELOAD:
2756 return unit_can_reload(u);
2757
2758 case JOB_RELOAD_OR_START:
2759 return unit_can_reload(u) && unit_can_start(u);
2760
2761 default:
2762 assert_not_reached("Invalid job type");
2763 }
2764 }
2765
2766 static void maybe_warn_about_dependency(Unit *u, const char *other, UnitDependency dependency) {
2767 assert(u);
2768
2769 /* Only warn about some unit types */
2770 if (!IN_SET(dependency, UNIT_CONFLICTS, UNIT_CONFLICTED_BY, UNIT_BEFORE, UNIT_AFTER, UNIT_ON_FAILURE, UNIT_TRIGGERS, UNIT_TRIGGERED_BY))
2771 return;
2772
2773 if (streq_ptr(u->id, other))
2774 log_unit_warning(u, "Dependency %s=%s dropped", unit_dependency_to_string(dependency), u->id);
2775 else
2776 log_unit_warning(u, "Dependency %s=%s dropped, merged into %s", unit_dependency_to_string(dependency), strna(other), u->id);
2777 }
2778
2779 static int unit_add_dependency_hashmap(
2780 Hashmap **h,
2781 Unit *other,
2782 UnitDependencyMask origin_mask,
2783 UnitDependencyMask destination_mask) {
2784
2785 UnitDependencyInfo info;
2786 int r;
2787
2788 assert(h);
2789 assert(other);
2790 assert(origin_mask < _UNIT_DEPENDENCY_MASK_FULL);
2791 assert(destination_mask < _UNIT_DEPENDENCY_MASK_FULL);
2792 assert(origin_mask > 0 || destination_mask > 0);
2793
2794 r = hashmap_ensure_allocated(h, NULL);
2795 if (r < 0)
2796 return r;
2797
2798 assert_cc(sizeof(void*) == sizeof(info));
2799
2800 info.data = hashmap_get(*h, other);
2801 if (info.data) {
2802 /* Entry already exists. Add in our mask. */
2803
2804 if (FLAGS_SET(origin_mask, info.origin_mask) &&
2805 FLAGS_SET(destination_mask, info.destination_mask))
2806 return 0; /* NOP */
2807
2808 info.origin_mask |= origin_mask;
2809 info.destination_mask |= destination_mask;
2810
2811 r = hashmap_update(*h, other, info.data);
2812 } else {
2813 info = (UnitDependencyInfo) {
2814 .origin_mask = origin_mask,
2815 .destination_mask = destination_mask,
2816 };
2817
2818 r = hashmap_put(*h, other, info.data);
2819 }
2820 if (r < 0)
2821 return r;
2822
2823 return 1;
2824 }
2825
2826 int unit_add_dependency(
2827 Unit *u,
2828 UnitDependency d,
2829 Unit *other,
2830 bool add_reference,
2831 UnitDependencyMask mask) {
2832
2833 static const UnitDependency inverse_table[_UNIT_DEPENDENCY_MAX] = {
2834 [UNIT_REQUIRES] = UNIT_REQUIRED_BY,
2835 [UNIT_WANTS] = UNIT_WANTED_BY,
2836 [UNIT_REQUISITE] = UNIT_REQUISITE_OF,
2837 [UNIT_BINDS_TO] = UNIT_BOUND_BY,
2838 [UNIT_PART_OF] = UNIT_CONSISTS_OF,
2839 [UNIT_REQUIRED_BY] = UNIT_REQUIRES,
2840 [UNIT_REQUISITE_OF] = UNIT_REQUISITE,
2841 [UNIT_WANTED_BY] = UNIT_WANTS,
2842 [UNIT_BOUND_BY] = UNIT_BINDS_TO,
2843 [UNIT_CONSISTS_OF] = UNIT_PART_OF,
2844 [UNIT_CONFLICTS] = UNIT_CONFLICTED_BY,
2845 [UNIT_CONFLICTED_BY] = UNIT_CONFLICTS,
2846 [UNIT_BEFORE] = UNIT_AFTER,
2847 [UNIT_AFTER] = UNIT_BEFORE,
2848 [UNIT_ON_FAILURE] = _UNIT_DEPENDENCY_INVALID,
2849 [UNIT_REFERENCES] = UNIT_REFERENCED_BY,
2850 [UNIT_REFERENCED_BY] = UNIT_REFERENCES,
2851 [UNIT_TRIGGERS] = UNIT_TRIGGERED_BY,
2852 [UNIT_TRIGGERED_BY] = UNIT_TRIGGERS,
2853 [UNIT_PROPAGATES_RELOAD_TO] = UNIT_RELOAD_PROPAGATED_FROM,
2854 [UNIT_RELOAD_PROPAGATED_FROM] = UNIT_PROPAGATES_RELOAD_TO,
2855 [UNIT_JOINS_NAMESPACE_OF] = UNIT_JOINS_NAMESPACE_OF,
2856 };
2857 Unit *original_u = u, *original_other = other;
2858 int r;
2859
2860 assert(u);
2861 assert(d >= 0 && d < _UNIT_DEPENDENCY_MAX);
2862 assert(other);
2863
2864 u = unit_follow_merge(u);
2865 other = unit_follow_merge(other);
2866
2867 /* We won't allow dependencies on ourselves. We will not
2868 * consider them an error however. */
2869 if (u == other) {
2870 maybe_warn_about_dependency(original_u, original_other->id, d);
2871 return 0;
2872 }
2873
2874 if ((d == UNIT_BEFORE && other->type == UNIT_DEVICE) ||
2875 (d == UNIT_AFTER && u->type == UNIT_DEVICE)) {
2876 log_unit_warning(u, "Dependency Before=%s ignored (.device units cannot be delayed)", other->id);
2877 return 0;
2878 }
2879
2880 r = unit_add_dependency_hashmap(u->dependencies + d, other, mask, 0);
2881 if (r < 0)
2882 return r;
2883
2884 if (inverse_table[d] != _UNIT_DEPENDENCY_INVALID && inverse_table[d] != d) {
2885 r = unit_add_dependency_hashmap(other->dependencies + inverse_table[d], u, 0, mask);
2886 if (r < 0)
2887 return r;
2888 }
2889
2890 if (add_reference) {
2891 r = unit_add_dependency_hashmap(u->dependencies + UNIT_REFERENCES, other, mask, 0);
2892 if (r < 0)
2893 return r;
2894
2895 r = unit_add_dependency_hashmap(other->dependencies + UNIT_REFERENCED_BY, u, 0, mask);
2896 if (r < 0)
2897 return r;
2898 }
2899
2900 unit_add_to_dbus_queue(u);
2901 return 0;
2902 }
2903
2904 int unit_add_two_dependencies(Unit *u, UnitDependency d, UnitDependency e, Unit *other, bool add_reference, UnitDependencyMask mask) {
2905 int r;
2906
2907 assert(u);
2908
2909 r = unit_add_dependency(u, d, other, add_reference, mask);
2910 if (r < 0)
2911 return r;
2912
2913 return unit_add_dependency(u, e, other, add_reference, mask);
2914 }
2915
2916 static int resolve_template(Unit *u, const char *name, char **buf, const char **ret) {
2917 int r;
2918
2919 assert(u);
2920 assert(name);
2921 assert(buf);
2922 assert(ret);
2923
2924 if (!unit_name_is_valid(name, UNIT_NAME_TEMPLATE)) {
2925 *buf = NULL;
2926 *ret = name;
2927 return 0;
2928 }
2929
2930 if (u->instance)
2931 r = unit_name_replace_instance(name, u->instance, buf);
2932 else {
2933 _cleanup_free_ char *i = NULL;
2934
2935 r = unit_name_to_prefix(u->id, &i);
2936 if (r < 0)
2937 return r;
2938
2939 r = unit_name_replace_instance(name, i, buf);
2940 }
2941 if (r < 0)
2942 return r;
2943
2944 *ret = *buf;
2945 return 0;
2946 }
2947
2948 int unit_add_dependency_by_name(Unit *u, UnitDependency d, const char *name, bool add_reference, UnitDependencyMask mask) {
2949 _cleanup_free_ char *buf = NULL;
2950 Unit *other;
2951 int r;
2952
2953 assert(u);
2954 assert(name);
2955
2956 r = resolve_template(u, name, &buf, &name);
2957 if (r < 0)
2958 return r;
2959
2960 r = manager_load_unit(u->manager, name, NULL, NULL, &other);
2961 if (r < 0)
2962 return r;
2963
2964 return unit_add_dependency(u, d, other, add_reference, mask);
2965 }
2966
2967 int unit_add_two_dependencies_by_name(Unit *u, UnitDependency d, UnitDependency e, const char *name, bool add_reference, UnitDependencyMask mask) {
2968 _cleanup_free_ char *buf = NULL;
2969 Unit *other;
2970 int r;
2971
2972 assert(u);
2973 assert(name);
2974
2975 r = resolve_template(u, name, &buf, &name);
2976 if (r < 0)
2977 return r;
2978
2979 r = manager_load_unit(u->manager, name, NULL, NULL, &other);
2980 if (r < 0)
2981 return r;
2982
2983 return unit_add_two_dependencies(u, d, e, other, add_reference, mask);
2984 }
2985
2986 int set_unit_path(const char *p) {
2987 /* This is mostly for debug purposes */
2988 if (setenv("SYSTEMD_UNIT_PATH", p, 1) < 0)
2989 return -errno;
2990
2991 return 0;
2992 }
2993
2994 char *unit_dbus_path(Unit *u) {
2995 assert(u);
2996
2997 if (!u->id)
2998 return NULL;
2999
3000 return unit_dbus_path_from_name(u->id);
3001 }
3002
3003 char *unit_dbus_path_invocation_id(Unit *u) {
3004 assert(u);
3005
3006 if (sd_id128_is_null(u->invocation_id))
3007 return NULL;
3008
3009 return unit_dbus_path_from_name(u->invocation_id_string);
3010 }
3011
3012 int unit_set_slice(Unit *u, Unit *slice) {
3013 assert(u);
3014 assert(slice);
3015
3016 /* Sets the unit slice if it has not been set before. Is extra
3017 * careful, to only allow this for units that actually have a
3018 * cgroup context. Also, we don't allow to set this for slices
3019 * (since the parent slice is derived from the name). Make
3020 * sure the unit we set is actually a slice. */
3021
3022 if (!UNIT_HAS_CGROUP_CONTEXT(u))
3023 return -EOPNOTSUPP;
3024
3025 if (u->type == UNIT_SLICE)
3026 return -EINVAL;
3027
3028 if (unit_active_state(u) != UNIT_INACTIVE)
3029 return -EBUSY;
3030
3031 if (slice->type != UNIT_SLICE)
3032 return -EINVAL;
3033
3034 if (unit_has_name(u, SPECIAL_INIT_SCOPE) &&
3035 !unit_has_name(slice, SPECIAL_ROOT_SLICE))
3036 return -EPERM;
3037
3038 if (UNIT_DEREF(u->slice) == slice)
3039 return 0;
3040
3041 /* Disallow slice changes if @u is already bound to cgroups */
3042 if (UNIT_ISSET(u->slice) && u->cgroup_realized)
3043 return -EBUSY;
3044
3045 unit_ref_set(&u->slice, u, slice);
3046 return 1;
3047 }
3048
3049 int unit_set_default_slice(Unit *u) {
3050 _cleanup_free_ char *b = NULL;
3051 const char *slice_name;
3052 Unit *slice;
3053 int r;
3054
3055 assert(u);
3056
3057 if (UNIT_ISSET(u->slice))
3058 return 0;
3059
3060 if (u->instance) {
3061 _cleanup_free_ char *prefix = NULL, *escaped = NULL;
3062
3063 /* Implicitly place all instantiated units in their
3064 * own per-template slice */
3065
3066 r = unit_name_to_prefix(u->id, &prefix);
3067 if (r < 0)
3068 return r;
3069
3070 /* The prefix is already escaped, but it might include
3071 * "-" which has a special meaning for slice units,
3072 * hence escape it here extra. */
3073 escaped = unit_name_escape(prefix);
3074 if (!escaped)
3075 return -ENOMEM;
3076
3077 if (MANAGER_IS_SYSTEM(u->manager))
3078 b = strjoin("system-", escaped, ".slice");
3079 else
3080 b = strappend(escaped, ".slice");
3081 if (!b)
3082 return -ENOMEM;
3083
3084 slice_name = b;
3085 } else
3086 slice_name =
3087 MANAGER_IS_SYSTEM(u->manager) && !unit_has_name(u, SPECIAL_INIT_SCOPE)
3088 ? SPECIAL_SYSTEM_SLICE
3089 : SPECIAL_ROOT_SLICE;
3090
3091 r = manager_load_unit(u->manager, slice_name, NULL, NULL, &slice);
3092 if (r < 0)
3093 return r;
3094
3095 return unit_set_slice(u, slice);
3096 }
3097
3098 const char *unit_slice_name(Unit *u) {
3099 assert(u);
3100
3101 if (!UNIT_ISSET(u->slice))
3102 return NULL;
3103
3104 return UNIT_DEREF(u->slice)->id;
3105 }
3106
3107 int unit_load_related_unit(Unit *u, const char *type, Unit **_found) {
3108 _cleanup_free_ char *t = NULL;
3109 int r;
3110
3111 assert(u);
3112 assert(type);
3113 assert(_found);
3114
3115 r = unit_name_change_suffix(u->id, type, &t);
3116 if (r < 0)
3117 return r;
3118 if (unit_has_name(u, t))
3119 return -EINVAL;
3120
3121 r = manager_load_unit(u->manager, t, NULL, NULL, _found);
3122 assert(r < 0 || *_found != u);
3123 return r;
3124 }
3125
3126 static int signal_name_owner_changed(sd_bus_message *message, void *userdata, sd_bus_error *error) {
3127 const char *name, *old_owner, *new_owner;
3128 Unit *u = userdata;
3129 int r;
3130
3131 assert(message);
3132 assert(u);
3133
3134 r = sd_bus_message_read(message, "sss", &name, &old_owner, &new_owner);
3135 if (r < 0) {
3136 bus_log_parse_error(r);
3137 return 0;
3138 }
3139
3140 old_owner = empty_to_null(old_owner);
3141 new_owner = empty_to_null(new_owner);
3142
3143 if (UNIT_VTABLE(u)->bus_name_owner_change)
3144 UNIT_VTABLE(u)->bus_name_owner_change(u, name, old_owner, new_owner);
3145
3146 return 0;
3147 }
3148
3149 int unit_install_bus_match(Unit *u, sd_bus *bus, const char *name) {
3150 const char *match;
3151
3152 assert(u);
3153 assert(bus);
3154 assert(name);
3155
3156 if (u->match_bus_slot)
3157 return -EBUSY;
3158
3159 match = strjoina("type='signal',"
3160 "sender='org.freedesktop.DBus',"
3161 "path='/org/freedesktop/DBus',"
3162 "interface='org.freedesktop.DBus',"
3163 "member='NameOwnerChanged',"
3164 "arg0='", name, "'");
3165
3166 return sd_bus_add_match_async(bus, &u->match_bus_slot, match, signal_name_owner_changed, NULL, u);
3167 }
3168
3169 int unit_watch_bus_name(Unit *u, const char *name) {
3170 int r;
3171
3172 assert(u);
3173 assert(name);
3174
3175 /* Watch a specific name on the bus. We only support one unit
3176 * watching each name for now. */
3177
3178 if (u->manager->api_bus) {
3179 /* If the bus is already available, install the match directly.
3180 * Otherwise, just put the name in the list. bus_setup_api() will take care later. */
3181 r = unit_install_bus_match(u, u->manager->api_bus, name);
3182 if (r < 0)
3183 return log_warning_errno(r, "Failed to subscribe to NameOwnerChanged signal for '%s': %m", name);
3184 }
3185
3186 r = hashmap_put(u->manager->watch_bus, name, u);
3187 if (r < 0) {
3188 u->match_bus_slot = sd_bus_slot_unref(u->match_bus_slot);
3189 return log_warning_errno(r, "Failed to put bus name to hashmap: %m");
3190 }
3191
3192 return 0;
3193 }
3194
3195 void unit_unwatch_bus_name(Unit *u, const char *name) {
3196 assert(u);
3197 assert(name);
3198
3199 (void) hashmap_remove_value(u->manager->watch_bus, name, u);
3200 u->match_bus_slot = sd_bus_slot_unref(u->match_bus_slot);
3201 }
3202
3203 bool unit_can_serialize(Unit *u) {
3204 assert(u);
3205
3206 return UNIT_VTABLE(u)->serialize && UNIT_VTABLE(u)->deserialize_item;
3207 }
3208
3209 static int unit_serialize_cgroup_mask(FILE *f, const char *key, CGroupMask mask) {
3210 _cleanup_free_ char *s = NULL;
3211 int r = 0;
3212
3213 assert(f);
3214 assert(key);
3215
3216 if (mask != 0) {
3217 r = cg_mask_to_string(mask, &s);
3218 if (r >= 0) {
3219 fputs(key, f);
3220 fputc('=', f);
3221 fputs(s, f);
3222 fputc('\n', f);
3223 }
3224 }
3225 return r;
3226 }
3227
3228 static const char *ip_accounting_metric_field[_CGROUP_IP_ACCOUNTING_METRIC_MAX] = {
3229 [CGROUP_IP_INGRESS_BYTES] = "ip-accounting-ingress-bytes",
3230 [CGROUP_IP_INGRESS_PACKETS] = "ip-accounting-ingress-packets",
3231 [CGROUP_IP_EGRESS_BYTES] = "ip-accounting-egress-bytes",
3232 [CGROUP_IP_EGRESS_PACKETS] = "ip-accounting-egress-packets",
3233 };
3234
3235 int unit_serialize(Unit *u, FILE *f, FDSet *fds, bool serialize_jobs) {
3236 CGroupIPAccountingMetric m;
3237 int r;
3238
3239 assert(u);
3240 assert(f);
3241 assert(fds);
3242
3243 if (unit_can_serialize(u)) {
3244 r = UNIT_VTABLE(u)->serialize(u, f, fds);
3245 if (r < 0)
3246 return r;
3247 }
3248
3249 dual_timestamp_serialize(f, "state-change-timestamp", &u->state_change_timestamp);
3250
3251 dual_timestamp_serialize(f, "inactive-exit-timestamp", &u->inactive_exit_timestamp);
3252 dual_timestamp_serialize(f, "active-enter-timestamp", &u->active_enter_timestamp);
3253 dual_timestamp_serialize(f, "active-exit-timestamp", &u->active_exit_timestamp);
3254 dual_timestamp_serialize(f, "inactive-enter-timestamp", &u->inactive_enter_timestamp);
3255
3256 dual_timestamp_serialize(f, "condition-timestamp", &u->condition_timestamp);
3257 dual_timestamp_serialize(f, "assert-timestamp", &u->assert_timestamp);
3258
3259 if (dual_timestamp_is_set(&u->condition_timestamp))
3260 unit_serialize_item(u, f, "condition-result", yes_no(u->condition_result));
3261
3262 if (dual_timestamp_is_set(&u->assert_timestamp))
3263 unit_serialize_item(u, f, "assert-result", yes_no(u->assert_result));
3264
3265 unit_serialize_item(u, f, "transient", yes_no(u->transient));
3266
3267 unit_serialize_item(u, f, "in-audit", yes_no(u->in_audit));
3268
3269 unit_serialize_item(u, f, "exported-invocation-id", yes_no(u->exported_invocation_id));
3270 unit_serialize_item(u, f, "exported-log-level-max", yes_no(u->exported_log_level_max));
3271 unit_serialize_item(u, f, "exported-log-extra-fields", yes_no(u->exported_log_extra_fields));
3272 unit_serialize_item(u, f, "exported-log-rate-limit-interval", yes_no(u->exported_log_rate_limit_interval));
3273 unit_serialize_item(u, f, "exported-log-rate-limit-burst", yes_no(u->exported_log_rate_limit_burst));
3274
3275 unit_serialize_item_format(u, f, "cpu-usage-base", "%" PRIu64, u->cpu_usage_base);
3276 if (u->cpu_usage_last != NSEC_INFINITY)
3277 unit_serialize_item_format(u, f, "cpu-usage-last", "%" PRIu64, u->cpu_usage_last);
3278
3279 if (u->cgroup_path)
3280 unit_serialize_item(u, f, "cgroup", u->cgroup_path);
3281 unit_serialize_item(u, f, "cgroup-realized", yes_no(u->cgroup_realized));
3282 (void) unit_serialize_cgroup_mask(f, "cgroup-realized-mask", u->cgroup_realized_mask);
3283 (void) unit_serialize_cgroup_mask(f, "cgroup-enabled-mask", u->cgroup_enabled_mask);
3284 (void) unit_serialize_cgroup_mask(f, "cgroup-invalidated-mask", u->cgroup_invalidated_mask);
3285
3286 if (uid_is_valid(u->ref_uid))
3287 unit_serialize_item_format(u, f, "ref-uid", UID_FMT, u->ref_uid);
3288 if (gid_is_valid(u->ref_gid))
3289 unit_serialize_item_format(u, f, "ref-gid", GID_FMT, u->ref_gid);
3290
3291 if (!sd_id128_is_null(u->invocation_id))
3292 unit_serialize_item_format(u, f, "invocation-id", SD_ID128_FORMAT_STR, SD_ID128_FORMAT_VAL(u->invocation_id));
3293
3294 bus_track_serialize(u->bus_track, f, "ref");
3295
3296 for (m = 0; m < _CGROUP_IP_ACCOUNTING_METRIC_MAX; m++) {
3297 uint64_t v;
3298
3299 r = unit_get_ip_accounting(u, m, &v);
3300 if (r >= 0)
3301 unit_serialize_item_format(u, f, ip_accounting_metric_field[m], "%" PRIu64, v);
3302 }
3303
3304 if (serialize_jobs) {
3305 if (u->job) {
3306 fprintf(f, "job\n");
3307 job_serialize(u->job, f);
3308 }
3309
3310 if (u->nop_job) {
3311 fprintf(f, "job\n");
3312 job_serialize(u->nop_job, f);
3313 }
3314 }
3315
3316 /* End marker */
3317 fputc('\n', f);
3318 return 0;
3319 }
3320
3321 int unit_serialize_item(Unit *u, FILE *f, const char *key, const char *value) {
3322 assert(u);
3323 assert(f);
3324 assert(key);
3325
3326 if (!value)
3327 return 0;
3328
3329 fputs(key, f);
3330 fputc('=', f);
3331 fputs(value, f);
3332 fputc('\n', f);
3333
3334 return 1;
3335 }
3336
3337 int unit_serialize_item_escaped(Unit *u, FILE *f, const char *key, const char *value) {
3338 _cleanup_free_ char *c = NULL;
3339
3340 assert(u);
3341 assert(f);
3342 assert(key);
3343
3344 if (!value)
3345 return 0;
3346
3347 c = cescape(value);
3348 if (!c)
3349 return -ENOMEM;
3350
3351 fputs(key, f);
3352 fputc('=', f);
3353 fputs(c, f);
3354 fputc('\n', f);
3355
3356 return 1;
3357 }
3358
3359 int unit_serialize_item_fd(Unit *u, FILE *f, FDSet *fds, const char *key, int fd) {
3360 int copy;
3361
3362 assert(u);
3363 assert(f);
3364 assert(key);
3365
3366 if (fd < 0)
3367 return 0;
3368
3369 copy = fdset_put_dup(fds, fd);
3370 if (copy < 0)
3371 return copy;
3372
3373 fprintf(f, "%s=%i\n", key, copy);
3374 return 1;
3375 }
3376
3377 void unit_serialize_item_format(Unit *u, FILE *f, const char *key, const char *format, ...) {
3378 va_list ap;
3379
3380 assert(u);
3381 assert(f);
3382 assert(key);
3383 assert(format);
3384
3385 fputs(key, f);
3386 fputc('=', f);
3387
3388 va_start(ap, format);
3389 vfprintf(f, format, ap);
3390 va_end(ap);
3391
3392 fputc('\n', f);
3393 }
3394
3395 int unit_deserialize(Unit *u, FILE *f, FDSet *fds) {
3396 int r;
3397
3398 assert(u);
3399 assert(f);
3400 assert(fds);
3401
3402 for (;;) {
3403 _cleanup_free_ char *line = NULL;
3404 CGroupIPAccountingMetric m;
3405 char *l, *v;
3406 size_t k;
3407
3408 r = read_line(f, LONG_LINE_MAX, &line);
3409 if (r < 0)
3410 return log_error_errno(r, "Failed to read serialization line: %m");
3411 if (r == 0) /* eof */
3412 break;
3413
3414 l = strstrip(line);
3415 if (isempty(l)) /* End marker */
3416 break;
3417
3418 k = strcspn(l, "=");
3419
3420 if (l[k] == '=') {
3421 l[k] = 0;
3422 v = l+k+1;
3423 } else
3424 v = l+k;
3425
3426 if (streq(l, "job")) {
3427 if (v[0] == '\0') {
3428 /* new-style serialized job */
3429 Job *j;
3430
3431 j = job_new_raw(u);
3432 if (!j)
3433 return log_oom();
3434
3435 r = job_deserialize(j, f);
3436 if (r < 0) {
3437 job_free(j);
3438 return r;
3439 }
3440
3441 r = hashmap_put(u->manager->jobs, UINT32_TO_PTR(j->id), j);
3442 if (r < 0) {
3443 job_free(j);
3444 return r;
3445 }
3446
3447 r = job_install_deserialized(j);
3448 if (r < 0) {
3449 hashmap_remove(u->manager->jobs, UINT32_TO_PTR(j->id));
3450 job_free(j);
3451 return r;
3452 }
3453 } else /* legacy for pre-44 */
3454 log_unit_warning(u, "Update from too old systemd versions are unsupported, cannot deserialize job: %s", v);
3455 continue;
3456 } else if (streq(l, "state-change-timestamp")) {
3457 dual_timestamp_deserialize(v, &u->state_change_timestamp);
3458 continue;
3459 } else if (streq(l, "inactive-exit-timestamp")) {
3460 dual_timestamp_deserialize(v, &u->inactive_exit_timestamp);
3461 continue;
3462 } else if (streq(l, "active-enter-timestamp")) {
3463 dual_timestamp_deserialize(v, &u->active_enter_timestamp);
3464 continue;
3465 } else if (streq(l, "active-exit-timestamp")) {
3466 dual_timestamp_deserialize(v, &u->active_exit_timestamp);
3467 continue;
3468 } else if (streq(l, "inactive-enter-timestamp")) {
3469 dual_timestamp_deserialize(v, &u->inactive_enter_timestamp);
3470 continue;
3471 } else if (streq(l, "condition-timestamp")) {
3472 dual_timestamp_deserialize(v, &u->condition_timestamp);
3473 continue;
3474 } else if (streq(l, "assert-timestamp")) {
3475 dual_timestamp_deserialize(v, &u->assert_timestamp);
3476 continue;
3477 } else if (streq(l, "condition-result")) {
3478
3479 r = parse_boolean(v);
3480 if (r < 0)
3481 log_unit_debug(u, "Failed to parse condition result value %s, ignoring.", v);
3482 else
3483 u->condition_result = r;
3484
3485 continue;
3486
3487 } else if (streq(l, "assert-result")) {
3488
3489 r = parse_boolean(v);
3490 if (r < 0)
3491 log_unit_debug(u, "Failed to parse assert result value %s, ignoring.", v);
3492 else
3493 u->assert_result = r;
3494
3495 continue;
3496
3497 } else if (streq(l, "transient")) {
3498
3499 r = parse_boolean(v);
3500 if (r < 0)
3501 log_unit_debug(u, "Failed to parse transient bool %s, ignoring.", v);
3502 else
3503 u->transient = r;
3504
3505 continue;
3506
3507 } else if (streq(l, "in-audit")) {
3508
3509 r = parse_boolean(v);
3510 if (r < 0)
3511 log_unit_debug(u, "Failed to parse in-audit bool %s, ignoring.", v);
3512 else
3513 u->in_audit = r;
3514
3515 continue;
3516
3517 } else if (streq(l, "exported-invocation-id")) {
3518
3519 r = parse_boolean(v);
3520 if (r < 0)
3521 log_unit_debug(u, "Failed to parse exported invocation ID bool %s, ignoring.", v);
3522 else
3523 u->exported_invocation_id = r;
3524
3525 continue;
3526
3527 } else if (streq(l, "exported-log-level-max")) {
3528
3529 r = parse_boolean(v);
3530 if (r < 0)
3531 log_unit_debug(u, "Failed to parse exported log level max bool %s, ignoring.", v);
3532 else
3533 u->exported_log_level_max = r;
3534
3535 continue;
3536
3537 } else if (streq(l, "exported-log-extra-fields")) {
3538
3539 r = parse_boolean(v);
3540 if (r < 0)
3541 log_unit_debug(u, "Failed to parse exported log extra fields bool %s, ignoring.", v);
3542 else
3543 u->exported_log_extra_fields = r;
3544
3545 continue;
3546
3547 } else if (streq(l, "exported-log-rate-limit-interval")) {
3548
3549 r = parse_boolean(v);
3550 if (r < 0)
3551 log_unit_debug(u, "Failed to parse exported log rate limit interval %s, ignoring.", v);
3552 else
3553 u->exported_log_rate_limit_interval = r;
3554
3555 continue;
3556
3557 } else if (streq(l, "exported-log-rate-limit-burst")) {
3558
3559 r = parse_boolean(v);
3560 if (r < 0)
3561 log_unit_debug(u, "Failed to parse exported log rate limit burst %s, ignoring.", v);
3562 else
3563 u->exported_log_rate_limit_burst = r;
3564
3565 continue;
3566
3567 } else if (STR_IN_SET(l, "cpu-usage-base", "cpuacct-usage-base")) {
3568
3569 r = safe_atou64(v, &u->cpu_usage_base);
3570 if (r < 0)
3571 log_unit_debug(u, "Failed to parse CPU usage base %s, ignoring.", v);
3572
3573 continue;
3574
3575 } else if (streq(l, "cpu-usage-last")) {
3576
3577 r = safe_atou64(v, &u->cpu_usage_last);
3578 if (r < 0)
3579 log_unit_debug(u, "Failed to read CPU usage last %s, ignoring.", v);
3580
3581 continue;
3582
3583 } else if (streq(l, "cgroup")) {
3584
3585 r = unit_set_cgroup_path(u, v);
3586 if (r < 0)
3587 log_unit_debug_errno(u, r, "Failed to set cgroup path %s, ignoring: %m", v);
3588
3589 (void) unit_watch_cgroup(u);
3590
3591 continue;
3592 } else if (streq(l, "cgroup-realized")) {
3593 int b;
3594
3595 b = parse_boolean(v);
3596 if (b < 0)
3597 log_unit_debug(u, "Failed to parse cgroup-realized bool %s, ignoring.", v);
3598 else
3599 u->cgroup_realized = b;
3600
3601 continue;
3602
3603 } else if (streq(l, "cgroup-realized-mask")) {
3604
3605 r = cg_mask_from_string(v, &u->cgroup_realized_mask);
3606 if (r < 0)
3607 log_unit_debug(u, "Failed to parse cgroup-realized-mask %s, ignoring.", v);
3608 continue;
3609
3610 } else if (streq(l, "cgroup-enabled-mask")) {
3611
3612 r = cg_mask_from_string(v, &u->cgroup_enabled_mask);
3613 if (r < 0)
3614 log_unit_debug(u, "Failed to parse cgroup-enabled-mask %s, ignoring.", v);
3615 continue;
3616
3617 } else if (streq(l, "cgroup-invalidated-mask")) {
3618
3619 r = cg_mask_from_string(v, &u->cgroup_invalidated_mask);
3620 if (r < 0)
3621 log_unit_debug(u, "Failed to parse cgroup-invalidated-mask %s, ignoring.", v);
3622 continue;
3623
3624 } else if (streq(l, "ref-uid")) {
3625 uid_t uid;
3626
3627 r = parse_uid(v, &uid);
3628 if (r < 0)
3629 log_unit_debug(u, "Failed to parse referenced UID %s, ignoring.", v);
3630 else
3631 unit_ref_uid_gid(u, uid, GID_INVALID);
3632
3633 continue;
3634
3635 } else if (streq(l, "ref-gid")) {
3636 gid_t gid;
3637
3638 r = parse_gid(v, &gid);
3639 if (r < 0)
3640 log_unit_debug(u, "Failed to parse referenced GID %s, ignoring.", v);
3641 else
3642 unit_ref_uid_gid(u, UID_INVALID, gid);
3643
3644 continue;
3645
3646 } else if (streq(l, "ref")) {
3647
3648 r = strv_extend(&u->deserialized_refs, v);
3649 if (r < 0)
3650 log_oom();
3651
3652 continue;
3653 } else if (streq(l, "invocation-id")) {
3654 sd_id128_t id;
3655
3656 r = sd_id128_from_string(v, &id);
3657 if (r < 0)
3658 log_unit_debug(u, "Failed to parse invocation id %s, ignoring.", v);
3659 else {
3660 r = unit_set_invocation_id(u, id);
3661 if (r < 0)
3662 log_unit_warning_errno(u, r, "Failed to set invocation ID for unit: %m");
3663 }
3664
3665 continue;
3666 }
3667
3668 /* Check if this is an IP accounting metric serialization field */
3669 for (m = 0; m < _CGROUP_IP_ACCOUNTING_METRIC_MAX; m++)
3670 if (streq(l, ip_accounting_metric_field[m]))
3671 break;
3672 if (m < _CGROUP_IP_ACCOUNTING_METRIC_MAX) {
3673 uint64_t c;
3674
3675 r = safe_atou64(v, &c);
3676 if (r < 0)
3677 log_unit_debug(u, "Failed to parse IP accounting value %s, ignoring.", v);
3678 else
3679 u->ip_accounting_extra[m] = c;
3680 continue;
3681 }
3682
3683 if (unit_can_serialize(u)) {
3684 r = exec_runtime_deserialize_compat(u, l, v, fds);
3685 if (r < 0) {
3686 log_unit_warning(u, "Failed to deserialize runtime parameter '%s', ignoring.", l);
3687 continue;
3688 }
3689
3690 /* Returns positive if key was handled by the call */
3691 if (r > 0)
3692 continue;
3693
3694 r = UNIT_VTABLE(u)->deserialize_item(u, l, v, fds);
3695 if (r < 0)
3696 log_unit_warning(u, "Failed to deserialize unit parameter '%s', ignoring.", l);
3697 }
3698 }
3699
3700 /* Versions before 228 did not carry a state change timestamp. In this case, take the current time. This is
3701 * useful, so that timeouts based on this timestamp don't trigger too early, and is in-line with the logic from
3702 * before 228 where the base for timeouts was not persistent across reboots. */
3703
3704 if (!dual_timestamp_is_set(&u->state_change_timestamp))
3705 dual_timestamp_get(&u->state_change_timestamp);
3706
3707 /* Let's make sure that everything that is deserialized also gets any potential new cgroup settings applied
3708 * after we are done. For that we invalidate anything already realized, so that we can realize it again. */
3709 unit_invalidate_cgroup(u, _CGROUP_MASK_ALL);
3710 unit_invalidate_cgroup_bpf(u);
3711
3712 return 0;
3713 }
3714
3715 int unit_deserialize_skip(FILE *f) {
3716 int r;
3717 assert(f);
3718
3719 /* Skip serialized data for this unit. We don't know what it is. */
3720
3721 for (;;) {
3722 _cleanup_free_ char *line = NULL;
3723 char *l;
3724
3725 r = read_line(f, LONG_LINE_MAX, &line);
3726 if (r < 0)
3727 return log_error_errno(r, "Failed to read serialization line: %m");
3728 if (r == 0)
3729 return 0;
3730
3731 l = strstrip(line);
3732
3733 /* End marker */
3734 if (isempty(l))
3735 return 1;
3736 }
3737 }
3738
3739 int unit_add_node_dependency(Unit *u, const char *what, bool wants, UnitDependency dep, UnitDependencyMask mask) {
3740 Unit *device;
3741 _cleanup_free_ char *e = NULL;
3742 int r;
3743
3744 assert(u);
3745
3746 /* Adds in links to the device node that this unit is based on */
3747 if (isempty(what))
3748 return 0;
3749
3750 if (!is_device_path(what))
3751 return 0;
3752
3753 /* When device units aren't supported (such as in a
3754 * container), don't create dependencies on them. */
3755 if (!unit_type_supported(UNIT_DEVICE))
3756 return 0;
3757
3758 r = unit_name_from_path(what, ".device", &e);
3759 if (r < 0)
3760 return r;
3761
3762 r = manager_load_unit(u->manager, e, NULL, NULL, &device);
3763 if (r < 0)
3764 return r;
3765
3766 if (dep == UNIT_REQUIRES && device_shall_be_bound_by(device, u))
3767 dep = UNIT_BINDS_TO;
3768
3769 r = unit_add_two_dependencies(u, UNIT_AFTER,
3770 MANAGER_IS_SYSTEM(u->manager) ? dep : UNIT_WANTS,
3771 device, true, mask);
3772 if (r < 0)
3773 return r;
3774
3775 if (wants) {
3776 r = unit_add_dependency(device, UNIT_WANTS, u, false, mask);
3777 if (r < 0)
3778 return r;
3779 }
3780
3781 return 0;
3782 }
3783
3784 int unit_coldplug(Unit *u) {
3785 int r = 0, q;
3786 char **i;
3787
3788 assert(u);
3789
3790 /* Make sure we don't enter a loop, when coldplugging recursively. */
3791 if (u->coldplugged)
3792 return 0;
3793
3794 u->coldplugged = true;
3795
3796 STRV_FOREACH(i, u->deserialized_refs) {
3797 q = bus_unit_track_add_name(u, *i);
3798 if (q < 0 && r >= 0)
3799 r = q;
3800 }
3801 u->deserialized_refs = strv_free(u->deserialized_refs);
3802
3803 if (UNIT_VTABLE(u)->coldplug) {
3804 q = UNIT_VTABLE(u)->coldplug(u);
3805 if (q < 0 && r >= 0)
3806 r = q;
3807 }
3808
3809 if (u->job) {
3810 q = job_coldplug(u->job);
3811 if (q < 0 && r >= 0)
3812 r = q;
3813 }
3814
3815 return r;
3816 }
3817
3818 void unit_catchup(Unit *u) {
3819 assert(u);
3820
3821 if (UNIT_VTABLE(u)->catchup)
3822 UNIT_VTABLE(u)->catchup(u);
3823 }
3824
3825 static bool fragment_mtime_newer(const char *path, usec_t mtime, bool path_masked) {
3826 struct stat st;
3827
3828 if (!path)
3829 return false;
3830
3831 /* If the source is some virtual kernel file system, then we assume we watch it anyway, and hence pretend we
3832 * are never out-of-date. */
3833 if (PATH_STARTSWITH_SET(path, "/proc", "/sys"))
3834 return false;
3835
3836 if (stat(path, &st) < 0)
3837 /* What, cannot access this anymore? */
3838 return true;
3839
3840 if (path_masked)
3841 /* For masked files check if they are still so */
3842 return !null_or_empty(&st);
3843 else
3844 /* For non-empty files check the mtime */
3845 return timespec_load(&st.st_mtim) > mtime;
3846
3847 return false;
3848 }
3849
3850 bool unit_need_daemon_reload(Unit *u) {
3851 _cleanup_strv_free_ char **t = NULL;
3852 char **path;
3853
3854 assert(u);
3855
3856 /* For unit files, we allow masking… */
3857 if (fragment_mtime_newer(u->fragment_path, u->fragment_mtime,
3858 u->load_state == UNIT_MASKED))
3859 return true;
3860
3861 /* Source paths should not be masked… */
3862 if (fragment_mtime_newer(u->source_path, u->source_mtime, false))
3863 return true;
3864
3865 if (u->load_state == UNIT_LOADED)
3866 (void) unit_find_dropin_paths(u, &t);
3867 if (!strv_equal(u->dropin_paths, t))
3868 return true;
3869
3870 /* … any drop-ins that are masked are simply omitted from the list. */
3871 STRV_FOREACH(path, u->dropin_paths)
3872 if (fragment_mtime_newer(*path, u->dropin_mtime, false))
3873 return true;
3874
3875 return false;
3876 }
3877
3878 void unit_reset_failed(Unit *u) {
3879 assert(u);
3880
3881 if (UNIT_VTABLE(u)->reset_failed)
3882 UNIT_VTABLE(u)->reset_failed(u);
3883
3884 RATELIMIT_RESET(u->start_limit);
3885 u->start_limit_hit = false;
3886 }
3887
3888 Unit *unit_following(Unit *u) {
3889 assert(u);
3890
3891 if (UNIT_VTABLE(u)->following)
3892 return UNIT_VTABLE(u)->following(u);
3893
3894 return NULL;
3895 }
3896
3897 bool unit_stop_pending(Unit *u) {
3898 assert(u);
3899
3900 /* This call does check the current state of the unit. It's
3901 * hence useful to be called from state change calls of the
3902 * unit itself, where the state isn't updated yet. This is
3903 * different from unit_inactive_or_pending() which checks both
3904 * the current state and for a queued job. */
3905
3906 return u->job && u->job->type == JOB_STOP;
3907 }
3908
3909 bool unit_inactive_or_pending(Unit *u) {
3910 assert(u);
3911
3912 /* Returns true if the unit is inactive or going down */
3913
3914 if (UNIT_IS_INACTIVE_OR_DEACTIVATING(unit_active_state(u)))
3915 return true;
3916
3917 if (unit_stop_pending(u))
3918 return true;
3919
3920 return false;
3921 }
3922
3923 bool unit_active_or_pending(Unit *u) {
3924 assert(u);
3925
3926 /* Returns true if the unit is active or going up */
3927
3928 if (UNIT_IS_ACTIVE_OR_ACTIVATING(unit_active_state(u)))
3929 return true;
3930
3931 if (u->job &&
3932 IN_SET(u->job->type, JOB_START, JOB_RELOAD_OR_START, JOB_RESTART))
3933 return true;
3934
3935 return false;
3936 }
3937
3938 bool unit_will_restart(Unit *u) {
3939 assert(u);
3940
3941 if (!UNIT_VTABLE(u)->will_restart)
3942 return false;
3943
3944 return UNIT_VTABLE(u)->will_restart(u);
3945 }
3946
3947 int unit_kill(Unit *u, KillWho w, int signo, sd_bus_error *error) {
3948 assert(u);
3949 assert(w >= 0 && w < _KILL_WHO_MAX);
3950 assert(SIGNAL_VALID(signo));
3951
3952 if (!UNIT_VTABLE(u)->kill)
3953 return -EOPNOTSUPP;
3954
3955 return UNIT_VTABLE(u)->kill(u, w, signo, error);
3956 }
3957
3958 static Set *unit_pid_set(pid_t main_pid, pid_t control_pid) {
3959 _cleanup_set_free_ Set *pid_set = NULL;
3960 int r;
3961
3962 pid_set = set_new(NULL);
3963 if (!pid_set)
3964 return NULL;
3965
3966 /* Exclude the main/control pids from being killed via the cgroup */
3967 if (main_pid > 0) {
3968 r = set_put(pid_set, PID_TO_PTR(main_pid));
3969 if (r < 0)
3970 return NULL;
3971 }
3972
3973 if (control_pid > 0) {
3974 r = set_put(pid_set, PID_TO_PTR(control_pid));
3975 if (r < 0)
3976 return NULL;
3977 }
3978
3979 return TAKE_PTR(pid_set);
3980 }
3981
3982 int unit_kill_common(
3983 Unit *u,
3984 KillWho who,
3985 int signo,
3986 pid_t main_pid,
3987 pid_t control_pid,
3988 sd_bus_error *error) {
3989
3990 int r = 0;
3991 bool killed = false;
3992
3993 if (IN_SET(who, KILL_MAIN, KILL_MAIN_FAIL)) {
3994 if (main_pid < 0)
3995 return sd_bus_error_setf(error, BUS_ERROR_NO_SUCH_PROCESS, "%s units have no main processes", unit_type_to_string(u->type));
3996 else if (main_pid == 0)
3997 return sd_bus_error_set_const(error, BUS_ERROR_NO_SUCH_PROCESS, "No main process to kill");
3998 }
3999
4000 if (IN_SET(who, KILL_CONTROL, KILL_CONTROL_FAIL)) {
4001 if (control_pid < 0)
4002 return sd_bus_error_setf(error, BUS_ERROR_NO_SUCH_PROCESS, "%s units have no control processes", unit_type_to_string(u->type));
4003 else if (control_pid == 0)
4004 return sd_bus_error_set_const(error, BUS_ERROR_NO_SUCH_PROCESS, "No control process to kill");
4005 }
4006
4007 if (IN_SET(who, KILL_CONTROL, KILL_CONTROL_FAIL, KILL_ALL, KILL_ALL_FAIL))
4008 if (control_pid > 0) {
4009 if (kill(control_pid, signo) < 0)
4010 r = -errno;
4011 else
4012 killed = true;
4013 }
4014
4015 if (IN_SET(who, KILL_MAIN, KILL_MAIN_FAIL, KILL_ALL, KILL_ALL_FAIL))
4016 if (main_pid > 0) {
4017 if (kill(main_pid, signo) < 0)
4018 r = -errno;
4019 else
4020 killed = true;
4021 }
4022
4023 if (IN_SET(who, KILL_ALL, KILL_ALL_FAIL) && u->cgroup_path) {
4024 _cleanup_set_free_ Set *pid_set = NULL;
4025 int q;
4026
4027 /* Exclude the main/control pids from being killed via the cgroup */
4028 pid_set = unit_pid_set(main_pid, control_pid);
4029 if (!pid_set)
4030 return -ENOMEM;
4031
4032 q = cg_kill_recursive(SYSTEMD_CGROUP_CONTROLLER, u->cgroup_path, signo, 0, pid_set, NULL, NULL);
4033 if (q < 0 && !IN_SET(q, -EAGAIN, -ESRCH, -ENOENT))
4034 r = q;
4035 else
4036 killed = true;
4037 }
4038
4039 if (r == 0 && !killed && IN_SET(who, KILL_ALL_FAIL, KILL_CONTROL_FAIL))
4040 return -ESRCH;
4041
4042 return r;
4043 }
4044
4045 int unit_following_set(Unit *u, Set **s) {
4046 assert(u);
4047 assert(s);
4048
4049 if (UNIT_VTABLE(u)->following_set)
4050 return UNIT_VTABLE(u)->following_set(u, s);
4051
4052 *s = NULL;
4053 return 0;
4054 }
4055
4056 UnitFileState unit_get_unit_file_state(Unit *u) {
4057 int r;
4058
4059 assert(u);
4060
4061 if (u->unit_file_state < 0 && u->fragment_path) {
4062 r = unit_file_get_state(
4063 u->manager->unit_file_scope,
4064 NULL,
4065 u->id,
4066 &u->unit_file_state);
4067 if (r < 0)
4068 u->unit_file_state = UNIT_FILE_BAD;
4069 }
4070
4071 return u->unit_file_state;
4072 }
4073
4074 int unit_get_unit_file_preset(Unit *u) {
4075 assert(u);
4076
4077 if (u->unit_file_preset < 0 && u->fragment_path)
4078 u->unit_file_preset = unit_file_query_preset(
4079 u->manager->unit_file_scope,
4080 NULL,
4081 basename(u->fragment_path));
4082
4083 return u->unit_file_preset;
4084 }
4085
4086 Unit* unit_ref_set(UnitRef *ref, Unit *source, Unit *target) {
4087 assert(ref);
4088 assert(source);
4089 assert(target);
4090
4091 if (ref->target)
4092 unit_ref_unset(ref);
4093
4094 ref->source = source;
4095 ref->target = target;
4096 LIST_PREPEND(refs_by_target, target->refs_by_target, ref);
4097 return target;
4098 }
4099
4100 void unit_ref_unset(UnitRef *ref) {
4101 assert(ref);
4102
4103 if (!ref->target)
4104 return;
4105
4106 /* We are about to drop a reference to the unit, make sure the garbage collection has a look at it as it might
4107 * be unreferenced now. */
4108 unit_add_to_gc_queue(ref->target);
4109
4110 LIST_REMOVE(refs_by_target, ref->target->refs_by_target, ref);
4111 ref->source = ref->target = NULL;
4112 }
4113
4114 static int user_from_unit_name(Unit *u, char **ret) {
4115
4116 static const uint8_t hash_key[] = {
4117 0x58, 0x1a, 0xaf, 0xe6, 0x28, 0x58, 0x4e, 0x96,
4118 0xb4, 0x4e, 0xf5, 0x3b, 0x8c, 0x92, 0x07, 0xec
4119 };
4120
4121 _cleanup_free_ char *n = NULL;
4122 int r;
4123
4124 r = unit_name_to_prefix(u->id, &n);
4125 if (r < 0)
4126 return r;
4127
4128 if (valid_user_group_name(n)) {
4129 *ret = TAKE_PTR(n);
4130 return 0;
4131 }
4132
4133 /* If we can't use the unit name as a user name, then let's hash it and use that */
4134 if (asprintf(ret, "_du%016" PRIx64, siphash24(n, strlen(n), hash_key)) < 0)
4135 return -ENOMEM;
4136
4137 return 0;
4138 }
4139
4140 int unit_patch_contexts(Unit *u) {
4141 CGroupContext *cc;
4142 ExecContext *ec;
4143 unsigned i;
4144 int r;
4145
4146 assert(u);
4147
4148 /* Patch in the manager defaults into the exec and cgroup
4149 * contexts, _after_ the rest of the settings have been
4150 * initialized */
4151
4152 ec = unit_get_exec_context(u);
4153 if (ec) {
4154 /* This only copies in the ones that need memory */
4155 for (i = 0; i < _RLIMIT_MAX; i++)
4156 if (u->manager->rlimit[i] && !ec->rlimit[i]) {
4157 ec->rlimit[i] = newdup(struct rlimit, u->manager->rlimit[i], 1);
4158 if (!ec->rlimit[i])
4159 return -ENOMEM;
4160 }
4161
4162 if (MANAGER_IS_USER(u->manager) &&
4163 !ec->working_directory) {
4164
4165 r = get_home_dir(&ec->working_directory);
4166 if (r < 0)
4167 return r;
4168
4169 /* Allow user services to run, even if the
4170 * home directory is missing */
4171 ec->working_directory_missing_ok = true;
4172 }
4173
4174 if (ec->private_devices)
4175 ec->capability_bounding_set &= ~((UINT64_C(1) << CAP_MKNOD) | (UINT64_C(1) << CAP_SYS_RAWIO));
4176
4177 if (ec->protect_kernel_modules)
4178 ec->capability_bounding_set &= ~(UINT64_C(1) << CAP_SYS_MODULE);
4179
4180 if (ec->dynamic_user) {
4181 if (!ec->user) {
4182 r = user_from_unit_name(u, &ec->user);
4183 if (r < 0)
4184 return r;
4185 }
4186
4187 if (!ec->group) {
4188 ec->group = strdup(ec->user);
4189 if (!ec->group)
4190 return -ENOMEM;
4191 }
4192
4193 /* If the dynamic user option is on, let's make sure that the unit can't leave its UID/GID
4194 * around in the file system or on IPC objects. Hence enforce a strict sandbox. */
4195
4196 ec->private_tmp = true;
4197 ec->remove_ipc = true;
4198 ec->protect_system = PROTECT_SYSTEM_STRICT;
4199 if (ec->protect_home == PROTECT_HOME_NO)
4200 ec->protect_home = PROTECT_HOME_READ_ONLY;
4201 }
4202 }
4203
4204 cc = unit_get_cgroup_context(u);
4205 if (cc && ec) {
4206
4207 if (ec->private_devices &&
4208 cc->device_policy == CGROUP_AUTO)
4209 cc->device_policy = CGROUP_CLOSED;
4210
4211 if (ec->root_image &&
4212 (cc->device_policy != CGROUP_AUTO || cc->device_allow)) {
4213
4214 /* When RootImage= is specified, the following devices are touched. */
4215 r = cgroup_add_device_allow(cc, "/dev/loop-control", "rw");
4216 if (r < 0)
4217 return r;
4218
4219 r = cgroup_add_device_allow(cc, "block-loop", "rwm");
4220 if (r < 0)
4221 return r;
4222
4223 r = cgroup_add_device_allow(cc, "block-blkext", "rwm");
4224 if (r < 0)
4225 return r;
4226 }
4227 }
4228
4229 return 0;
4230 }
4231
4232 ExecContext *unit_get_exec_context(Unit *u) {
4233 size_t offset;
4234 assert(u);
4235
4236 if (u->type < 0)
4237 return NULL;
4238
4239 offset = UNIT_VTABLE(u)->exec_context_offset;
4240 if (offset <= 0)
4241 return NULL;
4242
4243 return (ExecContext*) ((uint8_t*) u + offset);
4244 }
4245
4246 KillContext *unit_get_kill_context(Unit *u) {
4247 size_t offset;
4248 assert(u);
4249
4250 if (u->type < 0)
4251 return NULL;
4252
4253 offset = UNIT_VTABLE(u)->kill_context_offset;
4254 if (offset <= 0)
4255 return NULL;
4256
4257 return (KillContext*) ((uint8_t*) u + offset);
4258 }
4259
4260 CGroupContext *unit_get_cgroup_context(Unit *u) {
4261 size_t offset;
4262
4263 if (u->type < 0)
4264 return NULL;
4265
4266 offset = UNIT_VTABLE(u)->cgroup_context_offset;
4267 if (offset <= 0)
4268 return NULL;
4269
4270 return (CGroupContext*) ((uint8_t*) u + offset);
4271 }
4272
4273 ExecRuntime *unit_get_exec_runtime(Unit *u) {
4274 size_t offset;
4275
4276 if (u->type < 0)
4277 return NULL;
4278
4279 offset = UNIT_VTABLE(u)->exec_runtime_offset;
4280 if (offset <= 0)
4281 return NULL;
4282
4283 return *(ExecRuntime**) ((uint8_t*) u + offset);
4284 }
4285
4286 static const char* unit_drop_in_dir(Unit *u, UnitWriteFlags flags) {
4287 assert(u);
4288
4289 if (UNIT_WRITE_FLAGS_NOOP(flags))
4290 return NULL;
4291
4292 if (u->transient) /* Redirect drop-ins for transient units always into the transient directory. */
4293 return u->manager->lookup_paths.transient;
4294
4295 if (flags & UNIT_PERSISTENT)
4296 return u->manager->lookup_paths.persistent_control;
4297
4298 if (flags & UNIT_RUNTIME)
4299 return u->manager->lookup_paths.runtime_control;
4300
4301 return NULL;
4302 }
4303
4304 char* unit_escape_setting(const char *s, UnitWriteFlags flags, char **buf) {
4305 char *ret = NULL;
4306
4307 if (!s)
4308 return NULL;
4309
4310 /* Escapes the input string as requested. Returns the escaped string. If 'buf' is specified then the allocated
4311 * return buffer pointer is also written to *buf, except if no escaping was necessary, in which case *buf is
4312 * set to NULL, and the input pointer is returned as-is. This means the return value always contains a properly
4313 * escaped version, but *buf when passed only contains a pointer if an allocation was necessary. If *buf is
4314 * not specified, then the return value always needs to be freed. Callers can use this to optimize memory
4315 * allocations. */
4316
4317 if (flags & UNIT_ESCAPE_SPECIFIERS) {
4318 ret = specifier_escape(s);
4319 if (!ret)
4320 return NULL;
4321
4322 s = ret;
4323 }
4324
4325 if (flags & UNIT_ESCAPE_C) {
4326 char *a;
4327
4328 a = cescape(s);
4329 free(ret);
4330 if (!a)
4331 return NULL;
4332
4333 ret = a;
4334 }
4335
4336 if (buf) {
4337 *buf = ret;
4338 return ret ?: (char*) s;
4339 }
4340
4341 return ret ?: strdup(s);
4342 }
4343
4344 char* unit_concat_strv(char **l, UnitWriteFlags flags) {
4345 _cleanup_free_ char *result = NULL;
4346 size_t n = 0, allocated = 0;
4347 char **i;
4348
4349 /* Takes a list of strings, escapes them, and concatenates them. This may be used to format command lines in a
4350 * way suitable for ExecStart= stanzas */
4351
4352 STRV_FOREACH(i, l) {
4353 _cleanup_free_ char *buf = NULL;
4354 const char *p;
4355 size_t a;
4356 char *q;
4357
4358 p = unit_escape_setting(*i, flags, &buf);
4359 if (!p)
4360 return NULL;
4361
4362 a = (n > 0) + 1 + strlen(p) + 1; /* separating space + " + entry + " */
4363 if (!GREEDY_REALLOC(result, allocated, n + a + 1))
4364 return NULL;
4365
4366 q = result + n;
4367 if (n > 0)
4368 *(q++) = ' ';
4369
4370 *(q++) = '"';
4371 q = stpcpy(q, p);
4372 *(q++) = '"';
4373
4374 n += a;
4375 }
4376
4377 if (!GREEDY_REALLOC(result, allocated, n + 1))
4378 return NULL;
4379
4380 result[n] = 0;
4381
4382 return TAKE_PTR(result);
4383 }
4384
4385 int unit_write_setting(Unit *u, UnitWriteFlags flags, const char *name, const char *data) {
4386 _cleanup_free_ char *p = NULL, *q = NULL, *escaped = NULL;
4387 const char *dir, *wrapped;
4388 int r;
4389
4390 assert(u);
4391 assert(name);
4392 assert(data);
4393
4394 if (UNIT_WRITE_FLAGS_NOOP(flags))
4395 return 0;
4396
4397 data = unit_escape_setting(data, flags, &escaped);
4398 if (!data)
4399 return -ENOMEM;
4400
4401 /* Prefix the section header. If we are writing this out as transient file, then let's suppress this if the
4402 * previous section header is the same */
4403
4404 if (flags & UNIT_PRIVATE) {
4405 if (!UNIT_VTABLE(u)->private_section)
4406 return -EINVAL;
4407
4408 if (!u->transient_file || u->last_section_private < 0)
4409 data = strjoina("[", UNIT_VTABLE(u)->private_section, "]\n", data);
4410 else if (u->last_section_private == 0)
4411 data = strjoina("\n[", UNIT_VTABLE(u)->private_section, "]\n", data);
4412 } else {
4413 if (!u->transient_file || u->last_section_private < 0)
4414 data = strjoina("[Unit]\n", data);
4415 else if (u->last_section_private > 0)
4416 data = strjoina("\n[Unit]\n", data);
4417 }
4418
4419 if (u->transient_file) {
4420 /* When this is a transient unit file in creation, then let's not create a new drop-in but instead
4421 * write to the transient unit file. */
4422 fputs(data, u->transient_file);
4423
4424 if (!endswith(data, "\n"))
4425 fputc('\n', u->transient_file);
4426
4427 /* Remember which section we wrote this entry to */
4428 u->last_section_private = !!(flags & UNIT_PRIVATE);
4429 return 0;
4430 }
4431
4432 dir = unit_drop_in_dir(u, flags);
4433 if (!dir)
4434 return -EINVAL;
4435
4436 wrapped = strjoina("# This is a drop-in unit file extension, created via \"systemctl set-property\"\n"
4437 "# or an equivalent operation. Do not edit.\n",
4438 data,
4439 "\n");
4440
4441 r = drop_in_file(dir, u->id, 50, name, &p, &q);
4442 if (r < 0)
4443 return r;
4444
4445 (void) mkdir_p_label(p, 0755);
4446 r = write_string_file_atomic_label(q, wrapped);
4447 if (r < 0)
4448 return r;
4449
4450 r = strv_push(&u->dropin_paths, q);
4451 if (r < 0)
4452 return r;
4453 q = NULL;
4454
4455 strv_uniq(u->dropin_paths);
4456
4457 u->dropin_mtime = now(CLOCK_REALTIME);
4458
4459 return 0;
4460 }
4461
4462 int unit_write_settingf(Unit *u, UnitWriteFlags flags, const char *name, const char *format, ...) {
4463 _cleanup_free_ char *p = NULL;
4464 va_list ap;
4465 int r;
4466
4467 assert(u);
4468 assert(name);
4469 assert(format);
4470
4471 if (UNIT_WRITE_FLAGS_NOOP(flags))
4472 return 0;
4473
4474 va_start(ap, format);
4475 r = vasprintf(&p, format, ap);
4476 va_end(ap);
4477
4478 if (r < 0)
4479 return -ENOMEM;
4480
4481 return unit_write_setting(u, flags, name, p);
4482 }
4483
4484 int unit_make_transient(Unit *u) {
4485 _cleanup_free_ char *path = NULL;
4486 FILE *f;
4487
4488 assert(u);
4489
4490 if (!UNIT_VTABLE(u)->can_transient)
4491 return -EOPNOTSUPP;
4492
4493 (void) mkdir_p_label(u->manager->lookup_paths.transient, 0755);
4494
4495 path = strjoin(u->manager->lookup_paths.transient, "/", u->id);
4496 if (!path)
4497 return -ENOMEM;
4498
4499 /* Let's open the file we'll write the transient settings into. This file is kept open as long as we are
4500 * creating the transient, and is closed in unit_load(), as soon as we start loading the file. */
4501
4502 RUN_WITH_UMASK(0022) {
4503 f = fopen(path, "we");
4504 if (!f)
4505 return -errno;
4506 }
4507
4508 safe_fclose(u->transient_file);
4509 u->transient_file = f;
4510
4511 free_and_replace(u->fragment_path, path);
4512
4513 u->source_path = mfree(u->source_path);
4514 u->dropin_paths = strv_free(u->dropin_paths);
4515 u->fragment_mtime = u->source_mtime = u->dropin_mtime = 0;
4516
4517 u->load_state = UNIT_STUB;
4518 u->load_error = 0;
4519 u->transient = true;
4520
4521 unit_add_to_dbus_queue(u);
4522 unit_add_to_gc_queue(u);
4523
4524 fputs("# This is a transient unit file, created programmatically via the systemd API. Do not edit.\n",
4525 u->transient_file);
4526
4527 return 0;
4528 }
4529
4530 static void log_kill(pid_t pid, int sig, void *userdata) {
4531 _cleanup_free_ char *comm = NULL;
4532
4533 (void) get_process_comm(pid, &comm);
4534
4535 /* Don't log about processes marked with brackets, under the assumption that these are temporary processes
4536 only, like for example systemd's own PAM stub process. */
4537 if (comm && comm[0] == '(')
4538 return;
4539
4540 log_unit_notice(userdata,
4541 "Killing process " PID_FMT " (%s) with signal SIG%s.",
4542 pid,
4543 strna(comm),
4544 signal_to_string(sig));
4545 }
4546
4547 static int operation_to_signal(KillContext *c, KillOperation k) {
4548 assert(c);
4549
4550 switch (k) {
4551
4552 case KILL_TERMINATE:
4553 case KILL_TERMINATE_AND_LOG:
4554 return c->kill_signal;
4555
4556 case KILL_KILL:
4557 return c->final_kill_signal;
4558
4559 case KILL_WATCHDOG:
4560 return c->watchdog_signal;
4561
4562 default:
4563 assert_not_reached("KillOperation unknown");
4564 }
4565 }
4566
4567 int unit_kill_context(
4568 Unit *u,
4569 KillContext *c,
4570 KillOperation k,
4571 pid_t main_pid,
4572 pid_t control_pid,
4573 bool main_pid_alien) {
4574
4575 bool wait_for_exit = false, send_sighup;
4576 cg_kill_log_func_t log_func = NULL;
4577 int sig, r;
4578
4579 assert(u);
4580 assert(c);
4581
4582 /* Kill the processes belonging to this unit, in preparation for shutting the unit down.
4583 * Returns > 0 if we killed something worth waiting for, 0 otherwise. */
4584
4585 if (c->kill_mode == KILL_NONE)
4586 return 0;
4587
4588 sig = operation_to_signal(c, k);
4589
4590 send_sighup =
4591 c->send_sighup &&
4592 IN_SET(k, KILL_TERMINATE, KILL_TERMINATE_AND_LOG) &&
4593 sig != SIGHUP;
4594
4595 if (k != KILL_TERMINATE || IN_SET(sig, SIGKILL, SIGABRT))
4596 log_func = log_kill;
4597
4598 if (main_pid > 0) {
4599 if (log_func)
4600 log_func(main_pid, sig, u);
4601
4602 r = kill_and_sigcont(main_pid, sig);
4603 if (r < 0 && r != -ESRCH) {
4604 _cleanup_free_ char *comm = NULL;
4605 (void) get_process_comm(main_pid, &comm);
4606
4607 log_unit_warning_errno(u, r, "Failed to kill main process " PID_FMT " (%s), ignoring: %m", main_pid, strna(comm));
4608 } else {
4609 if (!main_pid_alien)
4610 wait_for_exit = true;
4611
4612 if (r != -ESRCH && send_sighup)
4613 (void) kill(main_pid, SIGHUP);
4614 }
4615 }
4616
4617 if (control_pid > 0) {
4618 if (log_func)
4619 log_func(control_pid, sig, u);
4620
4621 r = kill_and_sigcont(control_pid, sig);
4622 if (r < 0 && r != -ESRCH) {
4623 _cleanup_free_ char *comm = NULL;
4624 (void) get_process_comm(control_pid, &comm);
4625
4626 log_unit_warning_errno(u, r, "Failed to kill control process " PID_FMT " (%s), ignoring: %m", control_pid, strna(comm));
4627 } else {
4628 wait_for_exit = true;
4629
4630 if (r != -ESRCH && send_sighup)
4631 (void) kill(control_pid, SIGHUP);
4632 }
4633 }
4634
4635 if (u->cgroup_path &&
4636 (c->kill_mode == KILL_CONTROL_GROUP || (c->kill_mode == KILL_MIXED && k == KILL_KILL))) {
4637 _cleanup_set_free_ Set *pid_set = NULL;
4638
4639 /* Exclude the main/control pids from being killed via the cgroup */
4640 pid_set = unit_pid_set(main_pid, control_pid);
4641 if (!pid_set)
4642 return -ENOMEM;
4643
4644 r = cg_kill_recursive(SYSTEMD_CGROUP_CONTROLLER, u->cgroup_path,
4645 sig,
4646 CGROUP_SIGCONT|CGROUP_IGNORE_SELF,
4647 pid_set,
4648 log_func, u);
4649 if (r < 0) {
4650 if (!IN_SET(r, -EAGAIN, -ESRCH, -ENOENT))
4651 log_unit_warning_errno(u, r, "Failed to kill control group %s, ignoring: %m", u->cgroup_path);
4652
4653 } else if (r > 0) {
4654
4655 /* FIXME: For now, on the legacy hierarchy, we will not wait for the cgroup members to die if
4656 * we are running in a container or if this is a delegation unit, simply because cgroup
4657 * notification is unreliable in these cases. It doesn't work at all in containers, and outside
4658 * of containers it can be confused easily by left-over directories in the cgroup — which
4659 * however should not exist in non-delegated units. On the unified hierarchy that's different,
4660 * there we get proper events. Hence rely on them. */
4661
4662 if (cg_unified_controller(SYSTEMD_CGROUP_CONTROLLER) > 0 ||
4663 (detect_container() == 0 && !unit_cgroup_delegate(u)))
4664 wait_for_exit = true;
4665
4666 if (send_sighup) {
4667 set_free(pid_set);
4668
4669 pid_set = unit_pid_set(main_pid, control_pid);
4670 if (!pid_set)
4671 return -ENOMEM;
4672
4673 cg_kill_recursive(SYSTEMD_CGROUP_CONTROLLER, u->cgroup_path,
4674 SIGHUP,
4675 CGROUP_IGNORE_SELF,
4676 pid_set,
4677 NULL, NULL);
4678 }
4679 }
4680 }
4681
4682 return wait_for_exit;
4683 }
4684
4685 int unit_require_mounts_for(Unit *u, const char *path, UnitDependencyMask mask) {
4686 _cleanup_free_ char *p = NULL;
4687 char *prefix;
4688 UnitDependencyInfo di;
4689 int r;
4690
4691 assert(u);
4692 assert(path);
4693
4694 /* Registers a unit for requiring a certain path and all its prefixes. We keep a hashtable of these paths in
4695 * the unit (from the path to the UnitDependencyInfo structure indicating how to the dependency came to
4696 * be). However, we build a prefix table for all possible prefixes so that new appearing mount units can easily
4697 * determine which units to make themselves a dependency of. */
4698
4699 if (!path_is_absolute(path))
4700 return -EINVAL;
4701
4702 r = hashmap_ensure_allocated(&u->requires_mounts_for, &path_hash_ops);
4703 if (r < 0)
4704 return r;
4705
4706 p = strdup(path);
4707 if (!p)
4708 return -ENOMEM;
4709
4710 path = path_simplify(p, false);
4711
4712 if (!path_is_normalized(path))
4713 return -EPERM;
4714
4715 if (hashmap_contains(u->requires_mounts_for, path))
4716 return 0;
4717
4718 di = (UnitDependencyInfo) {
4719 .origin_mask = mask
4720 };
4721
4722 r = hashmap_put(u->requires_mounts_for, path, di.data);
4723 if (r < 0)
4724 return r;
4725 p = NULL;
4726
4727 prefix = alloca(strlen(path) + 1);
4728 PATH_FOREACH_PREFIX_MORE(prefix, path) {
4729 Set *x;
4730
4731 x = hashmap_get(u->manager->units_requiring_mounts_for, prefix);
4732 if (!x) {
4733 _cleanup_free_ char *q = NULL;
4734
4735 r = hashmap_ensure_allocated(&u->manager->units_requiring_mounts_for, &path_hash_ops);
4736 if (r < 0)
4737 return r;
4738
4739 q = strdup(prefix);
4740 if (!q)
4741 return -ENOMEM;
4742
4743 x = set_new(NULL);
4744 if (!x)
4745 return -ENOMEM;
4746
4747 r = hashmap_put(u->manager->units_requiring_mounts_for, q, x);
4748 if (r < 0) {
4749 set_free(x);
4750 return r;
4751 }
4752 q = NULL;
4753 }
4754
4755 r = set_put(x, u);
4756 if (r < 0)
4757 return r;
4758 }
4759
4760 return 0;
4761 }
4762
4763 int unit_setup_exec_runtime(Unit *u) {
4764 ExecRuntime **rt;
4765 size_t offset;
4766 Unit *other;
4767 Iterator i;
4768 void *v;
4769 int r;
4770
4771 offset = UNIT_VTABLE(u)->exec_runtime_offset;
4772 assert(offset > 0);
4773
4774 /* Check if there already is an ExecRuntime for this unit? */
4775 rt = (ExecRuntime**) ((uint8_t*) u + offset);
4776 if (*rt)
4777 return 0;
4778
4779 /* Try to get it from somebody else */
4780 HASHMAP_FOREACH_KEY(v, other, u->dependencies[UNIT_JOINS_NAMESPACE_OF], i) {
4781 r = exec_runtime_acquire(u->manager, NULL, other->id, false, rt);
4782 if (r == 1)
4783 return 1;
4784 }
4785
4786 return exec_runtime_acquire(u->manager, unit_get_exec_context(u), u->id, true, rt);
4787 }
4788
4789 int unit_setup_dynamic_creds(Unit *u) {
4790 ExecContext *ec;
4791 DynamicCreds *dcreds;
4792 size_t offset;
4793
4794 assert(u);
4795
4796 offset = UNIT_VTABLE(u)->dynamic_creds_offset;
4797 assert(offset > 0);
4798 dcreds = (DynamicCreds*) ((uint8_t*) u + offset);
4799
4800 ec = unit_get_exec_context(u);
4801 assert(ec);
4802
4803 if (!ec->dynamic_user)
4804 return 0;
4805
4806 return dynamic_creds_acquire(dcreds, u->manager, ec->user, ec->group);
4807 }
4808
4809 bool unit_type_supported(UnitType t) {
4810 if (_unlikely_(t < 0))
4811 return false;
4812 if (_unlikely_(t >= _UNIT_TYPE_MAX))
4813 return false;
4814
4815 if (!unit_vtable[t]->supported)
4816 return true;
4817
4818 return unit_vtable[t]->supported();
4819 }
4820
4821 void unit_warn_if_dir_nonempty(Unit *u, const char* where) {
4822 int r;
4823
4824 assert(u);
4825 assert(where);
4826
4827 r = dir_is_empty(where);
4828 if (r > 0 || r == -ENOTDIR)
4829 return;
4830 if (r < 0) {
4831 log_unit_warning_errno(u, r, "Failed to check directory %s: %m", where);
4832 return;
4833 }
4834
4835 log_struct(LOG_NOTICE,
4836 "MESSAGE_ID=" SD_MESSAGE_OVERMOUNTING_STR,
4837 LOG_UNIT_ID(u),
4838 LOG_UNIT_INVOCATION_ID(u),
4839 LOG_UNIT_MESSAGE(u, "Directory %s to mount over is not empty, mounting anyway.", where),
4840 "WHERE=%s", where);
4841 }
4842
4843 int unit_fail_if_noncanonical(Unit *u, const char* where) {
4844 _cleanup_free_ char *canonical_where;
4845 int r;
4846
4847 assert(u);
4848 assert(where);
4849
4850 r = chase_symlinks(where, NULL, CHASE_NONEXISTENT, &canonical_where);
4851 if (r < 0) {
4852 log_unit_debug_errno(u, r, "Failed to check %s for symlinks, ignoring: %m", where);
4853 return 0;
4854 }
4855
4856 /* We will happily ignore a trailing slash (or any redundant slashes) */
4857 if (path_equal(where, canonical_where))
4858 return 0;
4859
4860 /* No need to mention "." or "..", they would already have been rejected by unit_name_from_path() */
4861 log_struct(LOG_ERR,
4862 "MESSAGE_ID=" SD_MESSAGE_OVERMOUNTING_STR,
4863 LOG_UNIT_ID(u),
4864 LOG_UNIT_INVOCATION_ID(u),
4865 LOG_UNIT_MESSAGE(u, "Mount path %s is not canonical (contains a symlink).", where),
4866 "WHERE=%s", where);
4867
4868 return -ELOOP;
4869 }
4870
4871 bool unit_is_pristine(Unit *u) {
4872 assert(u);
4873
4874 /* Check if the unit already exists or is already around,
4875 * in a number of different ways. Note that to cater for unit
4876 * types such as slice, we are generally fine with units that
4877 * are marked UNIT_LOADED even though nothing was actually
4878 * loaded, as those unit types don't require a file on disk. */
4879
4880 return !(!IN_SET(u->load_state, UNIT_NOT_FOUND, UNIT_LOADED) ||
4881 u->fragment_path ||
4882 u->source_path ||
4883 !strv_isempty(u->dropin_paths) ||
4884 u->job ||
4885 u->merged_into);
4886 }
4887
4888 pid_t unit_control_pid(Unit *u) {
4889 assert(u);
4890
4891 if (UNIT_VTABLE(u)->control_pid)
4892 return UNIT_VTABLE(u)->control_pid(u);
4893
4894 return 0;
4895 }
4896
4897 pid_t unit_main_pid(Unit *u) {
4898 assert(u);
4899
4900 if (UNIT_VTABLE(u)->main_pid)
4901 return UNIT_VTABLE(u)->main_pid(u);
4902
4903 return 0;
4904 }
4905
4906 static void unit_unref_uid_internal(
4907 Unit *u,
4908 uid_t *ref_uid,
4909 bool destroy_now,
4910 void (*_manager_unref_uid)(Manager *m, uid_t uid, bool destroy_now)) {
4911
4912 assert(u);
4913 assert(ref_uid);
4914 assert(_manager_unref_uid);
4915
4916 /* Generic implementation of both unit_unref_uid() and unit_unref_gid(), under the assumption that uid_t and
4917 * gid_t are actually the same time, with the same validity rules.
4918 *
4919 * Drops a reference to UID/GID from a unit. */
4920
4921 assert_cc(sizeof(uid_t) == sizeof(gid_t));
4922 assert_cc(UID_INVALID == (uid_t) GID_INVALID);
4923
4924 if (!uid_is_valid(*ref_uid))
4925 return;
4926
4927 _manager_unref_uid(u->manager, *ref_uid, destroy_now);
4928 *ref_uid = UID_INVALID;
4929 }
4930
4931 void unit_unref_uid(Unit *u, bool destroy_now) {
4932 unit_unref_uid_internal(u, &u->ref_uid, destroy_now, manager_unref_uid);
4933 }
4934
4935 void unit_unref_gid(Unit *u, bool destroy_now) {
4936 unit_unref_uid_internal(u, (uid_t*) &u->ref_gid, destroy_now, manager_unref_gid);
4937 }
4938
4939 static int unit_ref_uid_internal(
4940 Unit *u,
4941 uid_t *ref_uid,
4942 uid_t uid,
4943 bool clean_ipc,
4944 int (*_manager_ref_uid)(Manager *m, uid_t uid, bool clean_ipc)) {
4945
4946 int r;
4947
4948 assert(u);
4949 assert(ref_uid);
4950 assert(uid_is_valid(uid));
4951 assert(_manager_ref_uid);
4952
4953 /* Generic implementation of both unit_ref_uid() and unit_ref_guid(), under the assumption that uid_t and gid_t
4954 * are actually the same type, and have the same validity rules.
4955 *
4956 * Adds a reference on a specific UID/GID to this unit. Each unit referencing the same UID/GID maintains a
4957 * reference so that we can destroy the UID/GID's IPC resources as soon as this is requested and the counter
4958 * drops to zero. */
4959
4960 assert_cc(sizeof(uid_t) == sizeof(gid_t));
4961 assert_cc(UID_INVALID == (uid_t) GID_INVALID);
4962
4963 if (*ref_uid == uid)
4964 return 0;
4965
4966 if (uid_is_valid(*ref_uid)) /* Already set? */
4967 return -EBUSY;
4968
4969 r = _manager_ref_uid(u->manager, uid, clean_ipc);
4970 if (r < 0)
4971 return r;
4972
4973 *ref_uid = uid;
4974 return 1;
4975 }
4976
4977 int unit_ref_uid(Unit *u, uid_t uid, bool clean_ipc) {
4978 return unit_ref_uid_internal(u, &u->ref_uid, uid, clean_ipc, manager_ref_uid);
4979 }
4980
4981 int unit_ref_gid(Unit *u, gid_t gid, bool clean_ipc) {
4982 return unit_ref_uid_internal(u, (uid_t*) &u->ref_gid, (uid_t) gid, clean_ipc, manager_ref_gid);
4983 }
4984
4985 static int unit_ref_uid_gid_internal(Unit *u, uid_t uid, gid_t gid, bool clean_ipc) {
4986 int r = 0, q = 0;
4987
4988 assert(u);
4989
4990 /* Reference both a UID and a GID in one go. Either references both, or neither. */
4991
4992 if (uid_is_valid(uid)) {
4993 r = unit_ref_uid(u, uid, clean_ipc);
4994 if (r < 0)
4995 return r;
4996 }
4997
4998 if (gid_is_valid(gid)) {
4999 q = unit_ref_gid(u, gid, clean_ipc);
5000 if (q < 0) {
5001 if (r > 0)
5002 unit_unref_uid(u, false);
5003
5004 return q;
5005 }
5006 }
5007
5008 return r > 0 || q > 0;
5009 }
5010
5011 int unit_ref_uid_gid(Unit *u, uid_t uid, gid_t gid) {
5012 ExecContext *c;
5013 int r;
5014
5015 assert(u);
5016
5017 c = unit_get_exec_context(u);
5018
5019 r = unit_ref_uid_gid_internal(u, uid, gid, c ? c->remove_ipc : false);
5020 if (r < 0)
5021 return log_unit_warning_errno(u, r, "Couldn't add UID/GID reference to unit, proceeding without: %m");
5022
5023 return r;
5024 }
5025
5026 void unit_unref_uid_gid(Unit *u, bool destroy_now) {
5027 assert(u);
5028
5029 unit_unref_uid(u, destroy_now);
5030 unit_unref_gid(u, destroy_now);
5031 }
5032
5033 void unit_notify_user_lookup(Unit *u, uid_t uid, gid_t gid) {
5034 int r;
5035
5036 assert(u);
5037
5038 /* This is invoked whenever one of the forked off processes let's us know the UID/GID its user name/group names
5039 * resolved to. We keep track of which UID/GID is currently assigned in order to be able to destroy its IPC
5040 * objects when no service references the UID/GID anymore. */
5041
5042 r = unit_ref_uid_gid(u, uid, gid);
5043 if (r > 0)
5044 bus_unit_send_change_signal(u);
5045 }
5046
5047 int unit_set_invocation_id(Unit *u, sd_id128_t id) {
5048 int r;
5049
5050 assert(u);
5051
5052 /* Set the invocation ID for this unit. If we cannot, this will not roll back, but reset the whole thing. */
5053
5054 if (sd_id128_equal(u->invocation_id, id))
5055 return 0;
5056
5057 if (!sd_id128_is_null(u->invocation_id))
5058 (void) hashmap_remove_value(u->manager->units_by_invocation_id, &u->invocation_id, u);
5059
5060 if (sd_id128_is_null(id)) {
5061 r = 0;
5062 goto reset;
5063 }
5064
5065 r = hashmap_ensure_allocated(&u->manager->units_by_invocation_id, &id128_hash_ops);
5066 if (r < 0)
5067 goto reset;
5068
5069 u->invocation_id = id;
5070 sd_id128_to_string(id, u->invocation_id_string);
5071
5072 r = hashmap_put(u->manager->units_by_invocation_id, &u->invocation_id, u);
5073 if (r < 0)
5074 goto reset;
5075
5076 return 0;
5077
5078 reset:
5079 u->invocation_id = SD_ID128_NULL;
5080 u->invocation_id_string[0] = 0;
5081 return r;
5082 }
5083
5084 int unit_acquire_invocation_id(Unit *u) {
5085 sd_id128_t id;
5086 int r;
5087
5088 assert(u);
5089
5090 r = sd_id128_randomize(&id);
5091 if (r < 0)
5092 return log_unit_error_errno(u, r, "Failed to generate invocation ID for unit: %m");
5093
5094 r = unit_set_invocation_id(u, id);
5095 if (r < 0)
5096 return log_unit_error_errno(u, r, "Failed to set invocation ID for unit: %m");
5097
5098 return 0;
5099 }
5100
5101 void unit_set_exec_params(Unit *u, ExecParameters *p) {
5102 assert(u);
5103 assert(p);
5104
5105 /* Copy parameters from manager */
5106 p->environment = u->manager->environment;
5107 p->confirm_spawn = manager_get_confirm_spawn(u->manager);
5108 p->cgroup_supported = u->manager->cgroup_supported;
5109 p->prefix = u->manager->prefix;
5110 SET_FLAG(p->flags, EXEC_PASS_LOG_UNIT|EXEC_CHOWN_DIRECTORIES, MANAGER_IS_SYSTEM(u->manager));
5111
5112 /* Copy paramaters from unit */
5113 p->cgroup_path = u->cgroup_path;
5114 SET_FLAG(p->flags, EXEC_CGROUP_DELEGATE, unit_cgroup_delegate(u));
5115 }
5116
5117 int unit_fork_helper_process(Unit *u, const char *name, pid_t *ret) {
5118 int r;
5119
5120 assert(u);
5121 assert(ret);
5122
5123 /* Forks off a helper process and makes sure it is a member of the unit's cgroup. Returns == 0 in the child,
5124 * and > 0 in the parent. The pid parameter is always filled in with the child's PID. */
5125
5126 (void) unit_realize_cgroup(u);
5127
5128 r = safe_fork(name, FORK_REOPEN_LOG, ret);
5129 if (r != 0)
5130 return r;
5131
5132 (void) default_signals(SIGNALS_CRASH_HANDLER, SIGNALS_IGNORE, -1);
5133 (void) ignore_signals(SIGPIPE, -1);
5134
5135 (void) prctl(PR_SET_PDEATHSIG, SIGTERM);
5136
5137 if (u->cgroup_path) {
5138 r = cg_attach_everywhere(u->manager->cgroup_supported, u->cgroup_path, 0, NULL, NULL);
5139 if (r < 0) {
5140 log_unit_error_errno(u, r, "Failed to join unit cgroup %s: %m", u->cgroup_path);
5141 _exit(EXIT_CGROUP);
5142 }
5143 }
5144
5145 return 0;
5146 }
5147
5148 static void unit_update_dependency_mask(Unit *u, UnitDependency d, Unit *other, UnitDependencyInfo di) {
5149 assert(u);
5150 assert(d >= 0);
5151 assert(d < _UNIT_DEPENDENCY_MAX);
5152 assert(other);
5153
5154 if (di.origin_mask == 0 && di.destination_mask == 0) {
5155 /* No bit set anymore, let's drop the whole entry */
5156 assert_se(hashmap_remove(u->dependencies[d], other));
5157 log_unit_debug(u, "%s lost dependency %s=%s", u->id, unit_dependency_to_string(d), other->id);
5158 } else
5159 /* Mask was reduced, let's update the entry */
5160 assert_se(hashmap_update(u->dependencies[d], other, di.data) == 0);
5161 }
5162
5163 void unit_remove_dependencies(Unit *u, UnitDependencyMask mask) {
5164 UnitDependency d;
5165
5166 assert(u);
5167
5168 /* Removes all dependencies u has on other units marked for ownership by 'mask'. */
5169
5170 if (mask == 0)
5171 return;
5172
5173 for (d = 0; d < _UNIT_DEPENDENCY_MAX; d++) {
5174 bool done;
5175
5176 do {
5177 UnitDependencyInfo di;
5178 Unit *other;
5179 Iterator i;
5180
5181 done = true;
5182
5183 HASHMAP_FOREACH_KEY(di.data, other, u->dependencies[d], i) {
5184 UnitDependency q;
5185
5186 if ((di.origin_mask & ~mask) == di.origin_mask)
5187 continue;
5188 di.origin_mask &= ~mask;
5189 unit_update_dependency_mask(u, d, other, di);
5190
5191 /* We updated the dependency from our unit to the other unit now. But most dependencies
5192 * imply a reverse dependency. Hence, let's delete that one too. For that we go through
5193 * all dependency types on the other unit and delete all those which point to us and
5194 * have the right mask set. */
5195
5196 for (q = 0; q < _UNIT_DEPENDENCY_MAX; q++) {
5197 UnitDependencyInfo dj;
5198
5199 dj.data = hashmap_get(other->dependencies[q], u);
5200 if ((dj.destination_mask & ~mask) == dj.destination_mask)
5201 continue;
5202 dj.destination_mask &= ~mask;
5203
5204 unit_update_dependency_mask(other, q, u, dj);
5205 }
5206
5207 unit_add_to_gc_queue(other);
5208
5209 done = false;
5210 break;
5211 }
5212
5213 } while (!done);
5214 }
5215 }
5216
5217 static int unit_export_invocation_id(Unit *u) {
5218 const char *p;
5219 int r;
5220
5221 assert(u);
5222
5223 if (u->exported_invocation_id)
5224 return 0;
5225
5226 if (sd_id128_is_null(u->invocation_id))
5227 return 0;
5228
5229 p = strjoina("/run/systemd/units/invocation:", u->id);
5230 r = symlink_atomic(u->invocation_id_string, p);
5231 if (r < 0)
5232 return log_unit_debug_errno(u, r, "Failed to create invocation ID symlink %s: %m", p);
5233
5234 u->exported_invocation_id = true;
5235 return 0;
5236 }
5237
5238 static int unit_export_log_level_max(Unit *u, const ExecContext *c) {
5239 const char *p;
5240 char buf[2];
5241 int r;
5242
5243 assert(u);
5244 assert(c);
5245
5246 if (u->exported_log_level_max)
5247 return 0;
5248
5249 if (c->log_level_max < 0)
5250 return 0;
5251
5252 assert(c->log_level_max <= 7);
5253
5254 buf[0] = '0' + c->log_level_max;
5255 buf[1] = 0;
5256
5257 p = strjoina("/run/systemd/units/log-level-max:", u->id);
5258 r = symlink_atomic(buf, p);
5259 if (r < 0)
5260 return log_unit_debug_errno(u, r, "Failed to create maximum log level symlink %s: %m", p);
5261
5262 u->exported_log_level_max = true;
5263 return 0;
5264 }
5265
5266 static int unit_export_log_extra_fields(Unit *u, const ExecContext *c) {
5267 _cleanup_close_ int fd = -1;
5268 struct iovec *iovec;
5269 const char *p;
5270 char *pattern;
5271 le64_t *sizes;
5272 ssize_t n;
5273 size_t i;
5274 int r;
5275
5276 if (u->exported_log_extra_fields)
5277 return 0;
5278
5279 if (c->n_log_extra_fields <= 0)
5280 return 0;
5281
5282 sizes = newa(le64_t, c->n_log_extra_fields);
5283 iovec = newa(struct iovec, c->n_log_extra_fields * 2);
5284
5285 for (i = 0; i < c->n_log_extra_fields; i++) {
5286 sizes[i] = htole64(c->log_extra_fields[i].iov_len);
5287
5288 iovec[i*2] = IOVEC_MAKE(sizes + i, sizeof(le64_t));
5289 iovec[i*2+1] = c->log_extra_fields[i];
5290 }
5291
5292 p = strjoina("/run/systemd/units/log-extra-fields:", u->id);
5293 pattern = strjoina(p, ".XXXXXX");
5294
5295 fd = mkostemp_safe(pattern);
5296 if (fd < 0)
5297 return log_unit_debug_errno(u, fd, "Failed to create extra fields file %s: %m", p);
5298
5299 n = writev(fd, iovec, c->n_log_extra_fields*2);
5300 if (n < 0) {
5301 r = log_unit_debug_errno(u, errno, "Failed to write extra fields: %m");
5302 goto fail;
5303 }
5304
5305 (void) fchmod(fd, 0644);
5306
5307 if (rename(pattern, p) < 0) {
5308 r = log_unit_debug_errno(u, errno, "Failed to rename extra fields file: %m");
5309 goto fail;
5310 }
5311
5312 u->exported_log_extra_fields = true;
5313 return 0;
5314
5315 fail:
5316 (void) unlink(pattern);
5317 return r;
5318 }
5319
5320 static int unit_export_log_rate_limit_interval(Unit *u, const ExecContext *c) {
5321 _cleanup_free_ char *buf = NULL;
5322 const char *p;
5323 int r;
5324
5325 assert(u);
5326 assert(c);
5327
5328 if (u->exported_log_rate_limit_interval)
5329 return 0;
5330
5331 if (c->log_rate_limit_interval_usec == 0)
5332 return 0;
5333
5334 p = strjoina("/run/systemd/units/log-rate-limit-interval:", u->id);
5335
5336 if (asprintf(&buf, "%" PRIu64, c->log_rate_limit_interval_usec) < 0)
5337 return log_oom();
5338
5339 r = symlink_atomic(buf, p);
5340 if (r < 0)
5341 return log_unit_debug_errno(u, r, "Failed to create log rate limit interval symlink %s: %m", p);
5342
5343 u->exported_log_rate_limit_interval = true;
5344 return 0;
5345 }
5346
5347 static int unit_export_log_rate_limit_burst(Unit *u, const ExecContext *c) {
5348 _cleanup_free_ char *buf = NULL;
5349 const char *p;
5350 int r;
5351
5352 assert(u);
5353 assert(c);
5354
5355 if (u->exported_log_rate_limit_burst)
5356 return 0;
5357
5358 if (c->log_rate_limit_burst == 0)
5359 return 0;
5360
5361 p = strjoina("/run/systemd/units/log-rate-limit-burst:", u->id);
5362
5363 if (asprintf(&buf, "%u", c->log_rate_limit_burst) < 0)
5364 return log_oom();
5365
5366 r = symlink_atomic(buf, p);
5367 if (r < 0)
5368 return log_unit_debug_errno(u, r, "Failed to create log rate limit burst symlink %s: %m", p);
5369
5370 u->exported_log_rate_limit_burst = true;
5371 return 0;
5372 }
5373
5374 void unit_export_state_files(Unit *u) {
5375 const ExecContext *c;
5376
5377 assert(u);
5378
5379 if (!u->id)
5380 return;
5381
5382 if (!MANAGER_IS_SYSTEM(u->manager))
5383 return;
5384
5385 if (MANAGER_IS_TEST_RUN(u->manager))
5386 return;
5387
5388 /* Exports a couple of unit properties to /run/systemd/units/, so that journald can quickly query this data
5389 * from there. Ideally, journald would use IPC to query this, like everybody else, but that's hard, as long as
5390 * the IPC system itself and PID 1 also log to the journal.
5391 *
5392 * Note that these files really shouldn't be considered API for anyone else, as use a runtime file system as
5393 * IPC replacement is not compatible with today's world of file system namespaces. However, this doesn't really
5394 * apply to communication between the journal and systemd, as we assume that these two daemons live in the same
5395 * namespace at least.
5396 *
5397 * Note that some of the "files" exported here are actually symlinks and not regular files. Symlinks work
5398 * better for storing small bits of data, in particular as we can write them with two system calls, and read
5399 * them with one. */
5400
5401 (void) unit_export_invocation_id(u);
5402
5403 c = unit_get_exec_context(u);
5404 if (c) {
5405 (void) unit_export_log_level_max(u, c);
5406 (void) unit_export_log_extra_fields(u, c);
5407 (void) unit_export_log_rate_limit_interval(u, c);
5408 (void) unit_export_log_rate_limit_burst(u, c);
5409 }
5410 }
5411
5412 void unit_unlink_state_files(Unit *u) {
5413 const char *p;
5414
5415 assert(u);
5416
5417 if (!u->id)
5418 return;
5419
5420 if (!MANAGER_IS_SYSTEM(u->manager))
5421 return;
5422
5423 /* Undoes the effect of unit_export_state() */
5424
5425 if (u->exported_invocation_id) {
5426 p = strjoina("/run/systemd/units/invocation:", u->id);
5427 (void) unlink(p);
5428
5429 u->exported_invocation_id = false;
5430 }
5431
5432 if (u->exported_log_level_max) {
5433 p = strjoina("/run/systemd/units/log-level-max:", u->id);
5434 (void) unlink(p);
5435
5436 u->exported_log_level_max = false;
5437 }
5438
5439 if (u->exported_log_extra_fields) {
5440 p = strjoina("/run/systemd/units/extra-fields:", u->id);
5441 (void) unlink(p);
5442
5443 u->exported_log_extra_fields = false;
5444 }
5445
5446 if (u->exported_log_rate_limit_interval) {
5447 p = strjoina("/run/systemd/units/log-rate-limit-interval:", u->id);
5448 (void) unlink(p);
5449
5450 u->exported_log_rate_limit_interval = false;
5451 }
5452
5453 if (u->exported_log_rate_limit_burst) {
5454 p = strjoina("/run/systemd/units/log-rate-limit-burst:", u->id);
5455 (void) unlink(p);
5456
5457 u->exported_log_rate_limit_burst = false;
5458 }
5459 }
5460
5461 int unit_prepare_exec(Unit *u) {
5462 int r;
5463
5464 assert(u);
5465
5466 /* Prepares everything so that we can fork of a process for this unit */
5467
5468 (void) unit_realize_cgroup(u);
5469
5470 if (u->reset_accounting) {
5471 (void) unit_reset_cpu_accounting(u);
5472 (void) unit_reset_ip_accounting(u);
5473 u->reset_accounting = false;
5474 }
5475
5476 unit_export_state_files(u);
5477
5478 r = unit_setup_exec_runtime(u);
5479 if (r < 0)
5480 return r;
5481
5482 r = unit_setup_dynamic_creds(u);
5483 if (r < 0)
5484 return r;
5485
5486 return 0;
5487 }
5488
5489 static void log_leftover(pid_t pid, int sig, void *userdata) {
5490 _cleanup_free_ char *comm = NULL;
5491
5492 (void) get_process_comm(pid, &comm);
5493
5494 if (comm && comm[0] == '(') /* Most likely our own helper process (PAM?), ignore */
5495 return;
5496
5497 log_unit_warning(userdata,
5498 "Found left-over process " PID_FMT " (%s) in control group while starting unit. Ignoring.\n"
5499 "This usually indicates unclean termination of a previous run, or service implementation deficiencies.",
5500 pid, strna(comm));
5501 }
5502
5503 void unit_warn_leftover_processes(Unit *u) {
5504 assert(u);
5505
5506 (void) unit_pick_cgroup_path(u);
5507
5508 if (!u->cgroup_path)
5509 return;
5510
5511 (void) cg_kill_recursive(SYSTEMD_CGROUP_CONTROLLER, u->cgroup_path, 0, 0, NULL, log_leftover, u);
5512 }
5513
5514 bool unit_needs_console(Unit *u) {
5515 ExecContext *ec;
5516 UnitActiveState state;
5517
5518 assert(u);
5519
5520 state = unit_active_state(u);
5521
5522 if (UNIT_IS_INACTIVE_OR_FAILED(state))
5523 return false;
5524
5525 if (UNIT_VTABLE(u)->needs_console)
5526 return UNIT_VTABLE(u)->needs_console(u);
5527
5528 /* If this unit type doesn't implement this call, let's use a generic fallback implementation: */
5529 ec = unit_get_exec_context(u);
5530 if (!ec)
5531 return false;
5532
5533 return exec_context_may_touch_console(ec);
5534 }
5535
5536 const char *unit_label_path(Unit *u) {
5537 const char *p;
5538
5539 /* Returns the file system path to use for MAC access decisions, i.e. the file to read the SELinux label off
5540 * when validating access checks. */
5541
5542 p = u->source_path ?: u->fragment_path;
5543 if (!p)
5544 return NULL;
5545
5546 /* If a unit is masked, then don't read the SELinux label of /dev/null, as that really makes no sense */
5547 if (path_equal(p, "/dev/null"))
5548 return NULL;
5549
5550 return p;
5551 }
5552
5553 int unit_pid_attachable(Unit *u, pid_t pid, sd_bus_error *error) {
5554 int r;
5555
5556 assert(u);
5557
5558 /* Checks whether the specified PID is generally good for attaching, i.e. a valid PID, not our manager itself,
5559 * and not a kernel thread either */
5560
5561 /* First, a simple range check */
5562 if (!pid_is_valid(pid))
5563 return sd_bus_error_setf(error, SD_BUS_ERROR_INVALID_ARGS, "Process identifier " PID_FMT " is not valid.", pid);
5564
5565 /* Some extra safety check */
5566 if (pid == 1 || pid == getpid_cached())
5567 return sd_bus_error_setf(error, SD_BUS_ERROR_INVALID_ARGS, "Process " PID_FMT " is a manager process, refusing.", pid);
5568
5569 /* Don't even begin to bother with kernel threads */
5570 r = is_kernel_thread(pid);
5571 if (r == -ESRCH)
5572 return sd_bus_error_setf(error, SD_BUS_ERROR_UNIX_PROCESS_ID_UNKNOWN, "Process with ID " PID_FMT " does not exist.", pid);
5573 if (r < 0)
5574 return sd_bus_error_set_errnof(error, r, "Failed to determine whether process " PID_FMT " is a kernel thread: %m", pid);
5575 if (r > 0)
5576 return sd_bus_error_setf(error, SD_BUS_ERROR_INVALID_ARGS, "Process " PID_FMT " is a kernel thread, refusing.", pid);
5577
5578 return 0;
5579 }
5580
5581 static const char* const collect_mode_table[_COLLECT_MODE_MAX] = {
5582 [COLLECT_INACTIVE] = "inactive",
5583 [COLLECT_INACTIVE_OR_FAILED] = "inactive-or-failed",
5584 };
5585
5586 DEFINE_STRING_TABLE_LOOKUP(collect_mode, CollectMode);