mwifiex: abort cac in del_station() handler
authorXinming Hu <huxm@marvell.com>
Mon, 14 Dec 2015 12:15:07 +0000 (04:15 -0800)
committerKalle Valo <kvalo@codeaurora.org>
Wed, 30 Dec 2015 14:57:58 +0000 (16:57 +0200)
When hostapd is killed with Ctrl+C before cac get completed,
stop_ap handler will not be called, thus priv->wdev.cac_started
flag remains set.
Hostapd restart attempt will be failed in this case with device
busy error. This patch aborts cac in del_station handler to
handle this corner case.

Signed-off-by: Xinming Hu <huxm@marvell.com>
Signed-off-by: Amitkumar Karwar <akarwar@marvell.com>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/marvell/mwifiex/cfg80211.c

index 0aab935..f7c26d6 100644 (file)
@@ -1708,6 +1708,11 @@ mwifiex_cfg80211_del_station(struct wiphy *wiphy, struct net_device *dev,
        u8 deauth_mac[ETH_ALEN];
        unsigned long flags;
 
+       if (!priv->bss_started && priv->wdev.cac_started) {
+               mwifiex_dbg(priv->adapter, INFO, "%s: abort CAC!\n", __func__);
+               mwifiex_abort_cac(priv);
+       }
+
        if (list_empty(&priv->sta_list) || !priv->bss_started)
                return 0;