esp-idf/components/soc/esp32c5/beta3/include/soc/pcr_struct.h
2024-03-01 10:16:14 +08:00

2240 lines
71 KiB
C

/**
* SPDX-FileCopyrightText: 2023-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;
* set this field to select clock-source. 0: XTAL, 1: fosc, 2: 80MHz
*/
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;
* set this field to select clock-source. 0: XTAL, 1: fosc, 2: 80MHz
*/
uint32_t uart1_sclk_sel:2;
/** uart1_sclk_en : R/W; bitpos: [22]; default: 1;
* Set 1 to enable uart0 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 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;
* set this field to select clock-source.
*/
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;
* set this field to select clock-source. 0(default): XTAL, 1: FOSC.
*/
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 twai0_conf register
* TWAI0 configuration register
*/
typedef union {
struct {
/** twai0_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable twai0 apb clock
*/
uint32_t twai0_clk_en:1;
/** twai0_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset twai0 module
*/
uint32_t twai0_rst_en:1;
/** twai0_ready : RO; bitpos: [2]; default: 1;
* Query this field after reset twai0 module
*/
uint32_t twai0_ready:1;
uint32_t reserved_3:29;
};
uint32_t val;
} pcr_twai0_conf_reg_t;
/** Type of twai0_func_clk_conf register
* TWAI0_FUNC_CLK configuration register
*/
typedef union {
struct {
uint32_t reserved_0:20;
/** twai0_func_clk_sel : R/W; bitpos: [20]; default: 0;
* set this field to select clock-source. 0(default): XTAL, 1: FOSC.
*/
uint32_t twai0_func_clk_sel:1;
uint32_t reserved_21:1;
/** twai0_func_clk_en : R/W; bitpos: [22]; default: 1;
* Set 1 to enable twai0 function clock
*/
uint32_t twai0_func_clk_en:1;
uint32_t reserved_23:9;
};
uint32_t val;
} pcr_twai0_func_clk_conf_reg_t;
/** Type of twai1_conf register
* TWAI1 configuration register
*/
typedef union {
struct {
/** twai1_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable twai1 apb clock
*/
uint32_t twai1_clk_en:1;
/** twai1_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset twai1 module
*/
uint32_t twai1_rst_en:1;
/** twai1_ready : RO; bitpos: [2]; default: 1;
* Query this field after reset twai1 module
*/
uint32_t twai1_ready:1;
uint32_t reserved_3:29;
};
uint32_t val;
} pcr_twai1_conf_reg_t;
/** Type of twai1_func_clk_conf register
* TWAI1_FUNC_CLK configuration register
*/
typedef union {
struct {
uint32_t reserved_0:20;
/** twai1_func_clk_sel : R/W; bitpos: [20]; default: 0;
* set this field to select clock-source. 0(default): XTAL, 1: FOSC.
*/
uint32_t twai1_func_clk_sel:1;
uint32_t reserved_21:1;
/** twai1_func_clk_en : R/W; bitpos: [22]; default: 1;
* Set 1 to enable twai1 function clock
*/
uint32_t twai1_func_clk_en:1;
uint32_t reserved_23:9;
};
uint32_t val;
} pcr_twai1_func_clk_conf_reg_t;
/** Type of uhci_conf register
* UHCI configuration register
*/
typedef union {
struct {
/** uhci_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable uhci clock
*/
uint32_t uhci_clk_en:1;
/** uhci_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset uhci module
*/
uint32_t uhci_rst_en:1;
/** uhci_ready : RO; bitpos: [2]; default: 1;
* Query this field after reset uhci module
*/
uint32_t uhci_ready:1;
uint32_t reserved_3:29;
};
uint32_t val;
} pcr_uhci_conf_reg_t;
/** Type of rmt_conf register
* RMT configuration register
*/
typedef union {
struct {
/** rmt_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable rmt apb clock
*/
uint32_t rmt_clk_en:1;
/** rmt_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset rmt module
*/
uint32_t rmt_rst_en:1;
uint32_t reserved_2:30;
};
uint32_t val;
} pcr_rmt_conf_reg_t;
/** Type of rmt_sclk_conf register
* RMT_SCLK configuration register
*/
typedef union {
struct {
/** rmt_sclk_div_a : R/W; bitpos: [5:0]; default: 0;
* The denominator of the frequency divider factor of the rmt function clock.
*/
uint32_t rmt_sclk_div_a:6;
/** rmt_sclk_div_b : R/W; bitpos: [11:6]; default: 0;
* The numerator of the frequency divider factor of the rmt function clock.
*/
uint32_t rmt_sclk_div_b:6;
/** rmt_sclk_div_num : R/W; bitpos: [19:12]; default: 1;
* The integral part of the frequency divider factor of the rmt function clock.
*/
uint32_t rmt_sclk_div_num:8;
/** rmt_sclk_sel : R/W; bitpos: [21:20]; default: 1;
* set this field to select clock-source. 0: XTAL, 1(default): FOSC, 2: 80MHz
*/
uint32_t rmt_sclk_sel:2;
/** rmt_sclk_en : R/W; bitpos: [22]; default: 1;
* Set 1 to enable rmt function clock
*/
uint32_t rmt_sclk_en:1;
uint32_t reserved_23:9;
};
uint32_t val;
} pcr_rmt_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;
* set this field to select clock-source. 0(default): do not select anyone clock, 1:
* 80MHz, 2: FOSC, 3: XTAL.
*/
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 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;
* set this field to select clock-source. 0(default): XTAL, 1: 80MHz, 2: FOSC, 3:
* reserved.
*/
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;
* set this field to select clock-source. 0(default): XTAL, 1: 80MHz, 2: FOSC, 3:
* reserved.
*/
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;
* set this field to select clock-source. 0(default): XTAL, 1: 80MHz, 2: FOSC, 3:
* reserved.
*/
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;
* set this field to select clock-source. 0(default): XTAL, 1: 80MHz, 2: FOSC, 3:
* reserved.
*/
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;
* set this field to select clock-source. 0(default): XTAL, 1: FOSC.
*/
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;
* Select I2S Tx module source clock. 0: XTAL clock. 1: APLL. 2: CLK160. 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;
* Select I2S Rx module source clock. 0: no clock. 1: APLL. 2: CLK160. 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;
* This field is used to select master-clock. 0(default): clk_i2s_rx, 1: clk_i2s_tx
*/
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;
* set this field to select clock-source. 0(default): XTAL, 1: 240MHz, 2: FOSC, 3:
* reserved.
*/
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;
* set this field to select clock-source. 0(default): FOSC, 1: XTAL.
*/
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 pcnt_conf register
* PCNT configuration register
*/
typedef union {
struct {
/** pcnt_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable pcnt clock
*/
uint32_t pcnt_clk_en:1;
/** pcnt_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset pcnt module
*/
uint32_t pcnt_rst_en:1;
/** pcnt_ready : RO; bitpos: [2]; default: 1;
* Query this field after reset pcnt module
*/
uint32_t pcnt_ready:1;
uint32_t reserved_3:29;
};
uint32_t val;
} pcr_pcnt_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 pwm_conf register
* PWM configuration register
*/
typedef union {
struct {
/** pwm_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable pwm clock
*/
uint32_t pwm_clk_en:1;
/** pwm_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset pwm module
*/
uint32_t pwm_rst_en:1;
/** pwm_ready : RO; bitpos: [2]; default: 1;
* Query this field after reset pwm module
*/
uint32_t pwm_ready:1;
uint32_t reserved_3:29;
};
uint32_t val;
} pcr_pwm_conf_reg_t;
/** Type of pwm_clk_conf register
* PWM_CLK configuration register
*/
typedef union {
struct {
uint32_t reserved_0:12;
/** pwm_div_num : R/W; bitpos: [19:12]; default: 4;
* The integral part of the frequency divider factor of the pwm function clock.
*/
uint32_t pwm_div_num:8;
/** pwm_clkm_sel : R/W; bitpos: [21:20]; default: 0;
* set this field to select clock-source. 0(default): do not select anyone clock, 1:
* 160MHz, 2: XTAL, 3: FOSC.
*/
uint32_t pwm_clkm_sel:2;
/** pwm_clkm_en : R/W; bitpos: [22]; default: 1;
* set this field as 1 to activate pwm clkm.
*/
uint32_t pwm_clkm_en:1;
uint32_t reserved_23:9;
};
uint32_t val;
} pcr_pwm_clk_conf_reg_t;
/** Type of parl_io_conf register
* PARL_IO configuration register
*/
typedef union {
struct {
/** parl_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable parl apb clock
*/
uint32_t parl_clk_en:1;
/** parl_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset parl apb reg
*/
uint32_t parl_rst_en:1;
/** parl_ready : RO; bitpos: [2]; default: 1;
* Query this field after reset parl module
*/
uint32_t parl_ready:1;
uint32_t reserved_3:29;
};
uint32_t val;
} pcr_parl_io_conf_reg_t;
/** Type of parl_clk_rx_conf register
* PARL_CLK_RX configuration register
*/
typedef union {
struct {
/** parl_clk_rx_div_num : R/W; bitpos: [15:0]; default: 0;
* The integral part of the frequency divider factor of the parl rx clock.
*/
uint32_t parl_clk_rx_div_num:16;
/** parl_clk_rx_sel : R/W; bitpos: [17:16]; default: 0;
* set this field to select clock-source. 0(default): XTAL, 1: 240MHz, 2: FOSC, 3:
* user clock from pad.
*/
uint32_t parl_clk_rx_sel:2;
/** parl_clk_rx_en : R/W; bitpos: [18]; default: 1;
* Set 1 to enable parl rx clock
*/
uint32_t parl_clk_rx_en:1;
/** parl_rx_rst_en : R/W; bitpos: [19]; default: 0;
* Set 0 to reset parl rx module
*/
uint32_t parl_rx_rst_en:1;
uint32_t reserved_20:12;
};
uint32_t val;
} pcr_parl_clk_rx_conf_reg_t;
/** Type of parl_clk_tx_conf register
* PARL_CLK_TX configuration register
*/
typedef union {
struct {
/** parl_clk_tx_div_num : R/W; bitpos: [15:0]; default: 0;
* The integral part of the frequency divider factor of the parl tx clock.
*/
uint32_t parl_clk_tx_div_num:16;
/** parl_clk_tx_sel : R/W; bitpos: [17:16]; default: 0;
* set this field to select clock-source. 0(default): XTAL, 1: 240MHz, 2: FOSC, 3:
* user clock from pad.
*/
uint32_t parl_clk_tx_sel:2;
/** parl_clk_tx_en : R/W; bitpos: [18]; default: 1;
* Set 1 to enable parl tx clock
*/
uint32_t parl_clk_tx_en:1;
/** parl_tx_rst_en : R/W; bitpos: [19]; default: 0;
* Set 0 to reset parl tx module
*/
uint32_t parl_tx_rst_en:1;
uint32_t reserved_20:12;
};
uint32_t val;
} pcr_parl_clk_tx_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 0 to reset all pvt monitor module
*/
uint32_t pvt_monitor_rst_en:1;
/** pvt_monitor_site1_clk_en : R/W; bitpos: [2]; default: 1;
* Set 1 to enable function clock of modem pvt module
*/
uint32_t pvt_monitor_site1_clk_en: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_site3_clk_en : R/W; bitpos: [4]; default: 1;
* Set 1 to enable function clock of hp_peri pvt module
*/
uint32_t pvt_monitor_site3_clk_en:1;
uint32_t reserved_5:27;
};
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;
* set this field to select clock-source. 0: XTAL, 1(default): 160MHz drived by SPLL
* divided by 3.
*/
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;
* set this field to select clock-source. 0(default): XTAL, 1: 80MHz, 2: FOSC, 3:
* reserved.
*/
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;
* set this field to select clock-source. 0: do not select anyone clock, 1: 80MHz, 2:
* FOSC, 3(default): XTAL.
*/
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 mem_monitor_conf register
* MEM_MONITOR configuration register
*/
typedef union {
struct {
/** mem_monitor_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable mem_monitor clock
*/
uint32_t mem_monitor_clk_en:1;
/** mem_monitor_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset mem_monitor module
*/
uint32_t mem_monitor_rst_en:1;
/** mem_monitor_ready : RO; bitpos: [2]; default: 1;
* Query this field after reset mem_monitor module
*/
uint32_t mem_monitor_ready:1;
uint32_t reserved_3:29;
};
uint32_t val;
} pcr_mem_monitor_conf_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 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 modem_conf register
* MODEM_APB configuration register
*/
typedef union {
struct {
uint32_t reserved_0:2;
/** modem_rst_en : R/W; bitpos: [2]; default: 0;
* Set this file as 1 to reset modem-subsystem.
*/
uint32_t modem_rst_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;
* This field is used to select clock source. 0: XTAL, 1: FOSC, 2: 160M_PLL, 3:
* 240M_PLL.
*/
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;
uint32_t reserved_31:1;
};
uint32_t val;
} pcr_sysclk_conf_reg_t;
/** Type of cpu_waiti_conf register
* CPU_WAITI configuration register
*/
typedef union {
struct {
uint32_t reserved_0:3;
/** 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 {
/** pll_240m_clk_en : R/W; bitpos: [0]; default: 1;
* This field is used to open 240 MHz clock (div2 of SPLL) drived from SPLL. 0: close,
* 1: open(default). Only avaliable when high-speed clock-source SPLL is active.
*/
uint32_t pll_240m_clk_en: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 : R/W; 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;
/** clk40x_bb_oen : R/W; bitpos: [9]; default: 1;
* Reserved
*/
uint32_t clk40x_bb_oen:1;
/** clk_xtal_oen : R/W; bitpos: [10]; default: 1;
* Set 1 to enable xtal clock
*/
uint32_t clk_xtal_oen:1;
uint32_t reserved_11:21;
};
uint32_t val;
} pcr_ctrl_clk_out_en_reg_t;
/** Type of ctrl_tick_conf register
* TICK configuration register
*/
typedef union {
struct {
/** xtal_tick_num : R/W; bitpos: [7:0]; default: 39;
* ******* Description ***********
*/
uint32_t xtal_tick_num:8;
/** fosc_tick_num : R/W; bitpos: [15:8]; default: 7;
* ******* Description ***********
*/
uint32_t fosc_tick_num:8;
/** tick_enable : R/W; bitpos: [16]; default: 1;
* ******* Description ***********
*/
uint32_t tick_enable:1;
/** rst_tick_cnt : R/W; bitpos: [17]; default: 0;
* ******* Description ***********
*/
uint32_t rst_tick_cnt:1;
uint32_t reserved_18:14;
};
uint32_t val;
} pcr_ctrl_tick_conf_reg_t;
/** Type of ctrl_32k_conf register
* 32KHz clock configuration register
*/
typedef union {
struct {
/** clk_32k_sel : R/W; bitpos: [1:0]; default: 0;
* This field indicates which one 32KHz clock will be used by timergroup. 0:
* OSC32K(default), 1: XTAL32K, 2/3: 32KHz from pad GPIO0.
*/
uint32_t clk_32k_sel:2;
uint32_t reserved_2:30;
};
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: [2:0]; default: 7;
* Set this bit to force power up ROM
*/
uint32_t rom_force_pu:3;
/** rom_force_pd : R/W; bitpos: [5:3]; default: 0;
* Set this bit to force power down ROM.
*/
uint32_t rom_force_pd:3;
/** rom_clkgate_force_on : R/W; bitpos: [8:6]; 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:3;
uint32_t reserved_9:23;
};
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: [3:0]; default: 15;
* Set this bit to force power up SRAM
*/
uint32_t sram_force_pu:4;
uint32_t reserved_4:6;
/** sram_force_pd : R/W; bitpos: [13:10]; default: 0;
* Set this bit to force power down SRAM.
*/
uint32_t sram_force_pd:4;
uint32_t reserved_14:6;
/** sram_clkgate_force_on : R/W; bitpos: [23: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:4;
uint32_t reserved_24:8;
};
uint32_t val;
} pcr_sram_power_conf_1_reg_t;
/** Type of sec_conf register
* xxxx
*/
typedef union {
struct {
/** sec_clk_sel : R/W; bitpos: [1:0]; default: 0;
* xxxx
*/
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 bus_clk_update register
* xxxx
*/
typedef union {
struct {
/** bus_clock_update : R/W/WTC; bitpos: [0]; default: 0;
* xxxx
*/
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
* xxxx
*/
typedef union {
struct {
/** sar2_clk_div_num : R/W; bitpos: [7:0]; default: 4;
* xxxx
*/
uint32_t sar2_clk_div_num:8;
/** sar1_clk_div_num : R/W; bitpos: [15:8]; default: 4;
* xxxx
*/
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 sdio_slave_conf register
* SDIO_SLAVE configuration register
*/
typedef union {
struct {
/** sdio_slave_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable sdio_slave clock
*/
uint32_t sdio_slave_clk_en:1;
/** sdio_slave_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset sdio_slave module
*/
uint32_t sdio_slave_rst_en:1;
uint32_t reserved_2:30;
};
uint32_t val;
} pcr_sdio_slave_conf_reg_t;
/** Type of usb_otg_conf register
* USB_OTG configuration register
*/
typedef union {
struct {
/** usb_otg_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable usb_otg bus clock
*/
uint32_t usb_otg_clk_en:1;
/** usb_otg_adp_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset usb_otg core adp
*/
uint32_t usb_otg_adp_rst_en:1;
/** usb_otg_misc_rst_en : R/W; bitpos: [2]; default: 0;
* Set 0 to reset usb_otg misc
*/
uint32_t usb_otg_misc_rst_en:1;
/** usb_otg_global_rst_en : R/W; bitpos: [3]; default: 0;
* Set 0 to reset usb_otg module
*/
uint32_t usb_otg_global_rst_en:1;
uint32_t reserved_4:28;
};
uint32_t val;
} pcr_usb_otg_conf_reg_t;
/** Type of usb_otg_clk_conf register
* USB_OTG func clk configuration register
*/
typedef union {
struct {
uint32_t reserved_0:20;
/** usb_otg_phy_refclk_sel : R/W; bitpos: [20]; default: 1;
* Set 1 to sel 12m pll clock, set 0 to sel pad clock
*/
uint32_t usb_otg_phy_refclk_sel:1;
/** usb_otg_phy_refclk_en : R/W; bitpos: [21]; default: 1;
* Set 1 to enable usb_otg_phy_refclk clock
*/
uint32_t usb_otg_phy_refclk_en:1;
/** usb_otg_adp_clk_sel : R/W; bitpos: [23:22]; default: 0;
* Set 0 to sel clock from gpio_matrix, set 1 to sel osc32k, set 2 to sel xtal32k, set
* 3 to sel ext32k
*/
uint32_t usb_otg_adp_clk_sel:2;
/** usb_otg_adp_clk_en : R/W; bitpos: [24]; default: 1;
* Set 1 to enable usb_otg_adp_clk clock
*/
uint32_t usb_otg_adp_clk_en:1;
uint32_t reserved_25:7;
};
uint32_t val;
} pcr_usb_otg_clk_conf_reg_t;
/** Type of bs_conf register
* BS configuration register
*/
typedef union {
struct {
/** bs_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable bs clock
*/
uint32_t bs_clk_en:1;
/** bs_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset bs module
*/
uint32_t bs_rst_en:1;
uint32_t reserved_2:30;
};
uint32_t val;
} pcr_bs_conf_reg_t;
/** Type of bs_func_conf register
* BS_FUNC_CLK configuration register
*/
typedef union {
struct {
uint32_t reserved_0:23;
/** bs_tx_rst_en : R/W; bitpos: [23]; default: 0;
* Set 0 to reset bs tx module
*/
uint32_t bs_tx_rst_en:1;
/** bs_rx_rst_en : R/W; bitpos: [24]; default: 0;
* Set 0 to reset bs rx module
*/
uint32_t bs_rx_rst_en:1;
uint32_t reserved_25:7;
};
uint32_t val;
} pcr_bs_func_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;
uint32_t reserved_2:30;
};
uint32_t val;
} pcr_timergroup_xtal_conf_reg_t;
/** Type of km_conf register
* Key Manager configuration register
*/
typedef union {
struct {
/** km_clk_en : R/W; bitpos: [0]; default: 1;
* Set 1 to enable km clock
*/
uint32_t km_clk_en:1;
/** km_rst_en : R/W; bitpos: [1]; default: 0;
* Set 0 to reset km module
*/
uint32_t km_rst_en:1;
/** km_ready : RO; bitpos: [2]; default: 1;
* Query this field after reset km module
*/
uint32_t km_ready:1;
uint32_t reserved_3:29;
};
uint32_t val;
} pcr_km_conf_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: Version Register */
/** Type of date register
* Date register.
*/
typedef union {
struct {
/** date : R/W; bitpos: [27:0]; default: 36720976;
* PCR version information.
*/
uint32_t date:28;
uint32_t reserved_28:4;
};
uint32_t val;
} pcr_date_reg_t;
/**
* @brief The struct of I2C configuration registers
*/
typedef struct {
pcr_i2c_conf_reg_t i2c_conf;
pcr_i2c_sclk_conf_reg_t i2c_sclk_conf;
} pcr_i2c_reg_t;
typedef struct pcr_dev_t {
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_mspi_conf_reg_t mspi_conf;
volatile pcr_mspi_clk_conf_reg_t mspi_clk_conf;
volatile pcr_i2c_reg_t i2c[1];
volatile pcr_twai0_conf_reg_t twai0_conf;
volatile pcr_twai0_func_clk_conf_reg_t twai0_func_clk_conf;
volatile pcr_twai1_conf_reg_t twai1_conf;
volatile pcr_twai1_func_clk_conf_reg_t twai1_func_clk_conf;
volatile pcr_uhci_conf_reg_t uhci_conf;
volatile pcr_rmt_conf_reg_t rmt_conf;
volatile pcr_rmt_sclk_conf_reg_t rmt_sclk_conf;
volatile pcr_ledc_conf_reg_t ledc_conf;
volatile pcr_ledc_sclk_conf_reg_t ledc_sclk_conf;
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_pcnt_conf_reg_t pcnt_conf;
volatile pcr_etm_conf_reg_t etm_conf;
volatile pcr_pwm_conf_reg_t pwm_conf;
volatile pcr_pwm_clk_conf_reg_t pwm_clk_conf;
volatile pcr_parl_io_conf_reg_t parl_io_conf;
volatile pcr_parl_clk_rx_conf_reg_t parl_clk_rx_conf;
volatile pcr_parl_clk_tx_conf_reg_t parl_clk_tx_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_mem_monitor_conf_reg_t mem_monitor_conf;
volatile pcr_regdma_conf_reg_t regdma_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_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;
volatile pcr_ctrl_tick_conf_reg_t ctrl_tick_conf;
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;
uint32_t reserved_140[2];
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_sdio_slave_conf_reg_t sdio_slave_conf;
volatile pcr_usb_otg_conf_reg_t usb_otg_conf;
volatile pcr_usb_otg_clk_conf_reg_t usb_otg_clk_conf;
volatile pcr_bs_conf_reg_t bs_conf;
volatile pcr_bs_func_conf_reg_t bs_func_conf;
volatile pcr_timergroup_wdt_conf_reg_t timergroup_wdt_conf;
volatile pcr_timergroup_xtal_conf_reg_t timergroup_xtal_conf;
volatile pcr_km_conf_reg_t km_conf;
uint32_t reserved_174[930];
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