comparison src/event/ngx_event_posted.h @ 7612:1ce3f01a4355

SSL: reworked posted next events. Introduced in 9d2ad2fb4423 available bytes handling in SSL relied on connection read handler being overwritten to set the ready flag and the amount of available bytes. This approach is, however, does not work properly when connection read handler is changed, for example, when switching to a next pipelined request, and can result in unexpected connection timeouts, see here: http://mailman.nginx.org/pipermail/nginx-devel/2019-December/012825.html Fix is to introduce ngx_event_process_posted_next() instead, which will set ready and available regardless of how event handler is set.
author Maxim Dounin <mdounin@mdounin.ru>
date Tue, 24 Dec 2019 17:24:59 +0300
parents 9d2ad2fb4423
children f1720934c45b
comparison
equal deleted inserted replaced
7611:8e64e11aaca0 7612:1ce3f01a4355
37 "delete posted event %p", ev); 37 "delete posted event %p", ev);
38 38
39 39
40 40
41 void ngx_event_process_posted(ngx_cycle_t *cycle, ngx_queue_t *posted); 41 void ngx_event_process_posted(ngx_cycle_t *cycle, ngx_queue_t *posted);
42 void ngx_event_process_posted_next(ngx_cycle_t *cycle, ngx_queue_t *posted);
42 43
43 44
44 extern ngx_queue_t ngx_posted_accept_events; 45 extern ngx_queue_t ngx_posted_accept_events;
45 extern ngx_queue_t ngx_posted_next_events; 46 extern ngx_queue_t ngx_posted_next_events;
46 extern ngx_queue_t ngx_posted_events; 47 extern ngx_queue_t ngx_posted_events;