]> git.ipfire.org Git - thirdparty/apache/httpd.git/commitdiff
mod_ssl: follow up to r1844779: fix rollback in char_buffer_consume().
authorYann Ylavic <ylavic@apache.org>
Wed, 24 Oct 2018 15:43:35 +0000 (15:43 +0000)
committerYann Ylavic <ylavic@apache.org>
Wed, 24 Oct 2018 15:43:35 +0000 (15:43 +0000)
This needs the same bucket insertion code as in char_buffer_write(), so define
a new char_buffer_insert() helper.

git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1844781 13f79535-47bb-0310-9956-ffa450edef68

modules/ssl/ssl_engine_io.c

index deb807a7dd4ad857b187ae819b634f3838d4bd39..37e8314b7ca38f5c09f7ffd1ceb8d1b0be482c71 100644 (file)
@@ -344,6 +344,17 @@ typedef struct {
  * any of this data and we need to remember the length.
  */
 
+static void char_buffer_insert(bio_filter_in_ctx_t *inctx)
+{
+    char_buffer_t *buf = &inctx->cbuf;
+    ap_filter_t *f = inctx->filter_ctx->pInputFilter;
+
+    /* set the bucket at the top of the filter's pending data */
+    ap_filter_reinstate_brigade(f, buf->bb, NULL);
+    APR_BRIGADE_INSERT_HEAD(buf->bb, buf->b);
+    ap_filter_adopt_brigade(f, buf->bb);
+}
+
 static void char_buffer_consume(bio_filter_in_ctx_t *inctx, int inl)
 {
     apr_bucket *b = inctx->cbuf.b;
@@ -357,7 +368,7 @@ static void char_buffer_consume(bio_filter_in_ctx_t *inctx, int inl)
     }
     else if (APR_BUCKET_NEXT(b) == b) {
         /* rollbacks might get us here (inl < 0) */
-        APR_BRIGADE_INSERT_HEAD(inctx->cbuf.bb, b);
+        char_buffer_insert(inctx);
     }
 }
 
@@ -369,8 +380,8 @@ static void char_buffer_consume(bio_filter_in_ctx_t *inctx, int inl)
  * presumed to be non-overlapping, and memmove must be used. */
 static int char_buffer_read(bio_filter_in_ctx_t *inctx, char *in, int inl)
 {
-    apr_bucket *b = inctx->cbuf.b;
-    int avail = b ? b->length : 0;
+    char_buffer_t *buf = &inctx->cbuf;
+    int avail = buf->b ? buf->b->length : 0;
 
     if (!avail) {
         return 0;
@@ -379,7 +390,7 @@ static int char_buffer_read(bio_filter_in_ctx_t *inctx, char *in, int inl)
     if (inl > avail) {
         inl = avail;
     }
-    memmove(in, b->data, inl);
+    memmove(in, buf->b->data, inl);
     char_buffer_consume(inctx, inl);
 
     return inl;
@@ -387,25 +398,21 @@ static int char_buffer_read(bio_filter_in_ctx_t *inctx, char *in, int inl)
 
 static int char_buffer_write(bio_filter_in_ctx_t *inctx, char *in, int inl)
 {
-    ap_filter_t *f = inctx->filter_ctx->pInputFilter;
     char_buffer_t *buf = &inctx->cbuf;
-    apr_bucket *b = buf->b;
 
-    if (!b) {
-        buf->b = b = apr_bucket_immortal_create("", 0, f->c->bucket_alloc);
-        buf->bb = apr_brigade_create(f->c->pool, f->c->bucket_alloc);
+    if (buf->b) {
+        AP_DEBUG_ASSERT(APR_BUCKET_NEXT(buf->b) == buf->b);
     }
     else {
-        AP_DEBUG_ASSERT(APR_BUCKET_NEXT(b) == b);
+        ap_filter_t *f = inctx->filter_ctx->pInputFilter;
+        buf->b = apr_bucket_immortal_create("", 0, f->c->bucket_alloc);
+        buf->bb = apr_brigade_create(f->c->pool, f->c->bucket_alloc);
     }
 
-    b->data = in;
-    b->length = inl;
-    if (b->length) {
-        /* set this at the top of the filter's pending data */
-        ap_filter_reinstate_brigade(f, buf->bb, NULL);
-        APR_BRIGADE_INSERT_HEAD(buf->bb, b);
-        ap_filter_adopt_brigade(f, buf->bb);
+    buf->b->data = in;
+    buf->b->length = inl;
+    if (buf->b->length) {
+        char_buffer_insert(inctx);
     }
 
     return inl;