在使用esp32进行深度睡眠模式的编程时,开发者可能会遇到这样的情况:设备进入深度睡眠后,唤醒时控制台显示rst:0x5 (deepsleep_reset)和boot:0x13 (spi_fast_flash_boot)。我们来探讨这意味着什么,以及如何解决这个问题。
以下是相关代码示例:
import machineimport time初始化RTC用于在深度睡眠间保存数据
rtc = machine.RTC()
定义任务函数
def task1():print("执行任务1")
这里添加任务1的具体操作
# 比如读取传感器、控制GPIO等
def task2():print("执行任务2")
这里添加任务2的具体操作
# 比如发送数据、改变状态等
检查唤醒原因
if machine.reset_cause() == machine.DEEPSLEEP_RESET:
从RTC内存读取状态
state = rtc.memory()print("从深度睡眠唤醒,之前状态:", state)if state == b'x00': task1() new_state = b'x01'else: task2() new_state = b'x00'
else:
首次启动时执行任务1
print("冷启动")task1()new_state = b'x01'
保存新状态到RTC内存
rtc.memory(new_state)
设置深度睡眠30秒(30000毫秒)后唤醒
print("进入深度睡眠...")machine.deepsleep(30000)
运行结果显示:
冷启动执行任务1进入深度睡眠...ets Jul 29 2019 12:21:46rst:0x5 (DEEPSLEEP_RESET),boot:0x13 (SPI_FAST_FLASH_BOOT)configsip: 0, SPIWP:0xeeclk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00mode:DIO, clock div:2load:0x3fff0030,len:4540ho 0 tail 12 room 4load:0x40078000,len:12344ho 0 tail 12 room 4load:0x40080400,len:4124entry 0x40080680MicroPython v1.19.1 on 2022-06-18; ESP32 module with ESP32Type "help()" for more information.
在以上输出中,rst:0x5 (DEEPSLEEP_RESET)表示设备是从深度睡眠状态中唤醒的,而boot:0x13 (SPI_FAST_FLASH_BOOT)则表明设备是通过SPI快闪启动的。这是正常的启动行为。
然而,如果代码未能正确上传到ESP32上,可能会导致问题。解决方案是确保将代码正确上传到ESP32设备上。

以上就是为什么ESP32深度睡眠唤醒后显示rst:0x5 (DEEPSLEEP_RESET)和boot:0x13 (SPI_FAST_FLASH_BOOT)?如何解决这个问题?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1360744.html
微信扫一扫
支付宝扫一扫