Message ID | 20210517163807.4d305e53c177.Ic19a47c0690e366ee84e3957b73ec6baddffad8a@changeid (mailing list archive) |
---|---|
State | Not Applicable |
Delegated to: | Johannes Berg |
Headers | show |
Series | [net] netlink: disable IRQs for netlink_lock_table() | expand |
Hello: This patch was applied to netdev/net.git (refs/heads/master): On Mon, 17 May 2021 16:38:09 +0200 you wrote: > From: Johannes Berg <johannes.berg@intel.com> > > Syzbot reports that in mac80211 we have a potential deadlock > between our "local->stop_queue_reasons_lock" (spinlock) and > netlink's nl_table_lock (rwlock). This is because there's at > least one situation in which we might try to send a netlink > message with this spinlock held while it is also possible to > take the spinlock from a hardirq context, resulting in the > following deadlock scenario reported by lockdep: > > [...] Here is the summary with links: - [net] netlink: disable IRQs for netlink_lock_table() https://git.kernel.org/netdev/net/c/1d482e666b8e You are awesome, thank you! -- Deet-doot-dot, I am a bot. https://korg.docs.kernel.org/patchwork/pwbot.html
diff --git a/net/netlink/af_netlink.c b/net/netlink/af_netlink.c index 3a62f97acf39..6133e412b948 100644 --- a/net/netlink/af_netlink.c +++ b/net/netlink/af_netlink.c @@ -461,11 +461,13 @@ void netlink_table_ungrab(void) static inline void netlink_lock_table(void) { + unsigned long flags; + /* read_lock() synchronizes us to netlink_table_grab */ - read_lock(&nl_table_lock); + read_lock_irqsave(&nl_table_lock, flags); atomic_inc(&nl_table_users); - read_unlock(&nl_table_lock); + read_unlock_irqrestore(&nl_table_lock, flags); } static inline void