]> git.baikalelectronics.ru Git - kernel.git/commit
net: sched: Do not drop root lock in tcf_qevent_handle()
authorPetr Machata <petrm@mellanox.com>
Tue, 14 Jul 2020 17:03:07 +0000 (20:03 +0300)
committerJakub Kicinski <kuba@kernel.org>
Thu, 16 Jul 2020 23:48:34 +0000 (16:48 -0700)
commit946dd37202327b56515d5376b3016a4c2d4fe296
tree6666f9802c95b192dc998a860b6c840d0a74a321
parent20be60c362dc4acebaae87e11bc2826920382604
net: sched: Do not drop root lock in tcf_qevent_handle()

Mirred currently does not mix well with blocks executed after the qdisc
root lock is taken. This includes classification blocks (such as in PRIO,
ETS, DRR qdiscs) and qevents. The locking caused by the packet mirrored by
mirred can cause deadlocks: either when the thread of execution attempts to
take the lock a second time, or when two threads end up waiting on each
other's locks.

The qevent patchset attempted to not introduce further badness of this
sort, and dropped the lock before executing the qevent block. However this
lead to too little locking and races between qdisc configuration and packet
enqueue in the RED qdisc.

Before the deadlock issues are solved in a way that can be applied across
many qdiscs reasonably easily, do for qevents what is done for the
classification blocks and just keep holding the root lock.

Signed-off-by: Petr Machata <petrm@mellanox.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
include/net/pkt_cls.h
net/sched/cls_api.c
net/sched/sch_red.c