Commit 98b6d238 authored by Vipin Mehta's avatar Vipin Mehta Committed by Greg Kroah-Hartman

staging: ath6kl: Adding state in driver to track the sme state

Adding state in driver to track the sme state. The connect/disconnect
events from the driver were messing up the state maintained within the
cfg80211 module.
Signed-off-by: default avatarVipin Mehta <vmehta@atheros.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 9ea979d3
...@@ -1670,6 +1670,7 @@ ar6000_avail_ev(void *context, void *hif_handle) ...@@ -1670,6 +1670,7 @@ ar6000_avail_ev(void *context, void *hif_handle)
SET_NETDEV_DEV(dev, wiphy_dev(wdev->wiphy)); SET_NETDEV_DEV(dev, wiphy_dev(wdev->wiphy));
wdev->netdev = dev; wdev->netdev = dev;
ar->arNetworkType = INFRA_NETWORK; ar->arNetworkType = INFRA_NETWORK;
ar->smeState = SME_DISCONNECTED;
#endif /* ATH6K_CONFIG_CFG80211 */ #endif /* ATH6K_CONFIG_CFG80211 */
init_netdev(dev, ifname); init_netdev(dev, ifname);
......
...@@ -248,6 +248,7 @@ ar6k_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev, ...@@ -248,6 +248,7 @@ ar6k_cfg80211_connect(struct wiphy *wiphy, struct net_device *dev,
int status; int status;
AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: \n", __func__)); AR_DEBUG_PRINTF(ATH_DEBUG_INFO, ("%s: \n", __func__));
ar->smeState = SME_CONNECTING;
if(ar->arWmiReady == false) { if(ar->arWmiReady == false) {
AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready yet\n", __func__)); AR_DEBUG_PRINTF(ATH_DEBUG_ERR, ("%s: Wmi not ready yet\n", __func__));
...@@ -562,6 +563,7 @@ ar6k_cfg80211_connect_event(AR_SOFTC_T *ar, u16 channel, ...@@ -562,6 +563,7 @@ ar6k_cfg80211_connect_event(AR_SOFTC_T *ar, u16 channel,
if (false == ar->arConnected) { if (false == ar->arConnected) {
/* inform connect result to cfg80211 */ /* inform connect result to cfg80211 */
ar->smeState = SME_DISCONNECTED;
cfg80211_connect_result(ar->arNetDev, bssid, cfg80211_connect_result(ar->arNetDev, bssid,
assocReqIe, assocReqLen, assocReqIe, assocReqLen,
assocRespIe, assocRespLen, assocRespIe, assocRespLen,
...@@ -644,19 +646,29 @@ ar6k_cfg80211_disconnect_event(AR_SOFTC_T *ar, u8 reason, ...@@ -644,19 +646,29 @@ ar6k_cfg80211_disconnect_event(AR_SOFTC_T *ar, u8 reason,
} }
} }
if(false == ar->arConnected) { if(true == ar->arConnectPending) {
if(NO_NETWORK_AVAIL == reason) { if(NO_NETWORK_AVAIL == reason) {
/* connect cmd failed */ /* connect cmd failed */
wmi_disconnect_cmd(ar->arWmi);
} else if (reason == DISCONNECT_CMD) {
/* connection loss due to disconnect cmd or low rssi */
ar->arConnectPending = false;
if (ar->smeState == SME_CONNECTING) {
cfg80211_connect_result(ar->arNetDev, bssid, cfg80211_connect_result(ar->arNetDev, bssid,
NULL, 0, NULL, 0,
NULL, 0, NULL, 0,
WLAN_STATUS_UNSPECIFIED_FAILURE, WLAN_STATUS_UNSPECIFIED_FAILURE,
GFP_KERNEL); GFP_KERNEL);
}
} else { } else {
/* connection loss due to disconnect cmd or low rssi */
cfg80211_disconnected(ar->arNetDev, reason, NULL, 0, GFP_KERNEL); cfg80211_disconnected(ar->arNetDev, reason, NULL, 0, GFP_KERNEL);
} }
ar->smeState = SME_DISCONNECTED;
}
} else {
if (reason != DISCONNECT_CMD) {
wmi_disconnect_cmd(ar->arWmi);
}
}
} }
void void
......
...@@ -393,6 +393,12 @@ struct ar_key { ...@@ -393,6 +393,12 @@ struct ar_key {
u8 seq_len; u8 seq_len;
u32 cipher; u32 cipher;
}; };
enum {
SME_DISCONNECTED,
SME_CONNECTING,
SME_CONNECTED
};
#endif /* ATH6K_CONFIG_CFG80211 */ #endif /* ATH6K_CONFIG_CFG80211 */
...@@ -595,6 +601,7 @@ typedef struct ar6_softc { ...@@ -595,6 +601,7 @@ typedef struct ar6_softc {
struct wireless_dev *wdev; struct wireless_dev *wdev;
struct cfg80211_scan_request *scan_request; struct cfg80211_scan_request *scan_request;
struct ar_key keys[WMI_MAX_KEY_INDEX + 1]; struct ar_key keys[WMI_MAX_KEY_INDEX + 1];
u32 smeState;
#endif /* ATH6K_CONFIG_CFG80211 */ #endif /* ATH6K_CONFIG_CFG80211 */
u16 arWlanPowerState; u16 arWlanPowerState;
bool arWlanOff; bool arWlanOff;
......
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