在micropython中使用machine.deepsleep()函数后出现的rst:0x5 (deepsleep_reset)和boot:0x13 (spi_fast_flash_boot)提示信息的原因和解决方法如下:
关于machine.deepsleep()后出现的rst:0x5 (DEEPSLEEP_RESET)和boot:0x13 (SPI_FAST_FLASH_BOOT)问题
在使用Micropython进行编程时,常常会遇到与硬件相关的特殊情况。最近,有用户在使用machine.deepsleep()函数后,设备在唤醒时出现了rst:0x5 (DEEPSLEEP_RESET)和boot:0x13 (SPI_FAST_FLASH_BOOT)的提示信息,并对其含义和解决方法感到困惑。
以下是用户提供的代码示例:
import machine import time <h1>初始化RTC用于在深度睡眠间保存数据</h1><p>rtc = machine.RTC()</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/00968c3c2c15" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">Python免费学习笔记(深入)</a>”;</p><h1>定义任务函数</h1><p>def task1(): print("执行任务1")</p><h1>这里添加任务1的具体操作</h1><pre class="brush:php;toolbar:false"># 比如读取传感器、控制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:46</p><p>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:2 load:0x3fff0030,len:4540 ho 0 tail 12 room 4 load:0x40078000,len:12344 ho 0 tail 12 room 4 load:0x40080400,len:4124 entry 0x40080680 MicroPython v1.19.1 on 2022-06-18; ESP32 module with ESP32 Type "help()" for more information.
用户在遇到这个问题后,经过一番排查,发现问题的原因是没有将代码上传到ESP32模块上。原来,rst:0x5 (DEEPSLEEP_RESET)表示设备是从深度睡眠状态中唤醒的,而boot:0x13 (SPI_FAST_FLASH_BOOT)表示设备正在使用SPI快速闪存启动模式。这两个信息本身并不表示有问题,而是正常的设备状态信息。
因此,解决这个问题的方法非常简单:确保将代码正确上传到ESP32模块上。用户在确认代码已经上传到设备后,设备能够正常进入深度睡眠并在设定时间后唤醒,运行相应的任务函数。