1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 09:12:24 +00:00
Go to file
Jacob Nevins 9897694920 Fix an apparently-harmless error spotted by Ben Rudiak-Gould:
do_ssh2_transport() was returning the wrong value for rekeys after the first.
This apparent error was introduced in r4901, but we can't see any reason for
the change to have been made. If it turns out to be a mistake to revert it,
I'm sure we'll find out.

Here for posterity is Simon's analysis:

| A lot of the return values from do_ssh2_transport appear to be vestigial: it
| used to be that a zero return from do_ssh2_transport meant it had handled the
| packet internally, and a 1 return meant the packet wasn't a transport-layer
| one and needed to pass on to do_ssh2_authconn. Since r4901, however, the
| layer discrimination is done based on the message type ranges, and the only
| remaining dependency on the return value from do_ssh2_transport is a special
| case in ssh2_protocol which detects the first 1 return and makes the
| initialisation call to do_ssh2_authconn.
| 
| Therefore, the gratuitous 1 return on every key exchange as a result of the
| confusing if statement is simply ignored in ssh2_protocol (because
| ssh->protocol_initial_phase_done is already TRUE). So the remaining question
| was, why does the _lack_ of that 1 return not cause a problem, if the if's
| sense is indeed reversed?
| 
| The answer is that 1 is still returned, just not by the crReturn inside the
| if statement. It's returned by the next crReturn, just after
| wait_for_rekey(). Which suggests that in fact, the if statement has the
| correct sense, but the crReturn inside it has the wrong value - it should be
| returning _zero_, to indicate that every NEWKEYS after the first one is
| uninteresting to the authconn code, and on the very first run through that
| doesn't happen and the NEWKEYS gets all the way to the crReturn(1) later on.

