chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
socket-util: use IP address when hostname is not found
[elogind.git]
/
src
/
core
/
main.c
diff --git
a/src/core/main.c
b/src/core/main.c
index bd148b1b33642c444d13c25ff7cf7687fab2afca..0388f46c36197e22cbfd9ccbd33d03dd69ebf3de 100644
(file)
--- a/
src/core/main.c
+++ b/
src/core/main.c
@@
-272,6
+272,7
@@
static int parse_proc_cmdline_item(const char *key, const char *value) {
static const char * const rlmap[] = {
"emergency", SPECIAL_EMERGENCY_TARGET,
"-b", SPECIAL_EMERGENCY_TARGET,
static const char * const rlmap[] = {
"emergency", SPECIAL_EMERGENCY_TARGET,
"-b", SPECIAL_EMERGENCY_TARGET,
+ "rescue", SPECIAL_RESCUE_TARGET,
"single", SPECIAL_RESCUE_TARGET,
"-s", SPECIAL_RESCUE_TARGET,
"s", SPECIAL_RESCUE_TARGET,
"single", SPECIAL_RESCUE_TARGET,
"-s", SPECIAL_RESCUE_TARGET,
"s", SPECIAL_RESCUE_TARGET,
@@
-1725,7
+1726,7
@@
int main(int argc, char *argv[]) {
after_startup = now(CLOCK_MONOTONIC);
log_full(arg_action == ACTION_TEST ? LOG_INFO : LOG_DEBUG,
"Loaded units and determined initial transaction in %s.",
after_startup = now(CLOCK_MONOTONIC);
log_full(arg_action == ACTION_TEST ? LOG_INFO : LOG_DEBUG,
"Loaded units and determined initial transaction in %s.",
- format_timespan(timespan, sizeof(timespan), after_startup - before_startup,
0
));
+ format_timespan(timespan, sizeof(timespan), after_startup - before_startup,
100 * USEC_PER_MSEC
));
if (arg_action == ACTION_TEST) {
printf("-> By jobs:\n");
if (arg_action == ACTION_TEST) {
printf("-> By jobs:\n");
@@
-1834,7
+1835,6
@@
finish:
if (reexecute) {
const char **args;
unsigned i, args_size;
if (reexecute) {
const char **args;
unsigned i, args_size;
- sigset_t ss;
/* Close and disarm the watchdog, so that the new
* instance can reinitialize it, but doesn't get
/* Close and disarm the watchdog, so that the new
* instance can reinitialize it, but doesn't get
@@
-1854,10
+1854,10
@@
finish:
* deserializing. */
broadcast_signal(SIGTERM, false, true);
* deserializing. */
broadcast_signal(SIGTERM, false, true);
- /* And switch root */
- r = switch_root(switch_root_dir);
+ /* And switch root
with MS_MOVE, because we remove the old directory afterwards and detach it.
*/
+ r = switch_root(switch_root_dir
, "/mnt", true, MS_MOVE
);
if (r < 0)
if (r < 0)
- log_error("Failed to switch root,
ignoring
: %s", strerror(-r));
+ log_error("Failed to switch root,
trying to continue
: %s", strerror(-r));
}
args_size = MAX(6, argc+1);
}
args_size = MAX(6, argc+1);
@@
-1918,12
+1918,10
@@
finish:
args[i++] = NULL;
assert(i <= args_size);
args[i++] = NULL;
assert(i <= args_size);
- /*
r
eenable any blocked signals, especially important
+ /*
R
eenable any blocked signals, especially important
* if we switch from initial ramdisk to init=... */
reset_all_signal_handlers();
* if we switch from initial ramdisk to init=... */
reset_all_signal_handlers();
-
- assert_se(sigemptyset(&ss) == 0);
- assert_se(sigprocmask(SIG_SETMASK, &ss, NULL) == 0);
+ reset_signal_mask();
if (switch_root_init) {
args[0] = switch_root_init;
if (switch_root_init) {
args[0] = switch_root_init;