Mercurial > hg > nginx
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; |