576df0
# ./pullrev.sh 1851471
576df0
http://svn.apache.org/viewvc?view=revision&revision=1851471
576df0
576df0
--- httpd-2.4.37/modules/ssl/ssl_engine_io.c
576df0
+++ httpd-2.4.37/modules/ssl/ssl_engine_io.c
576df0
@@ -200,6 +200,8 @@
576df0
     apr_bucket *e;
576df0
     int need_flush;
576df0
 
576df0
+    BIO_clear_retry_flags(bio);
576df0
+
576df0
     /* Abort early if the client has initiated a renegotiation. */
576df0
     if (outctx->filter_ctx->config->reneg_state == RENEG_ABORT) {
576df0
         outctx->rc = APR_ECONNABORTED;
576df0
@@ -206,12 +208,6 @@
576df0
         return -1;
576df0
     }
576df0
 
576df0
-    /* when handshaking we'll have a small number of bytes.
576df0
-     * max size SSL will pass us here is about 16k.
576df0
-     * (16413 bytes to be exact)
576df0
-     */
576df0
-    BIO_clear_retry_flags(bio);
576df0
-
576df0
     /* Use a transient bucket for the output data - any downstream
576df0
      * filter must setaside if necessary. */
576df0
     e = apr_bucket_transient_create(in, inl, outctx->bb->bucket_alloc);
576df0
@@ -458,6 +454,8 @@
576df0
     if (!in)
576df0
         return 0;
576df0
 
576df0
+    BIO_clear_retry_flags(bio);
576df0
+
576df0
     /* Abort early if the client has initiated a renegotiation. */
576df0
     if (inctx->filter_ctx->config->reneg_state == RENEG_ABORT) {
576df0
         inctx->rc = APR_ECONNABORTED;
576df0
@@ -464,8 +462,6 @@
576df0
         return -1;
576df0
     }
576df0
 
576df0
-    BIO_clear_retry_flags(bio);
576df0
-
576df0
     if (!inctx->bb) {
576df0
         inctx->rc = APR_EOF;
576df0
         return -1;