- djm@cvs.openbsd.org 2007/06/12 08:24:20
[scp.c] make scp try to skip FIFOs rather than blocking when nothing is listening. depends on the platform supporting sane O_NONBLOCK semantics for open on FIFOs (apparently POSIX does not mandate this), which OpenBSD does. bz #856; report by cjwatson AT debian.org; ok markus@
This commit is contained in:
parent
8f6d0ed60e
commit
43ce902449
|
@ -12,6 +12,12 @@
|
||||||
[ssh-gss.h gss-serv.c gss-genr.c]
|
[ssh-gss.h gss-serv.c gss-genr.c]
|
||||||
relocate server-only GSSAPI code from libssh to server; bz #1225
|
relocate server-only GSSAPI code from libssh to server; bz #1225
|
||||||
patch from simon AT sxw.org.uk; ok markus@ dtucker@
|
patch from simon AT sxw.org.uk; ok markus@ dtucker@
|
||||||
|
- djm@cvs.openbsd.org 2007/06/12 08:24:20
|
||||||
|
[scp.c]
|
||||||
|
make scp try to skip FIFOs rather than blocking when nothing is listening.
|
||||||
|
depends on the platform supporting sane O_NONBLOCK semantics for open
|
||||||
|
on FIFOs (apparently POSIX does not mandate this), which OpenBSD does.
|
||||||
|
bz #856; report by cjwatson AT debian.org; ok markus@
|
||||||
|
|
||||||
20070611
|
20070611
|
||||||
- (djm) Bugzilla #1306: silence spurious error messages from hang-on-exit
|
- (djm) Bugzilla #1306: silence spurious error messages from hang-on-exit
|
||||||
|
@ -3026,4 +3032,4 @@
|
||||||
OpenServer 6 and add osr5bigcrypt support so when someone migrates
|
OpenServer 6 and add osr5bigcrypt support so when someone migrates
|
||||||
passwords between UnixWare and OpenServer they will still work. OK dtucker@
|
passwords between UnixWare and OpenServer they will still work. OK dtucker@
|
||||||
|
|
||||||
$Id: ChangeLog,v 1.4691 2007/06/12 13:40:39 dtucker Exp $
|
$Id: ChangeLog,v 1.4692 2007/06/12 13:41:06 dtucker Exp $
|
||||||
|
|
5
scp.c
5
scp.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: scp.c,v 1.156 2007/01/22 13:06:21 djm Exp $ */
|
/* $OpenBSD: scp.c,v 1.157 2007/06/12 08:24:20 djm 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).
|
||||||
|
@ -596,12 +596,13 @@ source(int argc, char **argv)
|
||||||
name);
|
name);
|
||||||
goto next;
|
goto next;
|
||||||
}
|
}
|
||||||
if ((fd = open(name, O_RDONLY, 0)) < 0)
|
if ((fd = open(name, O_RDONLY|O_NONBLOCK, 0)) < 0)
|
||||||
goto syserr;
|
goto syserr;
|
||||||
if (fstat(fd, &stb) < 0) {
|
if (fstat(fd, &stb) < 0) {
|
||||||
syserr: run_err("%s: %s", name, strerror(errno));
|
syserr: run_err("%s: %s", name, strerror(errno));
|
||||||
goto next;
|
goto next;
|
||||||
}
|
}
|
||||||
|
unset_nonblock(fd);
|
||||||
switch (stb.st_mode & S_IFMT) {
|
switch (stb.st_mode & S_IFMT) {
|
||||||
case S_IFREG:
|
case S_IFREG:
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue