main.c revision 21bf2ab082b42f03df5b4685df2fddc4d6e0d572
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/>.
7384146530ac083efbef62b9ef5bb82c56565cd4Zbigniew Jędrzejewski-Szmek ACTION_DUMP_CONFIGURATION_ITEMS,
7384146530ac083efbef62b9ef5bb82c56565cd4Zbigniew Jędrzejewski-Szmekstatic char *arg_default_unit = NULL;
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poetteringstatic SystemdRunningAs arg_running_as = _SYSTEMD_RUNNING_AS_INVALID;
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poetteringstatic bool arg_dump_core = true;
7384146530ac083efbef62b9ef5bb82c56565cd4Zbigniew Jędrzejewski-Szmekstatic bool arg_crash_shell = false;
091526ab20485492124852dcf629787f35816df8Zbigniew Jędrzejewski-Szmekstatic bool arg_confirm_spawn = false;
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poetteringstatic bool arg_show_status = true;
7384146530ac083efbef62b9ef5bb82c56565cd4Zbigniew Jędrzejewski-Szmekstatic bool arg_switched_root = false;
7384146530ac083efbef62b9ef5bb82c56565cd4Zbigniew Jędrzejewski-Szmekstatic char ***arg_join_controllers = NULL;
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poetteringstatic ExecOutput arg_default_std_output = EXEC_OUTPUT_JOURNAL;
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poetteringstatic ExecOutput arg_default_std_error = EXEC_OUTPUT_INHERIT;
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poetteringstatic usec_t arg_shutdown_watchdog = 10 * USEC_PER_MINUTE;
7384146530ac083efbef62b9ef5bb82c56565cd4Zbigniew Jędrzejewski-Szmekstatic char **arg_default_environment = NULL;
7384146530ac083efbef62b9ef5bb82c56565cd4Zbigniew Jędrzejewski-Szmekstatic struct rlimit *arg_default_rlimit[RLIMIT_NLIMITS] = {};
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poetteringstatic uint64_t arg_capability_bounding_set_drop = 0;
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poetteringstatic nsec_t arg_timer_slack_nsec = (nsec_t) -1;
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* Pass this on immediately, if this is not PID 1 */
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_error("Caught <%s>, not dumping core.", signal_to_string(sig));
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* We want to wait for the core process, hence let's enable SIGCHLD */
7384146530ac083efbef62b9ef5bb82c56565cd4Zbigniew Jędrzejewski-Szmek log_error("Caught <%s>, cannot fork for core dump: %s", signal_to_string(sig), strerror(errno));
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering else if (pid == 0) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* Enable default signal handler for core dump */
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* Don't limit the core dump size */
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* Just to be sure... */
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* Raise the signal again */
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering assert_not_reached("We shouldn't be here...");
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* Order things nicely. */
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_error("Caught <%s>, waitpid() failed: %s", signal_to_string(sig), strerror(-r));
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_error("Caught <%s>, core dump failed.", signal_to_string(sig));
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_error("Caught <%s>, dumped core as pid %lu.", signal_to_string(sig), (unsigned long) pid);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering .sa_flags = SA_NOCLDSTOP|SA_NOCLDWAIT|SA_RESTART,
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_info("Executing crash shell in 10s...");
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* Let the kernel reap children for us */
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering assert_se(sigaction(SIGCHLD, &sa, NULL) == 0);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_error("Failed to fork off crash shell: %m");
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering else if (pid == 0) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_info("Successfully spawned crash shell as pid %lu.", (unsigned long) pid);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poetteringstatic void install_crash_handler(void) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering sigaction_many(&sa, SIGNALS_CRASH_HANDLER, -1);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* If we are init, we connect stdin/stdout/stderr to /dev/null
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering * and make sure we don't have a controlling tty. */
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering tty_fd = open_terminal("/dev/console", O_WRONLY|O_NOCTTY|O_CLOEXEC);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_error("Failed to open /dev/console: %s", strerror(-tty_fd));
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* We don't want to force text mode.
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering * plymouth may be showing pictures already from initrd. */
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_error("Failed to reset /dev/console: %s", strerror(-r));
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poetteringstatic int set_default_unit(const char *u) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poetteringstatic int parse_proc_cmdline_word(const char *word) {
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek static const char * const rlmap[] = {
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek "emergency", SPECIAL_EMERGENCY_TARGET,
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek return set_default_unit(word + 13);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering } else if (startswith(word, "rd.systemd.unit=")) {
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek } else if (startswith(word, "systemd.log_target=")) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering if (log_set_target_from_string(word + 19) < 0)
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse log target %s. Ignoring.", word + 19);
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek } else if (startswith(word, "systemd.log_level=")) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering if (log_set_max_level_from_string(word + 18) < 0)
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse log level %s. Ignoring.", word + 18);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering } else if (startswith(word, "systemd.log_color=")) {
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek if (log_show_color_from_string(word + 18) < 0)
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse log color setting %s. Ignoring.", word + 18);
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek } else if (startswith(word, "systemd.log_location=")) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering if (log_show_location_from_string(word + 21) < 0)
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering log_warning("Failed to parse log location setting %s. Ignoring.", word + 21);
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering } else if (startswith(word, "systemd.dump_core=")) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse dump core switch %s. Ignoring.", word + 18);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering } else if (startswith(word, "systemd.crash_shell=")) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse crash shell switch %s. Ignoring.", word + 20);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering } else if (startswith(word, "systemd.confirm_spawn=")) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse confirm spawn switch %s. Ignoring.", word + 22);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering } else if (startswith(word, "systemd.crash_chvt=")) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse crash chvt switch %s. Ignoring.", word + 19);
b47d419c25ecc735615a1088060c1ec8bef1e41fZbigniew Jędrzejewski-Szmek } else if (startswith(word, "systemd.show_status=")) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse show status switch %s. Ignoring.", word + 20);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering } else if (startswith(word, "systemd.default_standard_output=")) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering if ((r = exec_output_from_string(word + 32)) < 0)
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse default standard output switch %s. Ignoring.", word + 32);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering } else if (startswith(word, "systemd.default_standard_error=")) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering if ((r = exec_output_from_string(word + 31)) < 0)
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Failed to parse default standard error switch %s. Ignoring.", word + 31);
b47d419c25ecc735615a1088060c1ec8bef1e41fZbigniew Jędrzejewski-Szmek } else if (startswith(word, "systemd.setenv=")) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Environment variable name '%s' is not valid. Ignoring.", cenv);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Unsetting environment variable '%s' failed, ignoring: %m", cenv);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Environment variable assignment '%s' is not valid. Ignoring.", cenv);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Setting environment variable '%s=%s' failed, ignoring: %m", cenv, eq + 1);
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering } else if (startswith(word, "systemd.") ||
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering (in_initrd() && startswith(word, "rd.systemd."))) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering const char *c;
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* Ignore systemd.journald.xyz and friends */
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering log_warning("Unknown kernel switch %s. Ignoring.", word);
c51cf05646a11c65daf65c1123c77efb068f4f7bZbigniew Jędrzejewski-Szmek log_info("Supported kernel switches:\n"
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering "systemd.unit=UNIT Default unit to start\n"
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering "rd.systemd.unit=UNIT Default unit to start when run in initrd\n"
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering "systemd.dump_core=0|1 Dump core on crash\n"
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering "systemd.crash_shell=0|1 Run shell on crash\n"
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering "systemd.crash_chvt=N Change to VT #N on crash\n"
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering "systemd.confirm_spawn=0|1 Confirm every process spawn\n"
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek "systemd.show_status=0|1 Show status updates on the console during bootup\n"
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering "systemd.log_target=console|kmsg|journal|journal-or-kmsg|syslog|syslog-or-kmsg|null\n"
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering " Log target\n"
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering "systemd.log_level=LEVEL Log level\n"
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering "systemd.log_color=0|1 Highlight important log messages\n"
b47d419c25ecc735615a1088060c1ec8bef1e41fZbigniew Jędrzejewski-Szmek "systemd.log_location=0|1 Include code location in log messages\n"
b47d419c25ecc735615a1088060c1ec8bef1e41fZbigniew Jędrzejewski-Szmek "systemd.default_standard_output=null|tty|syslog|syslog+console|kmsg|kmsg+console|journal|journal+console\n"
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering " Set default log output for services\n"
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering "systemd.default_standard_error=null|tty|syslog|syslog+console|kmsg|kmsg+console|journal|journal+console\n"
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek " Set default log error output for services\n"
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek "systemd.setenv=ASSIGNMENT Set an environment variable for all spawned processes\n");
1ca208fb4f93e5869704af1812cbff7130a2fc03Zbigniew Jędrzejewski-Szmek } else if (streq(word, "quiet"))
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering /* SysV compatibility */
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering for (i = 0; i < ELEMENTSOF(rlmap); i += 2)
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering#define DEFINE_SETTER(name, func, descr) \
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering const char *lvalue, \
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering const char *rvalue, \
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering log_syntax(unit, LOG_ERR, filename, line, -r, \
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart PoetteringDEFINE_SETTER(config_parse_level2, log_set_max_level_from_string, "log level")
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart PoetteringDEFINE_SETTER(config_parse_target, log_set_target_from_string, "target")
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart PoetteringDEFINE_SETTER(config_parse_color, log_show_color_from_string, "color" )
3db604b907323b8df0fc810216f6112056d26a02Lennart PoetteringDEFINE_SETTER(config_parse_location, log_show_location_from_string, "location")
3db604b907323b8df0fc810216f6112056d26a02Lennart Poetteringstatic int config_parse_cpu_affinity2(const char *unit,
3db604b907323b8df0fc810216f6112056d26a02Lennart Poettering FOREACH_WORD_QUOTED(w, l, rvalue, state) {
1a14a53cfded6e78c6e8dfb73fdff0039971d642Lennart Poettering if (!(t = strndup(w, l)))
free(t);
return log_oom();
CPU_FREE(c);
return -EBADMSG;
CPU_FREE(c);
static void strv_free_free(char ***l) {
strv_free(*i);
free(l);
static void free_join_controllers(void) {
const char *filename,
unsigned line,
const char *section,
const char *lvalue,
int ltype,
const char *rvalue,
void *data,
void *userdata) {
char *state, *w;
return log_oom();
free(s);
strv_uniq(l);
strv_free(l);
if (!arg_join_controllers) {
if (!arg_join_controllers) {
strv_free(l);
return log_oom();
arg_join_controllers[0] = l;
strv_free(l);
return log_oom();
for (a = arg_join_controllers; *a; a++) {
if (strv_overlap(*a, l)) {
c = strv_merge(*a, l);
strv_free(l);
strv_free_free(t);
return log_oom();
strv_free(l);
c = strv_copy(*a);
strv_free(l);
strv_free_free(t);
return log_oom();
t[n++] = strv_uniq(l);
arg_join_controllers = t;
static int parse_config_file(void) {
{ "Manager", "CapabilityBoundingSet", config_parse_bounding_set, 0, &arg_capability_bounding_set_drop },
{ "Manager", "DefaultLimitSIGPENDING",config_parse_limit, 0, &arg_default_rlimit[RLIMIT_SIGPENDING]},
const char *fn;
r = config_parse(NULL, fn, f, "Manager\0", config_item_table_lookup, (void*) items, false, false, NULL);
static int parse_proc_cmdline(void) {
char *w, *state;
size_t l;
if (!word)
return log_oom();
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:
case ARG_VERSION:
case ARG_DUMP_CORE:
arg_dump_core = r;
case ARG_CRASH_SHELL:
arg_crash_shell = r;
case ARG_CONFIRM_SPAWN:
arg_confirm_spawn = r;
case ARG_SHOW_STATUS:
arg_show_status = r;
case ARG_DESERIALIZE: {
int fd;
FILE *f;
if (r < 0 || fd < 0) {
return r < 0 ? r : -EINVAL;
return -errno;
if (serialization)
serialization = f;
case ARG_SWITCHED_ROOT:
arg_switched_root = true;
case ARG_INTROSPECT: {
const char * const * i = NULL;
if (optarg)
if (!i[0] && optarg)
return -EINVAL;
return -EINVAL;
if ((r = parse_proc_cmdline_word(*a)) < 0) {
static int help(void) {
" --log-target=TARGET Set log target (console, journal, syslog, kmsg, journal-or-kmsg, syslog-or-kmsg, null)\n"
static int version(void) {
assert(m);
r = manager_open_serialization(m, &f);
goto fail;
m->n_reloading ++;
bus_broadcast_reloading(m, true);
if (!fds) {
r = -ENOMEM;
goto fail;
goto fail;
goto fail;
goto fail;
goto fail;
*_f = f;
fail:
fclose(f);
return -errno;
if (!rl)
return log_oom();
static void test_mtab(void) {
free(p);
"Please make sure to replace this file by a symlink to avoid incorrect or misleading mount(8) output.");
static void test_usr(void) {
log_warning("/usr appears to be on its own filesytem 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 void test_cgroups(void) {
"Consult http://0pointer.de/blog/projects/cgroups-vs-cgroups.html for more information.");
static int initialize_join_controllers(void) {
if (!arg_join_controllers)
return -ENOMEM;
return -ENOMEM;
bool reexecute = false;
bool skip_setup = false;
bool loaded_policy = false;
bool arm_reboot_watchdog = false;
bool queue_default_job = false;
#ifdef HAVE_SYSV_COMPAT
skip_setup = true;
skip_setup = false;
log_open();
if (in_initrd())
if (!skip_setup) {
goto finish;
if (ima_setup() < 0)
goto finish;
if (smack_setup() < 0)
goto finish;
goto finish;
if (!skip_setup) {
if (hwclock_is_localtime() > 0) {
int min;
} else if (!in_initrd()) {
log_open();
log_open();
goto finish;
r = initialize_join_controllers();
goto finish;
goto finish;
if (parse_config_file() < 0)
goto finish;
if (parse_proc_cmdline() < 0)
goto finish;
goto finish;
geteuid() == 0) {
goto finish;
sd_booted() <= 0) {
goto finish;
running_in_chroot() > 0) {
goto finish;
goto finish;
goto finish;
goto finish;
goto finish;
log_close();
goto finish;
if (serialization)
#ifdef HAVE_SPLIT_USR
setsid();
umask(0);
log_open();
goto finish;
if (virtualization)
if (in_initrd())
locale_setup();
#ifdef HAVE_KMOD
kmod_setup();
test_mtab();
test_usr();
test_cgroups();
goto finish;
goto finish;
goto finish;
if (serialization) {
if (queue_default_job) {
goto finish;
goto finish;
goto finish;
if (r == -EPERM) {
goto finish;
goto finish;
goto finish;
r = manager_loop(m);
goto finish;
switch (m->exit_code) {
case MANAGER_EXIT:
goto finish;
case MANAGER_RELOAD:
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_REBOOT:
case MANAGER_POWEROFF:
case MANAGER_HALT:
case MANAGER_KEXEC: {
goto finish;
manager_free(m);
for (j = 0; j < RLIMIT_NLIMITS; j++)
label_finish();
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 (serialization) {
if (fds) {
if (switch_root_init) {
if (serialization)
if (fds)
if (shutdown_verb) {
const char * command_line[] = {
char **env_block;
watchdog_close(false);
char_array_0(e);
watchdog_close(true);
freeze();
return retval;