fix(wifi): wpa3 softap fix deauth when assoc req recv before sae is finished

This commit is contained in:
Shreyas Sheth 2023-08-24 18:56:09 +05:30
parent b6a66b7d8c
commit 6c5b3c5d4c
2 changed files with 6 additions and 6 deletions

@ -1 +1 @@
Subproject commit 557c6fa326dc423118576a5f9d4b34ba60e0d991
Subproject commit 7c5d104970b91b8fccf377a3b4a50637728872ed

View File

@ -321,12 +321,15 @@ static bool hostap_sta_join(void **sta, u8 *bssid, u8 *wpa_ie, u8 wpa_ie_len,u8
sta_info = ap_sta_add(hapd, bssid);
if (!sta_info) {
wpa_printf(MSG_ERROR, "failed to add station " MACSTR, MAC2STR(bssid));
return false;
goto fail;
}
#ifdef CONFIG_SAE
if (sta_info->lock && os_semphr_take(sta_info->lock, 0) != TRUE) {
wpa_printf(MSG_INFO, "Ignore assoc request as softap is busy with sae calculation for station "MACSTR, MAC2STR(bssid));
if (esp_send_assoc_resp(hapd, sta_info, bssid, WLAN_STATUS_ASSOC_REJECTED_TEMPORARILY, rsnxe ? false : true, subtype) != WLAN_STATUS_SUCCESS) {
goto fail;
}
return false;
}
#endif /* CONFIG_SAE */
@ -357,10 +360,7 @@ static bool hostap_sta_join(void **sta, u8 *bssid, u8 *wpa_ie, u8 wpa_ie_len,u8
}
fail:
if (sta_info) {
ap_free_sta(hapd, sta_info);
}
esp_wifi_ap_deauth_internal(bssid, WLAN_REASON_PREV_AUTH_NOT_VALID);
return false;
}
#endif