mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
Merge branch 'feature/esp32c61_light_sleep_support_stage_2' into 'master'
feat(esp_hw_support): esp32c61 sleep support (Stage 2: support basic pmu sleep function) Closes IDF-9248, IDF-9247, IDF-9246, IDF-10993, IDF-9250, PM-203, and IDF-9244 See merge request espressif/esp-idf!33294
This commit is contained in:
commit
c7d532049a
@ -152,7 +152,7 @@ static void test_gptimer_sleep_retention(bool back_up_before_sleep)
|
|||||||
TEST_ESP_OK(gptimer_get_raw_count(timer, &count_value_after_sleep));
|
TEST_ESP_OK(gptimer_get_raw_count(timer, &count_value_after_sleep));
|
||||||
printf("gptimer count value: %llu\n", count_value_after_sleep);
|
printf("gptimer count value: %llu\n", count_value_after_sleep);
|
||||||
// the count value should near the reload value
|
// the count value should near the reload value
|
||||||
TEST_ASSERT_INT_WITHIN(1, 5000, count_value_after_sleep);
|
TEST_ASSERT_INT_WITHIN(5, 5000, count_value_after_sleep);
|
||||||
|
|
||||||
TEST_ESP_OK(gptimer_disable(timer));
|
TEST_ESP_OK(gptimer_disable(timer));
|
||||||
TEST_ESP_OK(gptimer_del_timer(timer));
|
TEST_ESP_OK(gptimer_del_timer(timer));
|
||||||
|
@ -140,16 +140,6 @@ if(NOT BOOTLOADER_BUILD)
|
|||||||
if(CONFIG_SOC_GPIO_CLOCKOUT_BY_GPIO_MATRIX OR CONFIG_SOC_GPIO_CLOCKOUT_BY_IO_MUX)
|
if(CONFIG_SOC_GPIO_CLOCKOUT_BY_GPIO_MATRIX OR CONFIG_SOC_GPIO_CLOCKOUT_BY_IO_MUX)
|
||||||
list(APPEND srcs "esp_clock_output.c")
|
list(APPEND srcs "esp_clock_output.c")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(CONFIG_IDF_TARGET_ESP32C61) # TODO: [ESP32C61] IDF-9245, IDF-9247, IDF-9248
|
|
||||||
list(REMOVE_ITEM srcs
|
|
||||||
"sleep_cpu.c"
|
|
||||||
"sleep_modem.c"
|
|
||||||
"sleep_modes.c"
|
|
||||||
"sleep_wake_stub.c"
|
|
||||||
"sleep_gpio.c"
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
else()
|
else()
|
||||||
# Requires "_esp_error_check_failed()" function
|
# Requires "_esp_error_check_failed()" function
|
||||||
list(APPEND priv_requires "esp_system")
|
list(APPEND priv_requires "esp_system")
|
||||||
|
@ -45,7 +45,7 @@ typedef struct {
|
|||||||
rtc_cntl_sleep_retent_t retent;
|
rtc_cntl_sleep_retent_t retent;
|
||||||
} sleep_cpu_retention_t;
|
} sleep_cpu_retention_t;
|
||||||
|
|
||||||
static DRAM_ATTR __attribute__((unused)) sleep_cpu_retention_t s_cpu_retention;
|
static DRAM_ATTR sleep_cpu_retention_t s_cpu_retention;
|
||||||
|
|
||||||
esp_err_t esp_sleep_cpu_pd_low_init(void)
|
esp_err_t esp_sleep_cpu_pd_low_init(void)
|
||||||
{
|
{
|
||||||
|
@ -65,7 +65,7 @@ typedef struct {
|
|||||||
} retent;
|
} retent;
|
||||||
} sleep_cpu_retention_t;
|
} sleep_cpu_retention_t;
|
||||||
|
|
||||||
static DRAM_ATTR __attribute__((unused)) sleep_cpu_retention_t s_cpu_retention;
|
static DRAM_ATTR sleep_cpu_retention_t s_cpu_retention;
|
||||||
|
|
||||||
#define CUSTOM_CSR_MTVT (0x307)
|
#define CUSTOM_CSR_MTVT (0x307)
|
||||||
#define CUSTOM_CSR_MINTTHRESH (0x347)
|
#define CUSTOM_CSR_MINTTHRESH (0x347)
|
||||||
@ -103,7 +103,8 @@ static void * cpu_domain_dev_sleep_frame_alloc_and_init(const cpu_domain_dev_reg
|
|||||||
static inline void * cpu_domain_cache_config_sleep_frame_alloc_and_init(void)
|
static inline void * cpu_domain_cache_config_sleep_frame_alloc_and_init(void)
|
||||||
{
|
{
|
||||||
const static cpu_domain_dev_regs_region_t regions[] = {
|
const static cpu_domain_dev_regs_region_t regions[] = {
|
||||||
{ .start = CACHE_L1_ICACHE_CTRL_REG, .end = CACHE_L1_BYPASS_CACHE_CONF_REG + 4 }
|
{ .start = CACHE_L1_ICACHE_CTRL_REG, .end = CACHE_L1_BYPASS_CACHE_CONF_REG + 4 },
|
||||||
|
{ .start = CACHE_L1_CACHE_AUTOLOAD_CTRL_REG, .end = CACHE_L1_CACHE_AUTOLOAD_SCT1_SIZE_REG + 4 },
|
||||||
};
|
};
|
||||||
return cpu_domain_dev_sleep_frame_alloc_and_init(regions, sizeof(regions) / sizeof(regions[0]));
|
return cpu_domain_dev_sleep_frame_alloc_and_init(regions, sizeof(regions) / sizeof(regions[0]));
|
||||||
}
|
}
|
||||||
|
@ -66,7 +66,7 @@ typedef struct {
|
|||||||
} retent;
|
} retent;
|
||||||
} sleep_cpu_retention_t;
|
} sleep_cpu_retention_t;
|
||||||
|
|
||||||
static DRAM_ATTR __attribute__((unused)) sleep_cpu_retention_t s_cpu_retention;
|
static DRAM_ATTR sleep_cpu_retention_t s_cpu_retention;
|
||||||
|
|
||||||
#define CUSTOM_CSR_PCER_MACHINE 0x7e0
|
#define CUSTOM_CSR_PCER_MACHINE 0x7e0
|
||||||
#define CUSTOM_CSR_PCMR_MACHINE 0x7e1
|
#define CUSTOM_CSR_PCMR_MACHINE 0x7e1
|
||||||
|
@ -0,0 +1,188 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2023-2024 Espressif Systems (Shanghai) CO LTD
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __RVSLEEP_FRAMES_H__
|
||||||
|
#define __RVSLEEP_FRAMES_H__
|
||||||
|
|
||||||
|
#include "sdkconfig.h"
|
||||||
|
|
||||||
|
/* Align a value up to nearest n-byte boundary, where n is a power of 2. */
|
||||||
|
#define ALIGNUP(n, val) (((val) + (n) - 1) & -(n))
|
||||||
|
|
||||||
|
#ifdef STRUCT_BEGIN
|
||||||
|
#undef STRUCT_BEGIN
|
||||||
|
#undef STRUCT_FIELD
|
||||||
|
#undef STRUCT_AFIELD
|
||||||
|
#undef STRUCT_END
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(_ASMLANGUAGE) || defined(__ASSEMBLER__)
|
||||||
|
#ifdef __clang__
|
||||||
|
#define STRUCT_BEGIN .set RV_STRUCT_OFFSET, 0
|
||||||
|
#define STRUCT_FIELD(ctype,size,asname,name) .set asname, RV_STRUCT_OFFSET; .set RV_STRUCT_OFFSET, asname + size
|
||||||
|
#define STRUCT_AFIELD(ctype,size,asname,name,n) .set asname, RV_STRUCT_OFFSET;\
|
||||||
|
.set RV_STRUCT_OFFSET, asname + (size)*(n);
|
||||||
|
#define STRUCT_END(sname) .set sname##Size, RV_STRUCT_OFFSET;
|
||||||
|
#else // __clang__
|
||||||
|
#define STRUCT_BEGIN .pushsection .text; .struct 0
|
||||||
|
#define STRUCT_FIELD(ctype,size,asname,name) asname: .space size
|
||||||
|
#define STRUCT_AFIELD(ctype,size,asname,name,n) asname: .space (size)*(n)
|
||||||
|
#define STRUCT_END(sname) sname##Size:; .popsection
|
||||||
|
#endif // __clang__
|
||||||
|
#else
|
||||||
|
#define STRUCT_BEGIN typedef struct {
|
||||||
|
#define STRUCT_FIELD(ctype,size,asname,name) ctype name;
|
||||||
|
#define STRUCT_AFIELD(ctype,size,asname,name,n) ctype name[n];
|
||||||
|
#define STRUCT_END(sname) } sname;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* -------------------------------------------------------------------------------
|
||||||
|
* RISC-V CORE CRITICAL REGISTER CONTEXT LAYOUT FOR SLEEP
|
||||||
|
* -------------------------------------------------------------------------------
|
||||||
|
*/
|
||||||
|
STRUCT_BEGIN
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MEPC, mepc) /* Machine Exception Program Counter */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_RA, ra) /* Return address */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_SP, sp) /* Stack pointer */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_GP, gp) /* Global pointer */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_TP, tp) /* Thread pointer */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_T0, t0) /* Temporary/alternate link register */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_T1, t1) /* t1-2: Temporaries */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_T2, t2)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S0, s0) /* Saved register/frame pointer */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S1, s1) /* Saved register */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_A0, a0) /* a0-1: Function arguments/return address */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_A1, a1)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_A2, a2) /* a2-7: Function arguments */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_A3, a3)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_A4, a4)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_A5, a5)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_A6, a6)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_A7, a7)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S2, s2) /* s2-11: Saved registers */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S3, s3)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S4, s4)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S5, s5)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S6, s6)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S7, s7)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S8, s8)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S9, s9)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S10, s10)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_S11, s11)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_T3, t3) /* t3-6: Temporaries */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_T4, t4)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_T5, t5)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_T6, t6)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MSTATUS, mstatus) /* Machine Status */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MTVEC, mtvec) /* Machine Trap-Vector Base Address */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MCAUSE, mcause) /* Machine Trap Cause */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MTVAL, mtval) /* Machine Trap Value */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MIE, mie) /* Machine intr enable */
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MIP, mip) /* Machine intr pending */
|
||||||
|
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMUFUNC, pmufunc) /* A field is used to identify whether it is going
|
||||||
|
* to sleep or has just been awakened. We use the
|
||||||
|
* lowest 2 bits as indication information, 3 means
|
||||||
|
* being awakened, 1 means going to sleep */
|
||||||
|
#if CONFIG_PM_CHECK_SLEEP_RETENTION_FRAME
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CSF_CTX_CRC, frame_crc) /* Used to check RvCoreCriticalSleepFrame integrity */
|
||||||
|
#endif
|
||||||
|
STRUCT_END(RvCoreCriticalSleepFrame)
|
||||||
|
|
||||||
|
#if defined(_ASMLANGUAGE) || defined(__ASSEMBLER__)
|
||||||
|
#define RV_SLEEP_CTX_SZ1 RvCoreCriticalSleepFrameSize
|
||||||
|
#else
|
||||||
|
#define RV_SLEEP_CTX_SZ1 sizeof(RvCoreCriticalSleepFrame)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Sleep stack frame size, after align up to 16 bytes boundary
|
||||||
|
*/
|
||||||
|
#define RV_SLEEP_CTX_FRMSZ (ALIGNUP(0x10, RV_SLEEP_CTX_SZ1))
|
||||||
|
|
||||||
|
/*
|
||||||
|
* -------------------------------------------------------------------------------
|
||||||
|
* RISC-V CORE NON-CRITICAL REGISTER CONTEXT LAYOUT FOR SLEEP
|
||||||
|
* -------------------------------------------------------------------------------
|
||||||
|
*/
|
||||||
|
STRUCT_BEGIN
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MSCRATCH, mscratch)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MISA, misa)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_TSELECT, tselect)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_TDATA1, tdata1)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_TDATA2, tdata2)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_TCONTROL, tcontrol)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR0, pmpaddr0)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR1, pmpaddr1)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR2, pmpaddr2)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR3, pmpaddr3)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR4, pmpaddr4)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR5, pmpaddr5)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR6, pmpaddr6)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR7, pmpaddr7)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR8, pmpaddr8)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR9, pmpaddr9)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR10, pmpaddr10)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR11, pmpaddr11)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR12, pmpaddr12)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR13, pmpaddr13)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR14, pmpaddr14)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPADDR15, pmpaddr15)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPCFG0, pmpcfg0)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPCFG1, pmpcfg1)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPCFG2, pmpcfg2)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMPCFG3, pmpcfg3)
|
||||||
|
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR0, pmaaddr0)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR1, pmaaddr1)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR2, pmaaddr2)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR3, pmaaddr3)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR4, pmaaddr4)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR5, pmaaddr5)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR6, pmaaddr6)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR7, pmaaddr7)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR8, pmaaddr8)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR9, pmaaddr9)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR10, pmaaddr10)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR11, pmaaddr11)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR12, pmaaddr12)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR13, pmaaddr13)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR14, pmaaddr14)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMAADDR15, pmaaddr15)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG0, pmacfg0)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG1, pmacfg1)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG2, pmacfg2)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG3, pmacfg3)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG4, pmacfg4)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG5, pmacfg5)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG6, pmacfg6)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG7, pmacfg7)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG8, pmacfg8)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG9, pmacfg9)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG10, pmacfg10)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG11, pmacfg11)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG12, pmacfg12)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG13, pmacfg13)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG14, pmacfg14)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_PMACFG15, pmacfg15)
|
||||||
|
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MCYCLE, mcycle)
|
||||||
|
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MTVT, mtvt)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MINTTHRESH, mintthresh)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MINTSTATUS, mintstatus)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MXSTATUS, mxstatus)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MHCR, mhcr)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MHINT, mhint)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_MEXSTATUS, mexstatus)
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_CTX_JVT, jvt)
|
||||||
|
#if CONFIG_PM_CHECK_SLEEP_RETENTION_FRAME
|
||||||
|
STRUCT_FIELD (long, 4, RV_SLP_NCSF_CTX_CRC, frame_crc) /* Used to check RvCoreNonCriticalSleepFrame integrity */
|
||||||
|
#endif
|
||||||
|
STRUCT_END(RvCoreNonCriticalSleepFrame)
|
||||||
|
|
||||||
|
#endif /* #ifndef __RVSLEEP_FRAMES_H__ */
|
499
components/esp_hw_support/lowpower/port/esp32c61/sleep_cpu.c
Normal file
499
components/esp_hw_support/lowpower/port/esp32c61/sleep_cpu.c
Normal file
@ -0,0 +1,499 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2023-2024 Espressif Systems (Shanghai) CO LTD
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <inttypes.h>
|
||||||
|
#include <sys/lock.h>
|
||||||
|
#include <sys/param.h>
|
||||||
|
|
||||||
|
#include "esp_attr.h"
|
||||||
|
#include "esp_check.h"
|
||||||
|
#include "esp_sleep.h"
|
||||||
|
#include "esp_log.h"
|
||||||
|
#include "esp_rom_crc.h"
|
||||||
|
#include "freertos/FreeRTOS.h"
|
||||||
|
#include "freertos/task.h"
|
||||||
|
#include "esp_heap_caps.h"
|
||||||
|
#include "riscv/csr.h"
|
||||||
|
#include "soc/soc_caps.h"
|
||||||
|
#include "soc/intpri_reg.h"
|
||||||
|
#include "soc/cache_reg.h"
|
||||||
|
#include "soc/clic_reg.h"
|
||||||
|
#include "soc/clint_reg.h"
|
||||||
|
#include "soc/rtc_periph.h"
|
||||||
|
#include "esp_private/esp_pmu.h"
|
||||||
|
#include "esp_private/sleep_cpu.h"
|
||||||
|
#include "esp_private/sleep_event.h"
|
||||||
|
#include "sdkconfig.h"
|
||||||
|
|
||||||
|
#include "esp32c61/rom/rtc.h"
|
||||||
|
#include "esp32c61/rom/cache.h"
|
||||||
|
#include "rvsleep-frames.h"
|
||||||
|
|
||||||
|
#if CONFIG_PM_CHECK_SLEEP_RETENTION_FRAME
|
||||||
|
#include "esp_private/system_internal.h"
|
||||||
|
#include "hal/uart_hal.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static __attribute__((unused)) const char *TAG = "sleep";
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
uint32_t start;
|
||||||
|
uint32_t end;
|
||||||
|
} cpu_domain_dev_regs_region_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
cpu_domain_dev_regs_region_t *region;
|
||||||
|
int region_num;
|
||||||
|
uint32_t *regs_frame;
|
||||||
|
} cpu_domain_dev_sleep_frame_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Internal structure which holds all requested light sleep cpu retention parameters
|
||||||
|
*/
|
||||||
|
typedef struct {
|
||||||
|
struct {
|
||||||
|
RvCoreCriticalSleepFrame *critical_frame;
|
||||||
|
RvCoreNonCriticalSleepFrame *non_critical_frame;
|
||||||
|
cpu_domain_dev_sleep_frame_t *cache_config_frame;
|
||||||
|
cpu_domain_dev_sleep_frame_t *clic_frame;
|
||||||
|
cpu_domain_dev_sleep_frame_t *clint_frame;
|
||||||
|
} retent;
|
||||||
|
} sleep_cpu_retention_t;
|
||||||
|
|
||||||
|
static DRAM_ATTR sleep_cpu_retention_t s_cpu_retention;
|
||||||
|
|
||||||
|
#define CUSTOM_CSR_MTVT (0x307)
|
||||||
|
#define CUSTOM_CSR_MINTTHRESH (0x347)
|
||||||
|
#define CUSTOM_CSR_MXSTATUS (0x7c0)
|
||||||
|
#define CUSTOM_CSR_MHCR (0x7c1)
|
||||||
|
#define CUSTOM_CSR_MHINT (0x7c5)
|
||||||
|
#define CUSTOM_CSR_MEXSTATUS (0x7e1)
|
||||||
|
#define CUSTOM_CSR_JVT (0x017)
|
||||||
|
|
||||||
|
extern RvCoreCriticalSleepFrame *rv_core_critical_regs_frame;
|
||||||
|
|
||||||
|
static void * cpu_domain_dev_sleep_frame_alloc_and_init(const cpu_domain_dev_regs_region_t *regions, const int region_num)
|
||||||
|
{
|
||||||
|
const int region_sz = sizeof(cpu_domain_dev_regs_region_t) * region_num;
|
||||||
|
int regs_frame_sz = 0;
|
||||||
|
for (int num = 0; num < region_num; num++) {
|
||||||
|
regs_frame_sz += regions[num].end - regions[num].start;
|
||||||
|
}
|
||||||
|
void *frame = heap_caps_malloc(sizeof(cpu_domain_dev_sleep_frame_t) + region_sz + regs_frame_sz, MALLOC_CAP_32BIT|MALLOC_CAP_INTERNAL);
|
||||||
|
if (frame) {
|
||||||
|
cpu_domain_dev_regs_region_t *region = (cpu_domain_dev_regs_region_t *)(frame + sizeof(cpu_domain_dev_sleep_frame_t));
|
||||||
|
memcpy(region, regions, region_num * sizeof(cpu_domain_dev_regs_region_t));
|
||||||
|
void *regs_frame = frame + sizeof(cpu_domain_dev_sleep_frame_t) + region_sz;
|
||||||
|
memset(regs_frame, 0, regs_frame_sz);
|
||||||
|
*(cpu_domain_dev_sleep_frame_t *)frame = (cpu_domain_dev_sleep_frame_t) {
|
||||||
|
.region = region,
|
||||||
|
.region_num = region_num,
|
||||||
|
.regs_frame = (uint32_t *)regs_frame
|
||||||
|
};
|
||||||
|
}
|
||||||
|
return frame;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline void * cpu_domain_cache_config_sleep_frame_alloc_and_init(void)
|
||||||
|
{
|
||||||
|
const static cpu_domain_dev_regs_region_t regions[] = {
|
||||||
|
{ .start = CACHE_L1_CACHE_CTRL_REG, .end = CACHE_L1_CACHE_CTRL_REG + 4 },
|
||||||
|
{ .start = CACHE_L1_CACHE_AUTOLOAD_CTRL_REG, .end = CACHE_L1_CACHE_AUTOLOAD_SCT1_SIZE_REG + 4 },
|
||||||
|
};
|
||||||
|
return cpu_domain_dev_sleep_frame_alloc_and_init(regions, sizeof(regions) / sizeof(regions[0]));
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void * cpu_domain_clint_sleep_frame_alloc_and_init(void)
|
||||||
|
{
|
||||||
|
const static cpu_domain_dev_regs_region_t regions[] = {
|
||||||
|
{ .start = CLINT_MINT_SIP_REG, .end = CLINT_MINT_SIP_REG + 4 },
|
||||||
|
{ .start = CLINT_MINT_MTIMECMP_L_REG, .end = CLINT_MINT_MTIMECMP_H_REG + 4 },
|
||||||
|
{ .start = CLINT_MINT_TIMECTL_REG, .end = CLINT_MINT_TIMECTL_REG + 4 },
|
||||||
|
{ .start = CLINT_MINT_MTIME_L_REG, .end = CLINT_MINT_MTIME_H_REG + 4 }
|
||||||
|
};
|
||||||
|
return cpu_domain_dev_sleep_frame_alloc_and_init(regions, sizeof(regions) / sizeof(regions[0]));
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void * cpu_domain_clic_sleep_frame_alloc_and_init(void)
|
||||||
|
{
|
||||||
|
const static cpu_domain_dev_regs_region_t regions[] = {
|
||||||
|
{ .start = CLIC_INT_CONFIG_REG, .end = CLIC_INT_THRESH_REG + 4 },
|
||||||
|
{ .start = CLIC_INT_CTRL_REG(0), .end = CLIC_INT_CTRL_REG(47) + 4 },
|
||||||
|
};
|
||||||
|
return cpu_domain_dev_sleep_frame_alloc_and_init(regions, sizeof(regions) / sizeof(regions[0]));
|
||||||
|
}
|
||||||
|
|
||||||
|
static esp_err_t esp_sleep_cpu_retention_init_impl(void)
|
||||||
|
{
|
||||||
|
if (s_cpu_retention.retent.critical_frame == NULL) {
|
||||||
|
void *frame = heap_caps_calloc(1, RV_SLEEP_CTX_FRMSZ, MALLOC_CAP_32BIT|MALLOC_CAP_INTERNAL);
|
||||||
|
if (frame == NULL) {
|
||||||
|
goto err;
|
||||||
|
}
|
||||||
|
s_cpu_retention.retent.critical_frame = (RvCoreCriticalSleepFrame *)frame;
|
||||||
|
rv_core_critical_regs_frame = (RvCoreCriticalSleepFrame *)frame;
|
||||||
|
}
|
||||||
|
if (s_cpu_retention.retent.non_critical_frame == NULL) {
|
||||||
|
void *frame = heap_caps_calloc(1, sizeof(RvCoreNonCriticalSleepFrame), MALLOC_CAP_32BIT|MALLOC_CAP_INTERNAL);
|
||||||
|
if (frame == NULL) {
|
||||||
|
goto err;
|
||||||
|
}
|
||||||
|
s_cpu_retention.retent.non_critical_frame = (RvCoreNonCriticalSleepFrame *)frame;
|
||||||
|
}
|
||||||
|
if (s_cpu_retention.retent.cache_config_frame == NULL) {
|
||||||
|
void *frame = cpu_domain_cache_config_sleep_frame_alloc_and_init();
|
||||||
|
if (frame == NULL) {
|
||||||
|
goto err;
|
||||||
|
}
|
||||||
|
s_cpu_retention.retent.cache_config_frame = (cpu_domain_dev_sleep_frame_t *)frame;
|
||||||
|
}
|
||||||
|
if (s_cpu_retention.retent.clic_frame == NULL) {
|
||||||
|
void *frame = cpu_domain_clic_sleep_frame_alloc_and_init();
|
||||||
|
if (frame == NULL) {
|
||||||
|
goto err;
|
||||||
|
}
|
||||||
|
s_cpu_retention.retent.clic_frame = (cpu_domain_dev_sleep_frame_t *)frame;
|
||||||
|
}
|
||||||
|
if (s_cpu_retention.retent.clint_frame == NULL) {
|
||||||
|
void *frame = cpu_domain_clint_sleep_frame_alloc_and_init();
|
||||||
|
if (frame == NULL) {
|
||||||
|
goto err;
|
||||||
|
}
|
||||||
|
s_cpu_retention.retent.clint_frame = (cpu_domain_dev_sleep_frame_t *)frame;
|
||||||
|
}
|
||||||
|
return ESP_OK;
|
||||||
|
err:
|
||||||
|
esp_sleep_cpu_retention_deinit();
|
||||||
|
return ESP_ERR_NO_MEM;
|
||||||
|
}
|
||||||
|
|
||||||
|
static esp_err_t esp_sleep_cpu_retention_deinit_impl(void)
|
||||||
|
{
|
||||||
|
if (s_cpu_retention.retent.critical_frame) {
|
||||||
|
heap_caps_free((void *)s_cpu_retention.retent.critical_frame);
|
||||||
|
s_cpu_retention.retent.critical_frame = NULL;
|
||||||
|
rv_core_critical_regs_frame = NULL;
|
||||||
|
}
|
||||||
|
if (s_cpu_retention.retent.non_critical_frame) {
|
||||||
|
heap_caps_free((void *)s_cpu_retention.retent.non_critical_frame);
|
||||||
|
s_cpu_retention.retent.non_critical_frame = NULL;
|
||||||
|
}
|
||||||
|
if (s_cpu_retention.retent.cache_config_frame) {
|
||||||
|
heap_caps_free((void *)s_cpu_retention.retent.cache_config_frame);
|
||||||
|
s_cpu_retention.retent.cache_config_frame = NULL;
|
||||||
|
}
|
||||||
|
if (s_cpu_retention.retent.clic_frame) {
|
||||||
|
heap_caps_free((void *)s_cpu_retention.retent.clic_frame);
|
||||||
|
s_cpu_retention.retent.clic_frame = NULL;
|
||||||
|
}
|
||||||
|
if (s_cpu_retention.retent.clint_frame) {
|
||||||
|
heap_caps_free((void *)s_cpu_retention.retent.clint_frame);
|
||||||
|
s_cpu_retention.retent.clint_frame = NULL;
|
||||||
|
}
|
||||||
|
return ESP_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR uint32_t save_mstatus_and_disable_global_int(void)
|
||||||
|
{
|
||||||
|
return RV_READ_MSTATUS_AND_DISABLE_INTR();
|
||||||
|
}
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR void restore_mstatus(uint32_t mstatus_val)
|
||||||
|
{
|
||||||
|
RV_WRITE_CSR(mstatus, mstatus_val);
|
||||||
|
}
|
||||||
|
|
||||||
|
static IRAM_ATTR RvCoreNonCriticalSleepFrame * rv_core_noncritical_regs_save(void)
|
||||||
|
{
|
||||||
|
assert(s_cpu_retention.retent.non_critical_frame);
|
||||||
|
RvCoreNonCriticalSleepFrame *frame = s_cpu_retention.retent.non_critical_frame;
|
||||||
|
frame->mscratch = RV_READ_CSR(mscratch);
|
||||||
|
frame->misa = RV_READ_CSR(misa);
|
||||||
|
frame->tselect = RV_READ_CSR(tselect);
|
||||||
|
frame->tdata1 = RV_READ_CSR(tdata1);
|
||||||
|
frame->tdata2 = RV_READ_CSR(tdata2);
|
||||||
|
frame->tcontrol = RV_READ_CSR(tcontrol);
|
||||||
|
|
||||||
|
frame->pmpaddr0 = RV_READ_CSR(pmpaddr0);
|
||||||
|
frame->pmpaddr1 = RV_READ_CSR(pmpaddr1);
|
||||||
|
frame->pmpaddr2 = RV_READ_CSR(pmpaddr2);
|
||||||
|
frame->pmpaddr3 = RV_READ_CSR(pmpaddr3);
|
||||||
|
frame->pmpaddr4 = RV_READ_CSR(pmpaddr4);
|
||||||
|
frame->pmpaddr5 = RV_READ_CSR(pmpaddr5);
|
||||||
|
frame->pmpaddr6 = RV_READ_CSR(pmpaddr6);
|
||||||
|
frame->pmpaddr7 = RV_READ_CSR(pmpaddr7);
|
||||||
|
frame->pmpaddr8 = RV_READ_CSR(pmpaddr8);
|
||||||
|
frame->pmpaddr9 = RV_READ_CSR(pmpaddr9);
|
||||||
|
frame->pmpaddr10 = RV_READ_CSR(pmpaddr10);
|
||||||
|
frame->pmpaddr11 = RV_READ_CSR(pmpaddr11);
|
||||||
|
frame->pmpaddr12 = RV_READ_CSR(pmpaddr12);
|
||||||
|
frame->pmpaddr13 = RV_READ_CSR(pmpaddr13);
|
||||||
|
frame->pmpaddr14 = RV_READ_CSR(pmpaddr14);
|
||||||
|
frame->pmpaddr15 = RV_READ_CSR(pmpaddr15);
|
||||||
|
frame->pmpcfg0 = RV_READ_CSR(pmpcfg0);
|
||||||
|
frame->pmpcfg1 = RV_READ_CSR(pmpcfg1);
|
||||||
|
frame->pmpcfg2 = RV_READ_CSR(pmpcfg2);
|
||||||
|
frame->pmpcfg3 = RV_READ_CSR(pmpcfg3);
|
||||||
|
|
||||||
|
frame->pmaaddr0 = RV_READ_CSR(CSR_PMAADDR(0));
|
||||||
|
frame->pmaaddr1 = RV_READ_CSR(CSR_PMAADDR(1));
|
||||||
|
frame->pmaaddr2 = RV_READ_CSR(CSR_PMAADDR(2));
|
||||||
|
frame->pmaaddr3 = RV_READ_CSR(CSR_PMAADDR(3));
|
||||||
|
frame->pmaaddr4 = RV_READ_CSR(CSR_PMAADDR(4));
|
||||||
|
frame->pmaaddr5 = RV_READ_CSR(CSR_PMAADDR(5));
|
||||||
|
frame->pmaaddr6 = RV_READ_CSR(CSR_PMAADDR(6));
|
||||||
|
frame->pmaaddr7 = RV_READ_CSR(CSR_PMAADDR(7));
|
||||||
|
frame->pmaaddr8 = RV_READ_CSR(CSR_PMAADDR(8));
|
||||||
|
frame->pmaaddr9 = RV_READ_CSR(CSR_PMAADDR(9));
|
||||||
|
frame->pmaaddr10 = RV_READ_CSR(CSR_PMAADDR(10));
|
||||||
|
frame->pmaaddr11 = RV_READ_CSR(CSR_PMAADDR(11));
|
||||||
|
frame->pmaaddr12 = RV_READ_CSR(CSR_PMAADDR(12));
|
||||||
|
frame->pmaaddr13 = RV_READ_CSR(CSR_PMAADDR(13));
|
||||||
|
frame->pmaaddr14 = RV_READ_CSR(CSR_PMAADDR(14));
|
||||||
|
frame->pmaaddr15 = RV_READ_CSR(CSR_PMAADDR(15));
|
||||||
|
frame->pmacfg0 = RV_READ_CSR(CSR_PMACFG(0));
|
||||||
|
frame->pmacfg1 = RV_READ_CSR(CSR_PMACFG(1));
|
||||||
|
frame->pmacfg2 = RV_READ_CSR(CSR_PMACFG(2));
|
||||||
|
frame->pmacfg3 = RV_READ_CSR(CSR_PMACFG(3));
|
||||||
|
frame->pmacfg4 = RV_READ_CSR(CSR_PMACFG(4));
|
||||||
|
frame->pmacfg5 = RV_READ_CSR(CSR_PMACFG(5));
|
||||||
|
frame->pmacfg6 = RV_READ_CSR(CSR_PMACFG(6));
|
||||||
|
frame->pmacfg7 = RV_READ_CSR(CSR_PMACFG(7));
|
||||||
|
frame->pmacfg8 = RV_READ_CSR(CSR_PMACFG(8));
|
||||||
|
frame->pmacfg9 = RV_READ_CSR(CSR_PMACFG(9));
|
||||||
|
frame->pmacfg10 = RV_READ_CSR(CSR_PMACFG(10));
|
||||||
|
frame->pmacfg11 = RV_READ_CSR(CSR_PMACFG(11));
|
||||||
|
frame->pmacfg12 = RV_READ_CSR(CSR_PMACFG(12));
|
||||||
|
frame->pmacfg13 = RV_READ_CSR(CSR_PMACFG(13));
|
||||||
|
frame->pmacfg14 = RV_READ_CSR(CSR_PMACFG(14));
|
||||||
|
frame->pmacfg15 = RV_READ_CSR(CSR_PMACFG(15));
|
||||||
|
|
||||||
|
frame->mcycle = RV_READ_CSR(mcycle);
|
||||||
|
|
||||||
|
frame->mtvt = RV_READ_CSR(CUSTOM_CSR_MTVT);
|
||||||
|
frame->mintthresh = RV_READ_CSR(CUSTOM_CSR_MINTTHRESH);
|
||||||
|
frame->mxstatus = RV_READ_CSR(CUSTOM_CSR_MXSTATUS);
|
||||||
|
frame->mhcr = RV_READ_CSR(CUSTOM_CSR_MHCR);
|
||||||
|
frame->mhint = RV_READ_CSR(CUSTOM_CSR_MHINT);
|
||||||
|
frame->mexstatus = RV_READ_CSR(CUSTOM_CSR_MEXSTATUS);
|
||||||
|
frame->jvt = RV_READ_CSR(CUSTOM_CSR_JVT);
|
||||||
|
return frame;
|
||||||
|
}
|
||||||
|
|
||||||
|
static IRAM_ATTR void rv_core_noncritical_regs_restore(RvCoreNonCriticalSleepFrame *frame)
|
||||||
|
{
|
||||||
|
assert(frame);
|
||||||
|
RV_WRITE_CSR(mscratch, frame->mscratch);
|
||||||
|
RV_WRITE_CSR(misa, frame->misa);
|
||||||
|
RV_WRITE_CSR(tselect, frame->tselect);
|
||||||
|
RV_WRITE_CSR(tdata1, frame->tdata1);
|
||||||
|
RV_WRITE_CSR(tdata2, frame->tdata2);
|
||||||
|
RV_WRITE_CSR(tcontrol, frame->tcontrol);
|
||||||
|
RV_WRITE_CSR(pmpaddr0, frame->pmpaddr0);
|
||||||
|
RV_WRITE_CSR(pmpaddr1, frame->pmpaddr1);
|
||||||
|
RV_WRITE_CSR(pmpaddr2, frame->pmpaddr2);
|
||||||
|
RV_WRITE_CSR(pmpaddr3, frame->pmpaddr3);
|
||||||
|
RV_WRITE_CSR(pmpaddr4, frame->pmpaddr4);
|
||||||
|
RV_WRITE_CSR(pmpaddr5, frame->pmpaddr5);
|
||||||
|
RV_WRITE_CSR(pmpaddr6, frame->pmpaddr6);
|
||||||
|
RV_WRITE_CSR(pmpaddr7, frame->pmpaddr7);
|
||||||
|
RV_WRITE_CSR(pmpaddr8, frame->pmpaddr8);
|
||||||
|
RV_WRITE_CSR(pmpaddr9, frame->pmpaddr9);
|
||||||
|
RV_WRITE_CSR(pmpaddr10,frame->pmpaddr10);
|
||||||
|
RV_WRITE_CSR(pmpaddr11,frame->pmpaddr11);
|
||||||
|
RV_WRITE_CSR(pmpaddr12,frame->pmpaddr12);
|
||||||
|
RV_WRITE_CSR(pmpaddr13,frame->pmpaddr13);
|
||||||
|
RV_WRITE_CSR(pmpaddr14,frame->pmpaddr14);
|
||||||
|
RV_WRITE_CSR(pmpaddr15,frame->pmpaddr15);
|
||||||
|
RV_WRITE_CSR(pmpcfg0, frame->pmpcfg0);
|
||||||
|
RV_WRITE_CSR(pmpcfg1, frame->pmpcfg1);
|
||||||
|
RV_WRITE_CSR(pmpcfg2, frame->pmpcfg2);
|
||||||
|
RV_WRITE_CSR(pmpcfg3, frame->pmpcfg3);
|
||||||
|
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(0), frame->pmaaddr0);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(1), frame->pmaaddr1);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(2), frame->pmaaddr2);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(3), frame->pmaaddr3);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(4), frame->pmaaddr4);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(5), frame->pmaaddr5);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(6), frame->pmaaddr6);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(7), frame->pmaaddr7);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(8), frame->pmaaddr8);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(9), frame->pmaaddr9);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(10),frame->pmaaddr10);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(11),frame->pmaaddr11);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(12),frame->pmaaddr12);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(13),frame->pmaaddr13);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(14),frame->pmaaddr14);
|
||||||
|
RV_WRITE_CSR(CSR_PMAADDR(15),frame->pmaaddr15);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(0), frame->pmacfg0);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(1), frame->pmacfg1);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(2), frame->pmacfg2);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(3), frame->pmacfg3);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(4), frame->pmacfg4);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(5), frame->pmacfg5);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(6), frame->pmacfg6);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(7), frame->pmacfg7);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(8), frame->pmacfg8);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(9), frame->pmacfg9);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(10), frame->pmacfg10);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(11), frame->pmacfg11);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(12), frame->pmacfg12);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(13), frame->pmacfg13);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(14), frame->pmacfg14);
|
||||||
|
RV_WRITE_CSR(CSR_PMACFG(15), frame->pmacfg15);
|
||||||
|
|
||||||
|
RV_WRITE_CSR(mcycle, frame->mcycle);
|
||||||
|
|
||||||
|
RV_WRITE_CSR(CUSTOM_CSR_MTVT, frame->mtvt);
|
||||||
|
RV_WRITE_CSR(CUSTOM_CSR_MINTTHRESH, frame->mintthresh);
|
||||||
|
RV_WRITE_CSR(CUSTOM_CSR_MXSTATUS, frame->mxstatus);
|
||||||
|
RV_WRITE_CSR(CUSTOM_CSR_MHCR, frame->mhcr);
|
||||||
|
RV_WRITE_CSR(CUSTOM_CSR_MHINT, frame->mhint);
|
||||||
|
RV_WRITE_CSR(CUSTOM_CSR_MEXSTATUS, frame->mexstatus);
|
||||||
|
RV_WRITE_CSR(CUSTOM_CSR_JVT, frame->jvt);
|
||||||
|
}
|
||||||
|
|
||||||
|
static IRAM_ATTR void cpu_domain_dev_regs_save(cpu_domain_dev_sleep_frame_t *frame)
|
||||||
|
{
|
||||||
|
assert(frame);
|
||||||
|
cpu_domain_dev_regs_region_t *region = frame->region;
|
||||||
|
uint32_t *regs_frame = frame->regs_frame;
|
||||||
|
|
||||||
|
int offset = 0;
|
||||||
|
for (int i = 0; i < frame->region_num; i++) {
|
||||||
|
for (uint32_t addr = region[i].start; addr < region[i].end; addr+=4) {
|
||||||
|
regs_frame[offset++] = *(uint32_t *)addr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static IRAM_ATTR void cpu_domain_dev_regs_restore(cpu_domain_dev_sleep_frame_t *frame)
|
||||||
|
{
|
||||||
|
assert(frame);
|
||||||
|
cpu_domain_dev_regs_region_t *region = frame->region;
|
||||||
|
uint32_t *regs_frame = frame->regs_frame;
|
||||||
|
|
||||||
|
int offset = 0;
|
||||||
|
for (int i = 0; i < frame->region_num; i++) {
|
||||||
|
for (uint32_t addr = region[i].start; addr < region[i].end; addr+=4) {
|
||||||
|
*(uint32_t *)addr = regs_frame[offset++];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#if CONFIG_PM_CHECK_SLEEP_RETENTION_FRAME
|
||||||
|
static IRAM_ATTR void update_retention_frame_crc(uint32_t *frame_ptr, uint32_t frame_check_size, uint32_t *frame_crc_ptr)
|
||||||
|
{
|
||||||
|
*(frame_crc_ptr) = esp_rom_crc32_le(0, (void *)frame_ptr, frame_check_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
static IRAM_ATTR void validate_retention_frame_crc(uint32_t *frame_ptr, uint32_t frame_check_size, uint32_t *frame_crc_ptr)
|
||||||
|
{
|
||||||
|
if(*(frame_crc_ptr) != esp_rom_crc32_le(0, (void *)(frame_ptr), frame_check_size)){
|
||||||
|
// resume uarts
|
||||||
|
for (int i = 0; i < SOC_UART_NUM; ++i) {
|
||||||
|
if (!uart_ll_is_enabled(i)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
uart_ll_force_xon(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Since it is still in the critical now, use ESP_EARLY_LOG */
|
||||||
|
ESP_EARLY_LOGE(TAG, "Sleep retention frame is corrupted");
|
||||||
|
esp_restart_noos();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern RvCoreCriticalSleepFrame * rv_core_critical_regs_save(void);
|
||||||
|
extern RvCoreCriticalSleepFrame * rv_core_critical_regs_restore(void);
|
||||||
|
typedef uint32_t (* sleep_cpu_entry_cb_t)(uint32_t, uint32_t, uint32_t, bool);
|
||||||
|
|
||||||
|
static IRAM_ATTR esp_err_t do_cpu_retention(sleep_cpu_entry_cb_t goto_sleep,
|
||||||
|
uint32_t wakeup_opt, uint32_t reject_opt, uint32_t lslp_mem_inf_fpu, bool dslp)
|
||||||
|
{
|
||||||
|
RvCoreCriticalSleepFrame * frame = rv_core_critical_regs_save();
|
||||||
|
if ((frame->pmufunc & 0x3) == 0x1) {
|
||||||
|
esp_sleep_execute_event_callbacks(SLEEP_EVENT_SW_CPU_TO_MEM_END, (void *)0);
|
||||||
|
#if CONFIG_PM_CHECK_SLEEP_RETENTION_FRAME
|
||||||
|
/* Minus 2 * sizeof(long) is for bypass `pmufunc` and `frame_crc` field */
|
||||||
|
update_retention_frame_crc((uint32_t*)frame, RV_SLEEP_CTX_FRMSZ - 2 * sizeof(long), (uint32_t *)(&frame->frame_crc));
|
||||||
|
#endif
|
||||||
|
REG_WRITE(RTC_SLEEP_WAKE_STUB_ADDR_REG, (uint32_t)rv_core_critical_regs_restore);
|
||||||
|
return (*goto_sleep)(wakeup_opt, reject_opt, lslp_mem_inf_fpu, dslp);
|
||||||
|
}
|
||||||
|
#if CONFIG_PM_CHECK_SLEEP_RETENTION_FRAME
|
||||||
|
else {
|
||||||
|
validate_retention_frame_crc((uint32_t*)frame, RV_SLEEP_CTX_FRMSZ - 2 * sizeof(long), (uint32_t *)(&frame->frame_crc));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return pmu_sleep_finish(dslp);
|
||||||
|
}
|
||||||
|
|
||||||
|
esp_err_t IRAM_ATTR esp_sleep_cpu_retention(uint32_t (*goto_sleep)(uint32_t, uint32_t, uint32_t, bool),
|
||||||
|
uint32_t wakeup_opt, uint32_t reject_opt, uint32_t lslp_mem_inf_fpu, bool dslp)
|
||||||
|
{
|
||||||
|
esp_sleep_execute_event_callbacks(SLEEP_EVENT_SW_CPU_TO_MEM_START, (void *)0);
|
||||||
|
uint32_t mstatus = save_mstatus_and_disable_global_int();
|
||||||
|
|
||||||
|
cpu_domain_dev_regs_save(s_cpu_retention.retent.clic_frame);
|
||||||
|
cpu_domain_dev_regs_save(s_cpu_retention.retent.clint_frame);
|
||||||
|
cpu_domain_dev_regs_save(s_cpu_retention.retent.cache_config_frame);
|
||||||
|
RvCoreNonCriticalSleepFrame *frame = rv_core_noncritical_regs_save();
|
||||||
|
|
||||||
|
#if CONFIG_PM_CHECK_SLEEP_RETENTION_FRAME
|
||||||
|
/* Minus sizeof(long) is for bypass `frame_crc` field */
|
||||||
|
update_retention_frame_crc((uint32_t*)frame, sizeof(RvCoreNonCriticalSleepFrame) - sizeof(long), (uint32_t *)(&frame->frame_crc));
|
||||||
|
#endif
|
||||||
|
esp_err_t err = do_cpu_retention(goto_sleep, wakeup_opt, reject_opt, lslp_mem_inf_fpu, dslp);
|
||||||
|
|
||||||
|
#if CONFIG_PM_CHECK_SLEEP_RETENTION_FRAME
|
||||||
|
validate_retention_frame_crc((uint32_t*)frame, sizeof(RvCoreNonCriticalSleepFrame) - sizeof(long), (uint32_t *)(&frame->frame_crc));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
rv_core_noncritical_regs_restore(frame);
|
||||||
|
cpu_domain_dev_regs_restore(s_cpu_retention.retent.cache_config_frame);
|
||||||
|
cpu_domain_dev_regs_restore(s_cpu_retention.retent.clint_frame);
|
||||||
|
cpu_domain_dev_regs_restore(s_cpu_retention.retent.clic_frame);
|
||||||
|
restore_mstatus(mstatus);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
esp_err_t esp_sleep_cpu_retention_init(void)
|
||||||
|
{
|
||||||
|
return esp_sleep_cpu_retention_init_impl();
|
||||||
|
}
|
||||||
|
|
||||||
|
esp_err_t esp_sleep_cpu_retention_deinit(void)
|
||||||
|
{
|
||||||
|
return esp_sleep_cpu_retention_deinit_impl();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool cpu_domain_pd_allowed(void)
|
||||||
|
{
|
||||||
|
return (s_cpu_retention.retent.critical_frame != NULL) && \
|
||||||
|
(s_cpu_retention.retent.non_critical_frame != NULL) && \
|
||||||
|
(s_cpu_retention.retent.cache_config_frame != NULL) && \
|
||||||
|
(s_cpu_retention.retent.clic_frame != NULL) && \
|
||||||
|
(s_cpu_retention.retent.clint_frame != NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
esp_err_t sleep_cpu_configure(bool light_sleep_enable)
|
||||||
|
{
|
||||||
|
#if ESP_SLEEP_POWER_DOWN_CPU
|
||||||
|
if (light_sleep_enable) {
|
||||||
|
ESP_RETURN_ON_ERROR(esp_sleep_cpu_retention_init(), TAG, "Failed to enable CPU power down during light sleep.");
|
||||||
|
} else {
|
||||||
|
ESP_RETURN_ON_ERROR(esp_sleep_cpu_retention_deinit(), TAG, "Failed to release CPU retention memory");
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return ESP_OK;
|
||||||
|
}
|
216
components/esp_hw_support/lowpower/port/esp32c61/sleep_cpu_asm.S
Normal file
216
components/esp_hw_support/lowpower/port/esp32c61/sleep_cpu_asm.S
Normal file
@ -0,0 +1,216 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2022-2024 Espressif Systems (Shanghai) CO LTD
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "soc/soc.h"
|
||||||
|
#include "rvsleep-frames.h"
|
||||||
|
#include "soc/soc_caps.h"
|
||||||
|
#include "sdkconfig.h"
|
||||||
|
|
||||||
|
.section .data1,"aw"
|
||||||
|
.global rv_core_critical_regs_frame
|
||||||
|
.type rv_core_critical_regs_frame,@object
|
||||||
|
.align 4
|
||||||
|
rv_core_critical_regs_frame:
|
||||||
|
.word 0
|
||||||
|
|
||||||
|
/*
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
This assembly subroutine is used to save the critical registers of the CPU
|
||||||
|
core to the internal RAM before sleep, and modify the PMU control flag to
|
||||||
|
indicate that the system needs to sleep. When the subroutine returns, it
|
||||||
|
will return the memory pointer that saves the context information of the CPU
|
||||||
|
critical registers.
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
*/
|
||||||
|
|
||||||
|
.section .iram1,"ax"
|
||||||
|
.global rv_core_critical_regs_save
|
||||||
|
.type rv_core_critical_regs_save,@function
|
||||||
|
.align 4
|
||||||
|
|
||||||
|
rv_core_critical_regs_save:
|
||||||
|
|
||||||
|
/* arrived here in critical section. we need:
|
||||||
|
save riscv core critical registers to RvCoreCriticalSleepFrame
|
||||||
|
*/
|
||||||
|
csrw mscratch, t0 /* use mscratch as temp storage */
|
||||||
|
la t0, rv_core_critical_regs_frame
|
||||||
|
lw t0, 0(t0) /* t0 pointer to RvCoreCriticalSleepFrame object */
|
||||||
|
|
||||||
|
sw ra, RV_SLP_CTX_RA(t0)
|
||||||
|
sw sp, RV_SLP_CTX_SP(t0)
|
||||||
|
sw gp, RV_SLP_CTX_GP(t0)
|
||||||
|
sw tp, RV_SLP_CTX_TP(t0)
|
||||||
|
sw t1, RV_SLP_CTX_T1(t0)
|
||||||
|
sw t2, RV_SLP_CTX_T2(t0)
|
||||||
|
sw s0, RV_SLP_CTX_S0(t0)
|
||||||
|
sw s1, RV_SLP_CTX_S1(t0)
|
||||||
|
|
||||||
|
/* a0 is caller saved, so it does not need to be saved, but it should be the
|
||||||
|
pointer value of RvCoreCriticalSleepFrame for return.
|
||||||
|
*/
|
||||||
|
mv a0, t0
|
||||||
|
sw a0, RV_SLP_CTX_A0(t0)
|
||||||
|
sw a1, RV_SLP_CTX_A1(t0)
|
||||||
|
sw a2, RV_SLP_CTX_A2(t0)
|
||||||
|
sw a3, RV_SLP_CTX_A3(t0)
|
||||||
|
sw a4, RV_SLP_CTX_A4(t0)
|
||||||
|
sw a5, RV_SLP_CTX_A5(t0)
|
||||||
|
sw a6, RV_SLP_CTX_A6(t0)
|
||||||
|
sw a7, RV_SLP_CTX_A7(t0)
|
||||||
|
sw s2, RV_SLP_CTX_S2(t0)
|
||||||
|
sw s3, RV_SLP_CTX_S3(t0)
|
||||||
|
sw s4, RV_SLP_CTX_S4(t0)
|
||||||
|
sw s5, RV_SLP_CTX_S5(t0)
|
||||||
|
sw s6, RV_SLP_CTX_S6(t0)
|
||||||
|
sw s7, RV_SLP_CTX_S7(t0)
|
||||||
|
sw s8, RV_SLP_CTX_S8(t0)
|
||||||
|
sw s9, RV_SLP_CTX_S9(t0)
|
||||||
|
sw s10, RV_SLP_CTX_S10(t0)
|
||||||
|
sw s11, RV_SLP_CTX_S11(t0)
|
||||||
|
sw t3, RV_SLP_CTX_T3(t0)
|
||||||
|
sw t4, RV_SLP_CTX_T4(t0)
|
||||||
|
sw t5, RV_SLP_CTX_T5(t0)
|
||||||
|
sw t6, RV_SLP_CTX_T6(t0)
|
||||||
|
|
||||||
|
csrr t1, mstatus
|
||||||
|
sw t1, RV_SLP_CTX_MSTATUS(t0)
|
||||||
|
csrr t2, mtvec
|
||||||
|
sw t2, RV_SLP_CTX_MTVEC(t0)
|
||||||
|
csrr t3, mcause
|
||||||
|
sw t3, RV_SLP_CTX_MCAUSE(t0)
|
||||||
|
|
||||||
|
csrr t1, mtval
|
||||||
|
sw t1, RV_SLP_CTX_MTVAL(t0)
|
||||||
|
csrr t2, mie
|
||||||
|
sw t2, RV_SLP_CTX_MIE(t0)
|
||||||
|
csrr t3, mip
|
||||||
|
sw t3, RV_SLP_CTX_MIP(t0)
|
||||||
|
csrr t1, mepc
|
||||||
|
sw t1, RV_SLP_CTX_MEPC(t0)
|
||||||
|
|
||||||
|
/*
|
||||||
|
!!! Let idf knows it's going to sleep !!!
|
||||||
|
|
||||||
|
RV_SLP_STK_PMUFUNC field is used to identify whether it is going to sleep or
|
||||||
|
has just been awakened. We use the lowest 2 bits as indication information,
|
||||||
|
3 means being awakened, 1 means going to sleep.
|
||||||
|
*/
|
||||||
|
li t1, ~0x3
|
||||||
|
lw t2, RV_SLP_CTX_PMUFUNC(t0)
|
||||||
|
and t2, t1, t2
|
||||||
|
ori t2, t2, 0x1
|
||||||
|
sw t2, RV_SLP_CTX_PMUFUNC(t0)
|
||||||
|
|
||||||
|
mv t3, t0
|
||||||
|
csrr t0, mscratch
|
||||||
|
lw t1, RV_SLP_CTX_T1(t3)
|
||||||
|
lw t2, RV_SLP_CTX_T2(t3)
|
||||||
|
lw t3, RV_SLP_CTX_T3(t3)
|
||||||
|
|
||||||
|
ret
|
||||||
|
|
||||||
|
.size rv_core_critical_regs_save, . - rv_core_critical_regs_save
|
||||||
|
|
||||||
|
|
||||||
|
#define CSR_PCER_U 0x800
|
||||||
|
#define CSR_PCMR_U 0x801
|
||||||
|
#define PCER_CYCLES (1<<0) /* count clock cycles */
|
||||||
|
#define PCMR_GLOBAL_EN (1<<0) /* enable count */
|
||||||
|
#define pcer CSR_PCER_U
|
||||||
|
#define pcmr CSR_PCMR_U
|
||||||
|
|
||||||
|
/*
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
This assembly subroutine is used to restore the CPU core critical register
|
||||||
|
context before sleep after system wakes up, modify the PMU control
|
||||||
|
information, and return the critical register context memory object pointer.
|
||||||
|
After the subroutine returns, continue to restore other modules of the
|
||||||
|
system.
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
*/
|
||||||
|
|
||||||
|
.section .iram1,"ax"
|
||||||
|
.global rv_core_critical_regs_restore
|
||||||
|
.weak rv_core_critical_regs_restore
|
||||||
|
.type rv_core_critical_regs_restore,@function
|
||||||
|
.global _rv_core_critical_regs_restore
|
||||||
|
.type _rv_core_critical_regs_restore,@function
|
||||||
|
.align 4
|
||||||
|
|
||||||
|
_rv_core_critical_regs_restore: /* export a strong symbol to jump to here, used
|
||||||
|
* for a static callback */
|
||||||
|
nop
|
||||||
|
|
||||||
|
rv_core_critical_regs_restore:
|
||||||
|
|
||||||
|
la t0, rv_core_critical_regs_frame
|
||||||
|
lw t0, 0(t0) /* t0 pointer to RvCoreCriticalSleepFrame object */
|
||||||
|
beqz t0, .skip_restore /* make sure we do not jump to zero address */
|
||||||
|
|
||||||
|
/*
|
||||||
|
!!! Let idf knows it's sleep awake. !!!
|
||||||
|
|
||||||
|
RV_SLP_STK_PMUFUNC field is used to identify whether it is going to sleep or
|
||||||
|
has just been awakened. We use the lowest 2 bits as indication information,
|
||||||
|
3 means being awakened, 1 means going to sleep.
|
||||||
|
*/
|
||||||
|
lw t1, RV_SLP_CTX_PMUFUNC(t0)
|
||||||
|
ori t1, t1, 0x3
|
||||||
|
sw t1, RV_SLP_CTX_PMUFUNC(t0)
|
||||||
|
|
||||||
|
lw t2, RV_SLP_CTX_MEPC(t0)
|
||||||
|
csrw mepc, t2
|
||||||
|
lw t3, RV_SLP_CTX_MIP(t0)
|
||||||
|
csrw mip, t3
|
||||||
|
lw t1, RV_SLP_CTX_MIE(t0)
|
||||||
|
csrw mie, t1
|
||||||
|
lw t2, RV_SLP_CTX_MSTATUS(t0)
|
||||||
|
csrw mstatus, t2
|
||||||
|
|
||||||
|
lw t3, RV_SLP_CTX_MTVEC(t0)
|
||||||
|
csrw mtvec, t3
|
||||||
|
lw t1, RV_SLP_CTX_MCAUSE(t0)
|
||||||
|
csrw mcause, t1
|
||||||
|
lw t2, RV_SLP_CTX_MTVAL(t0)
|
||||||
|
csrw mtval, t2
|
||||||
|
|
||||||
|
lw t6, RV_SLP_CTX_T6(t0)
|
||||||
|
lw t5, RV_SLP_CTX_T5(t0)
|
||||||
|
lw t4, RV_SLP_CTX_T4(t0)
|
||||||
|
lw t3, RV_SLP_CTX_T3(t0)
|
||||||
|
lw s11, RV_SLP_CTX_S11(t0)
|
||||||
|
lw s10, RV_SLP_CTX_S10(t0)
|
||||||
|
lw s9, RV_SLP_CTX_S9(t0)
|
||||||
|
lw s8, RV_SLP_CTX_S8(t0)
|
||||||
|
lw s7, RV_SLP_CTX_S7(t0)
|
||||||
|
lw s6, RV_SLP_CTX_S6(t0)
|
||||||
|
lw s5, RV_SLP_CTX_S5(t0)
|
||||||
|
lw s4, RV_SLP_CTX_S4(t0)
|
||||||
|
lw s3, RV_SLP_CTX_S3(t0)
|
||||||
|
lw s2, RV_SLP_CTX_S2(t0)
|
||||||
|
lw a7, RV_SLP_CTX_A7(t0)
|
||||||
|
lw a6, RV_SLP_CTX_A6(t0)
|
||||||
|
lw a5, RV_SLP_CTX_A5(t0)
|
||||||
|
lw a4, RV_SLP_CTX_A4(t0)
|
||||||
|
lw a3, RV_SLP_CTX_A3(t0)
|
||||||
|
lw a2, RV_SLP_CTX_A2(t0)
|
||||||
|
lw a1, RV_SLP_CTX_A1(t0)
|
||||||
|
lw a0, RV_SLP_CTX_A0(t0)
|
||||||
|
lw s1, RV_SLP_CTX_S1(t0)
|
||||||
|
lw s0, RV_SLP_CTX_S0(t0)
|
||||||
|
lw t2, RV_SLP_CTX_T2(t0)
|
||||||
|
lw t1, RV_SLP_CTX_T1(t0)
|
||||||
|
lw tp, RV_SLP_CTX_TP(t0)
|
||||||
|
lw gp, RV_SLP_CTX_GP(t0)
|
||||||
|
lw sp, RV_SLP_CTX_SP(t0)
|
||||||
|
lw ra, RV_SLP_CTX_RA(t0)
|
||||||
|
lw t0, RV_SLP_CTX_T0(t0)
|
||||||
|
|
||||||
|
.skip_restore:
|
||||||
|
ret
|
||||||
|
|
||||||
|
.size rv_core_critical_regs_restore, . - rv_core_critical_regs_restore
|
@ -66,7 +66,7 @@ typedef struct {
|
|||||||
} retent;
|
} retent;
|
||||||
} sleep_cpu_retention_t;
|
} sleep_cpu_retention_t;
|
||||||
|
|
||||||
static DRAM_ATTR __attribute__((unused)) sleep_cpu_retention_t s_cpu_retention;
|
static DRAM_ATTR sleep_cpu_retention_t s_cpu_retention;
|
||||||
|
|
||||||
#define CUSTOM_CSR_PCER_MACHINE 0x7e0
|
#define CUSTOM_CSR_PCER_MACHINE 0x7e0
|
||||||
#define CUSTOM_CSR_PCMR_MACHINE 0x7e1
|
#define CUSTOM_CSR_PCMR_MACHINE 0x7e1
|
||||||
|
@ -46,7 +46,7 @@ typedef struct {
|
|||||||
rtc_cntl_sleep_retent_t retent;
|
rtc_cntl_sleep_retent_t retent;
|
||||||
} sleep_cpu_retention_t;
|
} sleep_cpu_retention_t;
|
||||||
|
|
||||||
static DRAM_ATTR __attribute__((unused)) sleep_cpu_retention_t s_cpu_retention;
|
static DRAM_ATTR sleep_cpu_retention_t s_cpu_retention;
|
||||||
|
|
||||||
|
|
||||||
#if CONFIG_PM_RESTORE_CACHE_TAGMEM_AFTER_LIGHT_SLEEP
|
#if CONFIG_PM_RESTORE_CACHE_TAGMEM_AFTER_LIGHT_SLEEP
|
||||||
|
@ -28,7 +28,7 @@
|
|||||||
#include "hal/spimem_flash_ll.h"
|
#include "hal/spimem_flash_ll.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CONFIG_IDF_TARGET_ESP32C5 // TODO: IDF-10464
|
#if CONFIG_IDF_TARGET_ESP32C5 || CONFIG_IDF_TARGET_ESP32C61 // TODO: IDF-10464
|
||||||
#include "hal/mspi_timing_tuning_ll.h"
|
#include "hal/mspi_timing_tuning_ll.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -469,7 +469,7 @@ void mspi_timing_psram_tuning(void)
|
|||||||
void mspi_timing_enter_low_speed_mode(bool control_spi1)
|
void mspi_timing_enter_low_speed_mode(bool control_spi1)
|
||||||
{
|
{
|
||||||
#if SOC_MEMSPI_FLASH_CLK_SRC_IS_INDEPENDENT
|
#if SOC_MEMSPI_FLASH_CLK_SRC_IS_INDEPENDENT
|
||||||
#if CONFIG_IDF_TARGET_ESP32C5 // TODO: IDF-10464
|
#if CONFIG_IDF_TARGET_ESP32C5 || CONFIG_IDF_TARGET_ESP32C61 // TODO: IDF-10464
|
||||||
mspi_ll_clock_src_sel(MSPI_CLK_SRC_XTAL);
|
mspi_ll_clock_src_sel(MSPI_CLK_SRC_XTAL);
|
||||||
#else
|
#else
|
||||||
spimem_flash_ll_set_clock_source(MSPI_CLK_SRC_ROM_DEFAULT);
|
spimem_flash_ll_set_clock_source(MSPI_CLK_SRC_ROM_DEFAULT);
|
||||||
@ -509,7 +509,7 @@ void mspi_timing_enter_low_speed_mode(bool control_spi1)
|
|||||||
void mspi_timing_enter_high_speed_mode(bool control_spi1)
|
void mspi_timing_enter_high_speed_mode(bool control_spi1)
|
||||||
{
|
{
|
||||||
#if SOC_MEMSPI_FLASH_CLK_SRC_IS_INDEPENDENT
|
#if SOC_MEMSPI_FLASH_CLK_SRC_IS_INDEPENDENT
|
||||||
#if CONFIG_IDF_TARGET_ESP32C5 // TODO: IDF-10464
|
#if CONFIG_IDF_TARGET_ESP32C5 || CONFIG_IDF_TARGET_ESP32C61// TODO: IDF-10464
|
||||||
mspi_ll_clock_src_sel(MSPI_CLK_SRC_SPLL);
|
mspi_ll_clock_src_sel(MSPI_CLK_SRC_SPLL);
|
||||||
#else
|
#else
|
||||||
spimem_flash_ll_set_clock_source(MSPI_CLK_SRC_DEFAULT);
|
spimem_flash_ll_set_clock_source(MSPI_CLK_SRC_DEFAULT);
|
||||||
|
@ -20,7 +20,6 @@ endif()
|
|||||||
# TODO: [ESP32C61] IDF-9250
|
# TODO: [ESP32C61] IDF-9250
|
||||||
if(CONFIG_IDF_TARGET_ESP32C61)
|
if(CONFIG_IDF_TARGET_ESP32C61)
|
||||||
list(REMOVE_ITEM srcs
|
list(REMOVE_ITEM srcs
|
||||||
"pmu_sleep.c"
|
|
||||||
"sar_periph_ctrl.c"
|
"sar_periph_ctrl.c"
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
313
components/esp_hw_support/port/esp32c61/pmu_sleep.c
Normal file
313
components/esp_hw_support/port/esp32c61/pmu_sleep.c
Normal file
@ -0,0 +1,313 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2023-2024 Espressif Systems (Shanghai) CO LTD
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <sys/param.h>
|
||||||
|
#include <esp_types.h>
|
||||||
|
#include "sdkconfig.h"
|
||||||
|
#include "esp_err.h"
|
||||||
|
#include "esp_attr.h"
|
||||||
|
#include "soc/soc.h"
|
||||||
|
#include "soc/rtc.h"
|
||||||
|
#include "soc/pmu_struct.h"
|
||||||
|
#include "hal/lp_aon_hal.h"
|
||||||
|
#include "hal/efuse_ll.h"
|
||||||
|
#include "hal/efuse_hal.h"
|
||||||
|
#include "esp_private/esp_pmu.h"
|
||||||
|
#include "pmu_param.h"
|
||||||
|
|
||||||
|
#define HP(state) (PMU_MODE_HP_ ## state)
|
||||||
|
#define LP(state) (PMU_MODE_LP_ ## state)
|
||||||
|
|
||||||
|
|
||||||
|
static bool s_pmu_sleep_regdma_backup_enabled;
|
||||||
|
|
||||||
|
void pmu_sleep_enable_regdma_backup(void)
|
||||||
|
{
|
||||||
|
if(!s_pmu_sleep_regdma_backup_enabled){
|
||||||
|
assert(PMU_instance()->hal);
|
||||||
|
/* entry 0, 1, 2 is used by pmu HP_SLEEP and HP_ACTIVE, HP_SLEEP
|
||||||
|
* and HP_MODEM or HP_MODEM and HP_ACTIVE states switching,
|
||||||
|
* respectively. entry 3 is reserved, not used yet! */
|
||||||
|
pmu_hal_hp_set_sleep_active_backup_enable(PMU_instance()->hal);
|
||||||
|
pmu_hal_hp_set_sleep_modem_backup_enable(PMU_instance()->hal);
|
||||||
|
pmu_hal_hp_set_modem_active_backup_enable(PMU_instance()->hal);
|
||||||
|
s_pmu_sleep_regdma_backup_enabled = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void pmu_sleep_disable_regdma_backup(void)
|
||||||
|
{
|
||||||
|
if(s_pmu_sleep_regdma_backup_enabled){
|
||||||
|
assert(PMU_instance()->hal);
|
||||||
|
pmu_hal_hp_set_sleep_active_backup_disable(PMU_instance()->hal);
|
||||||
|
pmu_hal_hp_set_sleep_modem_backup_disable(PMU_instance()->hal);
|
||||||
|
pmu_hal_hp_set_modem_active_backup_disable(PMU_instance()->hal);
|
||||||
|
s_pmu_sleep_regdma_backup_enabled = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t pmu_sleep_calculate_hw_wait_time(uint32_t pd_flags, uint32_t slowclk_period, uint32_t fastclk_period)
|
||||||
|
{
|
||||||
|
const pmu_sleep_machine_constant_t *mc = (pmu_sleep_machine_constant_t *)PMU_instance()->mc;
|
||||||
|
|
||||||
|
/* LP core hardware wait time, microsecond */
|
||||||
|
const int lp_wakeup_wait_time_us = rtc_time_slowclk_to_us(mc->lp.wakeup_wait_cycle, slowclk_period);
|
||||||
|
const int lp_clk_switch_time_us = rtc_time_slowclk_to_us(mc->lp.clk_switch_cycle, slowclk_period);
|
||||||
|
const int lp_clk_power_on_wait_time_us = (pd_flags & PMU_SLEEP_PD_XTAL) ? mc->lp.xtal_wait_stable_time_us \
|
||||||
|
: rtc_time_slowclk_to_us(mc->lp.clk_power_on_wait_cycle, slowclk_period);
|
||||||
|
const int lp_control_wait_time_us = mc->lp.isolate_wait_time_us + mc->lp.reset_wait_time_us;
|
||||||
|
|
||||||
|
const int lp_hw_wait_time_us = mc->lp.min_slp_time_us + mc->lp.analog_wait_time_us + lp_clk_power_on_wait_time_us \
|
||||||
|
+ lp_wakeup_wait_time_us + lp_clk_switch_time_us + mc->lp.power_supply_wait_time_us \
|
||||||
|
+ mc->lp.power_up_wait_time_us + lp_control_wait_time_us;
|
||||||
|
|
||||||
|
/* HP core hardware wait time, microsecond */
|
||||||
|
const int hp_digital_power_up_wait_time_us = mc->hp.power_supply_wait_time_us + mc->hp.power_up_wait_time_us;
|
||||||
|
const int hp_control_wait_time_us = mc->hp.isolate_wait_time_us + mc->hp.reset_wait_time_us;
|
||||||
|
const int hp_regdma_wait_time_us = MAX(mc->hp.regdma_s2m_work_time_us + mc->hp.regdma_m2a_work_time_us, mc->hp.regdma_s2a_work_time_us);
|
||||||
|
const int hp_clock_wait_time_us = mc->hp.xtal_wait_stable_time_us + mc->hp.pll_wait_stable_time_us;
|
||||||
|
|
||||||
|
const int hp_hw_wait_time_us = mc->hp.analog_wait_time_us + MAX(hp_clock_wait_time_us, \
|
||||||
|
hp_digital_power_up_wait_time_us + hp_control_wait_time_us + hp_regdma_wait_time_us);
|
||||||
|
|
||||||
|
/* When the SOC wakeup (lp timer or GPIO wakeup) and Modem wakeup (Beacon wakeup) complete, the soc
|
||||||
|
* wakeup will be delayed until the RF is turned on in Modem state.
|
||||||
|
*
|
||||||
|
* modem wakeup TBTT, RF on by HW
|
||||||
|
* | |
|
||||||
|
* \|/ \|/
|
||||||
|
* PMU_HP_ACTIVE /------
|
||||||
|
* PMU_HP_MODEM /------------//////////////////
|
||||||
|
* PMU_HP_SLEEP ----------------------//////////////////
|
||||||
|
* /|\ /|\ /|\ /|\ /|\ /|\
|
||||||
|
* |<- some hw wait ->| | | |<- M2A switch ->|
|
||||||
|
* | slow cycles & | soc wakeup | |
|
||||||
|
* | FOSC cycles |<- S2M switch ->| |
|
||||||
|
* | |
|
||||||
|
* |<-- PMU guard time, also the maximum time for the SOC -->|
|
||||||
|
* | wake-up delay |
|
||||||
|
*/
|
||||||
|
#if SOC_PM_SUPPORT_PMU_MODEM_STATE && CONFIG_ESP_WIFI_ENHANCED_LIGHT_SLEEP
|
||||||
|
const int rf_on_protect_time_us = mc->hp.regdma_rf_on_work_time_us;
|
||||||
|
const int total_hw_wait_time_us = lp_hw_wait_time_us + hp_hw_wait_time_us + mc->hp.clock_domain_sync_time_us;
|
||||||
|
#else
|
||||||
|
const int rf_on_protect_time_us = 0;
|
||||||
|
const int total_hw_wait_time_us = lp_hw_wait_time_us + hp_hw_wait_time_us;
|
||||||
|
#endif
|
||||||
|
return total_hw_wait_time_us + rf_on_protect_time_us;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define rtc_time_us_to_fastclk(time_us, period) rtc_time_us_to_slowclk((time_us), (period))
|
||||||
|
|
||||||
|
static inline pmu_sleep_param_config_t * pmu_sleep_param_config_default(
|
||||||
|
pmu_sleep_param_config_t *param,
|
||||||
|
pmu_sleep_power_config_t *power, /* We'll use the runtime power parameter to determine some hardware parameters */
|
||||||
|
const uint32_t pd_flags,
|
||||||
|
const uint32_t adjustment,
|
||||||
|
const uint32_t slowclk_period,
|
||||||
|
const uint32_t fastclk_period
|
||||||
|
)
|
||||||
|
{
|
||||||
|
const pmu_sleep_machine_constant_t *mc = (pmu_sleep_machine_constant_t *)PMU_instance()->mc;
|
||||||
|
|
||||||
|
param->hp_sys.min_slp_slow_clk_cycle = rtc_time_us_to_slowclk(mc->hp.min_slp_time_us, slowclk_period);
|
||||||
|
param->hp_sys.analog_wait_target_cycle = rtc_time_us_to_fastclk(mc->hp.analog_wait_time_us, fastclk_period);
|
||||||
|
param->hp_sys.digital_power_supply_wait_cycle = rtc_time_us_to_fastclk(mc->hp.power_supply_wait_time_us, fastclk_period);
|
||||||
|
param->hp_sys.digital_power_up_wait_cycle = rtc_time_us_to_fastclk(mc->hp.power_up_wait_time_us, fastclk_period);
|
||||||
|
param->hp_sys.pll_stable_wait_cycle = rtc_time_us_to_fastclk(mc->hp.pll_wait_stable_time_us, fastclk_period);
|
||||||
|
param->hp_sys.isolate_wait_cycle = rtc_time_us_to_fastclk(mc->hp.isolate_wait_time_us, fastclk_period);
|
||||||
|
param->hp_sys.reset_wait_cycle = rtc_time_us_to_fastclk(mc->hp.reset_wait_time_us, fastclk_period);
|
||||||
|
|
||||||
|
const int hw_wait_time_us = pmu_sleep_calculate_hw_wait_time(pd_flags, slowclk_period, fastclk_period);
|
||||||
|
const int modem_state_skip_time_us = mc->hp.regdma_m2a_work_time_us + mc->hp.system_dfs_up_work_time_us + mc->lp.min_slp_time_us;
|
||||||
|
const int modem_wakeup_wait_time_us = adjustment - hw_wait_time_us + modem_state_skip_time_us + mc->hp.regdma_rf_on_work_time_us;
|
||||||
|
param->hp_sys.modem_wakeup_wait_cycle = rtc_time_us_to_fastclk(modem_wakeup_wait_time_us, fastclk_period);
|
||||||
|
|
||||||
|
param->lp_sys.min_slp_slow_clk_cycle = rtc_time_us_to_slowclk(mc->lp.min_slp_time_us, slowclk_period);
|
||||||
|
param->lp_sys.analog_wait_target_cycle = rtc_time_us_to_slowclk(mc->lp.analog_wait_time_us, slowclk_period);
|
||||||
|
param->lp_sys.digital_power_supply_wait_cycle = rtc_time_us_to_fastclk(mc->lp.power_supply_wait_time_us, fastclk_period);
|
||||||
|
param->lp_sys.digital_power_up_wait_cycle = rtc_time_us_to_fastclk(mc->lp.power_up_wait_time_us, fastclk_period);
|
||||||
|
param->lp_sys.isolate_wait_cycle = rtc_time_us_to_fastclk(mc->lp.isolate_wait_time_us, fastclk_period);
|
||||||
|
param->lp_sys.reset_wait_cycle = rtc_time_us_to_fastclk(mc->lp.reset_wait_time_us, fastclk_period);
|
||||||
|
|
||||||
|
if (power->hp_sys.xtal.xpd_xtal) {
|
||||||
|
param->hp_lp.xtal_stable_wait_slow_clk_cycle = rtc_time_us_to_slowclk(mc->lp.xtal_wait_stable_time_us, slowclk_period);
|
||||||
|
} else {
|
||||||
|
param->hp_lp.xtal_stable_wait_cycle = rtc_time_us_to_fastclk(mc->hp.xtal_wait_stable_time_us, fastclk_period);
|
||||||
|
}
|
||||||
|
return param;
|
||||||
|
}
|
||||||
|
|
||||||
|
const pmu_sleep_config_t* pmu_sleep_config_default(
|
||||||
|
pmu_sleep_config_t *config,
|
||||||
|
uint32_t pd_flags,
|
||||||
|
uint32_t adjustment,
|
||||||
|
uint32_t slowclk_period,
|
||||||
|
uint32_t fastclk_period,
|
||||||
|
bool dslp
|
||||||
|
)
|
||||||
|
{
|
||||||
|
pmu_sleep_power_config_t power_default = PMU_SLEEP_POWER_CONFIG_DEFAULT(pd_flags);
|
||||||
|
|
||||||
|
uint32_t iram_pd_flags = 0;
|
||||||
|
iram_pd_flags |= (pd_flags & PMU_SLEEP_PD_MEM_G0) ? BIT(0) : 0;
|
||||||
|
iram_pd_flags |= (pd_flags & PMU_SLEEP_PD_MEM_G1) ? BIT(1) : 0;
|
||||||
|
iram_pd_flags |= (pd_flags & PMU_SLEEP_PD_MEM_G2) ? BIT(2) : 0;
|
||||||
|
iram_pd_flags |= (pd_flags & PMU_SLEEP_PD_MEM_G3) ? BIT(3) : 0;
|
||||||
|
config->power = power_default;
|
||||||
|
|
||||||
|
pmu_sleep_param_config_t param_default = PMU_SLEEP_PARAM_CONFIG_DEFAULT(pd_flags);
|
||||||
|
config->param = *pmu_sleep_param_config_default(¶m_default, &power_default, pd_flags, adjustment, slowclk_period, fastclk_period);
|
||||||
|
|
||||||
|
if (dslp) {
|
||||||
|
config->param.lp_sys.analog_wait_target_cycle = rtc_time_us_to_slowclk(PMU_LP_ANALOG_WAIT_TARGET_TIME_DSLP_US, slowclk_period);
|
||||||
|
pmu_sleep_analog_config_t analog_default = PMU_SLEEP_ANALOG_DSLP_CONFIG_DEFAULT(pd_flags);
|
||||||
|
config->analog = analog_default;
|
||||||
|
} else {
|
||||||
|
pmu_sleep_digital_config_t digital_default = PMU_SLEEP_DIGITAL_LSLP_CONFIG_DEFAULT(pd_flags);
|
||||||
|
config->digital = digital_default;
|
||||||
|
|
||||||
|
pmu_sleep_analog_config_t analog_default = PMU_SLEEP_ANALOG_LSLP_CONFIG_DEFAULT(pd_flags);
|
||||||
|
|
||||||
|
if (!(pd_flags & PMU_SLEEP_PD_XTAL) || !(pd_flags & PMU_SLEEP_PD_RC_FAST)){
|
||||||
|
analog_default.hp_sys.analog.pd_cur = PMU_PD_CUR_SLEEP_ON;
|
||||||
|
analog_default.hp_sys.analog.bias_sleep = PMU_BIASSLP_SLEEP_ON;
|
||||||
|
analog_default.hp_sys.analog.dbias = HP_CALI_DBIAS_SLP_1V1;
|
||||||
|
analog_default.hp_sys.analog.dbg_atten = 0;
|
||||||
|
|
||||||
|
analog_default.lp_sys[LP(SLEEP)].analog.pd_cur = PMU_PD_CUR_SLEEP_ON;
|
||||||
|
analog_default.lp_sys[LP(SLEEP)].analog.bias_sleep = PMU_BIASSLP_SLEEP_ON;
|
||||||
|
analog_default.lp_sys[LP(SLEEP)].analog.dbias = LP_CALI_DBIAS_SLP_1V1;
|
||||||
|
analog_default.lp_sys[LP(SLEEP)].analog.dbg_atten = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
config->analog = analog_default;
|
||||||
|
}
|
||||||
|
return config;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void pmu_sleep_power_init(pmu_context_t *ctx, const pmu_sleep_power_config_t *power, bool dslp)
|
||||||
|
{
|
||||||
|
pmu_ll_hp_set_dig_power(ctx->hal->dev, HP(SLEEP), power->hp_sys.dig_power.val);
|
||||||
|
pmu_ll_hp_set_clk_power(ctx->hal->dev, HP(SLEEP), power->hp_sys.clk_power.val);
|
||||||
|
pmu_ll_hp_set_xtal_xpd (ctx->hal->dev, HP(SLEEP), power->hp_sys.xtal.xpd_xtal);
|
||||||
|
|
||||||
|
pmu_ll_lp_set_dig_power(ctx->hal->dev, LP(ACTIVE), power->lp_sys[LP(ACTIVE)].dig_power.val);
|
||||||
|
pmu_ll_lp_set_clk_power(ctx->hal->dev, LP(ACTIVE), power->lp_sys[LP(ACTIVE)].clk_power.val);
|
||||||
|
|
||||||
|
pmu_ll_lp_set_dig_power(ctx->hal->dev, LP(SLEEP), power->lp_sys[LP(SLEEP)].dig_power.val);
|
||||||
|
pmu_ll_lp_set_clk_power(ctx->hal->dev, LP(SLEEP), power->lp_sys[LP(SLEEP)].clk_power.val);
|
||||||
|
pmu_ll_lp_set_xtal_xpd (ctx->hal->dev, LP(SLEEP), power->lp_sys[LP(SLEEP)].xtal.xpd_xtal);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void pmu_sleep_digital_init(pmu_context_t *ctx, const pmu_sleep_digital_config_t *dig)
|
||||||
|
{
|
||||||
|
pmu_ll_hp_set_dig_pad_slp_sel (ctx->hal->dev, HP(SLEEP), dig->syscntl.dig_pad_slp_sel);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void pmu_sleep_analog_init(pmu_context_t *ctx, const pmu_sleep_analog_config_t *analog, bool dslp)
|
||||||
|
{
|
||||||
|
assert(ctx->hal);
|
||||||
|
pmu_ll_hp_set_dbg_atten (ctx->hal->dev, HP(SLEEP), analog->hp_sys.analog.dbg_atten);
|
||||||
|
pmu_ll_hp_set_current_power_off (ctx->hal->dev, HP(SLEEP), analog->hp_sys.analog.pd_cur);
|
||||||
|
pmu_ll_hp_set_bias_sleep_enable (ctx->hal->dev, HP(SLEEP), analog->hp_sys.analog.bias_sleep);
|
||||||
|
pmu_ll_hp_set_regulator_xpd (ctx->hal->dev, HP(SLEEP), analog->hp_sys.analog.xpd);
|
||||||
|
pmu_ll_hp_set_regulator_dbias (ctx->hal->dev, HP(SLEEP), analog->hp_sys.analog.dbias);
|
||||||
|
pmu_ll_hp_set_regulator_driver_bar (ctx->hal->dev, HP(SLEEP), analog->hp_sys.analog.drv_b);
|
||||||
|
|
||||||
|
pmu_ll_lp_set_dbg_atten (ctx->hal->dev, LP(SLEEP), analog->lp_sys[LP(SLEEP)].analog.dbg_atten);
|
||||||
|
pmu_ll_lp_set_current_power_off (ctx->hal->dev, LP(SLEEP), analog->lp_sys[LP(SLEEP)].analog.pd_cur);
|
||||||
|
pmu_ll_lp_set_bias_sleep_enable (ctx->hal->dev, LP(SLEEP), analog->lp_sys[LP(SLEEP)].analog.bias_sleep);
|
||||||
|
pmu_ll_lp_set_regulator_slp_xpd (ctx->hal->dev, LP(SLEEP), analog->lp_sys[LP(SLEEP)].analog.slp_xpd);
|
||||||
|
pmu_ll_lp_set_regulator_xpd (ctx->hal->dev, LP(SLEEP), analog->lp_sys[LP(SLEEP)].analog.xpd);
|
||||||
|
pmu_ll_lp_set_regulator_sleep_dbias(ctx->hal->dev, LP(SLEEP), analog->lp_sys[LP(SLEEP)].analog.slp_dbias);
|
||||||
|
pmu_ll_lp_set_regulator_dbias (ctx->hal->dev, LP(SLEEP), analog->lp_sys[LP(SLEEP)].analog.dbias);
|
||||||
|
pmu_ll_lp_set_regulator_driver_bar (ctx->hal->dev, LP(SLEEP), analog->lp_sys[LP(SLEEP)].analog.drv_b);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void pmu_sleep_param_init(pmu_context_t *ctx, const pmu_sleep_param_config_t *param, bool dslp)
|
||||||
|
{
|
||||||
|
assert(ctx->hal);
|
||||||
|
pmu_ll_hp_set_min_sleep_cycle(ctx->hal->dev, param->hp_sys.min_slp_slow_clk_cycle);
|
||||||
|
pmu_ll_lp_set_min_sleep_cycle(ctx->hal->dev, param->lp_sys.min_slp_slow_clk_cycle);
|
||||||
|
|
||||||
|
pmu_ll_hp_set_analog_wait_target_cycle(ctx->hal->dev, param->hp_sys.analog_wait_target_cycle);
|
||||||
|
pmu_ll_lp_set_analog_wait_target_cycle(ctx->hal->dev, param->lp_sys.analog_wait_target_cycle);
|
||||||
|
|
||||||
|
pmu_hal_hp_set_digital_power_up_wait_cycle(ctx->hal, param->hp_sys.digital_power_supply_wait_cycle, param->hp_sys.digital_power_up_wait_cycle);
|
||||||
|
pmu_hal_lp_set_digital_power_up_wait_cycle(ctx->hal, param->lp_sys.digital_power_supply_wait_cycle, param->lp_sys.digital_power_up_wait_cycle);
|
||||||
|
|
||||||
|
pmu_hal_hp_set_control_ready_wait_cycle(ctx->hal, param->hp_sys.isolate_wait_cycle, param->hp_sys.reset_wait_cycle);
|
||||||
|
pmu_hal_lp_set_control_ready_wait_cycle(ctx->hal, param->lp_sys.isolate_wait_cycle, param->lp_sys.reset_wait_cycle);
|
||||||
|
|
||||||
|
pmu_ll_set_modem_wait_target_cycle(ctx->hal->dev, param->hp_sys.modem_wakeup_wait_cycle);
|
||||||
|
pmu_ll_set_xtal_stable_wait_cycle(ctx->hal->dev, param->hp_lp.xtal_stable_wait_slow_clk_cycle);
|
||||||
|
pmu_ll_set_pll_stable_wait_cycle(ctx->hal->dev, param->hp_sys.pll_stable_wait_cycle);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool pmu_sleep_pll_already_enabled(void)
|
||||||
|
{
|
||||||
|
return (pmu_ll_get_sysclk_sleep_select_state(PMU_instance()->hal->dev) != 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void pmu_sleep_init(const pmu_sleep_config_t *config, bool dslp)
|
||||||
|
{
|
||||||
|
assert(PMU_instance());
|
||||||
|
pmu_sleep_power_init(PMU_instance(), &config->power, dslp);
|
||||||
|
if(!dslp){
|
||||||
|
pmu_sleep_digital_init(PMU_instance(), &config->digital);
|
||||||
|
}
|
||||||
|
pmu_sleep_analog_init(PMU_instance(), &config->analog, dslp);
|
||||||
|
pmu_sleep_param_init(PMU_instance(), &config->param, dslp);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t pmu_sleep_start(uint32_t wakeup_opt, uint32_t reject_opt, uint32_t lslp_mem_inf_fpu, bool dslp)
|
||||||
|
{
|
||||||
|
assert(PMU_instance()->hal);
|
||||||
|
|
||||||
|
lp_aon_hal_inform_wakeup_type(dslp);
|
||||||
|
|
||||||
|
pmu_ll_hp_set_wakeup_enable(PMU_instance()->hal->dev, wakeup_opt);
|
||||||
|
pmu_ll_hp_set_reject_enable(PMU_instance()->hal->dev, reject_opt);
|
||||||
|
|
||||||
|
pmu_ll_hp_clear_wakeup_intr_status(PMU_instance()->hal->dev);
|
||||||
|
pmu_ll_hp_clear_reject_intr_status(PMU_instance()->hal->dev);
|
||||||
|
pmu_ll_hp_clear_reject_cause(PMU_instance()->hal->dev);
|
||||||
|
|
||||||
|
/* Start entry into sleep mode */
|
||||||
|
pmu_ll_hp_set_sleep_enable(PMU_instance()->hal->dev);
|
||||||
|
|
||||||
|
/* In pd_cpu lightsleep and deepsleep mode, we never get here */
|
||||||
|
while (!pmu_ll_hp_is_sleep_wakeup(PMU_instance()->hal->dev) &&
|
||||||
|
!pmu_ll_hp_is_sleep_reject(PMU_instance()->hal->dev)) {
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
return pmu_sleep_finish(dslp);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool pmu_sleep_finish(bool dslp)
|
||||||
|
{
|
||||||
|
(void)dslp;
|
||||||
|
|
||||||
|
// Wait eFuse memory update done.
|
||||||
|
while(efuse_ll_get_controller_state() != EFUSE_CONTROLLER_STATE_IDLE);
|
||||||
|
|
||||||
|
return pmu_ll_hp_is_sleep_reject(PMU_instance()->hal->dev);
|
||||||
|
}
|
||||||
|
|
||||||
|
void pmu_sleep_enable_hp_sleep_sysclk(bool enable)
|
||||||
|
{
|
||||||
|
pmu_ll_hp_set_icg_sysclk_enable(PMU_instance()->hal->dev, HP(SLEEP), enable);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t pmu_sleep_get_wakup_retention_cost(void)
|
||||||
|
{
|
||||||
|
const pmu_sleep_machine_constant_t *mc = (pmu_sleep_machine_constant_t *)PMU_instance()->mc;
|
||||||
|
return mc->hp.regdma_s2a_work_time_us;
|
||||||
|
}
|
@ -20,6 +20,8 @@ extern "C" {
|
|||||||
|
|
||||||
#define HP_CALI_DBIAS_DEFAULT 26
|
#define HP_CALI_DBIAS_DEFAULT 26
|
||||||
#define LP_CALI_DBIAS_DEFAULT 25
|
#define LP_CALI_DBIAS_DEFAULT 25
|
||||||
|
#define HP_CALI_DBIAS_SLP_1V1 22
|
||||||
|
#define LP_CALI_DBIAS_SLP_1V1 22
|
||||||
|
|
||||||
// FOR XTAL FORCE PU IN SLEEP
|
// FOR XTAL FORCE PU IN SLEEP
|
||||||
#define PMU_PD_CUR_SLEEP_ON 0
|
#define PMU_PD_CUR_SLEEP_ON 0
|
||||||
@ -37,19 +39,19 @@ extern "C" {
|
|||||||
#define PMU_LP_DRVB_LIGHTSLEEP 0
|
#define PMU_LP_DRVB_LIGHTSLEEP 0
|
||||||
#define PMU_HP_XPD_LIGHTSLEEP 1
|
#define PMU_HP_XPD_LIGHTSLEEP 1
|
||||||
|
|
||||||
#define PMU_DBG_ATTEN_LIGHTSLEEP_DEFAULT 0
|
#define PMU_DBG_ATTEN_LIGHTSLEEP_DEFAULT 1
|
||||||
#define PMU_HP_DBIAS_LIGHTSLEEP_0V6_DEFAULT 1
|
#define PMU_HP_DBIAS_LIGHTSLEEP_0V6_DEFAULT 0
|
||||||
#define PMU_LP_DBIAS_LIGHTSLEEP_0V7_DEFAULT 12
|
#define PMU_LP_DBIAS_LIGHTSLEEP_0V7_DEFAULT 15
|
||||||
|
|
||||||
// FOR LIGHTSLEEP: XTAL FORCE PU
|
// FOR LIGHTSLEEP: XTAL FORCE PU
|
||||||
#define PMU_DBG_ATTEN_ACTIVE_DEFAULT 0
|
#define PMU_DBG_ATTEN_ACTIVE_DEFAULT 0
|
||||||
|
|
||||||
// FOR DEEPSLEEP
|
// FOR DEEPSLEEP
|
||||||
#define PMU_DBG_HP_DEEPSLEEP 0
|
#define PMU_DBG_HP_DEEPSLEEP 13
|
||||||
#define PMU_HP_XPD_DEEPSLEEP 0
|
#define PMU_HP_XPD_DEEPSLEEP 0
|
||||||
#define PMU_LP_DRVB_DEEPSLEEP 0
|
#define PMU_LP_DRVB_DEEPSLEEP 0
|
||||||
|
|
||||||
#define PMU_DBG_ATTEN_DEEPSLEEP_DEFAULT 12
|
#define PMU_DBG_ATTEN_DEEPSLEEP_DEFAULT 13
|
||||||
#define PMU_LP_DBIAS_DEEPSLEEP_0V7_DEFAULT 23
|
#define PMU_LP_DBIAS_DEEPSLEEP_0V7_DEFAULT 23
|
||||||
|
|
||||||
uint32_t get_act_hp_dbias(void);
|
uint32_t get_act_hp_dbias(void);
|
||||||
@ -365,8 +367,8 @@ typedef struct {
|
|||||||
#define PMU_SLEEP_ANALOG_DSLP_CONFIG_DEFAULT(pd_flags) { \
|
#define PMU_SLEEP_ANALOG_DSLP_CONFIG_DEFAULT(pd_flags) { \
|
||||||
.hp_sys = { \
|
.hp_sys = { \
|
||||||
.analog = { \
|
.analog = { \
|
||||||
.pd_cur = PMU_PD_CUR_SLEEP_ON, \
|
.pd_cur = PMU_PD_CUR_SLEEP_DEFAULT, \
|
||||||
.bias_sleep = PMU_BIASSLP_SLEEP_ON, \
|
.bias_sleep = PMU_BIASSLP_SLEEP_DEFAULT, \
|
||||||
.xpd = PMU_HP_XPD_DEEPSLEEP, \
|
.xpd = PMU_HP_XPD_DEEPSLEEP, \
|
||||||
.dbg_atten = PMU_DBG_HP_DEEPSLEEP \
|
.dbg_atten = PMU_DBG_HP_DEEPSLEEP \
|
||||||
} \
|
} \
|
||||||
@ -472,7 +474,7 @@ typedef struct pmu_sleep_machine_constant {
|
|||||||
.analog_wait_time_us = 154, \
|
.analog_wait_time_us = 154, \
|
||||||
.isolate_wait_time_us = 1, \
|
.isolate_wait_time_us = 1, \
|
||||||
.reset_wait_time_us = 1, \
|
.reset_wait_time_us = 1, \
|
||||||
.power_supply_wait_time_us = 2, \
|
.power_supply_wait_time_us = 20, \
|
||||||
.power_up_wait_time_us = 2, \
|
.power_up_wait_time_us = 2, \
|
||||||
.regdma_s2m_work_time_us = 172, \
|
.regdma_s2m_work_time_us = 172, \
|
||||||
.regdma_s2a_work_time_us = 480, \
|
.regdma_s2a_work_time_us = 480, \
|
||||||
|
@ -185,9 +185,7 @@ uint64_t rtc_time_slowclk_to_us(uint64_t rtc_cycles, uint32_t period)
|
|||||||
|
|
||||||
uint64_t rtc_time_get(void)
|
uint64_t rtc_time_get(void)
|
||||||
{
|
{
|
||||||
// return lp_timer_hal_get_cycle_count();
|
return lp_timer_hal_get_cycle_count();
|
||||||
ESP_EARLY_LOGW(TAG, "rtc_timer has not been implemented yet"); // TODO: IDF-9244
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t rtc_clk_freq_cal(uint32_t cal_val)
|
uint32_t rtc_clk_freq_cal(uint32_t cal_val)
|
||||||
|
@ -96,6 +96,9 @@
|
|||||||
#elif CONFIG_IDF_TARGET_ESP32C5
|
#elif CONFIG_IDF_TARGET_ESP32C5
|
||||||
#include "esp32c5/rom/rtc.h"
|
#include "esp32c5/rom/rtc.h"
|
||||||
#include "hal/gpio_ll.h"
|
#include "hal/gpio_ll.h"
|
||||||
|
#elif CONFIG_IDF_TARGET_ESP32C61
|
||||||
|
#include "esp32c61/rom/rtc.h"
|
||||||
|
#include "hal/gpio_ll.h"
|
||||||
#elif CONFIG_IDF_TARGET_ESP32H2
|
#elif CONFIG_IDF_TARGET_ESP32H2
|
||||||
#include "esp32h2/rom/rtc.h"
|
#include "esp32h2/rom/rtc.h"
|
||||||
#include "esp32h2/rom/cache.h"
|
#include "esp32h2/rom/cache.h"
|
||||||
@ -152,6 +155,9 @@
|
|||||||
#elif CONFIG_IDF_TARGET_ESP32C5
|
#elif CONFIG_IDF_TARGET_ESP32C5
|
||||||
#define DEFAULT_SLEEP_OUT_OVERHEAD_US (318)
|
#define DEFAULT_SLEEP_OUT_OVERHEAD_US (318)
|
||||||
#define DEFAULT_HARDWARE_OUT_OVERHEAD_US (56)
|
#define DEFAULT_HARDWARE_OUT_OVERHEAD_US (56)
|
||||||
|
#elif CONFIG_IDF_TARGET_ESP32C61
|
||||||
|
#define DEFAULT_SLEEP_OUT_OVERHEAD_US (318)
|
||||||
|
#define DEFAULT_HARDWARE_OUT_OVERHEAD_US (56)
|
||||||
#elif CONFIG_IDF_TARGET_ESP32H2
|
#elif CONFIG_IDF_TARGET_ESP32H2
|
||||||
#define DEFAULT_SLEEP_OUT_OVERHEAD_US (118)
|
#define DEFAULT_SLEEP_OUT_OVERHEAD_US (118)
|
||||||
#define DEFAULT_HARDWARE_OUT_OVERHEAD_US (9)
|
#define DEFAULT_HARDWARE_OUT_OVERHEAD_US (9)
|
||||||
@ -196,7 +202,7 @@
|
|||||||
#define MAX_DSLP_HOOKS 3
|
#define MAX_DSLP_HOOKS 3
|
||||||
|
|
||||||
static esp_deep_sleep_cb_t s_dslp_cb[MAX_DSLP_HOOKS] = {0};
|
static esp_deep_sleep_cb_t s_dslp_cb[MAX_DSLP_HOOKS] = {0};
|
||||||
#if CONFIG_ESP_PHY_ENABLED
|
#if CONFIG_ESP_PHY_ENABLED && SOC_DEEP_SLEEP_SUPPORTED
|
||||||
static esp_deep_sleep_cb_t s_dslp_phy_cb[MAX_DSLP_HOOKS] = {0};
|
static esp_deep_sleep_cb_t s_dslp_phy_cb[MAX_DSLP_HOOKS] = {0};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -247,7 +253,9 @@ void esp_sleep_set_sleep_context(esp_sleep_context_t *sleep_ctx)
|
|||||||
|
|
||||||
static uint32_t s_lightsleep_cnt = 0;
|
static uint32_t s_lightsleep_cnt = 0;
|
||||||
|
|
||||||
|
#if SOC_RTCIO_PIN_COUNT > 0
|
||||||
_Static_assert(22 >= SOC_RTCIO_PIN_COUNT, "Chip has more RTCIOs than 22, should increase ext1_rtc_gpio_mask field size");
|
_Static_assert(22 >= SOC_RTCIO_PIN_COUNT, "Chip has more RTCIOs than 22, should increase ext1_rtc_gpio_mask field size");
|
||||||
|
#endif
|
||||||
|
|
||||||
static sleep_config_t s_config = {
|
static sleep_config_t s_config = {
|
||||||
.domain = {
|
.domain = {
|
||||||
@ -676,7 +684,7 @@ FORCE_INLINE_ATTR void misc_modules_sleep_prepare(uint32_t pd_flags, bool deep_s
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !CONFIG_IDF_TARGET_ESP32P4
|
#if !CONFIG_IDF_TARGET_ESP32P4 && !CONFIG_IDF_TARGET_ESP32C61
|
||||||
// TODO: IDF-7370
|
// TODO: IDF-7370
|
||||||
if (!(deep_sleep && s_adc_tsen_enabled)){
|
if (!(deep_sleep && s_adc_tsen_enabled)){
|
||||||
sar_periph_ctrl_power_disable();
|
sar_periph_ctrl_power_disable();
|
||||||
@ -703,7 +711,9 @@ FORCE_INLINE_ATTR void misc_modules_wake_prepare(uint32_t pd_flags)
|
|||||||
#if SOC_USB_SERIAL_JTAG_SUPPORTED && !SOC_USB_SERIAL_JTAG_SUPPORT_LIGHT_SLEEP
|
#if SOC_USB_SERIAL_JTAG_SUPPORTED && !SOC_USB_SERIAL_JTAG_SUPPORT_LIGHT_SLEEP
|
||||||
sleep_console_usj_pad_restore();
|
sleep_console_usj_pad_restore();
|
||||||
#endif
|
#endif
|
||||||
|
#if !CONFIG_IDF_TARGET_ESP32C61
|
||||||
sar_periph_ctrl_power_enable();
|
sar_periph_ctrl_power_enable();
|
||||||
|
#endif
|
||||||
#if CONFIG_PM_POWER_DOWN_CPU_IN_LIGHT_SLEEP && SOC_PM_CPU_RETENTION_BY_RTCCNTL
|
#if CONFIG_PM_POWER_DOWN_CPU_IN_LIGHT_SLEEP && SOC_PM_CPU_RETENTION_BY_RTCCNTL
|
||||||
sleep_disable_cpu_retention();
|
sleep_disable_cpu_retention();
|
||||||
#endif
|
#endif
|
||||||
@ -789,7 +799,7 @@ static esp_err_t IRAM_ATTR esp_sleep_start(uint32_t pd_flags, esp_sleep_mode_t m
|
|||||||
should_skip_sleep = light_sleep_uart_prepare(pd_flags, sleep_duration);
|
should_skip_sleep = light_sleep_uart_prepare(pd_flags, sleep_duration);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if CONFIG_ESP_PHY_ENABLED
|
#if CONFIG_ESP_PHY_ENABLED && SOC_DEEP_SLEEP_SUPPORTED
|
||||||
// Do deep-sleep PHY related callback, which need to be executed when the PLL clock is exists.
|
// Do deep-sleep PHY related callback, which need to be executed when the PLL clock is exists.
|
||||||
// For light-sleep, PHY state is managed by the upper layer of the wifi/bt protocol stack.
|
// For light-sleep, PHY state is managed by the upper layer of the wifi/bt protocol stack.
|
||||||
if (deep_sleep) {
|
if (deep_sleep) {
|
||||||
@ -1765,7 +1775,7 @@ static void ext0_wakeup_prepare(void)
|
|||||||
|
|
||||||
#endif // SOC_PM_SUPPORT_EXT0_WAKEUP
|
#endif // SOC_PM_SUPPORT_EXT0_WAKEUP
|
||||||
|
|
||||||
#if SOC_PM_SUPPORT_EXT1_WAKEUP
|
#if SOC_PM_SUPPORT_EXT1_WAKEUP && SOC_RTCIO_PIN_COUNT > 0
|
||||||
esp_err_t esp_sleep_enable_ext1_wakeup(uint64_t io_mask, esp_sleep_ext1_wakeup_mode_t level_mode)
|
esp_err_t esp_sleep_enable_ext1_wakeup(uint64_t io_mask, esp_sleep_ext1_wakeup_mode_t level_mode)
|
||||||
{
|
{
|
||||||
if (io_mask == 0 && level_mode > ESP_EXT1_WAKEUP_ANY_HIGH) {
|
if (io_mask == 0 && level_mode > ESP_EXT1_WAKEUP_ANY_HIGH) {
|
||||||
@ -1945,7 +1955,7 @@ uint64_t esp_sleep_get_ext1_wakeup_status(void)
|
|||||||
return gpio_mask;
|
return gpio_mask;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // SOC_PM_SUPPORT_EXT1_WAKEUP
|
#endif // SOC_PM_SUPPORT_EXT1_WAKEUP && SOC_RTCIO_PIN_COUNT > 0
|
||||||
|
|
||||||
#if SOC_GPIO_SUPPORT_DEEPSLEEP_WAKEUP && SOC_DEEP_SLEEP_SUPPORTED
|
#if SOC_GPIO_SUPPORT_DEEPSLEEP_WAKEUP && SOC_DEEP_SLEEP_SUPPORTED
|
||||||
uint64_t esp_sleep_get_gpio_wakeup_status(void)
|
uint64_t esp_sleep_get_gpio_wakeup_status(void)
|
||||||
|
@ -63,14 +63,12 @@ static const char* TAG = "phy_init";
|
|||||||
static _lock_t s_phy_access_lock;
|
static _lock_t s_phy_access_lock;
|
||||||
|
|
||||||
#if SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
#if SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
||||||
#if !SOC_PMU_SUPPORTED
|
#if SOC_PM_MODEM_PD_BY_SW // TODO: [ESP32C5] IDF-8667
|
||||||
#if !(CONFIG_IDF_TARGET_ESP32C5 || CONFIG_IDF_TARGET_ESP32C61) // TODO: [ESP32C5] IDF-8667
|
|
||||||
static DRAM_ATTR struct {
|
static DRAM_ATTR struct {
|
||||||
int count; /* power on count of wifi and bt power domain */
|
int count; /* power on count of wifi and bt power domain */
|
||||||
_lock_t lock;
|
_lock_t lock;
|
||||||
} s_wifi_bt_pd_controller = { .count = 0 };
|
} s_wifi_bt_pd_controller = { .count = 0 };
|
||||||
#endif
|
#endif // SOC_PM_MODEM_PD_BY_SW
|
||||||
#endif // !SOC_PMU_SUPPORTED
|
|
||||||
#endif // SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
#endif // SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
||||||
|
|
||||||
#if CONFIG_IDF_TARGET_ESP32
|
#if CONFIG_IDF_TARGET_ESP32
|
||||||
@ -339,8 +337,7 @@ void esp_phy_disable(esp_phy_modem_t modem)
|
|||||||
void IRAM_ATTR esp_wifi_bt_power_domain_on(void)
|
void IRAM_ATTR esp_wifi_bt_power_domain_on(void)
|
||||||
{
|
{
|
||||||
#if SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
#if SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
||||||
#if !SOC_PMU_SUPPORTED
|
#if SOC_PM_MODEM_PD_BY_SW // TODO: [ESP32C5] IDF-8667
|
||||||
#if !(CONFIG_IDF_TARGET_ESP32C5 || CONFIG_IDF_TARGET_ESP32C61) // TODO: [ESP32C5] IDF-8667
|
|
||||||
_lock_acquire(&s_wifi_bt_pd_controller.lock);
|
_lock_acquire(&s_wifi_bt_pd_controller.lock);
|
||||||
if (s_wifi_bt_pd_controller.count++ == 0) {
|
if (s_wifi_bt_pd_controller.count++ == 0) {
|
||||||
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_WIFI_FORCE_PD);
|
CLEAR_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_WIFI_FORCE_PD);
|
||||||
@ -358,24 +355,21 @@ void IRAM_ATTR esp_wifi_bt_power_domain_on(void)
|
|||||||
wifi_bt_common_module_disable();
|
wifi_bt_common_module_disable();
|
||||||
}
|
}
|
||||||
_lock_release(&s_wifi_bt_pd_controller.lock);
|
_lock_release(&s_wifi_bt_pd_controller.lock);
|
||||||
#endif
|
#endif // SOC_PM_MODEM_PD_BY_SW
|
||||||
#endif // !SOC_PMU_SUPPORTED
|
|
||||||
#endif // SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
#endif // SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
||||||
}
|
}
|
||||||
|
|
||||||
void esp_wifi_bt_power_domain_off(void)
|
void esp_wifi_bt_power_domain_off(void)
|
||||||
{
|
{
|
||||||
#if SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
#if SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
||||||
#if !SOC_PMU_SUPPORTED
|
#if SOC_PM_MODEM_PD_BY_SW // TODO: [ESP32C5] IDF-8667
|
||||||
#if !(CONFIG_IDF_TARGET_ESP32C5 || CONFIG_IDF_TARGET_ESP32C61) // TODO: [ESP32C5] IDF-8667
|
|
||||||
_lock_acquire(&s_wifi_bt_pd_controller.lock);
|
_lock_acquire(&s_wifi_bt_pd_controller.lock);
|
||||||
if (--s_wifi_bt_pd_controller.count == 0) {
|
if (--s_wifi_bt_pd_controller.count == 0) {
|
||||||
SET_PERI_REG_MASK(RTC_CNTL_DIG_ISO_REG, RTC_CNTL_WIFI_FORCE_ISO);
|
SET_PERI_REG_MASK(RTC_CNTL_DIG_ISO_REG, RTC_CNTL_WIFI_FORCE_ISO);
|
||||||
SET_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_WIFI_FORCE_PD);
|
SET_PERI_REG_MASK(RTC_CNTL_DIG_PWC_REG, RTC_CNTL_WIFI_FORCE_PD);
|
||||||
}
|
}
|
||||||
_lock_release(&s_wifi_bt_pd_controller.lock);
|
_lock_release(&s_wifi_bt_pd_controller.lock);
|
||||||
#endif
|
#endif // SOC_PM_MODEM_PD_BY_SW
|
||||||
#endif // !SOC_PMU_SUPPORTED
|
|
||||||
#endif // SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
#endif // SOC_PM_SUPPORT_MODEM_PD || SOC_PM_SUPPORT_WIFI_PD
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -36,7 +36,7 @@ entries:
|
|||||||
sleep_system_peripheral:peripheral_domain_pd_allowed (noflash)
|
sleep_system_peripheral:peripheral_domain_pd_allowed (noflash)
|
||||||
sleep_modem:modem_domain_pd_allowed (noflash)
|
sleep_modem:modem_domain_pd_allowed (noflash)
|
||||||
sleep_modem:periph_inform_out_light_sleep_overhead (noflash)
|
sleep_modem:periph_inform_out_light_sleep_overhead (noflash)
|
||||||
if IDF_TARGET_ESP32P4 = n: # TODO: IDF-6496
|
if IDF_TARGET_ESP32P4 = n && IDF_TARGET_ESP32C61 = n : # TODO: IDF-6496, IDF-9304
|
||||||
sar_periph_ctrl:sar_periph_ctrl_power_disable (noflash)
|
sar_periph_ctrl:sar_periph_ctrl_power_disable (noflash)
|
||||||
|
|
||||||
[mapping:esp_system_pm]
|
[mapping:esp_system_pm]
|
||||||
|
@ -64,8 +64,8 @@ extern "C" {
|
|||||||
#define RTC_ENTRY_ADDR_REG LP_AON_STORE6_REG
|
#define RTC_ENTRY_ADDR_REG LP_AON_STORE6_REG
|
||||||
#define RTC_RESET_CAUSE_REG LP_AON_STORE6_REG
|
#define RTC_RESET_CAUSE_REG LP_AON_STORE6_REG
|
||||||
#define RTC_MEMORY_CRC_REG LP_AON_STORE7_REG
|
#define RTC_MEMORY_CRC_REG LP_AON_STORE7_REG
|
||||||
#define LIGHT_SLEEP_WAKE_STUB_ADDR_REG LP_AON_STORE8_REG
|
#define RTC_SLEEP_WAKE_STUB_ADDR_REG LP_AON_STORE8_REG
|
||||||
#define SLEEP_MODE_REG LP_AON_STORE9_REG
|
#define RTC_SLEEP_MODE_REG LP_AON_STORE8_REG
|
||||||
|
|
||||||
#define RTC_DISABLE_ROM_LOG ((1 << 0) | (1 << 16)) //!< Disable logging from the ROM code.
|
#define RTC_DISABLE_ROM_LOG ((1 << 0) | (1 << 16)) //!< Disable logging from the ROM code.
|
||||||
|
|
||||||
|
@ -858,7 +858,7 @@ TEST_CASE("Test a latency between a call of callback and real event", "[esp_time
|
|||||||
vTaskDelay(10 / portTICK_PERIOD_MS);
|
vTaskDelay(10 / portTICK_PERIOD_MS);
|
||||||
}
|
}
|
||||||
int diff = callback_time - expected_time;
|
int diff = callback_time - expected_time;
|
||||||
printf("%d us\n", diff);
|
esp_rom_printf(DRAM_STR("%d us\n"), diff);
|
||||||
#ifndef CONFIG_IDF_ENV_FPGA
|
#ifndef CONFIG_IDF_ENV_FPGA
|
||||||
if (i != 0) {
|
if (i != 0) {
|
||||||
// skip the first measurement
|
// skip the first measurement
|
||||||
|
@ -18,6 +18,15 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
EFUSE_CONTROLLER_STATE_RESET = 0, ///< efuse_controllerid is on reset state.
|
||||||
|
EFUSE_CONTROLLER_STATE_IDLE = 1, ///< efuse_controllerid is on idle state.
|
||||||
|
EFUSE_CONTROLLER_STATE_READ_INIT = 2, ///< efuse_controllerid is on read init state.
|
||||||
|
EFUSE_CONTROLLER_STATE_READ_BLK0 = 3, ///< efuse_controllerid is on reading block0 state.
|
||||||
|
EFUSE_CONTROLLER_STATE_BLK0_CRC_CHECK = 4, ///< efuse_controllerid is on checking block0 crc state.
|
||||||
|
EFUSE_CONTROLLER_STATE_READ_RS_BLK = 5, ///< efuse_controllerid is on reading RS block state.
|
||||||
|
} efuse_controller_state_t;
|
||||||
|
|
||||||
// Always inline these functions even no gcc optimization is applied.
|
// Always inline these functions even no gcc optimization is applied.
|
||||||
|
|
||||||
/******************* eFuse fields *************************/
|
/******************* eFuse fields *************************/
|
||||||
@ -153,6 +162,10 @@ __attribute__((always_inline)) static inline void efuse_ll_rs_bypass_update(void
|
|||||||
}
|
}
|
||||||
|
|
||||||
/******************* eFuse control functions *************************/
|
/******************* eFuse control functions *************************/
|
||||||
|
__attribute__((always_inline)) static inline uint32_t efuse_ll_get_controller_state(void)
|
||||||
|
{
|
||||||
|
return EFUSE0.status.state;
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
17
components/hal/esp32c61/include/hal/lp_aon_hal.h
Normal file
17
components/hal/esp32c61/include/hal/lp_aon_hal.h
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2020-2024 Espressif Systems (Shanghai) CO LTD
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "hal/lp_aon_ll.h"
|
||||||
|
|
||||||
|
#define rtc_hal_ext1_get_wakeup_status() lp_aon_ll_ext1_get_wakeup_status()
|
||||||
|
#define rtc_hal_ext1_clear_wakeup_status() lp_aon_ll_ext1_clear_wakeup_status()
|
||||||
|
#define rtc_hal_ext1_set_wakeup_pins(io_mask, mode_mask) lp_aon_ll_ext1_set_wakeup_pins(io_mask, mode_mask)
|
||||||
|
#define rtc_hal_ext1_clear_wakeup_pins() lp_aon_ll_ext1_clear_wakeup_pins()
|
||||||
|
#define rtc_hal_ext1_get_wakeup_pins() lp_aon_ll_ext1_get_wakeup_pins()
|
||||||
|
|
||||||
|
#define lp_aon_hal_inform_wakeup_type(dslp) lp_aon_ll_inform_wakeup_type(dslp)
|
114
components/hal/esp32c61/include/hal/lp_aon_ll.h
Normal file
114
components/hal/esp32c61/include/hal/lp_aon_ll.h
Normal file
@ -0,0 +1,114 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
// The LL layer for ESP32-C61 LP_AON register operations
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include "soc/soc.h"
|
||||||
|
#include "soc/lp_aon_struct.h"
|
||||||
|
#include "hal/misc.h"
|
||||||
|
#include "esp32c61/rom/rtc.h"
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get ext1 wakeup source status
|
||||||
|
* @return The lower 8 bits of the returned value are the bitmap of
|
||||||
|
* the wakeup source status, bit 0~7 corresponds to LP_IO 0~7
|
||||||
|
*/
|
||||||
|
static inline uint32_t lp_aon_ll_ext1_get_wakeup_status(void)
|
||||||
|
{
|
||||||
|
return HAL_FORCE_READ_U32_REG_FIELD(LP_AON.ext_wakeup_cntl, ext_wakeup_status);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Clear the ext1 wakeup source status
|
||||||
|
*/
|
||||||
|
static inline void lp_aon_ll_ext1_clear_wakeup_status(void)
|
||||||
|
{
|
||||||
|
HAL_FORCE_MODIFY_U32_REG_FIELD(LP_AON.ext_wakeup_cntl, ext_wakeup_status_clr, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Set the wake-up LP_IO of the ext1 wake-up source
|
||||||
|
* @param io_mask wakeup LP_IO bitmap, bit 0~7 corresponds to LP_IO 0~7
|
||||||
|
* @param level_mask LP_IO wakeup level bitmap, bit 0~7 corresponds to LP_IO 0~7 wakeup level
|
||||||
|
* each bit's corresponding position is set to 0, the wakeup level will be low
|
||||||
|
* on the contrary, each bit's corresponding position is set to 1, the wakeup
|
||||||
|
* level will be high
|
||||||
|
*/
|
||||||
|
static inline void lp_aon_ll_ext1_set_wakeup_pins(uint32_t io_mask, uint32_t level_mask)
|
||||||
|
{
|
||||||
|
uint32_t wakeup_sel_mask = HAL_FORCE_READ_U32_REG_FIELD(LP_AON.ext_wakeup_cntl, ext_wakeup_sel);
|
||||||
|
wakeup_sel_mask |= io_mask;
|
||||||
|
HAL_FORCE_MODIFY_U32_REG_FIELD(LP_AON.ext_wakeup_cntl, ext_wakeup_sel, wakeup_sel_mask);
|
||||||
|
|
||||||
|
uint32_t wakeup_level_mask = HAL_FORCE_READ_U32_REG_FIELD(LP_AON.ext_wakeup_cntl, ext_wakeup_lv);
|
||||||
|
wakeup_level_mask |= io_mask & level_mask;
|
||||||
|
wakeup_level_mask &= ~(io_mask & ~level_mask);
|
||||||
|
|
||||||
|
HAL_FORCE_MODIFY_U32_REG_FIELD(LP_AON.ext_wakeup_cntl, ext_wakeup_lv, wakeup_level_mask);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Clear all ext1 wakup-source setting
|
||||||
|
*/
|
||||||
|
static inline void lp_aon_ll_ext1_clear_wakeup_pins(void)
|
||||||
|
{
|
||||||
|
HAL_FORCE_MODIFY_U32_REG_FIELD(LP_AON.ext_wakeup_cntl, ext_wakeup_sel, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get ext1 wakeup source setting
|
||||||
|
* @return The lower 8 bits of the returned value are the bitmap of
|
||||||
|
* the wakeup source status, bit 0~7 corresponds to LP_IO 0~7
|
||||||
|
*/
|
||||||
|
static inline uint32_t lp_aon_ll_ext1_get_wakeup_pins(void)
|
||||||
|
{
|
||||||
|
return HAL_FORCE_READ_U32_REG_FIELD(LP_AON.ext_wakeup_cntl, ext_wakeup_sel);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief ROM obtains the wake-up type through LP_AON_STORE9_REG[0].
|
||||||
|
* Set the flag to inform
|
||||||
|
* @param true: deepsleep false: lightsleep
|
||||||
|
*/
|
||||||
|
static inline void lp_aon_ll_inform_wakeup_type(bool dslp)
|
||||||
|
{
|
||||||
|
if (dslp) {
|
||||||
|
REG_SET_BIT(RTC_SLEEP_MODE_REG, BIT(0)); /* Tell rom to run deep sleep wake stub */
|
||||||
|
|
||||||
|
} else {
|
||||||
|
REG_CLR_BIT(RTC_SLEEP_MODE_REG, BIT(0)); /* Tell rom to run light sleep wake stub */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Get the flag that marks whether LP CPU is awakened by ETM
|
||||||
|
*
|
||||||
|
* @return Return true if lpcore is woken up by soc_etm
|
||||||
|
*/
|
||||||
|
static inline bool lp_aon_ll_get_lpcore_etm_wakeup_flag(void)
|
||||||
|
{
|
||||||
|
return REG_GET_BIT(LP_AON_LPCORE_REG, LP_AON_LPCORE_ETM_WAKEUP_FLAG);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Clear the flag that marks whether LP CPU is awakened by soc_etm
|
||||||
|
*/
|
||||||
|
static inline void lp_aon_ll_clear_lpcore_etm_wakeup_flag(void)
|
||||||
|
{
|
||||||
|
REG_SET_BIT(LP_AON_LPCORE_REG, LP_AON_LPCORE_ETM_WAKEUP_FLAG_CLR);
|
||||||
|
}
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
78
components/hal/esp32c61/include/hal/lp_timer_ll.h
Normal file
78
components/hal/esp32c61/include/hal/lp_timer_ll.h
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
/*
|
||||||
|
* SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
// The LL layer for ESP32-C61 LP_Timer register operations
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include "soc/soc.h"
|
||||||
|
#include "soc/lp_timer_struct.h"
|
||||||
|
#include "soc/lp_timer_reg.h"
|
||||||
|
#include "soc/lp_aon_reg.h"
|
||||||
|
#include "hal/lp_timer_types.h"
|
||||||
|
#include "hal/misc.h"
|
||||||
|
#include "esp_attr.h"
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR void lp_timer_ll_set_alarm_target(lp_timer_dev_t *dev, uint8_t timer_id, uint64_t value)
|
||||||
|
{
|
||||||
|
HAL_FORCE_MODIFY_U32_REG_FIELD(dev->target[timer_id].hi, main_timer_tar_high0, (value >> 32) & 0xFFFF);
|
||||||
|
HAL_FORCE_MODIFY_U32_REG_FIELD(dev->target[timer_id].lo, main_timer_tar_low0, value & 0xFFFFFFFF);
|
||||||
|
}
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR void lp_timer_ll_set_target_enable(lp_timer_dev_t *dev, uint8_t timer_id, bool en)
|
||||||
|
{
|
||||||
|
dev->target[timer_id].hi.main_timer_tar_en0 = en;
|
||||||
|
}
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR uint32_t lp_timer_ll_get_counter_value_low(lp_timer_dev_t *dev, uint8_t buffer_id)
|
||||||
|
{
|
||||||
|
return HAL_FORCE_READ_U32_REG_FIELD(dev->counter[buffer_id].lo, main_timer_buf0_low);
|
||||||
|
}
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR uint32_t lp_timer_ll_get_counter_value_high(lp_timer_dev_t *dev, uint8_t buffer_id)
|
||||||
|
{
|
||||||
|
return HAL_FORCE_READ_U32_REG_FIELD(dev->counter[buffer_id].hi, main_timer_buf0_high);
|
||||||
|
}
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR void lp_timer_ll_counter_snapshot(lp_timer_dev_t *dev)
|
||||||
|
{
|
||||||
|
dev->update.main_timer_update = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR void lp_timer_ll_clear_alarm_intr_status(lp_timer_dev_t *dev)
|
||||||
|
{
|
||||||
|
dev->int_clr.soc_wakeup_int_clr = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR void lp_timer_ll_clear_overflow_intr_status(lp_timer_dev_t *dev)
|
||||||
|
{
|
||||||
|
dev->int_clr.overflow_clr = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR void lp_timer_ll_clear_lp_alarm_intr_status(lp_timer_dev_t *dev)
|
||||||
|
{
|
||||||
|
dev->lp_int_clr.main_timer_lp_int_clr = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR uint32_t lp_timer_ll_get_lp_intr_raw(lp_timer_dev_t *dev)
|
||||||
|
{
|
||||||
|
return dev->lp_int_raw.val;
|
||||||
|
}
|
||||||
|
|
||||||
|
FORCE_INLINE_ATTR void lp_timer_ll_clear_lp_intsts_mask(lp_timer_dev_t *dev, uint32_t mask)
|
||||||
|
{
|
||||||
|
dev->lp_int_clr.val = mask;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
@ -16,8 +16,6 @@ extern "C" {
|
|||||||
#include "hal/pmu_ll.h"
|
#include "hal/pmu_ll.h"
|
||||||
#include "hal/pmu_types.h"
|
#include "hal/pmu_types.h"
|
||||||
|
|
||||||
// TODO: [ESP32C61] IDF-9250, inherit from c6
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
pmu_dev_t *dev;
|
pmu_dev_t *dev;
|
||||||
} pmu_hal_context_t;
|
} pmu_hal_context_t;
|
||||||
@ -30,6 +28,10 @@ void pmu_hal_lp_set_digital_power_up_wait_cycle(pmu_hal_context_t *hal, uint32_t
|
|||||||
|
|
||||||
uint32_t pmu_hal_lp_get_digital_power_up_wait_cycle(pmu_hal_context_t *hal);
|
uint32_t pmu_hal_lp_get_digital_power_up_wait_cycle(pmu_hal_context_t *hal);
|
||||||
|
|
||||||
|
void pmu_hal_hp_set_control_ready_wait_cycle(pmu_hal_context_t *hal, uint32_t isolate_wait_cycle, uint32_t reset_wait_cycle);
|
||||||
|
|
||||||
|
void pmu_hal_lp_set_control_ready_wait_cycle(pmu_hal_context_t *hal, uint32_t isolate_wait_cycle, uint32_t reset_wait_cycle);
|
||||||
|
|
||||||
void pmu_hal_hp_set_sleep_active_backup_enable(pmu_hal_context_t *hal);
|
void pmu_hal_hp_set_sleep_active_backup_enable(pmu_hal_context_t *hal);
|
||||||
|
|
||||||
void pmu_hal_hp_set_sleep_active_backup_disable(pmu_hal_context_t *hal);
|
void pmu_hal_hp_set_sleep_active_backup_disable(pmu_hal_context_t *hal);
|
||||||
|
@ -17,8 +17,6 @@
|
|||||||
#include "hal/pmu_types.h"
|
#include "hal/pmu_types.h"
|
||||||
#include "hal/misc.h"
|
#include "hal/misc.h"
|
||||||
|
|
||||||
// TODO: [ESP32C61] IDF-9250
|
|
||||||
#pragma message "pmu_ll.h has not been fully updated on ESP32C61 (IDF-9250). Use with care!"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
@ -682,6 +680,9 @@ FORCE_INLINE_ATTR uint32_t pmu_ll_hp_get_analog_wait_target_cycle(pmu_dev_t *hw)
|
|||||||
|
|
||||||
FORCE_INLINE_ATTR void pmu_ll_hp_set_digital_power_supply_wait_cycle(pmu_dev_t *hw, uint32_t cycle)
|
FORCE_INLINE_ATTR void pmu_ll_hp_set_digital_power_supply_wait_cycle(pmu_dev_t *hw, uint32_t cycle)
|
||||||
{
|
{
|
||||||
|
if (cycle > 0x1FF) {
|
||||||
|
cycle = 0x1FF;
|
||||||
|
}
|
||||||
hw->power.wait_timer0.wait_timer = cycle;
|
hw->power.wait_timer0.wait_timer = cycle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,6 +37,18 @@ uint32_t pmu_hal_lp_get_digital_power_up_wait_cycle(pmu_hal_context_t *hal)
|
|||||||
return power_supply_wait_cycle + power_up_wait_cycle;
|
return power_supply_wait_cycle + power_up_wait_cycle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void pmu_hal_hp_set_control_ready_wait_cycle(pmu_hal_context_t *hal, uint32_t isolate_wait_cycle, uint32_t reset_wait_cycle)
|
||||||
|
{
|
||||||
|
pmu_ll_hp_set_isolate_wait_cycle(hal->dev, isolate_wait_cycle);
|
||||||
|
pmu_ll_hp_set_reset_wait_cycle(hal->dev, reset_wait_cycle);
|
||||||
|
}
|
||||||
|
|
||||||
|
void pmu_hal_lp_set_control_ready_wait_cycle(pmu_hal_context_t *hal, uint32_t isolate_wait_cycle, uint32_t reset_wait_cycle)
|
||||||
|
{
|
||||||
|
pmu_ll_lp_set_isolate_wait_cycle(hal->dev, isolate_wait_cycle);
|
||||||
|
pmu_ll_lp_set_reset_wait_cycle(hal->dev, reset_wait_cycle);
|
||||||
|
}
|
||||||
|
|
||||||
void pmu_hal_hp_set_sleep_active_backup_enable(pmu_hal_context_t *hal)
|
void pmu_hal_hp_set_sleep_active_backup_enable(pmu_hal_context_t *hal)
|
||||||
{
|
{
|
||||||
pmu_ll_hp_set_active_to_sleep_backup_enable(hal->dev);
|
pmu_ll_hp_set_active_to_sleep_backup_enable(hal->dev);
|
||||||
|
@ -871,6 +871,10 @@ config SOC_CONFIGURABLE_VDDSDIO_SUPPORTED
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_PM_MODEM_PD_BY_SW
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_CLK_APLL_SUPPORTED
|
config SOC_CLK_APLL_SUPPORTED
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
@ -415,7 +415,7 @@
|
|||||||
#define SOC_PM_SUPPORT_MODEM_PD (1) /*!<Modem here includes wifi and btdm */
|
#define SOC_PM_SUPPORT_MODEM_PD (1) /*!<Modem here includes wifi and btdm */
|
||||||
|
|
||||||
#define SOC_CONFIGURABLE_VDDSDIO_SUPPORTED (1)
|
#define SOC_CONFIGURABLE_VDDSDIO_SUPPORTED (1)
|
||||||
|
#define SOC_PM_MODEM_PD_BY_SW (1)
|
||||||
/*-------------------------- CLOCK SUBSYSTEM CAPS ----------------------------------------*/
|
/*-------------------------- CLOCK SUBSYSTEM CAPS ----------------------------------------*/
|
||||||
#define SOC_CLK_APLL_SUPPORTED (1)
|
#define SOC_CLK_APLL_SUPPORTED (1)
|
||||||
|
|
||||||
|
@ -1051,6 +1051,10 @@ config SOC_PM_MODEM_RETENTION_BY_BACKUPDMA
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_PM_MODEM_PD_BY_SW
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_CLK_RC_FAST_D256_SUPPORTED
|
config SOC_CLK_RC_FAST_D256_SUPPORTED
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
@ -440,6 +440,7 @@
|
|||||||
|
|
||||||
#define SOC_PM_CPU_RETENTION_BY_RTCCNTL (1)
|
#define SOC_PM_CPU_RETENTION_BY_RTCCNTL (1)
|
||||||
#define SOC_PM_MODEM_RETENTION_BY_BACKUPDMA (1)
|
#define SOC_PM_MODEM_RETENTION_BY_BACKUPDMA (1)
|
||||||
|
#define SOC_PM_MODEM_PD_BY_SW (1)
|
||||||
|
|
||||||
/*--------------------------- CLOCK SUBSYSTEM CAPS -------------------------- */
|
/*--------------------------- CLOCK SUBSYSTEM CAPS -------------------------- */
|
||||||
#define SOC_CLK_RC_FAST_D256_SUPPORTED (1)
|
#define SOC_CLK_RC_FAST_D256_SUPPORTED (1)
|
||||||
|
@ -91,6 +91,10 @@ config SOC_PMU_SUPPORTED
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_LP_TIMER_SUPPORTED
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_CLK_TREE_SUPPORTED
|
config SOC_CLK_TREE_SUPPORTED
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
@ -107,6 +111,14 @@ config SOC_REG_I2C_SUPPORTED
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_LIGHT_SLEEP_SUPPORTED
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
|
config SOC_PM_SUPPORTED
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_ECDSA_SUPPORTED
|
config SOC_ECDSA_SUPPORTED
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
@ -531,6 +543,10 @@ config SOC_MEMSPI_SRC_FREQ_20M_SUPPORTED
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_MEMSPI_FLASH_CLK_SRC_IS_INDEPENDENT
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_SYSTIMER_COUNTER_NUM
|
config SOC_SYSTIMER_COUNTER_NUM
|
||||||
int
|
int
|
||||||
default 2
|
default 2
|
||||||
@ -715,23 +731,7 @@ config SOC_WIFI_LIGHT_SLEEP_CLK_WIDTH
|
|||||||
int
|
int
|
||||||
default 12
|
default 12
|
||||||
|
|
||||||
config SOC_PM_SUPPORT_WIFI_WAKEUP
|
config SOC_PM_SUPPORT_CPU_PD
|
||||||
bool
|
|
||||||
default y
|
|
||||||
|
|
||||||
config SOC_PM_SUPPORT_BEACON_WAKEUP
|
|
||||||
bool
|
|
||||||
default y
|
|
||||||
|
|
||||||
config SOC_PM_SUPPORT_BT_WAKEUP
|
|
||||||
bool
|
|
||||||
default y
|
|
||||||
|
|
||||||
config SOC_PM_SUPPORT_EXT1_WAKEUP
|
|
||||||
bool
|
|
||||||
default y
|
|
||||||
|
|
||||||
config SOC_PM_SUPPORT_EXT1_WAKEUP_MODE_PER_PIN
|
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
@ -743,6 +743,10 @@ config SOC_PM_SUPPORT_XTAL32K_PD
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_PM_SUPPORT_RC32K_PD
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_PM_SUPPORT_RC_FAST_PD
|
config SOC_PM_SUPPORT_RC_FAST_PD
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
@ -767,7 +771,7 @@ config SOC_PM_SUPPORT_PMU_MODEM_STATE
|
|||||||
bool
|
bool
|
||||||
default n
|
default n
|
||||||
|
|
||||||
config SOC_PM_SUPPORT_DEEPSLEEP_CHECK_STUB_ONLY
|
config SOC_PM_CPU_RETENTION_BY_SW
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
@ -775,10 +779,6 @@ config SOC_PM_MODEM_RETENTION_BY_REGDMA
|
|||||||
bool
|
bool
|
||||||
default n
|
default n
|
||||||
|
|
||||||
config SOC_PM_RETENTION_HAS_CLOCK_BUG
|
|
||||||
bool
|
|
||||||
default y
|
|
||||||
|
|
||||||
config SOC_EXT_MEM_CACHE_TAG_IN_CPU_DOMAIN
|
config SOC_EXT_MEM_CACHE_TAG_IN_CPU_DOMAIN
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
@ -807,6 +807,10 @@ config SOC_CLK_LP_FAST_SUPPORT_XTAL
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_CLK_RC32K_NOT_TO_USE
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_RCC_IS_INDEPENDENT
|
config SOC_RCC_IS_INDEPENDENT
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
@ -11,7 +11,7 @@ extern "C" {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/** Group: configure_register */
|
/** Group: configure_register */
|
||||||
/** Type of tar0_low register
|
/** Type of tar_low register
|
||||||
* RTC timer threshold low bits register0
|
* RTC timer threshold low bits register0
|
||||||
*/
|
*/
|
||||||
typedef union {
|
typedef union {
|
||||||
@ -22,9 +22,9 @@ typedef union {
|
|||||||
uint32_t main_timer_tar_low0:32;
|
uint32_t main_timer_tar_low0:32;
|
||||||
};
|
};
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
} lp_timer_tar0_low_reg_t;
|
} lp_timer_tar_low_reg_t;
|
||||||
|
|
||||||
/** Type of tar0_high register
|
/** Type of tar_high register
|
||||||
* RTC timer enable register0
|
* RTC timer enable register0
|
||||||
*/
|
*/
|
||||||
typedef union {
|
typedef union {
|
||||||
@ -40,38 +40,7 @@ typedef union {
|
|||||||
uint32_t main_timer_tar_en0:1;
|
uint32_t main_timer_tar_en0:1;
|
||||||
};
|
};
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
} lp_timer_tar0_high_reg_t;
|
} lp_timer_tar_high_reg_t;
|
||||||
|
|
||||||
/** Type of tar1_low register
|
|
||||||
* RTC timer threshold low bits register1
|
|
||||||
*/
|
|
||||||
typedef union {
|
|
||||||
struct {
|
|
||||||
/** main_timer_tar_low1 : R/W; bitpos: [31:0]; default: 0;
|
|
||||||
* Configures the lower 32 bits of the trigger threshold for the RTC timer compare1.
|
|
||||||
*/
|
|
||||||
uint32_t main_timer_tar_low1:32;
|
|
||||||
};
|
|
||||||
uint32_t val;
|
|
||||||
} lp_timer_tar1_low_reg_t;
|
|
||||||
|
|
||||||
/** Type of tar1_high register
|
|
||||||
* RTC timer threshold high bits register0
|
|
||||||
*/
|
|
||||||
typedef union {
|
|
||||||
struct {
|
|
||||||
/** main_timer_tar_high1 : R/W; bitpos: [15:0]; default: 0;
|
|
||||||
* Configures the higher 16 bits of the trigger threshold for the RTC timer compare1
|
|
||||||
*/
|
|
||||||
uint32_t main_timer_tar_high1:16;
|
|
||||||
uint32_t reserved_16:15;
|
|
||||||
/** main_timer_tar_en1 : WT; bitpos: [31]; default: 0;
|
|
||||||
* Configure this bit to enable the timer compare1 alarm.\\0: Disable \\1: Enable
|
|
||||||
*/
|
|
||||||
uint32_t main_timer_tar_en1:1;
|
|
||||||
};
|
|
||||||
uint32_t val;
|
|
||||||
} lp_timer_tar1_high_reg_t;
|
|
||||||
|
|
||||||
/** Type of update register
|
/** Type of update register
|
||||||
* RTC timer update control register
|
* RTC timer update control register
|
||||||
@ -106,7 +75,7 @@ typedef union {
|
|||||||
uint32_t val;
|
uint32_t val;
|
||||||
} lp_timer_update_reg_t;
|
} lp_timer_update_reg_t;
|
||||||
|
|
||||||
/** Type of main_buf0_low register
|
/** Type of main_buf_low register
|
||||||
* RTC timer buffer0 low bits register
|
* RTC timer buffer0 low bits register
|
||||||
*/
|
*/
|
||||||
typedef union {
|
typedef union {
|
||||||
@ -117,9 +86,9 @@ typedef union {
|
|||||||
uint32_t main_timer_buf0_low:32;
|
uint32_t main_timer_buf0_low:32;
|
||||||
};
|
};
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
} lp_timer_main_buf0_low_reg_t;
|
} lp_timer_main_buf_low_reg_t;
|
||||||
|
|
||||||
/** Type of main_buf0_high register
|
/** Type of main_buf_high register
|
||||||
* RTC timer buffer0 high bits register
|
* RTC timer buffer0 high bits register
|
||||||
*/
|
*/
|
||||||
typedef union {
|
typedef union {
|
||||||
@ -131,34 +100,7 @@ typedef union {
|
|||||||
uint32_t reserved_16:16;
|
uint32_t reserved_16:16;
|
||||||
};
|
};
|
||||||
uint32_t val;
|
uint32_t val;
|
||||||
} lp_timer_main_buf0_high_reg_t;
|
} lp_timer_main_buf_high_reg_t;
|
||||||
|
|
||||||
/** Type of main_buf1_low register
|
|
||||||
* RTC timer buffer1 low bits register
|
|
||||||
*/
|
|
||||||
typedef union {
|
|
||||||
struct {
|
|
||||||
/** main_timer_buf1_low : RO; bitpos: [31:0]; default: 0;
|
|
||||||
* RTC timer buffer1 low bits register
|
|
||||||
*/
|
|
||||||
uint32_t main_timer_buf1_low:32;
|
|
||||||
};
|
|
||||||
uint32_t val;
|
|
||||||
} lp_timer_main_buf1_low_reg_t;
|
|
||||||
|
|
||||||
/** Type of main_buf1_high register
|
|
||||||
* RTC timer buffer1 high bits register
|
|
||||||
*/
|
|
||||||
typedef union {
|
|
||||||
struct {
|
|
||||||
/** main_timer_buf1_high : RO; bitpos: [15:0]; default: 0;
|
|
||||||
* RTC timer buffer1 high bits register
|
|
||||||
*/
|
|
||||||
uint32_t main_timer_buf1_high:16;
|
|
||||||
uint32_t reserved_16:16;
|
|
||||||
};
|
|
||||||
uint32_t val;
|
|
||||||
} lp_timer_main_buf1_high_reg_t;
|
|
||||||
|
|
||||||
/** Type of main_overflow register */
|
/** Type of main_overflow register */
|
||||||
typedef union {
|
typedef union {
|
||||||
@ -331,17 +273,20 @@ typedef union {
|
|||||||
uint32_t val;
|
uint32_t val;
|
||||||
} lp_timer_date_reg_t;
|
} lp_timer_date_reg_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
volatile lp_timer_tar_low_reg_t lo;
|
||||||
|
volatile lp_timer_tar_high_reg_t hi;
|
||||||
|
} lp_timer_target_reg_t;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
volatile lp_timer_tar0_low_reg_t tar0_low;
|
volatile lp_timer_main_buf_low_reg_t lo;
|
||||||
volatile lp_timer_tar0_high_reg_t tar0_high;
|
volatile lp_timer_main_buf_high_reg_t hi;
|
||||||
volatile lp_timer_tar1_low_reg_t tar1_low;
|
} lp_timer_counter_reg_t;
|
||||||
volatile lp_timer_tar1_high_reg_t tar1_high;
|
|
||||||
|
typedef struct {
|
||||||
|
volatile lp_timer_target_reg_t target[2];
|
||||||
volatile lp_timer_update_reg_t update;
|
volatile lp_timer_update_reg_t update;
|
||||||
volatile lp_timer_main_buf0_low_reg_t main_buf0_low;
|
volatile lp_timer_counter_reg_t counter[2];
|
||||||
volatile lp_timer_main_buf0_high_reg_t main_buf0_high;
|
|
||||||
volatile lp_timer_main_buf1_low_reg_t main_buf1_low;
|
|
||||||
volatile lp_timer_main_buf1_high_reg_t main_buf1_high;
|
|
||||||
volatile lp_timer_main_overflow_reg_t main_overflow;
|
volatile lp_timer_main_overflow_reg_t main_overflow;
|
||||||
volatile lp_timer_int_raw_reg_t int_raw;
|
volatile lp_timer_int_raw_reg_t int_raw;
|
||||||
volatile lp_timer_int_st_reg_t int_st;
|
volatile lp_timer_int_st_reg_t int_st;
|
||||||
|
@ -60,3 +60,4 @@
|
|||||||
#define DR_REG_ASSIST_DEBUG_BASE 0x600C2000
|
#define DR_REG_ASSIST_DEBUG_BASE 0x600C2000
|
||||||
#define DR_REG_INTPRI_BASE 0x600C5000
|
#define DR_REG_INTPRI_BASE 0x600C5000
|
||||||
#define DR_REG_CACHE_BASE 0x600C8000
|
#define DR_REG_CACHE_BASE 0x600C8000
|
||||||
|
#define DR_REG_CLINT_M_BASE 0x20000000
|
||||||
|
@ -46,8 +46,8 @@
|
|||||||
#define SOC_SECURE_BOOT_SUPPORTED 1
|
#define SOC_SECURE_BOOT_SUPPORTED 1
|
||||||
#define SOC_BOD_SUPPORTED 1
|
#define SOC_BOD_SUPPORTED 1
|
||||||
// \#define SOC_APM_SUPPORTED 1 //TODO: [ESP32C61] IDF-9230
|
// \#define SOC_APM_SUPPORTED 1 //TODO: [ESP32C61] IDF-9230
|
||||||
#define SOC_PMU_SUPPORTED 1 //TODO: [ESP32C61] IDF-9250
|
#define SOC_PMU_SUPPORTED 1
|
||||||
// \#define SOC_LP_TIMER_SUPPORTED 1 //TODO: [ESP32C61] IDF-9244
|
#define SOC_LP_TIMER_SUPPORTED 1
|
||||||
// \#define SOC_LP_AON_SUPPORTED 1
|
// \#define SOC_LP_AON_SUPPORTED 1
|
||||||
// \#define SOC_LP_PERIPHERALS_SUPPORTED 1
|
// \#define SOC_LP_PERIPHERALS_SUPPORTED 1
|
||||||
#define SOC_CLK_TREE_SUPPORTED 1
|
#define SOC_CLK_TREE_SUPPORTED 1
|
||||||
@ -60,7 +60,8 @@
|
|||||||
// \#define SOC_ETM_SUPPORTED 0
|
// \#define SOC_ETM_SUPPORTED 0
|
||||||
// \#define SOC_SDIO_SLAVE_SUPPORTED 0
|
// \#define SOC_SDIO_SLAVE_SUPPORTED 0
|
||||||
// \#define SOC_PAU_SUPPORTED 0
|
// \#define SOC_PAU_SUPPORTED 0
|
||||||
// \#define SOC_PM_SUPPORTED 1
|
#define SOC_LIGHT_SLEEP_SUPPORTED 1
|
||||||
|
#define SOC_PM_SUPPORTED 1
|
||||||
#define SOC_ECDSA_SUPPORTED 1
|
#define SOC_ECDSA_SUPPORTED 1
|
||||||
#define SOC_SPIRAM_SUPPORTED 1
|
#define SOC_SPIRAM_SUPPORTED 1
|
||||||
/*-------------------------- XTAL CAPS ---------------------------------------*/
|
/*-------------------------- XTAL CAPS ---------------------------------------*/
|
||||||
@ -320,6 +321,7 @@
|
|||||||
#define SOC_MEMSPI_SRC_FREQ_80M_SUPPORTED 1
|
#define SOC_MEMSPI_SRC_FREQ_80M_SUPPORTED 1
|
||||||
#define SOC_MEMSPI_SRC_FREQ_40M_SUPPORTED 1
|
#define SOC_MEMSPI_SRC_FREQ_40M_SUPPORTED 1
|
||||||
#define SOC_MEMSPI_SRC_FREQ_20M_SUPPORTED 1
|
#define SOC_MEMSPI_SRC_FREQ_20M_SUPPORTED 1
|
||||||
|
#define SOC_MEMSPI_FLASH_CLK_SRC_IS_INDEPENDENT 1
|
||||||
|
|
||||||
/*-------------------------- SYSTIMER CAPS ----------------------------------*/
|
/*-------------------------- SYSTIMER CAPS ----------------------------------*/
|
||||||
#define SOC_SYSTIMER_COUNTER_NUM 2 // Number of counter units
|
#define SOC_SYSTIMER_COUNTER_NUM 2 // Number of counter units
|
||||||
@ -403,15 +405,15 @@
|
|||||||
|
|
||||||
// TODO: IDF-5351 (Copy from esp32c3, need check)
|
// TODO: IDF-5351 (Copy from esp32c3, need check)
|
||||||
/*-------------------------- Power Management CAPS ----------------------------*/
|
/*-------------------------- Power Management CAPS ----------------------------*/
|
||||||
#define SOC_PM_SUPPORT_WIFI_WAKEUP (1)
|
// #define SOC_PM_SUPPORT_WIFI_WAKEUP (1)
|
||||||
#define SOC_PM_SUPPORT_BEACON_WAKEUP (1)
|
// #define SOC_PM_SUPPORT_BEACON_WAKEUP (1)
|
||||||
#define SOC_PM_SUPPORT_BT_WAKEUP (1)
|
// #define SOC_PM_SUPPORT_BT_WAKEUP (1)
|
||||||
#define SOC_PM_SUPPORT_EXT1_WAKEUP (1)
|
// #define SOC_PM_SUPPORT_EXT1_WAKEUP (1)
|
||||||
#define SOC_PM_SUPPORT_EXT1_WAKEUP_MODE_PER_PIN (1) /*!<Supports one bit per pin to configure the EXT1 trigger level */
|
// #define SOC_PM_SUPPORT_EXT1_WAKEUP_MODE_PER_PIN (1) /*!<Supports one bit per pin to configure the EXT1 trigger level */
|
||||||
// \#define SOC_PM_SUPPORT_CPU_PD (1)
|
#define SOC_PM_SUPPORT_CPU_PD (1)
|
||||||
#define SOC_PM_SUPPORT_MODEM_PD (1)
|
#define SOC_PM_SUPPORT_MODEM_PD (1)
|
||||||
#define SOC_PM_SUPPORT_XTAL32K_PD (1)
|
#define SOC_PM_SUPPORT_XTAL32K_PD (1)
|
||||||
// \#define SOC_PM_SUPPORT_RC32K_PD (1)
|
#define SOC_PM_SUPPORT_RC32K_PD (1)
|
||||||
#define SOC_PM_SUPPORT_RC_FAST_PD (1)
|
#define SOC_PM_SUPPORT_RC_FAST_PD (1)
|
||||||
#define SOC_PM_SUPPORT_VDDSDIO_PD (1)
|
#define SOC_PM_SUPPORT_VDDSDIO_PD (1)
|
||||||
// \#define SOC_PM_SUPPORT_TOP_PD (1)
|
// \#define SOC_PM_SUPPORT_TOP_PD (1)
|
||||||
@ -423,12 +425,10 @@
|
|||||||
/* macro redefine for pass esp_wifi headers md5sum check */
|
/* macro redefine for pass esp_wifi headers md5sum check */
|
||||||
#define MAC_SUPPORT_PMU_MODEM_STATE SOC_PM_SUPPORT_PMU_MODEM_STATE
|
#define MAC_SUPPORT_PMU_MODEM_STATE SOC_PM_SUPPORT_PMU_MODEM_STATE
|
||||||
|
|
||||||
|
// #define SOC_PM_SUPPORT_DEEPSLEEP_CHECK_STUB_ONLY (1) /*!<Supports CRC only the stub code in RTC memory */
|
||||||
|
|
||||||
#define SOC_PM_SUPPORT_DEEPSLEEP_CHECK_STUB_ONLY (1) /*!<Supports CRC only the stub code in RTC memory */
|
#define SOC_PM_CPU_RETENTION_BY_SW (1)
|
||||||
|
|
||||||
// \#define SOC_PM_CPU_RETENTION_BY_SW (1)
|
|
||||||
#define SOC_PM_MODEM_RETENTION_BY_REGDMA (0)
|
#define SOC_PM_MODEM_RETENTION_BY_REGDMA (0)
|
||||||
#define SOC_PM_RETENTION_HAS_CLOCK_BUG (1)
|
|
||||||
#define SOC_EXT_MEM_CACHE_TAG_IN_CPU_DOMAIN (1)
|
#define SOC_EXT_MEM_CACHE_TAG_IN_CPU_DOMAIN (1)
|
||||||
#define SOC_PM_PAU_LINK_NUM (4)
|
#define SOC_PM_PAU_LINK_NUM (4)
|
||||||
|
|
||||||
@ -439,7 +439,7 @@
|
|||||||
#define SOC_CLK_XTAL32K_SUPPORTED (1) /*!< Support to connect an external low frequency crystal */
|
#define SOC_CLK_XTAL32K_SUPPORTED (1) /*!< Support to connect an external low frequency crystal */
|
||||||
#define SOC_CLK_OSC_SLOW_SUPPORTED (1) /*!< Support to connect an external oscillator, not a crystal */
|
#define SOC_CLK_OSC_SLOW_SUPPORTED (1) /*!< Support to connect an external oscillator, not a crystal */
|
||||||
#define SOC_CLK_LP_FAST_SUPPORT_XTAL (1) /*!< Support XTAL clock as the LP_FAST clock source */
|
#define SOC_CLK_LP_FAST_SUPPORT_XTAL (1) /*!< Support XTAL clock as the LP_FAST clock source */
|
||||||
|
#define SOC_CLK_RC32K_NOT_TO_USE (1) /*!< Due to the poor low-temperature characteristics of RC32K (it cannot operate below -40 degrees Celsius), please avoid using it whenever possible. */
|
||||||
#define SOC_RCC_IS_INDEPENDENT 1 /*!< Reset and Clock Control is independent, thanks to the PCR registers */
|
#define SOC_RCC_IS_INDEPENDENT 1 /*!< Reset and Clock Control is independent, thanks to the PCR registers */
|
||||||
|
|
||||||
/*-------------------------- Temperature Sensor CAPS -------------------------------------*/
|
/*-------------------------- Temperature Sensor CAPS -------------------------------------*/
|
||||||
|
@ -1119,6 +1119,10 @@ config SOC_CONFIGURABLE_VDDSDIO_SUPPORTED
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_PM_MODEM_PD_BY_SW
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_CLK_APLL_SUPPORTED
|
config SOC_CLK_APLL_SUPPORTED
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
@ -469,6 +469,7 @@
|
|||||||
#define SOC_PM_SUPPORT_VDDSDIO_PD (1)
|
#define SOC_PM_SUPPORT_VDDSDIO_PD (1)
|
||||||
|
|
||||||
#define SOC_CONFIGURABLE_VDDSDIO_SUPPORTED (1)
|
#define SOC_CONFIGURABLE_VDDSDIO_SUPPORTED (1)
|
||||||
|
#define SOC_PM_MODEM_PD_BY_SW (1)
|
||||||
|
|
||||||
/*-------------------------- CLOCK SUBSYSTEM CAPS ----------------------------------------*/
|
/*-------------------------- CLOCK SUBSYSTEM CAPS ----------------------------------------*/
|
||||||
#define SOC_CLK_APLL_SUPPORTED (1)
|
#define SOC_CLK_APLL_SUPPORTED (1)
|
||||||
|
@ -1215,6 +1215,10 @@ config SOC_PM_MODEM_RETENTION_BY_BACKUPDMA
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_PM_MODEM_PD_BY_SW
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_CLK_RC_FAST_D256_SUPPORTED
|
config SOC_CLK_RC_FAST_D256_SUPPORTED
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
@ -473,6 +473,7 @@
|
|||||||
|
|
||||||
#define SOC_PM_CPU_RETENTION_BY_RTCCNTL (1)
|
#define SOC_PM_CPU_RETENTION_BY_RTCCNTL (1)
|
||||||
#define SOC_PM_MODEM_RETENTION_BY_BACKUPDMA (1)
|
#define SOC_PM_MODEM_RETENTION_BY_BACKUPDMA (1)
|
||||||
|
#define SOC_PM_MODEM_PD_BY_SW (1)
|
||||||
|
|
||||||
/*--------------------------- CLOCK SUBSYSTEM CAPS -------------------------- */
|
/*--------------------------- CLOCK SUBSYSTEM CAPS -------------------------- */
|
||||||
#define SOC_CLK_RC_FAST_D256_SUPPORTED (1)
|
#define SOC_CLK_RC_FAST_D256_SUPPORTED (1)
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-C61 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
||||||
| ----------------- | ----- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- |
|
| ----------------- | ----- | -------- | -------- | -------- | -------- | --------- | -------- | -------- | -------- | -------- |
|
||||||
|
|
||||||
# System Examples
|
# System Examples
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-C61 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
||||||
| ----------------- | ----- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- |
|
| ----------------- | ----- | -------- | -------- | -------- | -------- | --------- | -------- | -------- | -------- | -------- |
|
||||||
|
|
||||||
# ESP Timer Example (High Resolution Timer)
|
# ESP Timer Example (High Resolution Timer)
|
||||||
|
|
||||||
|
@ -28,8 +28,6 @@ ONE_SHOT_TIMER_PERIOD = 5000000
|
|||||||
|
|
||||||
|
|
||||||
@pytest.mark.supported_targets
|
@pytest.mark.supported_targets
|
||||||
# TODO: [ESP32C61] IDF-10993
|
|
||||||
@pytest.mark.temp_skip_ci(targets=['esp32c61'], reason='C61 has not supported light sleep')
|
|
||||||
@pytest.mark.generic
|
@pytest.mark.generic
|
||||||
@pytest.mark.parametrize(
|
@pytest.mark.parametrize(
|
||||||
'config',
|
'config',
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
| Supported Targets | ESP32 | ESP32-C2 | ESP32-C3 | ESP32-C5 | ESP32-C6 | ESP32-C61 | ESP32-H2 | ESP32-P4 | ESP32-S2 | ESP32-S3 |
|
||||||
| ----------------- | ----- | -------- | -------- | -------- | -------- | -------- | -------- | -------- | -------- |
|
| ----------------- | ----- | -------- | -------- | -------- | -------- | --------- | -------- | -------- | -------- | -------- |
|
||||||
|
|
||||||
# Light Sleep Example
|
# Light Sleep Example
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
* You can also change this to another pin.
|
* You can also change this to another pin.
|
||||||
*/
|
*/
|
||||||
#if CONFIG_IDF_TARGET_ESP32C3 || CONFIG_IDF_TARGET_ESP32C2 || CONFIG_IDF_TARGET_ESP32H2 \
|
#if CONFIG_IDF_TARGET_ESP32C3 || CONFIG_IDF_TARGET_ESP32C2 || CONFIG_IDF_TARGET_ESP32H2 \
|
||||||
|| CONFIG_IDF_TARGET_ESP32C6
|
|| CONFIG_IDF_TARGET_ESP32C6 || CONFIG_IDF_TARGET_ESP32C61
|
||||||
#define BOOT_BUTTON_NUM 9
|
#define BOOT_BUTTON_NUM 9
|
||||||
#elif CONFIG_IDF_TARGET_ESP32C5
|
#elif CONFIG_IDF_TARGET_ESP32C5
|
||||||
#define BOOT_BUTTON_NUM 28
|
#define BOOT_BUTTON_NUM 28
|
||||||
|
@ -8,7 +8,6 @@ from pytest_embedded import Dut
|
|||||||
|
|
||||||
|
|
||||||
@pytest.mark.supported_targets
|
@pytest.mark.supported_targets
|
||||||
@pytest.mark.temp_skip_ci(targets=['esp32c61'], reason='not supported light sleep') # TODO: [ESP32C61] IDF-9247 IDF-10993
|
|
||||||
@pytest.mark.generic
|
@pytest.mark.generic
|
||||||
def test_light_sleep(dut: Dut) -> None:
|
def test_light_sleep(dut: Dut) -> None:
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user