完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我有一个运行 ESP32-S3 WROOM 模块的定制板。这个模块上的一根线连接到一个外部按钮,在 GPIO13 上有一个上拉电阻,我希望这个按钮作为 DeepSleep 唤醒源运行。
大多数情况下,电路板唤醒并报告按钮已成功按下。不过,我偶尔会遇到一个问题,它报告为电源重置 esp_sleep_get_ext1_wakeup_status() 读取 0 和 esp_sleep_get_wakeup_cause() != ESP_SLEEP_WAKEUP_EXT1 我已经查看了尽可能多的资源,但我看不出有任何理由可以解释这种奇怪的行为. 我正在运行 ESP-IDF 版本 4.4.1。这个问题也不是特定于一块板——我有 10 块板都很少出现同样的问题。 代码:全选 void enter_deep_sleep(void) { ESP_LOGI(TAG, "Entering Deep Sleep"); // Application Specific Shutdown Here /**/ // Enable Wakeup Sources ESP_ERROR_CHECK(esp_sleep_enable_timer_wakeup(DEEP_SLEEP_PERIOD_MICROSECONDS)); // Wake after 30s, ESP_ERROR_CHECK(esp_sleep_enable_ext1_wakeup((1 << BTN_SNS_GPIO), ESP_EXT1_WAKEUP_ALL_LOW)); // Or on RGB Button Press // Actually Sleep Now esp_deep_sleep_start(); } void app_main(void) { ESP_LOGI(TAG, "nntController Version %u.%u.%u - %s", FW_VERSION[0], FW_VERSION[1], FW_VERSION[2], git_commit_id); // Check how / why we rebooted uint64_t wakepins = esp_sleep_get_ext1_wakeup_status(); ESP_LOGE(TAG, "Wake GPIO Source %llu (Bit %d)", wakepins, ffs(wakepins & wakepins)); // Should only ever have 1 bit set esp_sleep_wakeup_cause_t wakeup_reason = esp_sleep_get_wakeup_cause(); // Here, we check why we woke up // wakepins == 0 and wakeup_reason != ESP_SLEEP_WAKEUP_EXT1 /*********** Rest of our application code *****************/ } |
|
相关推荐
|
|
只有小组成员才能发言,加入小组>>
1140 浏览 1 评论
577浏览 6评论
478浏览 5评论
有没有办法在不使用混杂模式的情况下实现Wifi驱动程序接收缓冲区访问中断呢?
462浏览 5评论
463浏览 4评论
438浏览 4评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-22 20:04 , Processed in 0.814875 second(s), Total 73, Slave 56 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号