nl80211: Ignore disconnect event in case of locally generated request
Previously, there could be two disconnection events in core wpa_supplicant when going through a case of wpa_supplicant-requested disconnection with a driver that implements SME internally. This could result in undesired behavior when a disconnection is followed by a new connection attempt before the extra event has been received (e.g., during fast reassoc or WPS provisioning). Avoid such issues by ignoring locally generated disconnect events after requesting cfg80211 to disconnect. This makes the previously used ignore_next_local_disconnect more consistent by setting the variable within wpa_driver_nl80211_disconnect() so that both callers get the same behavior. Signed-hostap: Jithu Jance <jithu@broadcom.com>
This commit is contained in:
parent
1075b29571
commit
3f53c006c7
1 changed files with 11 additions and 5 deletions
|
@ -5165,12 +5165,20 @@ nla_put_failure:
|
||||||
static int wpa_driver_nl80211_disconnect(struct wpa_driver_nl80211_data *drv,
|
static int wpa_driver_nl80211_disconnect(struct wpa_driver_nl80211_data *drv,
|
||||||
int reason_code)
|
int reason_code)
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
wpa_printf(MSG_DEBUG, "%s(reason_code=%d)", __func__, reason_code);
|
wpa_printf(MSG_DEBUG, "%s(reason_code=%d)", __func__, reason_code);
|
||||||
nl80211_mark_disconnected(drv);
|
nl80211_mark_disconnected(drv);
|
||||||
drv->ignore_next_local_disconnect = 0;
|
|
||||||
/* Disconnect command doesn't need BSSID - it uses cached value */
|
/* Disconnect command doesn't need BSSID - it uses cached value */
|
||||||
return wpa_driver_nl80211_mlme(drv, NULL, NL80211_CMD_DISCONNECT,
|
ret = wpa_driver_nl80211_mlme(drv, NULL, NL80211_CMD_DISCONNECT,
|
||||||
reason_code, 0);
|
reason_code, 0);
|
||||||
|
/*
|
||||||
|
* For locally generated disconnect, supplicant already generates a
|
||||||
|
* DEAUTH event, so ignore the event from NL80211.
|
||||||
|
*/
|
||||||
|
drv->ignore_next_local_disconnect = ret == 0;
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -7798,8 +7806,6 @@ static int wpa_driver_nl80211_connect(
|
||||||
if (wpa_driver_nl80211_disconnect(
|
if (wpa_driver_nl80211_disconnect(
|
||||||
drv, WLAN_REASON_PREV_AUTH_NOT_VALID))
|
drv, WLAN_REASON_PREV_AUTH_NOT_VALID))
|
||||||
return -1;
|
return -1;
|
||||||
/* Ignore the next local disconnect message. */
|
|
||||||
drv->ignore_next_local_disconnect = 1;
|
|
||||||
ret = wpa_driver_nl80211_try_connect(drv, params);
|
ret = wpa_driver_nl80211_try_connect(drv, params);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
|
|
Loading…
Reference in a new issue