Commit e34870f8 authored by Roland Vossen's avatar Roland Vossen Committed by Greg Kroah-Hartman

staging: brcm80211: removed locks around Mac80211 calls

A spinlock was acquired prior to calling the Mac80211 functions
ieee80211_wake_queues() and ieee80211_stop_queues() and Cfg80211 functions
wiphy_rfkill_set_hw_state() and wiphy_rfkill_start_polling().
This is not required and could even lead to instability. Therefore the locks
were removed.
Signed-off-by: default avatarRoland Vossen <rvossen@broadcom.com>
Reviewed-by: default avatarArend van Spriel <arend@broadcom.com>
Reviewed-by: default avatarBrett Rudley <brudley@broadcom.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 55182a10
...@@ -171,9 +171,7 @@ static int wl_ops_start(struct ieee80211_hw *hw) ...@@ -171,9 +171,7 @@ static int wl_ops_start(struct ieee80211_hw *hw)
WL_NONE("%s : Initial channel: %d\n", __func__, curchan->hw_value); WL_NONE("%s : Initial channel: %d\n", __func__, curchan->hw_value);
*/ */
WL_LOCK(wl);
ieee80211_wake_queues(hw); ieee80211_wake_queues(hw);
WL_UNLOCK(wl);
blocked = wl_rfkill_set_hw_state(wl); blocked = wl_rfkill_set_hw_state(wl);
if (!blocked) if (!blocked)
wiphy_rfkill_stop_polling(wl->pub->ieee_hw->wiphy); wiphy_rfkill_stop_polling(wl->pub->ieee_hw->wiphy);
...@@ -185,9 +183,8 @@ static void wl_ops_stop(struct ieee80211_hw *hw) ...@@ -185,9 +183,8 @@ static void wl_ops_stop(struct ieee80211_hw *hw)
{ {
struct wl_info *wl = hw->priv; struct wl_info *wl = hw->priv;
ASSERT(wl); ASSERT(wl);
WL_LOCK(wl);
ieee80211_stop_queues(hw); ieee80211_stop_queues(hw);
WL_UNLOCK(wl); return;
} }
static int static int
...@@ -1988,8 +1985,10 @@ bool wl_rfkill_set_hw_state(struct wl_info *wl) ...@@ -1988,8 +1985,10 @@ bool wl_rfkill_set_hw_state(struct wl_info *wl)
WL_NONE("%s: update hw state: blocked=%s\n", __func__, WL_NONE("%s: update hw state: blocked=%s\n", __func__,
blocked ? "true" : "false"); blocked ? "true" : "false");
WL_UNLOCK(wl);
wiphy_rfkill_set_hw_state(wl->pub->ieee_hw->wiphy, blocked); wiphy_rfkill_set_hw_state(wl->pub->ieee_hw->wiphy, blocked);
if (blocked) if (blocked)
wiphy_rfkill_start_polling(wl->pub->ieee_hw->wiphy); wiphy_rfkill_start_polling(wl->pub->ieee_hw->wiphy);
WL_LOCK(wl);
return blocked; return blocked;
} }
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