Under OpenSSH 1.2pre17 I can duplicate and Input/Output error for scp: Conditions: pc36 is a RH6.0/i386 box. abc.co.za is a RH5.2/i386 box. (private network) openssh 1.2 pre 17 on both boxes. Line between them is a 128k leased line. It works between two 10baseT machines. If the scrollbar is active, the scp fails, if it isn't active, scp works. Note that without the scrollbar, the file gets there and is valid. I can try for an strace, but I'd rather not flood the mailing list. Also, server or client? I've attached scp -v info because its rather small, but useless. ---cut-here--- [bds at pc36 ssh-rh5]$ ls -la openssl-0.9.4-3.i386.rpm -rwxr-xr-x 1 root root 653323 Dec 14 11:07 openssl-0.9.4-3.i386.rpm [bds at pc36 ssh-rh5]$ scp openssl-0.9.4-3.i386.rpm root at abc.co.za:/tmp root at abc.co.za's password: openssl-0.9.4-3.i386 30% |******** | 196 KB - stalled - openssl-0.9.4-3.i386.rpm: Input/output error [bds at pc36 ssh-rh5]$ Killed by signal 2. ---cut-here--- Note: I had to press Ctrl-C (signal 2). ---cut-here--- [bds at pc36 ssh-rh5]$ scp openssl-0.9.4-3.i386.rpm root at abc.co.za:/tmp -q root at abc.co.za's password: [bds at pc36 ssh-rh5]$ ---cut-here--- ---cut-here--- [bds at pc36 ssh-rh5]$ scp openssl-0.9.4-3.i386.rpm root at abc.co.za:/tmp -q -v Executing: host abc.co.za, user root, command scp -v -t /tmp SSH Version OpenSSH-1.2, protocol version 1.5. Compiled with SSL. debug: Reading configuration data /etc/ssh/ssh_config debug: ssh_connect: getuid 513 geteuid 0 anon 0 debug: Connecting to abc.co.za [10.128.1.1] port 22. debug: Allocated local port 1023. debug: Connection established. debug: Remote protocol version 1.5, remote software version OpenSSH-1.2 debug: Waiting for server public key. debug: Received server public key (768 bits) and host key (1024 bits). debug: Host 'abc.co.za' is known and matches the host key. debug: Encryption type: 3des debug: Sent encrypted session key. debug: Installing crc compensation attack detector. debug: Received encrypted confirmation. debug: Doing password authentication. root at abc.co.za's password: debug: Sending command: scp -v -t /tmp debug: Entering interactive session. Sending file modes: C0755 653323 openssl-0.9.4-3.i386.rpm debug: Transferred: stdin 653362, stdout 3, stderr 0 bytes in 66.0 seconds debug: Bytes per second: stdin 9899.5, stdout 0.0, stderr 0.0 debug: Exit status 0 ---cut-here--- The failed verbose looks the same, except the last few lines: ---cut-here--- Sending file modes: C0755 653323 openssl-0.9.4-3.i386.rpm openssl-0.9.4-3.i386 30% |******** | 196 KB - stalled - openssl-0.9.4-3.i386.rpm: Input/output error [bds at pc36 ssh-rh5]$ Killed by signal 2. debug: Calling cleanup 0x80558f0(0x0) ---cut-here--- -- Kind regards, Berend -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-Berend De Schouwer, +27-11-712-1435, UCS
Berend De Schouwer wrote:> > Under OpenSSH 1.2pre17 I can duplicate and Input/Output error for scp: > > Conditions: > pc36 is a RH6.0/i386 box. > abc.co.za is a RH5.2/i386 box. (private network) > openssh 1.2 pre 17 on both boxes. > Line between them is a 128k leased line. It works between two 10baseT > machines. > If the scrollbar is active, the scp fails, if it isn't active, scp > works. Note that without the scrollbar, the file gets there and is > valid.I can confirm this problem - in our case, both ends are RH6.1 with a 2.2.13 kernel. I'm actually using it via a SOCKS5 firewall with the runsocks command - I don't know the spec of the intervening pipework. I also noticed that small files transfer without problem (anything larger than ~500k breaks). I rebuilt the supplied SRC rpm locally. Barrie -- Barrie Spence (313-2465) Agilent Technologies UK Ltd E-Mail: baz at sqf.hp.com South Queensferry, UK Play: barrie at calvin.demon.co.uk #include <std/disclaimer.h>
-----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 On Tue, 14 Dec 1999, Berend De Schouwer wrote:> Under OpenSSH 1.2pre17 I can duplicate and Input/Output error for scp:Does the attached patch sole your problems? Thanks for the report. Damien - -- | "Bombay is 250ms from New York in the new world order" - Alan Cox | Damien Miller - http://www.mindrot.org/ | Email: djm at mindrot.org (home) -or- djm at ibs.com.au (work) -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.0.0 (GNU/Linux) Comment: For info see http://www.gnupg.org iD8DBQE4VsVVormJ9RG1dI8RAsl6AKCmc/67Z9s5vGxpRxakfoxc7mDulwCghByS xcT+G0f9yFT7JjtjPyzNI4M=uYXx -----END PGP SIGNATURE----- -------------- next part -------------- Index: scp.c ==================================================================RCS file: /var/cvs/openssh/scp.c,v retrieving revision 1.12 diff -u -r1.12 scp.c --- scp.c 1999/12/07 04:38:32 1.12 +++ scp.c 1999/12/14 22:27:10 @@ -541,14 +541,14 @@ if (i + amt > stb.st_size) amt = stb.st_size - i; if (!haderr) { - result = read(fd, bp->buf, amt); + result = atomicio(read, fd, bp->buf, amt); if (result != amt) haderr = result >= 0 ? EIO : errno; } if (haderr) - (void) write(remout, bp->buf, amt); + (void) atomicio(write, remout, bp->buf, amt); else { - result = write(remout, bp->buf, amt); + result = atomicio(write, remout, bp->buf, amt); if (result != amt) haderr = result >= 0 ? EIO : errno; statbytes += result; @@ -1145,9 +1145,8 @@ i++; abbrevsize >>= 10; } - snprintf(buf + strlen(buf), sizeof(buf) - strlen(buf), " %5qd %c%c ", - (quad_t) abbrevsize, prefixes[i], prefixes[i] == ' ' ? ' ' : - 'B'); + snprintf(buf + strlen(buf), sizeof(buf) - strlen(buf), " %5d %c%c ", + (int) abbrevsize, prefixes[i], prefixes[i] == ' ' ? ' ' : 'B'); timersub(&now, &lastupdate, &wait); if (cursize > lastsize) {