feat(soc): rename rtc_wdt_reg to lp_wdt_reg

This commit is contained in:
Armando
2023-06-29 16:38:27 +08:00
parent 0959c0cb96
commit 8cf0e5d5b8
4 changed files with 577 additions and 1273 deletions

View File

@@ -1,5 +1,5 @@
/** /**
* SPDX-FileCopyrightText: 2022-2023 Espressif Systems (Shanghai) CO LTD * SPDX-FileCopyrightText: 2023 Espressif Systems (Shanghai) CO LTD
* *
* SPDX-License-Identifier: Apache-2.0 * SPDX-License-Identifier: Apache-2.0
*/ */
@@ -11,506 +11,313 @@
extern "C" { extern "C" {
#endif #endif
// TODO: IDF-5730 (better to rename and move to wdt_types.h?) /** LP_WDT_CONFIG0_REG register
/* The value that needs to be written to LP_WDT_WPROTECT_REG to write-enable the wdt registers */ * need_des
#define RTC_CNTL_WDT_WKEY_VALUE 0x50D83AA1 */
/* The value that needs to be written to LP_WDT_SWD_WPROTECT_REG to write-enable the swd registers */ #define LP_WDT_CONFIG0_REG (DR_REG_LP_WDT_BASE + 0x0)
#define LP_WDT_SWD_WKEY_VALUE 0x50D83AA1 /** LP_WDT_WDT_PAUSE_IN_SLP : R/W; bitpos: [9]; default: 1;
* need_des
/* Possible values for RTC_CNTL_WDT_CPU_RESET_LENGTH and RTC_CNTL_WDT_SYS_RESET_LENGTH */ */
#define RTC_WDT_RESET_LENGTH_100_NS 0 #define LP_WDT_WDT_PAUSE_IN_SLP (BIT(9))
#define RTC_WDT_RESET_LENGTH_200_NS 1 #define LP_WDT_WDT_PAUSE_IN_SLP_M (LP_WDT_WDT_PAUSE_IN_SLP_V << LP_WDT_WDT_PAUSE_IN_SLP_S)
#define RTC_WDT_RESET_LENGTH_300_NS 2 #define LP_WDT_WDT_PAUSE_IN_SLP_V 0x00000001U
#define RTC_WDT_RESET_LENGTH_400_NS 3 #define LP_WDT_WDT_PAUSE_IN_SLP_S 9
#define RTC_WDT_RESET_LENGTH_500_NS 4 /** LP_WDT_WDT_APPCPU_RESET_EN : R/W; bitpos: [10]; default: 0;
#define RTC_WDT_RESET_LENGTH_800_NS 5 * need_des
#define RTC_WDT_RESET_LENGTH_1600_NS 6 */
#define RTC_WDT_RESET_LENGTH_3200_NS 7 #define LP_WDT_WDT_APPCPU_RESET_EN (BIT(10))
#define LP_WDT_WDT_APPCPU_RESET_EN_M (LP_WDT_WDT_APPCPU_RESET_EN_V << LP_WDT_WDT_APPCPU_RESET_EN_S)
#define LP_WDT_RTC_WDTCONFIG0_REG (DR_REG_LP_WDT_BASE + 0x0) #define LP_WDT_WDT_APPCPU_RESET_EN_V 0x00000001U
/* LP_WDT_WDT_EN : R/W ;bitpos:[31] ;default: 1'h0 ; */ #define LP_WDT_WDT_APPCPU_RESET_EN_S 10
/*description: .*/ /** LP_WDT_WDT_PROCPU_RESET_EN : R/W; bitpos: [11]; default: 0;
#define LP_WDT_WDT_EN (BIT(31)) * need_des
#define LP_WDT_WDT_EN_M (BIT(31)) */
#define LP_WDT_WDT_EN_V 0x1 #define LP_WDT_WDT_PROCPU_RESET_EN (BIT(11))
#define LP_WDT_WDT_EN_S 31 #define LP_WDT_WDT_PROCPU_RESET_EN_M (LP_WDT_WDT_PROCPU_RESET_EN_V << LP_WDT_WDT_PROCPU_RESET_EN_S)
/* LP_WDT_WDT_STG0 : R/W ;bitpos:[30:28] ;default: 3'h0 ; */ #define LP_WDT_WDT_PROCPU_RESET_EN_V 0x00000001U
/*description: 1: interrupt stage en; 2: CPU reset stage en; 3: system reset stage en ; 4: RTC #define LP_WDT_WDT_PROCPU_RESET_EN_S 11
reset stage en.*/ /** LP_WDT_WDT_FLASHBOOT_MOD_EN : R/W; bitpos: [12]; default: 1;
#define LP_WDT_WDT_STG0 0x00000007 * need_des
#define LP_WDT_WDT_STG0_M ((LP_WDT_WDT_STG0_V)<<(LP_WDT_WDT_STG0_S)) */
#define LP_WDT_WDT_STG0_V 0x7
#define LP_WDT_WDT_STG0_S 28
/* LP_WDT_WDT_STG1 : R/W ;bitpos:[27:25] ;default: 3'h0 ; */
/*description: 1: interrupt stage en; 2: CPU reset stage en; 3: system reset stage en ; 4: RTC
reset stage en.*/
#define LP_WDT_WDT_STG1 0x00000007
#define LP_WDT_WDT_STG1_M ((LP_WDT_WDT_STG1_V)<<(LP_WDT_WDT_STG1_S))
#define LP_WDT_WDT_STG1_V 0x7
#define LP_WDT_WDT_STG1_S 25
/* LP_WDT_WDT_STG2 : R/W ;bitpos:[24:22] ;default: 3'h0 ; */
/*description: 1: interrupt stage en; 2: CPU reset stage en; 3: system reset stage en ; 4: RTC
reset stage en.*/
#define LP_WDT_WDT_STG2 0x00000007
#define LP_WDT_WDT_STG2_M ((LP_WDT_WDT_STG2_V)<<(LP_WDT_WDT_STG2_S))
#define LP_WDT_WDT_STG2_V 0x7
#define LP_WDT_WDT_STG2_S 22
/* LP_WDT_WDT_STG3 : R/W ;bitpos:[21:19] ;default: 3'h0 ; */
/*description: 1: interrupt stage en; 2: CPU reset stage en; 3: system reset stage en ; 4: RTC
reset stage en.*/
#define LP_WDT_WDT_STG3 0x00000007
#define LP_WDT_WDT_STG3_M ((LP_WDT_WDT_STG3_V)<<(LP_WDT_WDT_STG3_S))
#define LP_WDT_WDT_STG3_V 0x7
#define LP_WDT_WDT_STG3_S 19
/* LP_WDT_WDT_CPU_RESET_LENGTH : R/W ;bitpos:[18:16] ;default: 3'h1 ; */
/*description: CPU reset counter length.*/
#define LP_WDT_WDT_CPU_RESET_LENGTH 0x00000007
#define LP_WDT_WDT_CPU_RESET_LENGTH_M ((LP_WDT_WDT_CPU_RESET_LENGTH_V)<<(LP_WDT_WDT_CPU_RESET_LENGTH_S))
#define LP_WDT_WDT_CPU_RESET_LENGTH_V 0x7
#define LP_WDT_WDT_CPU_RESET_LENGTH_S 16
/* LP_WDT_WDT_SYS_RESET_LENGTH : R/W ;bitpos:[15:13] ;default: 3'h1 ; */
/*description: system reset counter length.*/
#define LP_WDT_WDT_SYS_RESET_LENGTH 0x00000007
#define LP_WDT_WDT_SYS_RESET_LENGTH_M ((LP_WDT_WDT_SYS_RESET_LENGTH_V)<<(LP_WDT_WDT_SYS_RESET_LENGTH_S))
#define LP_WDT_WDT_SYS_RESET_LENGTH_V 0x7
#define LP_WDT_WDT_SYS_RESET_LENGTH_S 13
/* LP_WDT_WDT_FLASHBOOT_MOD_EN : R/W ;bitpos:[12] ;default: 1'h0 ; */
/*description: enable WDT in flash boot.*/
#define LP_WDT_WDT_FLASHBOOT_MOD_EN (BIT(12)) #define LP_WDT_WDT_FLASHBOOT_MOD_EN (BIT(12))
#define LP_WDT_WDT_FLASHBOOT_MOD_EN_M (BIT(12)) #define LP_WDT_WDT_FLASHBOOT_MOD_EN_M (LP_WDT_WDT_FLASHBOOT_MOD_EN_V << LP_WDT_WDT_FLASHBOOT_MOD_EN_S)
#define LP_WDT_WDT_FLASHBOOT_MOD_EN_V 0x1 #define LP_WDT_WDT_FLASHBOOT_MOD_EN_V 0x00000001U
#define LP_WDT_WDT_FLASHBOOT_MOD_EN_S 12 #define LP_WDT_WDT_FLASHBOOT_MOD_EN_S 12
/* LP_WDT_WDT_PAUSE_IN_SLP : R/W ;bitpos:[11] ;default: 1'd1 ; */ /** LP_WDT_WDT_SYS_RESET_LENGTH : R/W; bitpos: [15:13]; default: 1;
/*description: pause WDT in sleep.*/ * need_des
#define LP_WDT_WDT_PAUSE_IN_SLP (BIT(11)) */
#define LP_WDT_WDT_PAUSE_IN_SLP_M (BIT(11)) #define LP_WDT_WDT_SYS_RESET_LENGTH 0x00000007U
#define LP_WDT_WDT_PAUSE_IN_SLP_V 0x1 #define LP_WDT_WDT_SYS_RESET_LENGTH_M (LP_WDT_WDT_SYS_RESET_LENGTH_V << LP_WDT_WDT_SYS_RESET_LENGTH_S)
#define LP_WDT_WDT_PAUSE_IN_SLP_S 11 #define LP_WDT_WDT_SYS_RESET_LENGTH_V 0x00000007U
/* LP_WDT_WDT_CHIP_RESET_EN : R/W ;bitpos:[10] ;default: 1'b0 ; */ #define LP_WDT_WDT_SYS_RESET_LENGTH_S 13
/*description: wdt reset whole chip enable.*/ /** LP_WDT_WDT_CPU_RESET_LENGTH : R/W; bitpos: [18:16]; default: 1;
#define LP_WDT_WDT_CHIP_RESET_EN (BIT(10)) * need_des
#define LP_WDT_WDT_CHIP_RESET_EN_M (BIT(10)) */
#define LP_WDT_WDT_CHIP_RESET_EN_V 0x1 #define LP_WDT_WDT_CPU_RESET_LENGTH 0x00000007U
#define LP_WDT_WDT_CHIP_RESET_EN_S 10 #define LP_WDT_WDT_CPU_RESET_LENGTH_M (LP_WDT_WDT_CPU_RESET_LENGTH_V << LP_WDT_WDT_CPU_RESET_LENGTH_S)
/* LP_WDT_WDT_CHIP_RESET_WIDTH : R/W ;bitpos:[9:2] ;default: 8'd20 ; */ #define LP_WDT_WDT_CPU_RESET_LENGTH_V 0x00000007U
/*description: chip reset siginal pulse width.*/ #define LP_WDT_WDT_CPU_RESET_LENGTH_S 16
#define LP_WDT_WDT_CHIP_RESET_WIDTH 0x000000FF /** LP_WDT_WDT_STG3 : R/W; bitpos: [21:19]; default: 0;
#define LP_WDT_WDT_CHIP_RESET_WIDTH_M ((LP_WDT_WDT_CHIP_RESET_WIDTH_V)<<(LP_WDT_WDT_CHIP_RESET_WIDTH_S)) * need_des
#define LP_WDT_WDT_CHIP_RESET_WIDTH_V 0xFF */
#define LP_WDT_WDT_CHIP_RESET_WIDTH_S 2 #define LP_WDT_WDT_STG3 0x00000007U
#define LP_WDT_WDT_STG3_M (LP_WDT_WDT_STG3_V << LP_WDT_WDT_STG3_S)
#define LP_WDT_WDT_STG3_V 0x00000007U
#define LP_WDT_WDT_STG3_S 19
/** LP_WDT_WDT_STG2 : R/W; bitpos: [24:22]; default: 0;
* need_des
*/
#define LP_WDT_WDT_STG2 0x00000007U
#define LP_WDT_WDT_STG2_M (LP_WDT_WDT_STG2_V << LP_WDT_WDT_STG2_S)
#define LP_WDT_WDT_STG2_V 0x00000007U
#define LP_WDT_WDT_STG2_S 22
/** LP_WDT_WDT_STG1 : R/W; bitpos: [27:25]; default: 0;
* need_des
*/
#define LP_WDT_WDT_STG1 0x00000007U
#define LP_WDT_WDT_STG1_M (LP_WDT_WDT_STG1_V << LP_WDT_WDT_STG1_S)
#define LP_WDT_WDT_STG1_V 0x00000007U
#define LP_WDT_WDT_STG1_S 25
/** LP_WDT_WDT_STG0 : R/W; bitpos: [30:28]; default: 0;
* need_des
*/
#define LP_WDT_WDT_STG0 0x00000007U
#define LP_WDT_WDT_STG0_M (LP_WDT_WDT_STG0_V << LP_WDT_WDT_STG0_S)
#define LP_WDT_WDT_STG0_V 0x00000007U
#define LP_WDT_WDT_STG0_S 28
/** LP_WDT_WDT_EN : R/W; bitpos: [31]; default: 0;
* need_des
*/
#define LP_WDT_WDT_EN (BIT(31))
#define LP_WDT_WDT_EN_M (LP_WDT_WDT_EN_V << LP_WDT_WDT_EN_S)
#define LP_WDT_WDT_EN_V 0x00000001U
#define LP_WDT_WDT_EN_S 31
#define LP_WDT_RTC_WDTCPURST_REG (DR_REG_LP_WDT_BASE + 0x4) /** LP_WDT_CONFIG1_REG register
/* LP_WDT_WDT_CORE0CPU_RESET_EN : R/W ;bitpos:[31] ;default: 1'd0 ; */ * need_des
/*description: enable WDT reset CORE0 CPU.*/ */
#define LP_WDT_WDT_CORE0CPU_RESET_EN (BIT(31)) #define LP_WDT_CONFIG1_REG (DR_REG_LP_WDT_BASE + 0x4)
#define LP_WDT_WDT_CORE0CPU_RESET_EN_M (BIT(31)) /** LP_WDT_WDT_STG0_HOLD : R/W; bitpos: [31:0]; default: 200000;
#define LP_WDT_WDT_CORE0CPU_RESET_EN_V 0x1 * need_des
#define LP_WDT_WDT_CORE0CPU_RESET_EN_S 31 */
/* LP_WDT_WDT_CORE1CPU_RESET_EN : R/W ;bitpos:[30] ;default: 1'd0 ; */ #define LP_WDT_WDT_STG0_HOLD 0xFFFFFFFFU
/*description: enable WDT reset CORE1 CPU.*/ #define LP_WDT_WDT_STG0_HOLD_M (LP_WDT_WDT_STG0_HOLD_V << LP_WDT_WDT_STG0_HOLD_S)
#define LP_WDT_WDT_CORE1CPU_RESET_EN (BIT(30)) #define LP_WDT_WDT_STG0_HOLD_V 0xFFFFFFFFU
#define LP_WDT_WDT_CORE1CPU_RESET_EN_M (BIT(30))
#define LP_WDT_WDT_CORE1CPU_RESET_EN_V 0x1
#define LP_WDT_WDT_CORE1CPU_RESET_EN_S 30
/* LP_WDT_WDT_CORE2CPU_RESET_EN : R/W ;bitpos:[29] ;default: 1'd0 ; */
/*description: enable WDT reset CORE2 CPU.*/
#define LP_WDT_WDT_CORE2CPU_RESET_EN (BIT(29))
#define LP_WDT_WDT_CORE2CPU_RESET_EN_M (BIT(29))
#define LP_WDT_WDT_CORE2CPU_RESET_EN_V 0x1
#define LP_WDT_WDT_CORE2CPU_RESET_EN_S 29
/* LP_WDT_WDT_CORE3CPU_RESET_EN : R/W ;bitpos:[28] ;default: 1'd0 ; */
/*description: enable WDT reset CORE3 CPU.*/
#define LP_WDT_WDT_CORE3CPU_RESET_EN (BIT(28))
#define LP_WDT_WDT_CORE3CPU_RESET_EN_M (BIT(28))
#define LP_WDT_WDT_CORE3CPU_RESET_EN_V 0x1
#define LP_WDT_WDT_CORE3CPU_RESET_EN_S 28
/* LP_WDT_WDT_LP_CPU_RESET_EN : R/W ;bitpos:[27] ;default: 1'd0 ; */
/*description: enable WDT reset LP CPU.*/
#define LP_WDT_WDT_LP_CPU_RESET_EN (BIT(27))
#define LP_WDT_WDT_LP_CPU_RESET_EN_M (BIT(27))
#define LP_WDT_WDT_LP_CPU_RESET_EN_V 0x1
#define LP_WDT_WDT_LP_CPU_RESET_EN_S 27
/* LP_WDT_WDT_LP_PERI_RESET_EN : R/W ;bitpos:[26] ;default: 1'd0 ; */
/*description: enable WDT reset LP PERI.*/
#define LP_WDT_WDT_LP_PERI_RESET_EN (BIT(26))
#define LP_WDT_WDT_LP_PERI_RESET_EN_M (BIT(26))
#define LP_WDT_WDT_LP_PERI_RESET_EN_V 0x1
#define LP_WDT_WDT_LP_PERI_RESET_EN_S 26
#define LP_WDT_RTC_WDTCONFIG1_REG (DR_REG_LP_WDT_BASE + 0x8)
/* LP_WDT_WDT_STG0_HOLD : R/W ;bitpos:[31:0] ;default: 32'd200000 ; */
/*description: .*/
#define LP_WDT_WDT_STG0_HOLD 0xFFFFFFFF
#define LP_WDT_WDT_STG0_HOLD_M ((LP_WDT_WDT_STG0_HOLD_V)<<(LP_WDT_WDT_STG0_HOLD_S))
#define LP_WDT_WDT_STG0_HOLD_V 0xFFFFFFFF
#define LP_WDT_WDT_STG0_HOLD_S 0 #define LP_WDT_WDT_STG0_HOLD_S 0
#define LP_WDT_RTC_WDTCONFIG2_REG (DR_REG_LP_WDT_BASE + 0xC) /** LP_WDT_CONFIG2_REG register
/* LP_WDT_WDT_STG1_HOLD : R/W ;bitpos:[31:0] ;default: 32'd80000 ; */ * need_des
/*description: .*/ */
#define LP_WDT_WDT_STG1_HOLD 0xFFFFFFFF #define LP_WDT_CONFIG2_REG (DR_REG_LP_WDT_BASE + 0x8)
#define LP_WDT_WDT_STG1_HOLD_M ((LP_WDT_WDT_STG1_HOLD_V)<<(LP_WDT_WDT_STG1_HOLD_S)) /** LP_WDT_WDT_STG1_HOLD : R/W; bitpos: [31:0]; default: 80000;
#define LP_WDT_WDT_STG1_HOLD_V 0xFFFFFFFF * need_des
*/
#define LP_WDT_WDT_STG1_HOLD 0xFFFFFFFFU
#define LP_WDT_WDT_STG1_HOLD_M (LP_WDT_WDT_STG1_HOLD_V << LP_WDT_WDT_STG1_HOLD_S)
#define LP_WDT_WDT_STG1_HOLD_V 0xFFFFFFFFU
#define LP_WDT_WDT_STG1_HOLD_S 0 #define LP_WDT_WDT_STG1_HOLD_S 0
#define LP_WDT_RTC_WDTCONFIG3_REG (DR_REG_LP_WDT_BASE + 0x10) /** LP_WDT_CONFIG3_REG register
/* LP_WDT_WDT_STG2_HOLD : R/W ;bitpos:[31:0] ;default: 32'hfff ; */ * need_des
/*description: .*/ */
#define LP_WDT_WDT_STG2_HOLD 0xFFFFFFFF #define LP_WDT_CONFIG3_REG (DR_REG_LP_WDT_BASE + 0xc)
#define LP_WDT_WDT_STG2_HOLD_M ((LP_WDT_WDT_STG2_HOLD_V)<<(LP_WDT_WDT_STG2_HOLD_S)) /** LP_WDT_WDT_STG2_HOLD : R/W; bitpos: [31:0]; default: 4095;
#define LP_WDT_WDT_STG2_HOLD_V 0xFFFFFFFF * need_des
*/
#define LP_WDT_WDT_STG2_HOLD 0xFFFFFFFFU
#define LP_WDT_WDT_STG2_HOLD_M (LP_WDT_WDT_STG2_HOLD_V << LP_WDT_WDT_STG2_HOLD_S)
#define LP_WDT_WDT_STG2_HOLD_V 0xFFFFFFFFU
#define LP_WDT_WDT_STG2_HOLD_S 0 #define LP_WDT_WDT_STG2_HOLD_S 0
#define LP_WDT_RTC_WDTCONFIG4_REG (DR_REG_LP_WDT_BASE + 0x14) /** LP_WDT_CONFIG4_REG register
/* LP_WDT_WDT_STG3_HOLD : R/W ;bitpos:[31:0] ;default: 32'hfff ; */ * need_des
/*description: .*/ */
#define LP_WDT_WDT_STG3_HOLD 0xFFFFFFFF #define LP_WDT_CONFIG4_REG (DR_REG_LP_WDT_BASE + 0x10)
#define LP_WDT_WDT_STG3_HOLD_M ((LP_WDT_WDT_STG3_HOLD_V)<<(LP_WDT_WDT_STG3_HOLD_S)) /** LP_WDT_WDT_STG3_HOLD : R/W; bitpos: [31:0]; default: 4095;
#define LP_WDT_WDT_STG3_HOLD_V 0xFFFFFFFF * need_des
*/
#define LP_WDT_WDT_STG3_HOLD 0xFFFFFFFFU
#define LP_WDT_WDT_STG3_HOLD_M (LP_WDT_WDT_STG3_HOLD_V << LP_WDT_WDT_STG3_HOLD_S)
#define LP_WDT_WDT_STG3_HOLD_V 0xFFFFFFFFU
#define LP_WDT_WDT_STG3_HOLD_S 0 #define LP_WDT_WDT_STG3_HOLD_S 0
#define LP_WDT_RTC_WDTFEED_REG (DR_REG_LP_WDT_BASE + 0x18) /** LP_WDT_FEED_REG register
/* LP_WDT_RTC_WDT_FEED : WO ;bitpos:[31] ;default: 1'd0 ; */ * need_des
/*description: .*/ */
#define LP_WDT_RTC_WDT_FEED (BIT(31)) #define LP_WDT_FEED_REG (DR_REG_LP_WDT_BASE + 0x14)
#define LP_WDT_RTC_WDT_FEED_M (BIT(31)) /** LP_WDT_FEED : WT; bitpos: [31]; default: 0;
#define LP_WDT_RTC_WDT_FEED_V 0x1 * need_des
#define LP_WDT_RTC_WDT_FEED_S 31 */
#define LP_WDT_FEED (BIT(31))
#define LP_WDT_FEED_M (LP_WDT_FEED_V << LP_WDT_FEED_S)
#define LP_WDT_FEED_V 0x00000001U
#define LP_WDT_FEED_S 31
#define LP_WDT_RTC_WDTWPROTECT_REG (DR_REG_LP_WDT_BASE + 0x1C) /** LP_WDT_WPROTECT_REG register
/* LP_WDT_WDT_WKEY : R/W ;bitpos:[31:0] ;default: 32'h50d83aa1 ; */ * need_des
/*description: .*/ */
#define LP_WDT_WDT_WKEY 0xFFFFFFFF #define LP_WDT_WPROTECT_REG (DR_REG_LP_WDT_BASE + 0x18)
#define LP_WDT_WDT_WKEY_M ((LP_WDT_WDT_WKEY_V)<<(LP_WDT_WDT_WKEY_S)) /** LP_WDT_WDT_WKEY : R/W; bitpos: [31:0]; default: 0;
#define LP_WDT_WDT_WKEY_V 0xFFFFFFFF * need_des
*/
#define LP_WDT_WDT_WKEY 0xFFFFFFFFU
#define LP_WDT_WDT_WKEY_M (LP_WDT_WDT_WKEY_V << LP_WDT_WDT_WKEY_S)
#define LP_WDT_WDT_WKEY_V 0xFFFFFFFFU
#define LP_WDT_WDT_WKEY_S 0 #define LP_WDT_WDT_WKEY_S 0
#define LP_WDT_RTC_SWD_CONF_REG (DR_REG_LP_WDT_BASE + 0x20) /** LP_WDT_SWD_CONFIG_REG register
/* LP_WDT_SWD_AUTO_FEED_EN : R/W ;bitpos:[31] ;default: 1'b0 ; */ * need_des
/*description: automatically feed swd when int comes.*/ */
#define LP_WDT_SWD_AUTO_FEED_EN (BIT(31)) #define LP_WDT_SWD_CONFIG_REG (DR_REG_LP_WDT_BASE + 0x1c)
#define LP_WDT_SWD_AUTO_FEED_EN_M (BIT(31)) /** LP_WDT_SWD_RESET_FLAG : RO; bitpos: [0]; default: 0;
#define LP_WDT_SWD_AUTO_FEED_EN_V 0x1 * need_des
#define LP_WDT_SWD_AUTO_FEED_EN_S 31 */
/* LP_WDT_SWD_DISABLE : R/W ;bitpos:[30] ;default: 1'b1 ; */
/*description: disabel SWD.*/
#define LP_WDT_SWD_DISABLE (BIT(30))
#define LP_WDT_SWD_DISABLE_M (BIT(30))
#define LP_WDT_SWD_DISABLE_V 0x1
#define LP_WDT_SWD_DISABLE_S 30
/* LP_WDT_SWD_FEED : WO ;bitpos:[29] ;default: 1'b0 ; */
/*description: Sw feed swd.*/
#define LP_WDT_SWD_FEED (BIT(29))
#define LP_WDT_SWD_FEED_M (BIT(29))
#define LP_WDT_SWD_FEED_V 0x1
#define LP_WDT_SWD_FEED_S 29
/* LP_WDT_SWD_RST_FLAG_CLR : WO ;bitpos:[28] ;default: 1'b0 ; */
/*description: reset swd reset flag.*/
#define LP_WDT_SWD_RST_FLAG_CLR (BIT(28))
#define LP_WDT_SWD_RST_FLAG_CLR_M (BIT(28))
#define LP_WDT_SWD_RST_FLAG_CLR_V 0x1
#define LP_WDT_SWD_RST_FLAG_CLR_S 28
/* LP_WDT_SWD_SIGNAL_WIDTH : R/W ;bitpos:[27:18] ;default: 10'd300 ; */
/*description: adjust signal width send to swd.*/
#define LP_WDT_SWD_SIGNAL_WIDTH 0x000003FF
#define LP_WDT_SWD_SIGNAL_WIDTH_M ((LP_WDT_SWD_SIGNAL_WIDTH_V)<<(LP_WDT_SWD_SIGNAL_WIDTH_S))
#define LP_WDT_SWD_SIGNAL_WIDTH_V 0x3FF
#define LP_WDT_SWD_SIGNAL_WIDTH_S 18
/* LP_WDT_SWD_FEED_INT : RO ;bitpos:[1] ;default: 1'b0 ; */
/*description: swd interrupt for feeding.*/
#define LP_WDT_SWD_FEED_INT (BIT(1))
#define LP_WDT_SWD_FEED_INT_M (BIT(1))
#define LP_WDT_SWD_FEED_INT_V 0x1
#define LP_WDT_SWD_FEED_INT_S 1
/* LP_WDT_SWD_RESET_FLAG : RO ;bitpos:[0] ;default: 1'b0 ; */
/*description: swd reset flag.*/
#define LP_WDT_SWD_RESET_FLAG (BIT(0)) #define LP_WDT_SWD_RESET_FLAG (BIT(0))
#define LP_WDT_SWD_RESET_FLAG_M (BIT(0)) #define LP_WDT_SWD_RESET_FLAG_M (LP_WDT_SWD_RESET_FLAG_V << LP_WDT_SWD_RESET_FLAG_S)
#define LP_WDT_SWD_RESET_FLAG_V 0x1 #define LP_WDT_SWD_RESET_FLAG_V 0x00000001U
#define LP_WDT_SWD_RESET_FLAG_S 0 #define LP_WDT_SWD_RESET_FLAG_S 0
/** LP_WDT_SWD_AUTO_FEED_EN : R/W; bitpos: [18]; default: 0;
* need_des
*/
#define LP_WDT_SWD_AUTO_FEED_EN (BIT(18))
#define LP_WDT_SWD_AUTO_FEED_EN_M (LP_WDT_SWD_AUTO_FEED_EN_V << LP_WDT_SWD_AUTO_FEED_EN_S)
#define LP_WDT_SWD_AUTO_FEED_EN_V 0x00000001U
#define LP_WDT_SWD_AUTO_FEED_EN_S 18
/** LP_WDT_SWD_RST_FLAG_CLR : WT; bitpos: [19]; default: 0;
* need_des
*/
#define LP_WDT_SWD_RST_FLAG_CLR (BIT(19))
#define LP_WDT_SWD_RST_FLAG_CLR_M (LP_WDT_SWD_RST_FLAG_CLR_V << LP_WDT_SWD_RST_FLAG_CLR_S)
#define LP_WDT_SWD_RST_FLAG_CLR_V 0x00000001U
#define LP_WDT_SWD_RST_FLAG_CLR_S 19
/** LP_WDT_SWD_SIGNAL_WIDTH : R/W; bitpos: [29:20]; default: 300;
* need_des
*/
#define LP_WDT_SWD_SIGNAL_WIDTH 0x000003FFU
#define LP_WDT_SWD_SIGNAL_WIDTH_M (LP_WDT_SWD_SIGNAL_WIDTH_V << LP_WDT_SWD_SIGNAL_WIDTH_S)
#define LP_WDT_SWD_SIGNAL_WIDTH_V 0x000003FFU
#define LP_WDT_SWD_SIGNAL_WIDTH_S 20
/** LP_WDT_SWD_DISABLE : R/W; bitpos: [30]; default: 0;
* need_des
*/
#define LP_WDT_SWD_DISABLE (BIT(30))
#define LP_WDT_SWD_DISABLE_M (LP_WDT_SWD_DISABLE_V << LP_WDT_SWD_DISABLE_S)
#define LP_WDT_SWD_DISABLE_V 0x00000001U
#define LP_WDT_SWD_DISABLE_S 30
/** LP_WDT_SWD_FEED : WT; bitpos: [31]; default: 0;
* need_des
*/
#define LP_WDT_SWD_FEED (BIT(31))
#define LP_WDT_SWD_FEED_M (LP_WDT_SWD_FEED_V << LP_WDT_SWD_FEED_S)
#define LP_WDT_SWD_FEED_V 0x00000001U
#define LP_WDT_SWD_FEED_S 31
#define LP_WDT_RTC_SWD_WPROTECT_REG (DR_REG_LP_WDT_BASE + 0x24) /** LP_WDT_SWD_WPROTECT_REG register
/* LP_WDT_SWD_WKEY : R/W ;bitpos:[31:0] ;default: 32'h8f1d312a ; */ * need_des
/*description: swd write protect.*/ */
#define LP_WDT_SWD_WKEY 0xFFFFFFFF #define LP_WDT_SWD_WPROTECT_REG (DR_REG_LP_WDT_BASE + 0x20)
#define LP_WDT_SWD_WKEY_M ((LP_WDT_SWD_WKEY_V)<<(LP_WDT_SWD_WKEY_S)) /** LP_WDT_SWD_WKEY : R/W; bitpos: [31:0]; default: 0;
#define LP_WDT_SWD_WKEY_V 0xFFFFFFFF * need_des
*/
#define LP_WDT_SWD_WKEY 0xFFFFFFFFU
#define LP_WDT_SWD_WKEY_M (LP_WDT_SWD_WKEY_V << LP_WDT_SWD_WKEY_S)
#define LP_WDT_SWD_WKEY_V 0xFFFFFFFFU
#define LP_WDT_SWD_WKEY_S 0 #define LP_WDT_SWD_WKEY_S 0
#define LP_WDT_WDT_CLK_EN_REG (DR_REG_LP_WDT_BASE + 0x28) /** LP_WDT_INT_RAW_REG register
/* LP_WDT_CLK_EN : R/W ;bitpos:[0] ;default: 1'b0 ; */ * need_des
/*description: .*/ */
#define LP_WDT_CLK_EN (BIT(0)) #define LP_WDT_INT_RAW_REG (DR_REG_LP_WDT_BASE + 0x24)
#define LP_WDT_CLK_EN_M (BIT(0)) /** LP_WDT_SUPER_WDT_INT_RAW : R/WTC/SS; bitpos: [30]; default: 0;
#define LP_WDT_CLK_EN_V 0x1 * need_des
#define LP_WDT_CLK_EN_S 0 */
#define LP_WDT_SUPER_WDT_INT_RAW (BIT(30))
#define LP_WDT_SUPER_WDT_INT_RAW_M (LP_WDT_SUPER_WDT_INT_RAW_V << LP_WDT_SUPER_WDT_INT_RAW_S)
#define LP_WDT_SUPER_WDT_INT_RAW_V 0x00000001U
#define LP_WDT_SUPER_WDT_INT_RAW_S 30
/** LP_WDT_LP_WDT_INT_RAW : R/WTC/SS; bitpos: [31]; default: 0;
* need_des
*/
#define LP_WDT_LP_WDT_INT_RAW (BIT(31))
#define LP_WDT_LP_WDT_INT_RAW_M (LP_WDT_LP_WDT_INT_RAW_V << LP_WDT_LP_WDT_INT_RAW_S)
#define LP_WDT_LP_WDT_INT_RAW_V 0x00000001U
#define LP_WDT_LP_WDT_INT_RAW_S 31
#define LP_WDT_INT_ENA_RTC_W1TS_REG (DR_REG_LP_WDT_BASE + 0x2C) /** LP_WDT_INT_ST_REG register
/* LP_WDT_RTC_SWD_INT_ENA_W1TS : WO ;bitpos:[1] ;default: 1'b0 ; */ * need_des
/*description: enable super watch dog interrupt.*/ */
#define LP_WDT_RTC_SWD_INT_ENA_W1TS (BIT(1)) #define LP_WDT_INT_ST_REG (DR_REG_LP_WDT_BASE + 0x28)
#define LP_WDT_RTC_SWD_INT_ENA_W1TS_M (BIT(1)) /** LP_WDT_SUPER_WDT_INT_ST : RO; bitpos: [30]; default: 0;
#define LP_WDT_RTC_SWD_INT_ENA_W1TS_V 0x1 * need_des
#define LP_WDT_RTC_SWD_INT_ENA_W1TS_S 1 */
/* LP_WDT_RTC_WDT_INT_ENA_W1TS : WO ;bitpos:[0] ;default: 1'b0 ; */ #define LP_WDT_SUPER_WDT_INT_ST (BIT(30))
/*description: enable RTC WDT interrupt.*/ #define LP_WDT_SUPER_WDT_INT_ST_M (LP_WDT_SUPER_WDT_INT_ST_V << LP_WDT_SUPER_WDT_INT_ST_S)
#define LP_WDT_RTC_WDT_INT_ENA_W1TS (BIT(0)) #define LP_WDT_SUPER_WDT_INT_ST_V 0x00000001U
#define LP_WDT_RTC_WDT_INT_ENA_W1TS_M (BIT(0)) #define LP_WDT_SUPER_WDT_INT_ST_S 30
#define LP_WDT_RTC_WDT_INT_ENA_W1TS_V 0x1 /** LP_WDT_LP_WDT_INT_ST : RO; bitpos: [31]; default: 0;
#define LP_WDT_RTC_WDT_INT_ENA_W1TS_S 0 * need_des
*/
#define LP_WDT_LP_WDT_INT_ST (BIT(31))
#define LP_WDT_LP_WDT_INT_ST_M (LP_WDT_LP_WDT_INT_ST_V << LP_WDT_LP_WDT_INT_ST_S)
#define LP_WDT_LP_WDT_INT_ST_V 0x00000001U
#define LP_WDT_LP_WDT_INT_ST_S 31
#define LP_WDT_INT_ENA_RTC_W1TC_REG (DR_REG_LP_WDT_BASE + 0x30) /** LP_WDT_INT_ENA_REG register
/* LP_WDT_RTC_SWD_INT_ENA_W1TC : WO ;bitpos:[1] ;default: 1'b0 ; */ * need_des
/*description: enable super watch dog interrupt.*/ */
#define LP_WDT_RTC_SWD_INT_ENA_W1TC (BIT(1)) #define LP_WDT_INT_ENA_REG (DR_REG_LP_WDT_BASE + 0x2c)
#define LP_WDT_RTC_SWD_INT_ENA_W1TC_M (BIT(1)) /** LP_WDT_SUPER_WDT_INT_ENA : R/W; bitpos: [30]; default: 0;
#define LP_WDT_RTC_SWD_INT_ENA_W1TC_V 0x1 * need_des
#define LP_WDT_RTC_SWD_INT_ENA_W1TC_S 1 */
/* LP_WDT_RTC_WDT_INT_ENA_W1TC : WO ;bitpos:[0] ;default: 1'b0 ; */ #define LP_WDT_SUPER_WDT_INT_ENA (BIT(30))
/*description: enable RTC WDT interrupt.*/ #define LP_WDT_SUPER_WDT_INT_ENA_M (LP_WDT_SUPER_WDT_INT_ENA_V << LP_WDT_SUPER_WDT_INT_ENA_S)
#define LP_WDT_RTC_WDT_INT_ENA_W1TC (BIT(0)) #define LP_WDT_SUPER_WDT_INT_ENA_V 0x00000001U
#define LP_WDT_RTC_WDT_INT_ENA_W1TC_M (BIT(0)) #define LP_WDT_SUPER_WDT_INT_ENA_S 30
#define LP_WDT_RTC_WDT_INT_ENA_W1TC_V 0x1 /** LP_WDT_LP_WDT_INT_ENA : R/W; bitpos: [31]; default: 0;
#define LP_WDT_RTC_WDT_INT_ENA_W1TC_S 0 * need_des
*/
#define LP_WDT_LP_WDT_INT_ENA (BIT(31))
#define LP_WDT_LP_WDT_INT_ENA_M (LP_WDT_LP_WDT_INT_ENA_V << LP_WDT_LP_WDT_INT_ENA_S)
#define LP_WDT_LP_WDT_INT_ENA_V 0x00000001U
#define LP_WDT_LP_WDT_INT_ENA_S 31
#define LP_WDT_INT_ENA_RTC_REG (DR_REG_LP_WDT_BASE + 0x34) /** LP_WDT_INT_CLR_REG register
/* LP_WDT_RTC_XTAL32K_DEAD_INT_ENA : R/W ;bitpos:[2] ;default: 1'b0 ; */ * need_des
/*description: enable xtal32k_dead interrupt.*/ */
#define LP_WDT_RTC_XTAL32K_DEAD_INT_ENA (BIT(2)) #define LP_WDT_INT_CLR_REG (DR_REG_LP_WDT_BASE + 0x30)
#define LP_WDT_RTC_XTAL32K_DEAD_INT_ENA_M (BIT(2)) /** LP_WDT_SUPER_WDT_INT_CLR : WT; bitpos: [30]; default: 0;
#define LP_WDT_RTC_XTAL32K_DEAD_INT_ENA_V 0x1 * need_des
#define LP_WDT_RTC_XTAL32K_DEAD_INT_ENA_S 2 */
/* LP_WDT_RTC_SWD_INT_ENA : R/W ;bitpos:[1] ;default: 1'b0 ; */ #define LP_WDT_SUPER_WDT_INT_CLR (BIT(30))
/*description: enable super watch dog interrupt.*/ #define LP_WDT_SUPER_WDT_INT_CLR_M (LP_WDT_SUPER_WDT_INT_CLR_V << LP_WDT_SUPER_WDT_INT_CLR_S)
#define LP_WDT_RTC_SWD_INT_ENA (BIT(1)) #define LP_WDT_SUPER_WDT_INT_CLR_V 0x00000001U
#define LP_WDT_RTC_SWD_INT_ENA_M (BIT(1)) #define LP_WDT_SUPER_WDT_INT_CLR_S 30
#define LP_WDT_RTC_SWD_INT_ENA_V 0x1 /** LP_WDT_LP_WDT_INT_CLR : WT; bitpos: [31]; default: 0;
#define LP_WDT_RTC_SWD_INT_ENA_S 1 * need_des
/* LP_WDT_RTC_WDT_INT_ENA : R/W ;bitpos:[0] ;default: 1'b0 ; */ */
/*description: enable RTC WDT interrupt.*/ #define LP_WDT_LP_WDT_INT_CLR (BIT(31))
#define LP_WDT_RTC_WDT_INT_ENA (BIT(0)) #define LP_WDT_LP_WDT_INT_CLR_M (LP_WDT_LP_WDT_INT_CLR_V << LP_WDT_LP_WDT_INT_CLR_S)
#define LP_WDT_RTC_WDT_INT_ENA_M (BIT(0)) #define LP_WDT_LP_WDT_INT_CLR_V 0x00000001U
#define LP_WDT_RTC_WDT_INT_ENA_V 0x1 #define LP_WDT_LP_WDT_INT_CLR_S 31
#define LP_WDT_RTC_WDT_INT_ENA_S 0
#define LP_WDT_INT_RAW_RTC_REG (DR_REG_LP_WDT_BASE + 0x38)
/* LP_WDT_RTC_XTAL32K_DEAD_INT_RAW : RO ;bitpos:[2] ;default: 1'b0 ; */
/*description: xtal32k dead detection interrupt raw.*/
#define LP_WDT_RTC_XTAL32K_DEAD_INT_RAW (BIT(2))
#define LP_WDT_RTC_XTAL32K_DEAD_INT_RAW_M (BIT(2))
#define LP_WDT_RTC_XTAL32K_DEAD_INT_RAW_V 0x1
#define LP_WDT_RTC_XTAL32K_DEAD_INT_RAW_S 2
/* LP_WDT_RTC_SWD_INT_RAW : RO ;bitpos:[1] ;default: 1'b0 ; */
/*description: super watch dog interrupt raw.*/
#define LP_WDT_RTC_SWD_INT_RAW (BIT(1))
#define LP_WDT_RTC_SWD_INT_RAW_M (BIT(1))
#define LP_WDT_RTC_SWD_INT_RAW_V 0x1
#define LP_WDT_RTC_SWD_INT_RAW_S 1
/* LP_WDT_RTC_WDT_INT_RAW : RO ;bitpos:[0] ;default: 1'b0 ; */
/*description: RTC WDT interrupt raw.*/
#define LP_WDT_RTC_WDT_INT_RAW (BIT(0))
#define LP_WDT_RTC_WDT_INT_RAW_M (BIT(0))
#define LP_WDT_RTC_WDT_INT_RAW_V 0x1
#define LP_WDT_RTC_WDT_INT_RAW_S 0
#define LP_WDT_INT_SWD_ST_RTC_REG (DR_REG_LP_WDT_BASE + 0x3C)
/* LP_WDT_RTC_XTAL32K_DEAD_INT_ST : RO ;bitpos:[2] ;default: 1'b0 ; */
/*description: xtal32k dead detection interrupt state.*/
#define LP_WDT_RTC_XTAL32K_DEAD_INT_ST (BIT(2))
#define LP_WDT_RTC_XTAL32K_DEAD_INT_ST_M (BIT(2))
#define LP_WDT_RTC_XTAL32K_DEAD_INT_ST_V 0x1
#define LP_WDT_RTC_XTAL32K_DEAD_INT_ST_S 2
/* LP_WDT_RTC_SWD_INT_ST : RO ;bitpos:[1] ;default: 1'b0 ; */
/*description: super watch dog interrupt state.*/
#define LP_WDT_RTC_SWD_INT_ST (BIT(1))
#define LP_WDT_RTC_SWD_INT_ST_M (BIT(1))
#define LP_WDT_RTC_SWD_INT_ST_V 0x1
#define LP_WDT_RTC_SWD_INT_ST_S 1
/* LP_WDT_RTC_WDT_INT_ST : RO ;bitpos:[0] ;default: 1'b0 ; */
/*description: watch dog interrupt state.*/
#define LP_WDT_RTC_WDT_INT_ST (BIT(0))
#define LP_WDT_RTC_WDT_INT_ST_M (BIT(0))
#define LP_WDT_RTC_WDT_INT_ST_V 0x1
#define LP_WDT_RTC_WDT_INT_ST_S 0
#define LP_WDT_INT_CLR_RTC_REG (DR_REG_LP_WDT_BASE + 0x40)
/* LP_WDT_RTC_XTAL32K_DEAD_INT_CLR : WO ;bitpos:[2] ;default: 1'b0 ; */
/*description: Clear RTC WDT interrupt state.*/
#define LP_WDT_RTC_XTAL32K_DEAD_INT_CLR (BIT(2))
#define LP_WDT_RTC_XTAL32K_DEAD_INT_CLR_M (BIT(2))
#define LP_WDT_RTC_XTAL32K_DEAD_INT_CLR_V 0x1
#define LP_WDT_RTC_XTAL32K_DEAD_INT_CLR_S 2
/* LP_WDT_RTC_SWD_INT_CLR : WO ;bitpos:[1] ;default: 1'b0 ; */
/*description: Clear super watch dog interrupt state.*/
#define LP_WDT_RTC_SWD_INT_CLR (BIT(1))
#define LP_WDT_RTC_SWD_INT_CLR_M (BIT(1))
#define LP_WDT_RTC_SWD_INT_CLR_V 0x1
#define LP_WDT_RTC_SWD_INT_CLR_S 1
/* LP_WDT_RTC_WDT_INT_CLR : WO ;bitpos:[0] ;default: 1'b0 ; */
/*description: Clear RTC WDT interrupt state.*/
#define LP_WDT_RTC_WDT_INT_CLR (BIT(0))
#define LP_WDT_RTC_WDT_INT_CLR_M (BIT(0))
#define LP_WDT_RTC_WDT_INT_CLR_V 0x1
#define LP_WDT_RTC_WDT_INT_CLR_S 0
#define LP_WDT_RTC_EXT_XTL_CONF_REG (DR_REG_LP_WDT_BASE + 0x44)
/* LP_WDT_XTL_EXT_CTR_EN : R/W ;bitpos:[31] ;default: 1'b0 ; */
/*description: .*/
#define LP_WDT_XTL_EXT_CTR_EN (BIT(31))
#define LP_WDT_XTL_EXT_CTR_EN_M (BIT(31))
#define LP_WDT_XTL_EXT_CTR_EN_V 0x1
#define LP_WDT_XTL_EXT_CTR_EN_S 31
/* LP_WDT_XTL_EXT_CTR_LV : R/W ;bitpos:[30] ;default: 1'b0 ; */
/*description: 0: power down XTAL at high level; 1: power down XTAL at low level.*/
#define LP_WDT_XTL_EXT_CTR_LV (BIT(30))
#define LP_WDT_XTL_EXT_CTR_LV_M (BIT(30))
#define LP_WDT_XTL_EXT_CTR_LV_V 0x1
#define LP_WDT_XTL_EXT_CTR_LV_S 30
/* LP_WDT_RTC_XTAL32K_GPIO_SEL : R/W ;bitpos:[23] ;default: 1'b0 ; */
/*description: XTAL_32K sel. ; 0: external XTAL_32K; 1: CLK from RTC pad X32P_C.*/
#define LP_WDT_RTC_XTAL32K_GPIO_SEL (BIT(23))
#define LP_WDT_RTC_XTAL32K_GPIO_SEL_M (BIT(23))
#define LP_WDT_RTC_XTAL32K_GPIO_SEL_V 0x1
#define LP_WDT_RTC_XTAL32K_GPIO_SEL_S 23
/* LP_WDT_RTC_WDT_STATE : RO ;bitpos:[22:20] ;default: 3'h0 ; */
/*description: state of 32k_wdt.*/
#define LP_WDT_RTC_WDT_STATE 0x00000007
#define LP_WDT_RTC_WDT_STATE_M ((LP_WDT_RTC_WDT_STATE_V)<<(LP_WDT_RTC_WDT_STATE_S))
#define LP_WDT_RTC_WDT_STATE_V 0x7
#define LP_WDT_RTC_WDT_STATE_S 20
/* LP_WDT_DAC_XTAL_32K : R/W ;bitpos:[19:17] ;default: 3'd3 ; */
/*description: DAC_XTAL_32K.*/
#define LP_WDT_DAC_XTAL_32K 0x00000007
#define LP_WDT_DAC_XTAL_32K_M ((LP_WDT_DAC_XTAL_32K_V)<<(LP_WDT_DAC_XTAL_32K_S))
#define LP_WDT_DAC_XTAL_32K_V 0x7
#define LP_WDT_DAC_XTAL_32K_S 17
/* LP_WDT_XPD_XTAL_32K : R/W ;bitpos:[16] ;default: 1'd0 ; */
/*description: XPD_XTAL_32K.*/
#define LP_WDT_XPD_XTAL_32K (BIT(16))
#define LP_WDT_XPD_XTAL_32K_M (BIT(16))
#define LP_WDT_XPD_XTAL_32K_V 0x1
#define LP_WDT_XPD_XTAL_32K_S 16
/* LP_WDT_DRES_XTAL_32K : R/W ;bitpos:[15:13] ;default: 3'd3 ; */
/*description: DRES_XTAL_32K.*/
#define LP_WDT_DRES_XTAL_32K 0x00000007
#define LP_WDT_DRES_XTAL_32K_M ((LP_WDT_DRES_XTAL_32K_V)<<(LP_WDT_DRES_XTAL_32K_S))
#define LP_WDT_DRES_XTAL_32K_V 0x7
#define LP_WDT_DRES_XTAL_32K_S 13
/* LP_WDT_DGM_XTAL_32K : R/W ;bitpos:[12:10] ;default: 3'd3 ; */
/*description: xtal_32k gm control.*/
#define LP_WDT_DGM_XTAL_32K 0x00000007
#define LP_WDT_DGM_XTAL_32K_M ((LP_WDT_DGM_XTAL_32K_V)<<(LP_WDT_DGM_XTAL_32K_S))
#define LP_WDT_DGM_XTAL_32K_V 0x7
#define LP_WDT_DGM_XTAL_32K_S 10
/* LP_WDT_DBUF_XTAL_32K : R/W ;bitpos:[9] ;default: 1'b0 ; */
/*description: 0: single-end buffer 1: differential buffer.*/
#define LP_WDT_DBUF_XTAL_32K (BIT(9))
#define LP_WDT_DBUF_XTAL_32K_M (BIT(9))
#define LP_WDT_DBUF_XTAL_32K_V 0x1
#define LP_WDT_DBUF_XTAL_32K_S 9
/* LP_WDT_ENCKINIT_XTAL_32K : R/W ;bitpos:[8] ;default: 1'b0 ; */
/*description: apply an internal clock to help xtal 32k to start.*/
#define LP_WDT_ENCKINIT_XTAL_32K (BIT(8))
#define LP_WDT_ENCKINIT_XTAL_32K_M (BIT(8))
#define LP_WDT_ENCKINIT_XTAL_32K_V 0x1
#define LP_WDT_ENCKINIT_XTAL_32K_S 8
/* LP_WDT_XTAL32K_XPD_FORCE : R/W ;bitpos:[7] ;default: 1'b1 ; */
/*description: Xtal 32k xpd control by sw or fsm.*/
#define LP_WDT_XTAL32K_XPD_FORCE (BIT(7))
#define LP_WDT_XTAL32K_XPD_FORCE_M (BIT(7))
#define LP_WDT_XTAL32K_XPD_FORCE_V 0x1
#define LP_WDT_XTAL32K_XPD_FORCE_S 7
/* LP_WDT_XTAL32K_AUTO_RETURN : R/W ;bitpos:[6] ;default: 1'b0 ; */
/*description: xtal 32k switch back xtal when xtal is restarted.*/
#define LP_WDT_XTAL32K_AUTO_RETURN (BIT(6))
#define LP_WDT_XTAL32K_AUTO_RETURN_M (BIT(6))
#define LP_WDT_XTAL32K_AUTO_RETURN_V 0x1
#define LP_WDT_XTAL32K_AUTO_RETURN_S 6
/* LP_WDT_XTAL32K_AUTO_RESTART : R/W ;bitpos:[5] ;default: 1'b0 ; */
/*description: xtal 32k restart xtal when xtal is dead.*/
#define LP_WDT_XTAL32K_AUTO_RESTART (BIT(5))
#define LP_WDT_XTAL32K_AUTO_RESTART_M (BIT(5))
#define LP_WDT_XTAL32K_AUTO_RESTART_V 0x1
#define LP_WDT_XTAL32K_AUTO_RESTART_S 5
/* LP_WDT_XTAL32K_AUTO_BACKUP : R/W ;bitpos:[4] ;default: 1'b0 ; */
/*description: xtal 32k switch to back up clock when xtal is dead.*/
#define LP_WDT_XTAL32K_AUTO_BACKUP (BIT(4))
#define LP_WDT_XTAL32K_AUTO_BACKUP_M (BIT(4))
#define LP_WDT_XTAL32K_AUTO_BACKUP_V 0x1
#define LP_WDT_XTAL32K_AUTO_BACKUP_S 4
/* LP_WDT_XTAL32K_EXT_CLK_FO : R/W ;bitpos:[3] ;default: 1'b0 ; */
/*description: xtal 32k external xtal clock force on.*/
#define LP_WDT_XTAL32K_EXT_CLK_FO (BIT(3))
#define LP_WDT_XTAL32K_EXT_CLK_FO_M (BIT(3))
#define LP_WDT_XTAL32K_EXT_CLK_FO_V 0x1
#define LP_WDT_XTAL32K_EXT_CLK_FO_S 3
/* LP_WDT_XTAL32K_WDT_RESET : R/W ;bitpos:[2] ;default: 1'b0 ; */
/*description: xtal 32k watch dog sw reset.*/
#define LP_WDT_XTAL32K_WDT_RESET (BIT(2))
#define LP_WDT_XTAL32K_WDT_RESET_M (BIT(2))
#define LP_WDT_XTAL32K_WDT_RESET_V 0x1
#define LP_WDT_XTAL32K_WDT_RESET_S 2
/* LP_WDT_XTAL32K_WDT_CLK_FO : R/W ;bitpos:[1] ;default: 1'b0 ; */
/*description: xtal 32k watch dog clock force on.*/
#define LP_WDT_XTAL32K_WDT_CLK_FO (BIT(1))
#define LP_WDT_XTAL32K_WDT_CLK_FO_M (BIT(1))
#define LP_WDT_XTAL32K_WDT_CLK_FO_V 0x1
#define LP_WDT_XTAL32K_WDT_CLK_FO_S 1
/* LP_WDT_XTAL32K_WDT_EN : R/W ;bitpos:[0] ;default: 1'b0 ; */
/*description: xtal 32k watch dog enable.*/
#define LP_WDT_XTAL32K_WDT_EN (BIT(0))
#define LP_WDT_XTAL32K_WDT_EN_M (BIT(0))
#define LP_WDT_XTAL32K_WDT_EN_V 0x1
#define LP_WDT_XTAL32K_WDT_EN_S 0
#define LP_WDT_RTC_XTAL32K_CLK_FACTOR_REG (DR_REG_LP_WDT_BASE + 0x48)
/* LP_WDT_XTAL32K_CLK_FACTOR : R/W ;bitpos:[31:0] ;default: 32'h0 ; */
/*description: xtal 32k watch dog backup clock factor.*/
#define LP_WDT_XTAL32K_CLK_FACTOR 0xFFFFFFFF
#define LP_WDT_XTAL32K_CLK_FACTOR_M ((LP_WDT_XTAL32K_CLK_FACTOR_V)<<(LP_WDT_XTAL32K_CLK_FACTOR_S))
#define LP_WDT_XTAL32K_CLK_FACTOR_V 0xFFFFFFFF
#define LP_WDT_XTAL32K_CLK_FACTOR_S 0
#define LP_WDT_RTC_XTAL32K_CONF_REG (DR_REG_LP_WDT_BASE + 0x5C)
/* LP_WDT_XTAL32K_STABLE_THRES : R/W ;bitpos:[31:28] ;default: 4'h0 ; */
/*description: if restarted xtal32k period is smaller than this, it is regarded as stable.*/
#define LP_WDT_XTAL32K_STABLE_THRES 0x0000000F
#define LP_WDT_XTAL32K_STABLE_THRES_M ((LP_WDT_XTAL32K_STABLE_THRES_V)<<(LP_WDT_XTAL32K_STABLE_THRES_S))
#define LP_WDT_XTAL32K_STABLE_THRES_V 0xF
#define LP_WDT_XTAL32K_STABLE_THRES_S 28
/* LP_WDT_XTAL32K_WDT_TIMEOUT : R/W ;bitpos:[27:20] ;default: 8'hff ; */
/*description: If no clock detected for this amount of time,32k is regarded as dead.*/
#define LP_WDT_XTAL32K_WDT_TIMEOUT 0x000000FF
#define LP_WDT_XTAL32K_WDT_TIMEOUT_M ((LP_WDT_XTAL32K_WDT_TIMEOUT_V)<<(LP_WDT_XTAL32K_WDT_TIMEOUT_S))
#define LP_WDT_XTAL32K_WDT_TIMEOUT_V 0xFF
#define LP_WDT_XTAL32K_WDT_TIMEOUT_S 20
/* LP_WDT_XTAL32K_RESTART_WAIT : R/W ;bitpos:[19:4] ;default: 16'h0 ; */
/*description: cycles to wait to repower on xtal 32k.*/
#define LP_WDT_XTAL32K_RESTART_WAIT 0x0000FFFF
#define LP_WDT_XTAL32K_RESTART_WAIT_M ((LP_WDT_XTAL32K_RESTART_WAIT_V)<<(LP_WDT_XTAL32K_RESTART_WAIT_S))
#define LP_WDT_XTAL32K_RESTART_WAIT_V 0xFFFF
#define LP_WDT_XTAL32K_RESTART_WAIT_S 4
/* LP_WDT_XTAL32K_RETURN_WAIT : R/W ;bitpos:[3:0] ;default: 4'h0 ; */
/*description: cycles to wait to return noral xtal 32k.*/
#define LP_WDT_XTAL32K_RETURN_WAIT 0x0000000F
#define LP_WDT_XTAL32K_RETURN_WAIT_M ((LP_WDT_XTAL32K_RETURN_WAIT_V)<<(LP_WDT_XTAL32K_RETURN_WAIT_S))
#define LP_WDT_XTAL32K_RETURN_WAIT_V 0xF
#define LP_WDT_XTAL32K_RETURN_WAIT_S 0
#define LP_WDT_RTC_EFUSE_FORCE_REG (DR_REG_LP_WDT_BASE + 0x60)
/* LP_WDT_WDT_FLASHBOOT_EFUSE_FORCE : R/W ;bitpos:[1] ;default: 1'b1 ; */
/*description: lp_wdt flashboot en default choose efuse control bit.*/
#define LP_WDT_WDT_FLASHBOOT_EFUSE_FORCE (BIT(1))
#define LP_WDT_WDT_FLASHBOOT_EFUSE_FORCE_M (BIT(1))
#define LP_WDT_WDT_FLASHBOOT_EFUSE_FORCE_V 0x1
#define LP_WDT_WDT_FLASHBOOT_EFUSE_FORCE_S 1
/* LP_WDT_SWD_DISABLE_EFUSE_FORCE : R/W ;bitpos:[0] ;default: 1'b1 ; */
/*description: swd disable default choose efuse control bit.*/
#define LP_WDT_SWD_DISABLE_EFUSE_FORCE (BIT(0))
#define LP_WDT_SWD_DISABLE_EFUSE_FORCE_M (BIT(0))
#define LP_WDT_SWD_DISABLE_EFUSE_FORCE_V 0x1
#define LP_WDT_SWD_DISABLE_EFUSE_FORCE_S 0
/** LP_WDT_DATE_REG register
* need_des
*/
#define LP_WDT_DATE_REG (DR_REG_LP_WDT_BASE + 0x3fc)
/** LP_WDT_LP_WDT_DATE : R/W; bitpos: [30:0]; default: 34676864;
* need_des
*/
#define LP_WDT_LP_WDT_DATE 0x7FFFFFFFU
#define LP_WDT_LP_WDT_DATE_M (LP_WDT_LP_WDT_DATE_V << LP_WDT_LP_WDT_DATE_S)
#define LP_WDT_LP_WDT_DATE_V 0x7FFFFFFFU
#define LP_WDT_LP_WDT_DATE_S 0
/** LP_WDT_CLK_EN : R/W; bitpos: [31]; default: 0;
* need_des
*/
#define LP_WDT_CLK_EN (BIT(31))
#define LP_WDT_CLK_EN_M (LP_WDT_CLK_EN_V << LP_WDT_CLK_EN_S)
#define LP_WDT_CLK_EN_V 0x00000001U
#define LP_WDT_CLK_EN_S 31
#ifdef __cplusplus #ifdef __cplusplus
} }

