mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
2053 lines
66 KiB
C
2053 lines
66 KiB
C
/**
|
|
* SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
#pragma once
|
|
|
|
#include <stdint.h>
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/** Group: Configuration Register */
|
|
/** Type of uart0_conf register
|
|
* UART0 configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** uart0_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable uart0 apb clock
|
|
*/
|
|
uint32_t uart0_clk_en:1;
|
|
/** uart0_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset uart0 module
|
|
*/
|
|
uint32_t uart0_rst_en:1;
|
|
/** uart0_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset uart0 module
|
|
*/
|
|
uint32_t uart0_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_uart0_conf_reg_t;
|
|
|
|
/** Type of uart0_sclk_conf register
|
|
* UART0_SCLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** uart0_sclk_div_a : R/W; bitpos: [5:0]; default: 0;
|
|
* The denominator of the frequency divider factor of the uart0 function clock.
|
|
*/
|
|
uint32_t uart0_sclk_div_a:6;
|
|
/** uart0_sclk_div_b : R/W; bitpos: [11:6]; default: 0;
|
|
* The numerator of the frequency divider factor of the uart0 function clock.
|
|
*/
|
|
uint32_t uart0_sclk_div_b:6;
|
|
/** uart0_sclk_div_num : R/W; bitpos: [19:12]; default: 0;
|
|
* The integral part of the frequency divider factor of the uart0 function clock.
|
|
*/
|
|
uint32_t uart0_sclk_div_num:8;
|
|
/** uart0_sclk_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of UART0.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
* 2: PLL_F80M_CLK\\
|
|
*/
|
|
uint32_t uart0_sclk_sel:2;
|
|
/** uart0_sclk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable uart0 function clock
|
|
*/
|
|
uint32_t uart0_sclk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_uart0_sclk_conf_reg_t;
|
|
|
|
/** Type of uart0_pd_ctrl register
|
|
* UART0 power control register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:1;
|
|
/** uart0_mem_force_pu : R/W; bitpos: [1]; default: 1;
|
|
* Set this bit to force power down UART0 memory.
|
|
*/
|
|
uint32_t uart0_mem_force_pu:1;
|
|
/** uart0_mem_force_pd : R/W; bitpos: [2]; default: 0;
|
|
* Set this bit to force power up UART0 memory.
|
|
*/
|
|
uint32_t uart0_mem_force_pd:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_uart0_pd_ctrl_reg_t;
|
|
|
|
/** Type of uart1_conf register
|
|
* UART1 configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** uart1_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable uart1 apb clock
|
|
*/
|
|
uint32_t uart1_clk_en:1;
|
|
/** uart1_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset uart1 module
|
|
*/
|
|
uint32_t uart1_rst_en:1;
|
|
/** uart1_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset uart1 module
|
|
*/
|
|
uint32_t uart1_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_uart1_conf_reg_t;
|
|
|
|
/** Type of uart1_sclk_conf register
|
|
* UART1_SCLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** uart1_sclk_div_a : R/W; bitpos: [5:0]; default: 0;
|
|
* The denominator of the frequency divider factor of the uart1 function clock.
|
|
*/
|
|
uint32_t uart1_sclk_div_a:6;
|
|
/** uart1_sclk_div_b : R/W; bitpos: [11:6]; default: 0;
|
|
* The numerator of the frequency divider factor of the uart1 function clock.
|
|
*/
|
|
uint32_t uart1_sclk_div_b:6;
|
|
/** uart1_sclk_div_num : R/W; bitpos: [19:12]; default: 0;
|
|
* The integral part of the frequency divider factor of the uart1 function clock.
|
|
*/
|
|
uint32_t uart1_sclk_div_num:8;
|
|
/** uart1_sclk_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of UART1.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
* 2: PLL_F80M_CLK\\
|
|
*/
|
|
uint32_t uart1_sclk_sel:2;
|
|
/** uart1_sclk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable uart1 function clock
|
|
*/
|
|
uint32_t uart1_sclk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_uart1_sclk_conf_reg_t;
|
|
|
|
/** Type of uart1_pd_ctrl register
|
|
* UART1 power control register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:1;
|
|
/** uart1_mem_force_pu : R/W; bitpos: [1]; default: 1;
|
|
* Set this bit to force power down UART1 memory.
|
|
*/
|
|
uint32_t uart1_mem_force_pu:1;
|
|
/** uart1_mem_force_pd : R/W; bitpos: [2]; default: 0;
|
|
* Set this bit to force power up UART1 memory.
|
|
*/
|
|
uint32_t uart1_mem_force_pd:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_uart1_pd_ctrl_reg_t;
|
|
|
|
/** Type of uart2_conf register
|
|
* UART2 configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** uart2_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable uart2 apb clock
|
|
*/
|
|
uint32_t uart2_clk_en:1;
|
|
/** uart2_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset uart2 module
|
|
*/
|
|
uint32_t uart2_rst_en:1;
|
|
/** uart2_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset uart2 module
|
|
*/
|
|
uint32_t uart2_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_uart2_conf_reg_t;
|
|
|
|
/** Type of uart2_sclk_conf register
|
|
* UART2_SCLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** uart2_sclk_div_a : R/W; bitpos: [5:0]; default: 0;
|
|
* The denominator of the frequency divider factor of the uart2 function clock.
|
|
*/
|
|
uint32_t uart2_sclk_div_a:6;
|
|
/** uart2_sclk_div_b : R/W; bitpos: [11:6]; default: 0;
|
|
* The numerator of the frequency divider factor of the uart2 function clock.
|
|
*/
|
|
uint32_t uart2_sclk_div_b:6;
|
|
/** uart2_sclk_div_num : R/W; bitpos: [19:12]; default: 0;
|
|
* The integral part of the frequency divider factor of the uart2 function clock.
|
|
*/
|
|
uint32_t uart2_sclk_div_num:8;
|
|
/** uart2_sclk_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of UART2.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
* 2: PLL_F80M_CLK\\
|
|
*/
|
|
uint32_t uart2_sclk_sel:2;
|
|
/** uart2_sclk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable uart2 function clock
|
|
*/
|
|
uint32_t uart2_sclk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_uart2_sclk_conf_reg_t;
|
|
|
|
/** Type of uart2_pd_ctrl register
|
|
* UART2 power control register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:1;
|
|
/** uart2_mem_force_pu : R/W; bitpos: [1]; default: 1;
|
|
* Set this bit to force power down UART2 memory.
|
|
*/
|
|
uint32_t uart2_mem_force_pu:1;
|
|
/** uart2_mem_force_pd : R/W; bitpos: [2]; default: 0;
|
|
* Set this bit to force power up UART2 memory.
|
|
*/
|
|
uint32_t uart2_mem_force_pd:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_uart2_pd_ctrl_reg_t;
|
|
|
|
/** Type of mspi_conf register
|
|
* MSPI configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** mspi_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable mspi apb clock and mspi pll clock
|
|
*/
|
|
uint32_t mspi_clk_en:1;
|
|
/** mspi_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset mspi module
|
|
*/
|
|
uint32_t mspi_rst_en:1;
|
|
/** mspi_pll_clk_en : R/W; bitpos: [2]; default: 1;
|
|
* Set 1 to enable mspi pll clock
|
|
*/
|
|
uint32_t mspi_pll_clk_en:1;
|
|
/** mspi_ready : RO; bitpos: [3]; default: 1;
|
|
* Query this field after reset mspi module
|
|
*/
|
|
uint32_t mspi_ready:1;
|
|
uint32_t reserved_4:28;
|
|
};
|
|
uint32_t val;
|
|
} pcr_mspi_conf_reg_t;
|
|
|
|
/** Type of mspi_clk_conf register
|
|
* MSPI_CLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** mspi_fast_div_num : R/W; bitpos: [7:0]; default: 0;
|
|
* Set as one within (0,1,2) to generate div1(default)/div2/div4 of low-speed
|
|
* clock-source to drive clk_mspi_fast. Only avaiable whe the clck-source is a
|
|
* low-speed clock-source such as XTAL/FOSC.
|
|
*/
|
|
uint32_t mspi_fast_div_num:8;
|
|
/** mspi_func_clk_sel : R/W; bitpos: [9:8]; default: 0;
|
|
* Configures the clock source for MSPI.\\
|
|
* 0(default): XTAL_CLK\\
|
|
* 1 RC_FAST_CLK\\
|
|
* 2: PLL_F480M_CLK\\
|
|
*/
|
|
uint32_t mspi_func_clk_sel:2;
|
|
/** mspi_func_clk_en : R/W; bitpos: [10]; default: 1;
|
|
* Set 1 to enable mspi func clock
|
|
*/
|
|
uint32_t mspi_func_clk_en:1;
|
|
/** mspi_axi_rst_en : R/W; bitpos: [11]; default: 0;
|
|
* Set 0 to reset axi_clock domain of mspi module
|
|
*/
|
|
uint32_t mspi_axi_rst_en:1;
|
|
uint32_t reserved_12:20;
|
|
};
|
|
uint32_t val;
|
|
} pcr_mspi_clk_conf_reg_t;
|
|
|
|
/** Type of i2c_conf register
|
|
* I2C configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** i2c_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable i2c apb clock
|
|
*/
|
|
uint32_t i2c_clk_en:1;
|
|
/** i2c_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset i2c module
|
|
*/
|
|
uint32_t i2c_rst_en:1;
|
|
uint32_t reserved_2:30;
|
|
};
|
|
uint32_t val;
|
|
} pcr_i2c_conf_reg_t;
|
|
|
|
/** Type of i2c_sclk_conf register
|
|
* I2C_SCLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** i2c_sclk_div_a : R/W; bitpos: [5:0]; default: 0;
|
|
* The denominator of the frequency divider factor of the i2c function clock.
|
|
*/
|
|
uint32_t i2c_sclk_div_a:6;
|
|
/** i2c_sclk_div_b : R/W; bitpos: [11:6]; default: 0;
|
|
* The numerator of the frequency divider factor of the i2c function clock.
|
|
*/
|
|
uint32_t i2c_sclk_div_b:6;
|
|
/** i2c_sclk_div_num : R/W; bitpos: [19:12]; default: 0;
|
|
* The integral part of the frequency divider factor of the i2c function clock.
|
|
*/
|
|
uint32_t i2c_sclk_div_num:8;
|
|
/** i2c_sclk_sel : R/W; bitpos: [20]; default: 0;
|
|
* Configures the clock source of I2C.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
*/
|
|
uint32_t i2c_sclk_sel:1;
|
|
uint32_t reserved_21:1;
|
|
/** i2c_sclk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable i2c function clock
|
|
*/
|
|
uint32_t i2c_sclk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_i2c_sclk_conf_reg_t;
|
|
|
|
/** Type of ledc_conf register
|
|
* LEDC configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** ledc_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable ledc apb clock
|
|
*/
|
|
uint32_t ledc_clk_en:1;
|
|
/** ledc_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset ledc module
|
|
*/
|
|
uint32_t ledc_rst_en:1;
|
|
/** ledc_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset ledc module
|
|
*/
|
|
uint32_t ledc_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_ledc_conf_reg_t;
|
|
|
|
/** Type of ledc_sclk_conf register
|
|
* LEDC_SCLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:20;
|
|
/** ledc_sclk_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of LEDC.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
* 2: PLL_F80M_CLK\\
|
|
*/
|
|
uint32_t ledc_sclk_sel:2;
|
|
/** ledc_sclk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable ledc function clock
|
|
*/
|
|
uint32_t ledc_sclk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_ledc_sclk_conf_reg_t;
|
|
|
|
/** Type of ledc_pd_ctrl register
|
|
* LEDC power control register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:1;
|
|
/** ledc_mem_force_pu : R/W; bitpos: [1]; default: 1;
|
|
* Set this bit to force power down LEDC memory.
|
|
*/
|
|
uint32_t ledc_mem_force_pu:1;
|
|
/** ledc_mem_force_pd : R/W; bitpos: [2]; default: 0;
|
|
* Set this bit to force power up LEDC memory.
|
|
*/
|
|
uint32_t ledc_mem_force_pd:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_ledc_pd_ctrl_reg_t;
|
|
|
|
/** Type of timergroup0_conf register
|
|
* TIMERGROUP0 configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** tg0_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable timer_group0 apb clock
|
|
*/
|
|
uint32_t tg0_clk_en:1;
|
|
/** tg0_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset timer_group0 module
|
|
*/
|
|
uint32_t tg0_rst_en:1;
|
|
/** tg0_wdt_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset timer_group0 wdt module
|
|
*/
|
|
uint32_t tg0_wdt_ready:1;
|
|
/** tg0_timer0_ready : RO; bitpos: [3]; default: 1;
|
|
* Query this field after reset timer_group0 timer0 module
|
|
*/
|
|
uint32_t tg0_timer0_ready:1;
|
|
/** tg0_timer1_ready : RO; bitpos: [4]; default: 1;
|
|
* reserved
|
|
*/
|
|
uint32_t tg0_timer1_ready:1;
|
|
uint32_t reserved_5:27;
|
|
};
|
|
uint32_t val;
|
|
} pcr_timergroup0_conf_reg_t;
|
|
|
|
/** Type of timergroup0_timer_clk_conf register
|
|
* TIMERGROUP0_TIMER_CLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:20;
|
|
/** tg0_timer_clk_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of general-purpose timers in Timer Group 0.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
* 2: PLL_F80M_CLK\\
|
|
*/
|
|
uint32_t tg0_timer_clk_sel:2;
|
|
/** tg0_timer_clk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable timer_group0 timer clock
|
|
*/
|
|
uint32_t tg0_timer_clk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_timergroup0_timer_clk_conf_reg_t;
|
|
|
|
/** Type of timergroup0_wdt_clk_conf register
|
|
* TIMERGROUP0_WDT_CLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:20;
|
|
/** tg0_wdt_clk_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of WDT in Timer Group 0.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
* 2: PLL_F80M_CLK\\
|
|
*/
|
|
uint32_t tg0_wdt_clk_sel:2;
|
|
/** tg0_wdt_clk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable timer_group0 wdt clock
|
|
*/
|
|
uint32_t tg0_wdt_clk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_timergroup0_wdt_clk_conf_reg_t;
|
|
|
|
/** Type of timergroup1_conf register
|
|
* TIMERGROUP1 configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** tg1_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable timer_group1 apb clock
|
|
*/
|
|
uint32_t tg1_clk_en:1;
|
|
/** tg1_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset timer_group1 module
|
|
*/
|
|
uint32_t tg1_rst_en:1;
|
|
/** tg1_wdt_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset timer_group1 wdt module
|
|
*/
|
|
uint32_t tg1_wdt_ready:1;
|
|
/** tg1_timer0_ready : RO; bitpos: [3]; default: 1;
|
|
* Query this field after reset timer_group1 timer0 module
|
|
*/
|
|
uint32_t tg1_timer0_ready:1;
|
|
/** tg1_timer1_ready : RO; bitpos: [4]; default: 1;
|
|
* reserved
|
|
*/
|
|
uint32_t tg1_timer1_ready:1;
|
|
uint32_t reserved_5:27;
|
|
};
|
|
uint32_t val;
|
|
} pcr_timergroup1_conf_reg_t;
|
|
|
|
/** Type of timergroup1_timer_clk_conf register
|
|
* TIMERGROUP1_TIMER_CLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:20;
|
|
/** tg1_timer_clk_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of general-purpose timers in Timer Group 1.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
* 2: PLL_F80M_CLK\\
|
|
*/
|
|
uint32_t tg1_timer_clk_sel:2;
|
|
/** tg1_timer_clk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable timer_group1 timer clock
|
|
*/
|
|
uint32_t tg1_timer_clk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_timergroup1_timer_clk_conf_reg_t;
|
|
|
|
/** Type of timergroup1_wdt_clk_conf register
|
|
* TIMERGROUP1_WDT_CLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:20;
|
|
/** tg1_wdt_clk_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of WDT in Timer Group 1.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
* 2: PLL_F80M_CLK\\
|
|
*/
|
|
uint32_t tg1_wdt_clk_sel:2;
|
|
/** tg1_wdt_clk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable timer_group0 wdt clock
|
|
*/
|
|
uint32_t tg1_wdt_clk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_timergroup1_wdt_clk_conf_reg_t;
|
|
|
|
/** Type of systimer_conf register
|
|
* SYSTIMER configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** systimer_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable systimer apb clock
|
|
*/
|
|
uint32_t systimer_clk_en:1;
|
|
/** systimer_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset systimer module
|
|
*/
|
|
uint32_t systimer_rst_en:1;
|
|
/** systimer_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset systimer module
|
|
*/
|
|
uint32_t systimer_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_systimer_conf_reg_t;
|
|
|
|
/** Type of systimer_func_clk_conf register
|
|
* SYSTIMER_FUNC_CLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:20;
|
|
/** systimer_func_clk_sel : R/W; bitpos: [20]; default: 0;
|
|
* Configures the clock source of System Timer.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
*/
|
|
uint32_t systimer_func_clk_sel:1;
|
|
uint32_t reserved_21:1;
|
|
/** systimer_func_clk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable systimer function clock
|
|
*/
|
|
uint32_t systimer_func_clk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_systimer_func_clk_conf_reg_t;
|
|
|
|
/** Type of i2s_conf register
|
|
* I2S configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** i2s_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable i2s apb clock
|
|
*/
|
|
uint32_t i2s_clk_en:1;
|
|
/** i2s_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset i2s module
|
|
*/
|
|
uint32_t i2s_rst_en:1;
|
|
/** i2s_rx_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field before using i2s rx function, after reset i2s module
|
|
*/
|
|
uint32_t i2s_rx_ready:1;
|
|
/** i2s_tx_ready : RO; bitpos: [3]; default: 1;
|
|
* Query this field before using i2s tx function, after reset i2s module
|
|
*/
|
|
uint32_t i2s_tx_ready:1;
|
|
uint32_t reserved_4:28;
|
|
};
|
|
uint32_t val;
|
|
} pcr_i2s_conf_reg_t;
|
|
|
|
/** Type of i2s_tx_clkm_conf register
|
|
* I2S_TX_CLKM configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:12;
|
|
/** i2s_tx_clkm_div_num : R/W; bitpos: [19:12]; default: 2;
|
|
* Integral I2S TX clock divider value. f_I2S_CLK = f_I2S_CLK_S/(N+b/a). There will be
|
|
* (a-b) * n-div and b * (n+1)-div. So the average combination will be: for b <=
|
|
* a/2, z * [x * n-div + (n+1)-div] + y * n-div. For b > a/2, z * [n-div + x *
|
|
* (n+1)-div] + y * (n+1)-div.
|
|
*/
|
|
uint32_t i2s_tx_clkm_div_num:8;
|
|
/** i2s_tx_clkm_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of I2S TX.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: PLL_F120M_CLK\\
|
|
* 2: PLL_F160M_CLK\\
|
|
* 3: I2S_MCLK_in\\
|
|
*/
|
|
uint32_t i2s_tx_clkm_sel:2;
|
|
/** i2s_tx_clkm_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable i2s_tx function clock
|
|
*/
|
|
uint32_t i2s_tx_clkm_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_i2s_tx_clkm_conf_reg_t;
|
|
|
|
/** Type of i2s_tx_clkm_div_conf register
|
|
* I2S_TX_CLKM_DIV configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** i2s_tx_clkm_div_z : R/W; bitpos: [8:0]; default: 0;
|
|
* For b <= a/2, the value of I2S_TX_CLKM_DIV_Z is b. For b > a/2, the value of
|
|
* I2S_TX_CLKM_DIV_Z is (a-b).
|
|
*/
|
|
uint32_t i2s_tx_clkm_div_z:9;
|
|
/** i2s_tx_clkm_div_y : R/W; bitpos: [17:9]; default: 1;
|
|
* For b <= a/2, the value of I2S_TX_CLKM_DIV_Y is (a%b) . For b > a/2, the value of
|
|
* I2S_TX_CLKM_DIV_Y is (a%(a-b)).
|
|
*/
|
|
uint32_t i2s_tx_clkm_div_y:9;
|
|
/** i2s_tx_clkm_div_x : R/W; bitpos: [26:18]; default: 0;
|
|
* For b <= a/2, the value of I2S_TX_CLKM_DIV_X is (a/b) - 1. For b > a/2, the value
|
|
* of I2S_TX_CLKM_DIV_X is (a/(a-b)) - 1.
|
|
*/
|
|
uint32_t i2s_tx_clkm_div_x:9;
|
|
/** i2s_tx_clkm_div_yn1 : R/W; bitpos: [27]; default: 0;
|
|
* For b <= a/2, the value of I2S_TX_CLKM_DIV_YN1 is 0 . For b > a/2, the value of
|
|
* I2S_TX_CLKM_DIV_YN1 is 1.
|
|
*/
|
|
uint32_t i2s_tx_clkm_div_yn1:1;
|
|
uint32_t reserved_28:4;
|
|
};
|
|
uint32_t val;
|
|
} pcr_i2s_tx_clkm_div_conf_reg_t;
|
|
|
|
/** Type of i2s_rx_clkm_conf register
|
|
* I2S_RX_CLKM configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:12;
|
|
/** i2s_rx_clkm_div_num : R/W; bitpos: [19:12]; default: 2;
|
|
* Integral I2S clock divider value
|
|
*/
|
|
uint32_t i2s_rx_clkm_div_num:8;
|
|
/** i2s_rx_clkm_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of I2S RX.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: PLL_F120M_CLK\\
|
|
* 2: PLL_F160M_CLK\\
|
|
* 3: I2S_MCLK_in\\
|
|
*/
|
|
uint32_t i2s_rx_clkm_sel:2;
|
|
/** i2s_rx_clkm_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable i2s_rx function clock
|
|
*/
|
|
uint32_t i2s_rx_clkm_en:1;
|
|
/** i2s_mclk_sel : R/W; bitpos: [23]; default: 0;
|
|
* Configures to select master clock.\\
|
|
* 0 (default): I2S_TX_CLK\\
|
|
* 1: I2S_RX_CLK\\
|
|
*/
|
|
uint32_t i2s_mclk_sel:1;
|
|
uint32_t reserved_24:8;
|
|
};
|
|
uint32_t val;
|
|
} pcr_i2s_rx_clkm_conf_reg_t;
|
|
|
|
/** Type of i2s_rx_clkm_div_conf register
|
|
* I2S_RX_CLKM_DIV configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** i2s_rx_clkm_div_z : R/W; bitpos: [8:0]; default: 0;
|
|
* For b <= a/2, the value of I2S_RX_CLKM_DIV_Z is b. For b > a/2, the value of
|
|
* I2S_RX_CLKM_DIV_Z is (a-b).
|
|
*/
|
|
uint32_t i2s_rx_clkm_div_z:9;
|
|
/** i2s_rx_clkm_div_y : R/W; bitpos: [17:9]; default: 1;
|
|
* For b <= a/2, the value of I2S_RX_CLKM_DIV_Y is (a%b) . For b > a/2, the value of
|
|
* I2S_RX_CLKM_DIV_Y is (a%(a-b)).
|
|
*/
|
|
uint32_t i2s_rx_clkm_div_y:9;
|
|
/** i2s_rx_clkm_div_x : R/W; bitpos: [26:18]; default: 0;
|
|
* For b <= a/2, the value of I2S_RX_CLKM_DIV_X is (a/b) - 1. For b > a/2, the value
|
|
* of I2S_RX_CLKM_DIV_X is (a/(a-b)) - 1.
|
|
*/
|
|
uint32_t i2s_rx_clkm_div_x:9;
|
|
/** i2s_rx_clkm_div_yn1 : R/W; bitpos: [27]; default: 0;
|
|
* For b <= a/2, the value of I2S_RX_CLKM_DIV_YN1 is 0 . For b > a/2, the value of
|
|
* I2S_RX_CLKM_DIV_YN1 is 1.
|
|
*/
|
|
uint32_t i2s_rx_clkm_div_yn1:1;
|
|
uint32_t reserved_28:4;
|
|
};
|
|
uint32_t val;
|
|
} pcr_i2s_rx_clkm_div_conf_reg_t;
|
|
|
|
/** Type of saradc_conf register
|
|
* SARADC configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** saradc_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* no use
|
|
*/
|
|
uint32_t saradc_clk_en:1;
|
|
/** saradc_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset function_register of saradc module
|
|
*/
|
|
uint32_t saradc_rst_en:1;
|
|
/** saradc_reg_clk_en : R/W; bitpos: [2]; default: 1;
|
|
* Set 1 to enable saradc apb clock
|
|
*/
|
|
uint32_t saradc_reg_clk_en:1;
|
|
/** saradc_reg_rst_en : R/W; bitpos: [3]; default: 0;
|
|
* Set 0 to reset apb_register of saradc module
|
|
*/
|
|
uint32_t saradc_reg_rst_en:1;
|
|
uint32_t reserved_4:28;
|
|
};
|
|
uint32_t val;
|
|
} pcr_saradc_conf_reg_t;
|
|
|
|
/** Type of saradc_clkm_conf register
|
|
* SARADC_CLKM configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** saradc_clkm_div_a : R/W; bitpos: [5:0]; default: 0;
|
|
* The denominator of the frequency divider factor of the saradc function clock.
|
|
*/
|
|
uint32_t saradc_clkm_div_a:6;
|
|
/** saradc_clkm_div_b : R/W; bitpos: [11:6]; default: 0;
|
|
* The numerator of the frequency divider factor of the saradc function clock.
|
|
*/
|
|
uint32_t saradc_clkm_div_b:6;
|
|
/** saradc_clkm_div_num : R/W; bitpos: [19:12]; default: 4;
|
|
* The integral part of the frequency divider factor of the saradc function clock.
|
|
*/
|
|
uint32_t saradc_clkm_div_num:8;
|
|
/** saradc_clkm_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of SAR ADC.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
* 2: PLL_F80M_CLK\\
|
|
*/
|
|
uint32_t saradc_clkm_sel:2;
|
|
/** saradc_clkm_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable saradc function clock
|
|
*/
|
|
uint32_t saradc_clkm_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_saradc_clkm_conf_reg_t;
|
|
|
|
/** Type of tsens_clk_conf register
|
|
* TSENS_CLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:20;
|
|
/** tsens_clk_sel : R/W; bitpos: [20]; default: 0;
|
|
* Configures the clock source of the temperature sensor.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
*/
|
|
uint32_t tsens_clk_sel:1;
|
|
uint32_t reserved_21:1;
|
|
/** tsens_clk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable tsens clock
|
|
*/
|
|
uint32_t tsens_clk_en:1;
|
|
/** tsens_rst_en : R/W; bitpos: [23]; default: 0;
|
|
* Set 0 to reset tsens module
|
|
*/
|
|
uint32_t tsens_rst_en:1;
|
|
uint32_t reserved_24:8;
|
|
};
|
|
uint32_t val;
|
|
} pcr_tsens_clk_conf_reg_t;
|
|
|
|
/** Type of usb_device_conf register
|
|
* USB_DEVICE configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** usb_device_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable usb_device clock
|
|
*/
|
|
uint32_t usb_device_clk_en:1;
|
|
/** usb_device_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset usb_device module
|
|
*/
|
|
uint32_t usb_device_rst_en:1;
|
|
/** usb_device_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset usb_device module
|
|
*/
|
|
uint32_t usb_device_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_usb_device_conf_reg_t;
|
|
|
|
/** Type of intmtx_conf register
|
|
* INTMTX configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** intmtx_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable intmtx clock
|
|
*/
|
|
uint32_t intmtx_clk_en:1;
|
|
/** intmtx_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset intmtx module
|
|
*/
|
|
uint32_t intmtx_rst_en:1;
|
|
/** intmtx_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset intmtx module
|
|
*/
|
|
uint32_t intmtx_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_intmtx_conf_reg_t;
|
|
|
|
/** Type of pvt_monitor_conf register
|
|
* PVT_MONITOR configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** pvt_monitor_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable apb clock of pvt module
|
|
*/
|
|
uint32_t pvt_monitor_clk_en:1;
|
|
/** pvt_monitor_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 1 to reset all pvt monitor module
|
|
*/
|
|
uint32_t pvt_monitor_rst_en:1;
|
|
uint32_t reserved_2:1;
|
|
/** pvt_monitor_site2_clk_en : R/W; bitpos: [3]; default: 1;
|
|
* Set 1 to enable function clock of cpu pvt module
|
|
*/
|
|
uint32_t pvt_monitor_site2_clk_en:1;
|
|
/** pvt_monitor_site2_rst_en : R/W; bitpos: [4]; default: 0;
|
|
* Set 1 to reset cpu pvt monitor site
|
|
*/
|
|
uint32_t pvt_monitor_site2_rst_en:1;
|
|
/** pvt_monitor_site3_clk_en : R/W; bitpos: [5]; default: 1;
|
|
* Set 1 to enable function clock of modem pvt module
|
|
*/
|
|
uint32_t pvt_monitor_site3_clk_en:1;
|
|
uint32_t reserved_6:26;
|
|
};
|
|
uint32_t val;
|
|
} pcr_pvt_monitor_conf_reg_t;
|
|
|
|
/** Type of pvt_monitor_func_clk_conf register
|
|
* PVT_MONITOR function clock configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** pvt_monitor_func_clk_div_num : R/W; bitpos: [3:0]; default: 0;
|
|
* The integral part of the frequency divider factor of the pvt_monitor function clock.
|
|
*/
|
|
uint32_t pvt_monitor_func_clk_div_num:4;
|
|
uint32_t reserved_4:16;
|
|
/** pvt_monitor_func_clk_sel : R/W; bitpos: [20]; default: 0;
|
|
* Configures the clock source of PVT MONITER.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: PLL_F160M_CLK\\
|
|
*/
|
|
uint32_t pvt_monitor_func_clk_sel:1;
|
|
uint32_t reserved_21:1;
|
|
/** pvt_monitor_func_clk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable source clock of pvt sitex
|
|
*/
|
|
uint32_t pvt_monitor_func_clk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_pvt_monitor_func_clk_conf_reg_t;
|
|
|
|
/** Type of gdma_conf register
|
|
* GDMA configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** gdma_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable gdma clock
|
|
*/
|
|
uint32_t gdma_clk_en:1;
|
|
/** gdma_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset gdma module
|
|
*/
|
|
uint32_t gdma_rst_en:1;
|
|
uint32_t reserved_2:30;
|
|
};
|
|
uint32_t val;
|
|
} pcr_gdma_conf_reg_t;
|
|
|
|
/** Type of spi2_conf register
|
|
* SPI2 configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** spi2_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable spi2 apb clock
|
|
*/
|
|
uint32_t spi2_clk_en:1;
|
|
/** spi2_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset spi2 module
|
|
*/
|
|
uint32_t spi2_rst_en:1;
|
|
/** spi2_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset spi2 module
|
|
*/
|
|
uint32_t spi2_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_spi2_conf_reg_t;
|
|
|
|
/** Type of spi2_clkm_conf register
|
|
* SPI2_CLKM configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:12;
|
|
/** spi2_clkm_div_num : R/W; bitpos: [19:12]; default: 0;
|
|
* The integral part of the frequency divider factor of the spi2_mst clock.
|
|
*/
|
|
uint32_t spi2_clkm_div_num:8;
|
|
/** spi2_clkm_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of SPI2.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: PLL_F160M_CLK\\
|
|
* 2: RC_FAST_CLK\\
|
|
*/
|
|
uint32_t spi2_clkm_sel:2;
|
|
/** spi2_clkm_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable spi2 function clock
|
|
*/
|
|
uint32_t spi2_clkm_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_spi2_clkm_conf_reg_t;
|
|
|
|
/** Type of aes_conf register
|
|
* AES configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** aes_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable aes clock
|
|
*/
|
|
uint32_t aes_clk_en:1;
|
|
/** aes_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset aes module
|
|
*/
|
|
uint32_t aes_rst_en:1;
|
|
/** aes_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset aes module
|
|
*/
|
|
uint32_t aes_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_aes_conf_reg_t;
|
|
|
|
/** Type of sha_conf register
|
|
* SHA configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** sha_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable sha clock
|
|
*/
|
|
uint32_t sha_clk_en:1;
|
|
/** sha_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset sha module
|
|
*/
|
|
uint32_t sha_rst_en:1;
|
|
/** sha_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset sha module
|
|
*/
|
|
uint32_t sha_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_sha_conf_reg_t;
|
|
|
|
/** Type of rsa_conf register
|
|
* RSA configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** rsa_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable rsa clock
|
|
*/
|
|
uint32_t rsa_clk_en:1;
|
|
/** rsa_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset rsa module
|
|
*/
|
|
uint32_t rsa_rst_en:1;
|
|
/** rsa_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset rsa module
|
|
*/
|
|
uint32_t rsa_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_rsa_conf_reg_t;
|
|
|
|
/** Type of rsa_pd_ctrl register
|
|
* RSA power control register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** rsa_mem_pd : R/W; bitpos: [0]; default: 0;
|
|
* Set this bit to power down rsa internal memory.
|
|
*/
|
|
uint32_t rsa_mem_pd:1;
|
|
/** rsa_mem_force_pu : R/W; bitpos: [1]; default: 1;
|
|
* Set this bit to force power up rsa internal memory
|
|
*/
|
|
uint32_t rsa_mem_force_pu:1;
|
|
/** rsa_mem_force_pd : R/W; bitpos: [2]; default: 0;
|
|
* Set this bit to force power down rsa internal memory.
|
|
*/
|
|
uint32_t rsa_mem_force_pd:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_rsa_pd_ctrl_reg_t;
|
|
|
|
/** Type of ecc_conf register
|
|
* ECC configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** ecc_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable ecc clock
|
|
*/
|
|
uint32_t ecc_clk_en:1;
|
|
/** ecc_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset ecc module
|
|
*/
|
|
uint32_t ecc_rst_en:1;
|
|
/** ecc_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset ecc module
|
|
*/
|
|
uint32_t ecc_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_ecc_conf_reg_t;
|
|
|
|
/** Type of ecc_pd_ctrl register
|
|
* ECC power control register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** ecc_mem_pd : R/W; bitpos: [0]; default: 0;
|
|
* Set this bit to power down ecc internal memory.
|
|
*/
|
|
uint32_t ecc_mem_pd:1;
|
|
/** ecc_mem_force_pu : R/W; bitpos: [1]; default: 1;
|
|
* Set this bit to force power up ecc internal memory
|
|
*/
|
|
uint32_t ecc_mem_force_pu:1;
|
|
/** ecc_mem_force_pd : R/W; bitpos: [2]; default: 0;
|
|
* Set this bit to force power down ecc internal memory.
|
|
*/
|
|
uint32_t ecc_mem_force_pd:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_ecc_pd_ctrl_reg_t;
|
|
|
|
/** Type of ds_conf register
|
|
* DS configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** ds_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable ds clock
|
|
*/
|
|
uint32_t ds_clk_en:1;
|
|
/** ds_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset ds module
|
|
*/
|
|
uint32_t ds_rst_en:1;
|
|
/** ds_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset ds module
|
|
*/
|
|
uint32_t ds_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_ds_conf_reg_t;
|
|
|
|
/** Type of hmac_conf register
|
|
* HMAC configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** hmac_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable hmac clock
|
|
*/
|
|
uint32_t hmac_clk_en:1;
|
|
/** hmac_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset hmac module
|
|
*/
|
|
uint32_t hmac_rst_en:1;
|
|
/** hmac_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset hmac module
|
|
*/
|
|
uint32_t hmac_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_hmac_conf_reg_t;
|
|
|
|
/** Type of ecdsa_conf register
|
|
* ECDSA configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** ecdsa_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable ecdsa clock
|
|
*/
|
|
uint32_t ecdsa_clk_en:1;
|
|
/** ecdsa_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset ecdsa module
|
|
*/
|
|
uint32_t ecdsa_rst_en:1;
|
|
/** ecdsa_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset ecdsa module
|
|
*/
|
|
uint32_t ecdsa_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_ecdsa_conf_reg_t;
|
|
|
|
/** Type of iomux_conf register
|
|
* IOMUX configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** iomux_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable iomux apb clock
|
|
*/
|
|
uint32_t iomux_clk_en:1;
|
|
/** iomux_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset iomux module
|
|
*/
|
|
uint32_t iomux_rst_en:1;
|
|
uint32_t reserved_2:30;
|
|
};
|
|
uint32_t val;
|
|
} pcr_iomux_conf_reg_t;
|
|
|
|
/** Type of iomux_clk_conf register
|
|
* IOMUX_CLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:20;
|
|
/** iomux_func_clk_sel : R/W; bitpos: [21:20]; default: 0;
|
|
* Configures the clock source of IO MUX.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
* 2: PLL_F80M_CLK\\
|
|
*/
|
|
uint32_t iomux_func_clk_sel:2;
|
|
/** iomux_func_clk_en : R/W; bitpos: [22]; default: 1;
|
|
* Set 1 to enable iomux function clock
|
|
*/
|
|
uint32_t iomux_func_clk_en:1;
|
|
uint32_t reserved_23:9;
|
|
};
|
|
uint32_t val;
|
|
} pcr_iomux_clk_conf_reg_t;
|
|
|
|
/** Type of tcm_mem_monitor_conf register
|
|
* TCM_MEM_MONITOR configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** tcm_mem_monitor_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable tcm_mem_monitor clock
|
|
*/
|
|
uint32_t tcm_mem_monitor_clk_en:1;
|
|
/** tcm_mem_monitor_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset tcm_mem_monitor module
|
|
*/
|
|
uint32_t tcm_mem_monitor_rst_en:1;
|
|
/** tcm_mem_monitor_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset tcm_mem_monitor module
|
|
*/
|
|
uint32_t tcm_mem_monitor_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_tcm_mem_monitor_conf_reg_t;
|
|
|
|
/** Type of psram_mem_monitor_conf register
|
|
* PSRAM_MEM_MONITOR configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** psram_mem_monitor_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable psram_mem_monitor clock
|
|
*/
|
|
uint32_t psram_mem_monitor_clk_en:1;
|
|
/** psram_mem_monitor_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset psram_mem_monitor module
|
|
*/
|
|
uint32_t psram_mem_monitor_rst_en:1;
|
|
/** psram_mem_monitor_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset psram_mem_monitor module
|
|
*/
|
|
uint32_t psram_mem_monitor_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_psram_mem_monitor_conf_reg_t;
|
|
|
|
/** Type of trace_conf register
|
|
* TRACE configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** trace_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable trace clock
|
|
*/
|
|
uint32_t trace_clk_en:1;
|
|
/** trace_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset trace module
|
|
*/
|
|
uint32_t trace_rst_en:1;
|
|
uint32_t reserved_2:30;
|
|
};
|
|
uint32_t val;
|
|
} pcr_trace_conf_reg_t;
|
|
|
|
/** Type of assist_conf register
|
|
* ASSIST configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** assist_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable assist clock
|
|
*/
|
|
uint32_t assist_clk_en:1;
|
|
/** assist_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset assist module
|
|
*/
|
|
uint32_t assist_rst_en:1;
|
|
uint32_t reserved_2:30;
|
|
};
|
|
uint32_t val;
|
|
} pcr_assist_conf_reg_t;
|
|
|
|
/** Type of cache_conf register
|
|
* CACHE configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** cache_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable cache clock
|
|
*/
|
|
uint32_t cache_clk_en:1;
|
|
/** cache_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset cache module
|
|
*/
|
|
uint32_t cache_rst_en:1;
|
|
uint32_t reserved_2:30;
|
|
};
|
|
uint32_t val;
|
|
} pcr_cache_conf_reg_t;
|
|
|
|
/** Type of cache_pd_ctrl register
|
|
* CACHE power control register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:1;
|
|
/** cache_mem_force_pu : R/W; bitpos: [1]; default: 1;
|
|
* Set this bit to force power down CACHE memory.
|
|
*/
|
|
uint32_t cache_mem_force_pu:1;
|
|
/** cache_mem_force_pd : R/W; bitpos: [2]; default: 0;
|
|
* Set this bit to force power up CACHE memory.
|
|
*/
|
|
uint32_t cache_mem_force_pd:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_cache_pd_ctrl_reg_t;
|
|
|
|
/** Type of modem_conf register
|
|
* MODEM_APB configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** modem_apb_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* This field indicates if modem_apb clock is enable. 0: disable, 1: enable(default).
|
|
*/
|
|
uint32_t modem_apb_clk_en:1;
|
|
/** modem_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set this file as 1 to reset modem-subsystem.
|
|
*/
|
|
uint32_t modem_rst_en:1;
|
|
/** modem_clk_en : R/W; bitpos: [2]; default: 1;
|
|
* This field indicates if modem source clock is enable. 0: disable, 1:
|
|
* enable(default).
|
|
*/
|
|
uint32_t modem_clk_en:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_modem_conf_reg_t;
|
|
|
|
/** Type of timeout_conf register
|
|
* TIMEOUT configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:1;
|
|
/** cpu_timeout_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset cpu_peri timeout module
|
|
*/
|
|
uint32_t cpu_timeout_rst_en:1;
|
|
/** hp_timeout_rst_en : R/W; bitpos: [2]; default: 0;
|
|
* Set 0 to reset hp_peri timeout module and hp_modem timeout module
|
|
*/
|
|
uint32_t hp_timeout_rst_en:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_timeout_conf_reg_t;
|
|
|
|
/** Type of sysclk_conf register
|
|
* SYSCLK configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** ls_div_num : HRO; bitpos: [7:0]; default: 0;
|
|
* clk_hproot is div1 of low-speed clock-source if clck-source is a low-speed
|
|
* clock-source such as XTAL/FOSC.
|
|
*/
|
|
uint32_t ls_div_num:8;
|
|
/** hs_div_num : HRO; bitpos: [15:8]; default: 2;
|
|
* clk_hproot is div3 of SPLL if the clock-source is high-speed clock SPLL.
|
|
*/
|
|
uint32_t hs_div_num:8;
|
|
/** soc_clk_sel : R/W; bitpos: [17:16]; default: 0;
|
|
* Configures to select the clock source of HP_ROOT_CLK.\\
|
|
* 0 (default): XTAL_CLK\\
|
|
* 1: RC_FAST_CLK\\
|
|
* 2: PLL_F160M_CLK\\
|
|
*/
|
|
uint32_t soc_clk_sel:2;
|
|
uint32_t reserved_18:6;
|
|
/** clk_xtal_freq : RO; bitpos: [30:24]; default: 40;
|
|
* This field indicates the frequency(MHz) of XTAL.
|
|
*/
|
|
uint32_t clk_xtal_freq:7;
|
|
/** cpu_dbgmd_clk_en : R/W; bitpos: [31]; default: 1;
|
|
* This field indicates if cpu debug mode clock is enable. 0: disable, 1:
|
|
* enable(default).
|
|
*/
|
|
uint32_t cpu_dbgmd_clk_en:1;
|
|
};
|
|
uint32_t val;
|
|
} pcr_sysclk_conf_reg_t;
|
|
|
|
/** Type of cpu_waiti_conf register
|
|
* CPU_WAITI configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** cpuperiod_sel : HRO; bitpos: [1:0]; default: 1;
|
|
* Reserved. This filed has been replaced by PCR_CPU_DIV_NUM
|
|
*/
|
|
uint32_t cpuperiod_sel:2;
|
|
/** pll_freq_sel : HRO; bitpos: [2]; default: 1;
|
|
* Reserved. This filed has been replaced by PCR_CPU_DIV_NUM
|
|
*/
|
|
uint32_t pll_freq_sel:1;
|
|
/** cpu_wait_mode_force_on : R/W; bitpos: [3]; default: 1;
|
|
* Set 1 to force cpu_waiti_clk enable.
|
|
*/
|
|
uint32_t cpu_wait_mode_force_on:1;
|
|
/** cpu_waiti_delay_num : R/W; bitpos: [7:4]; default: 0;
|
|
* This field used to set delay cycle when cpu enter waiti mode, after delay waiti_clk
|
|
* will close
|
|
*/
|
|
uint32_t cpu_waiti_delay_num:4;
|
|
uint32_t reserved_8:24;
|
|
};
|
|
uint32_t val;
|
|
} pcr_cpu_waiti_conf_reg_t;
|
|
|
|
/** Type of cpu_freq_conf register
|
|
* CPU_FREQ configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** cpu_div_num : R/W; bitpos: [7:0]; default: 0;
|
|
* Set this field to generate clk_cpu drived by clk_hproot. The clk_cpu is
|
|
* div1(default)/div2/div4 of clk_hproot. This field is only avaliable for low-speed
|
|
* clock-source such as XTAL/FOSC, and should be used together with PCR_AHB_DIV_NUM.
|
|
*/
|
|
uint32_t cpu_div_num:8;
|
|
uint32_t reserved_8:24;
|
|
};
|
|
uint32_t val;
|
|
} pcr_cpu_freq_conf_reg_t;
|
|
|
|
/** Type of ahb_freq_conf register
|
|
* AHB_FREQ configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** ahb_div_num : R/W; bitpos: [7:0]; default: 0;
|
|
* Set this field to generate clk_ahb drived by clk_hproot. The clk_ahb is
|
|
* div1(default)/div2/div4/div8 of clk_hproot. This field is only avaliable for
|
|
* low-speed clock-source such as XTAL/FOSC, and should be used together with
|
|
* PCR_CPU_DIV_NUM.
|
|
*/
|
|
uint32_t ahb_div_num:8;
|
|
uint32_t reserved_8:24;
|
|
};
|
|
uint32_t val;
|
|
} pcr_ahb_freq_conf_reg_t;
|
|
|
|
/** Type of apb_freq_conf register
|
|
* APB_FREQ configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** apb_decrease_div_num : R/W; bitpos: [7:0]; default: 0;
|
|
* If this field's value is grater than PCR_APB_DIV_NUM, the clk_apb will be
|
|
* automatically down to clk_apb_decrease only when no access is on apb-bus, and will
|
|
* recover to the previous frequency when a new access appears on apb-bus. Set as one
|
|
* within (0,1,3) to set clk_apb_decrease as div1/div2/div4(default) of clk_ahb. Note
|
|
* that enable this function will reduce performance. Users can set this field as zero
|
|
* to disable the auto-decrease-apb-freq function. By default, this function is
|
|
* disable.
|
|
*/
|
|
uint32_t apb_decrease_div_num:8;
|
|
/** apb_div_num : R/W; bitpos: [15:8]; default: 0;
|
|
* Set as one within (0,1,3) to generate clk_apb drived by clk_ahb. The clk_apb is
|
|
* div1(default)/div2/div4 of clk_ahb.
|
|
*/
|
|
uint32_t apb_div_num:8;
|
|
uint32_t reserved_16:16;
|
|
};
|
|
uint32_t val;
|
|
} pcr_apb_freq_conf_reg_t;
|
|
|
|
/** Type of pll_div_clk_en register
|
|
* SPLL DIV clock-gating configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
uint32_t reserved_0:1;
|
|
/** pll_160m_clk_en : R/W; bitpos: [1]; default: 1;
|
|
* This field is used to open 160 MHz clock (div3 of SPLL) drived from SPLL. 0: close,
|
|
* 1: open(default). Only avaliable when high-speed clock-source SPLL is active.
|
|
*/
|
|
uint32_t pll_160m_clk_en:1;
|
|
/** pll_120m_clk_en : R/W; bitpos: [2]; default: 1;
|
|
* This field is used to open 120 MHz clock (div4 of SPLL) drived from SPLL. 0: close,
|
|
* 1: open(default). Only avaliable when high-speed clock-source SPLL is active.
|
|
*/
|
|
uint32_t pll_120m_clk_en:1;
|
|
/** pll_80m_clk_en : R/W; bitpos: [3]; default: 1;
|
|
* This field is used to open 80 MHz clock (div6 of SPLL) drived from SPLL. 0: close,
|
|
* 1: open(default). Only avaliable when high-speed clock-source SPLL is active.
|
|
*/
|
|
uint32_t pll_80m_clk_en:1;
|
|
/** pll_60m_clk_en : R/W; bitpos: [4]; default: 1;
|
|
* This field is used to open 60 MHz clock (div8 of SPLL) drived from SPLL. 0: close,
|
|
* 1: open(default). Only avaliable when high-speed clock-source SPLL is active.
|
|
*/
|
|
uint32_t pll_60m_clk_en:1;
|
|
/** pll_48m_clk_en : R/W; bitpos: [5]; default: 1;
|
|
* This field is used to open 48 MHz clock (div10 of SPLL) drived from SPLL. 0: close,
|
|
* 1: open(default). Only avaliable when high-speed clock-source SPLL is active.
|
|
*/
|
|
uint32_t pll_48m_clk_en:1;
|
|
/** pll_40m_clk_en : R/W; bitpos: [6]; default: 1;
|
|
* This field is used to open 40 MHz clock (div12 of SPLL) drived from SPLL. 0: close,
|
|
* 1: open(default). Only avaliable when high-speed clock-source SPLL is active.
|
|
*/
|
|
uint32_t pll_40m_clk_en:1;
|
|
/** pll_20m_clk_en : R/W; bitpos: [7]; default: 1;
|
|
* This field is used to open 20 MHz clock (div24 of SPLL) drived from SPLL. 0: close,
|
|
* 1: open(default). Only avaliable when high-speed clock-source SPLL is active.
|
|
*/
|
|
uint32_t pll_20m_clk_en:1;
|
|
/** pll_12m_clk_en : HRO; bitpos: [8]; default: 1;
|
|
* This field is used to open 12 MHz clock (div40 of SPLL) drived from SPLL. 0: close,
|
|
* 1: open(default). Only avaliable when high-speed clock-source SPLL is active.
|
|
*/
|
|
uint32_t pll_12m_clk_en:1;
|
|
uint32_t reserved_9:23;
|
|
};
|
|
uint32_t val;
|
|
} pcr_pll_div_clk_en_reg_t;
|
|
|
|
/** Type of ctrl_clk_out_en register
|
|
* CLK_OUT_EN configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** clk20_oen : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable 20m clock
|
|
*/
|
|
uint32_t clk20_oen:1;
|
|
/** clk22_oen : R/W; bitpos: [1]; default: 1;
|
|
* Set 1 to enable 22m clock
|
|
*/
|
|
uint32_t clk22_oen:1;
|
|
/** clk44_oen : R/W; bitpos: [2]; default: 1;
|
|
* Set 1 to enable 44m clock
|
|
*/
|
|
uint32_t clk44_oen:1;
|
|
/** clk_bb_oen : R/W; bitpos: [3]; default: 1;
|
|
* Set 1 to enable bb clock
|
|
*/
|
|
uint32_t clk_bb_oen:1;
|
|
/** clk80_oen : R/W; bitpos: [4]; default: 1;
|
|
* Set 1 to enable 80m clock
|
|
*/
|
|
uint32_t clk80_oen:1;
|
|
/** clk160_oen : R/W; bitpos: [5]; default: 1;
|
|
* Set 1 to enable 160m clock
|
|
*/
|
|
uint32_t clk160_oen:1;
|
|
/** clk_320m_oen : R/W; bitpos: [6]; default: 1;
|
|
* Set 1 to enable 320m clock
|
|
*/
|
|
uint32_t clk_320m_oen:1;
|
|
/** clk_adc_inf_oen : R/W; bitpos: [7]; default: 1;
|
|
* Reserved
|
|
*/
|
|
uint32_t clk_adc_inf_oen:1;
|
|
/** clk_dac_cpu_oen : R/W; bitpos: [8]; default: 1;
|
|
* Reserved
|
|
*/
|
|
uint32_t clk_dac_cpu_oen:1;
|
|
/** clk_xtal_oen : R/W; bitpos: [9]; default: 1;
|
|
* Set 1 to enable xtal clock
|
|
*/
|
|
uint32_t clk_xtal_oen:1;
|
|
uint32_t reserved_10:22;
|
|
};
|
|
uint32_t val;
|
|
} pcr_ctrl_clk_out_en_reg_t;
|
|
|
|
/** Type of ctrl_32k_conf register
|
|
* 32KHz clock configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** 32k_sel : R/W; bitpos: [2:0]; default: 0;
|
|
* Configures the 32KHz clock for TIMER_GROUP.\\
|
|
* 0 (default): RC32K_CLK\\
|
|
* 1: XTAL32K_CLK\\
|
|
* 2: OSC_SLOW_CLK\\
|
|
* 3: RC_SLOW_CLK\\
|
|
* 4: RC_FAST_CLK\\
|
|
*/
|
|
uint32_t clk_32k_sel:3;
|
|
uint32_t reserved_3:5;
|
|
/** fosc_tick_num : R/W; bitpos: [15:8]; default: 7;
|
|
* When PCR_32K_SEL set as 4, This field PCR_FOSC_TICK_NUM is used to set the divider
|
|
* number of fosc.
|
|
*/
|
|
uint32_t fosc_tick_num:8;
|
|
uint32_t reserved_16:16;
|
|
};
|
|
uint32_t val;
|
|
} pcr_ctrl_32k_conf_reg_t;
|
|
|
|
/** Type of sram_power_conf_0 register
|
|
* HP SRAM/ROM configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** rom_force_pu : R/W; bitpos: [1:0]; default: 3;
|
|
* Set this bit to force power up ROM
|
|
*/
|
|
uint32_t rom_force_pu:2;
|
|
/** rom_force_pd : R/W; bitpos: [3:2]; default: 0;
|
|
* Set this bit to force power down ROM.
|
|
*/
|
|
uint32_t rom_force_pd:2;
|
|
/** rom_clkgate_force_on : R/W; bitpos: [5:4]; default: 0;
|
|
* 1: Force to open the clock and bypass the gate-clock when accessing the ROM. 0: A
|
|
* gate-clock will be used when accessing the ROM.
|
|
*/
|
|
uint32_t rom_clkgate_force_on:2;
|
|
uint32_t reserved_6:26;
|
|
};
|
|
uint32_t val;
|
|
} pcr_sram_power_conf_0_reg_t;
|
|
|
|
/** Type of sram_power_conf_1 register
|
|
* HP SRAM/ROM configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** sram_force_pu : R/W; bitpos: [4:0]; default: 31;
|
|
* Set this bit to force power up SRAM
|
|
*/
|
|
uint32_t sram_force_pu:5;
|
|
uint32_t reserved_5:5;
|
|
/** sram_force_pd : R/W; bitpos: [14:10]; default: 0;
|
|
* Set this bit to force power down SRAM.
|
|
*/
|
|
uint32_t sram_force_pd:5;
|
|
uint32_t reserved_15:5;
|
|
/** sram_clkgate_force_on : R/W; bitpos: [24:20]; default: 0;
|
|
* 1: Force to open the clock and bypass the gate-clock when accessing the SRAM. 0: A
|
|
* gate-clock will be used when accessing the SRAM.
|
|
*/
|
|
uint32_t sram_clkgate_force_on:5;
|
|
uint32_t reserved_25:7;
|
|
};
|
|
uint32_t val;
|
|
} pcr_sram_power_conf_1_reg_t;
|
|
|
|
/** Type of sec_conf register
|
|
* Clock source configuration register for External Memory Encryption and Decryption
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** sec_clk_sel : R/W; bitpos: [1:0]; default: 0;
|
|
* Configures the clock source for the External Memory Encryption and Decryption
|
|
* module.\\
|
|
* 0(default): XTAL_CLK\\
|
|
* 1 RC_FAST_CLK\\
|
|
* 2: PLL_F480M_CLK\\
|
|
*/
|
|
uint32_t sec_clk_sel:2;
|
|
/** sec_rst_en : R/W; bitpos: [2]; default: 0;
|
|
* Set 0 to reset sec module
|
|
*/
|
|
uint32_t sec_rst_en:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_sec_conf_reg_t;
|
|
|
|
/** Type of adc_dac_inv_phase_conf register
|
|
* xxxx
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** clk_rx_adc_inv_phase_ena : R/W; bitpos: [0]; default: 0;
|
|
* xxxx
|
|
*/
|
|
uint32_t clk_rx_adc_inv_phase_ena:1;
|
|
/** clk_tx_dac_inv_phase_ena : R/W; bitpos: [1]; default: 0;
|
|
* xxxx
|
|
*/
|
|
uint32_t clk_tx_dac_inv_phase_ena:1;
|
|
uint32_t reserved_2:30;
|
|
};
|
|
uint32_t val;
|
|
} pcr_adc_dac_inv_phase_conf_reg_t;
|
|
|
|
/** Type of bus_clk_update register
|
|
* Configuration register for applying updated high-performance system clock sources
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** bus_clock_update : R/W/WTC; bitpos: [0]; default: 0;
|
|
* Configures whether or not to update configurations for CPU_CLK division, AHB_CLK
|
|
* division and HP_ROOT_CLK clock source selection.\\
|
|
* 0: Not update configurations\\
|
|
* 1: Update configurations\\
|
|
* This bit is automatically cleared when configurations have been updated.\\
|
|
*/
|
|
uint32_t bus_clock_update:1;
|
|
uint32_t reserved_1:31;
|
|
};
|
|
uint32_t val;
|
|
} pcr_bus_clk_update_reg_t;
|
|
|
|
/** Type of sar_clk_div register
|
|
* SAR ADC clock divisor configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** sar2_clk_div_num : R/W; bitpos: [7:0]; default: 4;
|
|
* Configures the divisor for SAR ADC 2 clock to generate ADC analog control
|
|
* signals.\\
|
|
*/
|
|
uint32_t sar2_clk_div_num:8;
|
|
/** sar1_clk_div_num : R/W; bitpos: [15:8]; default: 4;
|
|
* Configures the divisor for SAR ADC 1 clock to generate ADC analog control
|
|
* signals.\\
|
|
*/
|
|
uint32_t sar1_clk_div_num:8;
|
|
uint32_t reserved_16:16;
|
|
};
|
|
uint32_t val;
|
|
} pcr_sar_clk_div_reg_t;
|
|
|
|
/** Type of pwdet_sar_clk_conf register
|
|
* xxxx
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** pwdet_sar_clk_div_num : R/W; bitpos: [7:0]; default: 7;
|
|
* xxxx
|
|
*/
|
|
uint32_t pwdet_sar_clk_div_num:8;
|
|
/** pwdet_sar_clk_en : R/W; bitpos: [8]; default: 1;
|
|
* xxxx
|
|
*/
|
|
uint32_t pwdet_sar_clk_en:1;
|
|
uint32_t reserved_9:23;
|
|
};
|
|
uint32_t val;
|
|
} pcr_pwdet_sar_clk_conf_reg_t;
|
|
|
|
/** Type of timergroup_wdt_conf register
|
|
* TIMERGROUP_WDT configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** tg0_wdt_rst_en : R/W; bitpos: [0]; default: 0;
|
|
* Set 0 to reset timer_group0 wdt module
|
|
*/
|
|
uint32_t tg0_wdt_rst_en:1;
|
|
/** tg1_wdt_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset timer_group1 wdt module
|
|
*/
|
|
uint32_t tg1_wdt_rst_en:1;
|
|
uint32_t reserved_2:30;
|
|
};
|
|
uint32_t val;
|
|
} pcr_timergroup_wdt_conf_reg_t;
|
|
|
|
/** Type of timergroup_xtal_conf register
|
|
* TIMERGROUP1 configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** tg0_xtal_rst_en : R/W; bitpos: [0]; default: 0;
|
|
* Set 0 to reset timer_group0 xtal clock domain
|
|
*/
|
|
uint32_t tg0_xtal_rst_en:1;
|
|
/** tg1_xtal_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset timer_group1 xtal clock domain
|
|
*/
|
|
uint32_t tg1_xtal_rst_en:1;
|
|
/** tg0_xtal_clk_en : R/W; bitpos: [2]; default: 1;
|
|
* Set 1 to enable tg0 xtal clock
|
|
*/
|
|
uint32_t tg0_xtal_clk_en:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_timergroup_xtal_conf_reg_t;
|
|
|
|
/** Type of reset_event_bypass register
|
|
* reset event bypass backdoor configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** reset_event_bypass_apm : R/W; bitpos: [0]; default: 0;
|
|
* This field is used to control reset event relationship for
|
|
* tee_reg/apm_reg/hp_system_reg. 1: tee_reg/apm_reg/hp_system_reg will only be reset
|
|
* by power-reset. some reset event will be bypass. 0: tee_reg/apm_reg/hp_system_reg
|
|
* will not only be reset by power-reset, but also some reset event.
|
|
*/
|
|
uint32_t reset_event_bypass_apm:1;
|
|
/** reset_event_bypass : R/W; bitpos: [1]; default: 1;
|
|
* This field is used to control reset event relationship for system-bus. 1: system
|
|
* bus (including arbiter/router) will only be reset by power-reset. some reset event
|
|
* will be bypass. 0: system bus (including arbiter/router) will not only be reset by
|
|
* power-reset, but also some reset event.
|
|
*/
|
|
uint32_t reset_event_bypass:1;
|
|
uint32_t reserved_2:30;
|
|
};
|
|
uint32_t val;
|
|
} pcr_reset_event_bypass_reg_t;
|
|
|
|
/** Type of regdma_conf register
|
|
* REGDMA configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** regdma_clk_en : R/W; bitpos: [0]; default: 0;
|
|
* Set 1 to enable regdma clock
|
|
*/
|
|
uint32_t regdma_clk_en:1;
|
|
/** regdma_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset regdma module
|
|
*/
|
|
uint32_t regdma_rst_en:1;
|
|
uint32_t reserved_2:30;
|
|
};
|
|
uint32_t val;
|
|
} pcr_regdma_conf_reg_t;
|
|
|
|
/** Type of etm_conf register
|
|
* ETM configuration register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** etm_clk_en : R/W; bitpos: [0]; default: 1;
|
|
* Set 1 to enable etm clock
|
|
*/
|
|
uint32_t etm_clk_en:1;
|
|
/** etm_rst_en : R/W; bitpos: [1]; default: 0;
|
|
* Set 0 to reset etm module
|
|
*/
|
|
uint32_t etm_rst_en:1;
|
|
/** etm_ready : RO; bitpos: [2]; default: 1;
|
|
* Query this field after reset etm module
|
|
*/
|
|
uint32_t etm_ready:1;
|
|
uint32_t reserved_3:29;
|
|
};
|
|
uint32_t val;
|
|
} pcr_etm_conf_reg_t;
|
|
|
|
/** Type of clock_gate register
|
|
* PCR clock gating configure register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** clk_en : R/W; bitpos: [0]; default: 0;
|
|
* Set this bit as 1 to force on clock gating.
|
|
*/
|
|
uint32_t clk_en:1;
|
|
uint32_t reserved_1:31;
|
|
};
|
|
uint32_t val;
|
|
} pcr_clock_gate_reg_t;
|
|
|
|
|
|
/** Group: Frequency Statistics Register */
|
|
/** Type of sysclk_freq_query_0 register
|
|
* SYSCLK frequency query 0 register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** fosc_freq : HRO; bitpos: [7:0]; default: 8;
|
|
* This field indicates the frequency(MHz) of FOSC.
|
|
*/
|
|
uint32_t fosc_freq:8;
|
|
/** pll_freq : HRO; bitpos: [17:8]; default: 96;
|
|
* This field indicates the frequency(MHz) of SPLL.
|
|
*/
|
|
uint32_t pll_freq:10;
|
|
uint32_t reserved_18:14;
|
|
};
|
|
uint32_t val;
|
|
} pcr_sysclk_freq_query_0_reg_t;
|
|
|
|
|
|
/** Group: FPGA Debug Register */
|
|
/** Type of fpga_debug register
|
|
* fpga debug register
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** fpga_debug : R/W; bitpos: [31:0]; default: 4294967295;
|
|
* Only used in fpga debug.
|
|
*/
|
|
uint32_t fpga_debug:32;
|
|
};
|
|
uint32_t val;
|
|
} pcr_fpga_debug_reg_t;
|
|
|
|
|
|
/** Group: Version Register */
|
|
/** Type of date register
|
|
* Date register.
|
|
*/
|
|
typedef union {
|
|
struct {
|
|
/** date : R/W; bitpos: [27:0]; default: 37753376;
|
|
* PCR version information.
|
|
*/
|
|
uint32_t date:28;
|
|
uint32_t reserved_28:4;
|
|
};
|
|
uint32_t val;
|
|
} pcr_date_reg_t;
|
|
|
|
|
|
typedef struct {
|
|
volatile pcr_uart0_conf_reg_t uart0_conf;
|
|
volatile pcr_uart0_sclk_conf_reg_t uart0_sclk_conf;
|
|
volatile pcr_uart0_pd_ctrl_reg_t uart0_pd_ctrl;
|
|
volatile pcr_uart1_conf_reg_t uart1_conf;
|
|
volatile pcr_uart1_sclk_conf_reg_t uart1_sclk_conf;
|
|
volatile pcr_uart1_pd_ctrl_reg_t uart1_pd_ctrl;
|
|
volatile pcr_uart2_conf_reg_t uart2_conf;
|
|
volatile pcr_uart2_sclk_conf_reg_t uart2_sclk_conf;
|
|
volatile pcr_uart2_pd_ctrl_reg_t uart2_pd_ctrl;
|
|
volatile pcr_mspi_conf_reg_t mspi_conf;
|
|
volatile pcr_mspi_clk_conf_reg_t mspi_clk_conf;
|
|
volatile pcr_i2c_conf_reg_t i2c_conf;
|
|
volatile pcr_i2c_sclk_conf_reg_t i2c_sclk_conf;
|
|
volatile pcr_ledc_conf_reg_t ledc_conf;
|
|
volatile pcr_ledc_sclk_conf_reg_t ledc_sclk_conf;
|
|
volatile pcr_ledc_pd_ctrl_reg_t ledc_pd_ctrl;
|
|
volatile pcr_timergroup0_conf_reg_t timergroup0_conf;
|
|
volatile pcr_timergroup0_timer_clk_conf_reg_t timergroup0_timer_clk_conf;
|
|
volatile pcr_timergroup0_wdt_clk_conf_reg_t timergroup0_wdt_clk_conf;
|
|
volatile pcr_timergroup1_conf_reg_t timergroup1_conf;
|
|
volatile pcr_timergroup1_timer_clk_conf_reg_t timergroup1_timer_clk_conf;
|
|
volatile pcr_timergroup1_wdt_clk_conf_reg_t timergroup1_wdt_clk_conf;
|
|
volatile pcr_systimer_conf_reg_t systimer_conf;
|
|
volatile pcr_systimer_func_clk_conf_reg_t systimer_func_clk_conf;
|
|
volatile pcr_i2s_conf_reg_t i2s_conf;
|
|
volatile pcr_i2s_tx_clkm_conf_reg_t i2s_tx_clkm_conf;
|
|
volatile pcr_i2s_tx_clkm_div_conf_reg_t i2s_tx_clkm_div_conf;
|
|
volatile pcr_i2s_rx_clkm_conf_reg_t i2s_rx_clkm_conf;
|
|
volatile pcr_i2s_rx_clkm_div_conf_reg_t i2s_rx_clkm_div_conf;
|
|
volatile pcr_saradc_conf_reg_t saradc_conf;
|
|
volatile pcr_saradc_clkm_conf_reg_t saradc_clkm_conf;
|
|
volatile pcr_tsens_clk_conf_reg_t tsens_clk_conf;
|
|
volatile pcr_usb_device_conf_reg_t usb_device_conf;
|
|
volatile pcr_intmtx_conf_reg_t intmtx_conf;
|
|
volatile pcr_pvt_monitor_conf_reg_t pvt_monitor_conf;
|
|
volatile pcr_pvt_monitor_func_clk_conf_reg_t pvt_monitor_func_clk_conf;
|
|
volatile pcr_gdma_conf_reg_t gdma_conf;
|
|
volatile pcr_spi2_conf_reg_t spi2_conf;
|
|
volatile pcr_spi2_clkm_conf_reg_t spi2_clkm_conf;
|
|
volatile pcr_aes_conf_reg_t aes_conf;
|
|
volatile pcr_sha_conf_reg_t sha_conf;
|
|
volatile pcr_rsa_conf_reg_t rsa_conf;
|
|
volatile pcr_rsa_pd_ctrl_reg_t rsa_pd_ctrl;
|
|
volatile pcr_ecc_conf_reg_t ecc_conf;
|
|
volatile pcr_ecc_pd_ctrl_reg_t ecc_pd_ctrl;
|
|
volatile pcr_ds_conf_reg_t ds_conf;
|
|
volatile pcr_hmac_conf_reg_t hmac_conf;
|
|
volatile pcr_ecdsa_conf_reg_t ecdsa_conf;
|
|
volatile pcr_iomux_conf_reg_t iomux_conf;
|
|
volatile pcr_iomux_clk_conf_reg_t iomux_clk_conf;
|
|
volatile pcr_tcm_mem_monitor_conf_reg_t tcm_mem_monitor_conf;
|
|
volatile pcr_psram_mem_monitor_conf_reg_t psram_mem_monitor_conf;
|
|
volatile pcr_trace_conf_reg_t trace_conf;
|
|
volatile pcr_assist_conf_reg_t assist_conf;
|
|
volatile pcr_cache_conf_reg_t cache_conf;
|
|
volatile pcr_cache_pd_ctrl_reg_t cache_pd_ctrl;
|
|
volatile pcr_modem_conf_reg_t modem_conf;
|
|
volatile pcr_timeout_conf_reg_t timeout_conf;
|
|
volatile pcr_sysclk_conf_reg_t sysclk_conf;
|
|
volatile pcr_cpu_waiti_conf_reg_t cpu_waiti_conf;
|
|
volatile pcr_cpu_freq_conf_reg_t cpu_freq_conf;
|
|
volatile pcr_ahb_freq_conf_reg_t ahb_freq_conf;
|
|
volatile pcr_apb_freq_conf_reg_t apb_freq_conf;
|
|
volatile pcr_sysclk_freq_query_0_reg_t sysclk_freq_query_0;
|
|
volatile pcr_pll_div_clk_en_reg_t pll_div_clk_en;
|
|
volatile pcr_ctrl_clk_out_en_reg_t ctrl_clk_out_en;
|
|
uint32_t reserved_108;
|
|
volatile pcr_ctrl_32k_conf_reg_t ctrl_32k_conf;
|
|
volatile pcr_sram_power_conf_0_reg_t sram_power_conf_0;
|
|
volatile pcr_sram_power_conf_1_reg_t sram_power_conf_1;
|
|
volatile pcr_sec_conf_reg_t sec_conf;
|
|
volatile pcr_adc_dac_inv_phase_conf_reg_t adc_dac_inv_phase_conf;
|
|
volatile pcr_bus_clk_update_reg_t bus_clk_update;
|
|
volatile pcr_sar_clk_div_reg_t sar_clk_div;
|
|
volatile pcr_pwdet_sar_clk_conf_reg_t pwdet_sar_clk_conf;
|
|
volatile pcr_timergroup_wdt_conf_reg_t timergroup_wdt_conf;
|
|
volatile pcr_timergroup_xtal_conf_reg_t timergroup_xtal_conf;
|
|
volatile pcr_reset_event_bypass_reg_t reset_event_bypass;
|
|
volatile pcr_regdma_conf_reg_t regdma_conf;
|
|
volatile pcr_etm_conf_reg_t etm_conf;
|
|
uint32_t reserved_140[941];
|
|
volatile pcr_fpga_debug_reg_t fpga_debug;
|
|
volatile pcr_clock_gate_reg_t clock_gate;
|
|
volatile pcr_date_reg_t date;
|
|
} pcr_dev_t;
|
|
|
|
extern pcr_dev_t PCR;
|
|
|
|
#ifndef __cplusplus
|
|
_Static_assert(sizeof(pcr_dev_t) == 0x1000, "Invalid size of pcr_dev_t structure");
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|