FT: Stop association attempt if Auth response processing fails (SME)
Call the FT processing function directly instead of going through wpa_supplicant_event() to process FT Authentication frame in SME case. This allows parsing error to be used to trigger immediate failure for the connection instead of trying to proceed to reassociation step that cannot succeed. Signed-off-by: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
50a19b0107
commit
ee140ef98f
1 changed files with 14 additions and 6 deletions
|
@ -831,12 +831,20 @@ void sme_event_auth(struct wpa_supplicant *wpa_s, union wpa_event_data *data)
|
||||||
|
|
||||||
#ifdef CONFIG_IEEE80211R
|
#ifdef CONFIG_IEEE80211R
|
||||||
if (data->auth.auth_type == WLAN_AUTH_FT) {
|
if (data->auth.auth_type == WLAN_AUTH_FT) {
|
||||||
union wpa_event_data edata;
|
if (wpa_ft_process_response(wpa_s->wpa, data->auth.ies,
|
||||||
os_memset(&edata, 0, sizeof(edata));
|
data->auth.ies_len, 0,
|
||||||
edata.ft_ies.ies = data->auth.ies;
|
data->auth.peer, NULL, 0) < 0) {
|
||||||
edata.ft_ies.ies_len = data->auth.ies_len;
|
wpa_dbg(wpa_s, MSG_DEBUG,
|
||||||
os_memcpy(edata.ft_ies.target_ap, data->auth.peer, ETH_ALEN);
|
"SME: FT Authentication response processing failed");
|
||||||
wpa_supplicant_event(wpa_s, EVENT_FT_RESPONSE, &edata);
|
wpa_msg(wpa_s, MSG_INFO, WPA_EVENT_DISCONNECTED "bssid="
|
||||||
|
MACSTR
|
||||||
|
" reason=%d locally_generated=1",
|
||||||
|
MAC2STR(wpa_s->pending_bssid),
|
||||||
|
WLAN_REASON_DEAUTH_LEAVING);
|
||||||
|
wpas_connection_failed(wpa_s, wpa_s->pending_bssid);
|
||||||
|
wpa_supplicant_mark_disassoc(wpa_s);
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_IEEE80211R */
|
#endif /* CONFIG_IEEE80211R */
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue