ESP32設備使用machine.deepsleep()函數后的喚醒情況詳解
近期,用戶在使用machine.deepsleep()函數控制ESP32設備進入深度睡眠后,發現設備在喚醒時顯示rst:0x5 (DEEPSLEEP_RESET)和boot:0x13 (SPI_FAST_FLASH_BOOT)的信息,并對此感到困惑。下面是用戶提供的代碼及運行結果:
import machine import time <h1>初始化RTC用于在深度睡眠間保存數據</h1><p>rtc = machine.RTC()</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.
用戶的問題在于為何會出現rst:0x5 (DEEPSLEEP_RESET)和boot:0x13 (SPI_FAST_FLASH_BOOT)的信息。經過分析,發現問題出在代碼未能正確上傳到ESP32設備上。
在使用machine.deepsleep()函數時,ESP32設備會進入深度睡眠狀態,并在設定時間后自動喚醒。rst:0x5 (DEEPSLEEP_RESET)表示設備是從深度睡眠狀態中喚醒的,而boot:0x13 (SPI_FAST_FLASH_BOOT)表示設備使用SPI快速閃存啟動模式進行啟動。這些信息都是正常的設備啟動和喚醒過程中的日志。
然而,用戶的問題在于代碼未能正確上傳到ESP32設備上,導致設備在喚醒后無法執行預期的代碼。因此,解決此問題的方法是確保將代碼正確上傳到ESP32設備上,這樣設備在從深度睡眠中喚醒后就能正確執行預期的任務。
? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END