diff options
author | deraadt@openbsd.org <deraadt@openbsd.org> | 2024-06-27 01:16:52 +0200 |
---|---|---|
committer | Damien Miller <djm@mindrot.org> | 2024-06-28 00:34:49 +0200 |
commit | d6bcd13297c2ab8b528df5a6898f994734849031 (patch) | |
tree | 4b56287d71ca5ef7c3e008e11c6b79a19e87799c /sshd-session.c | |
parent | upstream: save_errno wrappers inside two small signal handlers that (diff) | |
download | openssh-d6bcd13297c2ab8b528df5a6898f994734849031.tar.xz openssh-d6bcd13297c2ab8b528df5a6898f994734849031.zip |
upstream: Instead of using possibly complex ssh_signal(), write all
the parts of the grace_alarm_handler() using the exact things allowed by the
signal-safe rules. This is a good rule of thumb: Handlers should be written
to either set a global volatile sig_atomic_t inspected from outside, and/or
directly perform only safe operations listed in our sigaction(2) manual page.
ok djm markus
OpenBSD-Commit-ID: 14168ae8368aab76e4ed79e17a667cb46f404ecd
Diffstat (limited to 'sshd-session.c')
-rw-r--r-- | sshd-session.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/sshd-session.c b/sshd-session.c index 7ab1ea472..fe6ae7f32 100644 --- a/sshd-session.c +++ b/sshd-session.c @@ -1,4 +1,4 @@ -/* $OpenBSD: sshd-session.c,v 1.3 2024/06/06 17:15:25 djm Exp $ */ +/* $OpenBSD: sshd-session.c,v 1.4 2024/06/26 23:16:52 deraadt Exp $ */ /* * SSH2 implementation: * Privilege Separation: @@ -197,6 +197,8 @@ static void do_ssh2_kex(struct ssh *); /* * Signal handler for the alarm after the login grace period has expired. + * As usual, this may only take signal-safe actions, even though it is + * terminal. */ static void grace_alarm_handler(int sig) @@ -206,7 +208,14 @@ grace_alarm_handler(int sig) * keys command helpers or privsep children. */ if (getpgid(0) == getpid()) { - ssh_signal(SIGTERM, SIG_IGN); + struct sigaction sa; + + /* mask all other signals while in handler */ + memset(&sa, 0, sizeof(sa)); + sa.sa_handler = SIG_IGN; + sigfillset(&sa.sa_mask); + sa.sa_flags = SA_RESTART; + (void)sigaction(SIGTERM, &sa, NULL); kill(0, SIGTERM); } _exit(EXIT_LOGIN_GRACE); |