Do not invalidate EAP session cache on all network block parameter changes

The bssid and priority parameters in a network block do not have any
effect on the validity of an EAP session entry, so avoid flushing the
cached session when only these parameters are changed. This is mainly to
allow forced roaming or network selection changes without causing fast
reauthentication to be disabled if the changes are done during RSN
association that used EAP.

Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com>
This commit is contained in:
Jouni Malinen 2016-03-16 19:44:32 +02:00 committed by Jouni Malinen
parent 9231c2476f
commit c3dc68e844

View file

@ -2976,16 +2976,18 @@ static int wpa_supplicant_ctrl_iface_update_network(
} }
if (os_strcmp(name, "bssid") != 0 && if (os_strcmp(name, "bssid") != 0 &&
os_strcmp(name, "priority") != 0) os_strcmp(name, "priority") != 0) {
wpa_sm_pmksa_cache_flush(wpa_s->wpa, ssid); wpa_sm_pmksa_cache_flush(wpa_s->wpa, ssid);
if (wpa_s->current_ssid == ssid || wpa_s->current_ssid == NULL) { if (wpa_s->current_ssid == ssid ||
wpa_s->current_ssid == NULL) {
/* /*
* Invalidate the EAP session cache if anything in the current * Invalidate the EAP session cache if anything in the
* or previously used configuration changes. * current or previously used configuration changes.
*/ */
eapol_sm_invalidate_cached_session(wpa_s->eapol); eapol_sm_invalidate_cached_session(wpa_s->eapol);
} }
}
if ((os_strcmp(name, "psk") == 0 && if ((os_strcmp(name, "psk") == 0 &&
value[0] == '"' && ssid->ssid_len) || value[0] == '"' && ssid->ssid_len) ||