mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-27 14:03:43 +03:00
initctl: minor updates
This commit is contained in:
parent
92da345c02
commit
6542952f8b
48
initctl.c
48
initctl.c
@ -39,6 +39,7 @@
|
|||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
#include "initreq.h"
|
#include "initreq.h"
|
||||||
|
#include "manager.h"
|
||||||
|
|
||||||
#define SERVER_FD_START 3
|
#define SERVER_FD_START 3
|
||||||
#define SERVER_FD_MAX 16
|
#define SERVER_FD_MAX 16
|
||||||
@ -67,42 +68,35 @@ struct Fifo {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const char *translate_runlevel(int runlevel) {
|
static const char *translate_runlevel(int runlevel) {
|
||||||
|
static const struct {
|
||||||
|
const int runlevel;
|
||||||
|
const char *special;
|
||||||
|
} table[] = {
|
||||||
|
{ '0', SPECIAL_RUNLEVEL0_TARGET },
|
||||||
|
{ '1', SPECIAL_RUNLEVEL1_TARGET },
|
||||||
|
{ 's', SPECIAL_RUNLEVEL1_TARGET },
|
||||||
|
{ 'S', SPECIAL_RUNLEVEL1_TARGET },
|
||||||
|
{ '2', SPECIAL_RUNLEVEL2_TARGET },
|
||||||
|
{ '3', SPECIAL_RUNLEVEL3_TARGET },
|
||||||
|
{ '4', SPECIAL_RUNLEVEL4_TARGET },
|
||||||
|
{ '5', SPECIAL_RUNLEVEL5_TARGET },
|
||||||
|
{ '6', SPECIAL_RUNLEVEL6_TARGET },
|
||||||
|
};
|
||||||
|
|
||||||
switch (runlevel) {
|
unsigned i;
|
||||||
|
|
||||||
case '0':
|
for (i = 0; i < ELEMENTSOF(table); i++)
|
||||||
return "halt.target";
|
if (table[i].runlevel == runlevel)
|
||||||
|
return table[i].special;
|
||||||
|
|
||||||
case '1':
|
return NULL;
|
||||||
case 's':
|
|
||||||
case 'S':
|
|
||||||
return "rescue.target";
|
|
||||||
|
|
||||||
case '2':
|
|
||||||
return "runlevel2.target";
|
|
||||||
|
|
||||||
case '3':
|
|
||||||
return "runlevel3.target";
|
|
||||||
|
|
||||||
case '4':
|
|
||||||
return "runlevel4.target";
|
|
||||||
|
|
||||||
case '5':
|
|
||||||
return "runlevel5.target";
|
|
||||||
|
|
||||||
case '6':
|
|
||||||
return "reboot.target";
|
|
||||||
|
|
||||||
default:
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void change_runlevel(Server *s, int runlevel) {
|
static void change_runlevel(Server *s, int runlevel) {
|
||||||
const char *target;
|
const char *target;
|
||||||
DBusMessage *m = NULL, *reply = NULL;
|
DBusMessage *m = NULL, *reply = NULL;
|
||||||
DBusError error;
|
DBusError error;
|
||||||
const char *path, *replace = "replace";
|
const char *path, *replace = "isolate";
|
||||||
|
|
||||||
assert(s);
|
assert(s);
|
||||||
|
|
||||||
|
@ -85,6 +85,12 @@ struct Watch {
|
|||||||
|
|
||||||
#define SPECIAL_DEFAULT_TARGET "default.target"
|
#define SPECIAL_DEFAULT_TARGET "default.target"
|
||||||
|
|
||||||
|
/* This is not really intended to be started by directly. This is
|
||||||
|
* mostly so that other targets (reboot/halt/poweroff) can depend on
|
||||||
|
* it to bring all services down that want to be brought down on
|
||||||
|
* system shutdown. */
|
||||||
|
#define SPECIAL_SHUTDOWN_TARGET "shutdown.target"
|
||||||
|
|
||||||
#define SPECIAL_LOGGER_SOCKET "systemd-logger.socket"
|
#define SPECIAL_LOGGER_SOCKET "systemd-logger.socket"
|
||||||
|
|
||||||
#define SPECIAL_KBREQUEST_TARGET "kbrequest.target"
|
#define SPECIAL_KBREQUEST_TARGET "kbrequest.target"
|
||||||
|
29
service.c
29
service.c
@ -2197,7 +2197,7 @@ static int service_enumerate(Manager *m) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
while ((de = readdir(d))) {
|
while ((de = readdir(d))) {
|
||||||
Unit *runlevel, *service;
|
Unit *service;
|
||||||
|
|
||||||
if (ignore_file(de->d_name))
|
if (ignore_file(de->d_name))
|
||||||
continue;
|
continue;
|
||||||
@ -2233,31 +2233,42 @@ static int service_enumerate(Manager *m) {
|
|||||||
if ((r = manager_load_unit(m, name, NULL, &service)) < 0)
|
if ((r = manager_load_unit(m, name, NULL, &service)) < 0)
|
||||||
goto finish;
|
goto finish;
|
||||||
|
|
||||||
if ((r = manager_load_unit(m, rcnd_table[i+1], NULL, &runlevel)) < 0)
|
|
||||||
goto finish;
|
|
||||||
|
|
||||||
if (de->d_name[0] == 'S') {
|
if (de->d_name[0] == 'S') {
|
||||||
if ((r = unit_add_dependency(runlevel, UNIT_WANTS, service, true)) < 0)
|
Unit *runlevel_target;
|
||||||
|
|
||||||
|
if ((r = manager_load_unit(m, rcnd_table[i+1], NULL, &runlevel_target)) < 0)
|
||||||
goto finish;
|
goto finish;
|
||||||
|
|
||||||
if ((r = unit_add_dependency(runlevel, UNIT_AFTER, service, true)) < 0)
|
if ((r = unit_add_dependency(runlevel_target, UNIT_WANTS, service, true)) < 0)
|
||||||
|
goto finish;
|
||||||
|
|
||||||
|
if ((r = unit_add_dependency(runlevel_target, UNIT_AFTER, service, true)) < 0)
|
||||||
goto finish;
|
goto finish;
|
||||||
|
|
||||||
} else if (de->d_name[0] == 'K' &&
|
} else if (de->d_name[0] == 'K' &&
|
||||||
(streq(rcnd_table[i+1], SPECIAL_RUNLEVEL0_TARGET) ||
|
(streq(rcnd_table[i+1], SPECIAL_RUNLEVEL0_TARGET) ||
|
||||||
streq(rcnd_table[i+1], SPECIAL_RUNLEVEL6_TARGET))) {
|
streq(rcnd_table[i+1], SPECIAL_RUNLEVEL6_TARGET))) {
|
||||||
|
|
||||||
|
Unit *shutdown_target;
|
||||||
|
|
||||||
/* We honour K links only for
|
/* We honour K links only for
|
||||||
* halt/reboot. For the normal
|
* halt/reboot. For the normal
|
||||||
* runlevels we assume the
|
* runlevels we assume the
|
||||||
* stop jobs will be
|
* stop jobs will be
|
||||||
* implicitly added by the
|
* implicitly added by the
|
||||||
* core logic. */
|
* core logic. Also, we don't
|
||||||
|
* really distuingish here
|
||||||
|
* between the runlevels 0 and
|
||||||
|
* 6 and just add them to the
|
||||||
|
* special shutdown target. */
|
||||||
|
|
||||||
if ((r = unit_add_dependency(runlevel, UNIT_CONFLICTS, service, true)) < 0)
|
if ((r = manager_load_unit(m, SPECIAL_SHUTDOWN_TARGET, NULL, &shutdown_target)) < 0)
|
||||||
goto finish;
|
goto finish;
|
||||||
|
|
||||||
if ((r = unit_add_dependency(runlevel, UNIT_BEFORE, service, true)) < 0)
|
if ((r = unit_add_dependency(shutdown_target, UNIT_CONFLICTS, service, true)) < 0)
|
||||||
|
goto finish;
|
||||||
|
|
||||||
|
if ((r = unit_add_dependency(shutdown_target, UNIT_BEFORE, service, true)) < 0)
|
||||||
goto finish;
|
goto finish;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user