mirror of
https://github.com/espressif/esp-idf.git
synced 2025-08-05 21:54:33 +02:00
light sleep: light sleep support for esp32c3
This commit is contained in:
@@ -1,17 +1,10 @@
|
|||||||
|
|
||||||
idf_build_get_property(target IDF_TARGET)
|
|
||||||
# Remove when sleep is brought up on master for C3 TODO ESP32-C3 IDF-2571
|
|
||||||
if(NOT (${target} STREQUAL "esp32c3") )
|
|
||||||
list(APPEND sleep_src "sleep_modes.c")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
idf_component_register(SRCS "intr_alloc.c"
|
idf_component_register(SRCS "intr_alloc.c"
|
||||||
"esp_async_memcpy.c"
|
"esp_async_memcpy.c"
|
||||||
"panic.c"
|
"panic.c"
|
||||||
"system_api.c"
|
"system_api.c"
|
||||||
"startup.c"
|
"startup.c"
|
||||||
"system_time.c"
|
"system_time.c"
|
||||||
"${sleep_src}"
|
"sleep_modes.c"
|
||||||
INCLUDE_DIRS include
|
INCLUDE_DIRS include
|
||||||
PRIV_REQUIRES spi_flash
|
PRIV_REQUIRES spi_flash
|
||||||
# [refactor-todo] requirements due to init code,
|
# [refactor-todo] requirements due to init code,
|
||||||
|
@@ -171,8 +171,10 @@ static portMUX_TYPE spinlock_rtc_deep_sleep = portMUX_INITIALIZER_UNLOCKED;
|
|||||||
static const char* TAG = "sleep";
|
static const char* TAG = "sleep";
|
||||||
|
|
||||||
static uint32_t get_power_down_flags(void);
|
static uint32_t get_power_down_flags(void);
|
||||||
|
#if SOC_PM_SUPPORT_EXT_WAKEUP
|
||||||
static void ext0_wakeup_prepare(void);
|
static void ext0_wakeup_prepare(void);
|
||||||
static void ext1_wakeup_prepare(void);
|
static void ext1_wakeup_prepare(void);
|
||||||
|
#endif
|
||||||
static void timer_wakeup_prepare(void);
|
static void timer_wakeup_prepare(void);
|
||||||
#if CONFIG_IDF_TARGET_ESP32S2 || CONFIG_IDF_TARGET_ESP32S3
|
#if CONFIG_IDF_TARGET_ESP32S2 || CONFIG_IDF_TARGET_ESP32S3
|
||||||
static void touch_wakeup_prepare(void);
|
static void touch_wakeup_prepare(void);
|
||||||
@@ -326,8 +328,7 @@ void esp_sleep_gpio_status_switch_configure(bool enable)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif // SOC_GPIO_SUPPORT_SLP_SWITCH
|
||||||
#endif
|
|
||||||
|
|
||||||
static uint32_t IRAM_ATTR esp_sleep_start(uint32_t pd_flags)
|
static uint32_t IRAM_ATTR esp_sleep_start(uint32_t pd_flags)
|
||||||
{
|
{
|
||||||
@@ -356,6 +357,7 @@ static uint32_t IRAM_ATTR esp_sleep_start(uint32_t pd_flags)
|
|||||||
rtc_clk_cpu_freq_get_config(&cpu_freq_config);
|
rtc_clk_cpu_freq_get_config(&cpu_freq_config);
|
||||||
rtc_clk_cpu_freq_set_xtal();
|
rtc_clk_cpu_freq_set_xtal();
|
||||||
|
|
||||||
|
#if SOC_PM_SUPPORT_EXT_WAKEUP
|
||||||
// Configure pins for external wakeup
|
// Configure pins for external wakeup
|
||||||
if (s_config.wakeup_triggers & RTC_EXT0_TRIG_EN) {
|
if (s_config.wakeup_triggers & RTC_EXT0_TRIG_EN) {
|
||||||
ext0_wakeup_prepare();
|
ext0_wakeup_prepare();
|
||||||
@@ -363,6 +365,7 @@ static uint32_t IRAM_ATTR esp_sleep_start(uint32_t pd_flags)
|
|||||||
if (s_config.wakeup_triggers & RTC_EXT1_TRIG_EN) {
|
if (s_config.wakeup_triggers & RTC_EXT1_TRIG_EN) {
|
||||||
ext1_wakeup_prepare();
|
ext1_wakeup_prepare();
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_IDF_TARGET_ESP32
|
#ifdef CONFIG_IDF_TARGET_ESP32
|
||||||
// Enable ULP wakeup
|
// Enable ULP wakeup
|
||||||
@@ -407,6 +410,7 @@ static uint32_t IRAM_ATTR esp_sleep_start(uint32_t pd_flags)
|
|||||||
// Enter sleep
|
// Enter sleep
|
||||||
rtc_sleep_config_t config = RTC_SLEEP_CONFIG_DEFAULT(pd_flags);
|
rtc_sleep_config_t config = RTC_SLEEP_CONFIG_DEFAULT(pd_flags);
|
||||||
rtc_sleep_init(config);
|
rtc_sleep_init(config);
|
||||||
|
rtc_sleep_low_init(s_config.rtc_clk_cal_period);
|
||||||
|
|
||||||
// Set state machine time for light sleep
|
// Set state machine time for light sleep
|
||||||
if(!deep_sleep) {
|
if(!deep_sleep) {
|
||||||
@@ -665,6 +669,7 @@ esp_err_t esp_sleep_disable_wakeup_source(esp_sleep_source_t source)
|
|||||||
} else if (CHECK_SOURCE(source, ESP_SLEEP_WAKEUP_TIMER, RTC_TIMER_TRIG_EN)) {
|
} else if (CHECK_SOURCE(source, ESP_SLEEP_WAKEUP_TIMER, RTC_TIMER_TRIG_EN)) {
|
||||||
s_config.wakeup_triggers &= ~RTC_TIMER_TRIG_EN;
|
s_config.wakeup_triggers &= ~RTC_TIMER_TRIG_EN;
|
||||||
s_config.sleep_duration = 0;
|
s_config.sleep_duration = 0;
|
||||||
|
#if SOC_PM_SUPPORT_EXT_WAKEUP
|
||||||
} else if (CHECK_SOURCE(source, ESP_SLEEP_WAKEUP_EXT0, RTC_EXT0_TRIG_EN)) {
|
} else if (CHECK_SOURCE(source, ESP_SLEEP_WAKEUP_EXT0, RTC_EXT0_TRIG_EN)) {
|
||||||
s_config.ext0_rtc_gpio_num = 0;
|
s_config.ext0_rtc_gpio_num = 0;
|
||||||
s_config.ext0_trigger_level = 0;
|
s_config.ext0_trigger_level = 0;
|
||||||
@@ -673,8 +678,11 @@ esp_err_t esp_sleep_disable_wakeup_source(esp_sleep_source_t source)
|
|||||||
s_config.ext1_rtc_gpio_mask = 0;
|
s_config.ext1_rtc_gpio_mask = 0;
|
||||||
s_config.ext1_trigger_mode = 0;
|
s_config.ext1_trigger_mode = 0;
|
||||||
s_config.wakeup_triggers &= ~RTC_EXT1_TRIG_EN;
|
s_config.wakeup_triggers &= ~RTC_EXT1_TRIG_EN;
|
||||||
|
#endif
|
||||||
|
#if SOC_TOUCH_PAD_WAKE_SUPPORTED
|
||||||
} else if (CHECK_SOURCE(source, ESP_SLEEP_WAKEUP_TOUCHPAD, RTC_TOUCH_TRIG_EN)) {
|
} else if (CHECK_SOURCE(source, ESP_SLEEP_WAKEUP_TOUCHPAD, RTC_TOUCH_TRIG_EN)) {
|
||||||
s_config.wakeup_triggers &= ~RTC_TOUCH_TRIG_EN;
|
s_config.wakeup_triggers &= ~RTC_TOUCH_TRIG_EN;
|
||||||
|
#endif
|
||||||
} else if (CHECK_SOURCE(source, ESP_SLEEP_WAKEUP_GPIO, RTC_GPIO_TRIG_EN)) {
|
} else if (CHECK_SOURCE(source, ESP_SLEEP_WAKEUP_GPIO, RTC_GPIO_TRIG_EN)) {
|
||||||
s_config.wakeup_triggers &= ~RTC_GPIO_TRIG_EN;
|
s_config.wakeup_triggers &= ~RTC_GPIO_TRIG_EN;
|
||||||
} else if (CHECK_SOURCE(source, ESP_SLEEP_WAKEUP_UART, (RTC_UART0_TRIG_EN | RTC_UART1_TRIG_EN))) {
|
} else if (CHECK_SOURCE(source, ESP_SLEEP_WAKEUP_UART, (RTC_UART0_TRIG_EN | RTC_UART1_TRIG_EN))) {
|
||||||
@@ -712,6 +720,8 @@ esp_err_t esp_sleep_enable_ulp_wakeup(void)
|
|||||||
#elif CONFIG_IDF_TARGET_ESP32S2 || CONFIG_IDF_TARGET_ESP32S3
|
#elif CONFIG_IDF_TARGET_ESP32S2 || CONFIG_IDF_TARGET_ESP32S3
|
||||||
s_config.wakeup_triggers |= (RTC_ULP_TRIG_EN | RTC_COCPU_TRIG_EN | RTC_COCPU_TRAP_TRIG_EN);
|
s_config.wakeup_triggers |= (RTC_ULP_TRIG_EN | RTC_COCPU_TRIG_EN | RTC_COCPU_TRAP_TRIG_EN);
|
||||||
return ESP_OK;
|
return ESP_OK;
|
||||||
|
#else
|
||||||
|
return ESP_ERR_NOT_SUPPORTED;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -733,7 +743,6 @@ static void timer_wakeup_prepare(void)
|
|||||||
rtc_hal_set_wakeup_timer(s_config.rtc_ticks_at_sleep_start + ticks);
|
rtc_hal_set_wakeup_timer(s_config.rtc_ticks_at_sleep_start + ticks);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#if CONFIG_IDF_TARGET_ESP32S2 || CONFIG_IDF_TARGET_ESP32S3
|
#if CONFIG_IDF_TARGET_ESP32S2 || CONFIG_IDF_TARGET_ESP32S3
|
||||||
/* In deep sleep mode, only the sleep channel is supported, and other touch channels should be turned off. */
|
/* In deep sleep mode, only the sleep channel is supported, and other touch channels should be turned off. */
|
||||||
static void touch_wakeup_prepare(void)
|
static void touch_wakeup_prepare(void)
|
||||||
@@ -749,6 +758,7 @@ static void touch_wakeup_prepare(void)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if SOC_TOUCH_SENSOR_NUM > 0
|
||||||
esp_err_t esp_sleep_enable_touchpad_wakeup(void)
|
esp_err_t esp_sleep_enable_touchpad_wakeup(void)
|
||||||
{
|
{
|
||||||
#if ((defined CONFIG_ESP32_RTC_EXT_CRYST_ADDIT_CURRENT) || (defined CONFIG_ESP32_RTC_EXT_CRYST_ADDIT_CURRENT_V2))
|
#if ((defined CONFIG_ESP32_RTC_EXT_CRYST_ADDIT_CURRENT) || (defined CONFIG_ESP32_RTC_EXT_CRYST_ADDIT_CURRENT_V2))
|
||||||
@@ -773,6 +783,7 @@ touch_pad_t esp_sleep_get_touchpad_wakeup_status(void)
|
|||||||
assert(ret == ESP_OK && "wakeup reason is RTC_TOUCH_TRIG_EN but SENS_TOUCH_MEAS_EN is zero");
|
assert(ret == ESP_OK && "wakeup reason is RTC_TOUCH_TRIG_EN but SENS_TOUCH_MEAS_EN is zero");
|
||||||
return pad_num;
|
return pad_num;
|
||||||
}
|
}
|
||||||
|
#endif // SOC_TOUCH_SENSOR_NUM > 0
|
||||||
|
|
||||||
bool esp_sleep_is_valid_wakeup_gpio(gpio_num_t gpio_num)
|
bool esp_sleep_is_valid_wakeup_gpio(gpio_num_t gpio_num)
|
||||||
{
|
{
|
||||||
@@ -783,6 +794,7 @@ bool esp_sleep_is_valid_wakeup_gpio(gpio_num_t gpio_num)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if SOC_PM_SUPPORT_EXT_WAKEUP
|
||||||
esp_err_t esp_sleep_enable_ext0_wakeup(gpio_num_t gpio_num, int level)
|
esp_err_t esp_sleep_enable_ext0_wakeup(gpio_num_t gpio_num, int level)
|
||||||
{
|
{
|
||||||
if (level < 0 || level > 1) {
|
if (level < 0 || level > 1) {
|
||||||
@@ -889,6 +901,7 @@ uint64_t esp_sleep_get_ext1_wakeup_status(void)
|
|||||||
}
|
}
|
||||||
return gpio_mask;
|
return gpio_mask;
|
||||||
}
|
}
|
||||||
|
#endif // SOC_PM_SUPPORT_EXT_WAKEUP
|
||||||
|
|
||||||
esp_err_t esp_sleep_enable_gpio_wakeup(void)
|
esp_err_t esp_sleep_enable_gpio_wakeup(void)
|
||||||
{
|
{
|
||||||
@@ -917,14 +930,11 @@ esp_err_t esp_sleep_enable_uart_wakeup(int uart_num)
|
|||||||
|
|
||||||
esp_err_t esp_sleep_enable_wifi_wakeup(void)
|
esp_err_t esp_sleep_enable_wifi_wakeup(void)
|
||||||
{
|
{
|
||||||
#if CONFIG_IDF_TARGET_ESP32
|
#if SOC_PM_SUPPORT_WIFI_WAKEUP
|
||||||
return ESP_ERR_NOT_SUPPORTED;
|
|
||||||
#elif CONFIG_IDF_TARGET_ESP32S2
|
|
||||||
s_config.wakeup_triggers |= RTC_WIFI_TRIG_EN;
|
s_config.wakeup_triggers |= RTC_WIFI_TRIG_EN;
|
||||||
return ESP_OK;
|
return ESP_OK;
|
||||||
#elif CONFIG_IDF_TARGET_ESP32S3
|
#else
|
||||||
s_config.wakeup_triggers |= RTC_MAC_TRIG_EN;
|
return ESP_ERR_NOT_SUPPORTED;
|
||||||
return ESP_OK;
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -937,29 +947,39 @@ esp_sleep_wakeup_cause_t esp_sleep_get_wakeup_cause(void)
|
|||||||
|
|
||||||
#ifdef CONFIG_IDF_TARGET_ESP32
|
#ifdef CONFIG_IDF_TARGET_ESP32
|
||||||
uint32_t wakeup_cause = REG_GET_FIELD(RTC_CNTL_WAKEUP_STATE_REG, RTC_CNTL_WAKEUP_CAUSE);
|
uint32_t wakeup_cause = REG_GET_FIELD(RTC_CNTL_WAKEUP_STATE_REG, RTC_CNTL_WAKEUP_CAUSE);
|
||||||
#elif CONFIG_IDF_TARGET_ESP32S2 || CONFIG_IDF_TARGET_ESP32S3
|
#else
|
||||||
uint32_t wakeup_cause = REG_GET_FIELD(RTC_CNTL_SLP_WAKEUP_CAUSE_REG, RTC_CNTL_WAKEUP_CAUSE);
|
uint32_t wakeup_cause = REG_GET_FIELD(RTC_CNTL_SLP_WAKEUP_CAUSE_REG, RTC_CNTL_WAKEUP_CAUSE);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (wakeup_cause & RTC_EXT0_TRIG_EN) {
|
if (wakeup_cause & RTC_TIMER_TRIG_EN) {
|
||||||
return ESP_SLEEP_WAKEUP_EXT0;
|
|
||||||
} else if (wakeup_cause & RTC_EXT1_TRIG_EN) {
|
|
||||||
return ESP_SLEEP_WAKEUP_EXT1;
|
|
||||||
} else if (wakeup_cause & RTC_TIMER_TRIG_EN) {
|
|
||||||
return ESP_SLEEP_WAKEUP_TIMER;
|
return ESP_SLEEP_WAKEUP_TIMER;
|
||||||
} else if (wakeup_cause & RTC_TOUCH_TRIG_EN) {
|
|
||||||
return ESP_SLEEP_WAKEUP_TOUCHPAD;
|
|
||||||
#if SOC_ULP_SUPPORTED
|
|
||||||
} else if (wakeup_cause & RTC_ULP_TRIG_EN) {
|
|
||||||
return ESP_SLEEP_WAKEUP_ULP;
|
|
||||||
#endif
|
|
||||||
} else if (wakeup_cause & RTC_GPIO_TRIG_EN) {
|
} else if (wakeup_cause & RTC_GPIO_TRIG_EN) {
|
||||||
return ESP_SLEEP_WAKEUP_GPIO;
|
return ESP_SLEEP_WAKEUP_GPIO;
|
||||||
} else if (wakeup_cause & (RTC_UART0_TRIG_EN | RTC_UART1_TRIG_EN)) {
|
} else if (wakeup_cause & (RTC_UART0_TRIG_EN | RTC_UART1_TRIG_EN)) {
|
||||||
return ESP_SLEEP_WAKEUP_UART;
|
return ESP_SLEEP_WAKEUP_UART;
|
||||||
#if CONFIG_IDF_TARGET_ESP32S2
|
#if SOC_PM_SUPPORT_EXT_WAKEUP
|
||||||
|
} else if (wakeup_cause & RTC_EXT0_TRIG_EN) {
|
||||||
|
return ESP_SLEEP_WAKEUP_EXT0;
|
||||||
|
} else if (wakeup_cause & RTC_EXT1_TRIG_EN) {
|
||||||
|
return ESP_SLEEP_WAKEUP_EXT1;
|
||||||
|
#endif
|
||||||
|
#if SOC_TOUCH_PAD_WAKE_SUPPORTED
|
||||||
|
} else if (wakeup_cause & RTC_TOUCH_TRIG_EN) {
|
||||||
|
return ESP_SLEEP_WAKEUP_TOUCHPAD;
|
||||||
|
#endif
|
||||||
|
#if SOC_ULP_SUPPORTED
|
||||||
|
} else if (wakeup_cause & RTC_ULP_TRIG_EN) {
|
||||||
|
return ESP_SLEEP_WAKEUP_ULP;
|
||||||
|
#endif
|
||||||
|
#if SOC_PM_SUPPORT_WIFI_WAKEUP
|
||||||
} else if (wakeup_cause & RTC_WIFI_TRIG_EN) {
|
} else if (wakeup_cause & RTC_WIFI_TRIG_EN) {
|
||||||
return ESP_SLEEP_WAKEUP_WIFI;
|
return ESP_SLEEP_WAKEUP_WIFI;
|
||||||
|
#endif
|
||||||
|
#if SOC_PM_SUPPORT_BT_WAKEUP
|
||||||
|
} else if (wakeup_cause & RTC_BT_TRIG_EN) {
|
||||||
|
return ESP_SLEEP_WAKEUP_BT;
|
||||||
|
#endif
|
||||||
|
#if CONFIG_IDF_TARGET_ESP32S2
|
||||||
} else if (wakeup_cause & RTC_COCPU_TRIG_EN) {
|
} else if (wakeup_cause & RTC_COCPU_TRIG_EN) {
|
||||||
return ESP_SLEEP_WAKEUP_ULP;
|
return ESP_SLEEP_WAKEUP_ULP;
|
||||||
} else if (wakeup_cause & RTC_COCPU_TRAP_TRIG_EN) {
|
} else if (wakeup_cause & RTC_COCPU_TRAP_TRIG_EN) {
|
||||||
|
@@ -268,6 +268,9 @@
|
|||||||
#define SOC_AES_SUPPORT_AES_192 (1)
|
#define SOC_AES_SUPPORT_AES_192 (1)
|
||||||
#define SOC_AES_SUPPORT_AES_256 (1)
|
#define SOC_AES_SUPPORT_AES_256 (1)
|
||||||
|
|
||||||
|
/*-------------------------- Power Management CAPS ---------------------------*/
|
||||||
|
#define SOC_PM_SUPPORT_EXT_WAKEUP (1)
|
||||||
|
|
||||||
/* ---------------------------- Compatibility ------------------------------- */
|
/* ---------------------------- Compatibility ------------------------------- */
|
||||||
#define SOC_CAN_SUPPORTED SOC_TWAI_SUPPORTED
|
#define SOC_CAN_SUPPORTED SOC_TWAI_SUPPORTED
|
||||||
#define CAN_BRP_MIN SOC_TWAI_BRP_MIN
|
#define CAN_BRP_MIN SOC_TWAI_BRP_MIN
|
||||||
|
@@ -722,7 +722,7 @@ void rtc_sleep_set_wakeup_time(uint64_t t);
|
|||||||
|
|
||||||
#define RTC_GPIO_TRIG_EN BIT(2) //!< GPIO wakeup
|
#define RTC_GPIO_TRIG_EN BIT(2) //!< GPIO wakeup
|
||||||
#define RTC_TIMER_TRIG_EN BIT(3) //!< Timer wakeup
|
#define RTC_TIMER_TRIG_EN BIT(3) //!< Timer wakeup
|
||||||
#define RTC_MAC_TRIG_EN BIT(5) //!< MAC wakeup (light sleep only)
|
#define RTC_WIFI_TRIG_EN BIT(5) //!< WIFI wakeup (light sleep only)
|
||||||
#define RTC_UART0_TRIG_EN BIT(6) //!< UART0 wakeup (light sleep only)
|
#define RTC_UART0_TRIG_EN BIT(6) //!< UART0 wakeup (light sleep only)
|
||||||
#define RTC_UART1_TRIG_EN BIT(7) //!< UART1 wakeup (light sleep only)
|
#define RTC_UART1_TRIG_EN BIT(7) //!< UART1 wakeup (light sleep only)
|
||||||
#define RTC_BT_TRIG_EN BIT(10) //!< BT wakeup (light sleep only)
|
#define RTC_BT_TRIG_EN BIT(10) //!< BT wakeup (light sleep only)
|
||||||
|
@@ -121,3 +121,8 @@
|
|||||||
|
|
||||||
/*-------------------------- COEXISTENCE HARDWARE PTI CAPS -------------------------------*/
|
/*-------------------------- COEXISTENCE HARDWARE PTI CAPS -------------------------------*/
|
||||||
#define SOC_COEX_HW_PTI (1)
|
#define SOC_COEX_HW_PTI (1)
|
||||||
|
|
||||||
|
/*-------------------------- Power Management CAPS ----------------------------*/
|
||||||
|
#define SOC_PM_SUPPORT_WIFI_WAKEUP (1)
|
||||||
|
|
||||||
|
#define SOC_PM_SUPPORT_BT_WAKEUP (1)
|
||||||
|
@@ -295,6 +295,10 @@
|
|||||||
/*-------------------------- WI-FI HARDWARE TSF CAPS -------------------------------*/
|
/*-------------------------- WI-FI HARDWARE TSF CAPS -------------------------------*/
|
||||||
#define SOC_WIFI_HW_TSF (1)
|
#define SOC_WIFI_HW_TSF (1)
|
||||||
|
|
||||||
|
/*-------------------------- Power Management CAPS ---------------------------*/
|
||||||
|
#define SOC_PM_SUPPORT_EXT_WAKEUP (1)
|
||||||
|
|
||||||
|
#define SOC_PM_SUPPORT_WIFI_WAKEUP (1)
|
||||||
|
|
||||||
/* ---------------------------- Compatibility ------------------------------- */
|
/* ---------------------------- Compatibility ------------------------------- */
|
||||||
// No contents
|
// No contents
|
||||||
|
@@ -718,7 +718,7 @@ void rtc_sleep_set_wakeup_time(uint64_t t);
|
|||||||
#define RTC_GPIO_TRIG_EN BIT(2) //!< GPIO wakeup (light sleep only)
|
#define RTC_GPIO_TRIG_EN BIT(2) //!< GPIO wakeup (light sleep only)
|
||||||
#define RTC_TIMER_TRIG_EN BIT(3) //!< Timer wakeup
|
#define RTC_TIMER_TRIG_EN BIT(3) //!< Timer wakeup
|
||||||
#define RTC_SDIO_TRIG_EN BIT(4) //!< SDIO wakeup (light sleep only)
|
#define RTC_SDIO_TRIG_EN BIT(4) //!< SDIO wakeup (light sleep only)
|
||||||
#define RTC_MAC_TRIG_EN BIT(5) //!< MAC wakeup (light sleep only)
|
#define RTC_WIFI_TRIG_EN BIT(5) //!< WIFI wakeup (light sleep only)
|
||||||
#define RTC_UART0_TRIG_EN BIT(6) //!< UART0 wakeup (light sleep only)
|
#define RTC_UART0_TRIG_EN BIT(6) //!< UART0 wakeup (light sleep only)
|
||||||
#define RTC_UART1_TRIG_EN BIT(7) //!< UART1 wakeup (light sleep only)
|
#define RTC_UART1_TRIG_EN BIT(7) //!< UART1 wakeup (light sleep only)
|
||||||
#define RTC_TOUCH_TRIG_EN BIT(8) //!< Touch wakeup
|
#define RTC_TOUCH_TRIG_EN BIT(8) //!< Touch wakeup
|
||||||
|
@@ -143,6 +143,13 @@
|
|||||||
/*-------------------------- AES CAPS -----------------------------------------*/
|
/*-------------------------- AES CAPS -----------------------------------------*/
|
||||||
#define SOC_AES_SUPPORT_DMA (1)
|
#define SOC_AES_SUPPORT_DMA (1)
|
||||||
|
|
||||||
|
/*-------------------------- Power Management CAPS ---------------------------*/
|
||||||
|
#define SOC_PM_SUPPORT_EXT_WAKEUP (1)
|
||||||
|
|
||||||
|
#define SOC_PM_SUPPORT_WIFI_WAKEUP (1)
|
||||||
|
|
||||||
|
#define SOC_PM_SUPPORT_BT_WAKEUP (1)
|
||||||
|
|
||||||
/* Has a centralized DMA, which is shared with all peripherals */
|
/* Has a centralized DMA, which is shared with all peripherals */
|
||||||
#define SOC_AES_GENERAL_DMA (1)
|
#define SOC_AES_GENERAL_DMA (1)
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user