From 579ce771226babf823f60f9b96db0eb881f12bcf Mon Sep 17 00:00:00 2001 From: Jouni Malinen Date: Fri, 9 Apr 2010 16:59:27 +0300 Subject: [PATCH] FT: Deauthenticate in case of Reassoc Response validation error If validation of the Reassociation Response frame fails during FT Protocol, do not allow association to be completed; instead, force deauthentication. --- wpa_supplicant/events.c | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/wpa_supplicant/events.c b/wpa_supplicant/events.c index 734e7e939..afd06b4a4 100644 --- a/wpa_supplicant/events.c +++ b/wpa_supplicant/events.c @@ -1000,8 +1000,8 @@ static void wpa_assoc_set_ft_params(struct wpa_supplicant *wpa_s, } #endif /* CONFIG_IEEE80211R */ -static void wpa_supplicant_event_associnfo(struct wpa_supplicant *wpa_s, - union wpa_event_data *data) +static int wpa_supplicant_event_associnfo(struct wpa_supplicant *wpa_s, + union wpa_event_data *data) { int l, len, found = 0, wpa_found, rsn_found; const u8 *p; @@ -1060,7 +1060,9 @@ static void wpa_supplicant_event_associnfo(struct wpa_supplicant *wpa_s, bssid) < 0) { wpa_printf(MSG_DEBUG, "FT: Validation of " "Reassociation Response failed"); - /* TODO: force disconnection? */ + wpa_supplicant_deauthenticate( + wpa_s, WLAN_REASON_INVALID_IE); + return -1; } } #endif /* CONFIG_SME */ @@ -1126,6 +1128,8 @@ static void wpa_supplicant_event_associnfo(struct wpa_supplicant *wpa_s, wpa_s->ap_ies_from_associnfo = 1; wpa_s->assoc_freq = data->assoc_info.freq; + + return 0; } @@ -1148,8 +1152,8 @@ static void wpa_supplicant_event_assoc(struct wpa_supplicant *wpa_s, #endif /* CONFIG_AP */ ft_completed = wpa_ft_is_completed(wpa_s->wpa); - if (data) - wpa_supplicant_event_associnfo(wpa_s, data); + if (data && wpa_supplicant_event_associnfo(wpa_s, data) < 0) + return; wpa_supplicant_set_state(wpa_s, WPA_ASSOCIATED); if (wpa_s->drv_flags & WPA_DRIVER_FLAGS_USER_SPACE_MLME)