mirror of
https://github.com/espressif/esp-idf
synced 2025-04-21 14:01:33 -04:00
545 lines
25 KiB
C
545 lines
25 KiB
C
/*
|
|
* SPDX-FileCopyrightText: 2023 Espressif Systems (Shanghai) CO LTD
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
#pragma once
|
|
|
|
#include "soc/soc_caps.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/*
|
|
************************* ESP32P4 Root Clock Source ****************************
|
|
* 1) Internal 17.5MHz RC Oscillator: RC_FAST (may also referred as FOSC in TRM and reg. description)
|
|
*
|
|
* This RC oscillator generates a ~17.5MHz clock signal output as the RC_FAST_CLK.
|
|
*
|
|
* The exact frequency of RC_FAST_CLK can be computed in runtime through calibration.
|
|
*
|
|
* 2) External 40MHz Crystal Clock: XTAL
|
|
*
|
|
* 3) Internal 136kHz RC Oscillator: RC_SLOW (may also referrred as SOSC in TRM or reg. description)
|
|
*
|
|
* This RC oscillator generates a ~136kHz clock signal output as the RC_SLOW_CLK. The exact frequency of this clock
|
|
* can be computed in runtime through calibration.
|
|
*
|
|
* 4) Internal 32kHz RC Oscillator: RC32K
|
|
*
|
|
* The exact frequency of this clock can be computed in runtime through calibration.
|
|
*
|
|
* 5) External 32kHz Crystal Clock (optional): XTAL32K
|
|
*
|
|
* The clock source for this XTAL32K_CLK should be a 32kHz crystal connecting to the XTAL_32K_P and XTAL_32K_N
|
|
* pins.
|
|
*
|
|
* XTAL32K_CLK can also be calibrated to get its exact frequency.
|
|
*
|
|
* 6) External Slow Clock (optional): OSC_SLOW
|
|
*
|
|
* A slow clock signal generated by an external circuit can be connected to GPIO1 to be the clock source for the
|
|
* RTC_SLOW_CLK.
|
|
*
|
|
* OSC_SLOW_CLK can also be calibrated to get its exact frequency.
|
|
*
|
|
*
|
|
* PLL Clocks:
|
|
*
|
|
* from 40MHz XTAL oscillator frequency multipliers:
|
|
* 1) CPLL (400MHz), used for CPU, MSPI-Flash, MSPI-PSRAM clock source
|
|
* 2) MPLL (500MHz), used for MSPI-PSRAM clock source; and is further divided to PLL_F50M, PLL_F25M, to be used for peripheral's clock sources
|
|
* 3) SPLL (480MHz), directly used for MSPI-Flash, MSPI-PSRAM, GPSPI clock sources; and is further divided to PLL_F240M, PLL_F160M, PLL_F120M, PLL_F80M, PLL_F20M, to be used for peripherals' clock sources
|
|
* 4) APLL (configurable), can be the clock source for peripherals (GPSPI, I2S, LCD, CAM, etc.)
|
|
* 5) SDIO_PLL0/1/2
|
|
*
|
|
* from 32kHz slow clock oscillator frequency multiplier:
|
|
* 6) LP_PLL (8MHz), used for RTC_FAST_CLK clock source and LP peripherals' clock sources
|
|
*/
|
|
|
|
/* With the default value of FOSC_DFREQ = 100, RC_FAST clock frequency is 17.5 MHz +/- 7% */ // TODO: check
|
|
#define SOC_CLK_RC_FAST_FREQ_APPROX 17500000 /*!< Approximate RC_FAST_CLK frequency in Hz */
|
|
#define SOC_CLK_RC_SLOW_FREQ_APPROX 136000 /*!< Approximate RC_SLOW_CLK frequency in Hz */
|
|
#define SOC_CLK_RC32K_FREQ_APPROX 32768 /*!< Approximate RC32K_CLK frequency in Hz */
|
|
#define SOC_CLK_XTAL32K_FREQ_APPROX 32768 /*!< Approximate XTAL32K_CLK frequency in Hz */
|
|
#define SOC_CLK_OSC_SLOW_FREQ_APPROX 32768 /*!< Approximate OSC_SLOW_CLK (external slow clock) frequency in Hz */
|
|
|
|
// Naming convention: SOC_ROOT_CLK_{loc}_{type}_[attr]
|
|
// {loc}: EXT, INT
|
|
// {type}: XTAL, RC
|
|
// [attr] - optional: [frequency], FAST, SLOW
|
|
/**
|
|
* @brief Root clock
|
|
*/
|
|
typedef enum {
|
|
SOC_ROOT_CLK_INT_RC_FAST, /*!< Internal 17.5MHz RC oscillator */
|
|
SOC_ROOT_CLK_INT_RC_SLOW, /*!< Internal 136kHz RC oscillator */
|
|
SOC_ROOT_CLK_EXT_XTAL, /*!< External 40MHz crystal */
|
|
SOC_ROOT_CLK_EXT_XTAL32K, /*!< External 32kHz crystal */
|
|
SOC_ROOT_CLK_INT_RC32K, /*!< Internal 32kHz RC oscillator */
|
|
SOC_ROOT_CLK_EXT_OSC_SLOW, /*!< External slow clock signal at pin1 */
|
|
} soc_root_clk_t;
|
|
|
|
/**
|
|
* @brief CPU_CLK mux inputs, which are the supported clock sources for the CPU_CLK
|
|
* @note Enum values are matched with the register field values on purpose
|
|
*/
|
|
typedef enum {
|
|
SOC_CPU_CLK_SRC_XTAL = 0, /*!< Select XTAL_CLK as CPU_CLK source */
|
|
SOC_CPU_CLK_SRC_PLL = 1, /*!< Select (C)PLL_CLK as CPU_CLK source (CPLL_CLK is the output of 40MHz crystal oscillator frequency multiplier, 400MHz) */
|
|
SOC_CPU_CLK_SRC_RC_FAST = 2, /*!< Select RC_FAST_CLK as CPU_CLK source */
|
|
SOC_CPU_CLK_SRC_INVALID, /*!< Invalid CPU_CLK source */
|
|
} soc_cpu_clk_src_t;
|
|
|
|
/**
|
|
* @brief RTC_SLOW_CLK mux inputs, which are the supported clock sources for the RTC_SLOW_CLK
|
|
* @note Enum values are matched with the register field values on purpose
|
|
*/
|
|
typedef enum {
|
|
SOC_RTC_SLOW_CLK_SRC_RC_SLOW = 0, /*!< Select RC_SLOW_CLK as RTC_SLOW_CLK source */
|
|
SOC_RTC_SLOW_CLK_SRC_XTAL32K = 1, /*!< Select XTAL32K_CLK as RTC_SLOW_CLK source */
|
|
SOC_RTC_SLOW_CLK_SRC_RC32K = 2, /*!< Select RC32K_CLK as RTC_SLOW_CLK source */
|
|
SOC_RTC_SLOW_CLK_SRC_OSC_SLOW = 3, /*!< Select OSC_SLOW_CLK (external slow clock) as RTC_SLOW_CLK source */
|
|
SOC_RTC_SLOW_CLK_SRC_INVALID, /*!< Invalid RTC_SLOW_CLK source */
|
|
} soc_rtc_slow_clk_src_t;
|
|
|
|
/**
|
|
* @brief RTC_FAST_CLK mux inputs, which are the supported clock sources for the RTC_FAST_CLK
|
|
* @note Enum values are matched with the register field values on purpose
|
|
*/
|
|
typedef enum {
|
|
SOC_RTC_FAST_CLK_SRC_RC_FAST = 0, /*!< Select RC_FAST_CLK as RTC_FAST_CLK source */
|
|
SOC_RTC_FAST_CLK_SRC_XTAL = 1, /*!< Select XTAL_CLK as RTC_FAST_CLK source */
|
|
SOC_RTC_FAST_CLK_SRC_XTAL_DIV = SOC_RTC_FAST_CLK_SRC_XTAL, /*!< Alias name for `SOC_RTC_FAST_CLK_SRC_XTAL` */
|
|
SOC_RTC_FAST_CLK_SRC_LP_PLL = 2, /*!< Select LP_PLL_CLK as RTC_FAST_CLK source (LP_PLL_CLK is a 8MHz clock sourced from RC32K or XTAL32K) */
|
|
SOC_RTC_FAST_CLK_SRC_INVALID, /*!< Invalid RTC_FAST_CLK source */
|
|
} soc_rtc_fast_clk_src_t;
|
|
|
|
/**
|
|
* @brief LP_PLL_CLK mux inputs, which are the supported clock sources for the LP_PLL_CLK
|
|
* @note Enum values are matched with the register field values on purpose
|
|
*/
|
|
typedef enum {
|
|
SOC_LP_PLL_CLK_SRC_RC32K = 0, /*!< Select RC32K_CLK as LP_PLL_CLK source */
|
|
SOC_LP_PLL_CLK_SRC_XTAL32K = 1, /*!< Select XTAL32K_CLK as LP_PLL_CLK source */
|
|
SOC_LP_PLL_CLK_SRC_INVALID, /*!< Invalid LP_PLL_CLK source */
|
|
} soc_lp_pll_clk_src_t;
|
|
|
|
// Naming convention: SOC_MOD_CLK_{[upstream]clock_name}_[attr]
|
|
// {[upstream]clock_name}: XTAL, (S/M/A)PLL, etc.
|
|
// [attr] - optional: FAST, SLOW, D<divider>, F<freq>
|
|
/**
|
|
* @brief Supported clock sources for modules (CPU, peripherals, RTC, etc.)
|
|
*
|
|
* @note enum starts from 1, to save 0 for special purpose
|
|
*/
|
|
typedef enum {
|
|
// For CPU domain
|
|
SOC_MOD_CLK_CPU = 1, /*!< CPU_CLK can be sourced from XTAL, CPLL, or RC_FAST by configuring soc_cpu_clk_src_t */
|
|
// For RTC domain
|
|
SOC_MOD_CLK_RTC_FAST, /*!< RTC_FAST_CLK can be sourced from XTAL, RC_FAST, or LP_PLL by configuring soc_rtc_fast_clk_src_t */
|
|
SOC_MOD_CLK_RTC_SLOW, /*!< RTC_SLOW_CLK can be sourced from RC_SLOW, XTAL32K, RC32K, or OSC_SLOW by configuring soc_rtc_slow_clk_src_t */
|
|
// For digital domain: peripherals
|
|
SOC_MOD_CLK_PLL_F80M, /*!< PLL_F80M_CLK is derived from SPLL (clock gating + fixed divider of 6), it has a fixed frequency of 80MHz */
|
|
SOC_MOD_CLK_PLL_F160M, /*!< PLL_F160M_CLK is derived from SPLL (clock gating + fixed divider of 3), it has a fixed frequency of 160MHz */
|
|
SOC_MOD_CLK_PLL_F200M, /*!< PLL_F200M_CLK is derived from SPLL (clock gating + fixed divider of 3), it has a fixed frequency of 200MHz */
|
|
SOC_MOD_CLK_PLL_F240M, /*!< PLL_F240M_CLK is derived from SPLL (clock gating + fixed divider of 2), it has a fixed frequency of 240MHz */
|
|
SOC_MOD_CLK_CPLL, /*!< CPLL is from 40MHz XTAL oscillator frequency multipliers, it has a fixed frequency of 400MHz */
|
|
SOC_MOD_CLK_SPLL, /*!< SPLL is from 40MHz XTAL oscillator frequency multipliers, it has a fixed frequency of 480MHz */
|
|
SOC_MOD_CLK_MPLL, /*!< MPLL is from 40MHz XTAL oscillator frequency multipliers, it has a fixed frequency of 500MHz */
|
|
SOC_MOD_CLK_XTAL32K, /*!< XTAL32K_CLK comes from the external 32kHz crystal, passing a clock gating to the peripherals */
|
|
SOC_MOD_CLK_RC_FAST, /*!< RC_FAST_CLK comes from the internal 20MHz rc oscillator, passing a clock gating to the peripherals */
|
|
SOC_MOD_CLK_XTAL, /*!< XTAL_CLK comes from the external 40MHz crystal */
|
|
SOC_MOD_CLK_APLL, /*!< Audio PLL is sourced from PLL, and its frequency is configurable through APLL configuration registers */
|
|
// For LP peripherals
|
|
SOC_MOD_CLK_XTAL_D2, /*!< XTAL_D2_CLK comes from the external 40MHz crystal, passing a div of 2 to the LP peripherals */
|
|
SOC_MOD_CLK_LP_PLL, /*!< LP_PLL is from 32kHz XTAL oscillator frequency multipliers, it has a fixed frequency of 8MHz */
|
|
SOC_MOD_CLK_INVALID, /*!< Indication of the end of the available module clock sources */
|
|
} soc_module_clk_t;
|
|
|
|
//////////////////////////////////////////////////SYSTIMER//////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Type of SYSTIMER clock source
|
|
*/
|
|
typedef enum {
|
|
SYSTIMER_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< SYSTIMER source clock is XTAL */
|
|
SYSTIMER_CLK_SRC_RC_FAST = SOC_MOD_CLK_RC_FAST, /*!< SYSTIMER source clock is RC_FAST */
|
|
SYSTIMER_CLK_SRC_DEFAULT = SOC_MOD_CLK_XTAL, /*!< SYSTIMER source clock default choice is XTAL */
|
|
} soc_periph_systimer_clk_src_t;
|
|
|
|
//////////////////////////////////////////////////GPTimer///////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of GPTimer
|
|
*
|
|
* The following code can be used to iterate all possible clocks:
|
|
* @code{c}
|
|
* soc_periph_gptimer_clk_src_t gptimer_clks[] = (soc_periph_gptimer_clk_src_t)SOC_GPTIMER_CLKS;
|
|
* for (size_t i = 0; i< sizeof(gptimer_clks) / sizeof(gptimer_clks[0]); i++) {
|
|
* soc_periph_gptimer_clk_src_t clk = gptimer_clks[i];
|
|
* // Test GPTimer with the clock `clk`
|
|
* }
|
|
* @endcode
|
|
*/
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
#define SOC_GPTIMER_CLKS {SOC_MOD_CLK_PLL_F80M, SOC_MOD_CLK_RC_FAST, SOC_MOD_CLK_XTAL}
|
|
#else
|
|
#define SOC_GPTIMER_CLKS {SOC_MOD_CLK_XTAL}
|
|
#endif
|
|
|
|
/**
|
|
* @brief Type of GPTimer clock source
|
|
*/
|
|
typedef enum {
|
|
GPTIMER_CLK_SRC_PLL_F80M = SOC_MOD_CLK_PLL_F80M, /*!< Select PLL_F80M as the source clock */
|
|
GPTIMER_CLK_SRC_RC_FAST = SOC_MOD_CLK_RC_FAST, /*!< Select RC_FAST as the source clock */
|
|
GPTIMER_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the source clock */
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
GPTIMER_CLK_SRC_DEFAULT = SOC_MOD_CLK_PLL_F80M, /*!< Select PLL_F80M as the default choice */
|
|
#else
|
|
GPTIMER_CLK_SRC_DEFAULT = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the default choice */
|
|
#endif // SOC_CLK_TREE_SUPPORTED
|
|
} soc_periph_gptimer_clk_src_t;
|
|
|
|
/**
|
|
* @brief Type of Timer Group clock source, reserved for the legacy timer group driver
|
|
*/
|
|
typedef enum {
|
|
TIMER_SRC_CLK_PLL_F80M = SOC_MOD_CLK_PLL_F80M, /*!< Timer group clock source is PLL_F80M */
|
|
TIMER_SRC_CLK_XTAL = SOC_MOD_CLK_XTAL, /*!< Timer group clock source is XTAL */
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
TIMER_SRC_CLK_DEFAULT = SOC_MOD_CLK_PLL_F80M, /*!< Timer group clock source default choice is PLL_F80M */
|
|
#else
|
|
TIMER_SRC_CLK_DEFAULT = SOC_MOD_CLK_XTAL, /*!< Timer group clock source default choice is XTAL */
|
|
#endif // SOC_CLK_TREE_SUPPORTED
|
|
} soc_periph_tg_clk_src_legacy_t;
|
|
|
|
//////////////////////////////////////////////////RMT///////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of RMT
|
|
*/
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
#define SOC_RMT_CLKS {SOC_MOD_CLK_PLL_F80M, SOC_MOD_CLK_RC_FAST, SOC_MOD_CLK_XTAL}
|
|
#else
|
|
#define SOC_RMT_CLKS {SOC_MOD_CLK_XTAL}
|
|
#endif
|
|
|
|
/**
|
|
* @brief Type of RMT clock source
|
|
*/
|
|
typedef enum {
|
|
RMT_CLK_SRC_PLL_F80M = SOC_MOD_CLK_PLL_F80M, /*!< Select PLL_F80M as the source clock */
|
|
RMT_CLK_SRC_RC_FAST = SOC_MOD_CLK_RC_FAST, /*!< Select RC_FAST as the source clock */
|
|
RMT_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the source clock */
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
RMT_CLK_SRC_DEFAULT = SOC_MOD_CLK_PLL_F80M, /*!< Select PLL_F80M as the default choice */
|
|
#else
|
|
RMT_CLK_SRC_DEFAULT = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the default choice */
|
|
#endif
|
|
} soc_periph_rmt_clk_src_t;
|
|
|
|
/**
|
|
* @brief Type of RMT clock source, reserved for the legacy RMT driver
|
|
*/
|
|
typedef enum {
|
|
RMT_BASECLK_PLL_F80M = SOC_MOD_CLK_PLL_F80M, /*!< RMT source clock is PLL_F80M */
|
|
RMT_BASECLK_XTAL = SOC_MOD_CLK_XTAL, /*!< RMT source clock is XTAL */
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
RMT_BASECLK_DEFAULT = SOC_MOD_CLK_PLL_F80M, /*!< RMT source clock default choice is PLL_F80M */
|
|
#else
|
|
RMT_BASECLK_DEFAULT = SOC_MOD_CLK_XTAL, /*!< RMT source clock default choice is XTAL */
|
|
#endif
|
|
} soc_periph_rmt_clk_src_legacy_t;
|
|
|
|
//////////////////////////////////////////////////Temp Sensor///////////////////////////////////////////////////////////
|
|
|
|
///////////////////////////////////////////////////UART/////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Type of UART clock source, reserved for the legacy UART driver
|
|
*/
|
|
typedef enum {
|
|
UART_SCLK_PLL_F80M = SOC_MOD_CLK_PLL_F80M, /*!< UART source clock is PLL_F80M */
|
|
UART_SCLK_RTC = SOC_MOD_CLK_RC_FAST, /*!< UART source clock is RC_FAST */
|
|
UART_SCLK_XTAL = SOC_MOD_CLK_XTAL, /*!< UART source clock is XTAL */
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
UART_SCLK_DEFAULT = SOC_MOD_CLK_PLL_F80M, /*!< UART source clock default choice is PLL_F80M */
|
|
#else
|
|
UART_SCLK_DEFAULT = SOC_MOD_CLK_XTAL, /*!< UART source clock default choice is XTAL for FPGA environment */
|
|
#endif
|
|
} soc_periph_uart_clk_src_legacy_t;
|
|
|
|
/**
|
|
* @brief Type of LP_UART clock source
|
|
*/
|
|
typedef enum {
|
|
LP_UART_SCLK_LP_FAST = SOC_MOD_CLK_RTC_FAST, /*!< LP_UART source clock is LP(RTC)_FAST */
|
|
LP_UART_SCLK_XTAL_D2 = SOC_MOD_CLK_XTAL_D2, /*!< LP_UART source clock is XTAL_D2 */
|
|
LP_UART_SCLK_LP_PLL = SOC_MOD_CLK_LP_PLL, /*!< LP_UART source clock is LP_PLL (8M PLL) */
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
LP_UART_SCLK_DEFAULT = SOC_MOD_CLK_RTC_FAST,
|
|
#else
|
|
LP_UART_SCLK_DEFAULT = SOC_MOD_CLK_XTAL_D2, /*!< LP_UART source clock default choice is XTAL_D2 */
|
|
#endif
|
|
|
|
} soc_periph_lp_uart_clk_src_t;
|
|
|
|
//////////////////////////////////////////////////MCPWM/////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of MCPWM Timer
|
|
*/
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
#define SOC_MCPWM_TIMER_CLKS {SOC_MOD_CLK_PLL_F160M, SOC_MOD_CLK_XTAL}
|
|
#else
|
|
#define SOC_MCPWM_TIMER_CLKS {SOC_MOD_CLK_XTAL}
|
|
#endif
|
|
|
|
/**
|
|
* @brief Type of MCPWM timer clock source
|
|
*/
|
|
typedef enum {
|
|
MCPWM_TIMER_CLK_SRC_PLL160M = SOC_MOD_CLK_PLL_F160M, /*!< Select PLL_F160M as the source clock */
|
|
MCPWM_TIMER_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the source clock */
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
MCPWM_TIMER_CLK_SRC_DEFAULT = SOC_MOD_CLK_PLL_F160M, /*!< Select PLL_F160M as the default choice */
|
|
#else
|
|
MCPWM_TIMER_CLK_SRC_DEFAULT = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the default choice */
|
|
#endif // SOC_CLK_TREE_SUPPORTED
|
|
} soc_periph_mcpwm_timer_clk_src_t;
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of MCPWM Capture Timer
|
|
*/
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
#define SOC_MCPWM_CAPTURE_CLKS {SOC_MOD_CLK_PLL_F160M, SOC_MOD_CLK_XTAL}
|
|
#else
|
|
#define SOC_MCPWM_CAPTURE_CLKS {SOC_MOD_CLK_XTAL}
|
|
#endif
|
|
|
|
/**
|
|
* @brief Type of MCPWM capture clock source
|
|
*/
|
|
typedef enum {
|
|
MCPWM_CAPTURE_CLK_SRC_PLL160M = SOC_MOD_CLK_PLL_F160M, /*!< Select PLL_F160M as the source clock */
|
|
MCPWM_CAPTURE_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the source clock */
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
MCPWM_CAPTURE_CLK_SRC_DEFAULT = SOC_MOD_CLK_PLL_F160M, /*!< Select PLL_F160M as the default choice */
|
|
#else
|
|
MCPWM_CAPTURE_CLK_SRC_DEFAULT = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the default choice */
|
|
#endif // SOC_CLK_TREE_SUPPORTED
|
|
} soc_periph_mcpwm_capture_clk_src_t;
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of MCPWM Carrier
|
|
*/
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
#define SOC_MCPWM_CARRIER_CLKS {SOC_MOD_CLK_PLL_F160M, SOC_MOD_CLK_XTAL}
|
|
#else
|
|
#define SOC_MCPWM_CARRIER_CLKS {SOC_MOD_CLK_XTAL}
|
|
#endif
|
|
|
|
/**
|
|
* @brief Type of MCPWM carrier clock source
|
|
*/
|
|
typedef enum {
|
|
MCPWM_CARRIER_CLK_SRC_PLL160M = SOC_MOD_CLK_PLL_F160M, /*!< Select PLL_F160M as the source clock */
|
|
MCPWM_CARRIER_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the source clock */
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
MCPWM_CARRIER_CLK_SRC_DEFAULT = SOC_MOD_CLK_PLL_F160M, /*!< Select PLL_F160M as the default choice */
|
|
#else
|
|
MCPWM_CARRIER_CLK_SRC_DEFAULT = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the default choice */
|
|
#endif // SOC_CLK_TREE_SUPPORTED
|
|
} soc_periph_mcpwm_carrier_clk_src_t;
|
|
|
|
///////////////////////////////////////////////// I2S //////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of I2S
|
|
*/
|
|
#define SOC_I2S_CLKS {SOC_MOD_CLK_XTAL, SOC_MOD_CLK_APLL, I2S_CLK_SRC_EXTERNAL}
|
|
|
|
/**
|
|
* @brief I2S clock source enum
|
|
*/
|
|
typedef enum {
|
|
I2S_CLK_SRC_DEFAULT = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the default source clock */
|
|
I2S_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the source clock */
|
|
I2S_CLK_SRC_APLL = SOC_MOD_CLK_APLL, /*!< Select APLL as the source clock */
|
|
I2S_CLK_SRC_EXTERNAL = -1, /*!< Select external clock as source clock */
|
|
} soc_periph_i2s_clk_src_t;
|
|
|
|
/////////////////////////////////////////////////I2C////////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of I2C
|
|
*/
|
|
#define SOC_I2C_CLKS {SOC_MOD_CLK_XTAL, SOC_MOD_CLK_RC_FAST}
|
|
/**
|
|
* @brief Type of I2C clock source.
|
|
*/
|
|
typedef enum {
|
|
I2C_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the source clock */
|
|
I2C_CLK_SRC_RC_FAST = SOC_MOD_CLK_RC_FAST, /*!< Select RC_FAST as the source clock */
|
|
I2C_CLK_SRC_DEFAULT = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the default source clock */
|
|
} soc_periph_i2c_clk_src_t;
|
|
/////////////////////////////////////////////////SPI////////////////////////////////////////////////////////////////////
|
|
|
|
//TODO: IDF-7502
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of SPI
|
|
*/
|
|
#define SOC_SPI_CLKS {SOC_MOD_CLK_XTAL, SOC_MOD_CLK_RC_FAST, SOC_MOD_CLK_SPLL}
|
|
|
|
/**
|
|
* @brief Type of SPI clock source.
|
|
*/
|
|
typedef enum {
|
|
SPI_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select XTAL as SPI source clock */
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
SPI_CLK_SRC_RC_FAST = SOC_MOD_CLK_RC_FAST,
|
|
SPI_CLK_SRC_SPLL_480 = SOC_MOD_CLK_SPLL,
|
|
SPI_CLK_SRC_DEFAULT = SPI_CLK_SRC_SPLL_480, /*!< Select SPLL_480M as SPI source clock */
|
|
#else
|
|
SPI_CLK_SRC_DEFAULT = SOC_MOD_CLK_XTAL, /*!< Select XTAL as SPI source clock */
|
|
#endif
|
|
} soc_periph_spi_clk_src_t;
|
|
|
|
/////////////////////////////////////////////////PSRAM////////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of PSRAM
|
|
*/
|
|
#define SOC_PSRAM_CLKS {SOC_MOD_CLK_XTAL, SOC_MOD_CLK_CPLL, SOC_MOD_CLK_SPLL, SOC_MOD_CLK_MPLL}
|
|
|
|
/**
|
|
* @brief Type of PSRAM clock source.
|
|
*/
|
|
typedef enum {
|
|
PSRAM_CLK_SRC_DEFAULT = SOC_MOD_CLK_SPLL, /*!< Select SOC_MOD_CLK_SPLL as PSRAM source clock */
|
|
PSRAM_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select SOC_MOD_CLK_XTAL as PSRAM source clock */
|
|
PSRAM_CLK_SRC_CPLL = SOC_MOD_CLK_CPLL, /*!< Select SOC_MOD_CLK_CPLL as PSRAM source clock */
|
|
PSRAM_CLK_SRC_SPLL = SOC_MOD_CLK_SPLL, /*!< Select SOC_MOD_CLK_SPLL as PSRAM source clock */
|
|
PSRAM_CLK_SRC_MPLL = SOC_MOD_CLK_MPLL, /*!< Select SOC_MOD_CLK_MPLL as PSRAM source clock */
|
|
} soc_periph_psram_clk_src_t;
|
|
|
|
/////////////////////////////////////////////////FLASH////////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of FLASH
|
|
*/
|
|
#define SOC_FLASH_CLKS {SOC_MOD_CLK_XTAL, SOC_MOD_CLK_CPLL, SOC_MOD_CLK_SPLL}
|
|
|
|
/**
|
|
* @brief Type of FLASH clock source.
|
|
*/
|
|
typedef enum {
|
|
FLASH_CLK_SRC_DEFAULT = SOC_MOD_CLK_SPLL, /*!< Select SOC_MOD_CLK_SPLL as FLASH source clock */
|
|
FLASH_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select SOC_MOD_CLK_XTAL as FLASH source clock */
|
|
FLASH_CLK_SRC_CPLL = SOC_MOD_CLK_CPLL, /*!< Select SOC_MOD_CLK_CPLL as FLASH source clock */
|
|
FLASH_CLK_SRC_SPLL = SOC_MOD_CLK_SPLL, /*!< Select SOC_MOD_CLK_SPLL as FLASH source clock */
|
|
} soc_periph_flash_clk_src_t;
|
|
|
|
//////////////////////////////////////////////////SDM//////////////////////////////////////////////////////////////
|
|
|
|
//////////////////////////////////////////////////GPIO Glitch Filter////////////////////////////////////////////////////
|
|
|
|
///////////////////////////////////////////////////Analog Comparator////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of Analog Comparator
|
|
*/
|
|
#define SOC_ANA_CMPR_CLKS {SOC_MOD_CLK_PLL_F80M, SOC_MOD_CLK_XTAL}
|
|
|
|
/**
|
|
* @brief Analog Comparator clock source
|
|
*/
|
|
typedef enum {
|
|
ANA_CMPR_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select XTAL clock as the source clock */
|
|
ANA_CMPR_CLK_SRC_PLL_F80M = SOC_MOD_CLK_PLL_F80M, /*!< Select PLL_F80M clock as the source clock */
|
|
ANA_CMPR_CLK_SRC_DEFAULT = SOC_MOD_CLK_PLL_F80M, /*!< Select PLL_F80M as the default clock choice */
|
|
} soc_periph_ana_cmpr_clk_src_t;
|
|
|
|
//////////////////////////////////////////////////TWAI//////////////////////////////////////////////////////////////////
|
|
|
|
//////////////////////////////////////////////////ADC///////////////////////////////////////////////////////////////////
|
|
|
|
//////////////////////////////////////////////////MWDT/////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of MWDT
|
|
*/
|
|
#define SOC_MWDT_CLKS {SOC_MOD_CLK_XTAL, SOC_MOD_CLK_PLL_F80M, SOC_MOD_CLK_RC_FAST}
|
|
|
|
/**
|
|
* @brief MWDT clock source
|
|
*/
|
|
typedef enum {
|
|
MWDT_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the source clock */
|
|
MWDT_CLK_SRC_PLL_F80M = SOC_MOD_CLK_PLL_F80M, /*!< Select PLL fixed 80 MHz as the source clock */
|
|
MWDT_CLK_SRC_RC_FAST = SOC_MOD_CLK_RC_FAST, /*!< Select RTC fast as the source clock */
|
|
MWDT_CLK_SRC_DEFAULT = SOC_MOD_CLK_XTAL, /*!< Select XTAL 40 MHz as the default clock choice */
|
|
} soc_periph_mwdt_clk_src_t;
|
|
|
|
//////////////////////////////////////////////////LEDC/////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of LEDC
|
|
*/
|
|
#define SOC_LEDC_CLKS {SOC_MOD_CLK_XTAL, SOC_MOD_CLK_PLL_F80M, SOC_MOD_CLK_RC_FAST}
|
|
|
|
/**
|
|
* @brief Type of LEDC clock source, reserved for the legacy LEDC driver
|
|
*/
|
|
typedef enum {
|
|
LEDC_AUTO_CLK = 0, /*!< LEDC source clock will be automatically selected based on the giving resolution and duty parameter when init the timer*/
|
|
LEDC_USE_XTAL_CLK = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the source clock */
|
|
LEDC_USE_PLL_DIV_CLK = SOC_MOD_CLK_PLL_F80M, /*!< Select PLL_F80M clock as the source clock */
|
|
LEDC_USE_RC_FAST_CLK = SOC_MOD_CLK_RC_FAST, /*!< Select RC_FAST as the source clock */
|
|
} soc_periph_ledc_clk_src_legacy_t;
|
|
|
|
//////////////////////////////////////////////////PARLIO////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of PARLIO
|
|
*/
|
|
#define SOC_PARLIO_CLKS {SOC_MOD_CLK_XTAL, SOC_MOD_CLK_PLL_F160M, SOC_MOD_CLK_RC_FAST, PARLIO_CLK_SRC_EXTERNAL}
|
|
|
|
/**
|
|
* @brief PARLIO clock source
|
|
*/
|
|
typedef enum {
|
|
PARLIO_CLK_SRC_XTAL = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the source clock */
|
|
PARLIO_CLK_SRC_PLL_F160M = SOC_MOD_CLK_PLL_F160M, /*!< Select PLL_F160M as the source clock */
|
|
PARLIO_CLK_SRC_RC_FAST = SOC_MOD_CLK_RC_FAST, /*!< Select RC_FAST as the source clock */
|
|
PARLIO_CLK_SRC_EXTERNAL = -1, /*!< Select EXTERNAL clock as the source clock */
|
|
#if SOC_CLK_TREE_SUPPORTED
|
|
PARLIO_CLK_SRC_DEFAULT = SOC_MOD_CLK_PLL_F160M, /*!< Select PLL_F160M as the default clock choice */
|
|
#else
|
|
PARLIO_CLK_SRC_DEFAULT = SOC_MOD_CLK_XTAL, /*!< Select XTAL as the default clock choice */
|
|
#endif
|
|
} soc_periph_parlio_clk_src_t;
|
|
|
|
//////////////////////////////////////////////////SDMMC///////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
* @brief Array initializer for all supported clock sources of SDMMC
|
|
*/
|
|
#define SOC_SDMMC_CLKS {SOC_MOD_CLK_PLL_F160M, SOC_MOD_CLK_PLL_F200M}
|
|
|
|
/**
|
|
* @brief Type of SDMMC clock source
|
|
*/
|
|
typedef enum {
|
|
SDMMC_CLK_SRC_DEFAULT = SOC_MOD_CLK_PLL_F160M, /*!< Select PLL_160M as the default choice */
|
|
SDMMC_CLK_SRC_PLL160M = SOC_MOD_CLK_PLL_F160M, /*!< Select PLL_160M as the source clock */
|
|
SDMMC_CLK_SRC_PLL200M = SOC_MOD_CLK_PLL_F200M, /*!< Select PLL_200M as the source clock */
|
|
} soc_periph_sdmmc_clk_src_t;
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|