BUG/MAJOR: sched: make sure task_kill() always queues the task

task_kill() may fail to queue a task if this task has never ever run,
because its equivalent (tasklet->list) member has never been "emptied"
since it didn't pass through the LIST_DEL_INIT() that's performed by
run_tasks_from_lists(). This results in these tasks to never be freed.

It happens during the mux takeover since the target task usually is
the timeout task which, by definition, has never run yet.

This fixes commit eb8c2c69f ("MEDIUM: sched: implement task_kill() to
kill a task") which was introduced after 2.2-dev11 and doesn't need to
be backported.
diff --git a/src/task.c b/src/task.c
index 761fc29..7ce1cd2 100644
--- a/src/task.c
+++ b/src/task.c
@@ -94,16 +94,18 @@
 			 * the task's first thread for the job.
 			 */
 			thr = my_ffsl(t->thread_mask) - 1;
-			if (MT_LIST_ADDQ(&task_per_thread[thr].shared_tasklet_list,
-			                 (struct mt_list *)&((struct tasklet *)t)->list)) {
-				_HA_ATOMIC_ADD(&tasks_run_queue, 1);
-				_HA_ATOMIC_ADD(&task_per_thread[thr].task_list_size, 1);
-				if (sleeping_thread_mask & (1UL << thr)) {
-					_HA_ATOMIC_AND(&sleeping_thread_mask, ~(1UL << thr));
-					wake_thread(thr);
-				}
-				return;
+
+			/* Beware: tasks that have never run don't have their ->list empty yet! */
+			LIST_INIT(&((struct tasklet *)t)->list);
+			BUG_ON(!MT_LIST_ADDQ(&task_per_thread[thr].shared_tasklet_list,
+			                     (struct mt_list *)&((struct tasklet *)t)->list));
+			_HA_ATOMIC_ADD(&tasks_run_queue, 1);
+			_HA_ATOMIC_ADD(&task_per_thread[thr].task_list_size, 1);
+			if (sleeping_thread_mask & (1UL << thr)) {
+				_HA_ATOMIC_AND(&sleeping_thread_mask, ~(1UL << thr));
+				wake_thread(thr);
 			}
+			return;
 		}
 	}
 }