[originally from svn r5986]
[r4901 == a4ba026838]
2005-06-21 20:13:48 +00:00
charset Remove .cvsignore files on all active branches. 2004-11-16 15:29:14 +00:00
contrib Consistently use a single notation to refer to SSH protocol versions, as 2005-03-10 16:36:05 +00:00
doc s/public/private/ spotted by Walter Cleverly. 2005-05-09 21:01:11 +00:00
mac First crack at `terminal-modes' in SSH. PuTTY now sends ERASE by default, 2005-04-21 13:57:08 +00:00
macosx First crack at `terminal-modes' in SSH. PuTTY now sends ERASE by default, 2005-04-21 13:57:08 +00:00
testdata Add an option to use wcwidth_cjk() instead of wcwidth(), as several people 2005-03-22 23:20:23 +00:00
unix Add experimental support for detecting BREAK on input and propagating it as 2005-05-14 22:01:10 +00:00
windows Move comment about ECHO and LINE input modes to a more sensible position. 2005-06-19 13:57:50 +00:00
be_all.c Now that we have `appname', make much wider use of it. In 2003-04-06 14:11:33 +00:00
be_none.c First phase of porting. pterm now compiles and runs under Linux+gtk. 2002-10-09 18:09:42 +00:00
be_nossh.c Loose end from timing shakeup: sshrand.c is now a client of 2004-11-27 19:56:38 +00:00
CHECKLST.txt I always get a lot of personal mail about PuTTY when I send out a 2005-04-07 12:38:17 +00:00
cmdgen.c Try to make our PGP signing more useful: 2005-03-19 02:26:58 +00:00
cmdline.c Fix potential fault where -L/-R/-D could accept a string too long for our 2005-03-04 01:54:56 +00:00
config.c Implement `bypass-ssh2-userauth', since from correspondence it sounds like 2005-05-05 22:37:54 +00:00
cproxy.c Fix/bludgeon Mac compile wrinkles. 2005-01-20 16:42:25 +00:00
dialog.c Patch from Rene Post: ctrl_{drag,drop}list both now initialise the 2003-05-12 13:41:41 +00:00
dialog.h Event Log for Unix PuTTY. Doesn't yet allow X selection of its 2003-04-09 18:46:45 +00:00
import.c On some systems (NetBSD 1.6 and Solaris 9, at least), GCC doesn't understand 2005-04-24 14:43:00 +00:00
int64.c uint64_decimal() incorrectly output 0 as "" instead of "0". This only affected 2004-11-25 13:40:01 +00:00
int64.h More upgrades to psftp: it now supports mv, chmod, reget and reput. 2001-08-26 11:35:11 +00:00
LATEST.VER Version number and other tweakings prior to the 0.58 release. 2005-04-05 19:36:25 +00:00
ldisc.c At last! After much delay, much faffing back and forth, and much 2004-05-22 10:36:50 +00:00
ldisc.h Add a Config * argument to ldisc_create(), and use it in place of the global 2002-11-23 20:02:38 +00:00
ldiscucs.c Introduced wrapper macros snew(), snewn() and sresize() for the 2003-03-29 16:14:26 +00:00
LICENCE Oops, forgot to credit Ahmad Khalifa of arabeyes.org for the bidi/shaping work. 2005-04-07 12:00:01 +00:00
logging.c Log file open mode lost a "b" in r5344. Windows at least needs log files to 2005-02-19 01:20:16 +00:00
minibidi.c Mac SC compiler whinges about trailing commas in enums 2005-01-16 14:33:43 +00:00
misc.c Invent a way of specifying control characters numerically in ctrlparse(): 2005-04-19 19:18:14 +00:00
misc.h Pull out parsing of ^C style strings from the terminal answerback code to 2005-04-19 18:58:29 +00:00
mkauto.sh Move generation of the "configure" script into its own script so that 2005-04-25 16:36:43 +00:00
mkfiles.pl Add a mechanism for using autoconf to detect the quirks of Unix systems 2005-04-25 15:55:06 +00:00
mksrcarc.sh Fiddle with source archive for new OS X files. 2005-03-11 09:07:37 +00:00
mkunxarc.sh mkunxarc.sh is supposed to be silent, so I'm having it discard the 2005-04-27 08:09:32 +00:00
network.h Support for falling back through the list of addresses returned from 2005-01-16 14:29:34 +00:00
nocproxy.c Malcolm Smith's patch to support CHAP (digest-based) authentication 2004-08-30 13:11:17 +00:00
notiming.c Oops; forgot to add this file in r4913. 2004-11-28 00:48:31 +00:00
pinger.c New timing infrastructure. There's a new function schedule_timer() 2004-11-27 13:20:21 +00:00
portfwd.c Unify GET_32BIT()/PUT_32BIT() et al from numerous source files into misc.h. 2005-04-12 20:04:56 +00:00
pproxy.c Add a configuration option for TCP keepalives (SO_KEEPALIVE), default off. 2004-06-20 17:07:38 +00:00
proxy.c Change proxy-dns `Auto' default for SOCKS5 from local DNS to remote DNS. 2005-04-22 00:00:49 +00:00
proxy.h Malcolm Smith's patch to support CHAP (digest-based) authentication 2004-08-30 13:11:17 +00:00
pscp.c A major purpose of PuTTY's memory-allocation functions is to succeed or die 2005-06-19 14:17:24 +00:00
psftp.c Double-free on mkdir error, spotted by Brian Hartsock. 2005-06-08 15:14:47 +00:00
psftp.h General mechanism for ensuring a dodgy SFTP server can't return 2004-12-16 19:36:47 +00:00
putty.h Implement `bypass-ssh2-userauth', since from correspondence it sounds like 2005-05-05 22:37:54 +00:00
puttymem.h Additional robustness to SFTP packet parsing and memory allocation. 2005-02-20 10:30:05 +00:00
puttyps.h Initial checkin of a native Mac OS X port, sharing most of its code 2005-02-15 21:45:50 +00:00
raw.c Support for falling back through the list of addresses returned from 2005-01-16 14:29:34 +00:00
README Miscellaneous updates: 2005-05-23 12:41:21 +00:00
README.txt Silly grammatical error. 2004-02-07 17:36:05 +00:00
Recipe Fix documentation of NO_MANIFESTS (oops). 2005-05-21 15:09:36 +00:00
resource.h Initial checkin: beta 0.43 1999-01-08 13:02:13 +00:00
rlogin.c We should wait until the Rlogin server indicates that it's happy to receive 2005-06-14 14:48:17 +00:00
settings.c Implement `bypass-ssh2-userauth', since from correspondence it sounds like 2005-05-05 22:37:54 +00:00
sftp.c Unify GET_32BIT()/PUT_32BIT() et al from numerous source files into misc.h. 2005-04-12 20:04:56 +00:00
sftp.h Joe Yates's memory leak patches. 2003-12-19 12:44:46 +00:00
ssh.c Fix an apparently-harmless error spotted by Ben Rudiak-Gould: 2005-06-21 20:13:48 +00:00
ssh.h Now that we've got at least some SDCTR modes working (and aes256-ctr is our 2005-04-23 16:22:51 +00:00
sshaes.c Now that we've got at least some SDCTR modes working (and aes256-ctr is our 2005-04-23 16:22:51 +00:00
ssharcf.c Now that we've got at least some SDCTR modes working (and aes256-ctr is our 2005-04-23 16:22:51 +00:00
sshblowf.c Enable blowfish-ctr by default. It's been tested and found working. 2005-04-28 08:56:03 +00:00
sshbn.c Consistently use a single notation to refer to SSH protocol versions, as 2005-03-10 16:36:05 +00:00
sshcrc.c Rename crc32() to crc32_compute(), to avoid clashing catastrophically 2003-05-13 18:23:43 +00:00
sshcrcda.c Unify GET_32BIT()/PUT_32BIT() et al from numerous source files into misc.h. 2005-04-12 20:04:56 +00:00
sshdes.c Unlike the AES and Blowfish code, our implementations of the various DES 2005-04-30 14:30:07 +00:00
sshdh.c Support diffie-hellman-group14-sha1 group exchange. Tested against 2004-12-22 10:53:58 +00:00
sshdss.c Unify GET_32BIT()/PUT_32BIT() et al from numerous source files into misc.h. 2005-04-12 20:04:56 +00:00
sshdssg.c Arrgh, there's always one. Actually check in the extra file :-) 2001-09-22 21:00:53 +00:00
sshmd5.c Owen tells me the Mac compiler complains at a char / unsigned char 2005-01-16 14:02:56 +00:00
sshprime.c Failure to set multipliers[NPRIMES] was rendering the input-modulus 2003-06-28 14:11:28 +00:00
sshpubk.c Unify GET_32BIT()/PUT_32BIT() et al from numerous source files into misc.h. 2005-04-12 20:04:56 +00:00
sshrand.c Owen's just pointed out that random_stir() is capable of recursion. 2005-01-22 14:51:29 +00:00
sshrsa.c Unify GET_32BIT()/PUT_32BIT() et al from numerous source files into misc.h. 2005-04-12 20:04:56 +00:00
sshrsag.c Add support for DSA authentication in SSH2, following clever ideas 2001-09-22 20:52:21 +00:00
sshsh512.c SHA512_Core_Init() and SHA512_Block() are unused outside this file. Make 2003-01-05 23:34:00 +00:00
sshsha.c Consistently use a single notation to refer to SSH protocol versions, as 2005-03-10 16:36:05 +00:00
sshzlib.c I just had a need to decode a piece of Zlib data from out of the 2004-10-21 10:59:53 +00:00
storage.h Various error-handling fixes, mostly in Unix PuTTY but one (failure 2003-04-01 18:10:25 +00:00
telnet.c Fix `telnet-option-loop', I think. (Untested except to check it 2005-03-16 13:20:02 +00:00
terminal.c First crack at `terminal-modes' in SSH. PuTTY now sends ERASE by default, 2005-04-21 13:57:08 +00:00
terminal.h Cursor position, selection highlights and mouse clicks are now all 2004-11-28 09:24:57 +00:00
testback.c Mac PuTTY.ppc wouldn't compile for me until I added this prototype. 2005-02-05 10:55:09 +00:00
time.c Comment explaining location in top-level directory. 2005-02-07 15:23:45 +00:00
timing.c Render timing.c robust in the face of strangeness. The strangenesses 2005-03-28 17:48:24 +00:00
tree234.c Introduced wrapper macros snew(), snewn() and sresize() for the 2003-03-29 16:14:26 +00:00
tree234.h Run entire source base through GNU indent to tidy up the varying 2001-05-06 14:35:20 +00:00
version.c At long last: PuTTY will now report its version to the server 2001-03-15 12:15:02 +00:00
wcwidth.c `wcwidth-upgrade': upgrade to latest wcwidth.c from Markus Kuhn 2005-03-23 20:04:08 +00:00
wildcard.c Add notes on our globs' incompatibilities with POSIX 2004-04-27 12:52:34 +00:00
x11fwd.c Unify GET_32BIT()/PUT_32BIT() et al from numerous source files into misc.h. 2005-04-12 20:04:56 +00:00

PuTTY README
============

This is the README file for the PuTTY installer distribution. If
you're reading this, you've probably just run our installer and
installed PuTTY on your system.

What should I do next?
----------------------

If you want to use PuTTY to connect to other computers, or use PSFTP
to transfer files, you should just be able to run them from the
Start menu.

If you want to use the command-line-only file transfer utility PSCP,
you will probably want to put the PuTTY installation directory on
your PATH. How you do this depends on your version of Windows. On
Windows NT and 2000, you can set it using Control Panel > System; on
Windows 95 you will need to edit AUTOEXEC.BAT. Consult your Windows
manuals for details.

What do I do if it doesn't work?
--------------------------------

The PuTTY home web site is

    http://www.chiark.greenend.org.uk/~sgtatham/putty/

Here you will find our list of known bugs and pending feature
requests. If your problem is not listed in there, or in the FAQ, or
in the manuals, read the Feedback page to find out how to report
bugs to us. PLEASE read the Feedback page carefully: it is there to
save you time as well as us. Do not send us one-line bug reports
telling us `it doesn't work'.