HPM SDK
HPMicro Software Development Kit
hpm_ewdg_regs.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2021-2024 HPMicro
3  *
4  * SPDX-License-Identifier: BSD-3-Clause
5  *
6  */
7 
8 
9 #ifndef HPM_EWDG_H
10 #define HPM_EWDG_H
11 
12 typedef struct {
13  __RW uint32_t CTRL0; /* 0x0: wdog ctrl register 0
14 Note: Parity check is required once writing to this register. The result should be zero by modular two addition of all bits */
15  __RW uint32_t CTRL1; /* 0x4: wdog ctrl register 1
16 Note: Parity check is required once writing to this register. The result should be zero by modular two addition of all bits */
17  __R uint8_t RESERVED0[4]; /* 0x8 - 0xB: Reserved */
18  __RW uint32_t OT_RST_VAL; /* 0xC: wdog timeout reset counter value */
19  __W uint32_t WDT_REFRESH_REG; /* 0x10: wdog refresh register */
20  __W uint32_t WDT_STATUS; /* 0x14: wdog status register */
21  __RW uint32_t CFG_PROT; /* 0x18: ctrl register protection register */
22  __RW uint32_t REF_PROT; /* 0x1C: refresh protection register */
23  __RW uint32_t WDT_EN; /* 0x20: Wdog enable */
24  __RW uint32_t REF_TIME; /* 0x24: Refresh period value */
25 } EWDG_Type;
26 
27 
28 /* Bitfield definition for register: CTRL0 */
29 /*
30  * CLK_SEL (RW)
31  *
32  * clock select
33  * 0:bus clock
34  * 1:ext clock
35  */
36 #define EWDG_CTRL0_CLK_SEL_MASK (0x20000000UL)
37 #define EWDG_CTRL0_CLK_SEL_SHIFT (29U)
38 #define EWDG_CTRL0_CLK_SEL_SET(x) (((uint32_t)(x) << EWDG_CTRL0_CLK_SEL_SHIFT) & EWDG_CTRL0_CLK_SEL_MASK)
39 #define EWDG_CTRL0_CLK_SEL_GET(x) (((uint32_t)(x) & EWDG_CTRL0_CLK_SEL_MASK) >> EWDG_CTRL0_CLK_SEL_SHIFT)
40 
41 /*
42  * DIV_VALUE (RW)
43  *
44  * clock divider, the clock divider works as 2 ^ div_value for wdt counter
45  */
46 #define EWDG_CTRL0_DIV_VALUE_MASK (0xE000000UL)
47 #define EWDG_CTRL0_DIV_VALUE_SHIFT (25U)
48 #define EWDG_CTRL0_DIV_VALUE_SET(x) (((uint32_t)(x) << EWDG_CTRL0_DIV_VALUE_SHIFT) & EWDG_CTRL0_DIV_VALUE_MASK)
49 #define EWDG_CTRL0_DIV_VALUE_GET(x) (((uint32_t)(x) & EWDG_CTRL0_DIV_VALUE_MASK) >> EWDG_CTRL0_DIV_VALUE_SHIFT)
50 
51 /*
52  * WIN_EN (RW)
53  *
54  * window mode enable
55  */
56 #define EWDG_CTRL0_WIN_EN_MASK (0x1000000UL)
57 #define EWDG_CTRL0_WIN_EN_SHIFT (24U)
58 #define EWDG_CTRL0_WIN_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL0_WIN_EN_SHIFT) & EWDG_CTRL0_WIN_EN_MASK)
59 #define EWDG_CTRL0_WIN_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL0_WIN_EN_MASK) >> EWDG_CTRL0_WIN_EN_SHIFT)
60 
61 /*
62  * WIN_LOWER (RW)
63  *
64  * Once window mode is opened, the lower counter value to refresh wdt
65  * 00: 4/8 overtime value
66  * 01: 5/8 of overtime value
67  * 10: 6/8 of overtime value
68  * 11: 7/8 of overtime value
69  */
70 #define EWDG_CTRL0_WIN_LOWER_MASK (0xC00000UL)
71 #define EWDG_CTRL0_WIN_LOWER_SHIFT (22U)
72 #define EWDG_CTRL0_WIN_LOWER_SET(x) (((uint32_t)(x) << EWDG_CTRL0_WIN_LOWER_SHIFT) & EWDG_CTRL0_WIN_LOWER_MASK)
73 #define EWDG_CTRL0_WIN_LOWER_GET(x) (((uint32_t)(x) & EWDG_CTRL0_WIN_LOWER_MASK) >> EWDG_CTRL0_WIN_LOWER_SHIFT)
74 
75 /*
76  * CFG_LOCK (RW)
77  *
78  * The register is locked and unlock is needed before re-config registers
79  * Once the lock mechanism takes effect, the CTRL0, CTRL1, timeout int register, timeout rst register, needs unlock before re-config them.
80  * The register update needs to be finished in the required period defined by UPD_OT_TIME register
81  */
82 #define EWDG_CTRL0_CFG_LOCK_MASK (0x200000UL)
83 #define EWDG_CTRL0_CFG_LOCK_SHIFT (21U)
84 #define EWDG_CTRL0_CFG_LOCK_SET(x) (((uint32_t)(x) << EWDG_CTRL0_CFG_LOCK_SHIFT) & EWDG_CTRL0_CFG_LOCK_MASK)
85 #define EWDG_CTRL0_CFG_LOCK_GET(x) (((uint32_t)(x) & EWDG_CTRL0_CFG_LOCK_MASK) >> EWDG_CTRL0_CFG_LOCK_SHIFT)
86 
87 /*
88  * OT_SELF_CLEAR (RW)
89  *
90  * overtime reset can be self released after 32 function cycles
91  */
92 #define EWDG_CTRL0_OT_SELF_CLEAR_MASK (0x20000UL)
93 #define EWDG_CTRL0_OT_SELF_CLEAR_SHIFT (17U)
94 #define EWDG_CTRL0_OT_SELF_CLEAR_SET(x) (((uint32_t)(x) << EWDG_CTRL0_OT_SELF_CLEAR_SHIFT) & EWDG_CTRL0_OT_SELF_CLEAR_MASK)
95 #define EWDG_CTRL0_OT_SELF_CLEAR_GET(x) (((uint32_t)(x) & EWDG_CTRL0_OT_SELF_CLEAR_MASK) >> EWDG_CTRL0_OT_SELF_CLEAR_SHIFT)
96 
97 /*
98  * REF_OT_REQ (RW)
99  *
100  * If refresh event has to be limited into a period after refresh unlocked.
101  * Note: the refresh overtime counter works in bus clock domain, not in wdt function clock domain. The wdt divider doesn't take effect for refresh counter
102  */
103 #define EWDG_CTRL0_REF_OT_REQ_MASK (0x8000U)
104 #define EWDG_CTRL0_REF_OT_REQ_SHIFT (15U)
105 #define EWDG_CTRL0_REF_OT_REQ_SET(x) (((uint32_t)(x) << EWDG_CTRL0_REF_OT_REQ_SHIFT) & EWDG_CTRL0_REF_OT_REQ_MASK)
106 #define EWDG_CTRL0_REF_OT_REQ_GET(x) (((uint32_t)(x) & EWDG_CTRL0_REF_OT_REQ_MASK) >> EWDG_CTRL0_REF_OT_REQ_SHIFT)
107 
108 /*
109  * WIN_UPPER (RW)
110  *
111  * The upper threshold of window value
112  * The window period upper limit is: lower_limit + (overtime_rst_value / 16) * upper_reg_value
113  * If this register value is zero, then no upper level limitation
114  */
115 #define EWDG_CTRL0_WIN_UPPER_MASK (0x7000U)
116 #define EWDG_CTRL0_WIN_UPPER_SHIFT (12U)
117 #define EWDG_CTRL0_WIN_UPPER_SET(x) (((uint32_t)(x) << EWDG_CTRL0_WIN_UPPER_SHIFT) & EWDG_CTRL0_WIN_UPPER_MASK)
118 #define EWDG_CTRL0_WIN_UPPER_GET(x) (((uint32_t)(x) & EWDG_CTRL0_WIN_UPPER_MASK) >> EWDG_CTRL0_WIN_UPPER_SHIFT)
119 
120 /*
121  * REF_LOCK (RW)
122  *
123  * WDT refresh has to be unlocked firstly once refresh lock is enable.
124  */
125 #define EWDG_CTRL0_REF_LOCK_MASK (0x20U)
126 #define EWDG_CTRL0_REF_LOCK_SHIFT (5U)
127 #define EWDG_CTRL0_REF_LOCK_SET(x) (((uint32_t)(x) << EWDG_CTRL0_REF_LOCK_SHIFT) & EWDG_CTRL0_REF_LOCK_MASK)
128 #define EWDG_CTRL0_REF_LOCK_GET(x) (((uint32_t)(x) & EWDG_CTRL0_REF_LOCK_MASK) >> EWDG_CTRL0_REF_LOCK_SHIFT)
129 
130 /*
131  * REF_UNLOCK_MEC (RW)
132  *
133  * Unlock refresh mechanism
134  * 00: the required unlock password is the same with refresh_psd_register
135  * 01: the required unlock password is a ring shift left value of refresh_psd_register
136  * 10: the required unlock password is always 16'h55AA, no matter what refresh_psd_register is
137  * 11: the required unlock password is a LSFR result of refresh_psd_register, the characteristic polynomial is X^15 + 1
138  */
139 #define EWDG_CTRL0_REF_UNLOCK_MEC_MASK (0x18U)
140 #define EWDG_CTRL0_REF_UNLOCK_MEC_SHIFT (3U)
141 #define EWDG_CTRL0_REF_UNLOCK_MEC_SET(x) (((uint32_t)(x) << EWDG_CTRL0_REF_UNLOCK_MEC_SHIFT) & EWDG_CTRL0_REF_UNLOCK_MEC_MASK)
142 #define EWDG_CTRL0_REF_UNLOCK_MEC_GET(x) (((uint32_t)(x) & EWDG_CTRL0_REF_UNLOCK_MEC_MASK) >> EWDG_CTRL0_REF_UNLOCK_MEC_SHIFT)
143 
144 /*
145  * EN_DBG (RW)
146  *
147  * WTD enable or not in debug mode
148  */
149 #define EWDG_CTRL0_EN_DBG_MASK (0x4U)
150 #define EWDG_CTRL0_EN_DBG_SHIFT (2U)
151 #define EWDG_CTRL0_EN_DBG_SET(x) (((uint32_t)(x) << EWDG_CTRL0_EN_DBG_SHIFT) & EWDG_CTRL0_EN_DBG_MASK)
152 #define EWDG_CTRL0_EN_DBG_GET(x) (((uint32_t)(x) & EWDG_CTRL0_EN_DBG_MASK) >> EWDG_CTRL0_EN_DBG_SHIFT)
153 
154 /*
155  * EN_LP (RW)
156  *
157  * WDT enable or not in low power mode
158  * 2'b00: wdt is halted once in low power mode
159  * 2'b01: wdt will work with 1/4 normal clock freq in low power mode
160  * 2'b10: wdt will work with 1/2 normal clock freq in low power mode
161  * 2'b11: wdt will work with normal clock freq in low power mode
162  */
163 #define EWDG_CTRL0_EN_LP_MASK (0x3U)
164 #define EWDG_CTRL0_EN_LP_SHIFT (0U)
165 #define EWDG_CTRL0_EN_LP_SET(x) (((uint32_t)(x) << EWDG_CTRL0_EN_LP_SHIFT) & EWDG_CTRL0_EN_LP_MASK)
166 #define EWDG_CTRL0_EN_LP_GET(x) (((uint32_t)(x) & EWDG_CTRL0_EN_LP_MASK) >> EWDG_CTRL0_EN_LP_SHIFT)
167 
168 /* Bitfield definition for register: CTRL1 */
169 /*
170  * REF_FAIL_RST_EN (RW)
171  *
172  * Refresh violation will trigger an reset.
173  * These event will be taken as a refresh violation:
174  * 1) Not refresh in the window once window mode is enabled
175  * 2) Not unlock refresh firstly if unlock is required
176  * 3) Not refresh in the required time after unlock, once refresh unlock overtime is enabled.
177  * 4) Not write the required word to refresh wdt.
178  */
179 #define EWDG_CTRL1_REF_FAIL_RST_EN_MASK (0x800000UL)
180 #define EWDG_CTRL1_REF_FAIL_RST_EN_SHIFT (23U)
181 #define EWDG_CTRL1_REF_FAIL_RST_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL1_REF_FAIL_RST_EN_SHIFT) & EWDG_CTRL1_REF_FAIL_RST_EN_MASK)
182 #define EWDG_CTRL1_REF_FAIL_RST_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL1_REF_FAIL_RST_EN_MASK) >> EWDG_CTRL1_REF_FAIL_RST_EN_SHIFT)
183 
184 /*
185  * REF_FAIL_INT_EN (RW)
186  *
187  * Refresh violation will trigger an interrupt
188  */
189 #define EWDG_CTRL1_REF_FAIL_INT_EN_MASK (0x400000UL)
190 #define EWDG_CTRL1_REF_FAIL_INT_EN_SHIFT (22U)
191 #define EWDG_CTRL1_REF_FAIL_INT_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL1_REF_FAIL_INT_EN_SHIFT) & EWDG_CTRL1_REF_FAIL_INT_EN_MASK)
192 #define EWDG_CTRL1_REF_FAIL_INT_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL1_REF_FAIL_INT_EN_MASK) >> EWDG_CTRL1_REF_FAIL_INT_EN_SHIFT)
193 
194 /*
195  * UNL_REF_FAIL_RST_EN (RW)
196  *
197  * Refresh unlock fail will trigger a reset
198  */
199 #define EWDG_CTRL1_UNL_REF_FAIL_RST_EN_MASK (0x200000UL)
200 #define EWDG_CTRL1_UNL_REF_FAIL_RST_EN_SHIFT (21U)
201 #define EWDG_CTRL1_UNL_REF_FAIL_RST_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL1_UNL_REF_FAIL_RST_EN_SHIFT) & EWDG_CTRL1_UNL_REF_FAIL_RST_EN_MASK)
202 #define EWDG_CTRL1_UNL_REF_FAIL_RST_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL1_UNL_REF_FAIL_RST_EN_MASK) >> EWDG_CTRL1_UNL_REF_FAIL_RST_EN_SHIFT)
203 
204 /*
205  * UNL_REF_FAIL_INT_EN (RW)
206  *
207  * Refresh unlock fail will trigger a interrupt
208  */
209 #define EWDG_CTRL1_UNL_REF_FAIL_INT_EN_MASK (0x100000UL)
210 #define EWDG_CTRL1_UNL_REF_FAIL_INT_EN_SHIFT (20U)
211 #define EWDG_CTRL1_UNL_REF_FAIL_INT_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL1_UNL_REF_FAIL_INT_EN_SHIFT) & EWDG_CTRL1_UNL_REF_FAIL_INT_EN_MASK)
212 #define EWDG_CTRL1_UNL_REF_FAIL_INT_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL1_UNL_REF_FAIL_INT_EN_MASK) >> EWDG_CTRL1_UNL_REF_FAIL_INT_EN_SHIFT)
213 
214 /*
215  * OT_RST_EN (RW)
216  *
217  * WDT overtime will generate a reset
218  */
219 #define EWDG_CTRL1_OT_RST_EN_MASK (0x20000UL)
220 #define EWDG_CTRL1_OT_RST_EN_SHIFT (17U)
221 #define EWDG_CTRL1_OT_RST_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL1_OT_RST_EN_SHIFT) & EWDG_CTRL1_OT_RST_EN_MASK)
222 #define EWDG_CTRL1_OT_RST_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL1_OT_RST_EN_MASK) >> EWDG_CTRL1_OT_RST_EN_SHIFT)
223 
224 /*
225  * CTL_VIO_RST_EN (RW)
226  *
227  * Ctrl update violation will trigger a reset
228  * The violation event is to try updating the locked register before unlock them
229  */
230 #define EWDG_CTRL1_CTL_VIO_RST_EN_MASK (0x80U)
231 #define EWDG_CTRL1_CTL_VIO_RST_EN_SHIFT (7U)
232 #define EWDG_CTRL1_CTL_VIO_RST_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL1_CTL_VIO_RST_EN_SHIFT) & EWDG_CTRL1_CTL_VIO_RST_EN_MASK)
233 #define EWDG_CTRL1_CTL_VIO_RST_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL1_CTL_VIO_RST_EN_MASK) >> EWDG_CTRL1_CTL_VIO_RST_EN_SHIFT)
234 
235 /*
236  * CTL_VIO_INT_EN (RW)
237  *
238  * Ctrl update violation will trigger a interrupt
239  */
240 #define EWDG_CTRL1_CTL_VIO_INT_EN_MASK (0x40U)
241 #define EWDG_CTRL1_CTL_VIO_INT_EN_SHIFT (6U)
242 #define EWDG_CTRL1_CTL_VIO_INT_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL1_CTL_VIO_INT_EN_SHIFT) & EWDG_CTRL1_CTL_VIO_INT_EN_MASK)
243 #define EWDG_CTRL1_CTL_VIO_INT_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL1_CTL_VIO_INT_EN_MASK) >> EWDG_CTRL1_CTL_VIO_INT_EN_SHIFT)
244 
245 /*
246  * UNL_CTL_FAIL_RST_EN (RW)
247  *
248  * Unlock register update failure will trigger a reset
249  */
250 #define EWDG_CTRL1_UNL_CTL_FAIL_RST_EN_MASK (0x20U)
251 #define EWDG_CTRL1_UNL_CTL_FAIL_RST_EN_SHIFT (5U)
252 #define EWDG_CTRL1_UNL_CTL_FAIL_RST_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL1_UNL_CTL_FAIL_RST_EN_SHIFT) & EWDG_CTRL1_UNL_CTL_FAIL_RST_EN_MASK)
253 #define EWDG_CTRL1_UNL_CTL_FAIL_RST_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL1_UNL_CTL_FAIL_RST_EN_MASK) >> EWDG_CTRL1_UNL_CTL_FAIL_RST_EN_SHIFT)
254 
255 /*
256  * UNL_CTL_FAIL_INT_EN (RW)
257  *
258  * Unlock register update failure will trigger a interrupt
259  */
260 #define EWDG_CTRL1_UNL_CTL_FAIL_INT_EN_MASK (0x10U)
261 #define EWDG_CTRL1_UNL_CTL_FAIL_INT_EN_SHIFT (4U)
262 #define EWDG_CTRL1_UNL_CTL_FAIL_INT_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL1_UNL_CTL_FAIL_INT_EN_SHIFT) & EWDG_CTRL1_UNL_CTL_FAIL_INT_EN_MASK)
263 #define EWDG_CTRL1_UNL_CTL_FAIL_INT_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL1_UNL_CTL_FAIL_INT_EN_MASK) >> EWDG_CTRL1_UNL_CTL_FAIL_INT_EN_SHIFT)
264 
265 /*
266  * PARITY_FAIL_RST_EN (RW)
267  *
268  * Parity error will trigger a reset
269  * A parity check is required once writing to ctrl0 and ctrl1 register. The result should be zero by modular two addition of all bits
270  */
271 #define EWDG_CTRL1_PARITY_FAIL_RST_EN_MASK (0x8U)
272 #define EWDG_CTRL1_PARITY_FAIL_RST_EN_SHIFT (3U)
273 #define EWDG_CTRL1_PARITY_FAIL_RST_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL1_PARITY_FAIL_RST_EN_SHIFT) & EWDG_CTRL1_PARITY_FAIL_RST_EN_MASK)
274 #define EWDG_CTRL1_PARITY_FAIL_RST_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL1_PARITY_FAIL_RST_EN_MASK) >> EWDG_CTRL1_PARITY_FAIL_RST_EN_SHIFT)
275 
276 /*
277  * PARITY_FAIL_INT_EN (RW)
278  *
279  * Parity error will trigger a interrupt
280  */
281 #define EWDG_CTRL1_PARITY_FAIL_INT_EN_MASK (0x4U)
282 #define EWDG_CTRL1_PARITY_FAIL_INT_EN_SHIFT (2U)
283 #define EWDG_CTRL1_PARITY_FAIL_INT_EN_SET(x) (((uint32_t)(x) << EWDG_CTRL1_PARITY_FAIL_INT_EN_SHIFT) & EWDG_CTRL1_PARITY_FAIL_INT_EN_MASK)
284 #define EWDG_CTRL1_PARITY_FAIL_INT_EN_GET(x) (((uint32_t)(x) & EWDG_CTRL1_PARITY_FAIL_INT_EN_MASK) >> EWDG_CTRL1_PARITY_FAIL_INT_EN_SHIFT)
285 
286 /* Bitfield definition for register: OT_RST_VAL */
287 /*
288  * OT_RST_VAL (RW)
289  *
290  * WDT timeout reset value
291  */
292 #define EWDG_OT_RST_VAL_OT_RST_VAL_MASK (0xFFFFU)
293 #define EWDG_OT_RST_VAL_OT_RST_VAL_SHIFT (0U)
294 #define EWDG_OT_RST_VAL_OT_RST_VAL_SET(x) (((uint32_t)(x) << EWDG_OT_RST_VAL_OT_RST_VAL_SHIFT) & EWDG_OT_RST_VAL_OT_RST_VAL_MASK)
295 #define EWDG_OT_RST_VAL_OT_RST_VAL_GET(x) (((uint32_t)(x) & EWDG_OT_RST_VAL_OT_RST_VAL_MASK) >> EWDG_OT_RST_VAL_OT_RST_VAL_SHIFT)
296 
297 /* Bitfield definition for register: WDT_REFRESH_REG */
298 /*
299  * WDT_REFRESH_REG (WO)
300  *
301  * Write this register by 32'h5A45_524F to refresh wdog
302  * Note: Reading this register can read back wdt real time counter value, while it is only used by debug purpose
303  */
304 #define EWDG_WDT_REFRESH_REG_WDT_REFRESH_REG_MASK (0xFFFFFFFFUL)
305 #define EWDG_WDT_REFRESH_REG_WDT_REFRESH_REG_SHIFT (0U)
306 #define EWDG_WDT_REFRESH_REG_WDT_REFRESH_REG_SET(x) (((uint32_t)(x) << EWDG_WDT_REFRESH_REG_WDT_REFRESH_REG_SHIFT) & EWDG_WDT_REFRESH_REG_WDT_REFRESH_REG_MASK)
307 #define EWDG_WDT_REFRESH_REG_WDT_REFRESH_REG_GET(x) (((uint32_t)(x) & EWDG_WDT_REFRESH_REG_WDT_REFRESH_REG_MASK) >> EWDG_WDT_REFRESH_REG_WDT_REFRESH_REG_SHIFT)
308 
309 /* Bitfield definition for register: WDT_STATUS */
310 /*
311  * PARITY_ERROR (W1C)
312  *
313  * parity error
314  * Write one to clear the bit
315  */
316 #define EWDG_WDT_STATUS_PARITY_ERROR_MASK (0x40U)
317 #define EWDG_WDT_STATUS_PARITY_ERROR_SHIFT (6U)
318 #define EWDG_WDT_STATUS_PARITY_ERROR_SET(x) (((uint32_t)(x) << EWDG_WDT_STATUS_PARITY_ERROR_SHIFT) & EWDG_WDT_STATUS_PARITY_ERROR_MASK)
319 #define EWDG_WDT_STATUS_PARITY_ERROR_GET(x) (((uint32_t)(x) & EWDG_WDT_STATUS_PARITY_ERROR_MASK) >> EWDG_WDT_STATUS_PARITY_ERROR_SHIFT)
320 
321 /*
322  * OT_RST (W1C)
323  *
324  * Timeout happens, a reset will happen once enable bit set
325  * This bit can be cleared only by refreshing wdt or reset
326  */
327 #define EWDG_WDT_STATUS_OT_RST_MASK (0x20U)
328 #define EWDG_WDT_STATUS_OT_RST_SHIFT (5U)
329 #define EWDG_WDT_STATUS_OT_RST_SET(x) (((uint32_t)(x) << EWDG_WDT_STATUS_OT_RST_SHIFT) & EWDG_WDT_STATUS_OT_RST_MASK)
330 #define EWDG_WDT_STATUS_OT_RST_GET(x) (((uint32_t)(x) & EWDG_WDT_STATUS_OT_RST_MASK) >> EWDG_WDT_STATUS_OT_RST_SHIFT)
331 
332 /*
333  * CTL_UNL_FAIL (W1C)
334  *
335  * Unlock ctrl reg update protection fail
336  * Write one to clear the bit
337  */
338 #define EWDG_WDT_STATUS_CTL_UNL_FAIL_MASK (0x8U)
339 #define EWDG_WDT_STATUS_CTL_UNL_FAIL_SHIFT (3U)
340 #define EWDG_WDT_STATUS_CTL_UNL_FAIL_SET(x) (((uint32_t)(x) << EWDG_WDT_STATUS_CTL_UNL_FAIL_SHIFT) & EWDG_WDT_STATUS_CTL_UNL_FAIL_MASK)
341 #define EWDG_WDT_STATUS_CTL_UNL_FAIL_GET(x) (((uint32_t)(x) & EWDG_WDT_STATUS_CTL_UNL_FAIL_MASK) >> EWDG_WDT_STATUS_CTL_UNL_FAIL_SHIFT)
342 
343 /*
344  * CTL_VIO (W1C)
345  *
346  * Violate register update protection mechanism
347  * Write one to clear the bit
348  */
349 #define EWDG_WDT_STATUS_CTL_VIO_MASK (0x4U)
350 #define EWDG_WDT_STATUS_CTL_VIO_SHIFT (2U)
351 #define EWDG_WDT_STATUS_CTL_VIO_SET(x) (((uint32_t)(x) << EWDG_WDT_STATUS_CTL_VIO_SHIFT) & EWDG_WDT_STATUS_CTL_VIO_MASK)
352 #define EWDG_WDT_STATUS_CTL_VIO_GET(x) (((uint32_t)(x) & EWDG_WDT_STATUS_CTL_VIO_MASK) >> EWDG_WDT_STATUS_CTL_VIO_SHIFT)
353 
354 /*
355  * REF_UNL_FAIL (W1C)
356  *
357  * Refresh unlock fail
358  * Write one to clear the bit
359  */
360 #define EWDG_WDT_STATUS_REF_UNL_FAIL_MASK (0x2U)
361 #define EWDG_WDT_STATUS_REF_UNL_FAIL_SHIFT (1U)
362 #define EWDG_WDT_STATUS_REF_UNL_FAIL_SET(x) (((uint32_t)(x) << EWDG_WDT_STATUS_REF_UNL_FAIL_SHIFT) & EWDG_WDT_STATUS_REF_UNL_FAIL_MASK)
363 #define EWDG_WDT_STATUS_REF_UNL_FAIL_GET(x) (((uint32_t)(x) & EWDG_WDT_STATUS_REF_UNL_FAIL_MASK) >> EWDG_WDT_STATUS_REF_UNL_FAIL_SHIFT)
364 
365 /*
366  * REF_VIO (W1C)
367  *
368  * Refresh fail
369  * Write one to clear the bit
370  */
371 #define EWDG_WDT_STATUS_REF_VIO_MASK (0x1U)
372 #define EWDG_WDT_STATUS_REF_VIO_SHIFT (0U)
373 #define EWDG_WDT_STATUS_REF_VIO_SET(x) (((uint32_t)(x) << EWDG_WDT_STATUS_REF_VIO_SHIFT) & EWDG_WDT_STATUS_REF_VIO_MASK)
374 #define EWDG_WDT_STATUS_REF_VIO_GET(x) (((uint32_t)(x) & EWDG_WDT_STATUS_REF_VIO_MASK) >> EWDG_WDT_STATUS_REF_VIO_SHIFT)
375 
376 /* Bitfield definition for register: CFG_PROT */
377 /*
378  * UPD_OT_TIME (RW)
379  *
380  * The period in which register update has to be in after unlock
381  * The required period is less than: 128 * 2 ^ UPD_OT_TIME * bus_clock_cycle
382  */
383 #define EWDG_CFG_PROT_UPD_OT_TIME_MASK (0xF0000UL)
384 #define EWDG_CFG_PROT_UPD_OT_TIME_SHIFT (16U)
385 #define EWDG_CFG_PROT_UPD_OT_TIME_SET(x) (((uint32_t)(x) << EWDG_CFG_PROT_UPD_OT_TIME_SHIFT) & EWDG_CFG_PROT_UPD_OT_TIME_MASK)
386 #define EWDG_CFG_PROT_UPD_OT_TIME_GET(x) (((uint32_t)(x) & EWDG_CFG_PROT_UPD_OT_TIME_MASK) >> EWDG_CFG_PROT_UPD_OT_TIME_SHIFT)
387 
388 /*
389  * UPD_PSD (RW)
390  *
391  * The password of unlocking register update
392  */
393 #define EWDG_CFG_PROT_UPD_PSD_MASK (0xFFFFU)
394 #define EWDG_CFG_PROT_UPD_PSD_SHIFT (0U)
395 #define EWDG_CFG_PROT_UPD_PSD_SET(x) (((uint32_t)(x) << EWDG_CFG_PROT_UPD_PSD_SHIFT) & EWDG_CFG_PROT_UPD_PSD_MASK)
396 #define EWDG_CFG_PROT_UPD_PSD_GET(x) (((uint32_t)(x) & EWDG_CFG_PROT_UPD_PSD_MASK) >> EWDG_CFG_PROT_UPD_PSD_SHIFT)
397 
398 /* Bitfield definition for register: REF_PROT */
399 /*
400  * REF_UNL_PSD (RW)
401  *
402  * The password to unlock refreshing
403  */
404 #define EWDG_REF_PROT_REF_UNL_PSD_MASK (0xFFFFU)
405 #define EWDG_REF_PROT_REF_UNL_PSD_SHIFT (0U)
406 #define EWDG_REF_PROT_REF_UNL_PSD_SET(x) (((uint32_t)(x) << EWDG_REF_PROT_REF_UNL_PSD_SHIFT) & EWDG_REF_PROT_REF_UNL_PSD_MASK)
407 #define EWDG_REF_PROT_REF_UNL_PSD_GET(x) (((uint32_t)(x) & EWDG_REF_PROT_REF_UNL_PSD_MASK) >> EWDG_REF_PROT_REF_UNL_PSD_SHIFT)
408 
409 /* Bitfield definition for register: WDT_EN */
410 /*
411  * WDOG_EN (RW)
412  *
413  * Wdog is enabled, the re-written of this register is impacted by enable lock function
414  */
415 #define EWDG_WDT_EN_WDOG_EN_MASK (0x1U)
416 #define EWDG_WDT_EN_WDOG_EN_SHIFT (0U)
417 #define EWDG_WDT_EN_WDOG_EN_SET(x) (((uint32_t)(x) << EWDG_WDT_EN_WDOG_EN_SHIFT) & EWDG_WDT_EN_WDOG_EN_MASK)
418 #define EWDG_WDT_EN_WDOG_EN_GET(x) (((uint32_t)(x) & EWDG_WDT_EN_WDOG_EN_MASK) >> EWDG_WDT_EN_WDOG_EN_SHIFT)
419 
420 /* Bitfield definition for register: REF_TIME */
421 /*
422  * REFRESH_PERIOD (RW)
423  *
424  * The refresh period after refresh unlocked
425  * Note: the refresh overtime counter works in bus clock domain, not in wdt function clock domain. The wdt divider doesn't take effect for refresh counter
426  */
427 #define EWDG_REF_TIME_REFRESH_PERIOD_MASK (0xFFFFU)
428 #define EWDG_REF_TIME_REFRESH_PERIOD_SHIFT (0U)
429 #define EWDG_REF_TIME_REFRESH_PERIOD_SET(x) (((uint32_t)(x) << EWDG_REF_TIME_REFRESH_PERIOD_SHIFT) & EWDG_REF_TIME_REFRESH_PERIOD_MASK)
430 #define EWDG_REF_TIME_REFRESH_PERIOD_GET(x) (((uint32_t)(x) & EWDG_REF_TIME_REFRESH_PERIOD_MASK) >> EWDG_REF_TIME_REFRESH_PERIOD_SHIFT)
431 
432 
433 
434 
435 #endif /* HPM_EWDG_H */
Definition: hpm_ewdg_regs.h:12