diff options
author | Ruediger Pluem <rpluem@apache.org> | 2020-04-01 21:30:49 +0200 |
---|---|---|
committer | Ruediger Pluem <rpluem@apache.org> | 2020-04-01 21:30:49 +0200 |
commit | fd5afc092ccd71a4e48a0f6c891ed6e1b14e187f (patch) | |
tree | fa451316fc6365eeb261eb4baac2f0cca4bf409b | |
parent | ap_core_output_filter: follow up to r1875947: don't swallow bucket read EOF. (diff) | |
download | apache2-fd5afc092ccd71a4e48a0f6c891ed6e1b14e187f.tar.xz apache2-fd5afc092ccd71a4e48a0f6c891ed6e1b14e187f.zip |
* modules/ssl/ssl_engine_io.c (ssl_io_filter_coalesce): Handle the case
where apr_bucket_read fails with an error and hence our current bucket
remains the morphing bucket and is not replaced with a 'data' bucket.
If the error is not EAGAINi, error out with an AP_FILTER_ERROR,
otherwise just do not consider the morphing bucket that has no data for
coalesce.
git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1876014 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r-- | modules/ssl/ssl_engine_io.c | 58 |
1 files changed, 29 insertions, 29 deletions
diff --git a/modules/ssl/ssl_engine_io.c b/modules/ssl/ssl_engine_io.c index 35ccc14ec5..4880c5b6a2 100644 --- a/modules/ssl/ssl_engine_io.c +++ b/modules/ssl/ssl_engine_io.c @@ -1739,7 +1739,7 @@ static apr_status_t ssl_io_filter_coalesce(ap_filter_t *f, && bytes + buffered < COALESCE_BYTES && e != APR_BRIGADE_SENTINEL(bb) && !APR_BUCKET_IS_METADATA(e)) { - apr_status_t rv; + apr_status_t rv = APR_SUCCESS; /* For an indeterminate length bucket (PIPE/CGI/...), try a * non-blocking read to have it morph into a HEAP. If the @@ -1753,38 +1753,38 @@ static apr_status_t ssl_io_filter_coalesce(ap_filter_t *f, if (rv != APR_SUCCESS && !APR_STATUS_IS_EAGAIN(rv)) { ap_log_cerror(APLOG_MARK, APLOG_ERR, rv, f->c, APLOGNO(10232) "coalesce failed to read from data bucket"); + return AP_FILTER_ERROR; } } - /* If the read above made the bucket morph, it may now fit - * entirely within the buffer. Otherwise, split it so it does - * fit. */ - if (e->length < COALESCE_BYTES - && e->length + buffered + bytes < COALESCE_BYTES) { - rv = APR_SUCCESS; - } - else { - rv = apr_bucket_split(e, COALESCE_BYTES - (buffered + bytes)); - } - - if (rv == APR_SUCCESS && e->length == 0) { - /* As above, don't count in the prefix if the bucket is - * now zero-length. */ - } - else if (rv == APR_SUCCESS) { - ap_log_cerror(APLOG_MARK, APLOG_TRACE4, 0, f->c, - "coalesce: adding %" APR_SIZE_T_FMT " bytes " - "from split bucket, adding %" APR_SIZE_T_FMT, - e->length, bytes + buffered); + if (rv == APR_SUCCESS) { + /* If the read above made the bucket morph, it may now fit + * entirely within the buffer. Otherwise, split it so it does + * fit. */ + if (e->length >= COALESCE_BYTES + || e->length + buffered + bytes >= COALESCE_BYTES) { + rv = apr_bucket_split(e, COALESCE_BYTES - (buffered + bytes)); + } - count++; - bytes += e->length; - e = APR_BUCKET_NEXT(e); - } - else if (rv != APR_ENOTIMPL) { - ap_log_cerror(APLOG_MARK, APLOG_ERR, rv, f->c, APLOGNO(10233) - "coalesce: failed to split data bucket"); - return AP_FILTER_ERROR; + if (rv == APR_SUCCESS && e->length == 0) { + /* As above, don't count in the prefix if the bucket is + * now zero-length. */ + } + else if (rv == APR_SUCCESS) { + ap_log_cerror(APLOG_MARK, APLOG_TRACE4, 0, f->c, + "coalesce: adding %" APR_SIZE_T_FMT " bytes " + "from split bucket, adding %" APR_SIZE_T_FMT, + e->length, bytes + buffered); + + count++; + bytes += e->length; + e = APR_BUCKET_NEXT(e); + } + else if (rv != APR_ENOTIMPL) { + ap_log_cerror(APLOG_MARK, APLOG_ERR, rv, f->c, APLOGNO(10233) + "coalesce: failed to split data bucket"); + return AP_FILTER_ERROR; + } } } |