← index #6151Issue #15563
Related · medium · value 4.846
QUERY · ISSUE

esp_wifi_internal_reg_rxcb ret=0x3014

openby mryu-orgopened 2020-06-15updated 2020-06-17
port-esp32

micropython: ESP-IDF v3.x GENERICv1.12
Can't Connect WiFi,REPL:
E (1999968) event: system_event_sta_disconnected_handle_default 294 esp_wifi_internal_reg_rxcb ret=0x3014
E (1999968) wifi: esp_wifi_connect 1134 wifi not start

CANDIDATE · ISSUE

ESP32 wifi issues

openby fjmtttyopened 2024-07-28updated 2025-03-03
bugport-esp32needs-info

Port, board and/or hardware

ESP32

MicroPython version

esp32-20220618-v1.19.1.bin

Reproduction

Issue No.1:On startup
Issue No.2:On startup / while running

Expected behaviour

Connected to the wifi smooth and keep that.

Observed behaviour

Issue No.1: "Wifi internal error" occurs. After power off and on, sometimes it works but mostly not. Once it gets recovered, it keep working without any error which looks strange for me. Just adding print(anything) may have solved...

Issue No.2:I'm using 30+ ESP32 with micropython. Most of them connect wifi smooth and keep it. But some 1 or 2 of them suddenly start struggling to connect wifi when start up(cannot connect even after the reboot, unplug power and plug) or lose connection when it's working. But after a while, it works completely normal. The boards which have this issue is random.

(1)This is the code to connect wifi.

"""Wifi"""
def connect_wifi(ssid, passkey, timeout=5): 
global speed_filtered, bias, speed_raw 
wifi= network.WLAN(network.STA_IF)
wifi.active(False)
time.sleep(1)
wifi.active(True)
wifi.connect(ssid, passkey)
start = time.time()
start_count = time.time()
while not wifi.isconnected():
    print('*')
    time.sleep(1)
    if time.time()-start > timeout:
        wifi.disconnect()
        time.sleep(1)
        wifi.connect(ssid, passkey)
        start = time.time()
    
if wifi.isconnected():
    print('Connected')
    print(time.time() - start_count)
    return wifi

.
(2) this is the code to check wifi status. if it's not connected, it try to reconnect.

if wifi.isconnected():
    if wifi_strength > 80:
        wifi_strength_category = 4
    elif wifi_strength > 60:
        wifi_strength_category = 3
    elif wifi_strength > 40:
        wifi_strength_category = 2
    else:
        wifi_strength_category = 1
else:
    wifi = connect_wifi(SSID_NAME, SSID_PASS)

Additional Information

No, I've provided everything above.

Code of Conduct

Yes, I agree

Keyboard

j / / n
next pair
k / / p
previous pair
1 / / h
show query pane
2 / / l
show candidate pane
c
copy suggested comment
r
toggle reasoning
g i
go to index
?
show this help
esc
close overlays

press ? or esc to close

copied