2016-12-08 09:22:10 -05:00
|
|
|
#include "unity.h"
|
2016-12-13 00:23:04 -05:00
|
|
|
#include "esp_deep_sleep.h"
|
2016-12-08 09:22:10 -05:00
|
|
|
#include "driver/rtc_io.h"
|
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/task.h"
|
|
|
|
|
|
|
|
TEST_CASE("esp_deepsleep works", "[deepsleep]")
|
|
|
|
{
|
|
|
|
esp_deep_sleep(2000000);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void deep_sleep_task(void* arg)
|
|
|
|
{
|
|
|
|
esp_deep_sleep_start();
|
|
|
|
}
|
|
|
|
|
|
|
|
static void do_deep_sleep_from_app_cpu()
|
|
|
|
{
|
|
|
|
xTaskCreatePinnedToCore(&deep_sleep_task, "ds", 2048, NULL, 5, NULL, 1);
|
|
|
|
|
|
|
|
// keep running some non-IRAM code
|
|
|
|
vTaskSuspendAll();
|
|
|
|
while(true) {
|
|
|
|
;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-16 01:10:07 -05:00
|
|
|
TEST_CASE("wake up using timer", "[deepsleep]")
|
2016-12-08 09:22:10 -05:00
|
|
|
{
|
|
|
|
esp_deep_sleep_enable_timer_wakeup(2000000);
|
|
|
|
esp_deep_sleep_start();
|
|
|
|
}
|
|
|
|
|
2016-12-16 01:10:07 -05:00
|
|
|
TEST_CASE("enter deep sleep on APP CPU and wake up using timer", "[deepsleep]")
|
2016-12-08 09:22:10 -05:00
|
|
|
{
|
|
|
|
esp_deep_sleep_enable_timer_wakeup(2000000);
|
|
|
|
do_deep_sleep_from_app_cpu();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-12-16 01:10:07 -05:00
|
|
|
TEST_CASE("wake up using ext0 (13 high)", "[deepsleep]")
|
2016-12-08 09:22:10 -05:00
|
|
|
{
|
|
|
|
ESP_ERROR_CHECK(rtc_gpio_init(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(gpio_pullup_dis(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(gpio_pulldown_en(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(esp_deep_sleep_enable_ext0_wakeup(GPIO_NUM_13, 1));
|
|
|
|
esp_deep_sleep_start();
|
|
|
|
}
|
|
|
|
|
2016-12-16 01:10:07 -05:00
|
|
|
TEST_CASE("wake up using ext0 (13 low)", "[deepsleep]")
|
2016-12-08 09:22:10 -05:00
|
|
|
{
|
|
|
|
ESP_ERROR_CHECK(rtc_gpio_init(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(gpio_pullup_en(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(gpio_pulldown_dis(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(esp_deep_sleep_enable_ext0_wakeup(GPIO_NUM_13, 0));
|
|
|
|
esp_deep_sleep_start();
|
|
|
|
}
|
|
|
|
|
2016-12-16 01:10:07 -05:00
|
|
|
TEST_CASE("wake up using ext1 when RTC_PERIPH is off (13 high)", "[deepsleep]")
|
|
|
|
{
|
|
|
|
// This test needs external pulldown
|
|
|
|
ESP_ERROR_CHECK(rtc_gpio_init(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(esp_deep_sleep_enable_ext1_wakeup(BIT(GPIO_NUM_13), ESP_EXT1_WAKEUP_ANY_HIGH));
|
|
|
|
esp_deep_sleep_start();
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("wake up using ext1 when RTC_PERIPH is off (13 low)", "[deepsleep]")
|
|
|
|
{
|
|
|
|
// This test needs external pullup
|
|
|
|
ESP_ERROR_CHECK(rtc_gpio_init(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(esp_deep_sleep_enable_ext1_wakeup(BIT(GPIO_NUM_13), ESP_EXT1_WAKEUP_ALL_LOW));
|
|
|
|
esp_deep_sleep_start();
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("wake up using ext1 when RTC_PERIPH is on (13 high)", "[deepsleep]")
|
2016-12-08 09:22:10 -05:00
|
|
|
{
|
|
|
|
ESP_ERROR_CHECK(rtc_gpio_init(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(gpio_pullup_dis(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(gpio_pulldown_en(GPIO_NUM_13));
|
2016-12-16 01:10:07 -05:00
|
|
|
ESP_ERROR_CHECK(esp_deep_sleep_pd_config(ESP_PD_DOMAIN_RTC_PERIPH, ESP_PD_OPTION_ON));
|
2016-12-14 01:20:01 -05:00
|
|
|
ESP_ERROR_CHECK(esp_deep_sleep_enable_ext1_wakeup(BIT(GPIO_NUM_13), ESP_EXT1_WAKEUP_ANY_HIGH));
|
2016-12-08 09:22:10 -05:00
|
|
|
esp_deep_sleep_start();
|
|
|
|
}
|
|
|
|
|
2016-12-16 01:10:07 -05:00
|
|
|
TEST_CASE("wake up using ext1 when RTC_PERIPH is on (13 low)", "[deepsleep]")
|
2016-12-08 09:22:10 -05:00
|
|
|
{
|
|
|
|
ESP_ERROR_CHECK(rtc_gpio_init(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(gpio_pullup_en(GPIO_NUM_13));
|
|
|
|
ESP_ERROR_CHECK(gpio_pulldown_dis(GPIO_NUM_13));
|
2016-12-16 01:10:07 -05:00
|
|
|
ESP_ERROR_CHECK(esp_deep_sleep_pd_config(ESP_PD_DOMAIN_RTC_PERIPH, ESP_PD_OPTION_ON));
|
2016-12-14 01:20:01 -05:00
|
|
|
ESP_ERROR_CHECK(esp_deep_sleep_enable_ext1_wakeup(BIT(GPIO_NUM_13), ESP_EXT1_WAKEUP_ALL_LOW));
|
2016-12-08 09:22:10 -05:00
|
|
|
esp_deep_sleep_start();
|
|
|
|
}
|