BASIC4MCU | 질문게시판 | esp32 C3 Deep Sleep Mode 관련 질문
페이지 정보
작성자 cansad 작성일2023-10-14 13:03 조회1,693회 댓글2건첨부파일
본문
안녕하세요.
현재 센싱된 데이터를 서버로 전송하는 프로젝트를 진행하고 있습니다.
장기간 사용하다보니 리튬 폴리머 배터리의 소모전력을 최소화해야겠더라구요.
그래서 Deep Sleep Mode 진입 후 정해진 타이머에 일어나 데이터를 전송하고 다시 잠이 드는 펌웨어를 설계하려고 합니다.
칩셋은 esp-c3-mini-1 을 사용하고 있고 PCB 회로는 따로 첨부하였습니다.
문제는.
아두이노 IDE에서 기본적으로 제공하는 Deep Sleep 예제를 사용하게 되면 보드가 죽는 현상이 발생합니다.
인터럽트 핀으로 칩셋을 깨우는 형태가 아닌 타이머로 5초간 재웠다고 깨우는 코드로 알고있습니다.
예제를 업로드 하게 되면 보드가 죽고포트 인식이 되지 않고 업로드가 되지 않습니다. (부트로더를 다시 업로드하고 이전 소스를 지우고 하면 살아나긴 합니다)
[TimerWakeup 에제 코드]
#define uS_TO_S_FACTOR 1000000ULL
#define TIME_TO_SLEEP 5
RTC_DATA_ATTR int bootCount = 0;
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: %d\n",wakeup_reason); break;
}
}
void setup(){
Serial.begin(115200);
delay(1000);
++bootCount;
Serial.println("Boot number: " + String(bootCount));
print_wakeup_reason();
esp_sleep_enable_timer_wakeup(TIME_TO_SLEEP * uS_TO_S_FACTOR);
Serial.println("Setup ESP32 to sleep for every " + String(TIME_TO_SLEEP) +
" Seconds");
Serial.println("Going to sleep now");
Serial.flush();
esp_deep_sleep_start();
Serial.println("This will never be printed");
}
void loop(){
//This is not going to be called
}
타이머를 사용하는데 회로의 영향을 받는 것인지... (ADC 포트 사용시 Wifi 동작이 안되는 부분도 있으니까..)
해당 칩셋에 업로드가 되면 안되는 예제인지 잘 모르겠네요..
제가 문제를 찾을 수 있도록 실마리라도 부탁드립니다!
댓글 2
조회수 1,693cansad님의 댓글
cansad 작성일
14:46:31.299 -> Boot number: 1
14:46:31.299 -> Wakeup was not caused by deep sleep: 0
14:46:31.299 -> Setup ESP32 to sleep for every 5 Seconds
14:46:36.313 -> Going to sleep now
출력 결과는 이렇게 나오는데 Wakeup 에서 timer Wakeup 적용이 안되는것같네요
master님의 댓글
master 작성일
https://lastminuteengineers.com/esp32-deep-sleep-wakeup-sources/
이 예제를 돌려보고 계신가봅니다.
예제에서 구현한 회로와 동일하게 구성해서 돌려보세요
동일하게 동작하는 것을 확인 한 후에 하나씩 기능을 추가하면서 체크 해보세요