ESP32 为什么 WiFi 连接会导致深度睡眠后出现"Brownout detector was triggered"



从深度睡眠中醒来后重新连接WiFi时,触发错误的"限电检测器";,导致ESP部分重启。设置阶段再次完成,但现在WiFi成功连接。

深度睡眠后如何正确重建WiFi连接?

#include <WiFi.h>
#include "esp_wifi.h"

#define SSID    "myssid"
#define PASS    "ssidpass"

#define uS_TO_S_FACTOR 1000000ULL   /* Conversion factor for micro seconds to seconds */
#define TIME_TO_SLEEP  10           /* Time ESP32 will go to sleep (in seconds) */

RTC_DATA_ATTR int boot_count = 0;

void setup() {
Serial.begin(115200);
delay(200);

print_wakeup_reason();
Serial.print("Boot count: "); Serial.println(boot_count);

Serial.println("WiFi connection");
WiFi.begin(SSID, PASS);
int try_count = 0;
while (WiFi.status() != WL_CONNECTED && try_count < 10) {
try_count++;
delay(1000);
Serial.println("Connection...");
}
Serial.println("WiFi connected");

WiFi.disconnect();
esp_wifi_stop();
Serial.println("Sleeping in 1s ...");
delay(1000);

esp_deep_sleep(TIME_TO_SLEEP * uS_TO_S_FACTOR);  
}

void loop() {
}

void print_wakeup_reason(){
esp_sleep_wakeup_cause_t wakeup_reason;

wakeup_reason = esp_sleep_get_wakeup_cause();

switch(wakeup_reason)
{
case ESP_SLEEP_WAKEUP_EXT0 : Serial.println("Wakeup caused by external signal using RTC_IO"); break;
case ESP_SLEEP_WAKEUP_EXT1 : Serial.println("Wakeup caused by external signal using RTC_CNTL"); break;
case ESP_SLEEP_WAKEUP_TIMER : Serial.println("Wakeup caused by timer"); break;
case ESP_SLEEP_WAKEUP_TOUCHPAD : Serial.println("Wakeup caused by touchpad"); break;
case ESP_SLEEP_WAKEUP_ULP : Serial.println("Wakeup caused by ULP program"); break;
default : Serial.printf("Wakeup was not caused by deep sleep: %dn",wakeup_reason); break;
}
}

对应的串口监控信息:

ets Jun  8 2016 00:22:57
rst:0xc (SW_CPU_RESET),boot:0x13 (SPI_FAST_FLASH_BOOT)
configsip: 0, SPIWP:0xee
clk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00
mode:DIO, clock div:1
load:0x3fff0018,len:4
load:0x3fff001c,len:1044
load:0x40078000,len:8896
load:0x40080400,len:5816
entry 0x400806ac
Wakeup was not caused by deep sleep: 0
Boot count: 0
WiFi connection
Connection...
WiFi connected
Sleeping in 1s ...
ets Jun  8 2016 00:22:57
rst:0x5 (DEEPSLEEP_RESET),boot:0x13 (SPI_FAST_FLASH_BOOT)
configsip: 0, SPIWP:0xee
clk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00
mode:DIO, clock div:1
load:0x3fff0018,len:4
load:0x3fff001c,len:1044
load:0x40078000,len:8896
load:0x40080400,len:5816
entry 0x400806ac
Wakeup caused by timer
Boot count: 0
WiFi connection
Brownout detector was triggered
ets Jun  8 2016 00:22:57
rst:0xc (SW_CPU_RESET),boot:0x13 (SPI_FAST_FLASH_BOOT)
configsip: 0, SPIWP:0xee
clk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00
mode:DIO, clock div:1
load:0x3fff0018,len:4
load:0x3fff001c,len:1044
load:0x40078000,len:8896
load:0x40080400,len:5816
entry 0x400806ac
Wakeup was not caused by deep sleep: 0
Boot count: 0
WiFi connection
Connection...
WiFi connected
Sleeping in 1s ...
ets Jun  8 2016 00:22:57
rst:0x5 (DEEPSLEEP_RESET),boot:0x13 (SPI_FAST_FLASH_BOOT)
configsip: 0, SPIWP:0xee
clk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00
mode:DIO, clock div:1
load:0x3fff0018,len:4
load:0x3fff001c,len:1044
load:0x40078000,len:8896
load:0x40080400,len:5816
entry 0x400806ac
Wakeup caused by timer
Boot count: 0
WiFi connection
Brownout detector was triggered

我使用的是esp - woom -32(芯片是ESP32D0WDQ6(修订1)),在GNU Linux上,使用Arduino IDE 1.8.13,卡库:expressif System 1.0.4

这是电源问题。你需要一个更强大的电源来为ESP32供电。如果使用USB供电的开发板,请尝试更换USB电缆并将其直接连接到计算机上的USB端口。电源USB集线器也可能有帮助。

由于我的电缆无疑是好的,我坚持不懈,并在网上找到了这个解决方案。故障是否来自于仿制品而非真品?谜。

#include "soc/soc.h"
#include "soc/rtc_cntl_reg.h"
void initialize() {
WRITE_PERI_REG(RTC_CNTL_BROWN_OUT_REG, 0);
}

我也遇到了同样的问题,有人提到过这是一个电源相关的问题吗?我把电源从2.0换成了3.0,问题就解决了。

所以我也看到了这个问题。"停电检测器被触发";在我的ESP32-S2-WROOMD (DevKit)。当WiFi。Begin被调用,但只有当我的ESP32 DevKit加载时:这意味着我正在使用3.3V导轨为一些gpio供电,并且我还使用5V传感器。

认为USB(2和3)端口不能驱动足够的电压/电流,我从USB源移动到一个单独的稳压5V电源。这似乎可以很好地驱动MCU和外设线,但我仍然会间歇性断电。

然后我在5V正/负源上添加了一个极化220uF电容器,这几乎消除了我的问题。但不幸的是,这种情况偶尔也会发生。

我的钻机包括一个EPROG/JTAG调试板与PlatformIO。认为板也可能是贡献,我断开了调试板,这似乎已经解决了我的问题(我不想试图禁用停电检测器btw)。

所以,坦率地说,我的想法是ESP32-S2对功率波动非常敏感和挑剔,当MCU单独或简单地与一两个传感器连接时,通常不会发生功率波动,但是当您"负载"时,它会发生波动。如果有电源波动(即使是外部供电而不是通过USB供电),芯片也有问题。顺便说一句,我甚至把调节电源调到5.5V,看看额外的果汁是否能解决问题,但仍然没有100%治愈。

考虑迁移到较新的S3....

在寻找最低消耗的过程中,我最终进行了各种优化。关闭WiFi后,我的ESP进入深度睡眠状态,我在关闭WiFi的情况下将ESP从深度睡眠状态中取出。我在使用WiFi之前会重新激活它。ESP唤醒时间不是问题,低消耗是我的首要任务。它的工作没有问题,甚至没有使用我发布的第一个解决方案。

最新更新