MINOR: haproxy: process signals before runnable tasks
Nowadays signals cause tasks to be woken up. The historic code still
processes signals after tasks, which forces a second round in the loop
before they can effectively be processed. Let's move the signal queue
handling between wake_expired_tasks() and process_runnable_tasks() where
it makes much more sense.
diff --git a/src/haproxy.c b/src/haproxy.c
index 06e5a22..8f50486 100644
--- a/src/haproxy.c
+++ b/src/haproxy.c
@@ -2889,13 +2889,15 @@
while (1) {
wake_expired_tasks();
- /* Process a few tasks */
- process_runnable_tasks();
-
/* check if we caught some signals and process them in the
first thread */
- if (tid == 0)
+ if (signal_queue_len && tid == 0) {
+ activity[tid].wake_signal++;
signal_process_queue();
+ }
+
+ /* Process a few tasks */
+ process_runnable_tasks();
/* also stop if we failed to cleanly stop all tasks */
if (killed > 1)
@@ -2905,8 +2907,6 @@
wake = 1;
if (thread_has_tasks())
activity[tid].wake_tasks++;
- else if (signal_queue_len && tid == 0)
- activity[tid].wake_signal++;
else {
_HA_ATOMIC_OR(&sleeping_thread_mask, tid_bit);
__ha_barrier_atomic_store();