diff options
author | Darren Tucker <dtucker@zip.com.au> | 2011-06-03 14:14:16 +1000 |
---|---|---|
committer | Darren Tucker <dtucker@zip.com.au> | 2011-06-03 14:14:16 +1000 |
commit | 3e78a516a0f476f193bc3b566b5e0919d29ccc17 (patch) | |
tree | 7a35a0bc46dbf75c3c7ae2ab9272711955d85c06 /ssh-agent.c | |
parent | c09182f61366f31609224765b36386bab84298b2 (diff) |
- dtucker@cvs.openbsd.org 2011/06/03 01:37:40
[ssh-agent.c]
Check current parent process ID against saved one to determine if the parent
has exited, rather than attempting to send a zero signal, since the latter
won't work if the parent has changed privs. bz#1905, patch from Daniel Kahn
Gillmor, ok djm@
Diffstat (limited to 'ssh-agent.c')
-rw-r--r-- | ssh-agent.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/ssh-agent.c b/ssh-agent.c index ae204b145..b9498e6ef 100644 --- a/ssh-agent.c +++ b/ssh-agent.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: ssh-agent.c,v 1.171 2010/11/21 01:01:13 djm Exp $ */ | 1 | /* $OpenBSD: ssh-agent.c,v 1.172 2011/06/03 01:37:40 dtucker Exp $ */ |
2 | /* | 2 | /* |
3 | * Author: Tatu Ylonen <ylo@cs.hut.fi> | 3 | * Author: Tatu Ylonen <ylo@cs.hut.fi> |
4 | * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland | 4 | * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland |
@@ -1097,7 +1097,11 @@ cleanup_handler(int sig) | |||
1097 | static void | 1097 | static void |
1098 | check_parent_exists(void) | 1098 | check_parent_exists(void) |
1099 | { | 1099 | { |
1100 | if (parent_pid != -1 && kill(parent_pid, 0) < 0) { | 1100 | /* |
1101 | * If our parent has exited then getppid() will return (pid_t)1, | ||
1102 | * so testing for that should be safe. | ||
1103 | */ | ||
1104 | if (parent_pid != -1 && getppid() != parent_pid) { | ||
1101 | /* printf("Parent has died - Authentication agent exiting.\n"); */ | 1105 | /* printf("Parent has died - Authentication agent exiting.\n"); */ |
1102 | cleanup_socket(); | 1106 | cleanup_socket(); |
1103 | _exit(2); | 1107 | _exit(2); |