| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368 |
- /**
- * SPDX-FileCopyrightText: 2022 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 regdma_conf register
- * Peri backup control register
- */
- typedef union {
- struct {
- /** flow_err : RO; bitpos: [2:0]; default: 0;
- * backup error type
- */
- uint32_t flow_err:3;
- /** start : WT; bitpos: [3]; default: 0;
- * backup start signal
- */
- uint32_t start:1;
- /** to_mem : R/W; bitpos: [4]; default: 0;
- * backup direction(reg to mem / mem to reg)
- */
- uint32_t to_mem:1;
- /** link_sel : R/W; bitpos: [6:5]; default: 0;
- * Link select
- */
- uint32_t link_sel:2;
- /** start_mac : WT; bitpos: [7]; default: 0;
- * mac sw backup start signal
- */
- uint32_t start_mac:1;
- /** to_mem_mac : R/W; bitpos: [8]; default: 0;
- * mac sw backup direction(reg to mem / mem to reg)
- */
- uint32_t to_mem_mac:1;
- /** sel_mac : R/W; bitpos: [9]; default: 0;
- * mac hw/sw select
- */
- uint32_t sel_mac:1;
- uint32_t reserved_10:22;
- };
- uint32_t val;
- } pau_regdma_conf_reg_t;
- /** Type of regdma_clk_conf register
- * Clock control register
- */
- typedef union {
- struct {
- /** clk_en : R/W; bitpos: [0]; default: 0;
- * clock enable
- */
- uint32_t clk_en:1;
- uint32_t reserved_1:31;
- };
- uint32_t val;
- } pau_regdma_clk_conf_reg_t;
- /** Type of regdma_etm_ctrl register
- * ETM start ctrl reg
- */
- typedef union {
- struct {
- /** etm_start_0 : WT; bitpos: [0]; default: 0;
- * etm_start_0 reg
- */
- uint32_t etm_start_0:1;
- /** etm_start_1 : WT; bitpos: [1]; default: 0;
- * etm_start_1 reg
- */
- uint32_t etm_start_1:1;
- /** etm_start_2 : WT; bitpos: [2]; default: 0;
- * etm_start_2 reg
- */
- uint32_t etm_start_2:1;
- /** etm_start_3 : WT; bitpos: [3]; default: 0;
- * etm_start_3 reg
- */
- uint32_t etm_start_3:1;
- uint32_t reserved_4:28;
- };
- uint32_t val;
- } pau_regdma_etm_ctrl_reg_t;
- /** Type of regdma_link_0_addr register
- * link_0_addr
- */
- typedef union {
- struct {
- /** link_addr_0 : R/W; bitpos: [31:0]; default: 0;
- * link_0_addr reg
- */
- uint32_t link_addr_0:32;
- };
- uint32_t val;
- } pau_regdma_link_0_addr_reg_t;
- /** Type of regdma_link_1_addr register
- * Link_1_addr
- */
- typedef union {
- struct {
- /** link_addr_1 : R/W; bitpos: [31:0]; default: 0;
- * Link_1_addr reg
- */
- uint32_t link_addr_1:32;
- };
- uint32_t val;
- } pau_regdma_link_1_addr_reg_t;
- /** Type of regdma_link_2_addr register
- * Link_2_addr
- */
- typedef union {
- struct {
- /** link_addr_2 : R/W; bitpos: [31:0]; default: 0;
- * Link_2_addr reg
- */
- uint32_t link_addr_2:32;
- };
- uint32_t val;
- } pau_regdma_link_2_addr_reg_t;
- /** Type of regdma_link_3_addr register
- * Link_3_addr
- */
- typedef union {
- struct {
- /** link_addr_3 : R/W; bitpos: [31:0]; default: 0;
- * Link_3_addr reg
- */
- uint32_t link_addr_3:32;
- };
- uint32_t val;
- } pau_regdma_link_3_addr_reg_t;
- /** Type of regdma_link_mac_addr register
- * Link_mac_addr
- */
- typedef union {
- struct {
- /** link_addr_mac : R/W; bitpos: [31:0]; default: 0;
- * Link_mac_addr reg
- */
- uint32_t link_addr_mac:32;
- };
- uint32_t val;
- } pau_regdma_link_mac_addr_reg_t;
- /** Type of regdma_current_link_addr register
- * current link addr
- */
- typedef union {
- struct {
- /** current_link_addr : RO; bitpos: [31:0]; default: 0;
- * current link addr reg
- */
- uint32_t current_link_addr:32;
- };
- uint32_t val;
- } pau_regdma_current_link_addr_reg_t;
- /** Type of regdma_backup_addr register
- * Backup addr
- */
- typedef union {
- struct {
- /** backup_addr : RO; bitpos: [31:0]; default: 0;
- * backup addr reg
- */
- uint32_t backup_addr:32;
- };
- uint32_t val;
- } pau_regdma_backup_addr_reg_t;
- /** Type of regdma_mem_addr register
- * mem addr
- */
- typedef union {
- struct {
- /** mem_addr : RO; bitpos: [31:0]; default: 0;
- * mem addr reg
- */
- uint32_t mem_addr:32;
- };
- uint32_t val;
- } pau_regdma_mem_addr_reg_t;
- /** Type of regdma_bkp_conf register
- * backup config
- */
- typedef union {
- struct {
- /** read_interval : R/W; bitpos: [6:0]; default: 32;
- * Link read_interval
- */
- uint32_t read_interval:7;
- /** link_tout_thres : R/W; bitpos: [16:7]; default: 50;
- * link wait timeout threshold
- */
- uint32_t link_tout_thres:10;
- /** burst_limit : R/W; bitpos: [21:17]; default: 8;
- * burst limit
- */
- uint32_t burst_limit:5;
- /** backup_tout_thres : R/W; bitpos: [31:22]; default: 500;
- * Backup timeout threshold
- */
- uint32_t backup_tout_thres:10;
- };
- uint32_t val;
- } pau_regdma_bkp_conf_reg_t;
- /** Type of retention_link_base register
- * retention dma link base
- */
- typedef union {
- struct {
- /** link_base_addr : R/W; bitpos: [26:0]; default: 0;
- * retention dma link base
- */
- uint32_t link_base_addr:27;
- uint32_t reserved_27:5;
- };
- uint32_t val;
- } pau_retention_link_base_reg_t;
- /** Type of retention_cfg register
- * retention_cfg
- */
- typedef union {
- struct {
- /** ret_inv_cfg : R/W; bitpos: [31:0]; default: 4294967295;
- * retention inv scan out
- */
- uint32_t ret_inv_cfg:32;
- };
- uint32_t val;
- } pau_retention_cfg_reg_t;
- /** Type of int_ena register
- * Read only register for error and done
- */
- typedef union {
- struct {
- /** done_int_ena : R/W; bitpos: [0]; default: 0;
- * backup done flag
- */
- uint32_t done_int_ena:1;
- /** error_int_ena : R/W; bitpos: [1]; default: 0;
- * error flag
- */
- uint32_t error_int_ena:1;
- uint32_t reserved_2:30;
- };
- uint32_t val;
- } pau_int_ena_reg_t;
- /** Type of int_raw register
- * Read only register for error and done
- */
- typedef union {
- struct {
- /** done_int_raw : R/WTC/SS; bitpos: [0]; default: 0;
- * backup done flag
- */
- uint32_t done_int_raw:1;
- /** error_int_raw : R/WTC/SS; bitpos: [1]; default: 0;
- * error flag
- */
- uint32_t error_int_raw:1;
- uint32_t reserved_2:30;
- };
- uint32_t val;
- } pau_int_raw_reg_t;
- /** Type of int_clr register
- * Read only register for error and done
- */
- typedef union {
- struct {
- /** done_int_clr : WT; bitpos: [0]; default: 0;
- * backup done flag
- */
- uint32_t done_int_clr:1;
- /** error_int_clr : WT; bitpos: [1]; default: 0;
- * error flag
- */
- uint32_t error_int_clr:1;
- uint32_t reserved_2:30;
- };
- uint32_t val;
- } pau_int_clr_reg_t;
- /** Type of int_st register
- * Read only register for error and done
- */
- typedef union {
- struct {
- /** done_int_st : RO; bitpos: [0]; default: 0;
- * backup done flag
- */
- uint32_t done_int_st:1;
- /** error_int_st : RO; bitpos: [1]; default: 0;
- * error flag
- */
- uint32_t error_int_st:1;
- uint32_t reserved_2:30;
- };
- uint32_t val;
- } pau_int_st_reg_t;
- /** Group: Version Register */
- /** Type of date register
- * Date register.
- */
- typedef union {
- struct {
- /** date : R/W; bitpos: [27:0]; default: 35663984;
- * REGDMA date information/ REGDMA version information.
- */
- uint32_t date:28;
- uint32_t reserved_28:4;
- };
- uint32_t val;
- } pau_date_reg_t;
- typedef struct pau_dev_t {
- volatile pau_regdma_conf_reg_t regdma_conf;
- volatile pau_regdma_clk_conf_reg_t regdma_clk_conf;
- volatile pau_regdma_etm_ctrl_reg_t regdma_etm_ctrl;
- volatile pau_regdma_link_0_addr_reg_t regdma_link_0_addr;
- volatile pau_regdma_link_1_addr_reg_t regdma_link_1_addr;
- volatile pau_regdma_link_2_addr_reg_t regdma_link_2_addr;
- volatile pau_regdma_link_3_addr_reg_t regdma_link_3_addr;
- volatile pau_regdma_link_mac_addr_reg_t regdma_link_mac_addr;
- volatile pau_regdma_current_link_addr_reg_t regdma_current_link_addr;
- volatile pau_regdma_backup_addr_reg_t regdma_backup_addr;
- volatile pau_regdma_mem_addr_reg_t regdma_mem_addr;
- volatile pau_regdma_bkp_conf_reg_t regdma_bkp_conf;
- volatile pau_retention_link_base_reg_t retention_link_base;
- volatile pau_retention_cfg_reg_t retention_cfg;
- volatile pau_int_ena_reg_t int_ena;
- volatile pau_int_raw_reg_t int_raw;
- volatile pau_int_clr_reg_t int_clr;
- volatile pau_int_st_reg_t int_st;
- uint32_t reserved_048[237];
- volatile pau_date_reg_t date;
- } pau_dev_t;
- extern pau_dev_t PAU;
- #ifndef __cplusplus
- _Static_assert(sizeof(pau_dev_t) == 0x400, "Invalid size of pau_dev_t structure");
- #endif
- #ifdef __cplusplus
- }
- #endif
|