[scp.c]
     Fix a longstanding problem where if you suspend scp at the
     password/passphrase prompt the terminal mode is not restored.
     OK djm@
This commit is contained in:
Damien Miller 2010-07-02 13:37:33 +10:00
parent d59dab8353
commit 0979b40934
2 changed files with 24 additions and 1 deletions

View File

@ -23,6 +23,11 @@
- jmc@cvs.openbsd.org 2010/06/30 07:28:34 - jmc@cvs.openbsd.org 2010/06/30 07:28:34
[sshd_config.5] [sshd_config.5]
tweak previous; tweak previous;
- millert@cvs.openbsd.org 2010/07/01 13:06:59
[scp.c]
Fix a longstanding problem where if you suspend scp at the
password/passphrase prompt the terminal mode is not restored.
OK djm@
20100627 20100627
- (tim) [openbsd-compat/port-uw.c] Reorder includes. auth-options.h now needs - (tim) [openbsd-compat/port-uw.c] Reorder includes. auth-options.h now needs

20
scp.c
View File

@ -1,4 +1,4 @@
/* $OpenBSD: scp.c,v 1.165 2009/12/20 07:28:36 guenther Exp $ */ /* $OpenBSD: scp.c,v 1.166 2010/07/01 13:06:59 millert Exp $ */
/* /*
* scp - secure remote copy. This is basically patched BSD rcp which * scp - secure remote copy. This is basically patched BSD rcp which
* uses ssh to do the data transfer (instead of using rcmd). * uses ssh to do the data transfer (instead of using rcmd).
@ -156,6 +156,20 @@ killchild(int signo)
exit(1); exit(1);
} }
static void
suspchild(int signo)
{
int status;
if (do_cmd_pid > 1) {
kill(do_cmd_pid, signo);
while (waitpid(do_cmd_pid, &status, WUNTRACED) == -1 &&
errno == EINTR)
;
kill(getpid(), SIGSTOP);
}
}
static int static int
do_local_cmd(arglist *a) do_local_cmd(arglist *a)
{ {
@ -232,6 +246,10 @@ do_cmd(char *host, char *remuser, char *cmd, int *fdin, int *fdout)
close(reserved[0]); close(reserved[0]);
close(reserved[1]); close(reserved[1]);
signal(SIGTSTP, suspchild);
signal(SIGTTIN, suspchild);
signal(SIGTTOU, suspchild);
/* Fork a child to execute the command on the remote host using ssh. */ /* Fork a child to execute the command on the remote host using ssh. */
do_cmd_pid = fork(); do_cmd_pid = fork();
if (do_cmd_pid == 0) { if (do_cmd_pid == 0) {