Eric Dumazet
d9bd9d4c60
net_sched: add __rcu annotation to netdev->qdisc
...
commit 5891cd5ec4
upstream.
syzbot found a data-race [1] which lead me to add __rcu
annotations to netdev->qdisc, and proper accessors
to get LOCKDEP support.
[1]
BUG: KCSAN: data-race in dev_activate / qdisc_lookup_rcu
write to 0xffff888168ad6410 of 8 bytes by task 13559 on cpu 1:
attach_default_qdiscs net/sched/sch_generic.c:1167 [inline]
dev_activate+0x2ed/0x8f0 net/sched/sch_generic.c:1221
__dev_open+0x2e9/0x3a0 net/core/dev.c:1416
__dev_change_flags+0x167/0x3f0 net/core/dev.c:8139
rtnl_configure_link+0xc2/0x150 net/core/rtnetlink.c:3150
__rtnl_newlink net/core/rtnetlink.c:3489 [inline]
rtnl_newlink+0xf4d/0x13e0 net/core/rtnetlink.c:3529
rtnetlink_rcv_msg+0x745/0x7e0 net/core/rtnetlink.c:5594
netlink_rcv_skb+0x14e/0x250 net/netlink/af_netlink.c:2494
rtnetlink_rcv+0x18/0x20 net/core/rtnetlink.c:5612
netlink_unicast_kernel net/netlink/af_netlink.c:1317 [inline]
netlink_unicast+0x602/0x6d0 net/netlink/af_netlink.c:1343
netlink_sendmsg+0x728/0x850 net/netlink/af_netlink.c:1919
sock_sendmsg_nosec net/socket.c:705 [inline]
sock_sendmsg net/socket.c:725 [inline]
____sys_sendmsg+0x39a/0x510 net/socket.c:2413
___sys_sendmsg net/socket.c:2467 [inline]
__sys_sendmsg+0x195/0x230 net/socket.c:2496
__do_sys_sendmsg net/socket.c:2505 [inline]
__se_sys_sendmsg net/socket.c:2503 [inline]
__x64_sys_sendmsg+0x42/0x50 net/socket.c:2503
do_syscall_x64 arch/x86/entry/common.c:50 [inline]
do_syscall_64+0x44/0xd0 arch/x86/entry/common.c:80
entry_SYSCALL_64_after_hwframe+0x44/0xae
read to 0xffff888168ad6410 of 8 bytes by task 13560 on cpu 0:
qdisc_lookup_rcu+0x30/0x2e0 net/sched/sch_api.c:323
__tcf_qdisc_find+0x74/0x3a0 net/sched/cls_api.c:1050
tc_del_tfilter+0x1c7/0x1350 net/sched/cls_api.c:2211
rtnetlink_rcv_msg+0x5ba/0x7e0 net/core/rtnetlink.c:5585
netlink_rcv_skb+0x14e/0x250 net/netlink/af_netlink.c:2494
rtnetlink_rcv+0x18/0x20 net/core/rtnetlink.c:5612
netlink_unicast_kernel net/netlink/af_netlink.c:1317 [inline]
netlink_unicast+0x602/0x6d0 net/netlink/af_netlink.c:1343
netlink_sendmsg+0x728/0x850 net/netlink/af_netlink.c:1919
sock_sendmsg_nosec net/socket.c:705 [inline]
sock_sendmsg net/socket.c:725 [inline]
____sys_sendmsg+0x39a/0x510 net/socket.c:2413
___sys_sendmsg net/socket.c:2467 [inline]
__sys_sendmsg+0x195/0x230 net/socket.c:2496
__do_sys_sendmsg net/socket.c:2505 [inline]
__se_sys_sendmsg net/socket.c:2503 [inline]
__x64_sys_sendmsg+0x42/0x50 net/socket.c:2503
do_syscall_x64 arch/x86/entry/common.c:50 [inline]
do_syscall_64+0x44/0xd0 arch/x86/entry/common.c:80
entry_SYSCALL_64_after_hwframe+0x44/0xae
value changed: 0xffffffff85dee080 -> 0xffff88815d96ec00
Reported by Kernel Concurrency Sanitizer on:
CPU: 0 PID: 13560 Comm: syz-executor.2 Not tainted 5.17.0-rc3-syzkaller-00116-gf1baf68e1383-dirty #0
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011
Fixes: 470502de5b
("net: sched: unlock rules update API")
Signed-off-by: Eric Dumazet <edumazet@google.com >
Cc: Vlad Buslov <vladbu@mellanox.com >
Reported-by: syzbot <syzkaller@googlegroups.com >
Cc: Jamal Hadi Salim <jhs@mojatatu.com >
Cc: Cong Wang <xiyou.wangcong@gmail.com >
Cc: Jiri Pirko <jiri@resnulli.us >
Signed-off-by: David S. Miller <davem@davemloft.net >
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org >
2022-02-23 12:01:02 +01:00
..
2020-09-25 13:58:01 -07:00
2021-02-17 11:02:28 +01:00
2020-09-28 15:00:15 -07:00
2021-03-07 12:34:07 +01:00
2022-01-27 10:54:30 +01:00
2022-01-27 10:54:34 +01:00
2022-02-23 12:01:02 +01:00
2021-12-08 09:03:22 +01:00
2021-03-30 14:32:05 +02:00
2019-10-04 11:10:56 -07:00
2021-12-08 09:03:21 +01:00
2022-01-27 10:54:16 +01:00
2021-09-18 13:40:22 +02:00
2021-09-18 13:40:30 +02:00
2021-01-27 11:55:23 +01:00
2020-04-28 14:39:46 -07:00
2020-11-25 11:28:12 -08:00
2019-06-09 19:40:10 -07:00
2021-08-18 08:59:13 +02:00
2020-12-07 11:53:40 -08:00
2022-01-11 15:25:00 +01:00
2019-12-12 17:07:05 -08:00
2021-12-14 11:32:43 +01:00
2022-01-27 10:54:33 +01:00
2022-02-01 17:25:44 +01:00
2022-01-27 10:54:15 +01:00
2020-02-26 20:07:25 -08:00
2019-06-19 11:23:13 -04:00
2020-04-21 15:44:30 -07:00
2020-11-18 11:04:11 -08:00
2020-05-09 20:59:21 -07:00
2021-05-19 10:13:17 +02:00
2021-03-07 12:34:09 +01:00
2020-08-19 16:07:49 -07:00
2019-10-13 10:13:08 -07:00
2022-02-23 12:01:02 +01:00
2020-07-13 11:03:44 -07:00
2020-05-08 15:32:17 +10:00
2021-12-22 09:30:55 +01:00
2021-08-04 12:46:44 +02:00
2020-09-30 11:50:35 -07:00
2021-12-17 10:14:41 +01:00
2021-01-23 16:03:59 +01:00
2021-11-26 10:39:14 +01:00
2021-11-18 14:04:08 +01:00
2021-11-18 14:03:42 +01:00
2019-12-25 19:51:33 -08:00
2020-06-18 20:46:23 -07:00
2020-01-24 20:54:30 +01:00
2021-04-14 08:42:09 +02:00