Call to ieee80211_color_collision_detection_work() needs wiphy lock to be
held. This lock cannot be taken directly in the delayed work because it
would cause a potential deadlock. Indeed ieee80211_link_stop() is calling
cancel_delayed_work_sync() with the lock held. To avoid such deadlock one
can use a wiphy delayed work instead.
Thus this patchset convert ieee80211_color_collision_detection_work() to
use wiphy delayed work instead of classical delayed work. But because
this work is used to ratelimit cfg80211_obss_color_collision_notify() a
way to tell if it has already been scheduled is needed as discussed in
[0]. In this thread three different solutions has been considered:
- Implementing wiphy_delayed_work_pending() to detect if work can be
queued without postponing a previous schedule
- Using a __ratelimit or an equivalent to queue the work
- Modifying wiphy_delayed_work_queue() to mimic queue_delayed_work() by
not queuing the work if already queued (while also possibly having to
add wiphy_delayed_work_mod() for those who need the mod_delayed_work()
behavior).
This patchset implement the first solution.
[0]: https://lore.kernel.org/linux-wireless/D4A40Q44OAY2.W3SIF6UEPBUN@freebox.fr/
Remi Pommarel (2):
wifi: cfg80211: Add wiphy_delayed_work_pending()
wifi: mac80211: Convert color collision detection to wiphy work
include/net/cfg80211.h | 44 ++++++++++++++++++++++++++++++++++++++
net/mac80211/cfg.c | 17 ++++++++-------
net/mac80211/ieee80211_i.h | 5 +++--
net/mac80211/link.c | 7 +++---
net/wireless/core.c | 7 ++++++
5 files changed, 67 insertions(+), 13 deletions(-)
--
2.46.0