diff options
author | Philip Hazel <ph10@hermes.cam.ac.uk> | 2006-04-04 09:09:44 +0000 |
---|---|---|
committer | Philip Hazel <ph10@hermes.cam.ac.uk> | 2006-04-04 09:09:44 +0000 |
commit | d515a9174a5ea517bc3d27bc4d40223b24d7a47f (patch) | |
tree | b9e85c1cbc573ab72f2737ded50c9dab5bb3c6e1 /doc/doc-txt | |
parent | 6b31b1506cb3c0f48bd0bfd88b96cf04b0e95d91 (diff) |
Fix subtle but important bug in ip_connect(); it shouldn't close the
socket on a connection error. Also ensure that socket is closed in
iplookup.c after ip_connect() failure.
Diffstat (limited to 'doc/doc-txt')
-rw-r--r-- | doc/doc-txt/ChangeLog | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/doc/doc-txt/ChangeLog b/doc/doc-txt/ChangeLog index ddc8b47ab..fcf835025 100644 --- a/doc/doc-txt/ChangeLog +++ b/doc/doc-txt/ChangeLog @@ -1,4 +1,4 @@ -$Cambridge: exim/doc/doc-txt/ChangeLog,v 1.336 2006/04/04 08:35:39 ph10 Exp $ +$Cambridge: exim/doc/doc-txt/ChangeLog,v 1.337 2006/04/04 09:09:44 ph10 Exp $ Change log file for Exim from version 4.21 ------------------------------------------- @@ -340,6 +340,18 @@ PH/69 The HTML version of the specification is now built in a directory called PH/70 Catch two compiler warnings in sieve.c. +PH/71 Fixed an obscure and subtle bug (thanks Alexander & Matthias). The + function verify_get_ident() calls ip_connect() to connect a socket, but + if the "connect()" function timed out, ip_connect() used to close the + socket. However, verify_get_ident() also closes the socket later, and in + between Exim writes to the log, which may get opened at this point. When + the socket was closed in ip_connect(), the log could get the same file + descriptor number as the socket. This naturally causes chaos. The fix is + not to close the socket in ip_connect(); the socket should be closed by + the function that creates it. There was only one place in the code where + this was missing, in the iplookup router, which I don't think anybody now + uses, but I've fixed it anyway. + Exim version 4.60 ----------------- |