# HG changeset patch # User Valentin Bartenev # Date 1468949642 -10800 # Node ID b5d1c17181ca26a85258739092e311bec7deb65c # Parent e78eca6bfaf0ea22c9d864a41e6588dfd8a29370 HTTP/2: refactored ngx_http_v2_send_output_queue(). Now it returns NGX_AGAIN if there's still data to be sent. diff -r e78eca6bfaf0 -r b5d1c17181ca src/http/v2/ngx_http_v2.c --- a/src/http/v2/ngx_http_v2.c Tue Jul 19 20:31:09 2016 +0300 +++ b/src/http/v2/ngx_http_v2.c Tue Jul 19 20:34:02 2016 +0300 @@ -478,7 +478,7 @@ wev = c->write; if (!wev->ready) { - return NGX_OK; + return NGX_AGAIN; } cl = NULL; @@ -549,15 +549,6 @@ c->tcp_nodelay = NGX_TCP_NODELAY_SET; } - if (!wev->ready) { - ngx_add_timer(wev, clcf->send_timeout); - - } else { - if (wev->timer_set) { - ngx_del_timer(wev); - } - } - for ( /* void */ ; out; out = fn) { fn = out->next; @@ -582,6 +573,15 @@ h2c->last_out = frame; + if (!wev->ready) { + ngx_add_timer(wev, clcf->send_timeout); + return NGX_AGAIN; + } + + if (wev->timer_set) { + ngx_del_timer(wev); + } + return NGX_OK; error: