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