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