forked from espressif/esp-idf
feat(i2s): support i2s retention on C61
This commit is contained in:
committed by
Kevin (Lao Kaiyao)
parent
9b270c4c7d
commit
059de88f23
@ -5,6 +5,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "soc/i2s_periph.h"
|
#include "soc/i2s_periph.h"
|
||||||
|
#include "soc/i2s_reg.h"
|
||||||
#include "soc/gpio_sig_map.h"
|
#include "soc/gpio_sig_map.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -32,3 +33,41 @@ const i2s_signal_conn_t i2s_periph_signal[SOC_I2S_NUM] = {
|
|||||||
.irq = ETS_I2S0_INTR_SOURCE,
|
.irq = ETS_I2S0_INTR_SOURCE,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* I2S Registers to be saved during sleep retention
|
||||||
|
* - I2S_RX_CONF_REG
|
||||||
|
* - I2S_TX_CONF_REG
|
||||||
|
* - I2S_RX_CONF1_REG
|
||||||
|
* - I2S_TX_CONF1_REG
|
||||||
|
* - I2S_TX_PCM2PDM_CONF_REG
|
||||||
|
* - I2S_TX_PCM2PDM_CONF1_REG
|
||||||
|
* - I2S_RX_TDM_CTRL_REG
|
||||||
|
* - I2S_TX_TDM_CTRL_REG
|
||||||
|
* - I2S_RXEOF_NUM_REG
|
||||||
|
* - I2S_ETM_CONF_REG
|
||||||
|
*/
|
||||||
|
#define I2S_RETENTION_REGS_CNT 10
|
||||||
|
#define I2S_RETENTION_REGS_BASE(i) I2S_RX_CONF_REG
|
||||||
|
static const uint32_t i2s_regs_map[4] = {0x12360f, 0x0, 0x0, 0x0};
|
||||||
|
#define I2S_SLEEP_RETENTION_ENTRIES(i2s_port) { \
|
||||||
|
/* Save/restore the register values */ \
|
||||||
|
[0] = { .config = REGDMA_LINK_ADDR_MAP_INIT( \
|
||||||
|
REGDMA_I2S_LINK(0x00), \
|
||||||
|
I2S_RETENTION_REGS_BASE(i2s_port), \
|
||||||
|
I2S_RETENTION_REGS_BASE(i2s_port), \
|
||||||
|
I2S_RETENTION_REGS_CNT, 0, 0, \
|
||||||
|
i2s_regs_map[0], i2s_regs_map[1], \
|
||||||
|
i2s_regs_map[2], i2s_regs_map[3]), \
|
||||||
|
.owner = ENTRY(0) | ENTRY(2)}, \
|
||||||
|
};
|
||||||
|
|
||||||
|
static const regdma_entries_config_t i2s0_regs_retention[] = I2S_SLEEP_RETENTION_ENTRIES(0);
|
||||||
|
|
||||||
|
const i2s_reg_retention_info_t i2s_reg_retention_info[SOC_I2S_NUM] = {
|
||||||
|
[0] = {
|
||||||
|
.retention_module = SLEEP_RETENTION_MODULE_I2S0,
|
||||||
|
.entry_array = i2s0_regs_retention,
|
||||||
|
.array_size = ARRAY_SIZE(i2s0_regs_retention)
|
||||||
|
},
|
||||||
|
};
|
||||||
|
@ -495,6 +495,10 @@ config SOC_I2S_SUPPORTS_TDM
|
|||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config SOC_I2S_SUPPORT_SLEEP_RETENTION
|
||||||
|
bool
|
||||||
|
default y
|
||||||
|
|
||||||
config SOC_LEDC_SUPPORT_PLL_DIV_CLOCK
|
config SOC_LEDC_SUPPORT_PLL_DIV_CLOCK
|
||||||
bool
|
bool
|
||||||
default y
|
default y
|
||||||
|
@ -36,6 +36,7 @@ typedef enum periph_retention_module {
|
|||||||
SLEEP_RETENTION_MODULE_ETM0 = 16,
|
SLEEP_RETENTION_MODULE_ETM0 = 16,
|
||||||
SLEEP_RETENTION_MODULE_GPSPI2 = 17,
|
SLEEP_RETENTION_MODULE_GPSPI2 = 17,
|
||||||
SLEEP_RETENTION_MODULE_LEDC = 18,
|
SLEEP_RETENTION_MODULE_LEDC = 18,
|
||||||
|
SLEEP_RETENTION_MODULE_I2S0 = 19,
|
||||||
|
|
||||||
/* Modem module, which includes WiFi, BLE and 802.15.4 */
|
/* Modem module, which includes WiFi, BLE and 802.15.4 */
|
||||||
SLEEP_RETENTION_MODULE_WIFI_MAC = 26,
|
SLEEP_RETENTION_MODULE_WIFI_MAC = 26,
|
||||||
@ -68,6 +69,7 @@ typedef enum periph_retention_module_bitmap {
|
|||||||
SLEEP_RETENTION_MODULE_BM_ETM0 = BIT(SLEEP_RETENTION_MODULE_ETM0),
|
SLEEP_RETENTION_MODULE_BM_ETM0 = BIT(SLEEP_RETENTION_MODULE_ETM0),
|
||||||
SLEEP_RETENTION_MODULE_BM_GPSPI2 = BIT(SLEEP_RETENTION_MODULE_GPSPI2),
|
SLEEP_RETENTION_MODULE_BM_GPSPI2 = BIT(SLEEP_RETENTION_MODULE_GPSPI2),
|
||||||
SLEEP_RETENTION_MODULE_BM_LEDC = BIT(SLEEP_RETENTION_MODULE_LEDC),
|
SLEEP_RETENTION_MODULE_BM_LEDC = BIT(SLEEP_RETENTION_MODULE_LEDC),
|
||||||
|
SLEEP_RETENTION_MODULE_BM_I2S0 = BIT(SLEEP_RETENTION_MODULE_I2S0),
|
||||||
/* modem module, which includes WiFi, BLE and 802.15.4 */
|
/* modem module, which includes WiFi, BLE and 802.15.4 */
|
||||||
SLEEP_RETENTION_MODULE_BM_WIFI_MAC = BIT(SLEEP_RETENTION_MODULE_WIFI_MAC),
|
SLEEP_RETENTION_MODULE_BM_WIFI_MAC = BIT(SLEEP_RETENTION_MODULE_WIFI_MAC),
|
||||||
SLEEP_RETENTION_MODULE_BM_WIFI_BB = BIT(SLEEP_RETENTION_MODULE_WIFI_BB),
|
SLEEP_RETENTION_MODULE_BM_WIFI_BB = BIT(SLEEP_RETENTION_MODULE_WIFI_BB),
|
||||||
@ -90,6 +92,7 @@ typedef enum periph_retention_module_bitmap {
|
|||||||
| SLEEP_RETENTION_MODULE_BM_ETM0 \
|
| SLEEP_RETENTION_MODULE_BM_ETM0 \
|
||||||
| SLEEP_RETENTION_MODULE_BM_GPSPI2 \
|
| SLEEP_RETENTION_MODULE_BM_GPSPI2 \
|
||||||
| SLEEP_RETENTION_MODULE_BM_LEDC \
|
| SLEEP_RETENTION_MODULE_BM_LEDC \
|
||||||
|
| SLEEP_RETENTION_MODULE_BM_I2S0 \
|
||||||
)
|
)
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -244,6 +244,7 @@
|
|||||||
#define SOC_I2S_SUPPORTS_PDM_TX (1)
|
#define SOC_I2S_SUPPORTS_PDM_TX (1)
|
||||||
#define SOC_I2S_PDM_MAX_TX_LINES (2)
|
#define SOC_I2S_PDM_MAX_TX_LINES (2)
|
||||||
#define SOC_I2S_SUPPORTS_TDM (1)
|
#define SOC_I2S_SUPPORTS_TDM (1)
|
||||||
|
#define SOC_I2S_SUPPORT_SLEEP_RETENTION (1)
|
||||||
|
|
||||||
/*-------------------------- LEDC CAPS ---------------------------------------*/
|
/*-------------------------- LEDC CAPS ---------------------------------------*/
|
||||||
#define SOC_LEDC_SUPPORT_PLL_DIV_CLOCK (1)
|
#define SOC_LEDC_SUPPORT_PLL_DIV_CLOCK (1)
|
||||||
|
Reference in New Issue
Block a user