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();