Fix from main trunk, 2000-09-26 13:30 bodo:
authorRichard Levitte <levitte@openssl.org>
Wed, 11 Oct 2000 09:15:53 +0000 (09:15 +0000)
committerRichard Levitte <levitte@openssl.org>
Wed, 11 Oct 2000 09:15:53 +0000 (09:15 +0000)
Don't modify s->read_ahead in SSL_clear, which is called from
accept/connect functions; those should not change the read_ahead
setting of the SSL structure.

Fix from main trunk, 2000-09-26 13:38  bodo:

Set s->read_ahead in SSL_new because SSL_clear no longer modifies it.

ssl/ssl_lib.c

index 635b25062e8b4775d7a9d73554fbad327f3cc89e..fec98dd8f43d44eee71df442be777ec74a43c4a6 100644 (file)
@@ -119,7 +119,9 @@ int SSL_clear(SSL *s)
        s->client_version=s->version;
        s->rwstate=SSL_NOTHING;
        s->rstate=SSL_ST_READ_HEADER;
+#if 0
        s->read_ahead=s->ctx->read_ahead;
+#endif
 
        if (s->init_buf != NULL)
                {
@@ -229,6 +231,7 @@ SSL *SSL_new(SSL_CTX *ctx)
        s->server=(ctx->method->ssl_accept == ssl_undefined_function)?0:1;
        s->options=ctx->options;
        s->mode=ctx->mode;
+       s->read_ahead=ctx->read_ahead; /* used to happen in SSL_clear */
        SSL_clear(s);
 
        CRYPTO_new_ex_data(ssl_meth,s,&s->ex_data);