View File

@@ -1,5 +1,5 @@
/** /**
* SPDX-FileCopyrightText: 2022-2023 Espressif Systems (Shanghai) CO LTD * SPDX-FileCopyrightText: 2023 Espressif Systems (Shanghai) CO LTD
* *
* SPDX-License-Identifier: Apache-2.0 * SPDX-License-Identifier: Apache-2.0
*/ */
@@ -10,171 +10,301 @@
extern "C" { extern "C" {
#endif #endif
typedef volatile struct { /** Group: configure_register */
union { /** Type of config0 register
struct { * need_des
uint32_t reserved0 : 2; */
uint32_t wdt_chip_reset_width : 8; /*chip reset siginal pulse width*/ typedef union {
uint32_t wdt_chip_reset_en : 1; /*wdt reset whole chip enable*/ struct {
uint32_t wdt_pause_in_slp : 1; /*pause WDT in sleep*/ uint32_t reserved_0:9;
uint32_t wdt_flashboot_mod_en : 1; /*enable WDT in flash boot*/ /** wdt_pause_in_slp : R/W; bitpos: [9]; default: 1;
uint32_t wdt_sys_reset_length : 3; /*system reset counter length*/ * need_des
uint32_t wdt_cpu_reset_length : 3; /*CPU reset counter length*/ */
uint32_t wdt_stg3 : 3; /*1: interrupt stage en; 2: CPU reset stage en; 3: system reset stage en ; 4: RTC reset stage en*/ uint32_t wdt_pause_in_slp:1;
uint32_t wdt_stg2 : 3; /*1: interrupt stage en; 2: CPU reset stage en; 3: system reset stage en ; 4: RTC reset stage en*/ /** wdt_appcpu_reset_en : R/W; bitpos: [10]; default: 0;
uint32_t wdt_stg1 : 3; /*1: interrupt stage en; 2: CPU reset stage en; 3: system reset stage en ; 4: RTC reset stage en*/ * need_des
uint32_t wdt_stg0 : 3; /*1: interrupt stage en; 2: CPU reset stage en; 3: system reset stage en ; 4: RTC reset stage en*/ */
uint32_t wdt_en : 1; uint32_t wdt_appcpu_reset_en:1;
}; /** wdt_procpu_reset_en : R/W; bitpos: [11]; default: 0;
uint32_t val; * need_des
} wdtconfig0; */
union { uint32_t wdt_procpu_reset_en:1;
struct { /** wdt_flashboot_mod_en : R/W; bitpos: [12]; default: 1;
uint32_t reserved0 : 26; * need_des
uint32_t wdt_lp_peri_reset_en : 1; /*enable WDT reset LP PERI*/ */
uint32_t wdt_lp_cpu_reset_en : 1; /*enable WDT reset LP CPU*/ uint32_t wdt_flashboot_mod_en:1;
uint32_t wdt_core3cpu_reset_en : 1; /*enable WDT reset CORE3 CPU*/ /** wdt_sys_reset_length : R/W; bitpos: [15:13]; default: 1;
uint32_t wdt_core2cpu_reset_en : 1; /*enable WDT reset CORE2 CPU*/ * need_des
uint32_t wdt_core1cpu_reset_en : 1; /*enable WDT reset CORE1 CPU*/ */
uint32_t wdt_core0cpu_reset_en : 1; /*enable WDT reset CORE0 CPU*/ uint32_t wdt_sys_reset_length:3;
}; /** wdt_cpu_reset_length : R/W; bitpos: [18:16]; default: 1;
uint32_t val; * need_des
} wdtcpurst; */
uint32_t wdtconfig1; uint32_t wdt_cpu_reset_length:3;
uint32_t wdtconfig2; /** wdt_stg3 : R/W; bitpos: [21:19]; default: 0;
uint32_t wdtconfig3; * need_des
uint32_t wdtconfig4; */
union { uint32_t wdt_stg3:3;
struct { /** wdt_stg2 : R/W; bitpos: [24:22]; default: 0;
uint32_t reserved0 : 31; * need_des
uint32_t wdt_feed : 1; */
}; uint32_t wdt_stg2:3;
uint32_t val; /** wdt_stg1 : R/W; bitpos: [27:25]; default: 0;
} wdtfeed; * need_des
uint32_t wdtwprotect; */
union { uint32_t wdt_stg1:3;
struct { /** wdt_stg0 : R/W; bitpos: [30:28]; default: 0;
uint32_t swd_reset_flag : 1; /*swd reset flag*/ * need_des
uint32_t swd_feed_int : 1; /*swd interrupt for feeding*/ */
uint32_t reserved2 : 16; uint32_t wdt_stg0:3;
uint32_t swd_signal_width : 10; /*adjust signal width send to swd*/ /** wdt_en : R/W; bitpos: [31]; default: 0;
uint32_t swd_rst_flag_clr : 1; /*reset swd reset flag*/ * need_des
uint32_t swd_feed : 1; /*Sw feed swd*/ */
uint32_t swd_disable : 1; /*disabel SWD*/ uint32_t wdt_en:1;
uint32_t swd_auto_feed_en : 1; /*automatically feed swd when int comes*/ };
}; uint32_t val;
uint32_t val; } lp_wdt_config0_reg_t;
} swd_conf;
uint32_t swd_wprotect; /** Type of config1 register
union { * need_des
struct { */
uint32_t clk_en : 1; typedef union {
uint32_t reserved1 : 31; struct {
}; /** wdt_stg0_hold : R/W; bitpos: [31:0]; default: 200000;
uint32_t val; * need_des
} wdt_clk_en; */
union { uint32_t wdt_stg0_hold:32;
struct { };
uint32_t wdt : 1; /*enable RTC WDT interrupt*/ uint32_t val;
uint32_t swd : 1; /*enable super watch dog interrupt*/ } lp_wdt_config1_reg_t;
uint32_t reserved2 : 30;
}; /** Type of config2 register
uint32_t val; * need_des
} int_ena_w1ts; */
union { typedef union {
struct { struct {
uint32_t wdt : 1; /*enable RTC WDT interrupt*/ /** wdt_stg1_hold : R/W; bitpos: [31:0]; default: 80000;
uint32_t swd : 1; /*enable super watch dog interrupt*/ * need_des
uint32_t reserved2 : 30; */
}; uint32_t wdt_stg1_hold:32;
uint32_t val; };
} int_ena_w1tc; uint32_t val;
union { } lp_wdt_config2_reg_t;
struct {
uint32_t wdt : 1; /*enable RTC WDT interrupt*/ /** Type of config3 register
uint32_t swd : 1; /*enable super watch dog interrupt*/ * need_des
uint32_t xtal32k_dead : 1; /*enable xtal32k_dead interrupt*/ */
uint32_t reserved3 : 29; typedef union {
}; struct {
uint32_t val; /** wdt_stg2_hold : R/W; bitpos: [31:0]; default: 4095;
} int_ena; * need_des
union { */
struct { uint32_t wdt_stg2_hold:32;
uint32_t wdt : 1; /*RTC WDT interrupt raw*/ };
uint32_t swd : 1; /*super watch dog interrupt raw*/ uint32_t val;
uint32_t xtal32k_dead : 1; /*xtal32k dead detection interrupt raw*/ } lp_wdt_config3_reg_t;
uint32_t reserved3 : 29;
}; /** Type of config4 register
uint32_t val; * need_des
} int_raw; */
union { typedef union {
struct { struct {
uint32_t wdt : 1; /*watch dog interrupt state*/ /** wdt_stg3_hold : R/W; bitpos: [31:0]; default: 4095;
uint32_t swd : 1; /*super watch dog interrupt state*/ * need_des
uint32_t xtal32k_dead : 1; /*xtal32k dead detection interrupt state*/ */
uint32_t reserved3 : 29; uint32_t wdt_stg3_hold:32;
}; };
uint32_t val; uint32_t val;
} int_swd_st; } lp_wdt_config4_reg_t;
union {
struct { /** Type of feed register
uint32_t wdt : 1; /*Clear RTC WDT interrupt state*/ * need_des
uint32_t swd : 1; /*Clear super watch dog interrupt state*/ */
uint32_t xtal32k_dead : 1; /*Clear RTC WDT interrupt state*/ typedef union {
uint32_t reserved3 : 29; struct {
}; uint32_t reserved_0:31;
uint32_t val; /** feed : WT; bitpos: [31]; default: 0;
} int_clr; * need_des
union { */
struct { uint32_t feed:1;
uint32_t xtal32k_wdt_en : 1; /*xtal 32k watch dog enable*/ };
uint32_t xtal32k_wdt_clk_fo : 1; /*xtal 32k watch dog clock force on*/ uint32_t val;
uint32_t xtal32k_wdt_reset : 1; /*xtal 32k watch dog sw reset*/ } lp_wdt_feed_reg_t;
uint32_t xtal32k_ext_clk_fo : 1; /*xtal 32k external xtal clock force on*/
uint32_t xtal32k_auto_backup : 1; /*xtal 32k switch to back up clock when xtal is dead*/ /** Type of wprotect register
uint32_t xtal32k_auto_restart : 1; /*xtal 32k restart xtal when xtal is dead*/ * need_des
uint32_t xtal32k_auto_return : 1; /*xtal 32k switch back xtal when xtal is restarted*/ */
uint32_t xtal32k_xpd_force : 1; /*Xtal 32k xpd control by sw or fsm*/ typedef union {
uint32_t enckinit_xtal_32k : 1; /*apply an internal clock to help xtal 32k to start*/ struct {
uint32_t dbuf_xtal_32k : 1; /*0: single-end buffer 1: differential buffer*/ /** wdt_wkey : R/W; bitpos: [31:0]; default: 0;
uint32_t dgm_xtal_32k : 3; /*xtal_32k gm control*/ * need_des
uint32_t dres_xtal_32k : 3; /*DRES_XTAL_32K*/ */
uint32_t xpd_xtal_32k : 1; /*XPD_XTAL_32K*/ uint32_t wdt_wkey:32;
uint32_t dac_xtal_32k : 3; /*DAC_XTAL_32K*/ };
uint32_t wdt_state : 3; /*state of 32k_wdt*/ uint32_t val;
uint32_t xtal32k_gpio_sel : 1; /*XTAL_32K sel. ; 0: external XTAL_32K; 1: CLK from RTC pad X32P_C*/ } lp_wdt_wprotect_reg_t;
uint32_t reserved24 : 6;
uint32_t xtl_ext_ctr_lv : 1; /*0: power down XTAL at high level; 1: power down XTAL at low level*/ /** Type of swd_config register
uint32_t xtl_ext_ctr_en : 1; * need_des
}; */
uint32_t val; typedef union {
} ext_xtl_conf; struct {
uint32_t xtal32k_clk_factor; /** swd_reset_flag : RO; bitpos: [0]; default: 0;
uint32_t reserved_4c; * need_des
uint32_t reserved_50; */
uint32_t reserved_54; uint32_t swd_reset_flag:1;
uint32_t reserved_58; uint32_t reserved_1:17;
union { /** swd_auto_feed_en : R/W; bitpos: [18]; default: 0;
struct { * need_des
uint32_t xtal32k_return_wait : 4; /*cycles to wait to return noral xtal 32k*/ */
uint32_t xtal32k_restart_wait : 16; /*cycles to wait to repower on xtal 32k*/ uint32_t swd_auto_feed_en:1;
uint32_t xtal32k_wdt_timeout : 8; /*If no clock detected for this amount of time,32k is regarded as dead*/ /** swd_rst_flag_clr : WT; bitpos: [19]; default: 0;
uint32_t xtal32k_stable_thres : 4; /*if restarted xtal32k period is smaller than this, it is regarded as stable*/ * need_des
}; */
uint32_t val; uint32_t swd_rst_flag_clr:1;
} xtal32k_conf; /** swd_signal_width : R/W; bitpos: [29:20]; default: 300;
union { * need_des
struct { */
uint32_t swd_disable_efuse_force : 1; /*swd disable default choose efuse control bit*/ uint32_t swd_signal_width:10;
uint32_t wdt_flashboot_efuse_force : 1; /*lp_wdt flashboot en default choose efuse control bit*/ /** swd_disable : R/W; bitpos: [30]; default: 0;
uint32_t reserved2 : 30; * need_des
}; */
uint32_t val; uint32_t swd_disable:1;
} efuse_force; /** swd_feed : WT; bitpos: [31]; default: 0;
* need_des
*/
uint32_t swd_feed:1;
};
uint32_t val;
} lp_wdt_swd_config_reg_t;
/** Type of swd_wprotect register
* need_des
*/
typedef union {
struct {
/** swd_wkey : R/W; bitpos: [31:0]; default: 0;
* need_des
*/
uint32_t swd_wkey:32;
};
uint32_t val;
} lp_wdt_swd_wprotect_reg_t;
/** Type of int_raw register
* need_des
*/
typedef union {
struct {
uint32_t reserved_0:30;
/** super_wdt_int_raw : R/WTC/SS; bitpos: [30]; default: 0;
* need_des
*/
uint32_t super_wdt_int_raw:1;
/** lp_wdt_int_raw : R/WTC/SS; bitpos: [31]; default: 0;
* need_des
*/
uint32_t lp_wdt_int_raw:1;
};
uint32_t val;
} lp_wdt_int_raw_reg_t;
/** Type of int_st register
* need_des
*/
typedef union {
struct {
uint32_t reserved_0:30;
/** super_wdt_int_st : RO; bitpos: [30]; default: 0;
* need_des
*/
uint32_t super_wdt_int_st:1;
/** lp_wdt_int_st : RO; bitpos: [31]; default: 0;
* need_des
*/
uint32_t lp_wdt_int_st:1;
};
uint32_t val;
} lp_wdt_int_st_reg_t;
/** Type of int_ena register
* need_des
*/
typedef union {
struct {
uint32_t reserved_0:30;
/** super_wdt_int_ena : R/W; bitpos: [30]; default: 0;
* need_des
*/
uint32_t super_wdt_int_ena:1;
/** lp_wdt_int_ena : R/W; bitpos: [31]; default: 0;
* need_des
*/
uint32_t lp_wdt_int_ena:1;
};
uint32_t val;
} lp_wdt_int_ena_reg_t;
/** Type of int_clr register
* need_des
*/
typedef union {
struct {
uint32_t reserved_0:30;
/** super_wdt_int_clr : WT; bitpos: [30]; default: 0;
* need_des
*/
uint32_t super_wdt_int_clr:1;
/** lp_wdt_int_clr : WT; bitpos: [31]; default: 0;
* need_des
*/
uint32_t lp_wdt_int_clr:1;
};
uint32_t val;
} lp_wdt_int_clr_reg_t;
/** Type of date register
* need_des
*/
typedef union {
struct {
/** lp_wdt_date : R/W; bitpos: [30:0]; default: 34676864;
* need_des
*/
uint32_t lp_wdt_date:31;
/** clk_en : R/W; bitpos: [31]; default: 0;
* need_des
*/
uint32_t clk_en:1;
};
uint32_t val;
} lp_wdt_date_reg_t;
typedef struct {
volatile lp_wdt_config0_reg_t config0;
volatile lp_wdt_config1_reg_t config1;
volatile lp_wdt_config2_reg_t config2;
volatile lp_wdt_config3_reg_t config3;
volatile lp_wdt_config4_reg_t config4;
volatile lp_wdt_feed_reg_t feed;
volatile lp_wdt_wprotect_reg_t wprotect;
volatile lp_wdt_swd_config_reg_t swd_config;
volatile lp_wdt_swd_wprotect_reg_t swd_wprotect;
volatile lp_wdt_int_raw_reg_t int_raw;
volatile lp_wdt_int_st_reg_t int_st;
volatile lp_wdt_int_ena_reg_t int_ena;
volatile lp_wdt_int_clr_reg_t int_clr;
uint32_t reserved_034[242];
volatile lp_wdt_date_reg_t date;
} lp_wdt_dev_t; } lp_wdt_dev_t;
extern lp_wdt_dev_t LP_WDT; extern lp_wdt_dev_t LP_WDT;
#ifndef __cplusplus
_Static_assert(sizeof(lp_wdt_dev_t) == 0x400, "Invalid size of lp_wdt_dev_t structure");
#endif
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View File

@@ -1,324 +0,0 @@
/**
* SPDX-FileCopyrightText: 2023 Espressif Systems (Shanghai) CO LTD
*
* SPDX-License-Identifier: Apache-2.0
*/
#pragma once
#include <stdint.h>
#include "soc/soc.h"
#ifdef __cplusplus
extern "C" {
#endif
/** RTC_WDT_CONFIG0_REG register
* need_des
*/
#define RTC_WDT_CONFIG0_REG (DR_REG_RTC_WDT_BASE + 0x0)
/** RTC_WDT_WDT_PAUSE_IN_SLP : R/W; bitpos: [9]; default: 1;
* need_des
*/
#define RTC_WDT_WDT_PAUSE_IN_SLP (BIT(9))
#define RTC_WDT_WDT_PAUSE_IN_SLP_M (RTC_WDT_WDT_PAUSE_IN_SLP_V << RTC_WDT_WDT_PAUSE_IN_SLP_S)
#define RTC_WDT_WDT_PAUSE_IN_SLP_V 0x00000001U
#define RTC_WDT_WDT_PAUSE_IN_SLP_S 9
/** RTC_WDT_WDT_APPCPU_RESET_EN : R/W; bitpos: [10]; default: 0;
* need_des
*/
#define RTC_WDT_WDT_APPCPU_RESET_EN (BIT(10))
#define RTC_WDT_WDT_APPCPU_RESET_EN_M (RTC_WDT_WDT_APPCPU_RESET_EN_V << RTC_WDT_WDT_APPCPU_RESET_EN_S)
#define RTC_WDT_WDT_APPCPU_RESET_EN_V 0x00000001U
#define RTC_WDT_WDT_APPCPU_RESET_EN_S 10
/** RTC_WDT_WDT_PROCPU_RESET_EN : R/W; bitpos: [11]; default: 0;
* need_des
*/
#define RTC_WDT_WDT_PROCPU_RESET_EN (BIT(11))
#define RTC_WDT_WDT_PROCPU_RESET_EN_M (RTC_WDT_WDT_PROCPU_RESET_EN_V << RTC_WDT_WDT_PROCPU_RESET_EN_S)
#define RTC_WDT_WDT_PROCPU_RESET_EN_V 0x00000001U
#define RTC_WDT_WDT_PROCPU_RESET_EN_S 11
/** RTC_WDT_WDT_FLASHBOOT_MOD_EN : R/W; bitpos: [12]; default: 1;
* need_des
*/
#define RTC_WDT_WDT_FLASHBOOT_MOD_EN (BIT(12))
#define RTC_WDT_WDT_FLASHBOOT_MOD_EN_M (RTC_WDT_WDT_FLASHBOOT_MOD_EN_V << RTC_WDT_WDT_FLASHBOOT_MOD_EN_S)
#define RTC_WDT_WDT_FLASHBOOT_MOD_EN_V 0x00000001U
#define RTC_WDT_WDT_FLASHBOOT_MOD_EN_S 12
/** RTC_WDT_WDT_SYS_RESET_LENGTH : R/W; bitpos: [15:13]; default: 1;
* need_des
*/
#define RTC_WDT_WDT_SYS_RESET_LENGTH 0x00000007U
#define RTC_WDT_WDT_SYS_RESET_LENGTH_M (RTC_WDT_WDT_SYS_RESET_LENGTH_V << RTC_WDT_WDT_SYS_RESET_LENGTH_S)
#define RTC_WDT_WDT_SYS_RESET_LENGTH_V 0x00000007U
#define RTC_WDT_WDT_SYS_RESET_LENGTH_S 13
/** RTC_WDT_WDT_CPU_RESET_LENGTH : R/W; bitpos: [18:16]; default: 1;
* need_des
*/
#define RTC_WDT_WDT_CPU_RESET_LENGTH 0x00000007U
#define RTC_WDT_WDT_CPU_RESET_LENGTH_M (RTC_WDT_WDT_CPU_RESET_LENGTH_V << RTC_WDT_WDT_CPU_RESET_LENGTH_S)
#define RTC_WDT_WDT_CPU_RESET_LENGTH_V 0x00000007U
#define RTC_WDT_WDT_CPU_RESET_LENGTH_S 16
/** RTC_WDT_WDT_STG3 : R/W; bitpos: [21:19]; default: 0;
* need_des
*/
#define RTC_WDT_WDT_STG3 0x00000007U
#define RTC_WDT_WDT_STG3_M (RTC_WDT_WDT_STG3_V << RTC_WDT_WDT_STG3_S)
#define RTC_WDT_WDT_STG3_V 0x00000007U
#define RTC_WDT_WDT_STG3_S 19
/** RTC_WDT_WDT_STG2 : R/W; bitpos: [24:22]; default: 0;
* need_des
*/
#define RTC_WDT_WDT_STG2 0x00000007U
#define RTC_WDT_WDT_STG2_M (RTC_WDT_WDT_STG2_V << RTC_WDT_WDT_STG2_S)
#define RTC_WDT_WDT_STG2_V 0x00000007U
#define RTC_WDT_WDT_STG2_S 22
/** RTC_WDT_WDT_STG1 : R/W; bitpos: [27:25]; default: 0;
* need_des
*/
#define RTC_WDT_WDT_STG1 0x00000007U
#define RTC_WDT_WDT_STG1_M (RTC_WDT_WDT_STG1_V << RTC_WDT_WDT_STG1_S)
#define RTC_WDT_WDT_STG1_V 0x00000007U
#define RTC_WDT_WDT_STG1_S 25
/** RTC_WDT_WDT_STG0 : R/W; bitpos: [30:28]; default: 0;
* need_des
*/
#define RTC_WDT_WDT_STG0 0x00000007U
#define RTC_WDT_WDT_STG0_M (RTC_WDT_WDT_STG0_V << RTC_WDT_WDT_STG0_S)
#define RTC_WDT_WDT_STG0_V 0x00000007U
#define RTC_WDT_WDT_STG0_S 28
/** RTC_WDT_WDT_EN : R/W; bitpos: [31]; default: 0;
* need_des
*/
#define RTC_WDT_WDT_EN (BIT(31))
#define RTC_WDT_WDT_EN_M (RTC_WDT_WDT_EN_V << RTC_WDT_WDT_EN_S)
#define RTC_WDT_WDT_EN_V 0x00000001U
#define RTC_WDT_WDT_EN_S 31
/** RTC_WDT_CONFIG1_REG register
* need_des
*/
#define RTC_WDT_CONFIG1_REG (DR_REG_RTC_WDT_BASE + 0x4)
/** RTC_WDT_WDT_STG0_HOLD : R/W; bitpos: [31:0]; default: 200000;
* need_des
*/
#define RTC_WDT_WDT_STG0_HOLD 0xFFFFFFFFU
#define RTC_WDT_WDT_STG0_HOLD_M (RTC_WDT_WDT_STG0_HOLD_V << RTC_WDT_WDT_STG0_HOLD_S)
#define RTC_WDT_WDT_STG0_HOLD_V 0xFFFFFFFFU
#define RTC_WDT_WDT_STG0_HOLD_S 0
/** RTC_WDT_CONFIG2_REG register
* need_des
*/
#define RTC_WDT_CONFIG2_REG (DR_REG_RTC_WDT_BASE + 0x8)
/** RTC_WDT_WDT_STG1_HOLD : R/W; bitpos: [31:0]; default: 80000;
* need_des
*/
#define RTC_WDT_WDT_STG1_HOLD 0xFFFFFFFFU
#define RTC_WDT_WDT_STG1_HOLD_M (RTC_WDT_WDT_STG1_HOLD_V << RTC_WDT_WDT_STG1_HOLD_S)
#define RTC_WDT_WDT_STG1_HOLD_V 0xFFFFFFFFU
#define RTC_WDT_WDT_STG1_HOLD_S 0
/** RTC_WDT_CONFIG3_REG register
* need_des
*/
#define RTC_WDT_CONFIG3_REG (DR_REG_RTC_WDT_BASE + 0xc)
/** RTC_WDT_WDT_STG2_HOLD : R/W; bitpos: [31:0]; default: 4095;
* need_des
*/
#define RTC_WDT_WDT_STG2_HOLD 0xFFFFFFFFU
#define RTC_WDT_WDT_STG2_HOLD_M (RTC_WDT_WDT_STG2_HOLD_V << RTC_WDT_WDT_STG2_HOLD_S)
#define RTC_WDT_WDT_STG2_HOLD_V 0xFFFFFFFFU
#define RTC_WDT_WDT_STG2_HOLD_S 0
/** RTC_WDT_CONFIG4_REG register
* need_des
*/
#define RTC_WDT_CONFIG4_REG (DR_REG_RTC_WDT_BASE + 0x10)
/** RTC_WDT_WDT_STG3_HOLD : R/W; bitpos: [31:0]; default: 4095;
* need_des
*/
#define RTC_WDT_WDT_STG3_HOLD 0xFFFFFFFFU
#define RTC_WDT_WDT_STG3_HOLD_M (RTC_WDT_WDT_STG3_HOLD_V << RTC_WDT_WDT_STG3_HOLD_S)
#define RTC_WDT_WDT_STG3_HOLD_V 0xFFFFFFFFU
#define RTC_WDT_WDT_STG3_HOLD_S 0
/** RTC_WDT_FEED_REG register
* need_des
*/
#define RTC_WDT_FEED_REG (DR_REG_RTC_WDT_BASE + 0x14)
/** RTC_WDT_FEED : WT; bitpos: [31]; default: 0;
* need_des
*/
#define RTC_WDT_FEED (BIT(31))
#define RTC_WDT_FEED_M (RTC_WDT_FEED_V << RTC_WDT_FEED_S)
#define RTC_WDT_FEED_V 0x00000001U
#define RTC_WDT_FEED_S 31
/** RTC_WDT_WPROTECT_REG register
* need_des
*/
#define RTC_WDT_WPROTECT_REG (DR_REG_RTC_WDT_BASE + 0x18)
/** RTC_WDT_WDT_WKEY : R/W; bitpos: [31:0]; default: 0;
* need_des
*/
#define RTC_WDT_WDT_WKEY 0xFFFFFFFFU
#define RTC_WDT_WDT_WKEY_M (RTC_WDT_WDT_WKEY_V << RTC_WDT_WDT_WKEY_S)
#define RTC_WDT_WDT_WKEY_V 0xFFFFFFFFU
#define RTC_WDT_WDT_WKEY_S 0
/** RTC_WDT_SWD_CONFIG_REG register
* need_des
*/
#define RTC_WDT_SWD_CONFIG_REG (DR_REG_RTC_WDT_BASE + 0x1c)
/** RTC_WDT_SWD_RESET_FLAG : RO; bitpos: [0]; default: 0;
* need_des
*/
#define RTC_WDT_SWD_RESET_FLAG (BIT(0))
#define RTC_WDT_SWD_RESET_FLAG_M (RTC_WDT_SWD_RESET_FLAG_V << RTC_WDT_SWD_RESET_FLAG_S)
#define RTC_WDT_SWD_RESET_FLAG_V 0x00000001U
#define RTC_WDT_SWD_RESET_FLAG_S 0
/** RTC_WDT_SWD_AUTO_FEED_EN : R/W; bitpos: [18]; default: 0;
* need_des
*/
#define RTC_WDT_SWD_AUTO_FEED_EN (BIT(18))
#define RTC_WDT_SWD_AUTO_FEED_EN_M (RTC_WDT_SWD_AUTO_FEED_EN_V << RTC_WDT_SWD_AUTO_FEED_EN_S)
#define RTC_WDT_SWD_AUTO_FEED_EN_V 0x00000001U
#define RTC_WDT_SWD_AUTO_FEED_EN_S 18
/** RTC_WDT_SWD_RST_FLAG_CLR : WT; bitpos: [19]; default: 0;
* need_des
*/
#define RTC_WDT_SWD_RST_FLAG_CLR (BIT(19))
#define RTC_WDT_SWD_RST_FLAG_CLR_M (RTC_WDT_SWD_RST_FLAG_CLR_V << RTC_WDT_SWD_RST_FLAG_CLR_S)
#define RTC_WDT_SWD_RST_FLAG_CLR_V 0x00000001U
#define RTC_WDT_SWD_RST_FLAG_CLR_S 19
/** RTC_WDT_SWD_SIGNAL_WIDTH : R/W; bitpos: [29:20]; default: 300;
* need_des
*/
#define RTC_WDT_SWD_SIGNAL_WIDTH 0x000003FFU
#define RTC_WDT_SWD_SIGNAL_WIDTH_M (RTC_WDT_SWD_SIGNAL_WIDTH_V << RTC_WDT_SWD_SIGNAL_WIDTH_S)
#define RTC_WDT_SWD_SIGNAL_WIDTH_V 0x000003FFU
#define RTC_WDT_SWD_SIGNAL_WIDTH_S 20
/** RTC_WDT_SWD_DISABLE : R/W; bitpos: [30]; default: 0;
* need_des
*/
#define RTC_WDT_SWD_DISABLE (BIT(30))
#define RTC_WDT_SWD_DISABLE_M (RTC_WDT_SWD_DISABLE_V << RTC_WDT_SWD_DISABLE_S)
#define RTC_WDT_SWD_DISABLE_V 0x00000001U
#define RTC_WDT_SWD_DISABLE_S 30
/** RTC_WDT_SWD_FEED : WT; bitpos: [31]; default: 0;
* need_des
*/
#define RTC_WDT_SWD_FEED (BIT(31))
#define RTC_WDT_SWD_FEED_M (RTC_WDT_SWD_FEED_V << RTC_WDT_SWD_FEED_S)
#define RTC_WDT_SWD_FEED_V 0x00000001U
#define RTC_WDT_SWD_FEED_S 31
/** RTC_WDT_SWD_WPROTECT_REG register
* need_des
*/
#define RTC_WDT_SWD_WPROTECT_REG (DR_REG_RTC_WDT_BASE + 0x20)
/** RTC_WDT_SWD_WKEY : R/W; bitpos: [31:0]; default: 0;
* need_des
*/
#define RTC_WDT_SWD_WKEY 0xFFFFFFFFU
#define RTC_WDT_SWD_WKEY_M (RTC_WDT_SWD_WKEY_V << RTC_WDT_SWD_WKEY_S)
#define RTC_WDT_SWD_WKEY_V 0xFFFFFFFFU
#define RTC_WDT_SWD_WKEY_S 0
/** RTC_WDT_INT_RAW_REG register
* need_des
*/
#define RTC_WDT_INT_RAW_REG (DR_REG_RTC_WDT_BASE + 0x24)
/** RTC_WDT_SUPER_WDT_INT_RAW : R/WTC/SS; bitpos: [30]; default: 0;
* need_des
*/
#define RTC_WDT_SUPER_WDT_INT_RAW (BIT(30))
#define RTC_WDT_SUPER_WDT_INT_RAW_M (RTC_WDT_SUPER_WDT_INT_RAW_V << RTC_WDT_SUPER_WDT_INT_RAW_S)
#define RTC_WDT_SUPER_WDT_INT_RAW_V 0x00000001U
#define RTC_WDT_SUPER_WDT_INT_RAW_S 30
/** RTC_WDT_LP_WDT_INT_RAW : R/WTC/SS; bitpos: [31]; default: 0;
* need_des
*/
#define RTC_WDT_LP_WDT_INT_RAW (BIT(31))
#define RTC_WDT_LP_WDT_INT_RAW_M (RTC_WDT_LP_WDT_INT_RAW_V << RTC_WDT_LP_WDT_INT_RAW_S)
#define RTC_WDT_LP_WDT_INT_RAW_V 0x00000001U
#define RTC_WDT_LP_WDT_INT_RAW_S 31
/** RTC_WDT_INT_ST_REG register
* need_des
*/
#define RTC_WDT_INT_ST_REG (DR_REG_RTC_WDT_BASE + 0x28)
/** RTC_WDT_SUPER_WDT_INT_ST : RO; bitpos: [30]; default: 0;
* need_des
*/
#define RTC_WDT_SUPER_WDT_INT_ST (BIT(30))
#define RTC_WDT_SUPER_WDT_INT_ST_M (RTC_WDT_SUPER_WDT_INT_ST_V << RTC_WDT_SUPER_WDT_INT_ST_S)
#define RTC_WDT_SUPER_WDT_INT_ST_V 0x00000001U
#define RTC_WDT_SUPER_WDT_INT_ST_S 30
/** RTC_WDT_LP_WDT_INT_ST : RO; bitpos: [31]; default: 0;
* need_des
*/
#define RTC_WDT_LP_WDT_INT_ST (BIT(31))
#define RTC_WDT_LP_WDT_INT_ST_M (RTC_WDT_LP_WDT_INT_ST_V << RTC_WDT_LP_WDT_INT_ST_S)
#define RTC_WDT_LP_WDT_INT_ST_V 0x00000001U
#define RTC_WDT_LP_WDT_INT_ST_S 31
/** RTC_WDT_INT_ENA_REG register
* need_des
*/
#define RTC_WDT_INT_ENA_REG (DR_REG_RTC_WDT_BASE + 0x2c)
/** RTC_WDT_SUPER_WDT_INT_ENA : R/W; bitpos: [30]; default: 0;
* need_des
*/
#define RTC_WDT_SUPER_WDT_INT_ENA (BIT(30))
#define RTC_WDT_SUPER_WDT_INT_ENA_M (RTC_WDT_SUPER_WDT_INT_ENA_V << RTC_WDT_SUPER_WDT_INT_ENA_S)
#define RTC_WDT_SUPER_WDT_INT_ENA_V 0x00000001U
#define RTC_WDT_SUPER_WDT_INT_ENA_S 30
/** RTC_WDT_LP_WDT_INT_ENA : R/W; bitpos: [31]; default: 0;
* need_des
*/
#define RTC_WDT_LP_WDT_INT_ENA (BIT(31))
#define RTC_WDT_LP_WDT_INT_ENA_M (RTC_WDT_LP_WDT_INT_ENA_V << RTC_WDT_LP_WDT_INT_ENA_S)
#define RTC_WDT_LP_WDT_INT_ENA_V 0x00000001U
#define RTC_WDT_LP_WDT_INT_ENA_S 31
/** RTC_WDT_INT_CLR_REG register
* need_des
*/
#define RTC_WDT_INT_CLR_REG (DR_REG_RTC_WDT_BASE + 0x30)
/** RTC_WDT_SUPER_WDT_INT_CLR : WT; bitpos: [30]; default: 0;
* need_des
*/
#define RTC_WDT_SUPER_WDT_INT_CLR (BIT(30))
#define RTC_WDT_SUPER_WDT_INT_CLR_M (RTC_WDT_SUPER_WDT_INT_CLR_V << RTC_WDT_SUPER_WDT_INT_CLR_S)
#define RTC_WDT_SUPER_WDT_INT_CLR_V 0x00000001U
#define RTC_WDT_SUPER_WDT_INT_CLR_S 30
/** RTC_WDT_LP_WDT_INT_CLR : WT; bitpos: [31]; default: 0;
* need_des
*/
#define RTC_WDT_LP_WDT_INT_CLR (BIT(31))
#define RTC_WDT_LP_WDT_INT_CLR_M (RTC_WDT_LP_WDT_INT_CLR_V << RTC_WDT_LP_WDT_INT_CLR_S)
#define RTC_WDT_LP_WDT_INT_CLR_V 0x00000001U
#define RTC_WDT_LP_WDT_INT_CLR_S 31
/** RTC_WDT_DATE_REG register
* need_des
*/
#define RTC_WDT_DATE_REG (DR_REG_RTC_WDT_BASE + 0x3fc)
/** RTC_WDT_LP_WDT_DATE : R/W; bitpos: [30:0]; default: 34676864;
* need_des
*/
#define RTC_WDT_LP_WDT_DATE 0x7FFFFFFFU
#define RTC_WDT_LP_WDT_DATE_M (RTC_WDT_LP_WDT_DATE_V << RTC_WDT_LP_WDT_DATE_S)
#define RTC_WDT_LP_WDT_DATE_V 0x7FFFFFFFU
#define RTC_WDT_LP_WDT_DATE_S 0
/** RTC_WDT_CLK_EN : R/W; bitpos: [31]; default: 0;
* need_des
*/
#define RTC_WDT_CLK_EN (BIT(31))
#define RTC_WDT_CLK_EN_M (RTC_WDT_CLK_EN_V << RTC_WDT_CLK_EN_S)
#define RTC_WDT_CLK_EN_V 0x00000001U
#define RTC_WDT_CLK_EN_S 31
#ifdef __cplusplus
}
#endif

View File

@@ -1,309 +0,0 @@
/**
* SPDX-FileCopyrightText: 2023 Espressif Systems (Shanghai) CO LTD
*
* SPDX-License-Identifier: Apache-2.0
*/
#pragma once
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
/** Group: configure_register */
/** Type of config0 register
* need_des
*/
typedef union {
struct {
uint32_t reserved_0:9;
/** wdt_pause_in_slp : R/W; bitpos: [9]; default: 1;
* need_des
*/
uint32_t wdt_pause_in_slp:1;
/** wdt_appcpu_reset_en : R/W; bitpos: [10]; default: 0;
* need_des
*/
uint32_t wdt_appcpu_reset_en:1;
/** wdt_procpu_reset_en : R/W; bitpos: [11]; default: 0;
* need_des
*/
uint32_t wdt_procpu_reset_en:1;
/** wdt_flashboot_mod_en : R/W; bitpos: [12]; default: 1;
* need_des
*/
uint32_t wdt_flashboot_mod_en:1;
/** wdt_sys_reset_length : R/W; bitpos: [15:13]; default: 1;
* need_des
*/
uint32_t wdt_sys_reset_length:3;
/** wdt_cpu_reset_length : R/W; bitpos: [18:16]; default: 1;
* need_des
*/
uint32_t wdt_cpu_reset_length:3;
/** wdt_stg3 : R/W; bitpos: [21:19]; default: 0;
* need_des
*/
uint32_t wdt_stg3:3;
/** wdt_stg2 : R/W; bitpos: [24:22]; default: 0;
* need_des
*/
uint32_t wdt_stg2:3;
/** wdt_stg1 : R/W; bitpos: [27:25]; default: 0;
* need_des
*/
uint32_t wdt_stg1:3;
/** wdt_stg0 : R/W; bitpos: [30:28]; default: 0;
* need_des
*/
uint32_t wdt_stg0:3;
/** wdt_en : R/W; bitpos: [31]; default: 0;
* need_des
*/
uint32_t wdt_en:1;
};
uint32_t val;
} rtc_wdt_config0_reg_t;
/** Type of config1 register
* need_des
*/
typedef union {
struct {
/** wdt_stg0_hold : R/W; bitpos: [31:0]; default: 200000;
* need_des
*/
uint32_t wdt_stg0_hold:32;
};
uint32_t val;
} rtc_wdt_config1_reg_t;
/** Type of config2 register
* need_des
*/
typedef union {
struct {
/** wdt_stg1_hold : R/W; bitpos: [31:0]; default: 80000;
* need_des
*/
uint32_t wdt_stg1_hold:32;
};
uint32_t val;
} rtc_wdt_config2_reg_t;
/** Type of config3 register
* need_des
*/
typedef union {
struct {
/** wdt_stg2_hold : R/W; bitpos: [31:0]; default: 4095;
* need_des
*/
uint32_t wdt_stg2_hold:32;
};
uint32_t val;
} rtc_wdt_config3_reg_t;
/** Type of config4 register
* need_des
*/
typedef union {
struct {
/** wdt_stg3_hold : R/W; bitpos: [31:0]; default: 4095;
* need_des
*/
uint32_t wdt_stg3_hold:32;
};
uint32_t val;
} rtc_wdt_config4_reg_t;
/** Type of feed register
* need_des
*/
typedef union {
struct {
uint32_t reserved_0:31;
/** feed : WT; bitpos: [31]; default: 0;
* need_des
*/
uint32_t feed:1;
};
uint32_t val;
} rtc_wdt_feed_reg_t;
/** Type of wprotect register
* need_des
*/
typedef union {
struct {
/** wdt_wkey : R/W; bitpos: [31:0]; default: 0;
* need_des
*/
uint32_t wdt_wkey:32;
};
uint32_t val;
} rtc_wdt_wprotect_reg_t;
/** Type of swd_config register
* need_des
*/
typedef union {
struct {
/** swd_reset_flag : RO; bitpos: [0]; default: 0;
* need_des
*/
uint32_t swd_reset_flag:1;
uint32_t reserved_1:17;
/** swd_auto_feed_en : R/W; bitpos: [18]; default: 0;
* need_des
*/
uint32_t swd_auto_feed_en:1;
/** swd_rst_flag_clr : WT; bitpos: [19]; default: 0;
* need_des
*/
uint32_t swd_rst_flag_clr:1;
/** swd_signal_width : R/W; bitpos: [29:20]; default: 300;
* need_des
*/
uint32_t swd_signal_width:10;
/** swd_disable : R/W; bitpos: [30]; default: 0;
* need_des
*/
uint32_t swd_disable:1;
/** swd_feed : WT; bitpos: [31]; default: 0;
* need_des
*/
uint32_t swd_feed:1;
};
uint32_t val;
} rtc_wdt_swd_config_reg_t;
/** Type of swd_wprotect register
* need_des
*/
typedef union {
struct {
/** swd_wkey : R/W; bitpos: [31:0]; default: 0;
* need_des
*/
uint32_t swd_wkey:32;
};
uint32_t val;
} rtc_wdt_swd_wprotect_reg_t;
/** Type of int_raw register
* need_des
*/
typedef union {
struct {
uint32_t reserved_0:30;
/** super_wdt_int_raw : R/WTC/SS; bitpos: [30]; default: 0;
* need_des
*/
uint32_t super_wdt_int_raw:1;
/** lp_wdt_int_raw : R/WTC/SS; bitpos: [31]; default: 0;
* need_des
*/
uint32_t lp_wdt_int_raw:1;
};
uint32_t val;
} rtc_wdt_int_raw_reg_t;
/** Type of int_st register
* need_des
*/
typedef union {
struct {
uint32_t reserved_0:30;
/** super_wdt_int_st : RO; bitpos: [30]; default: 0;
* need_des
*/
uint32_t super_wdt_int_st:1;
/** lp_wdt_int_st : RO; bitpos: [31]; default: 0;
* need_des
*/
uint32_t lp_wdt_int_st:1;
};
uint32_t val;
} rtc_wdt_int_st_reg_t;
/** Type of int_ena register
* need_des
*/
typedef union {
struct {
uint32_t reserved_0:30;
/** super_wdt_int_ena : R/W; bitpos: [30]; default: 0;
* need_des
*/
uint32_t super_wdt_int_ena:1;
/** lp_wdt_int_ena : R/W; bitpos: [31]; default: 0;
* need_des
*/
uint32_t lp_wdt_int_ena:1;
};
uint32_t val;
} rtc_wdt_int_ena_reg_t;
/** Type of int_clr register
* need_des
*/
typedef union {
struct {
uint32_t reserved_0:30;
/** super_wdt_int_clr : WT; bitpos: [30]; default: 0;
* need_des
*/
uint32_t super_wdt_int_clr:1;
/** lp_wdt_int_clr : WT; bitpos: [31]; default: 0;
* need_des
*/
uint32_t lp_wdt_int_clr:1;
};
uint32_t val;
} rtc_wdt_int_clr_reg_t;
/** Type of date register
* need_des
*/
typedef union {
struct {
/** lp_wdt_date : R/W; bitpos: [30:0]; default: 34676864;
* need_des
*/
uint32_t lp_wdt_date:31;
/** clk_en : R/W; bitpos: [31]; default: 0;
* need_des
*/
uint32_t clk_en:1;
};
uint32_t val;
} rtc_wdt_date_reg_t;
typedef struct {
volatile rtc_wdt_config0_reg_t config0;
volatile rtc_wdt_config1_reg_t config1;
volatile rtc_wdt_config2_reg_t config2;
volatile rtc_wdt_config3_reg_t config3;
volatile rtc_wdt_config4_reg_t config4;
volatile rtc_wdt_feed_reg_t feed;
volatile rtc_wdt_wprotect_reg_t wprotect;
volatile rtc_wdt_swd_config_reg_t swd_config;
volatile rtc_wdt_swd_wprotect_reg_t swd_wprotect;
volatile rtc_wdt_int_raw_reg_t int_raw;
volatile rtc_wdt_int_st_reg_t int_st;
volatile rtc_wdt_int_ena_reg_t int_ena;
volatile rtc_wdt_int_clr_reg_t int_clr;
uint32_t reserved_034[242];
volatile rtc_wdt_date_reg_t date;
} rtc_wdt_dev_t;
#ifndef __cplusplus
_Static_assert(sizeof(rtc_wdt_dev_t) == 0x400, "Invalid size of rtc_wdt_dev_t structure");
#endif
#ifdef __cplusplus
}
#endif