]>
Commit | Line | Data |
---|---|---|
db9ecf05 | 1 | /* SPDX-License-Identifier: LGPL-2.1-or-later */ |
c2f1db8f | 2 | #pragma once |
514f4ef5 | 3 | |
514f4ef5 | 4 | #define SPECIAL_DEFAULT_TARGET "default.target" |
8755dbad | 5 | #define SPECIAL_INITRD_TARGET "initrd.target" |
514f4ef5 | 6 | |
f1dd0c3f LP |
7 | /* Shutdown targets */ |
8 | #define SPECIAL_UMOUNT_TARGET "umount.target" | |
514f4ef5 LP |
9 | /* This is not really intended to be started by directly. This is |
10 | * mostly so that other targets (reboot/halt/poweroff) can depend on | |
11 | * it to bring all services down that want to be brought down on | |
12 | * system shutdown. */ | |
13 | #define SPECIAL_SHUTDOWN_TARGET "shutdown.target" | |
177b3ffe LP |
14 | #define SPECIAL_HALT_TARGET "halt.target" |
15 | #define SPECIAL_POWEROFF_TARGET "poweroff.target" | |
16 | #define SPECIAL_REBOOT_TARGET "reboot.target" | |
17 | #define SPECIAL_KEXEC_TARGET "kexec.target" | |
18 | #define SPECIAL_EXIT_TARGET "exit.target" | |
6edd7d0a LP |
19 | #define SPECIAL_SUSPEND_TARGET "suspend.target" |
20 | #define SPECIAL_HIBERNATE_TARGET "hibernate.target" | |
6524990f | 21 | #define SPECIAL_HYBRID_SLEEP_TARGET "hybrid-sleep.target" |
e68c79db | 22 | #define SPECIAL_SUSPEND_THEN_HIBERNATE_TARGET "suspend-then-hibernate.target" |
514f4ef5 | 23 | |
f1dd0c3f | 24 | /* Special boot targets */ |
177b3ffe LP |
25 | #define SPECIAL_RESCUE_TARGET "rescue.target" |
26 | #define SPECIAL_EMERGENCY_TARGET "emergency.target" | |
d5d8429a LP |
27 | #define SPECIAL_MULTI_USER_TARGET "multi-user.target" |
28 | #define SPECIAL_GRAPHICAL_TARGET "graphical.target" | |
514f4ef5 | 29 | |
f1dd0c3f | 30 | /* Early boot targets */ |
177b3ffe LP |
31 | #define SPECIAL_SYSINIT_TARGET "sysinit.target" |
32 | #define SPECIAL_SOCKETS_TARGET "sockets.target" | |
e3d84721 LP |
33 | #define SPECIAL_TIMERS_TARGET "timers.target" |
34 | #define SPECIAL_PATHS_TARGET "paths.target" | |
5d4caf56 | 35 | #define SPECIAL_LOCAL_FS_TARGET "local-fs.target" |
21e557ed | 36 | #define SPECIAL_LOCAL_FS_PRE_TARGET "local-fs-pre.target" |
700e07ff | 37 | #define SPECIAL_INITRD_FS_TARGET "initrd-fs.target" |
7163e1ca | 38 | #define SPECIAL_INITRD_ROOT_DEVICE_TARGET "initrd-root-device.target" |
9e5f0f92 | 39 | #define SPECIAL_INITRD_ROOT_FS_TARGET "initrd-root-fs.target" |
514f4ef5 | 40 | #define SPECIAL_REMOTE_FS_TARGET "remote-fs.target" /* LSB's $remote_fs */ |
21e557ed | 41 | #define SPECIAL_REMOTE_FS_PRE_TARGET "remote-fs-pre.target" |
514f4ef5 | 42 | #define SPECIAL_SWAP_TARGET "swap.target" |
0c17fbce | 43 | #define SPECIAL_NETWORK_ONLINE_TARGET "network-online.target" |
19f8d037 | 44 | #define SPECIAL_TIME_SYNC_TARGET "time-sync.target" /* LSB's $time */ |
177b3ffe LP |
45 | #define SPECIAL_BASIC_TARGET "basic.target" |
46 | ||
f1dd0c3f | 47 | /* LSB compatibility */ |
514f4ef5 LP |
48 | #define SPECIAL_NETWORK_TARGET "network.target" /* LSB's $network */ |
49 | #define SPECIAL_NSS_LOOKUP_TARGET "nss-lookup.target" /* LSB's $named */ | |
50 | #define SPECIAL_RPCBIND_TARGET "rpcbind.target" /* LSB's $portmap */ | |
669b04a4 LP |
51 | |
52 | /* | |
53 | * Rules regarding adding further high level targets like the above: | |
54 | * | |
55 | * - Be conservative, only add more of these when we really need | |
56 | * them. We need strong usecases for further additions. | |
57 | * | |
58 | * - When there can be multiple implementations running side-by-side, | |
59 | * it needs to be a .target unit which can pull in all | |
60 | * implementations. | |
61 | * | |
62 | * - If something can be implemented with socket activation, and | |
63 | * without, it needs to be a .target unit, so that it can pull in | |
64 | * the appropriate unit. | |
65 | * | |
66 | * - Otherwise, it should be a .service unit. | |
67 | * | |
68 | * - In some cases it is OK to have both a .service and a .target | |
69 | * unit, i.e. if there can be multiple parallel implementations, but | |
70 | * only one is the "system" one. Example: syslog. | |
71 | * | |
72 | * Or to put this in other words: .service symlinks can be used to | |
73 | * arbitrate between multiple implementations if there can be only one | |
74 | * of a kind. .target units can be used to support multiple | |
75 | * implementations that can run side-by-side. | |
76 | */ | |
177b3ffe | 77 | |
f1dd0c3f | 78 | /* Magic early boot services */ |
93a1d735 | 79 | #define SPECIAL_FSCK_SERVICE "systemd-fsck@.service" |
5ff8da10 | 80 | #define SPECIAL_FSCK_ROOT_SERVICE "systemd-fsck-root.service" |
93a1d735 | 81 | #define SPECIAL_QUOTACHECK_SERVICE "systemd-quotacheck.service" |
0c380104 | 82 | #define SPECIAL_QUOTAON_SERVICE "quotaon.service" |
2b93b027 | 83 | #define SPECIAL_REMOUNT_FS_SERVICE "systemd-remount-fs.service" |
312da637 | 84 | #define SPECIAL_VOLATILE_ROOT_SERVICE "systemd-volatile-root.service" |
33b58dfb | 85 | #define SPECIAL_UDEVD_SERVICE "systemd-udevd.service" |
177b3ffe | 86 | |
f1dd0c3f | 87 | /* Services systemd relies on */ |
514f4ef5 | 88 | #define SPECIAL_DBUS_SERVICE "dbus.service" |
8f6df3fa | 89 | #define SPECIAL_DBUS_SOCKET "dbus.socket" |
64f5002a | 90 | #define SPECIAL_JOURNALD_SOCKET "systemd-journald.socket" |
731a676c | 91 | #define SPECIAL_JOURNALD_SERVICE "systemd-journald.service" |
d71f0505 | 92 | #define SPECIAL_TMPFILES_SETUP_SERVICE "systemd-tmpfiles-setup.service" |
177b3ffe | 93 | |
f1dd0c3f | 94 | /* Magic init signals */ |
177b3ffe LP |
95 | #define SPECIAL_KBREQUEST_TARGET "kbrequest.target" |
96 | #define SPECIAL_SIGPWR_TARGET "sigpwr.target" | |
97 | #define SPECIAL_CTRL_ALT_DEL_TARGET "ctrl-alt-del.target" | |
514f4ef5 | 98 | |
9444b1f2 | 99 | /* Where we add all our system units, users and machines by default */ |
a016b922 | 100 | #define SPECIAL_SYSTEM_SLICE "system.slice" |
9444b1f2 LP |
101 | #define SPECIAL_USER_SLICE "user.slice" |
102 | #define SPECIAL_MACHINE_SLICE "machine.slice" | |
4ad49000 | 103 | #define SPECIAL_ROOT_SLICE "-.slice" |
efdb0237 LP |
104 | |
105 | /* The scope unit systemd itself lives in. */ | |
106 | #define SPECIAL_INIT_SCOPE "init.scope" | |
11222d0f LP |
107 | |
108 | /* The root directory. */ | |
109 | #define SPECIAL_ROOT_MOUNT "-.mount" | |
0b432bdc BB |
110 | |
111 | /* Special slices valid for the user instance */ | |
112 | #define SPECIAL_SESSION_SLICE "session.slice" | |
113 | #define SPECIAL_APP_SLICE "app.slice" | |
114 | #define SPECIAL_BACKGROUND_SLICE "background.slice" |