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:
Jouni Malinen 2015-06-20 17:36:58 +03:00
parent 50a19b0107
commit ee140ef98f

View file

@ -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 */