Commit b8b80770 authored by Benjamin Berg's avatar Benjamin Berg Committed by Johannes Berg

wifi: mac80211: avoid lockdep checking when removing deflink

struct sta_info may be removed without holding sta_mtx if it has not
yet been inserted. To support this, only assert that the lock is held
for links other than the deflink.

This fixes lockdep issues that may be triggered in error cases.
Signed-off-by: default avatarBenjamin Berg <benjamin.berg@intel.com>
Signed-off-by: default avatarGregory Greenman <gregory.greenman@intel.com>
Link: https://lore.kernel.org/r/20230619161906.cdd81377dea0.If5a6734b4b85608a2275a09b4f99b5564d82997f@changeidSigned-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent 4484de23
...@@ -355,8 +355,9 @@ static void sta_remove_link(struct sta_info *sta, unsigned int link_id, ...@@ -355,8 +355,9 @@ static void sta_remove_link(struct sta_info *sta, unsigned int link_id,
struct sta_link_alloc *alloc = NULL; struct sta_link_alloc *alloc = NULL;
struct link_sta_info *link_sta; struct link_sta_info *link_sta;
link_sta = rcu_dereference_protected(sta->link[link_id], link_sta = rcu_access_pointer(sta->link[link_id]);
lockdep_is_held(&sta->local->sta_mtx)); if (link_sta != &sta->deflink)
lockdep_assert_held(&sta->local->sta_mtx);
if (WARN_ON(!link_sta)) if (WARN_ON(!link_sta))
return; return;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment