]> git.ipfire.org Git - thirdparty/kernel/stable.git/commit
net/sched: sch_qfq: Fix race condition on qfq_aggregate
authorXiang Mei <xmei5@asu.edu>
Thu, 10 Jul 2025 10:09:42 +0000 (03:09 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 24 Jul 2025 06:51:51 +0000 (08:51 +0200)
commit466e10194ab81caa2ee6a332d33ba16bcceeeba6
treef126804b6fcd35f54e30020a81cf6fc45e3a6a12
parentd24d34c4ec1f02ad67a1954d81ef6d36eb452b48
net/sched: sch_qfq: Fix race condition on qfq_aggregate

[ Upstream commit 5e28d5a3f774f118896aec17a3a20a9c5c9dfc64 ]

A race condition can occur when 'agg' is modified in qfq_change_agg
(called during qfq_enqueue) while other threads access it
concurrently. For example, qfq_dump_class may trigger a NULL
dereference, and qfq_delete_class may cause a use-after-free.

This patch addresses the issue by:

1. Moved qfq_destroy_class into the critical section.

2. Added sch_tree_lock protection to qfq_dump_class and
qfq_dump_class_stats.

Fixes: 462dbc9101ac ("pkt_sched: QFQ Plus: fair-queueing service at DRR cost")
Signed-off-by: Xiang Mei <xmei5@asu.edu>
Reviewed-by: Cong Wang <xiyou.wangcong@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
net/sched/sch_qfq.c