Commit 44e688bc authored by Richard Levitte's avatar Richard Levitte
Browse files

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 cb2e10f2

Reviewed-by: default avatarBernd Edlinger <bernd.edlinger@hotmail.de>
(Merged from https://github.com/openssl/openssl/pull/5074)

(cherry picked from commit 27da42d8)
parent cffda9f3
Loading
Loading
Loading
Loading
+5 −1
Original line number Diff line number Diff line
@@ -2461,7 +2461,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
@@ -2469,8 +2469,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