Fix PeerKey deinit behavior
PeerKey entries need to be removed on disassociation and this needs to be done in a way that cancels the possibly pending eloop timeout. Signed-hostap: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
4472aafbe0
commit
773272989a
2 changed files with 2 additions and 1 deletions
|
@ -1110,7 +1110,7 @@ void peerkey_deinit(struct wpa_sm *sm)
|
|||
while (peerkey) {
|
||||
prev = peerkey;
|
||||
peerkey = peerkey->next;
|
||||
os_free(prev);
|
||||
wpa_supplicant_peerkey_free(sm, prev);
|
||||
}
|
||||
sm->peerkey = NULL;
|
||||
}
|
||||
|
|
|
@ -2098,6 +2098,7 @@ void wpa_sm_notify_assoc(struct wpa_sm *sm, const u8 *bssid)
|
|||
*/
|
||||
void wpa_sm_notify_disassoc(struct wpa_sm *sm)
|
||||
{
|
||||
peerkey_deinit(sm);
|
||||
rsn_preauth_deinit(sm);
|
||||
pmksa_cache_clear_current(sm);
|
||||
if (wpa_sm_get_state(sm) == WPA_4WAY_HANDSHAKE)
|
||||
|
|
Loading…
Reference in a new issue