From a8d05fca5f14fc3b89cc408a58c47fad7470364e Mon Sep 17 00:00:00 2001 From: Jouni Malinen Date: Sun, 30 Nov 2008 17:22:51 +0200 Subject: Clear various flags on re-association to allow key_mgmt changes If a STA reassociates and changes key_mgmt (e.g., from WPA-PSK to WPS), hostapd needs to reset some of the existing STA and WPA state machine variables to allow correct processing for the new association. --- hostapd/wpa.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'hostapd/wpa.c') diff --git a/hostapd/wpa.c b/hostapd/wpa.c index b1f35ad..946552c 100644 --- a/hostapd/wpa.c +++ b/hostapd/wpa.c @@ -516,6 +516,18 @@ void wpa_auth_sta_associated(struct wpa_authenticator *wpa_auth, } +void wpa_auth_sta_no_wpa(struct wpa_state_machine *sm) +{ + /* WPA/RSN was not used - clear WPA state. This is needed if the STA + * reassociates back to the same AP while the previous entry for the + * STA has not yet been removed. */ + if (sm == NULL) + return; + + sm->wpa_key_mgmt = 0; +} + + static void wpa_free_sta_sm(struct wpa_state_machine *sm) { os_free(sm->last_rx_eapol_key); -- cgit v1.1