[nginx] svn commit: r4925 - trunk/src/http
mdounin at mdounin.ru
mdounin at mdounin.ru
Wed Nov 21 00:57:57 UTC 2012
Author: mdounin
Date: 2012-11-21 00:57:56 +0000 (Wed, 21 Nov 2012)
New Revision: 4925
URL: http://trac.nginx.org/nginx/changeset/4925/nginx
Log:
Request body: properly handle events while discarding body.
An attempt to call ngx_handle_read_event() before actually reading
data from a socket might result in read event being disabled, which is
wrong. Catched by body.t test on Solaris.
Modified:
trunk/src/http/ngx_http_request_body.c
Modified: trunk/src/http/ngx_http_request_body.c
===================================================================
--- trunk/src/http/ngx_http_request_body.c 2012-11-21 00:57:16 UTC (rev 4924)
+++ trunk/src/http/ngx_http_request_body.c 2012-11-21 00:57:56 UTC (rev 4925)
@@ -482,20 +482,22 @@
}
}
+ if (ngx_http_read_discarded_request_body(r) == NGX_OK) {
+ r->lingering_close = 0;
+ return NGX_OK;
+ }
+
+ /* == NGX_AGAIN */
+
r->read_event_handler = ngx_http_discarded_request_body_handler;
if (ngx_handle_read_event(rev, 0) != NGX_OK) {
return NGX_HTTP_INTERNAL_SERVER_ERROR;
}
- if (ngx_http_read_discarded_request_body(r) == NGX_OK) {
- r->lingering_close = 0;
+ r->count++;
+ r->discard_body = 1;
- } else {
- r->count++;
- r->discard_body = 1;
- }
-
return NGX_OK;
}
More information about the nginx-devel
mailing list