mac80211: remove ieee80211_notify_mac

Before ieee80211_notify_mac() was added, it was presented with the
use case of using it to tell mac80211 that the association may
have been lost because the firmware crashed/reset.

Since then, it has also been used by iwlwifi to (slightly) speed
up re-association after resume, a workaround around the fact that
mac80211 has no suspend/resume handling yet. It is also not used
by any other drivers, so clearly it cannot be necessary for "good
enough" suspend/resume.

Unfortunately, the callback suffers from a severe problem: It only
works for station mode. If suspend/resume happens while in IBSS or
any other mode (but station), then the callback is pointless.

Recently, it has created a number of locking issues, first because
it required rtnl locking rather than RCU due to calling sleeping
functions within the critical section, and now because it's called
by iwlwifi from the mac80211 workqueue that may not use the rtnl
because it is flushed under rtnl.
(cf. http://bugzilla.kernel.org/show_bug.cgi?id=12046)

I think, therefore, that we should take a step back, remove it
entirely for now and add the small feature it provided properly.
For suspend and resume we will need to introduce new hooks, and for
the case where the firmware was reset the driver will probably
simply just pretend it has done a suspend/resume cycle to get
mac80211 to reprogram the hardware completely, not just try to
connect to the current AP again in station mode. When doing so, we
will need to take into account locking issues and possibly defer
to schedule_work from within mac80211 for the resume operation,
while the suspend operation must be done directly.

Proper suspend/resume should also not necessarily try to reconnect
to the current AP, the time spent in suspend may have been short
enough to not be disconnected from the AP, mac80211 will detect
that the AP went out of range quickly if it did, and if the
association is lost then the AP will disassoc as soon as a data
frame is sent. We might also take into account WWOL then, and
have mac80211 program the hardware into such a mode where it is
available and requested.

Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>

authored by Johannes Berg and committed by John W. Linville 8e3bad65 9b44fb89

-44
-1
drivers/net/wireless/iwlwifi/iwl-agn.c
··· 2341 2341 mutex_lock(&priv->mutex); 2342 2342 iwl_alive_start(priv); 2343 2343 mutex_unlock(&priv->mutex); 2344 - ieee80211_notify_mac(priv->hw, IEEE80211_NOTIFY_RE_ASSOC); 2345 2344 } 2346 2345 2347 2346 static void iwl4965_bg_rf_kill(struct work_struct *work)
-1
drivers/net/wireless/iwlwifi/iwl3945-base.c
··· 6012 6012 mutex_lock(&priv->mutex); 6013 6013 iwl3945_alive_start(priv); 6014 6014 mutex_unlock(&priv->mutex); 6015 - ieee80211_notify_mac(priv->hw, IEEE80211_NOTIFY_RE_ASSOC); 6016 6015 } 6017 6016 6018 6017 static void iwl3945_bg_rf_kill(struct work_struct *work)
-20
include/net/mac80211.h
··· 74 74 */ 75 75 76 76 /** 77 - * enum ieee80211_notification_type - Low level driver notification 78 - * @IEEE80211_NOTIFY_RE_ASSOC: start the re-association sequence 79 - */ 80 - enum ieee80211_notification_types { 81 - IEEE80211_NOTIFY_RE_ASSOC, 82 - }; 83 - 84 - /** 85 77 * struct ieee80211_ht_bss_info - describing BSS's HT characteristics 86 78 * 87 79 * This structure describes most essential parameters needed ··· 1788 1796 */ 1789 1797 void ieee80211_stop_tx_ba_cb_irqsafe(struct ieee80211_hw *hw, const u8 *ra, 1790 1798 u16 tid); 1791 - 1792 - /** 1793 - * ieee80211_notify_mac - low level driver notification 1794 - * @hw: pointer as obtained from ieee80211_alloc_hw(). 1795 - * @notif_type: enum ieee80211_notification_types 1796 - * 1797 - * This function must be called by low level driver to inform mac80211 of 1798 - * low level driver status change or force mac80211 to re-assoc for low 1799 - * level driver internal error that require re-assoc. 1800 - */ 1801 - void ieee80211_notify_mac(struct ieee80211_hw *hw, 1802 - enum ieee80211_notification_types notif_type); 1803 1799 1804 1800 /** 1805 1801 * ieee80211_find_sta - find a station
-22
net/mac80211/mlme.c
··· 2560 2560 ieee80211_restart_sta_timer(sdata); 2561 2561 rcu_read_unlock(); 2562 2562 } 2563 - 2564 - /* driver notification call */ 2565 - void ieee80211_notify_mac(struct ieee80211_hw *hw, 2566 - enum ieee80211_notification_types notif_type) 2567 - { 2568 - struct ieee80211_local *local = hw_to_local(hw); 2569 - struct ieee80211_sub_if_data *sdata; 2570 - 2571 - switch (notif_type) { 2572 - case IEEE80211_NOTIFY_RE_ASSOC: 2573 - rtnl_lock(); 2574 - list_for_each_entry(sdata, &local->interfaces, list) { 2575 - if (sdata->vif.type != NL80211_IFTYPE_STATION) 2576 - continue; 2577 - 2578 - ieee80211_sta_req_auth(sdata, &sdata->u.sta); 2579 - } 2580 - rtnl_unlock(); 2581 - break; 2582 - } 2583 - } 2584 - EXPORT_SYMBOL(ieee80211_notify_mac);