net: avoid race between device unregistration and ethnl ops
[ Upstream commit 12e070eb ] The following trace can be seen if a device is being unregistered while its number of channels are being modified. DEBUG_LOCKS_WARN_ON(lock->magic != lock) WARNING: CPU: 3 PID: 3754 at kernel/locking/mutex.c:564 __mutex_lock+0xc8a/0x1120 CPU: 3 UID: 0 PID: 3754 Comm: ethtool Not tainted 6.13.0-rc6+ #771 RIP: 0010:__mutex_lock+0xc8a/0x1120 Call Trace: <TASK> ethtool_check_max_channel+0x1ea/0x880 ethnl_set_channels+0x3c3/0xb10 ethnl_default_set_doit+0x306/0x650 genl_family_rcv_msg_doit+0x1e3/0x2c0 genl_rcv_msg+0x432/0x6f0 netlink_rcv_skb+0x13d/0x3b0 genl_rcv+0x28/0x40 netlink_unicast+0x42e/0x720 netlink_sendmsg+0x765/0xc20 __sys_sendto+0x3ac/0x420 __x64_sys_sendto+0xe0/0x1c0 do_syscall_64+0x95/0x180 entry_SYSCALL_64_after_hwframe+0x76/0x7e This is because unregister_netdevice_many_notify might run before the rtnl lock section of ethnl operations, eg. set_channels in the above example. In this example the rss lock would be destroyed by the device unregistration path before being used again, but in general running ethnl operations while dismantle has started is not a good idea. Fix this by denying any operation on devices being unregistered. A check was already there in ethnl_ops_begin, but not wide enough. Note that the same issue cannot be seen on the ioctl version (__dev_ethtool) because the device reference is retrieved from within the rtnl lock section there. Once dismantle started, the net device is unlisted and no reference will be found. Fixes: dde91ccf ("ethtool: do not perform operations on net devices being unregistered") Signed-off-by:Antoine Tenart <atenart@kernel.org> Reviewed-by:
Przemek Kitszel <przemyslaw.kitszel@intel.com> Reviewed-by:
Edward Cree <ecree.xilinx@gmail.com> Link: https://patch.msgid.link/20250116092159.50890-1-atenart@kernel.org Signed-off-by:
Jakub Kicinski <kuba@kernel.org> Signed-off-by:
Sasha Levin <sashal@kernel.org>
-
mentioned in commit 96ddb774
-
mentioned in commit 709165b1
-
mentioned in commit eab4bb09
-
mentioned in commit d4e05c7d
-
mentioned in commit 07c1df18
-
mentioned in commit faca4ecc
-
mentioned in commit 3f31d866
-
mentioned in commit 0d0226a1
-
mentioned in commit fe2e168a
-
mentioned in commit 6c3a4ac3
-
mentioned in commit 0ad95192
-
mentioned in commit a63c7930
-
mentioned in commit 07b1ff85
-
mentioned in commit 901cd3d5
-
mentioned in commit 079f1fe2
-
mentioned in commit 7f2e502f
-
mentioned in commit 4e3084cb
-
mentioned in commit 2644bd20
-
mentioned in commit d16ec4f3
-
mentioned in commit 21c4eb17
-
mentioned in commit f2c25a3f
-
mentioned in commit 57a74fed
-
mentioned in commit 8b9829df
-
mentioned in commit fe59dc05
-
mentioned in commit 2406ed8c
-
mentioned in commit 524c4fcb
-
mentioned in commit 23e2e493
-
mentioned in commit 3cc96319
-
mentioned in commit 6064ff4e
-
mentioned in commit 9a444f37
-
mentioned in commit 2afd0800
-
mentioned in commit 1c9aeb1c
-
mentioned in commit 32650097
-
mentioned in commit 6cac4b51
-
mentioned in commit 6960fd82
-
mentioned in commit 723d107d
-
mentioned in commit 65b4e562
-
mentioned in commit ed8f6dad
-
mentioned in commit 11721150
-
mentioned in commit 97ef534d