DPP: Clear bootstrap entries only after clearing authentication state
This fixes an issue where the pending authentication might have held a reference to auth->tmp_peer_bi and dpp_auth_deinit() would try to free that bootstrapping entry. This needs to happen before the call to dpp_global_clear() to avoid double-removal of the bootstrapping entry from the list. Signed-off-by: Jouni Malinen <jouni@codeaurora.org>
This commit is contained in:
parent
b649fa4f42
commit
4f4a52c3cc
1 changed files with 1 additions and 1 deletions
|
@ -3260,7 +3260,6 @@ void wpas_dpp_deinit(struct wpa_supplicant *wpa_s)
|
||||||
#endif /* CONFIG_TESTING_OPTIONS */
|
#endif /* CONFIG_TESTING_OPTIONS */
|
||||||
if (!wpa_s->dpp)
|
if (!wpa_s->dpp)
|
||||||
return;
|
return;
|
||||||
dpp_global_clear(wpa_s->dpp);
|
|
||||||
eloop_cancel_timeout(wpas_dpp_pkex_retry_timeout, wpa_s, NULL);
|
eloop_cancel_timeout(wpas_dpp_pkex_retry_timeout, wpa_s, NULL);
|
||||||
eloop_cancel_timeout(wpas_dpp_reply_wait_timeout, wpa_s, NULL);
|
eloop_cancel_timeout(wpas_dpp_reply_wait_timeout, wpa_s, NULL);
|
||||||
eloop_cancel_timeout(wpas_dpp_init_timeout, wpa_s, NULL);
|
eloop_cancel_timeout(wpas_dpp_init_timeout, wpa_s, NULL);
|
||||||
|
@ -3284,6 +3283,7 @@ void wpas_dpp_deinit(struct wpa_supplicant *wpa_s)
|
||||||
os_memset(wpa_s->dpp_intro_bssid, 0, ETH_ALEN);
|
os_memset(wpa_s->dpp_intro_bssid, 0, ETH_ALEN);
|
||||||
os_free(wpa_s->dpp_configurator_params);
|
os_free(wpa_s->dpp_configurator_params);
|
||||||
wpa_s->dpp_configurator_params = NULL;
|
wpa_s->dpp_configurator_params = NULL;
|
||||||
|
dpp_global_clear(wpa_s->dpp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue