summaryrefslogtreecommitdiff
path: root/drivers/net/wireless/bcmdhd/wl_cfg80211.c
diff options
context:
space:
mode:
authorDmitry Shmidt <dimitrysh@google.com>2011-07-11 10:45:33 -0700
committerDmitry Shmidt <dimitrysh@google.com>2011-07-11 11:27:42 -0700
commit7543710368958d90b50f454ee225a79451fce595 (patch)
treeb2c9c9fa89717a5112734c435ec3bf112c6a8a38 /drivers/net/wireless/bcmdhd/wl_cfg80211.c
parent8c3bcb428538007d88b0e76b1c2ce25e4c2ba0cf (diff)
net: wireless: bcmdhd: Fix CFG80211 suspend/resume if interface is down
Signed-off-by: Dmitry Shmidt <dimitrysh@google.com>
Diffstat (limited to 'drivers/net/wireless/bcmdhd/wl_cfg80211.c')
-rw-r--r--drivers/net/wireless/bcmdhd/wl_cfg80211.c16
1 files changed, 13 insertions, 3 deletions
diff --git a/drivers/net/wireless/bcmdhd/wl_cfg80211.c b/drivers/net/wireless/bcmdhd/wl_cfg80211.c
index 3196da3559b..d9c7e658769 100644
--- a/drivers/net/wireless/bcmdhd/wl_cfg80211.c
+++ b/drivers/net/wireless/bcmdhd/wl_cfg80211.c
@@ -2594,10 +2594,16 @@ wl_cfg80211_set_bitrate_mask(struct wiphy *wiphy, struct net_device *dev,
static s32 wl_cfg80211_resume(struct wiphy *wiphy)
{
+ struct wl_priv *wl = WL_PRIV_GET();
s32 err = 0;
- CHECK_SYS_UP();
- wl_invoke_iscan(WL_PRIV_GET());
+ if (unlikely(!test_bit(WL_STATUS_READY, &wl->status))) {
+ WL_INFO(("device is not ready : status (%d)\n",
+ (int)wl->status));
+ return 0;
+ }
+
+ wl_invoke_iscan(wl);
return err;
}
@@ -2611,7 +2617,11 @@ static s32 wl_cfg80211_suspend(struct wiphy *wiphy)
struct wl_priv *wl = WL_PRIV_GET();
s32 err = 0;
- CHECK_SYS_UP();
+ if (unlikely(!test_bit(WL_STATUS_READY, &wl->status))) {
+ WL_INFO(("device is not ready : status (%d)\n",
+ (int)wl->status));
+ return 0;
+ }
set_bit(WL_STATUS_SCAN_ABORTING, &wl->status);
wl_term_iscan(wl);