comparison src/event/ngx_event_posted.h @ 7617:f1720934c45b

SSL: reworked posted next events again. Previous change 1ce3f01a4355 incorrectly introduced processing of the ngx_posted_next_events queue at the end of operation, effectively making posted next events a nop, since at the end of an event loop iteration the queue is always empty. Correct approach is to move events to the ngx_posted_events queue at an iteration start, as it was done previously. Further, in some cases the c->read event might be already in the ngx_posted_events queue, and calling ngx_post_event() with the ngx_posted_next_events queue won't do anything. To make sure the event will be correctly placed into the ngx_posted_next_events queue we now check if it is already posted.
author Maxim Dounin <mdounin@mdounin.ru>
date Fri, 27 Dec 2019 19:43:01 +0300
parents 1ce3f01a4355
children
comparison
equal deleted inserted replaced
7616:fd4d2155d3e6 7617:f1720934c45b
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 void ngx_event_move_posted_next(ngx_cycle_t *cycle);
43 43
44 44
45 extern ngx_queue_t ngx_posted_accept_events; 45 extern ngx_queue_t ngx_posted_accept_events;
46 extern ngx_queue_t ngx_posted_next_events; 46 extern ngx_queue_t ngx_posted_next_events;
47 extern ngx_queue_t ngx_posted_events; 47 extern ngx_queue_t ngx_posted_events;