HPM SDK
HPMicro Software Development Kit
hpm_pcfg_regs.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2021-2025 HPMicro
3  *
4  * SPDX-License-Identifier: BSD-3-Clause
5  *
6  */
7 
8 
9 #ifndef HPM_PCFG_H
10 #define HPM_PCFG_H
11 
12 typedef struct {
13  __RW uint32_t BANDGAP; /* 0x0: BANGGAP control */
14  __RW uint32_t LDO1P1; /* 0x4: 1V LDO config */
15  __RW uint32_t LDO2P5; /* 0x8: 2.5V LDO config */
16  __R uint8_t RESERVED0[4]; /* 0xC - 0xF: Reserved */
17  __RW uint32_t DCDC_MODE; /* 0x10: DCDC mode select */
18  __RW uint32_t DCDC_LPMODE; /* 0x14: DCDC low power mode */
19  __RW uint32_t DCDC_PROT; /* 0x18: DCDC protection */
20  __RW uint32_t DCDC_CURRENT; /* 0x1C: DCDC current estimation */
21  __RW uint32_t DCDC_ADVMODE; /* 0x20: DCDC advance setting */
22  __RW uint32_t DCDC_ADVPARAM; /* 0x24: DCDC advance parameter */
23  __RW uint32_t DCDC_MISC; /* 0x28: DCDC misc parameter */
24  __RW uint32_t DCDC_DEBUG; /* 0x2C: DCDC Debug */
25  __RW uint32_t DCDC_START_TIME; /* 0x30: DCDC ramp time */
26  __RW uint32_t DCDC_RESUME_TIME; /* 0x34: DCDC resume time */
27  __R uint8_t RESERVED1[8]; /* 0x38 - 0x3F: Reserved */
28  __RW uint32_t POWER_TRAP; /* 0x40: SOC power trap */
29  __RW uint32_t WAKE_CAUSE; /* 0x44: Wake up source */
30  __RW uint32_t WAKE_MASK; /* 0x48: Wake up mask */
31  __RW uint32_t SCG_CTRL; /* 0x4C: Clock gate control in PMIC */
32  __R uint8_t RESERVED2[16]; /* 0x50 - 0x5F: Reserved */
33  __RW uint32_t RC24M; /* 0x60: RC 24M config */
34  __RW uint32_t RC24M_TRACK; /* 0x64: RC 24M track mode */
35  __RW uint32_t TRACK_TARGET; /* 0x68: RC 24M track target */
36  __R uint32_t STATUS; /* 0x6C: RC 24M track status */
37 } PCFG_Type;
38 
39 
40 /* Bitfield definition for register: BANDGAP */
41 /*
42  * VBG_TRIMMED (RW)
43  *
44  * Bandgap trim happened, this bit set by hardware after trim value loaded, and stop load, write 0 will clear this bit and reload trim value
45  * 0: bandgap is not trimmed
46  * 1: bandgap is trimmed
47  */
48 #define PCFG_BANDGAP_VBG_TRIMMED_MASK (0x80000000UL)
49 #define PCFG_BANDGAP_VBG_TRIMMED_SHIFT (31U)
50 #define PCFG_BANDGAP_VBG_TRIMMED_SET(x) (((uint32_t)(x) << PCFG_BANDGAP_VBG_TRIMMED_SHIFT) & PCFG_BANDGAP_VBG_TRIMMED_MASK)
51 #define PCFG_BANDGAP_VBG_TRIMMED_GET(x) (((uint32_t)(x) & PCFG_BANDGAP_VBG_TRIMMED_MASK) >> PCFG_BANDGAP_VBG_TRIMMED_SHIFT)
52 
53 /*
54  * VBG_1P0_TRIM (RW)
55  *
56  * Banggap 1.0V output trim value
57  */
58 #define PCFG_BANDGAP_VBG_1P0_TRIM_MASK (0x1F0000UL)
59 #define PCFG_BANDGAP_VBG_1P0_TRIM_SHIFT (16U)
60 #define PCFG_BANDGAP_VBG_1P0_TRIM_SET(x) (((uint32_t)(x) << PCFG_BANDGAP_VBG_1P0_TRIM_SHIFT) & PCFG_BANDGAP_VBG_1P0_TRIM_MASK)
61 #define PCFG_BANDGAP_VBG_1P0_TRIM_GET(x) (((uint32_t)(x) & PCFG_BANDGAP_VBG_1P0_TRIM_MASK) >> PCFG_BANDGAP_VBG_1P0_TRIM_SHIFT)
62 
63 /*
64  * VBG_P65_TRIM (RW)
65  *
66  * Banggap 1.0V output trim value
67  */
68 #define PCFG_BANDGAP_VBG_P65_TRIM_MASK (0x1F00U)
69 #define PCFG_BANDGAP_VBG_P65_TRIM_SHIFT (8U)
70 #define PCFG_BANDGAP_VBG_P65_TRIM_SET(x) (((uint32_t)(x) << PCFG_BANDGAP_VBG_P65_TRIM_SHIFT) & PCFG_BANDGAP_VBG_P65_TRIM_MASK)
71 #define PCFG_BANDGAP_VBG_P65_TRIM_GET(x) (((uint32_t)(x) & PCFG_BANDGAP_VBG_P65_TRIM_MASK) >> PCFG_BANDGAP_VBG_P65_TRIM_SHIFT)
72 
73 /*
74  * VBG_P50_TRIM (RW)
75  *
76  * Banggap 1.0V output trim value
77  */
78 #define PCFG_BANDGAP_VBG_P50_TRIM_MASK (0x1FU)
79 #define PCFG_BANDGAP_VBG_P50_TRIM_SHIFT (0U)
80 #define PCFG_BANDGAP_VBG_P50_TRIM_SET(x) (((uint32_t)(x) << PCFG_BANDGAP_VBG_P50_TRIM_SHIFT) & PCFG_BANDGAP_VBG_P50_TRIM_MASK)
81 #define PCFG_BANDGAP_VBG_P50_TRIM_GET(x) (((uint32_t)(x) & PCFG_BANDGAP_VBG_P50_TRIM_MASK) >> PCFG_BANDGAP_VBG_P50_TRIM_SHIFT)
82 
83 /* Bitfield definition for register: LDO1P1 */
84 /*
85  * VOLT (RW)
86  *
87  * LDO output voltage in mV, value valid through 700-1320, , step 20mV. Hardware select voltage no less than target if not on valid steps, with maximum 1320mV.
88  * 700: 700mV
89  * 720: 720mV
90  * . . .
91  * 1320:1320mV
92  */
93 #define PCFG_LDO1P1_VOLT_MASK (0xFFFU)
94 #define PCFG_LDO1P1_VOLT_SHIFT (0U)
95 #define PCFG_LDO1P1_VOLT_SET(x) (((uint32_t)(x) << PCFG_LDO1P1_VOLT_SHIFT) & PCFG_LDO1P1_VOLT_MASK)
96 #define PCFG_LDO1P1_VOLT_GET(x) (((uint32_t)(x) & PCFG_LDO1P1_VOLT_MASK) >> PCFG_LDO1P1_VOLT_SHIFT)
97 
98 /* Bitfield definition for register: LDO2P5 */
99 /*
100  * READY (RO)
101  *
102  * Ready flag, will set 1ms after enabled or voltage change
103  * 0: LDO is not ready for use
104  * 1: LDO is ready
105  */
106 #define PCFG_LDO2P5_READY_MASK (0x10000000UL)
107 #define PCFG_LDO2P5_READY_SHIFT (28U)
108 #define PCFG_LDO2P5_READY_GET(x) (((uint32_t)(x) & PCFG_LDO2P5_READY_MASK) >> PCFG_LDO2P5_READY_SHIFT)
109 
110 /*
111  * ENABLE (RW)
112  *
113  * LDO enable
114  * 0: turn off LDO
115  * 1: turn on LDO
116  */
117 #define PCFG_LDO2P5_ENABLE_MASK (0x10000UL)
118 #define PCFG_LDO2P5_ENABLE_SHIFT (16U)
119 #define PCFG_LDO2P5_ENABLE_SET(x) (((uint32_t)(x) << PCFG_LDO2P5_ENABLE_SHIFT) & PCFG_LDO2P5_ENABLE_MASK)
120 #define PCFG_LDO2P5_ENABLE_GET(x) (((uint32_t)(x) & PCFG_LDO2P5_ENABLE_MASK) >> PCFG_LDO2P5_ENABLE_SHIFT)
121 
122 /*
123  * VOLT (RW)
124  *
125  * LDO output voltage in mV, value valid through 2125-2900, step 25mV. Hardware select voltage no less than target if not on valid steps, with maximum 2900mV.
126  * 2125: 2125mV
127  * 2150: 2150mV
128  * . . .
129  * 2900:2900mV
130  */
131 #define PCFG_LDO2P5_VOLT_MASK (0xFFFU)
132 #define PCFG_LDO2P5_VOLT_SHIFT (0U)
133 #define PCFG_LDO2P5_VOLT_SET(x) (((uint32_t)(x) << PCFG_LDO2P5_VOLT_SHIFT) & PCFG_LDO2P5_VOLT_MASK)
134 #define PCFG_LDO2P5_VOLT_GET(x) (((uint32_t)(x) & PCFG_LDO2P5_VOLT_MASK) >> PCFG_LDO2P5_VOLT_SHIFT)
135 
136 /* Bitfield definition for register: DCDC_MODE */
137 /*
138  * READY (RO)
139  *
140  * Ready flag
141  * 0: DCDC is applying new change
142  * 1: DCDC is ready
143  */
144 #define PCFG_DCDC_MODE_READY_MASK (0x10000000UL)
145 #define PCFG_DCDC_MODE_READY_SHIFT (28U)
146 #define PCFG_DCDC_MODE_READY_GET(x) (((uint32_t)(x) & PCFG_DCDC_MODE_READY_MASK) >> PCFG_DCDC_MODE_READY_SHIFT)
147 
148 /*
149  * MODE (RW)
150  *
151  * DCDC work mode
152  * XX0: trun off
153  * 001: basic mode
154  * 011: generic mode
155  * 101: automatic mode
156  * 111: expert mode
157  */
158 #define PCFG_DCDC_MODE_MODE_MASK (0x70000UL)
159 #define PCFG_DCDC_MODE_MODE_SHIFT (16U)
160 #define PCFG_DCDC_MODE_MODE_SET(x) (((uint32_t)(x) << PCFG_DCDC_MODE_MODE_SHIFT) & PCFG_DCDC_MODE_MODE_MASK)
161 #define PCFG_DCDC_MODE_MODE_GET(x) (((uint32_t)(x) & PCFG_DCDC_MODE_MODE_MASK) >> PCFG_DCDC_MODE_MODE_SHIFT)
162 
163 /*
164  * VOLT (RW)
165  *
166  * DCDC voltage in mV in normal mode, value valid through 600-1375, , step 25mV. Hardware select voltage no less than target if not on valid steps, with maximum 1375mV.
167  * 600: 600mV
168  * 625: 625mV
169  * . . .
170  * 1375:1375mV
171  */
172 #define PCFG_DCDC_MODE_VOLT_MASK (0xFFFU)
173 #define PCFG_DCDC_MODE_VOLT_SHIFT (0U)
174 #define PCFG_DCDC_MODE_VOLT_SET(x) (((uint32_t)(x) << PCFG_DCDC_MODE_VOLT_SHIFT) & PCFG_DCDC_MODE_VOLT_MASK)
175 #define PCFG_DCDC_MODE_VOLT_GET(x) (((uint32_t)(x) & PCFG_DCDC_MODE_VOLT_MASK) >> PCFG_DCDC_MODE_VOLT_SHIFT)
176 
177 /* Bitfield definition for register: DCDC_LPMODE */
178 /*
179  * STBY_VOLT (RW)
180  *
181  * DCDC voltage in mV in standby mode, , value valid through 600-1375, , step 25mV. Hardware select voltage no less than target if not on valid steps, with maximum 1375mV.
182  * 600: 600mV
183  * 625: 625mV
184  * . . .
185  * 1375:1375mV
186  */
187 #define PCFG_DCDC_LPMODE_STBY_VOLT_MASK (0xFFFU)
188 #define PCFG_DCDC_LPMODE_STBY_VOLT_SHIFT (0U)
189 #define PCFG_DCDC_LPMODE_STBY_VOLT_SET(x) (((uint32_t)(x) << PCFG_DCDC_LPMODE_STBY_VOLT_SHIFT) & PCFG_DCDC_LPMODE_STBY_VOLT_MASK)
190 #define PCFG_DCDC_LPMODE_STBY_VOLT_GET(x) (((uint32_t)(x) & PCFG_DCDC_LPMODE_STBY_VOLT_MASK) >> PCFG_DCDC_LPMODE_STBY_VOLT_SHIFT)
191 
192 /* Bitfield definition for register: DCDC_PROT */
193 /*
194  * ILIMIT_LP (RW)
195  *
196  * over current setting for low power mode
197  * 0:250mA
198  * 1:200mA
199  */
200 #define PCFG_DCDC_PROT_ILIMIT_LP_MASK (0x10000000UL)
201 #define PCFG_DCDC_PROT_ILIMIT_LP_SHIFT (28U)
202 #define PCFG_DCDC_PROT_ILIMIT_LP_SET(x) (((uint32_t)(x) << PCFG_DCDC_PROT_ILIMIT_LP_SHIFT) & PCFG_DCDC_PROT_ILIMIT_LP_MASK)
203 #define PCFG_DCDC_PROT_ILIMIT_LP_GET(x) (((uint32_t)(x) & PCFG_DCDC_PROT_ILIMIT_LP_MASK) >> PCFG_DCDC_PROT_ILIMIT_LP_SHIFT)
204 
205 /*
206  * OVERLOAD_LP (RO)
207  *
208  * over current in low power mode
209  * 0: current is below setting
210  * 1: overcurrent happened in low power mode
211  */
212 #define PCFG_DCDC_PROT_OVERLOAD_LP_MASK (0x1000000UL)
213 #define PCFG_DCDC_PROT_OVERLOAD_LP_SHIFT (24U)
214 #define PCFG_DCDC_PROT_OVERLOAD_LP_GET(x) (((uint32_t)(x) & PCFG_DCDC_PROT_OVERLOAD_LP_MASK) >> PCFG_DCDC_PROT_OVERLOAD_LP_SHIFT)
215 
216 /*
217  * POWER_LOSS_FLAG (RO)
218  *
219  * power loss
220  * 0: input power is good
221  * 1: input power is too low
222  */
223 #define PCFG_DCDC_PROT_POWER_LOSS_FLAG_MASK (0x10000UL)
224 #define PCFG_DCDC_PROT_POWER_LOSS_FLAG_SHIFT (16U)
225 #define PCFG_DCDC_PROT_POWER_LOSS_FLAG_GET(x) (((uint32_t)(x) & PCFG_DCDC_PROT_POWER_LOSS_FLAG_MASK) >> PCFG_DCDC_PROT_POWER_LOSS_FLAG_SHIFT)
226 
227 /*
228  * DISABLE_OVERVOLTAGE (RW)
229  *
230  * ouput over voltage protection
231  * 0: protection enabled, DCDC will shut down is output voltage is unexpected high
232  * 1: protection disabled, DCDC continue to adjust output voltage
233  */
234 #define PCFG_DCDC_PROT_DISABLE_OVERVOLTAGE_MASK (0x8000U)
235 #define PCFG_DCDC_PROT_DISABLE_OVERVOLTAGE_SHIFT (15U)
236 #define PCFG_DCDC_PROT_DISABLE_OVERVOLTAGE_SET(x) (((uint32_t)(x) << PCFG_DCDC_PROT_DISABLE_OVERVOLTAGE_SHIFT) & PCFG_DCDC_PROT_DISABLE_OVERVOLTAGE_MASK)
237 #define PCFG_DCDC_PROT_DISABLE_OVERVOLTAGE_GET(x) (((uint32_t)(x) & PCFG_DCDC_PROT_DISABLE_OVERVOLTAGE_MASK) >> PCFG_DCDC_PROT_DISABLE_OVERVOLTAGE_SHIFT)
238 
239 /*
240  * OVERVOLT_FLAG (RO)
241  *
242  * output over voltage flag
243  * 0: output is normal
244  * 1: output is unexpected high
245  */
246 #define PCFG_DCDC_PROT_OVERVOLT_FLAG_MASK (0x100U)
247 #define PCFG_DCDC_PROT_OVERVOLT_FLAG_SHIFT (8U)
248 #define PCFG_DCDC_PROT_OVERVOLT_FLAG_GET(x) (((uint32_t)(x) & PCFG_DCDC_PROT_OVERVOLT_FLAG_MASK) >> PCFG_DCDC_PROT_OVERVOLT_FLAG_SHIFT)
249 
250 /*
251  * DISABLE_SHORT (RW)
252  *
253  * disable output short circuit protection
254  * 0: short circuits protection enabled, DCDC shut down if short circuit on ouput detected
255  * 1: short circuit protection disabled
256  */
257 #define PCFG_DCDC_PROT_DISABLE_SHORT_MASK (0x80U)
258 #define PCFG_DCDC_PROT_DISABLE_SHORT_SHIFT (7U)
259 #define PCFG_DCDC_PROT_DISABLE_SHORT_SET(x) (((uint32_t)(x) << PCFG_DCDC_PROT_DISABLE_SHORT_SHIFT) & PCFG_DCDC_PROT_DISABLE_SHORT_MASK)
260 #define PCFG_DCDC_PROT_DISABLE_SHORT_GET(x) (((uint32_t)(x) & PCFG_DCDC_PROT_DISABLE_SHORT_MASK) >> PCFG_DCDC_PROT_DISABLE_SHORT_SHIFT)
261 
262 /*
263  * SHORT_CURRENT (RW)
264  *
265  * short circuit current setting
266  * 0: 2.0A,
267  * 1: 1.3A
268  */
269 #define PCFG_DCDC_PROT_SHORT_CURRENT_MASK (0x10U)
270 #define PCFG_DCDC_PROT_SHORT_CURRENT_SHIFT (4U)
271 #define PCFG_DCDC_PROT_SHORT_CURRENT_SET(x) (((uint32_t)(x) << PCFG_DCDC_PROT_SHORT_CURRENT_SHIFT) & PCFG_DCDC_PROT_SHORT_CURRENT_MASK)
272 #define PCFG_DCDC_PROT_SHORT_CURRENT_GET(x) (((uint32_t)(x) & PCFG_DCDC_PROT_SHORT_CURRENT_MASK) >> PCFG_DCDC_PROT_SHORT_CURRENT_SHIFT)
273 
274 /*
275  * SHORT_FLAG (RO)
276  *
277  * short circuit flag
278  * 0: current is within limit
279  * 1: short circuits detected
280  */
281 #define PCFG_DCDC_PROT_SHORT_FLAG_MASK (0x1U)
282 #define PCFG_DCDC_PROT_SHORT_FLAG_SHIFT (0U)
283 #define PCFG_DCDC_PROT_SHORT_FLAG_GET(x) (((uint32_t)(x) & PCFG_DCDC_PROT_SHORT_FLAG_MASK) >> PCFG_DCDC_PROT_SHORT_FLAG_SHIFT)
284 
285 /* Bitfield definition for register: DCDC_CURRENT */
286 /*
287  * ESTI_EN (RW)
288  *
289  * enable current measure
290  */
291 #define PCFG_DCDC_CURRENT_ESTI_EN_MASK (0x8000U)
292 #define PCFG_DCDC_CURRENT_ESTI_EN_SHIFT (15U)
293 #define PCFG_DCDC_CURRENT_ESTI_EN_SET(x) (((uint32_t)(x) << PCFG_DCDC_CURRENT_ESTI_EN_SHIFT) & PCFG_DCDC_CURRENT_ESTI_EN_MASK)
294 #define PCFG_DCDC_CURRENT_ESTI_EN_GET(x) (((uint32_t)(x) & PCFG_DCDC_CURRENT_ESTI_EN_MASK) >> PCFG_DCDC_CURRENT_ESTI_EN_SHIFT)
295 
296 /*
297  * VALID (RO)
298  *
299  * Current level valid
300  * 0: data is invalid
301  * 1: data is valid
302  */
303 #define PCFG_DCDC_CURRENT_VALID_MASK (0x100U)
304 #define PCFG_DCDC_CURRENT_VALID_SHIFT (8U)
305 #define PCFG_DCDC_CURRENT_VALID_GET(x) (((uint32_t)(x) & PCFG_DCDC_CURRENT_VALID_MASK) >> PCFG_DCDC_CURRENT_VALID_SHIFT)
306 
307 /*
308  * LEVEL (RO)
309  *
310  * DCDC current level, current level is num * 50mA
311  */
312 #define PCFG_DCDC_CURRENT_LEVEL_MASK (0x1FU)
313 #define PCFG_DCDC_CURRENT_LEVEL_SHIFT (0U)
314 #define PCFG_DCDC_CURRENT_LEVEL_GET(x) (((uint32_t)(x) & PCFG_DCDC_CURRENT_LEVEL_MASK) >> PCFG_DCDC_CURRENT_LEVEL_SHIFT)
315 
316 /* Bitfield definition for register: DCDC_ADVMODE */
317 /*
318  * EN_RCSCALE (RW)
319  *
320  * Enable RC scale
321  */
322 #define PCFG_DCDC_ADVMODE_EN_RCSCALE_MASK (0x7000000UL)
323 #define PCFG_DCDC_ADVMODE_EN_RCSCALE_SHIFT (24U)
324 #define PCFG_DCDC_ADVMODE_EN_RCSCALE_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVMODE_EN_RCSCALE_SHIFT) & PCFG_DCDC_ADVMODE_EN_RCSCALE_MASK)
325 #define PCFG_DCDC_ADVMODE_EN_RCSCALE_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVMODE_EN_RCSCALE_MASK) >> PCFG_DCDC_ADVMODE_EN_RCSCALE_SHIFT)
326 
327 /*
328  * DC_C (RW)
329  *
330  * Loop C number
331  */
332 #define PCFG_DCDC_ADVMODE_DC_C_MASK (0x300000UL)
333 #define PCFG_DCDC_ADVMODE_DC_C_SHIFT (20U)
334 #define PCFG_DCDC_ADVMODE_DC_C_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVMODE_DC_C_SHIFT) & PCFG_DCDC_ADVMODE_DC_C_MASK)
335 #define PCFG_DCDC_ADVMODE_DC_C_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVMODE_DC_C_MASK) >> PCFG_DCDC_ADVMODE_DC_C_SHIFT)
336 
337 /*
338  * DC_R (RW)
339  *
340  * Loop R number
341  */
342 #define PCFG_DCDC_ADVMODE_DC_R_MASK (0xF0000UL)
343 #define PCFG_DCDC_ADVMODE_DC_R_SHIFT (16U)
344 #define PCFG_DCDC_ADVMODE_DC_R_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVMODE_DC_R_SHIFT) & PCFG_DCDC_ADVMODE_DC_R_MASK)
345 #define PCFG_DCDC_ADVMODE_DC_R_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVMODE_DC_R_MASK) >> PCFG_DCDC_ADVMODE_DC_R_SHIFT)
346 
347 /*
348  * EN_FF_DET (RW)
349  *
350  * enable feed forward detect
351  * 0: feed forward detect is disabled
352  * 1: feed forward detect is enabled
353  */
354 #define PCFG_DCDC_ADVMODE_EN_FF_DET_MASK (0x40U)
355 #define PCFG_DCDC_ADVMODE_EN_FF_DET_SHIFT (6U)
356 #define PCFG_DCDC_ADVMODE_EN_FF_DET_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVMODE_EN_FF_DET_SHIFT) & PCFG_DCDC_ADVMODE_EN_FF_DET_MASK)
357 #define PCFG_DCDC_ADVMODE_EN_FF_DET_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVMODE_EN_FF_DET_MASK) >> PCFG_DCDC_ADVMODE_EN_FF_DET_SHIFT)
358 
359 /*
360  * EN_FF_LOOP (RW)
361  *
362  * enable feed forward loop
363  * 0: feed forward loop is disabled
364  * 1: feed forward loop is enabled
365  */
366 #define PCFG_DCDC_ADVMODE_EN_FF_LOOP_MASK (0x20U)
367 #define PCFG_DCDC_ADVMODE_EN_FF_LOOP_SHIFT (5U)
368 #define PCFG_DCDC_ADVMODE_EN_FF_LOOP_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVMODE_EN_FF_LOOP_SHIFT) & PCFG_DCDC_ADVMODE_EN_FF_LOOP_MASK)
369 #define PCFG_DCDC_ADVMODE_EN_FF_LOOP_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVMODE_EN_FF_LOOP_MASK) >> PCFG_DCDC_ADVMODE_EN_FF_LOOP_SHIFT)
370 
371 /*
372  * EN_AUTOLP (RW)
373  *
374  * enable auto enter low power mode
375  * 0: do not enter low power mode
376  * 1: enter low power mode if current is detected low
377  */
378 #define PCFG_DCDC_ADVMODE_EN_AUTOLP_MASK (0x10U)
379 #define PCFG_DCDC_ADVMODE_EN_AUTOLP_SHIFT (4U)
380 #define PCFG_DCDC_ADVMODE_EN_AUTOLP_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVMODE_EN_AUTOLP_SHIFT) & PCFG_DCDC_ADVMODE_EN_AUTOLP_MASK)
381 #define PCFG_DCDC_ADVMODE_EN_AUTOLP_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVMODE_EN_AUTOLP_MASK) >> PCFG_DCDC_ADVMODE_EN_AUTOLP_SHIFT)
382 
383 /*
384  * EN_DCM_EXIT (RW)
385  *
386  * avoid over voltage
387  * 0: stay in DCM mode when voltage excess
388  * 1: change to CCM mode when voltage excess
389  */
390 #define PCFG_DCDC_ADVMODE_EN_DCM_EXIT_MASK (0x8U)
391 #define PCFG_DCDC_ADVMODE_EN_DCM_EXIT_SHIFT (3U)
392 #define PCFG_DCDC_ADVMODE_EN_DCM_EXIT_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVMODE_EN_DCM_EXIT_SHIFT) & PCFG_DCDC_ADVMODE_EN_DCM_EXIT_MASK)
393 #define PCFG_DCDC_ADVMODE_EN_DCM_EXIT_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVMODE_EN_DCM_EXIT_MASK) >> PCFG_DCDC_ADVMODE_EN_DCM_EXIT_SHIFT)
394 
395 /*
396  * EN_SKIP (RW)
397  *
398  * enable skip on narrow pulse
399  * 0: do not skip narrow pulse
400  * 1: skip narrow pulse
401  */
402 #define PCFG_DCDC_ADVMODE_EN_SKIP_MASK (0x4U)
403 #define PCFG_DCDC_ADVMODE_EN_SKIP_SHIFT (2U)
404 #define PCFG_DCDC_ADVMODE_EN_SKIP_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVMODE_EN_SKIP_SHIFT) & PCFG_DCDC_ADVMODE_EN_SKIP_MASK)
405 #define PCFG_DCDC_ADVMODE_EN_SKIP_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVMODE_EN_SKIP_MASK) >> PCFG_DCDC_ADVMODE_EN_SKIP_SHIFT)
406 
407 /*
408  * EN_IDLE (RW)
409  *
410  * enable skip when voltage is higher than threshold
411  * 0: do not skip
412  * 1: skip if voltage is excess
413  */
414 #define PCFG_DCDC_ADVMODE_EN_IDLE_MASK (0x2U)
415 #define PCFG_DCDC_ADVMODE_EN_IDLE_SHIFT (1U)
416 #define PCFG_DCDC_ADVMODE_EN_IDLE_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVMODE_EN_IDLE_SHIFT) & PCFG_DCDC_ADVMODE_EN_IDLE_MASK)
417 #define PCFG_DCDC_ADVMODE_EN_IDLE_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVMODE_EN_IDLE_MASK) >> PCFG_DCDC_ADVMODE_EN_IDLE_SHIFT)
418 
419 /*
420  * EN_DCM (RW)
421  *
422  * DCM mode
423  * 0: CCM mode
424  * 1: DCM mode
425  */
426 #define PCFG_DCDC_ADVMODE_EN_DCM_MASK (0x1U)
427 #define PCFG_DCDC_ADVMODE_EN_DCM_SHIFT (0U)
428 #define PCFG_DCDC_ADVMODE_EN_DCM_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVMODE_EN_DCM_SHIFT) & PCFG_DCDC_ADVMODE_EN_DCM_MASK)
429 #define PCFG_DCDC_ADVMODE_EN_DCM_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVMODE_EN_DCM_MASK) >> PCFG_DCDC_ADVMODE_EN_DCM_SHIFT)
430 
431 /* Bitfield definition for register: DCDC_ADVPARAM */
432 /*
433  * MIN_DUT (RW)
434  *
435  * minimum duty cycle
436  */
437 #define PCFG_DCDC_ADVPARAM_MIN_DUT_MASK (0x7F00U)
438 #define PCFG_DCDC_ADVPARAM_MIN_DUT_SHIFT (8U)
439 #define PCFG_DCDC_ADVPARAM_MIN_DUT_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVPARAM_MIN_DUT_SHIFT) & PCFG_DCDC_ADVPARAM_MIN_DUT_MASK)
440 #define PCFG_DCDC_ADVPARAM_MIN_DUT_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVPARAM_MIN_DUT_MASK) >> PCFG_DCDC_ADVPARAM_MIN_DUT_SHIFT)
441 
442 /*
443  * MAX_DUT (RW)
444  *
445  * maximum duty cycle
446  */
447 #define PCFG_DCDC_ADVPARAM_MAX_DUT_MASK (0x7FU)
448 #define PCFG_DCDC_ADVPARAM_MAX_DUT_SHIFT (0U)
449 #define PCFG_DCDC_ADVPARAM_MAX_DUT_SET(x) (((uint32_t)(x) << PCFG_DCDC_ADVPARAM_MAX_DUT_SHIFT) & PCFG_DCDC_ADVPARAM_MAX_DUT_MASK)
450 #define PCFG_DCDC_ADVPARAM_MAX_DUT_GET(x) (((uint32_t)(x) & PCFG_DCDC_ADVPARAM_MAX_DUT_MASK) >> PCFG_DCDC_ADVPARAM_MAX_DUT_SHIFT)
451 
452 /* Bitfield definition for register: DCDC_MISC */
453 /*
454  * EN_HYST (RW)
455  *
456  * hysteres enable
457  */
458 #define PCFG_DCDC_MISC_EN_HYST_MASK (0x10000000UL)
459 #define PCFG_DCDC_MISC_EN_HYST_SHIFT (28U)
460 #define PCFG_DCDC_MISC_EN_HYST_SET(x) (((uint32_t)(x) << PCFG_DCDC_MISC_EN_HYST_SHIFT) & PCFG_DCDC_MISC_EN_HYST_MASK)
461 #define PCFG_DCDC_MISC_EN_HYST_GET(x) (((uint32_t)(x) & PCFG_DCDC_MISC_EN_HYST_MASK) >> PCFG_DCDC_MISC_EN_HYST_SHIFT)
462 
463 /*
464  * HYST_SIGN (RW)
465  *
466  * hysteres sign
467  */
468 #define PCFG_DCDC_MISC_HYST_SIGN_MASK (0x2000000UL)
469 #define PCFG_DCDC_MISC_HYST_SIGN_SHIFT (25U)
470 #define PCFG_DCDC_MISC_HYST_SIGN_SET(x) (((uint32_t)(x) << PCFG_DCDC_MISC_HYST_SIGN_SHIFT) & PCFG_DCDC_MISC_HYST_SIGN_MASK)
471 #define PCFG_DCDC_MISC_HYST_SIGN_GET(x) (((uint32_t)(x) & PCFG_DCDC_MISC_HYST_SIGN_MASK) >> PCFG_DCDC_MISC_HYST_SIGN_SHIFT)
472 
473 /*
474  * HYST_THRS (RW)
475  *
476  * hysteres threshold
477  */
478 #define PCFG_DCDC_MISC_HYST_THRS_MASK (0x1000000UL)
479 #define PCFG_DCDC_MISC_HYST_THRS_SHIFT (24U)
480 #define PCFG_DCDC_MISC_HYST_THRS_SET(x) (((uint32_t)(x) << PCFG_DCDC_MISC_HYST_THRS_SHIFT) & PCFG_DCDC_MISC_HYST_THRS_MASK)
481 #define PCFG_DCDC_MISC_HYST_THRS_GET(x) (((uint32_t)(x) & PCFG_DCDC_MISC_HYST_THRS_MASK) >> PCFG_DCDC_MISC_HYST_THRS_SHIFT)
482 
483 /*
484  * RC_SCALE (RW)
485  *
486  * Loop RC scale threshold
487  */
488 #define PCFG_DCDC_MISC_RC_SCALE_MASK (0x100000UL)
489 #define PCFG_DCDC_MISC_RC_SCALE_SHIFT (20U)
490 #define PCFG_DCDC_MISC_RC_SCALE_SET(x) (((uint32_t)(x) << PCFG_DCDC_MISC_RC_SCALE_SHIFT) & PCFG_DCDC_MISC_RC_SCALE_MASK)
491 #define PCFG_DCDC_MISC_RC_SCALE_GET(x) (((uint32_t)(x) & PCFG_DCDC_MISC_RC_SCALE_MASK) >> PCFG_DCDC_MISC_RC_SCALE_SHIFT)
492 
493 /*
494  * DC_FF (RW)
495  *
496  * Loop feed forward number
497  */
498 #define PCFG_DCDC_MISC_DC_FF_MASK (0x70000UL)
499 #define PCFG_DCDC_MISC_DC_FF_SHIFT (16U)
500 #define PCFG_DCDC_MISC_DC_FF_SET(x) (((uint32_t)(x) << PCFG_DCDC_MISC_DC_FF_SHIFT) & PCFG_DCDC_MISC_DC_FF_MASK)
501 #define PCFG_DCDC_MISC_DC_FF_GET(x) (((uint32_t)(x) & PCFG_DCDC_MISC_DC_FF_MASK) >> PCFG_DCDC_MISC_DC_FF_SHIFT)
502 
503 /*
504  * OL_THRE (RW)
505  *
506  * overload threshold in low power mode
507  */
508 #define PCFG_DCDC_MISC_OL_THRE_MASK (0x300U)
509 #define PCFG_DCDC_MISC_OL_THRE_SHIFT (8U)
510 #define PCFG_DCDC_MISC_OL_THRE_SET(x) (((uint32_t)(x) << PCFG_DCDC_MISC_OL_THRE_SHIFT) & PCFG_DCDC_MISC_OL_THRE_MASK)
511 #define PCFG_DCDC_MISC_OL_THRE_GET(x) (((uint32_t)(x) & PCFG_DCDC_MISC_OL_THRE_MASK) >> PCFG_DCDC_MISC_OL_THRE_SHIFT)
512 
513 /*
514  * OL_HYST (RW)
515  *
516  * voltage ripple threshold in low power mode
517  * 0: 12.5mV
518  * 1: 25mV
519  */
520 #define PCFG_DCDC_MISC_OL_HYST_MASK (0x10U)
521 #define PCFG_DCDC_MISC_OL_HYST_SHIFT (4U)
522 #define PCFG_DCDC_MISC_OL_HYST_SET(x) (((uint32_t)(x) << PCFG_DCDC_MISC_OL_HYST_SHIFT) & PCFG_DCDC_MISC_OL_HYST_MASK)
523 #define PCFG_DCDC_MISC_OL_HYST_GET(x) (((uint32_t)(x) & PCFG_DCDC_MISC_OL_HYST_MASK) >> PCFG_DCDC_MISC_OL_HYST_SHIFT)
524 
525 /*
526  * DELAY (RW)
527  *
528  * enable delay
529  * 0: delay disabled,
530  * 1: delay enabled
531  */
532 #define PCFG_DCDC_MISC_DELAY_MASK (0x4U)
533 #define PCFG_DCDC_MISC_DELAY_SHIFT (2U)
534 #define PCFG_DCDC_MISC_DELAY_SET(x) (((uint32_t)(x) << PCFG_DCDC_MISC_DELAY_SHIFT) & PCFG_DCDC_MISC_DELAY_MASK)
535 #define PCFG_DCDC_MISC_DELAY_GET(x) (((uint32_t)(x) & PCFG_DCDC_MISC_DELAY_MASK) >> PCFG_DCDC_MISC_DELAY_SHIFT)
536 
537 /*
538  * CLK_SEL (RW)
539  *
540  * clock selection
541  * 0: select DCDC internal oscillator
542  * 1: select RC24M oscillator
543  */
544 #define PCFG_DCDC_MISC_CLK_SEL_MASK (0x2U)
545 #define PCFG_DCDC_MISC_CLK_SEL_SHIFT (1U)
546 #define PCFG_DCDC_MISC_CLK_SEL_SET(x) (((uint32_t)(x) << PCFG_DCDC_MISC_CLK_SEL_SHIFT) & PCFG_DCDC_MISC_CLK_SEL_MASK)
547 #define PCFG_DCDC_MISC_CLK_SEL_GET(x) (((uint32_t)(x) & PCFG_DCDC_MISC_CLK_SEL_MASK) >> PCFG_DCDC_MISC_CLK_SEL_SHIFT)
548 
549 /*
550  * EN_STEP (RW)
551  *
552  * enable stepping in voltage change
553  * 0: stepping disabled
554  * 1: steping enabled
555  */
556 #define PCFG_DCDC_MISC_EN_STEP_MASK (0x1U)
557 #define PCFG_DCDC_MISC_EN_STEP_SHIFT (0U)
558 #define PCFG_DCDC_MISC_EN_STEP_SET(x) (((uint32_t)(x) << PCFG_DCDC_MISC_EN_STEP_SHIFT) & PCFG_DCDC_MISC_EN_STEP_MASK)
559 #define PCFG_DCDC_MISC_EN_STEP_GET(x) (((uint32_t)(x) & PCFG_DCDC_MISC_EN_STEP_MASK) >> PCFG_DCDC_MISC_EN_STEP_SHIFT)
560 
561 /* Bitfield definition for register: DCDC_DEBUG */
562 /*
563  * UPDATE_TIME (RW)
564  *
565  * DCDC voltage change time in 24M clock cycles, default value is 1mS
566  */
567 #define PCFG_DCDC_DEBUG_UPDATE_TIME_MASK (0xFFFFFUL)
568 #define PCFG_DCDC_DEBUG_UPDATE_TIME_SHIFT (0U)
569 #define PCFG_DCDC_DEBUG_UPDATE_TIME_SET(x) (((uint32_t)(x) << PCFG_DCDC_DEBUG_UPDATE_TIME_SHIFT) & PCFG_DCDC_DEBUG_UPDATE_TIME_MASK)
570 #define PCFG_DCDC_DEBUG_UPDATE_TIME_GET(x) (((uint32_t)(x) & PCFG_DCDC_DEBUG_UPDATE_TIME_MASK) >> PCFG_DCDC_DEBUG_UPDATE_TIME_SHIFT)
571 
572 /* Bitfield definition for register: DCDC_START_TIME */
573 /*
574  * START_TIME (RW)
575  *
576  * Start delay for DCDC to turn on, in 24M clock cycles, default value is 3mS
577  */
578 #define PCFG_DCDC_START_TIME_START_TIME_MASK (0xFFFFFUL)
579 #define PCFG_DCDC_START_TIME_START_TIME_SHIFT (0U)
580 #define PCFG_DCDC_START_TIME_START_TIME_SET(x) (((uint32_t)(x) << PCFG_DCDC_START_TIME_START_TIME_SHIFT) & PCFG_DCDC_START_TIME_START_TIME_MASK)
581 #define PCFG_DCDC_START_TIME_START_TIME_GET(x) (((uint32_t)(x) & PCFG_DCDC_START_TIME_START_TIME_MASK) >> PCFG_DCDC_START_TIME_START_TIME_SHIFT)
582 
583 /* Bitfield definition for register: DCDC_RESUME_TIME */
584 /*
585  * RESUME_TIME (RW)
586  *
587  * Resume delay for DCDC to recover from low power mode, in 24M clock cycles, default value is 1.5mS
588  */
589 #define PCFG_DCDC_RESUME_TIME_RESUME_TIME_MASK (0xFFFFFUL)
590 #define PCFG_DCDC_RESUME_TIME_RESUME_TIME_SHIFT (0U)
591 #define PCFG_DCDC_RESUME_TIME_RESUME_TIME_SET(x) (((uint32_t)(x) << PCFG_DCDC_RESUME_TIME_RESUME_TIME_SHIFT) & PCFG_DCDC_RESUME_TIME_RESUME_TIME_MASK)
592 #define PCFG_DCDC_RESUME_TIME_RESUME_TIME_GET(x) (((uint32_t)(x) & PCFG_DCDC_RESUME_TIME_RESUME_TIME_MASK) >> PCFG_DCDC_RESUME_TIME_RESUME_TIME_SHIFT)
593 
594 /* Bitfield definition for register: POWER_TRAP */
595 /*
596  * TRIGGERED (RW)
597  *
598  * Low power trap status, thit bit will set when power related low power flow triggered, write 1 to clear this flag.
599  * 0: low power trap is not triggered
600  * 1: low power trap triggered
601  */
602 #define PCFG_POWER_TRAP_TRIGGERED_MASK (0x80000000UL)
603 #define PCFG_POWER_TRAP_TRIGGERED_SHIFT (31U)
604 #define PCFG_POWER_TRAP_TRIGGERED_SET(x) (((uint32_t)(x) << PCFG_POWER_TRAP_TRIGGERED_SHIFT) & PCFG_POWER_TRAP_TRIGGERED_MASK)
605 #define PCFG_POWER_TRAP_TRIGGERED_GET(x) (((uint32_t)(x) & PCFG_POWER_TRAP_TRIGGERED_MASK) >> PCFG_POWER_TRAP_TRIGGERED_SHIFT)
606 
607 /*
608  * RETENTION (RW)
609  *
610  * DCDC enter standby mode, which will reduce voltage for memory content retention
611  * 0: Shutdown DCDC
612  * 1: reduce DCDC voltage
613  */
614 #define PCFG_POWER_TRAP_RETENTION_MASK (0x10000UL)
615 #define PCFG_POWER_TRAP_RETENTION_SHIFT (16U)
616 #define PCFG_POWER_TRAP_RETENTION_SET(x) (((uint32_t)(x) << PCFG_POWER_TRAP_RETENTION_SHIFT) & PCFG_POWER_TRAP_RETENTION_MASK)
617 #define PCFG_POWER_TRAP_RETENTION_GET(x) (((uint32_t)(x) & PCFG_POWER_TRAP_RETENTION_MASK) >> PCFG_POWER_TRAP_RETENTION_SHIFT)
618 
619 /*
620  * TRAP (RW)
621  *
622  * Enable trap of SOC power supply, trap is used to hold SOC in low power mode for DCDC to enter further low power mode, this bit will self-clear when power related low pwer flow triggered
623  * 0: trap not enabled, pmic side low power function disabled
624  * 1: trap enabled, STOP operation leads to PMIC low power flow if SOC is not retentioned.
625  */
626 #define PCFG_POWER_TRAP_TRAP_MASK (0x1U)
627 #define PCFG_POWER_TRAP_TRAP_SHIFT (0U)
628 #define PCFG_POWER_TRAP_TRAP_SET(x) (((uint32_t)(x) << PCFG_POWER_TRAP_TRAP_SHIFT) & PCFG_POWER_TRAP_TRAP_MASK)
629 #define PCFG_POWER_TRAP_TRAP_GET(x) (((uint32_t)(x) & PCFG_POWER_TRAP_TRAP_MASK) >> PCFG_POWER_TRAP_TRAP_SHIFT)
630 
631 /* Bitfield definition for register: WAKE_CAUSE */
632 /*
633  * CAUSE (RW)
634  *
635  * wake up cause, each bit represents one wake up source, write 1 to clear the register bit
636  * 0: wake up source is not active during last wakeup
637  * 1: wake up source is active furing last wakeup
638  * bit 0: pmic_enable
639  * bit 7: UART interrupt
640  * bit 8: TMR interrupt
641  * bit 9: WDG interrupt
642  * bit10: GPIO in PMIC interrupt
643  * bit31: pin wakeup
644  */
645 #define PCFG_WAKE_CAUSE_CAUSE_MASK (0xFFFFFFFFUL)
646 #define PCFG_WAKE_CAUSE_CAUSE_SHIFT (0U)
647 #define PCFG_WAKE_CAUSE_CAUSE_SET(x) (((uint32_t)(x) << PCFG_WAKE_CAUSE_CAUSE_SHIFT) & PCFG_WAKE_CAUSE_CAUSE_MASK)
648 #define PCFG_WAKE_CAUSE_CAUSE_GET(x) (((uint32_t)(x) & PCFG_WAKE_CAUSE_CAUSE_MASK) >> PCFG_WAKE_CAUSE_CAUSE_SHIFT)
649 
650 /* Bitfield definition for register: WAKE_MASK */
651 /*
652  * MASK (RW)
653  *
654  * mask for wake up sources, each bit represents one wakeup source
655  * 0: allow source to wake up system
656  * 1: disallow source to wakeup system
657  * bit 0: pmic_enable
658  * bit 7: UART interrupt
659  * bit 8: TMR interrupt
660  * bit 9: WDG interrupt
661  * bit10: GPIO in PMIC interrupt
662  * bit31: pin wakeup
663  */
664 #define PCFG_WAKE_MASK_MASK_MASK (0xFFFFFFFFUL)
665 #define PCFG_WAKE_MASK_MASK_SHIFT (0U)
666 #define PCFG_WAKE_MASK_MASK_SET(x) (((uint32_t)(x) << PCFG_WAKE_MASK_MASK_SHIFT) & PCFG_WAKE_MASK_MASK_MASK)
667 #define PCFG_WAKE_MASK_MASK_GET(x) (((uint32_t)(x) & PCFG_WAKE_MASK_MASK_MASK) >> PCFG_WAKE_MASK_MASK_SHIFT)
668 
669 /* Bitfield definition for register: SCG_CTRL */
670 /*
671  * SCG (RW)
672  *
673  * control whether clock being gated during PMIC low power flow, 2 bits for each peripheral
674  * 00,01: reserved
675  * 10: clock is always off
676  * 11: clock is always on
677  * bit6-7:gpio
678  * bit8-9:ioc
679  * bit10-11: timer
680  * bit12-13:wdog
681  * bit14-15:uart
682  */
683 #define PCFG_SCG_CTRL_SCG_MASK (0xFFFFFFFFUL)
684 #define PCFG_SCG_CTRL_SCG_SHIFT (0U)
685 #define PCFG_SCG_CTRL_SCG_SET(x) (((uint32_t)(x) << PCFG_SCG_CTRL_SCG_SHIFT) & PCFG_SCG_CTRL_SCG_MASK)
686 #define PCFG_SCG_CTRL_SCG_GET(x) (((uint32_t)(x) & PCFG_SCG_CTRL_SCG_MASK) >> PCFG_SCG_CTRL_SCG_SHIFT)
687 
688 /* Bitfield definition for register: RC24M */
689 /*
690  * RC_TRIMMED (RW)
691  *
692  * RC24M trim happened, this bit set by hardware after trim value loaded, and stop load, write 0 will clear this bit and reload trim value
693  * 0: RC is not trimmed
694  * 1: RC is trimmed
695  */
696 #define PCFG_RC24M_RC_TRIMMED_MASK (0x80000000UL)
697 #define PCFG_RC24M_RC_TRIMMED_SHIFT (31U)
698 #define PCFG_RC24M_RC_TRIMMED_SET(x) (((uint32_t)(x) << PCFG_RC24M_RC_TRIMMED_SHIFT) & PCFG_RC24M_RC_TRIMMED_MASK)
699 #define PCFG_RC24M_RC_TRIMMED_GET(x) (((uint32_t)(x) & PCFG_RC24M_RC_TRIMMED_MASK) >> PCFG_RC24M_RC_TRIMMED_SHIFT)
700 
701 /*
702  * TRIM_C (RW)
703  *
704  * Coarse trim for RC24M, bigger value means faster
705  */
706 #define PCFG_RC24M_TRIM_C_MASK (0x700U)
707 #define PCFG_RC24M_TRIM_C_SHIFT (8U)
708 #define PCFG_RC24M_TRIM_C_SET(x) (((uint32_t)(x) << PCFG_RC24M_TRIM_C_SHIFT) & PCFG_RC24M_TRIM_C_MASK)
709 #define PCFG_RC24M_TRIM_C_GET(x) (((uint32_t)(x) & PCFG_RC24M_TRIM_C_MASK) >> PCFG_RC24M_TRIM_C_SHIFT)
710 
711 /*
712  * TRIM_F (RW)
713  *
714  * Fine trim for RC24M, bigger value means faster
715  */
716 #define PCFG_RC24M_TRIM_F_MASK (0x1FU)
717 #define PCFG_RC24M_TRIM_F_SHIFT (0U)
718 #define PCFG_RC24M_TRIM_F_SET(x) (((uint32_t)(x) << PCFG_RC24M_TRIM_F_SHIFT) & PCFG_RC24M_TRIM_F_MASK)
719 #define PCFG_RC24M_TRIM_F_GET(x) (((uint32_t)(x) & PCFG_RC24M_TRIM_F_MASK) >> PCFG_RC24M_TRIM_F_SHIFT)
720 
721 /* Bitfield definition for register: RC24M_TRACK */
722 /*
723  * SEL24M (RW)
724  *
725  * Select track reference
726  * 0: select 32K as reference
727  * 1: select 24M XTAL as reference
728  */
729 #define PCFG_RC24M_TRACK_SEL24M_MASK (0x10000UL)
730 #define PCFG_RC24M_TRACK_SEL24M_SHIFT (16U)
731 #define PCFG_RC24M_TRACK_SEL24M_SET(x) (((uint32_t)(x) << PCFG_RC24M_TRACK_SEL24M_SHIFT) & PCFG_RC24M_TRACK_SEL24M_MASK)
732 #define PCFG_RC24M_TRACK_SEL24M_GET(x) (((uint32_t)(x) & PCFG_RC24M_TRACK_SEL24M_MASK) >> PCFG_RC24M_TRACK_SEL24M_SHIFT)
733 
734 /*
735  * RETURN (RW)
736  *
737  * Retrun default value when XTAL loss
738  * 0: remain last tracking value
739  * 1: switch to default value
740  */
741 #define PCFG_RC24M_TRACK_RETURN_MASK (0x10U)
742 #define PCFG_RC24M_TRACK_RETURN_SHIFT (4U)
743 #define PCFG_RC24M_TRACK_RETURN_SET(x) (((uint32_t)(x) << PCFG_RC24M_TRACK_RETURN_SHIFT) & PCFG_RC24M_TRACK_RETURN_MASK)
744 #define PCFG_RC24M_TRACK_RETURN_GET(x) (((uint32_t)(x) & PCFG_RC24M_TRACK_RETURN_MASK) >> PCFG_RC24M_TRACK_RETURN_SHIFT)
745 
746 /*
747  * TRACK (RW)
748  *
749  * track mode
750  * 0: RC24M free running
751  * 1: track RC24M to external XTAL
752  */
753 #define PCFG_RC24M_TRACK_TRACK_MASK (0x1U)
754 #define PCFG_RC24M_TRACK_TRACK_SHIFT (0U)
755 #define PCFG_RC24M_TRACK_TRACK_SET(x) (((uint32_t)(x) << PCFG_RC24M_TRACK_TRACK_SHIFT) & PCFG_RC24M_TRACK_TRACK_MASK)
756 #define PCFG_RC24M_TRACK_TRACK_GET(x) (((uint32_t)(x) & PCFG_RC24M_TRACK_TRACK_MASK) >> PCFG_RC24M_TRACK_TRACK_SHIFT)
757 
758 /* Bitfield definition for register: TRACK_TARGET */
759 /*
760  * PRE_DIV (RW)
761  *
762  * Divider for reference source
763  */
764 #define PCFG_TRACK_TARGET_PRE_DIV_MASK (0xFFFF0000UL)
765 #define PCFG_TRACK_TARGET_PRE_DIV_SHIFT (16U)
766 #define PCFG_TRACK_TARGET_PRE_DIV_SET(x) (((uint32_t)(x) << PCFG_TRACK_TARGET_PRE_DIV_SHIFT) & PCFG_TRACK_TARGET_PRE_DIV_MASK)
767 #define PCFG_TRACK_TARGET_PRE_DIV_GET(x) (((uint32_t)(x) & PCFG_TRACK_TARGET_PRE_DIV_MASK) >> PCFG_TRACK_TARGET_PRE_DIV_SHIFT)
768 
769 /*
770  * TARGET (RW)
771  *
772  * Target frequency multiplier of divided source
773  */
774 #define PCFG_TRACK_TARGET_TARGET_MASK (0xFFFFU)
775 #define PCFG_TRACK_TARGET_TARGET_SHIFT (0U)
776 #define PCFG_TRACK_TARGET_TARGET_SET(x) (((uint32_t)(x) << PCFG_TRACK_TARGET_TARGET_SHIFT) & PCFG_TRACK_TARGET_TARGET_MASK)
777 #define PCFG_TRACK_TARGET_TARGET_GET(x) (((uint32_t)(x) & PCFG_TRACK_TARGET_TARGET_MASK) >> PCFG_TRACK_TARGET_TARGET_SHIFT)
778 
779 /* Bitfield definition for register: STATUS */
780 /*
781  * SEL32K (RO)
782  *
783  * track is using XTAL32K
784  * 0: track is not using XTAL32K
785  * 1: track is using XTAL32K
786  */
787 #define PCFG_STATUS_SEL32K_MASK (0x100000UL)
788 #define PCFG_STATUS_SEL32K_SHIFT (20U)
789 #define PCFG_STATUS_SEL32K_GET(x) (((uint32_t)(x) & PCFG_STATUS_SEL32K_MASK) >> PCFG_STATUS_SEL32K_SHIFT)
790 
791 /*
792  * SEL24M (RO)
793  *
794  * track is using XTAL24M
795  * 0: track is not using XTAL24M
796  * 1: track is using XTAL24M
797  */
798 #define PCFG_STATUS_SEL24M_MASK (0x10000UL)
799 #define PCFG_STATUS_SEL24M_SHIFT (16U)
800 #define PCFG_STATUS_SEL24M_GET(x) (((uint32_t)(x) & PCFG_STATUS_SEL24M_MASK) >> PCFG_STATUS_SEL24M_SHIFT)
801 
802 /*
803  * EN_TRIM (RO)
804  *
805  * default value takes effect
806  * 0: default value is invalid
807  * 1: default value is valid
808  */
809 #define PCFG_STATUS_EN_TRIM_MASK (0x8000U)
810 #define PCFG_STATUS_EN_TRIM_SHIFT (15U)
811 #define PCFG_STATUS_EN_TRIM_GET(x) (((uint32_t)(x) & PCFG_STATUS_EN_TRIM_MASK) >> PCFG_STATUS_EN_TRIM_SHIFT)
812 
813 /*
814  * TRIM_C (RO)
815  *
816  * default coarse trim value
817  */
818 #define PCFG_STATUS_TRIM_C_MASK (0x700U)
819 #define PCFG_STATUS_TRIM_C_SHIFT (8U)
820 #define PCFG_STATUS_TRIM_C_GET(x) (((uint32_t)(x) & PCFG_STATUS_TRIM_C_MASK) >> PCFG_STATUS_TRIM_C_SHIFT)
821 
822 /*
823  * TRIM_F (RO)
824  *
825  * default fine trim value
826  */
827 #define PCFG_STATUS_TRIM_F_MASK (0x1FU)
828 #define PCFG_STATUS_TRIM_F_SHIFT (0U)
829 #define PCFG_STATUS_TRIM_F_GET(x) (((uint32_t)(x) & PCFG_STATUS_TRIM_F_MASK) >> PCFG_STATUS_TRIM_F_SHIFT)
830 
831 
832 
833 
834 #endif /* HPM_PCFG_H */
Definition: hpm_pcfg_regs.h:12