main.c revision ecee72e1b6c3476b674b58472c483fc4aef7ceed
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering This file is part of systemd.
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering Copyright 2010 Lennart Poettering
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering systemd is free software; you can redistribute it and/or modify it
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering under the terms of the GNU Lesser General Public License as published by
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering the Free Software Foundation; either version 2.1 of the License, or
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering (at your option) any later version.
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering systemd is distributed in the hope that it will be useful, but
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering WITHOUT ANY WARRANTY; without even the implied warranty of
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering Lesser General Public License for more details.
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering You should have received a copy of the GNU Lesser General Public License
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering along with systemd; If not, see <http://www.gnu.org/licenses/>.
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic ManagerRunningAs arg_running_as = _MANAGER_RUNNING_AS_INVALID;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic bool arg_dump_core = true;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic bool arg_crash_shell = false;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic bool arg_crash_reboot = false;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic bool arg_confirm_spawn = false;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic ShowStatus arg_show_status = _SHOW_STATUS_UNSET;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic bool arg_switched_root = false;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic char ***arg_join_controllers = NULL;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic ExecOutput arg_default_std_output = EXEC_OUTPUT_JOURNAL;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic ExecOutput arg_default_std_error = EXEC_OUTPUT_INHERIT;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic usec_t arg_default_restart_usec = DEFAULT_RESTART_USEC;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic usec_t arg_default_timeout_start_usec = DEFAULT_TIMEOUT_USEC;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic usec_t arg_default_timeout_stop_usec = DEFAULT_TIMEOUT_USEC;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic usec_t arg_default_start_limit_interval = DEFAULT_START_LIMIT_INTERVAL;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic unsigned arg_default_start_limit_burst = DEFAULT_START_LIMIT_BURST;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic usec_t arg_shutdown_watchdog = 10 * USEC_PER_MINUTE;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic char **arg_default_environment = NULL;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic struct rlimit *arg_default_rlimit[_RLIMIT_MAX] = {};
4a62c710b62a5a3c7a8a278b810b9d5b5a0c8f4fMichal Schmidtstatic uint64_t arg_capability_bounding_set_drop = 0;
4a62c710b62a5a3c7a8a278b810b9d5b5a0c8f4fMichal Schmidtstatic nsec_t arg_timer_slack_nsec = NSEC_INFINITY;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic usec_t arg_default_timer_accuracy_usec = 1 * USEC_PER_MINUTE;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic bool arg_default_cpu_accounting = false;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic bool arg_default_blockio_accounting = false;
c3834f9b881f2b1a68dc7d797c134f0b66b47b57Lennart Poetteringstatic bool arg_default_memory_accounting = false;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic bool arg_default_tasks_accounting = false;
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poetteringstatic void pager_open_if_enabled(void) {
cca1dfddd4ce4357113663532696488427cc54e4Lennart Poetteringnoreturn static void freeze_or_reboot(void) {
4a62c710b62a5a3c7a8a278b810b9d5b5a0c8f4fMichal Schmidt log_emergency_errno(errno, "Failed to reboot: %m");
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poettering /* Pass this on immediately, if this is not PID 1 */
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poettering log_emergency("Caught <%s>, not dumping core.", signal_to_string(sig));
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poettering /* We want to wait for the core process, hence let's enable SIGCHLD */
4a62c710b62a5a3c7a8a278b810b9d5b5a0c8f4fMichal Schmidt log_emergency_errno(errno, "Caught <%s>, cannot fork for core dump: %m", signal_to_string(sig));
4a62c710b62a5a3c7a8a278b810b9d5b5a0c8f4fMichal Schmidt else if (pid == 0) {
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poettering /* Enable default signal handler for core dump */
23bbb0de4e3f85d9704a5c12a5afa2dfa0159e41Michal Schmidt /* Don't limit the core dump size */
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poettering /* Just to be sure... */
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poettering /* Raise the signal again */
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poettering (void) kill(pid, sig); /* raise() would kill the parent */
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poettering assert_not_reached("We shouldn't be here...");
cca1dfddd4ce4357113663532696488427cc54e4Lennart Poettering /* Order things nicely. */
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering log_emergency_errno(r, "Caught <%s>, waitpid() failed: %m", signal_to_string(sig));
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_emergency("Caught <%s>, core dump failed (child "PID_FMT", code=%s, status=%i/%s).",
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering pid, sigchld_code_to_string(status.si_code),
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poettering ? exit_status_to_string(status.si_status, EXIT_STATUS_FULL)
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering log_emergency("Caught <%s>, dumped core as pid "PID_FMT".", signal_to_string(sig), pid);
1af7211984a8dba3c5ba40fae794c4c55f5e6bd3Lennart Poettering .sa_flags = SA_NOCLDSTOP|SA_NOCLDWAIT|SA_RESTART,
e48fdd84432bbf9c2ecc339183258c7c33116032Lennart Poettering /* Let the kernel reap children for us */
e48fdd84432bbf9c2ecc339183258c7c33116032Lennart Poettering log_notice("Executing crash shell in 10s...");
4a62c710b62a5a3c7a8a278b810b9d5b5a0c8f4fMichal Schmidt log_emergency_errno(errno, "Failed to fork off crash shell: %m");
4a62c710b62a5a3c7a8a278b810b9d5b5a0c8f4fMichal Schmidt else if (pid == 0) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering (void) execle("/bin/sh", "/bin/sh", NULL, environ);
c3834f9b881f2b1a68dc7d797c134f0b66b47b57Lennart Poettering log_emergency_errno(errno, "execle() failed: %m");
e48fdd84432bbf9c2ecc339183258c7c33116032Lennart Poettering log_info("Spawned crash shell as PID "PID_FMT".", pid);
e48fdd84432bbf9c2ecc339183258c7c33116032Lennart Poetteringstatic void install_crash_handler(void) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering .sa_flags = SA_NODEFER, /* So that we can raise the signal again from the signal handler */
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering /* We ignore the return value here, since, we don't mind if we
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering * cannot set up a crash handler */
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering r = sigaction_many(&sa, SIGNALS_CRASH_HANDLER, -1);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_debug_errno(r, "I had trouble setting up the crash handler, ignoring: %m");
4a62c710b62a5a3c7a8a278b810b9d5b5a0c8f4fMichal Schmidtstatic int console_setup(void) {
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering tty_fd = open_terminal("/dev/console", O_WRONLY|O_NOCTTY|O_CLOEXEC);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering return log_error_errno(tty_fd, "Failed to open /dev/console: %m");
4a62c710b62a5a3c7a8a278b810b9d5b5a0c8f4fMichal Schmidt /* We don't want to force text mode. plymouth may be showing
4a62c710b62a5a3c7a8a278b810b9d5b5a0c8f4fMichal Schmidt * pictures already from initrd. */
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering return log_error_errno(r, "Failed to reset /dev/console: %m");
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poetteringstatic int parse_crash_chvt(const char *value) {
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering if (safe_atoi(value, &arg_crash_chvt) >= 0)
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering arg_crash_chvt = 0; /* switch to where kmsg goes */
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering arg_crash_chvt = -1; /* turn off switching */
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poetteringstatic int parse_proc_cmdline_item(const char *key, const char *value) {
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering if (streq(key, "systemd.unit") && value) {
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering return free_and_strdup(&arg_default_unit, value);
56f64d95763a799ba4475daf44d8e9f72a1bd474Michal Schmidt } else if (streq(key, "rd.systemd.unit") && value) {
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering return free_and_strdup(&arg_default_unit, value);
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering } else if (streq(key, "systemd.dump_core") && value) {
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering log_warning("Failed to parse dump core switch %s. Ignoring.", value);
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering } else if (streq(key, "systemd.crash_chvt") && value) {
a0b1209c4a59754f428894e0485413542da50014Zbigniew Jędrzejewski-Szmek if (parse_crash_chvt(value) < 0)
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering log_warning("Failed to parse crash chvt switch %s. Ignoring.", value);
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering } else if (streq(key, "systemd.crash_shell") && value) {
cca1dfddd4ce4357113663532696488427cc54e4Lennart Poettering log_warning("Failed to parse crash shell switch %s. Ignoring.", value);
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering } else if (streq(key, "systemd.crash_reboot") && value) {
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek log_warning("Failed to parse crash reboot switch %s. Ignoring.", value);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering } else if (streq(key, "systemd.confirm_spawn") && value) {
cca1dfddd4ce4357113663532696488427cc54e4Lennart Poettering log_warning("Failed to parse confirm spawn switch %s. Ignoring.", value);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering } else if (streq(key, "systemd.show_status") && value) {
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering r = parse_show_status(value, &arg_show_status);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse show status switch %s. Ignoring.", value);
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek } else if (streq(key, "systemd.default_standard_output") && value) {
d2a623823f8d83c97c35fcd28f90e8cd59066f8aZbigniew Jędrzejewski-Szmek log_warning("Failed to parse default standard output switch %s. Ignoring.", value);
d2a623823f8d83c97c35fcd28f90e8cd59066f8aZbigniew Jędrzejewski-Szmek } else if (streq(key, "systemd.default_standard_error") && value) {
d2a623823f8d83c97c35fcd28f90e8cd59066f8aZbigniew Jędrzejewski-Szmek r = exec_output_from_string(value);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse default standard error switch %s. Ignoring.", value);
fa041593fe04b12ffd7e81d8b3598a7a6f313fb3Lennart Poettering } else if (streq(key, "systemd.setenv") && value) {
d2a623823f8d83c97c35fcd28f90e8cd59066f8aZbigniew Jędrzejewski-Szmek env = strv_env_set(arg_default_environment, value);
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering log_warning_errno(ENOMEM, "Setting environment variable '%s' failed, ignoring: %m", value);
d2a623823f8d83c97c35fcd28f90e8cd59066f8aZbigniew Jędrzejewski-Szmek log_warning("Environment variable name '%s' is not valid. Ignoring.", value);
fa041593fe04b12ffd7e81d8b3598a7a6f313fb3Lennart Poettering } else if (streq(key, "quiet") && !value) {
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering if (arg_show_status == _SHOW_STATUS_UNSET)
d2a623823f8d83c97c35fcd28f90e8cd59066f8aZbigniew Jędrzejewski-Szmek } else if (streq(key, "debug") && !value) {
fa041593fe04b12ffd7e81d8b3598a7a6f313fb3Lennart Poettering /* Note that log_parse_environment() handles 'debug'
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering * too, and sets the log level to LOG_DEBUG. */
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering /* SysV compatibility */
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering return free_and_strdup(&arg_default_unit, target);
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering#define DEFINE_SETTER(name, func, descr) \
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering const char *rvalue, \
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering log_syntax(unit, LOG_ERR, filename, line, r, \
d2a623823f8d83c97c35fcd28f90e8cd59066f8aZbigniew Jędrzejewski-SzmekDEFINE_SETTER(config_parse_level2, log_set_max_level_from_string, "log level")
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart PoetteringDEFINE_SETTER(config_parse_target, log_set_target_from_string, "target")
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart PoetteringDEFINE_SETTER(config_parse_color, log_show_color_from_string, "color" )
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart PoetteringDEFINE_SETTER(config_parse_location, log_show_location_from_string, "location")
d2a623823f8d83c97c35fcd28f90e8cd59066f8aZbigniew Jędrzejewski-Szmek _cleanup_cpu_free_ cpu_set_t *c = NULL;
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering ncpus = parse_cpu_set_and_warn(rvalue, &c, unit, filename, line, lvalue);
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering if (sched_setaffinity(0, CPU_ALLOC_SIZE(ncpus), c) < 0)
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering log_warning("Failed to set CPU affinity: %m");
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmekstatic int config_parse_show_status(
cca1dfddd4ce4357113663532696488427cc54e4Lennart Poettering log_syntax(unit, LOG_ERR, filename, line, k, "Failed to parse show status setting, ignoring: %s", rvalue);
e48fdd84432bbf9c2ecc339183258c7c33116032Lennart Poettering log_syntax(unit, LOG_ERR, filename, line, r, "Failed to parse CrashChangeVT= setting, ignoring: %s", rvalue);
e48fdd84432bbf9c2ecc339183258c7c33116032Lennart Poetteringstatic int config_parse_join_controllers(const char *unit,
e48fdd84432bbf9c2ecc339183258c7c33116032Lennart Poettering unsigned n = 0;
d736e4f3e76daca4ab1b1fc444737e5ee20a27cdMathieu Chevrier arg_join_controllers = strv_free_free(arg_join_controllers);
cca1dfddd4ce4357113663532696488427cc54e4Lennart Poettering r = extract_first_word(&rvalue, &word, WHITESPACE, EXTRACT_QUOTES);
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering log_syntax(unit, LOG_ERR, filename, line, r, "Invalid value for %s: %s", lvalue, whole_rvalue);
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering for (a = arg_join_controllers; *a; a++) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering if (strv_extend_strv(&l, *a, false) < 0) {
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering log_syntax(unit, LOG_ERR, filename, line, 0, "Trailing garbage, ignoring.");
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poetteringstatic int parse_config_file(void) {
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "LogLevel", config_parse_level2, 0, NULL },
23bbb0de4e3f85d9704a5c12a5afa2dfa0159e41Michal Schmidt { "Manager", "LogTarget", config_parse_target, 0, NULL },
23bbb0de4e3f85d9704a5c12a5afa2dfa0159e41Michal Schmidt { "Manager", "LogColor", config_parse_color, 0, NULL },
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering { "Manager", "LogLocation", config_parse_location, 0, NULL },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DumpCore", config_parse_bool, 0, &arg_dump_core },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "CrashChVT", /* legacy */ config_parse_crash_chvt, 0, NULL },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "CrashChangeVT", config_parse_crash_chvt, 0, NULL },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "CrashShell", config_parse_bool, 0, &arg_crash_shell },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "CrashReboot", config_parse_bool, 0, &arg_crash_reboot },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "ShowStatus", config_parse_show_status, 0, &arg_show_status },
98b2f766b24c84fc49a4df954717b1f96bbce00dLennart Poettering { "Manager", "CPUAffinity", config_parse_cpu_affinity2, 0, NULL },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "JoinControllers", config_parse_join_controllers, 0, &arg_join_controllers },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "RuntimeWatchdogSec", config_parse_sec, 0, &arg_runtime_watchdog },
cca1dfddd4ce4357113663532696488427cc54e4Lennart Poettering { "Manager", "ShutdownWatchdogSec", config_parse_sec, 0, &arg_shutdown_watchdog },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "CapabilityBoundingSet", config_parse_bounding_set, 0, &arg_capability_bounding_set_drop },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "SystemCallArchitectures", config_parse_syscall_archs, 0, &arg_syscall_archs },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "TimerSlackNSec", config_parse_nsec, 0, &arg_timer_slack_nsec },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultTimerAccuracySec", config_parse_sec, 0, &arg_default_timer_accuracy_usec },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultStandardOutput", config_parse_output, 0, &arg_default_std_output },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultStandardError", config_parse_output, 0, &arg_default_std_error },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultTimeoutStartSec", config_parse_sec, 0, &arg_default_timeout_start_usec },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultTimeoutStopSec", config_parse_sec, 0, &arg_default_timeout_stop_usec },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultRestartSec", config_parse_sec, 0, &arg_default_restart_usec },
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering { "Manager", "DefaultStartLimitInterval", config_parse_sec, 0, &arg_default_start_limit_interval },
23bbb0de4e3f85d9704a5c12a5afa2dfa0159e41Michal Schmidt { "Manager", "DefaultStartLimitBurst", config_parse_unsigned, 0, &arg_default_start_limit_burst },
23bbb0de4e3f85d9704a5c12a5afa2dfa0159e41Michal Schmidt { "Manager", "DefaultEnvironment", config_parse_environ, 0, &arg_default_environment },
23bbb0de4e3f85d9704a5c12a5afa2dfa0159e41Michal Schmidt { "Manager", "DefaultLimitCPU", config_parse_sec_limit, 0, &arg_default_rlimit[RLIMIT_CPU] },
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering { "Manager", "DefaultLimitFSIZE", config_parse_bytes_limit, 0, &arg_default_rlimit[RLIMIT_FSIZE] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultLimitDATA", config_parse_bytes_limit, 0, &arg_default_rlimit[RLIMIT_DATA] },
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering { "Manager", "DefaultLimitSTACK", config_parse_bytes_limit, 0, &arg_default_rlimit[RLIMIT_STACK] },
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering { "Manager", "DefaultLimitCORE", config_parse_bytes_limit, 0, &arg_default_rlimit[RLIMIT_CORE] },
61331eab0a53cd9b8446eab6d1ebf1a046d8efc1Lennart Poettering { "Manager", "DefaultLimitRSS", config_parse_bytes_limit, 0, &arg_default_rlimit[RLIMIT_RSS] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultLimitNOFILE", config_parse_limit, 0, &arg_default_rlimit[RLIMIT_NOFILE] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultLimitAS", config_parse_bytes_limit, 0, &arg_default_rlimit[RLIMIT_AS] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultLimitNPROC", config_parse_limit, 0, &arg_default_rlimit[RLIMIT_NPROC] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultLimitMEMLOCK", config_parse_bytes_limit, 0, &arg_default_rlimit[RLIMIT_MEMLOCK] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultLimitLOCKS", config_parse_limit, 0, &arg_default_rlimit[RLIMIT_LOCKS] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultLimitSIGPENDING", config_parse_limit, 0, &arg_default_rlimit[RLIMIT_SIGPENDING] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultLimitMSGQUEUE", config_parse_bytes_limit, 0, &arg_default_rlimit[RLIMIT_MSGQUEUE] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultLimitNICE", config_parse_limit, 0, &arg_default_rlimit[RLIMIT_NICE] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultLimitRTPRIO", config_parse_limit, 0, &arg_default_rlimit[RLIMIT_RTPRIO] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultLimitRTTIME", config_parse_usec_limit, 0, &arg_default_rlimit[RLIMIT_RTTIME] },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultCPUAccounting", config_parse_bool, 0, &arg_default_cpu_accounting },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultBlockIOAccounting", config_parse_bool, 0, &arg_default_blockio_accounting },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultMemoryAccounting", config_parse_bool, 0, &arg_default_memory_accounting },
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering { "Manager", "DefaultTasksAccounting", config_parse_bool, 0, &arg_default_tasks_accounting },
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering conf_dirs_nulstr = arg_running_as == MANAGER_SYSTEM ?
b5884878a2874447b2a9f07f324a7cd909d96d48Lennart Poettering CONF_PATHS_NULSTR("systemd/system.conf.d") :
b5884878a2874447b2a9f07f324a7cd909d96d48Lennart Poettering CONF_PATHS_NULSTR("systemd/user.conf.d");
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering config_parse_many(fn, conf_dirs_nulstr, "Manager\0",
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering config_item_table_lookup, items, false, NULL);
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poetteringstatic void manager_set_defaults(Manager *m) {
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering m->default_timer_accuracy_usec = arg_default_timer_accuracy_usec;
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering m->default_std_output = arg_default_std_output;
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering m->default_std_error = arg_default_std_error;
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering m->default_timeout_start_usec = arg_default_timeout_start_usec;
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering m->default_timeout_stop_usec = arg_default_timeout_stop_usec;
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering m->default_restart_usec = arg_default_restart_usec;
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering m->default_start_limit_interval = arg_default_start_limit_interval;
73b80ec2d999c45ce13f3e034704249d80829f7eLennart Poettering m->default_start_limit_burst = arg_default_start_limit_burst;
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering m->default_cpu_accounting = arg_default_cpu_accounting;
opterr = 0;
case ARG_LOG_LEVEL:
case ARG_LOG_TARGET:
case ARG_LOG_COLOR:
if (optarg) {
log_show_color(true);
case ARG_LOG_LOCATION:
if (optarg) {
log_show_location(true);
case ARG_DEFAULT_STD_OUTPUT:
case ARG_DEFAULT_STD_ERROR:
case ARG_UNIT:
case ARG_SYSTEM:
case ARG_USER:
case ARG_TEST:
if (arg_no_pager < 0)
arg_no_pager = true;
case ARG_NO_PAGER:
arg_no_pager = true;
case ARG_VERSION:
case ARG_DUMP_CORE:
if (!optarg)
arg_dump_core = true;
arg_dump_core = r;
case ARG_CRASH_CHVT:
case ARG_CRASH_SHELL:
if (!optarg)
arg_crash_shell = true;
arg_crash_shell = r;
case ARG_CRASH_REBOOT:
if (!optarg)
arg_crash_reboot = true;
arg_crash_reboot = r;
case ARG_CONFIRM_SPAWN:
arg_confirm_spawn = r;
case ARG_SHOW_STATUS:
if (optarg) {
case ARG_DESERIALIZE: {
int fd;
FILE *f;
if (r < 0 || fd < 0) {
return -EINVAL;
arg_serialization = f;
case ARG_SWITCHED_ROOT:
arg_switched_root = true;
if (arg_no_pager < 0)
arg_no_pager = true;
return -EINVAL;
return -EINVAL;
static int help(void) {
assert(m);
r = manager_open_serialization(m, &f);
m->n_reloading ++;
bus_manager_send_reloading(m, true);
if (!fds)
return log_oom();
*_f = f;
f = NULL;
if (!rl)
return log_oom();
static void test_usr(void) {
log_warning("/usr appears to be on its own filesystem and is not already mounted. This is not a supported setup. "
"Consult http://freedesktop.org/wiki/Software/systemd/separate-usr-is-broken for more information.");
static int initialize_join_controllers(void) {
if (!arg_join_controllers)
return -ENOMEM;
if (!arg_join_controllers[0])
goto oom;
goto oom;
oom:
return -ENOMEM;
#ifdef HAVE_SECCOMP
Iterator i;
void *id;
if (!seccomp)
return log_oom();
if (r == -EEXIST)
goto finish;
goto finish;
static int status_welcome(void) {
NULL);
if (r == -ENOENT)
NULL);
if (r < 0 && r != -ENOENT)
static int write_container_id(void) {
if (isempty(c))
static int bump_unix_max_dgram_qlen(void) {
if (v >= DEFAULT_UNIX_MAX_DGRAM_QLEN)
return log_oom();
bool reexecute = false;
bool skip_setup = false;
bool loaded_policy = false;
bool arm_reboot_watchdog = false;
bool queue_default_job = false;
bool empty_etc = false;
#ifdef HAVE_SYSV_COMPAT
skip_setup = true;
skip_setup = false;
umask(0);
log_open();
if (in_initrd())
if (!skip_setup) {
goto finish;
} else if (ima_setup() < 0) {
goto finish;
goto finish;
goto finish;
if (!skip_setup) {
if (clock_is_localtime() > 0) {
int min;
} else if (!in_initrd()) {
log_open();
log_open();
goto finish;
r = initialize_join_controllers();
goto finish;
if (!skip_setup)
kmod_setup();
goto finish;
(void) reset_all_signal_handlers();
if (parse_config_file() < 0) {
goto finish;
goto finish;
geteuid() == 0) {
goto finish;
sd_booted() <= 0) {
goto finish;
running_in_chroot() > 0) {
goto finish;
skip_setup = true;
goto finish;
goto finish;
goto finish;
goto finish;
goto finish;
log_close();
goto finish;
if (arg_serialization)
setsid();
log_open();
goto finish;
v = detect_virtualization();
if (in_initrd())
* /etc/machine-id as flag file. This allows container
if (empty_etc)
_cleanup_free_ char *t;
if (arg_show_status > 0)
test_usr();
goto finish;
goto finish;
if (arg_syscall_archs) {
goto finish;
if (empty_etc) {
r = unit_file_preset_all(UNIT_FILE_SYSTEM, false, NULL, UNIT_FILE_PRESET_ENABLE_ONLY, false, NULL, 0);
goto finish;
if (queue_default_job) {
goto finish;
goto finish;
goto finish;
if (r == -EPERM) {
log_debug("Default target could not be isolated, starting instead: %s", bus_error_message(&error, r));
goto finish;
goto finish;
goto finish;
r = manager_loop(m);
goto finish;
switch (m->exit_code) {
case MANAGER_RELOAD:
r = parse_config_file();
r = manager_reload(m);
case MANAGER_REEXECUTE:
goto finish;
reexecute = true;
goto finish;
case MANAGER_SWITCH_ROOT:
if (!switch_root_init)
goto finish;
reexecute = true;
goto finish;
case MANAGER_EXIT:
goto finish;
case MANAGER_REBOOT:
case MANAGER_POWEROFF:
case MANAGER_HALT:
case MANAGER_KEXEC: {
goto finish;
pager_close();
m = manager_free(m);
if (reexecute) {
const char **args;
unsigned i, args_size;
watchdog_close(true);
if (switch_root_dir) {
if (!switch_root_init) {
if (switch_root_dir)
if (switch_root_dir)
(void) clearenv();
(void) make_console_stdio();
(void) reset_all_signal_handlers();
(void) reset_signal_mask();
if (switch_root_init) {
#ifdef HAVE_VALGRIND_VALGRIND_H
if (shutdown_verb) {
switch (log_get_target()) {
case LOG_TARGET_KMSG:
case LOG_TARGET_NULL:
case LOG_TARGET_CONSOLE:
if (log_get_show_color())
if (log_get_show_location())
watchdog_close(r < 0);
watchdog_close(true);
if (detect_container() <= 0)
if (error_message)
return retval;