]> git.ipfire.org Git - thirdparty/haproxy.git/commitdiff
BUG/MEDIUM: tasks: Make tasklet_remove_from_tasklet_list() no matter the tasklet.
authorOlivier Houchard <ohouchard@haproxy.com>
Fri, 8 Nov 2019 14:41:55 +0000 (15:41 +0100)
committerOlivier Houchard <cognet@ci0.org>
Sat, 9 Nov 2019 17:27:17 +0000 (18:27 +0100)
In tasklet_remove_from_tasket_list(), we can be called for a tasklet that is
either in the private task list, or in the shared tasklet list. Take that into
account and always use MT_LIST_DEL() to remove it, otherwise if we're in the
shared list and another thread attempts to add a tasklet in it, bad things
will happen.

__tasklet_remove_from_tasklet_list() is left unchanged, it's only supposed
to be used by process_runnable_task() to remove task/tasklets from the private
tast list.

This should not be backported.
This should fix github issue #357.

include/proto/task.h

index 5f2b144a7a0ae73420bd0906748faec3a107771d..b29d84a9144f60334d2e786322d2e2603905c18b 100644 (file)
@@ -270,8 +270,8 @@ static inline void __tasklet_remove_from_tasklet_list(struct tasklet *t)
 
 static inline void tasklet_remove_from_tasklet_list(struct tasklet *t)
 {
-       if (likely(!LIST_ISEMPTY(&t->list)))
-               __tasklet_remove_from_tasklet_list(t);
+       if (MT_LIST_DEL((struct mt_list *)&t->list))
+               _HA_ATOMIC_SUB(&tasks_run_queue, 1);
 }
 
 /*