summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2019-04-02 10:10:02 +0200
committerLennart Poettering <lennart@poettering.net>2019-04-02 10:19:22 +0200
commitd850296466c502106e680a2a5c07d3aa3213b97f (patch)
treecfef11e219df0501ecc792f8734d9295d82d3f0a
parent7452917740bc005cd4605b7be313238c0e9c5099 (diff)
downloadsystemd-d850296466c502106e680a2a5c07d3aa3213b97f.tar.gz
tty-ask-password: simplify signal handler installation
-rw-r--r--src/tty-ask-password-agent/tty-ask-password-agent.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/src/tty-ask-password-agent/tty-ask-password-agent.c b/src/tty-ask-password-agent/tty-ask-password-agent.c
index 4633779837..17cf35126f 100644
--- a/src/tty-ask-password-agent/tty-ask-password-agent.c
+++ b/src/tty-ask-password-agent/tty-ask-password-agent.c
@@ -697,23 +697,24 @@ static int parse_argv(int argc, char *argv[]) {
*/
static int ask_on_this_console(const char *tty, pid_t *ret_pid, char *argv[]) {
_cleanup_strv_free_ char **arguments = NULL;
- struct sigaction sig = {
+ static const struct sigaction sigchld = {
.sa_handler = nop_signal_handler,
.sa_flags = SA_NOCLDSTOP | SA_RESTART,
};
+ static const struct sigaction sighup = {
+ .sa_handler = SIG_DFL,
+ .sa_flags = SA_RESTART,
+ };
int r;
arguments = strv_copy(argv);
if (!arguments)
return log_oom();
+ assert_se(sigaction(SIGCHLD, &sigchld, NULL) >= 0);
+ assert_se(sigaction(SIGHUP, &sighup, NULL) >= 0);
assert_se(sigprocmask_many(SIG_UNBLOCK, NULL, SIGHUP, SIGCHLD, -1) >= 0);
- assert_se(sigaction(SIGCHLD, &sig, NULL) >= 0);
-
- sig.sa_handler = SIG_DFL;
- assert_se(sigaction(SIGHUP, &sig, NULL) >= 0);
-
r = safe_fork("(sd-passwd)", FORK_RESET_SIGNALS|FORK_LOG, ret_pid);
if (r < 0)
return r;