chiark
/
gitweb
/
~ianmdlvl
/
elogind.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
main: expclitly ignore signal when executing crash shell
[elogind.git]
/
main.c
diff --git
a/main.c
b/main.c
index 3e2bfe10ca94b5ed384a9e6ca205d848c5de8e08..622ba631519b90811d92e8aae79d9c15acf5514f 100644
(file)
--- a/
main.c
+++ b/
main.c
@@
-110,9
+110,19
@@
_noreturn static void crash(int sig) {
chvt(crash_chvt);
if (crash_shell) {
chvt(crash_chvt);
if (crash_shell) {
+ sigset_t mask;
+
log_info("Executing crash shell in 10s...");
sleep(10);
log_info("Executing crash shell in 10s...");
sleep(10);
+ /* Make sure the signal is not delivered inside the
+ * exec() */
+ assert_se(sigemptyset(&mask) == 0);
+ assert_se(sigaddset(&mask, sig) == 0);
+ assert_se(sigprocmask(SIG_SETMASK, &mask, NULL) == 0);
+
+ ignore_signal(sig);
+
execl("/bin/sh", "/bin/sh", NULL);
log_error("execl() failed: %s", strerror(errno));
}
execl("/bin/sh", "/bin/sh", NULL);
log_error("execl() failed: %s", strerror(errno));
}
@@
-567,5
+577,8
@@
finish:
dbus_shutdown();
dbus_shutdown();
+ if (getpid() == 1)
+ freeze();
+
return retval;
}
return retval;
}