Commit 3956b4a2 authored by Arend van Spriel's avatar Arend van Spriel Committed by Greg Kroah-Hartman

staging: brcm80211: remove locking macro definitions

The driver contained locking macros which map directly to the
lock function provided by the kernel. It does not provide any
additional value so these have been removed.
Reported-by: default avatarJohannes Berg <johannes@sipsolutions.net>
Reviewed-by: default avatarRoland Vossen <rvossen@broadcom.com>
Reviewed-by: default avatarAlwin Beukers <alwin@broadcom.com>
Signed-off-by: default avatarArend van Spriel <arend@broadcom.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 7ddaad7e
...@@ -35,26 +35,6 @@ ...@@ -35,26 +35,6 @@
#define N_TX_QUEUES 4 /* #tx queues on mac80211<->driver interface */ #define N_TX_QUEUES 4 /* #tx queues on mac80211<->driver interface */
#define LOCK(wl) spin_lock_bh(&(wl)->lock)
#define UNLOCK(wl) spin_unlock_bh(&(wl)->lock)
/* locking from inside brcms_isr */
#define ISR_LOCK(wl, flags)\
do {\
spin_lock(&(wl)->isr_lock);\
(void)(flags); } \
while (0)
#define ISR_UNLOCK(wl, flags)\
do {\
spin_unlock(&(wl)->isr_lock);\
(void)(flags); } \
while (0)
/* locking under LOCK() to synchronize with brcms_isr */
#define INT_LOCK(wl, flags) spin_lock_irqsave(&(wl)->isr_lock, flags)
#define INT_UNLOCK(wl, flags) spin_unlock_irqrestore(&(wl)->isr_lock, flags)
/* Flags we support */ /* Flags we support */
#define MAC_FILTERS (FIF_PROMISC_IN_BSS | \ #define MAC_FILTERS (FIF_PROMISC_IN_BSS | \
FIF_ALLMULTI | \ FIF_ALLMULTI | \
...@@ -291,7 +271,7 @@ static void brcms_ops_tx(struct ieee80211_hw *hw, struct sk_buff *skb) ...@@ -291,7 +271,7 @@ static void brcms_ops_tx(struct ieee80211_hw *hw, struct sk_buff *skb)
{ {
struct brcms_info *wl = hw->priv; struct brcms_info *wl = hw->priv;
LOCK(wl); spin_lock_bh(&wl->lock);
if (!wl->pub->up) { if (!wl->pub->up) {
wiphy_err(wl->wiphy, "ops->tx called while down\n"); wiphy_err(wl->wiphy, "ops->tx called while down\n");
kfree_skb(skb); kfree_skb(skb);
...@@ -299,7 +279,7 @@ static void brcms_ops_tx(struct ieee80211_hw *hw, struct sk_buff *skb) ...@@ -299,7 +279,7 @@ static void brcms_ops_tx(struct ieee80211_hw *hw, struct sk_buff *skb)
} }
brcms_c_sendpkt_mac80211(wl->wlc, skb, hw); brcms_c_sendpkt_mac80211(wl->wlc, skb, hw);
done: done:
UNLOCK(wl); spin_unlock_bh(&wl->lock);
} }
static int brcms_ops_start(struct ieee80211_hw *hw) static int brcms_ops_start(struct ieee80211_hw *hw)
...@@ -308,9 +288,9 @@ static int brcms_ops_start(struct ieee80211_hw *hw) ...@@ -308,9 +288,9 @@ static int brcms_ops_start(struct ieee80211_hw *hw)
bool blocked; bool blocked;
ieee80211_wake_queues(hw); ieee80211_wake_queues(hw);
LOCK(wl); spin_lock_bh(&wl->lock);
blocked = brcms_rfkill_set_hw_state(wl); blocked = brcms_rfkill_set_hw_state(wl);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
if (!blocked) if (!blocked)
wiphy_rfkill_stop_polling(wl->pub->ieee_hw->wiphy); wiphy_rfkill_stop_polling(wl->pub->ieee_hw->wiphy);
...@@ -340,12 +320,12 @@ brcms_ops_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif) ...@@ -340,12 +320,12 @@ brcms_ops_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
} }
wl = hw->priv; wl = hw->priv;
LOCK(wl); spin_lock_bh(&wl->lock);
if (!wl->pub->up) if (!wl->pub->up)
err = brcms_up(wl); err = brcms_up(wl);
else else
err = -ENODEV; err = -ENODEV;
UNLOCK(wl); spin_unlock_bh(&wl->lock);
if (err != 0) if (err != 0)
wiphy_err(hw->wiphy, "%s: brcms_up() returned %d\n", __func__, wiphy_err(hw->wiphy, "%s: brcms_up() returned %d\n", __func__,
...@@ -362,9 +342,9 @@ brcms_ops_remove_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif) ...@@ -362,9 +342,9 @@ brcms_ops_remove_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
wl = hw->priv; wl = hw->priv;
/* put driver in down state */ /* put driver in down state */
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_down(wl); brcms_down(wl);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
} }
static int brcms_ops_config(struct ieee80211_hw *hw, u32 changed) static int brcms_ops_config(struct ieee80211_hw *hw, u32 changed)
...@@ -375,7 +355,7 @@ static int brcms_ops_config(struct ieee80211_hw *hw, u32 changed) ...@@ -375,7 +355,7 @@ static int brcms_ops_config(struct ieee80211_hw *hw, u32 changed)
int new_int; int new_int;
struct wiphy *wiphy = hw->wiphy; struct wiphy *wiphy = hw->wiphy;
LOCK(wl); spin_lock_bh(&wl->lock);
if (changed & IEEE80211_CONF_CHANGE_LISTEN_INTERVAL) { if (changed & IEEE80211_CONF_CHANGE_LISTEN_INTERVAL) {
brcms_c_set_beacon_listen_interval(wl->wlc, brcms_c_set_beacon_listen_interval(wl->wlc,
conf->listen_interval); conf->listen_interval);
...@@ -416,7 +396,7 @@ static int brcms_ops_config(struct ieee80211_hw *hw, u32 changed) ...@@ -416,7 +396,7 @@ static int brcms_ops_config(struct ieee80211_hw *hw, u32 changed)
conf->long_frame_max_tx_count); conf->long_frame_max_tx_count);
config_out: config_out:
UNLOCK(wl); spin_unlock_bh(&wl->lock);
return err; return err;
} }
...@@ -434,9 +414,9 @@ brcms_ops_bss_info_changed(struct ieee80211_hw *hw, ...@@ -434,9 +414,9 @@ brcms_ops_bss_info_changed(struct ieee80211_hw *hw,
*/ */
wiphy_err(wiphy, "%s: %s: %sassociated\n", KBUILD_MODNAME, wiphy_err(wiphy, "%s: %s: %sassociated\n", KBUILD_MODNAME,
__func__, info->assoc ? "" : "dis"); __func__, info->assoc ? "" : "dis");
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_associate_upd(wl->wlc, info->assoc); brcms_c_associate_upd(wl->wlc, info->assoc);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
} }
if (changed & BSS_CHANGED_ERP_SLOT) { if (changed & BSS_CHANGED_ERP_SLOT) {
s8 val; s8 val;
...@@ -446,23 +426,23 @@ brcms_ops_bss_info_changed(struct ieee80211_hw *hw, ...@@ -446,23 +426,23 @@ brcms_ops_bss_info_changed(struct ieee80211_hw *hw,
val = 1; val = 1;
else else
val = 0; val = 0;
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_set_shortslot_override(wl->wlc, val); brcms_c_set_shortslot_override(wl->wlc, val);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
} }
if (changed & BSS_CHANGED_HT) { if (changed & BSS_CHANGED_HT) {
/* 802.11n parameters changed */ /* 802.11n parameters changed */
u16 mode = info->ht_operation_mode; u16 mode = info->ht_operation_mode;
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_protection_upd(wl->wlc, BRCMS_PROT_N_CFG, brcms_c_protection_upd(wl->wlc, BRCMS_PROT_N_CFG,
mode & IEEE80211_HT_OP_MODE_PROTECTION); mode & IEEE80211_HT_OP_MODE_PROTECTION);
brcms_c_protection_upd(wl->wlc, BRCMS_PROT_N_NONGF, brcms_c_protection_upd(wl->wlc, BRCMS_PROT_N_NONGF,
mode & IEEE80211_HT_OP_MODE_NON_GF_STA_PRSNT); mode & IEEE80211_HT_OP_MODE_NON_GF_STA_PRSNT);
brcms_c_protection_upd(wl->wlc, BRCMS_PROT_N_OBSS, brcms_c_protection_upd(wl->wlc, BRCMS_PROT_N_OBSS,
mode & IEEE80211_HT_OP_MODE_NON_HT_STA_PRSNT); mode & IEEE80211_HT_OP_MODE_NON_HT_STA_PRSNT);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
} }
if (changed & BSS_CHANGED_BASIC_RATES) { if (changed & BSS_CHANGED_BASIC_RATES) {
struct ieee80211_supported_band *bi; struct ieee80211_supported_band *bi;
...@@ -472,9 +452,9 @@ brcms_ops_bss_info_changed(struct ieee80211_hw *hw, ...@@ -472,9 +452,9 @@ brcms_ops_bss_info_changed(struct ieee80211_hw *hw,
int error; int error;
/* retrieve the current rates */ /* retrieve the current rates */
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_get_current_rateset(wl->wlc, &rs); brcms_c_get_current_rateset(wl->wlc, &rs);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
br_mask = info->basic_rates; br_mask = info->basic_rates;
bi = hw->wiphy->bands[brcms_c_get_curband(wl->wlc)]; bi = hw->wiphy->bands[brcms_c_get_curband(wl->wlc)];
...@@ -488,24 +468,24 @@ brcms_ops_bss_info_changed(struct ieee80211_hw *hw, ...@@ -488,24 +468,24 @@ brcms_ops_bss_info_changed(struct ieee80211_hw *hw,
} }
/* update the rate set */ /* update the rate set */
LOCK(wl); spin_lock_bh(&wl->lock);
error = brcms_c_set_rateset(wl->wlc, &rs); error = brcms_c_set_rateset(wl->wlc, &rs);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
if (error) if (error)
wiphy_err(wiphy, "changing basic rates failed: %d\n", wiphy_err(wiphy, "changing basic rates failed: %d\n",
error); error);
} }
if (changed & BSS_CHANGED_BEACON_INT) { if (changed & BSS_CHANGED_BEACON_INT) {
/* Beacon interval changed */ /* Beacon interval changed */
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_set_beacon_period(wl->wlc, info->beacon_int); brcms_c_set_beacon_period(wl->wlc, info->beacon_int);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
} }
if (changed & BSS_CHANGED_BSSID) { if (changed & BSS_CHANGED_BSSID) {
/* BSSID changed, for whatever reason (IBSS and managed mode) */ /* BSSID changed, for whatever reason (IBSS and managed mode) */
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_set_addrmatch(wl->wlc, RCM_BSSID_OFFSET, info->bssid); brcms_c_set_addrmatch(wl->wlc, RCM_BSSID_OFFSET, info->bssid);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
} }
if (changed & BSS_CHANGED_BEACON) if (changed & BSS_CHANGED_BEACON)
/* Beacon data changed, retrieve new beacon (beaconing modes) */ /* Beacon data changed, retrieve new beacon (beaconing modes) */
...@@ -571,7 +551,7 @@ brcms_ops_configure_filter(struct ieee80211_hw *hw, ...@@ -571,7 +551,7 @@ brcms_ops_configure_filter(struct ieee80211_hw *hw,
if (changed_flags & FIF_OTHER_BSS) if (changed_flags & FIF_OTHER_BSS)
wiphy_err(wiphy, "FIF_OTHER_BSS\n"); wiphy_err(wiphy, "FIF_OTHER_BSS\n");
if (changed_flags & FIF_BCN_PRBRESP_PROMISC) { if (changed_flags & FIF_BCN_PRBRESP_PROMISC) {
LOCK(wl); spin_lock_bh(&wl->lock);
if (*total_flags & FIF_BCN_PRBRESP_PROMISC) { if (*total_flags & FIF_BCN_PRBRESP_PROMISC) {
wl->pub->mac80211_state |= MAC80211_PROMISC_BCNS; wl->pub->mac80211_state |= MAC80211_PROMISC_BCNS;
brcms_c_mac_bcn_promisc_change(wl->wlc, 1); brcms_c_mac_bcn_promisc_change(wl->wlc, 1);
...@@ -579,7 +559,7 @@ brcms_ops_configure_filter(struct ieee80211_hw *hw, ...@@ -579,7 +559,7 @@ brcms_ops_configure_filter(struct ieee80211_hw *hw,
brcms_c_mac_bcn_promisc_change(wl->wlc, 0); brcms_c_mac_bcn_promisc_change(wl->wlc, 0);
wl->pub->mac80211_state &= ~MAC80211_PROMISC_BCNS; wl->pub->mac80211_state &= ~MAC80211_PROMISC_BCNS;
} }
UNLOCK(wl); spin_unlock_bh(&wl->lock);
} }
return; return;
} }
...@@ -587,18 +567,18 @@ brcms_ops_configure_filter(struct ieee80211_hw *hw, ...@@ -587,18 +567,18 @@ brcms_ops_configure_filter(struct ieee80211_hw *hw,
static void brcms_ops_sw_scan_start(struct ieee80211_hw *hw) static void brcms_ops_sw_scan_start(struct ieee80211_hw *hw)
{ {
struct brcms_info *wl = hw->priv; struct brcms_info *wl = hw->priv;
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_scan_start(wl->wlc); brcms_c_scan_start(wl->wlc);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
return; return;
} }
static void brcms_ops_sw_scan_complete(struct ieee80211_hw *hw) static void brcms_ops_sw_scan_complete(struct ieee80211_hw *hw)
{ {
struct brcms_info *wl = hw->priv; struct brcms_info *wl = hw->priv;
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_scan_stop(wl->wlc); brcms_c_scan_stop(wl->wlc);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
return; return;
} }
...@@ -608,9 +588,9 @@ brcms_ops_conf_tx(struct ieee80211_hw *hw, u16 queue, ...@@ -608,9 +588,9 @@ brcms_ops_conf_tx(struct ieee80211_hw *hw, u16 queue,
{ {
struct brcms_info *wl = hw->priv; struct brcms_info *wl = hw->priv;
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_wme_setparams(wl->wlc, queue, params, true); brcms_c_wme_setparams(wl->wlc, queue, params, true);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
return 0; return 0;
} }
...@@ -661,9 +641,9 @@ brcms_ops_ampdu_action(struct ieee80211_hw *hw, ...@@ -661,9 +641,9 @@ brcms_ops_ampdu_action(struct ieee80211_hw *hw,
case IEEE80211_AMPDU_RX_STOP: case IEEE80211_AMPDU_RX_STOP:
break; break;
case IEEE80211_AMPDU_TX_START: case IEEE80211_AMPDU_TX_START:
LOCK(wl); spin_lock_bh(&wl->lock);
status = brcms_c_aggregatable(wl->wlc, tid); status = brcms_c_aggregatable(wl->wlc, tid);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
if (!status) { if (!status) {
wiphy_err(wl->wiphy, "START: tid %d is not agg\'able\n", wiphy_err(wl->wiphy, "START: tid %d is not agg\'able\n",
tid); tid);
...@@ -673,9 +653,9 @@ brcms_ops_ampdu_action(struct ieee80211_hw *hw, ...@@ -673,9 +653,9 @@ brcms_ops_ampdu_action(struct ieee80211_hw *hw,
break; break;
case IEEE80211_AMPDU_TX_STOP: case IEEE80211_AMPDU_TX_STOP:
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_ampdu_flush(wl->wlc, sta, tid); brcms_c_ampdu_flush(wl->wlc, sta, tid);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
ieee80211_stop_tx_ba_cb_irqsafe(vif, sta->addr, tid); ieee80211_stop_tx_ba_cb_irqsafe(vif, sta->addr, tid);
break; break;
case IEEE80211_AMPDU_TX_OPERATIONAL: case IEEE80211_AMPDU_TX_OPERATIONAL:
...@@ -685,11 +665,11 @@ brcms_ops_ampdu_action(struct ieee80211_hw *hw, ...@@ -685,11 +665,11 @@ brcms_ops_ampdu_action(struct ieee80211_hw *hw,
* recipient and traffic class. 'ampdu_factor' gives maximum * recipient and traffic class. 'ampdu_factor' gives maximum
* AMPDU size. * AMPDU size.
*/ */
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_ampdu_tx_operational(wl->wlc, tid, buf_size, brcms_c_ampdu_tx_operational(wl->wlc, tid, buf_size,
(1 << (IEEE80211_HT_MAX_AMPDU_FACTOR + (1 << (IEEE80211_HT_MAX_AMPDU_FACTOR +
sta->ht_cap.ampdu_factor)) - 1); sta->ht_cap.ampdu_factor)) - 1);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
/* Power save wakeup */ /* Power save wakeup */
break; break;
default: default:
...@@ -705,9 +685,9 @@ static void brcms_ops_rfkill_poll(struct ieee80211_hw *hw) ...@@ -705,9 +685,9 @@ static void brcms_ops_rfkill_poll(struct ieee80211_hw *hw)
struct brcms_info *wl = hw->priv; struct brcms_info *wl = hw->priv;
bool blocked; bool blocked;
LOCK(wl); spin_lock_bh(&wl->lock);
blocked = brcms_c_check_radio_disabled(wl->wlc); blocked = brcms_c_check_radio_disabled(wl->wlc);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
wiphy_rfkill_set_hw_state(wl->pub->ieee_hw->wiphy, blocked); wiphy_rfkill_set_hw_state(wl->pub->ieee_hw->wiphy, blocked);
} }
...@@ -719,9 +699,9 @@ static void brcms_ops_flush(struct ieee80211_hw *hw, bool drop) ...@@ -719,9 +699,9 @@ static void brcms_ops_flush(struct ieee80211_hw *hw, bool drop)
no_printk("%s: drop = %s\n", __func__, drop ? "true" : "false"); no_printk("%s: drop = %s\n", __func__, drop ? "true" : "false");
/* wait for packet queue and dma fifos to run empty */ /* wait for packet queue and dma fifos to run empty */
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_c_wait_for_tx_completion(wl->wlc, drop); brcms_c_wait_for_tx_completion(wl->wlc, drop);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
} }
static const struct ieee80211_ops brcms_ops = { static const struct ieee80211_ops brcms_ops = {
...@@ -756,16 +736,16 @@ void brcms_dpc(unsigned long data) ...@@ -756,16 +736,16 @@ void brcms_dpc(unsigned long data)
wl = (struct brcms_info *) data; wl = (struct brcms_info *) data;
LOCK(wl); spin_lock_bh(&wl->lock);
/* call the common second level interrupt handler */ /* call the common second level interrupt handler */
if (wl->pub->up) { if (wl->pub->up) {
if (wl->resched) { if (wl->resched) {
unsigned long flags; unsigned long flags;
INT_LOCK(wl, flags); spin_lock_irqsave(&wl->isr_lock, flags);
brcms_c_intrsupd(wl->wlc); brcms_c_intrsupd(wl->wlc);
INT_UNLOCK(wl, flags); spin_unlock_irqrestore(&wl->isr_lock, flags);
} }
wl->resched = brcms_c_dpc(wl->wlc, true); wl->resched = brcms_c_dpc(wl->wlc, true);
...@@ -783,7 +763,7 @@ void brcms_dpc(unsigned long data) ...@@ -783,7 +763,7 @@ void brcms_dpc(unsigned long data)
brcms_intrson(wl); brcms_intrson(wl);
done: done:
UNLOCK(wl); spin_unlock_bh(&wl->lock);
} }
/* /*
...@@ -912,9 +892,9 @@ static void brcms_remove(struct pci_dev *pdev) ...@@ -912,9 +892,9 @@ static void brcms_remove(struct pci_dev *pdev)
return; return;
} }
LOCK(wl); spin_lock_bh(&wl->lock);
status = brcms_c_chipmatch(pdev->vendor, pdev->device); status = brcms_c_chipmatch(pdev->vendor, pdev->device);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
if (!status) { if (!status) {
wiphy_err(wl->wiphy, "wl: brcms_remove: chipmatch " wiphy_err(wl->wiphy, "wl: brcms_remove: chipmatch "
"failed\n"); "failed\n");
...@@ -924,9 +904,9 @@ static void brcms_remove(struct pci_dev *pdev) ...@@ -924,9 +904,9 @@ static void brcms_remove(struct pci_dev *pdev)
wiphy_rfkill_set_hw_state(wl->pub->ieee_hw->wiphy, false); wiphy_rfkill_set_hw_state(wl->pub->ieee_hw->wiphy, false);
wiphy_rfkill_stop_polling(wl->pub->ieee_hw->wiphy); wiphy_rfkill_stop_polling(wl->pub->ieee_hw->wiphy);
ieee80211_unregister_hw(hw); ieee80211_unregister_hw(hw);
LOCK(wl); spin_lock_bh(&wl->lock);
brcms_down(wl); brcms_down(wl);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
} }
pci_disable_device(pdev); pci_disable_device(pdev);
...@@ -940,11 +920,10 @@ static irqreturn_t brcms_isr(int irq, void *dev_id) ...@@ -940,11 +920,10 @@ static irqreturn_t brcms_isr(int irq, void *dev_id)
{ {
struct brcms_info *wl; struct brcms_info *wl;
bool ours, wantdpc; bool ours, wantdpc;
unsigned long flags;
wl = (struct brcms_info *) dev_id; wl = (struct brcms_info *) dev_id;
ISR_LOCK(wl, flags); spin_lock(&wl->isr_lock);
/* call common first level interrupt handler */ /* call common first level interrupt handler */
ours = brcms_c_isr(wl->wlc, &wantdpc); ours = brcms_c_isr(wl->wlc, &wantdpc);
...@@ -958,7 +937,7 @@ static irqreturn_t brcms_isr(int irq, void *dev_id) ...@@ -958,7 +937,7 @@ static irqreturn_t brcms_isr(int irq, void *dev_id)
} }
} }
ISR_UNLOCK(wl, flags); spin_unlock(&wl->isr_lock);
return IRQ_RETVAL(ours); return IRQ_RETVAL(ours);
} }
...@@ -1226,9 +1205,9 @@ static int brcms_suspend(struct pci_dev *pdev, pm_message_t state) ...@@ -1226,9 +1205,9 @@ static int brcms_suspend(struct pci_dev *pdev, pm_message_t state)
} }
/* only need to flag hw is down for proper resume */ /* only need to flag hw is down for proper resume */
LOCK(wl); spin_lock_bh(&wl->lock);
wl->pub->hw_up = false; wl->pub->hw_up = false;
UNLOCK(wl); spin_unlock_bh(&wl->lock);
pci_save_state(pdev); pci_save_state(pdev);
pci_disable_device(pdev); pci_disable_device(pdev);
...@@ -1365,9 +1344,9 @@ void brcms_intrson(struct brcms_info *wl) ...@@ -1365,9 +1344,9 @@ void brcms_intrson(struct brcms_info *wl)
{ {
unsigned long flags; unsigned long flags;
INT_LOCK(wl, flags); spin_lock_irqsave(&wl->isr_lock, flags);
brcms_c_intrson(wl->wlc); brcms_c_intrson(wl->wlc);
INT_UNLOCK(wl, flags); spin_unlock_irqrestore(&wl->isr_lock, flags);
} }
u32 brcms_intrsoff(struct brcms_info *wl) u32 brcms_intrsoff(struct brcms_info *wl)
...@@ -1375,9 +1354,9 @@ u32 brcms_intrsoff(struct brcms_info *wl) ...@@ -1375,9 +1354,9 @@ u32 brcms_intrsoff(struct brcms_info *wl)
unsigned long flags; unsigned long flags;
u32 status; u32 status;
INT_LOCK(wl, flags); spin_lock_irqsave(&wl->isr_lock, flags);
status = brcms_c_intrsoff(wl->wlc); status = brcms_c_intrsoff(wl->wlc);
INT_UNLOCK(wl, flags); spin_unlock_irqrestore(&wl->isr_lock, flags);
return status; return status;
} }
...@@ -1385,9 +1364,9 @@ void brcms_intrsrestore(struct brcms_info *wl, u32 macintmask) ...@@ -1385,9 +1364,9 @@ void brcms_intrsrestore(struct brcms_info *wl, u32 macintmask)
{ {
unsigned long flags; unsigned long flags;
INT_LOCK(wl, flags); spin_lock_irqsave(&wl->isr_lock, flags);
brcms_c_intrsrestore(wl->wlc, macintmask); brcms_c_intrsrestore(wl->wlc, macintmask);
INT_UNLOCK(wl, flags); spin_unlock_irqrestore(&wl->isr_lock, flags);
} }
/* /*
...@@ -1417,14 +1396,14 @@ void brcms_down(struct brcms_info *wl) ...@@ -1417,14 +1396,14 @@ void brcms_down(struct brcms_info *wl)
callbacks = atomic_read(&wl->callbacks) - ret_val; callbacks = atomic_read(&wl->callbacks) - ret_val;
/* wait for down callbacks to complete */ /* wait for down callbacks to complete */
UNLOCK(wl); spin_unlock_bh(&wl->lock);
/* For HIGH_only driver, it's important to actually schedule other work, /* For HIGH_only driver, it's important to actually schedule other work,
* not just spin wait since everything runs at schedule level * not just spin wait since everything runs at schedule level
*/ */
SPINWAIT((atomic_read(&wl->callbacks) > callbacks), 100 * 1000); SPINWAIT((atomic_read(&wl->callbacks) > callbacks), 100 * 1000);
LOCK(wl); spin_lock_bh(&wl->lock);
} }
/* /*
...@@ -1432,7 +1411,7 @@ void brcms_down(struct brcms_info *wl) ...@@ -1432,7 +1411,7 @@ void brcms_down(struct brcms_info *wl)
*/ */
void brcms_timer(struct brcms_timer *t) void brcms_timer(struct brcms_timer *t)
{ {
LOCK(t->wl); spin_lock_bh(&t->wl->lock);
if (t->set) { if (t->set) {
if (t->periodic) { if (t->periodic) {
...@@ -1448,7 +1427,7 @@ void brcms_timer(struct brcms_timer *t) ...@@ -1448,7 +1427,7 @@ void brcms_timer(struct brcms_timer *t)
atomic_dec(&t->wl->callbacks); atomic_dec(&t->wl->callbacks);
UNLOCK(t->wl); spin_unlock_bh(&t->wl->lock);
} }
/* /*
...@@ -1703,11 +1682,11 @@ bool brcms_rfkill_set_hw_state(struct brcms_info *wl) ...@@ -1703,11 +1682,11 @@ bool brcms_rfkill_set_hw_state(struct brcms_info *wl)
{ {
bool blocked = brcms_c_check_radio_disabled(wl->wlc); bool blocked = brcms_c_check_radio_disabled(wl->wlc);
UNLOCK(wl); spin_unlock_bh(&wl->lock);
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);
LOCK(wl); spin_lock_bh(&wl->lock);
return blocked; return blocked;
} }
...@@ -1716,7 +1695,7 @@ bool brcms_rfkill_set_hw_state(struct brcms_info *wl) ...@@ -1716,7 +1695,7 @@ bool brcms_rfkill_set_hw_state(struct brcms_info *wl)
*/ */
void brcms_msleep(struct brcms_info *wl, uint ms) void brcms_msleep(struct brcms_info *wl, uint ms)
{ {
UNLOCK(wl); spin_unlock_bh(&wl->lock);
msleep(ms); msleep(ms);
LOCK(wl); spin_lock_bh(&wl->lock);
} }
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