diff options
author | Richard Levitte <levitte@openssl.org> | 2018-01-14 17:15:32 +0100 |
---|---|---|
committer | Richard Levitte <levitte@openssl.org> | 2018-01-14 22:13:39 +0100 |
commit | 27da42d85212f80fc0db02b1cedf1d49fbfb8c43 (patch) | |
tree | 9be1343b4a23d62367442930bbc806c43498dab8 /apps/s_client.c | |
parent | 803141f6100ca8d756928328a262e1dc52daef2d (diff) |
Fix intermittent Cygwin failures in s_client
This was identified for Windows almost two years ago for VC and
msys/mingw. It seems that Cygwin suffers from the same issue, and
since Cygwin doesn't define OPENSSL_SYS_WINDOWS, we need to make a
special case to have a 50ms pause before closing the TLS connection.
Ref: git commit cb2e10f257a464c6b475b321dd9e4769df84dbf6
Reviewed-by: Bernd Edlinger <bernd.edlinger@hotmail.de>
(Merged from https://github.com/openssl/openssl/pull/5074)
Diffstat (limited to 'apps/s_client.c')
-rw-r--r-- | apps/s_client.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/apps/s_client.c b/apps/s_client.c index a549304b34..218accf0f9 100644 --- a/apps/s_client.c +++ b/apps/s_client.c @@ -3025,7 +3025,7 @@ int s_client_main(int argc, char **argv) if (in_init) print_stuff(bio_c_out, con, full_log); do_ssl_shutdown(con); -#if defined(OPENSSL_SYS_WINDOWS) + /* * Give the socket time to send its last data before we close it. * No amount of setting SO_LINGER etc on the socket seems to persuade @@ -3033,8 +3033,12 @@ int s_client_main(int argc, char **argv) * for a short time seems to do it (units in ms) * TODO: Find a better way to do this */ +#if defined(OPENSSL_SYS_WINDOWS) Sleep(50); +#elif defined(OPENSSL_SYS_CYGWIN) + usleep(50000); #endif + /* * If we ended with an alert being sent, but still with data in the * network buffer to be read, then calling BIO_closesocket() will |