2023-06-11 04:43:03

by Peilin Ye

[permalink] [raw]
Subject: [PATCH net 0/2] net/sched: Fix race conditions in mini_qdisc_pair_swap()

Hi all,

These 2 patches fix race conditions for ingress and clsact Qdiscs as
reported [1] by syzbot, split out from another [2] series (last 2 patches
of it). Per-patch changelog omitted.

Patch 1 hasn't been touched since last version; I just included
everybody's tag.

Patch 2 bases on patch 6 v1 of [2], with comments and commit log slightly
changed. We also need rtnl_dereference() to load ->qdisc_sleeping since
commit d636fc5dd692 ("net: sched: add rcu annotations around
qdisc->qdisc_sleeping"), so I changed that; please take yet another look,
thanks!

Patch 2 has been tested with the new reproducer Pedro posted [3].

[1] https://syzkaller.appspot.com/bug?extid=b53a9c0d1ea4ad62da8b
[2] https://lore.kernel.org/r/[email protected]/
[3] https://lore.kernel.org/r/[email protected]/

Thanks,
Peilin Ye (2):
net/sched: Refactor qdisc_graft() for ingress and clsact Qdiscs
net/sched: qdisc_destroy() old ingress and clsact Qdiscs before
grafting

include/net/sch_generic.h | 8 +++++++
net/sched/sch_api.c | 44 +++++++++++++++++++++++++++------------
net/sched/sch_generic.c | 14 ++++++++++---
3 files changed, 50 insertions(+), 16 deletions(-)

--
2.20.1



2023-06-14 09:01:08

by patchwork-bot+netdevbpf

[permalink] [raw]
Subject: Re: [PATCH net 0/2] net/sched: Fix race conditions in mini_qdisc_pair_swap()

Hello:

This series was applied to netdev/net.git (main)
by Paolo Abeni <[email protected]>:

On Sat, 10 Jun 2023 20:29:41 -0700 you wrote:
> Hi all,
>
> These 2 patches fix race conditions for ingress and clsact Qdiscs as
> reported [1] by syzbot, split out from another [2] series (last 2 patches
> of it). Per-patch changelog omitted.
>
> Patch 1 hasn't been touched since last version; I just included
> everybody's tag.
>
> [...]

Here is the summary with links:
- [net,1/2] net/sched: Refactor qdisc_graft() for ingress and clsact Qdiscs
https://git.kernel.org/netdev/net/c/2d5f6a8d7aef
- [net,2/2] net/sched: qdisc_destroy() old ingress and clsact Qdiscs before grafting
https://git.kernel.org/netdev/net/c/84ad0af0bccd

You are awesome, thank you!
--
Deet-doot-dot, I am a bot.
https://korg.docs.kernel.org/patchwork/pwbot.html