mirror of
https://github.com/0xFEEDC0DE64/arduino-esp32.git
synced 2025-07-04 14:26:31 +02:00
Reliability fix for autoReconnect when assoc_fail, autoReconnect did not work before for these failures. Changes behavior of WIFI_REASON_ASSOC_FAIL event when autoReconnect is set, removes WIFI_REASON_ASSOC_FAIL/WL_CONNECT_FAILED so retry waitforconnectresult loop stays active for the retry, was not working before.
This commit is contained in:
@ -852,7 +852,7 @@ esp_err_t WiFiGenericClass::_eventCallback(arduino_event_t *event)
|
|||||||
log_w("Reason: %u - %s", reason, reason2str(reason));
|
log_w("Reason: %u - %s", reason, reason2str(reason));
|
||||||
if(reason == WIFI_REASON_NO_AP_FOUND) {
|
if(reason == WIFI_REASON_NO_AP_FOUND) {
|
||||||
WiFiSTAClass::_setStatus(WL_NO_SSID_AVAIL);
|
WiFiSTAClass::_setStatus(WL_NO_SSID_AVAIL);
|
||||||
} else if(reason == WIFI_REASON_AUTH_FAIL || reason == WIFI_REASON_ASSOC_FAIL) {
|
} else if(reason == WIFI_REASON_AUTH_FAIL) {
|
||||||
WiFiSTAClass::_setStatus(WL_CONNECT_FAILED);
|
WiFiSTAClass::_setStatus(WL_CONNECT_FAILED);
|
||||||
} else if(reason == WIFI_REASON_BEACON_TIMEOUT || reason == WIFI_REASON_HANDSHAKE_TIMEOUT) {
|
} else if(reason == WIFI_REASON_BEACON_TIMEOUT || reason == WIFI_REASON_HANDSHAKE_TIMEOUT) {
|
||||||
WiFiSTAClass::_setStatus(WL_CONNECTION_LOST);
|
WiFiSTAClass::_setStatus(WL_CONNECTION_LOST);
|
||||||
@ -862,12 +862,17 @@ esp_err_t WiFiGenericClass::_eventCallback(arduino_event_t *event)
|
|||||||
WiFiSTAClass::_setStatus(WL_DISCONNECTED);
|
WiFiSTAClass::_setStatus(WL_DISCONNECTED);
|
||||||
}
|
}
|
||||||
clearStatusBits(STA_CONNECTED_BIT | STA_HAS_IP_BIT | STA_HAS_IP6_BIT);
|
clearStatusBits(STA_CONNECTED_BIT | STA_HAS_IP_BIT | STA_HAS_IP6_BIT);
|
||||||
if(((reason == WIFI_REASON_AUTH_EXPIRE) ||
|
if(WiFi.getAutoReconnect()){
|
||||||
(reason >= WIFI_REASON_BEACON_TIMEOUT && reason != WIFI_REASON_AUTH_FAIL)) &&
|
if((reason == WIFI_REASON_AUTH_EXPIRE) ||
|
||||||
WiFi.getAutoReconnect())
|
(reason >= WIFI_REASON_BEACON_TIMEOUT && reason != WIFI_REASON_AUTH_FAIL))
|
||||||
{
|
{
|
||||||
WiFi.disconnect();
|
log_d("WiFi AutoReconnect Running");
|
||||||
WiFi.begin();
|
WiFi.disconnect();
|
||||||
|
WiFi.begin();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (reason == WIFI_REASON_ASSOC_FAIL){
|
||||||
|
WiFiSTAClass::_setStatus(WL_CONNECT_FAILED);
|
||||||
}
|
}
|
||||||
} else if(event->event_id == ARDUINO_EVENT_WIFI_STA_GOT_IP) {
|
} else if(event->event_id == ARDUINO_EVENT_WIFI_STA_GOT_IP) {
|
||||||
#if ARDUHAL_LOG_LEVEL >= ARDUHAL_LOG_LEVEL_DEBUG
|
#if ARDUHAL_LOG_LEVEL >= ARDUHAL_LOG_LEVEL_DEBUG
|
||||||
|
Reference in New Issue
Block a user