net: wireless: bcmdhd: Fix wl_cfg80211_suspend() crash
authorDmitry Shmidt <dimitrysh@google.com>
Fri, 16 Sep 2011 21:03:13 +0000 (14:03 -0700)
committerDmitry Shmidt <dimitrysh@google.com>
Fri, 16 Sep 2011 21:19:17 +0000 (14:19 -0700)
- Eliminate wlan chip access during suspend
- Add DHD_CLEAR_ON_SUSPEND define to clear statuses on suspend

Signed-off-by: Dmitry Shmidt <dimitrysh@google.com>
drivers/net/wireless/bcmdhd/wl_cfg80211.c

index 13530d2063db49de2e772c1f59aea63feebb3b57..0c3854d17e4c1bb7d0df3aae3ba73fc4d66ccf49 100644 (file)
@@ -2881,6 +2881,7 @@ static s32 wl_cfg80211_suspend(struct wiphy *wiphy, struct cfg80211_wowlan *wow)
 static s32 wl_cfg80211_suspend(struct wiphy *wiphy)
 #endif
 {
+#ifdef DHD_CLEAR_ON_SUSPEND
        struct wl_priv *wl = wiphy_priv(wiphy);
        struct net_device *ndev = wl_to_prmry_ndev(wl);
        unsigned long flags;
@@ -2893,11 +2894,6 @@ static s32 wl_cfg80211_suspend(struct wiphy *wiphy)
 
        wl_set_drv_status(wl, SCAN_ABORTING);
        wl_term_iscan(wl);
-       if (wl_get_drv_status(wl, CONNECTING)) {
-               wl_bss_connect_done(wl, ndev, NULL, NULL, false);
-               wl_delay(500);
-               return -EAGAIN;
-       }
        flags = dhd_os_spin_lock((dhd_pub_t *)(wl->pub));
        if (wl->scan_request) {
                cfg80211_scan_done(wl->scan_request, true);
@@ -2906,6 +2902,13 @@ static s32 wl_cfg80211_suspend(struct wiphy *wiphy)
        wl_clr_drv_status(wl, SCANNING);
        wl_clr_drv_status(wl, SCAN_ABORTING);
        dhd_os_spin_unlock((dhd_pub_t *)(wl->pub), flags);
+
+       if (wl_get_drv_status(wl, CONNECTING)) {
+               wl_bss_connect_done(wl, ndev, NULL, NULL, false);
+               wl_delay(500);
+               return -EAGAIN;
+       }
+#endif
        return 0;
 }