lpc845_pac/syscon/
pdawakecfg.rs

1#[doc = "Register `PDAWAKECFG` reader"]
2pub struct R(crate::R<PDAWAKECFG_SPEC>);
3impl core::ops::Deref for R {
4    type Target = crate::R<PDAWAKECFG_SPEC>;
5    #[inline(always)]
6    fn deref(&self) -> &Self::Target {
7        &self.0
8    }
9}
10impl From<crate::R<PDAWAKECFG_SPEC>> for R {
11    #[inline(always)]
12    fn from(reader: crate::R<PDAWAKECFG_SPEC>) -> Self {
13        R(reader)
14    }
15}
16#[doc = "Register `PDAWAKECFG` writer"]
17pub struct W(crate::W<PDAWAKECFG_SPEC>);
18impl core::ops::Deref for W {
19    type Target = crate::W<PDAWAKECFG_SPEC>;
20    #[inline(always)]
21    fn deref(&self) -> &Self::Target {
22        &self.0
23    }
24}
25impl core::ops::DerefMut for W {
26    #[inline(always)]
27    fn deref_mut(&mut self) -> &mut Self::Target {
28        &mut self.0
29    }
30}
31impl From<crate::W<PDAWAKECFG_SPEC>> for W {
32    #[inline(always)]
33    fn from(writer: crate::W<PDAWAKECFG_SPEC>) -> Self {
34        W(writer)
35    }
36}
37#[doc = "FRO oscillator output wake-up configuration\n\nValue on reset: 0"]
38#[derive(Clone, Copy, Debug, PartialEq)]
39pub enum FROOUT_PD_A {
40    #[doc = "0: powered"]
41    POWERED = 0,
42    #[doc = "1: powered down"]
43    POWERED_DOWN = 1,
44}
45impl From<FROOUT_PD_A> for bool {
46    #[inline(always)]
47    fn from(variant: FROOUT_PD_A) -> Self {
48        variant as u8 != 0
49    }
50}
51#[doc = "Field `FROOUT_PD` reader - FRO oscillator output wake-up configuration"]
52pub struct FROOUT_PD_R(crate::FieldReader<bool, FROOUT_PD_A>);
53impl FROOUT_PD_R {
54    pub(crate) fn new(bits: bool) -> Self {
55        FROOUT_PD_R(crate::FieldReader::new(bits))
56    }
57    #[doc = r"Get enumerated values variant"]
58    #[inline(always)]
59    pub fn variant(&self) -> FROOUT_PD_A {
60        match self.bits {
61            false => FROOUT_PD_A::POWERED,
62            true => FROOUT_PD_A::POWERED_DOWN,
63        }
64    }
65    #[doc = "Checks if the value of the field is `POWERED`"]
66    #[inline(always)]
67    pub fn is_powered(&self) -> bool {
68        **self == FROOUT_PD_A::POWERED
69    }
70    #[doc = "Checks if the value of the field is `POWERED_DOWN`"]
71    #[inline(always)]
72    pub fn is_powered_down(&self) -> bool {
73        **self == FROOUT_PD_A::POWERED_DOWN
74    }
75}
76impl core::ops::Deref for FROOUT_PD_R {
77    type Target = crate::FieldReader<bool, FROOUT_PD_A>;
78    #[inline(always)]
79    fn deref(&self) -> &Self::Target {
80        &self.0
81    }
82}
83#[doc = "Field `FROOUT_PD` writer - FRO oscillator output wake-up configuration"]
84pub struct FROOUT_PD_W<'a> {
85    w: &'a mut W,
86}
87impl<'a> FROOUT_PD_W<'a> {
88    #[doc = r"Writes `variant` to the field"]
89    #[inline(always)]
90    pub fn variant(self, variant: FROOUT_PD_A) -> &'a mut W {
91        self.bit(variant.into())
92    }
93    #[doc = "powered"]
94    #[inline(always)]
95    pub fn powered(self) -> &'a mut W {
96        self.variant(FROOUT_PD_A::POWERED)
97    }
98    #[doc = "powered down"]
99    #[inline(always)]
100    pub fn powered_down(self) -> &'a mut W {
101        self.variant(FROOUT_PD_A::POWERED_DOWN)
102    }
103    #[doc = r"Sets the field bit"]
104    #[inline(always)]
105    pub fn set_bit(self) -> &'a mut W {
106        self.bit(true)
107    }
108    #[doc = r"Clears the field bit"]
109    #[inline(always)]
110    pub fn clear_bit(self) -> &'a mut W {
111        self.bit(false)
112    }
113    #[doc = r"Writes raw bits to the field"]
114    #[inline(always)]
115    pub fn bit(self, value: bool) -> &'a mut W {
116        self.w.bits = (self.w.bits & !0x01) | (value as u32 & 0x01);
117        self.w
118    }
119}
120#[doc = "FRO oscillator power-down wake-up configuration\n\nValue on reset: 0"]
121#[derive(Clone, Copy, Debug, PartialEq)]
122pub enum FRO_PD_A {
123    #[doc = "0: powered"]
124    POWERED = 0,
125    #[doc = "1: powered down"]
126    POWERED_DOWN = 1,
127}
128impl From<FRO_PD_A> for bool {
129    #[inline(always)]
130    fn from(variant: FRO_PD_A) -> Self {
131        variant as u8 != 0
132    }
133}
134#[doc = "Field `FRO_PD` reader - FRO oscillator power-down wake-up configuration"]
135pub struct FRO_PD_R(crate::FieldReader<bool, FRO_PD_A>);
136impl FRO_PD_R {
137    pub(crate) fn new(bits: bool) -> Self {
138        FRO_PD_R(crate::FieldReader::new(bits))
139    }
140    #[doc = r"Get enumerated values variant"]
141    #[inline(always)]
142    pub fn variant(&self) -> FRO_PD_A {
143        match self.bits {
144            false => FRO_PD_A::POWERED,
145            true => FRO_PD_A::POWERED_DOWN,
146        }
147    }
148    #[doc = "Checks if the value of the field is `POWERED`"]
149    #[inline(always)]
150    pub fn is_powered(&self) -> bool {
151        **self == FRO_PD_A::POWERED
152    }
153    #[doc = "Checks if the value of the field is `POWERED_DOWN`"]
154    #[inline(always)]
155    pub fn is_powered_down(&self) -> bool {
156        **self == FRO_PD_A::POWERED_DOWN
157    }
158}
159impl core::ops::Deref for FRO_PD_R {
160    type Target = crate::FieldReader<bool, FRO_PD_A>;
161    #[inline(always)]
162    fn deref(&self) -> &Self::Target {
163        &self.0
164    }
165}
166#[doc = "Field `FRO_PD` writer - FRO oscillator power-down wake-up configuration"]
167pub struct FRO_PD_W<'a> {
168    w: &'a mut W,
169}
170impl<'a> FRO_PD_W<'a> {
171    #[doc = r"Writes `variant` to the field"]
172    #[inline(always)]
173    pub fn variant(self, variant: FRO_PD_A) -> &'a mut W {
174        self.bit(variant.into())
175    }
176    #[doc = "powered"]
177    #[inline(always)]
178    pub fn powered(self) -> &'a mut W {
179        self.variant(FRO_PD_A::POWERED)
180    }
181    #[doc = "powered down"]
182    #[inline(always)]
183    pub fn powered_down(self) -> &'a mut W {
184        self.variant(FRO_PD_A::POWERED_DOWN)
185    }
186    #[doc = r"Sets the field bit"]
187    #[inline(always)]
188    pub fn set_bit(self) -> &'a mut W {
189        self.bit(true)
190    }
191    #[doc = r"Clears the field bit"]
192    #[inline(always)]
193    pub fn clear_bit(self) -> &'a mut W {
194        self.bit(false)
195    }
196    #[doc = r"Writes raw bits to the field"]
197    #[inline(always)]
198    pub fn bit(self, value: bool) -> &'a mut W {
199        self.w.bits = (self.w.bits & !(0x01 << 1)) | ((value as u32 & 0x01) << 1);
200        self.w
201    }
202}
203#[doc = "Flash wake-up configuration\n\nValue on reset: 0"]
204#[derive(Clone, Copy, Debug, PartialEq)]
205pub enum FLASH_PD_A {
206    #[doc = "0: powered"]
207    POWERED = 0,
208    #[doc = "1: powered down"]
209    POWERED_DOWN = 1,
210}
211impl From<FLASH_PD_A> for bool {
212    #[inline(always)]
213    fn from(variant: FLASH_PD_A) -> Self {
214        variant as u8 != 0
215    }
216}
217#[doc = "Field `FLASH_PD` reader - Flash wake-up configuration"]
218pub struct FLASH_PD_R(crate::FieldReader<bool, FLASH_PD_A>);
219impl FLASH_PD_R {
220    pub(crate) fn new(bits: bool) -> Self {
221        FLASH_PD_R(crate::FieldReader::new(bits))
222    }
223    #[doc = r"Get enumerated values variant"]
224    #[inline(always)]
225    pub fn variant(&self) -> FLASH_PD_A {
226        match self.bits {
227            false => FLASH_PD_A::POWERED,
228            true => FLASH_PD_A::POWERED_DOWN,
229        }
230    }
231    #[doc = "Checks if the value of the field is `POWERED`"]
232    #[inline(always)]
233    pub fn is_powered(&self) -> bool {
234        **self == FLASH_PD_A::POWERED
235    }
236    #[doc = "Checks if the value of the field is `POWERED_DOWN`"]
237    #[inline(always)]
238    pub fn is_powered_down(&self) -> bool {
239        **self == FLASH_PD_A::POWERED_DOWN
240    }
241}
242impl core::ops::Deref for FLASH_PD_R {
243    type Target = crate::FieldReader<bool, FLASH_PD_A>;
244    #[inline(always)]
245    fn deref(&self) -> &Self::Target {
246        &self.0
247    }
248}
249#[doc = "Field `FLASH_PD` writer - Flash wake-up configuration"]
250pub struct FLASH_PD_W<'a> {
251    w: &'a mut W,
252}
253impl<'a> FLASH_PD_W<'a> {
254    #[doc = r"Writes `variant` to the field"]
255    #[inline(always)]
256    pub fn variant(self, variant: FLASH_PD_A) -> &'a mut W {
257        self.bit(variant.into())
258    }
259    #[doc = "powered"]
260    #[inline(always)]
261    pub fn powered(self) -> &'a mut W {
262        self.variant(FLASH_PD_A::POWERED)
263    }
264    #[doc = "powered down"]
265    #[inline(always)]
266    pub fn powered_down(self) -> &'a mut W {
267        self.variant(FLASH_PD_A::POWERED_DOWN)
268    }
269    #[doc = r"Sets the field bit"]
270    #[inline(always)]
271    pub fn set_bit(self) -> &'a mut W {
272        self.bit(true)
273    }
274    #[doc = r"Clears the field bit"]
275    #[inline(always)]
276    pub fn clear_bit(self) -> &'a mut W {
277        self.bit(false)
278    }
279    #[doc = r"Writes raw bits to the field"]
280    #[inline(always)]
281    pub fn bit(self, value: bool) -> &'a mut W {
282        self.w.bits = (self.w.bits & !(0x01 << 2)) | ((value as u32 & 0x01) << 2);
283        self.w
284    }
285}
286#[doc = "BOD wake-up configuration\n\nValue on reset: 1"]
287#[derive(Clone, Copy, Debug, PartialEq)]
288pub enum BOD_PD_A {
289    #[doc = "0: powered"]
290    POWERED = 0,
291    #[doc = "1: powered down"]
292    POWERED_DOWN = 1,
293}
294impl From<BOD_PD_A> for bool {
295    #[inline(always)]
296    fn from(variant: BOD_PD_A) -> Self {
297        variant as u8 != 0
298    }
299}
300#[doc = "Field `BOD_PD` reader - BOD wake-up configuration"]
301pub struct BOD_PD_R(crate::FieldReader<bool, BOD_PD_A>);
302impl BOD_PD_R {
303    pub(crate) fn new(bits: bool) -> Self {
304        BOD_PD_R(crate::FieldReader::new(bits))
305    }
306    #[doc = r"Get enumerated values variant"]
307    #[inline(always)]
308    pub fn variant(&self) -> BOD_PD_A {
309        match self.bits {
310            false => BOD_PD_A::POWERED,
311            true => BOD_PD_A::POWERED_DOWN,
312        }
313    }
314    #[doc = "Checks if the value of the field is `POWERED`"]
315    #[inline(always)]
316    pub fn is_powered(&self) -> bool {
317        **self == BOD_PD_A::POWERED
318    }
319    #[doc = "Checks if the value of the field is `POWERED_DOWN`"]
320    #[inline(always)]
321    pub fn is_powered_down(&self) -> bool {
322        **self == BOD_PD_A::POWERED_DOWN
323    }
324}
325impl core::ops::Deref for BOD_PD_R {
326    type Target = crate::FieldReader<bool, BOD_PD_A>;
327    #[inline(always)]
328    fn deref(&self) -> &Self::Target {
329        &self.0
330    }
331}
332#[doc = "Field `BOD_PD` writer - BOD wake-up configuration"]
333pub struct BOD_PD_W<'a> {
334    w: &'a mut W,
335}
336impl<'a> BOD_PD_W<'a> {
337    #[doc = r"Writes `variant` to the field"]
338    #[inline(always)]
339    pub fn variant(self, variant: BOD_PD_A) -> &'a mut W {
340        self.bit(variant.into())
341    }
342    #[doc = "powered"]
343    #[inline(always)]
344    pub fn powered(self) -> &'a mut W {
345        self.variant(BOD_PD_A::POWERED)
346    }
347    #[doc = "powered down"]
348    #[inline(always)]
349    pub fn powered_down(self) -> &'a mut W {
350        self.variant(BOD_PD_A::POWERED_DOWN)
351    }
352    #[doc = r"Sets the field bit"]
353    #[inline(always)]
354    pub fn set_bit(self) -> &'a mut W {
355        self.bit(true)
356    }
357    #[doc = r"Clears the field bit"]
358    #[inline(always)]
359    pub fn clear_bit(self) -> &'a mut W {
360        self.bit(false)
361    }
362    #[doc = r"Writes raw bits to the field"]
363    #[inline(always)]
364    pub fn bit(self, value: bool) -> &'a mut W {
365        self.w.bits = (self.w.bits & !(0x01 << 3)) | ((value as u32 & 0x01) << 3);
366        self.w
367    }
368}
369#[doc = "ADC wake-up configuration\n\nValue on reset: 1"]
370#[derive(Clone, Copy, Debug, PartialEq)]
371pub enum ADC_PD_A {
372    #[doc = "0: powered"]
373    POWERED = 0,
374    #[doc = "1: powered down"]
375    POWERED_DOWN = 1,
376}
377impl From<ADC_PD_A> for bool {
378    #[inline(always)]
379    fn from(variant: ADC_PD_A) -> Self {
380        variant as u8 != 0
381    }
382}
383#[doc = "Field `ADC_PD` reader - ADC wake-up configuration"]
384pub struct ADC_PD_R(crate::FieldReader<bool, ADC_PD_A>);
385impl ADC_PD_R {
386    pub(crate) fn new(bits: bool) -> Self {
387        ADC_PD_R(crate::FieldReader::new(bits))
388    }
389    #[doc = r"Get enumerated values variant"]
390    #[inline(always)]
391    pub fn variant(&self) -> ADC_PD_A {
392        match self.bits {
393            false => ADC_PD_A::POWERED,
394            true => ADC_PD_A::POWERED_DOWN,
395        }
396    }
397    #[doc = "Checks if the value of the field is `POWERED`"]
398    #[inline(always)]
399    pub fn is_powered(&self) -> bool {
400        **self == ADC_PD_A::POWERED
401    }
402    #[doc = "Checks if the value of the field is `POWERED_DOWN`"]
403    #[inline(always)]
404    pub fn is_powered_down(&self) -> bool {
405        **self == ADC_PD_A::POWERED_DOWN
406    }
407}
408impl core::ops::Deref for ADC_PD_R {
409    type Target = crate::FieldReader<bool, ADC_PD_A>;
410    #[inline(always)]
411    fn deref(&self) -> &Self::Target {
412        &self.0
413    }
414}
415#[doc = "Field `ADC_PD` writer - ADC wake-up configuration"]
416pub struct ADC_PD_W<'a> {
417    w: &'a mut W,
418}
419impl<'a> ADC_PD_W<'a> {
420    #[doc = r"Writes `variant` to the field"]
421    #[inline(always)]
422    pub fn variant(self, variant: ADC_PD_A) -> &'a mut W {
423        self.bit(variant.into())
424    }
425    #[doc = "powered"]
426    #[inline(always)]
427    pub fn powered(self) -> &'a mut W {
428        self.variant(ADC_PD_A::POWERED)
429    }
430    #[doc = "powered down"]
431    #[inline(always)]
432    pub fn powered_down(self) -> &'a mut W {
433        self.variant(ADC_PD_A::POWERED_DOWN)
434    }
435    #[doc = r"Sets the field bit"]
436    #[inline(always)]
437    pub fn set_bit(self) -> &'a mut W {
438        self.bit(true)
439    }
440    #[doc = r"Clears the field bit"]
441    #[inline(always)]
442    pub fn clear_bit(self) -> &'a mut W {
443        self.bit(false)
444    }
445    #[doc = r"Writes raw bits to the field"]
446    #[inline(always)]
447    pub fn bit(self, value: bool) -> &'a mut W {
448        self.w.bits = (self.w.bits & !(0x01 << 4)) | ((value as u32 & 0x01) << 4);
449        self.w
450    }
451}
452#[doc = "Crystal oscillator wake-up configuration\n\nValue on reset: 1"]
453#[derive(Clone, Copy, Debug, PartialEq)]
454pub enum SYSOSC_PD_A {
455    #[doc = "0: powered"]
456    POWERED = 0,
457    #[doc = "1: powered down"]
458    POWERED_DOWN = 1,
459}
460impl From<SYSOSC_PD_A> for bool {
461    #[inline(always)]
462    fn from(variant: SYSOSC_PD_A) -> Self {
463        variant as u8 != 0
464    }
465}
466#[doc = "Field `SYSOSC_PD` reader - Crystal oscillator wake-up configuration"]
467pub struct SYSOSC_PD_R(crate::FieldReader<bool, SYSOSC_PD_A>);
468impl SYSOSC_PD_R {
469    pub(crate) fn new(bits: bool) -> Self {
470        SYSOSC_PD_R(crate::FieldReader::new(bits))
471    }
472    #[doc = r"Get enumerated values variant"]
473    #[inline(always)]
474    pub fn variant(&self) -> SYSOSC_PD_A {
475        match self.bits {
476            false => SYSOSC_PD_A::POWERED,
477            true => SYSOSC_PD_A::POWERED_DOWN,
478        }
479    }
480    #[doc = "Checks if the value of the field is `POWERED`"]
481    #[inline(always)]
482    pub fn is_powered(&self) -> bool {
483        **self == SYSOSC_PD_A::POWERED
484    }
485    #[doc = "Checks if the value of the field is `POWERED_DOWN`"]
486    #[inline(always)]
487    pub fn is_powered_down(&self) -> bool {
488        **self == SYSOSC_PD_A::POWERED_DOWN
489    }
490}
491impl core::ops::Deref for SYSOSC_PD_R {
492    type Target = crate::FieldReader<bool, SYSOSC_PD_A>;
493    #[inline(always)]
494    fn deref(&self) -> &Self::Target {
495        &self.0
496    }
497}
498#[doc = "Field `SYSOSC_PD` writer - Crystal oscillator wake-up configuration"]
499pub struct SYSOSC_PD_W<'a> {
500    w: &'a mut W,
501}
502impl<'a> SYSOSC_PD_W<'a> {
503    #[doc = r"Writes `variant` to the field"]
504    #[inline(always)]
505    pub fn variant(self, variant: SYSOSC_PD_A) -> &'a mut W {
506        self.bit(variant.into())
507    }
508    #[doc = "powered"]
509    #[inline(always)]
510    pub fn powered(self) -> &'a mut W {
511        self.variant(SYSOSC_PD_A::POWERED)
512    }
513    #[doc = "powered down"]
514    #[inline(always)]
515    pub fn powered_down(self) -> &'a mut W {
516        self.variant(SYSOSC_PD_A::POWERED_DOWN)
517    }
518    #[doc = r"Sets the field bit"]
519    #[inline(always)]
520    pub fn set_bit(self) -> &'a mut W {
521        self.bit(true)
522    }
523    #[doc = r"Clears the field bit"]
524    #[inline(always)]
525    pub fn clear_bit(self) -> &'a mut W {
526        self.bit(false)
527    }
528    #[doc = r"Writes raw bits to the field"]
529    #[inline(always)]
530    pub fn bit(self, value: bool) -> &'a mut W {
531        self.w.bits = (self.w.bits & !(0x01 << 5)) | ((value as u32 & 0x01) << 5);
532        self.w
533    }
534}
535#[doc = "Watchdog oscillator wake-up configuration. Changing this bit to powered-down has no effect when the LOCK bit in the WWDT MOD register is set. In this case, the watchdog oscillator is always running\n\nValue on reset: 1"]
536#[derive(Clone, Copy, Debug, PartialEq)]
537pub enum WDTOSC_PD_A {
538    #[doc = "0: Disabled"]
539    DISABLED = 0,
540    #[doc = "1: Enabled"]
541    ENABLED = 1,
542}
543impl From<WDTOSC_PD_A> for bool {
544    #[inline(always)]
545    fn from(variant: WDTOSC_PD_A) -> Self {
546        variant as u8 != 0
547    }
548}
549#[doc = "Field `WDTOSC_PD` reader - Watchdog oscillator wake-up configuration. Changing this bit to powered-down has no effect when the LOCK bit in the WWDT MOD register is set. In this case, the watchdog oscillator is always running"]
550pub struct WDTOSC_PD_R(crate::FieldReader<bool, WDTOSC_PD_A>);
551impl WDTOSC_PD_R {
552    pub(crate) fn new(bits: bool) -> Self {
553        WDTOSC_PD_R(crate::FieldReader::new(bits))
554    }
555    #[doc = r"Get enumerated values variant"]
556    #[inline(always)]
557    pub fn variant(&self) -> WDTOSC_PD_A {
558        match self.bits {
559            false => WDTOSC_PD_A::DISABLED,
560            true => WDTOSC_PD_A::ENABLED,
561        }
562    }
563    #[doc = "Checks if the value of the field is `DISABLED`"]
564    #[inline(always)]
565    pub fn is_disabled(&self) -> bool {
566        **self == WDTOSC_PD_A::DISABLED
567    }
568    #[doc = "Checks if the value of the field is `ENABLED`"]
569    #[inline(always)]
570    pub fn is_enabled(&self) -> bool {
571        **self == WDTOSC_PD_A::ENABLED
572    }
573}
574impl core::ops::Deref for WDTOSC_PD_R {
575    type Target = crate::FieldReader<bool, WDTOSC_PD_A>;
576    #[inline(always)]
577    fn deref(&self) -> &Self::Target {
578        &self.0
579    }
580}
581#[doc = "Field `WDTOSC_PD` writer - Watchdog oscillator wake-up configuration. Changing this bit to powered-down has no effect when the LOCK bit in the WWDT MOD register is set. In this case, the watchdog oscillator is always running"]
582pub struct WDTOSC_PD_W<'a> {
583    w: &'a mut W,
584}
585impl<'a> WDTOSC_PD_W<'a> {
586    #[doc = r"Writes `variant` to the field"]
587    #[inline(always)]
588    pub fn variant(self, variant: WDTOSC_PD_A) -> &'a mut W {
589        self.bit(variant.into())
590    }
591    #[doc = "Disabled"]
592    #[inline(always)]
593    pub fn disabled(self) -> &'a mut W {
594        self.variant(WDTOSC_PD_A::DISABLED)
595    }
596    #[doc = "Enabled"]
597    #[inline(always)]
598    pub fn enabled(self) -> &'a mut W {
599        self.variant(WDTOSC_PD_A::ENABLED)
600    }
601    #[doc = r"Sets the field bit"]
602    #[inline(always)]
603    pub fn set_bit(self) -> &'a mut W {
604        self.bit(true)
605    }
606    #[doc = r"Clears the field bit"]
607    #[inline(always)]
608    pub fn clear_bit(self) -> &'a mut W {
609        self.bit(false)
610    }
611    #[doc = r"Writes raw bits to the field"]
612    #[inline(always)]
613    pub fn bit(self, value: bool) -> &'a mut W {
614        self.w.bits = (self.w.bits & !(0x01 << 6)) | ((value as u32 & 0x01) << 6);
615        self.w
616    }
617}
618#[doc = "System PLL wake-up configuration\n\nValue on reset: 1"]
619#[derive(Clone, Copy, Debug, PartialEq)]
620pub enum SYSPLL_PD_A {
621    #[doc = "0: Disabled"]
622    DISABLED = 0,
623    #[doc = "1: Enabled"]
624    ENABLED = 1,
625}
626impl From<SYSPLL_PD_A> for bool {
627    #[inline(always)]
628    fn from(variant: SYSPLL_PD_A) -> Self {
629        variant as u8 != 0
630    }
631}
632#[doc = "Field `SYSPLL_PD` reader - System PLL wake-up configuration"]
633pub struct SYSPLL_PD_R(crate::FieldReader<bool, SYSPLL_PD_A>);
634impl SYSPLL_PD_R {
635    pub(crate) fn new(bits: bool) -> Self {
636        SYSPLL_PD_R(crate::FieldReader::new(bits))
637    }
638    #[doc = r"Get enumerated values variant"]
639    #[inline(always)]
640    pub fn variant(&self) -> SYSPLL_PD_A {
641        match self.bits {
642            false => SYSPLL_PD_A::DISABLED,
643            true => SYSPLL_PD_A::ENABLED,
644        }
645    }
646    #[doc = "Checks if the value of the field is `DISABLED`"]
647    #[inline(always)]
648    pub fn is_disabled(&self) -> bool {
649        **self == SYSPLL_PD_A::DISABLED
650    }
651    #[doc = "Checks if the value of the field is `ENABLED`"]
652    #[inline(always)]
653    pub fn is_enabled(&self) -> bool {
654        **self == SYSPLL_PD_A::ENABLED
655    }
656}
657impl core::ops::Deref for SYSPLL_PD_R {
658    type Target = crate::FieldReader<bool, SYSPLL_PD_A>;
659    #[inline(always)]
660    fn deref(&self) -> &Self::Target {
661        &self.0
662    }
663}
664#[doc = "Field `SYSPLL_PD` writer - System PLL wake-up configuration"]
665pub struct SYSPLL_PD_W<'a> {
666    w: &'a mut W,
667}
668impl<'a> SYSPLL_PD_W<'a> {
669    #[doc = r"Writes `variant` to the field"]
670    #[inline(always)]
671    pub fn variant(self, variant: SYSPLL_PD_A) -> &'a mut W {
672        self.bit(variant.into())
673    }
674    #[doc = "Disabled"]
675    #[inline(always)]
676    pub fn disabled(self) -> &'a mut W {
677        self.variant(SYSPLL_PD_A::DISABLED)
678    }
679    #[doc = "Enabled"]
680    #[inline(always)]
681    pub fn enabled(self) -> &'a mut W {
682        self.variant(SYSPLL_PD_A::ENABLED)
683    }
684    #[doc = r"Sets the field bit"]
685    #[inline(always)]
686    pub fn set_bit(self) -> &'a mut W {
687        self.bit(true)
688    }
689    #[doc = r"Clears the field bit"]
690    #[inline(always)]
691    pub fn clear_bit(self) -> &'a mut W {
692        self.bit(false)
693    }
694    #[doc = r"Writes raw bits to the field"]
695    #[inline(always)]
696    pub fn bit(self, value: bool) -> &'a mut W {
697        self.w.bits = (self.w.bits & !(0x01 << 7)) | ((value as u32 & 0x01) << 7);
698        self.w
699    }
700}
701#[doc = "VREF2 wake-up configuration\n\nValue on reset: 1"]
702#[derive(Clone, Copy, Debug, PartialEq)]
703pub enum VREF2_PD_A {
704    #[doc = "0: Disabled"]
705    DISABLED = 0,
706    #[doc = "1: Enabled"]
707    ENABLED = 1,
708}
709impl From<VREF2_PD_A> for bool {
710    #[inline(always)]
711    fn from(variant: VREF2_PD_A) -> Self {
712        variant as u8 != 0
713    }
714}
715#[doc = "Field `VREF2_PD` reader - VREF2 wake-up configuration"]
716pub struct VREF2_PD_R(crate::FieldReader<bool, VREF2_PD_A>);
717impl VREF2_PD_R {
718    pub(crate) fn new(bits: bool) -> Self {
719        VREF2_PD_R(crate::FieldReader::new(bits))
720    }
721    #[doc = r"Get enumerated values variant"]
722    #[inline(always)]
723    pub fn variant(&self) -> VREF2_PD_A {
724        match self.bits {
725            false => VREF2_PD_A::DISABLED,
726            true => VREF2_PD_A::ENABLED,
727        }
728    }
729    #[doc = "Checks if the value of the field is `DISABLED`"]
730    #[inline(always)]
731    pub fn is_disabled(&self) -> bool {
732        **self == VREF2_PD_A::DISABLED
733    }
734    #[doc = "Checks if the value of the field is `ENABLED`"]
735    #[inline(always)]
736    pub fn is_enabled(&self) -> bool {
737        **self == VREF2_PD_A::ENABLED
738    }
739}
740impl core::ops::Deref for VREF2_PD_R {
741    type Target = crate::FieldReader<bool, VREF2_PD_A>;
742    #[inline(always)]
743    fn deref(&self) -> &Self::Target {
744        &self.0
745    }
746}
747#[doc = "Field `VREF2_PD` writer - VREF2 wake-up configuration"]
748pub struct VREF2_PD_W<'a> {
749    w: &'a mut W,
750}
751impl<'a> VREF2_PD_W<'a> {
752    #[doc = r"Writes `variant` to the field"]
753    #[inline(always)]
754    pub fn variant(self, variant: VREF2_PD_A) -> &'a mut W {
755        self.bit(variant.into())
756    }
757    #[doc = "Disabled"]
758    #[inline(always)]
759    pub fn disabled(self) -> &'a mut W {
760        self.variant(VREF2_PD_A::DISABLED)
761    }
762    #[doc = "Enabled"]
763    #[inline(always)]
764    pub fn enabled(self) -> &'a mut W {
765        self.variant(VREF2_PD_A::ENABLED)
766    }
767    #[doc = r"Sets the field bit"]
768    #[inline(always)]
769    pub fn set_bit(self) -> &'a mut W {
770        self.bit(true)
771    }
772    #[doc = r"Clears the field bit"]
773    #[inline(always)]
774    pub fn clear_bit(self) -> &'a mut W {
775        self.bit(false)
776    }
777    #[doc = r"Writes raw bits to the field"]
778    #[inline(always)]
779    pub fn bit(self, value: bool) -> &'a mut W {
780        self.w.bits = (self.w.bits & !(0x01 << 10)) | ((value as u32 & 0x01) << 10);
781        self.w
782    }
783}
784#[doc = "DAC0 wake-up configuration\n\nValue on reset: 1"]
785#[derive(Clone, Copy, Debug, PartialEq)]
786pub enum DAC0_A {
787    #[doc = "0: Disabled"]
788    DISABLED = 0,
789    #[doc = "1: Enabled"]
790    ENABLED = 1,
791}
792impl From<DAC0_A> for bool {
793    #[inline(always)]
794    fn from(variant: DAC0_A) -> Self {
795        variant as u8 != 0
796    }
797}
798#[doc = "Field `DAC0` reader - DAC0 wake-up configuration"]
799pub struct DAC0_R(crate::FieldReader<bool, DAC0_A>);
800impl DAC0_R {
801    pub(crate) fn new(bits: bool) -> Self {
802        DAC0_R(crate::FieldReader::new(bits))
803    }
804    #[doc = r"Get enumerated values variant"]
805    #[inline(always)]
806    pub fn variant(&self) -> DAC0_A {
807        match self.bits {
808            false => DAC0_A::DISABLED,
809            true => DAC0_A::ENABLED,
810        }
811    }
812    #[doc = "Checks if the value of the field is `DISABLED`"]
813    #[inline(always)]
814    pub fn is_disabled(&self) -> bool {
815        **self == DAC0_A::DISABLED
816    }
817    #[doc = "Checks if the value of the field is `ENABLED`"]
818    #[inline(always)]
819    pub fn is_enabled(&self) -> bool {
820        **self == DAC0_A::ENABLED
821    }
822}
823impl core::ops::Deref for DAC0_R {
824    type Target = crate::FieldReader<bool, DAC0_A>;
825    #[inline(always)]
826    fn deref(&self) -> &Self::Target {
827        &self.0
828    }
829}
830#[doc = "Field `DAC0` writer - DAC0 wake-up configuration"]
831pub struct DAC0_W<'a> {
832    w: &'a mut W,
833}
834impl<'a> DAC0_W<'a> {
835    #[doc = r"Writes `variant` to the field"]
836    #[inline(always)]
837    pub fn variant(self, variant: DAC0_A) -> &'a mut W {
838        self.bit(variant.into())
839    }
840    #[doc = "Disabled"]
841    #[inline(always)]
842    pub fn disabled(self) -> &'a mut W {
843        self.variant(DAC0_A::DISABLED)
844    }
845    #[doc = "Enabled"]
846    #[inline(always)]
847    pub fn enabled(self) -> &'a mut W {
848        self.variant(DAC0_A::ENABLED)
849    }
850    #[doc = r"Sets the field bit"]
851    #[inline(always)]
852    pub fn set_bit(self) -> &'a mut W {
853        self.bit(true)
854    }
855    #[doc = r"Clears the field bit"]
856    #[inline(always)]
857    pub fn clear_bit(self) -> &'a mut W {
858        self.bit(false)
859    }
860    #[doc = r"Writes raw bits to the field"]
861    #[inline(always)]
862    pub fn bit(self, value: bool) -> &'a mut W {
863        self.w.bits = (self.w.bits & !(0x01 << 13)) | ((value as u32 & 0x01) << 13);
864        self.w
865    }
866}
867#[doc = "DAC1 wake-up configuration\n\nValue on reset: 1"]
868#[derive(Clone, Copy, Debug, PartialEq)]
869pub enum DAC1_A {
870    #[doc = "0: Disabled"]
871    DISABLED = 0,
872    #[doc = "1: Enabled"]
873    ENABLED = 1,
874}
875impl From<DAC1_A> for bool {
876    #[inline(always)]
877    fn from(variant: DAC1_A) -> Self {
878        variant as u8 != 0
879    }
880}
881#[doc = "Field `DAC1` reader - DAC1 wake-up configuration"]
882pub struct DAC1_R(crate::FieldReader<bool, DAC1_A>);
883impl DAC1_R {
884    pub(crate) fn new(bits: bool) -> Self {
885        DAC1_R(crate::FieldReader::new(bits))
886    }
887    #[doc = r"Get enumerated values variant"]
888    #[inline(always)]
889    pub fn variant(&self) -> DAC1_A {
890        match self.bits {
891            false => DAC1_A::DISABLED,
892            true => DAC1_A::ENABLED,
893        }
894    }
895    #[doc = "Checks if the value of the field is `DISABLED`"]
896    #[inline(always)]
897    pub fn is_disabled(&self) -> bool {
898        **self == DAC1_A::DISABLED
899    }
900    #[doc = "Checks if the value of the field is `ENABLED`"]
901    #[inline(always)]
902    pub fn is_enabled(&self) -> bool {
903        **self == DAC1_A::ENABLED
904    }
905}
906impl core::ops::Deref for DAC1_R {
907    type Target = crate::FieldReader<bool, DAC1_A>;
908    #[inline(always)]
909    fn deref(&self) -> &Self::Target {
910        &self.0
911    }
912}
913#[doc = "Field `DAC1` writer - DAC1 wake-up configuration"]
914pub struct DAC1_W<'a> {
915    w: &'a mut W,
916}
917impl<'a> DAC1_W<'a> {
918    #[doc = r"Writes `variant` to the field"]
919    #[inline(always)]
920    pub fn variant(self, variant: DAC1_A) -> &'a mut W {
921        self.bit(variant.into())
922    }
923    #[doc = "Disabled"]
924    #[inline(always)]
925    pub fn disabled(self) -> &'a mut W {
926        self.variant(DAC1_A::DISABLED)
927    }
928    #[doc = "Enabled"]
929    #[inline(always)]
930    pub fn enabled(self) -> &'a mut W {
931        self.variant(DAC1_A::ENABLED)
932    }
933    #[doc = r"Sets the field bit"]
934    #[inline(always)]
935    pub fn set_bit(self) -> &'a mut W {
936        self.bit(true)
937    }
938    #[doc = r"Clears the field bit"]
939    #[inline(always)]
940    pub fn clear_bit(self) -> &'a mut W {
941        self.bit(false)
942    }
943    #[doc = r"Writes raw bits to the field"]
944    #[inline(always)]
945    pub fn bit(self, value: bool) -> &'a mut W {
946        self.w.bits = (self.w.bits & !(0x01 << 14)) | ((value as u32 & 0x01) << 14);
947        self.w
948    }
949}
950#[doc = "Analog comparator wake-up configuration\n\nValue on reset: 1"]
951#[derive(Clone, Copy, Debug, PartialEq)]
952pub enum ACMP_A {
953    #[doc = "0: Disabled"]
954    DISABLED = 0,
955    #[doc = "1: Enabled"]
956    ENABLED = 1,
957}
958impl From<ACMP_A> for bool {
959    #[inline(always)]
960    fn from(variant: ACMP_A) -> Self {
961        variant as u8 != 0
962    }
963}
964#[doc = "Field `ACMP` reader - Analog comparator wake-up configuration"]
965pub struct ACMP_R(crate::FieldReader<bool, ACMP_A>);
966impl ACMP_R {
967    pub(crate) fn new(bits: bool) -> Self {
968        ACMP_R(crate::FieldReader::new(bits))
969    }
970    #[doc = r"Get enumerated values variant"]
971    #[inline(always)]
972    pub fn variant(&self) -> ACMP_A {
973        match self.bits {
974            false => ACMP_A::DISABLED,
975            true => ACMP_A::ENABLED,
976        }
977    }
978    #[doc = "Checks if the value of the field is `DISABLED`"]
979    #[inline(always)]
980    pub fn is_disabled(&self) -> bool {
981        **self == ACMP_A::DISABLED
982    }
983    #[doc = "Checks if the value of the field is `ENABLED`"]
984    #[inline(always)]
985    pub fn is_enabled(&self) -> bool {
986        **self == ACMP_A::ENABLED
987    }
988}
989impl core::ops::Deref for ACMP_R {
990    type Target = crate::FieldReader<bool, ACMP_A>;
991    #[inline(always)]
992    fn deref(&self) -> &Self::Target {
993        &self.0
994    }
995}
996#[doc = "Field `ACMP` writer - Analog comparator wake-up configuration"]
997pub struct ACMP_W<'a> {
998    w: &'a mut W,
999}
1000impl<'a> ACMP_W<'a> {
1001    #[doc = r"Writes `variant` to the field"]
1002    #[inline(always)]
1003    pub fn variant(self, variant: ACMP_A) -> &'a mut W {
1004        self.bit(variant.into())
1005    }
1006    #[doc = "Disabled"]
1007    #[inline(always)]
1008    pub fn disabled(self) -> &'a mut W {
1009        self.variant(ACMP_A::DISABLED)
1010    }
1011    #[doc = "Enabled"]
1012    #[inline(always)]
1013    pub fn enabled(self) -> &'a mut W {
1014        self.variant(ACMP_A::ENABLED)
1015    }
1016    #[doc = r"Sets the field bit"]
1017    #[inline(always)]
1018    pub fn set_bit(self) -> &'a mut W {
1019        self.bit(true)
1020    }
1021    #[doc = r"Clears the field bit"]
1022    #[inline(always)]
1023    pub fn clear_bit(self) -> &'a mut W {
1024        self.bit(false)
1025    }
1026    #[doc = r"Writes raw bits to the field"]
1027    #[inline(always)]
1028    pub fn bit(self, value: bool) -> &'a mut W {
1029        self.w.bits = (self.w.bits & !(0x01 << 15)) | ((value as u32 & 0x01) << 15);
1030        self.w
1031    }
1032}
1033impl R {
1034    #[doc = "Bit 0 - FRO oscillator output wake-up configuration"]
1035    #[inline(always)]
1036    pub fn froout_pd(&self) -> FROOUT_PD_R {
1037        FROOUT_PD_R::new((self.bits & 0x01) != 0)
1038    }
1039    #[doc = "Bit 1 - FRO oscillator power-down wake-up configuration"]
1040    #[inline(always)]
1041    pub fn fro_pd(&self) -> FRO_PD_R {
1042        FRO_PD_R::new(((self.bits >> 1) & 0x01) != 0)
1043    }
1044    #[doc = "Bit 2 - Flash wake-up configuration"]
1045    #[inline(always)]
1046    pub fn flash_pd(&self) -> FLASH_PD_R {
1047        FLASH_PD_R::new(((self.bits >> 2) & 0x01) != 0)
1048    }
1049    #[doc = "Bit 3 - BOD wake-up configuration"]
1050    #[inline(always)]
1051    pub fn bod_pd(&self) -> BOD_PD_R {
1052        BOD_PD_R::new(((self.bits >> 3) & 0x01) != 0)
1053    }
1054    #[doc = "Bit 4 - ADC wake-up configuration"]
1055    #[inline(always)]
1056    pub fn adc_pd(&self) -> ADC_PD_R {
1057        ADC_PD_R::new(((self.bits >> 4) & 0x01) != 0)
1058    }
1059    #[doc = "Bit 5 - Crystal oscillator wake-up configuration"]
1060    #[inline(always)]
1061    pub fn sysosc_pd(&self) -> SYSOSC_PD_R {
1062        SYSOSC_PD_R::new(((self.bits >> 5) & 0x01) != 0)
1063    }
1064    #[doc = "Bit 6 - Watchdog oscillator wake-up configuration. Changing this bit to powered-down has no effect when the LOCK bit in the WWDT MOD register is set. In this case, the watchdog oscillator is always running"]
1065    #[inline(always)]
1066    pub fn wdtosc_pd(&self) -> WDTOSC_PD_R {
1067        WDTOSC_PD_R::new(((self.bits >> 6) & 0x01) != 0)
1068    }
1069    #[doc = "Bit 7 - System PLL wake-up configuration"]
1070    #[inline(always)]
1071    pub fn syspll_pd(&self) -> SYSPLL_PD_R {
1072        SYSPLL_PD_R::new(((self.bits >> 7) & 0x01) != 0)
1073    }
1074    #[doc = "Bit 10 - VREF2 wake-up configuration"]
1075    #[inline(always)]
1076    pub fn vref2_pd(&self) -> VREF2_PD_R {
1077        VREF2_PD_R::new(((self.bits >> 10) & 0x01) != 0)
1078    }
1079    #[doc = "Bit 13 - DAC0 wake-up configuration"]
1080    #[inline(always)]
1081    pub fn dac0(&self) -> DAC0_R {
1082        DAC0_R::new(((self.bits >> 13) & 0x01) != 0)
1083    }
1084    #[doc = "Bit 14 - DAC1 wake-up configuration"]
1085    #[inline(always)]
1086    pub fn dac1(&self) -> DAC1_R {
1087        DAC1_R::new(((self.bits >> 14) & 0x01) != 0)
1088    }
1089    #[doc = "Bit 15 - Analog comparator wake-up configuration"]
1090    #[inline(always)]
1091    pub fn acmp(&self) -> ACMP_R {
1092        ACMP_R::new(((self.bits >> 15) & 0x01) != 0)
1093    }
1094}
1095impl W {
1096    #[doc = "Bit 0 - FRO oscillator output wake-up configuration"]
1097    #[inline(always)]
1098    pub fn froout_pd(&mut self) -> FROOUT_PD_W {
1099        FROOUT_PD_W { w: self }
1100    }
1101    #[doc = "Bit 1 - FRO oscillator power-down wake-up configuration"]
1102    #[inline(always)]
1103    pub fn fro_pd(&mut self) -> FRO_PD_W {
1104        FRO_PD_W { w: self }
1105    }
1106    #[doc = "Bit 2 - Flash wake-up configuration"]
1107    #[inline(always)]
1108    pub fn flash_pd(&mut self) -> FLASH_PD_W {
1109        FLASH_PD_W { w: self }
1110    }
1111    #[doc = "Bit 3 - BOD wake-up configuration"]
1112    #[inline(always)]
1113    pub fn bod_pd(&mut self) -> BOD_PD_W {
1114        BOD_PD_W { w: self }
1115    }
1116    #[doc = "Bit 4 - ADC wake-up configuration"]
1117    #[inline(always)]
1118    pub fn adc_pd(&mut self) -> ADC_PD_W {
1119        ADC_PD_W { w: self }
1120    }
1121    #[doc = "Bit 5 - Crystal oscillator wake-up configuration"]
1122    #[inline(always)]
1123    pub fn sysosc_pd(&mut self) -> SYSOSC_PD_W {
1124        SYSOSC_PD_W { w: self }
1125    }
1126    #[doc = "Bit 6 - Watchdog oscillator wake-up configuration. Changing this bit to powered-down has no effect when the LOCK bit in the WWDT MOD register is set. In this case, the watchdog oscillator is always running"]
1127    #[inline(always)]
1128    pub fn wdtosc_pd(&mut self) -> WDTOSC_PD_W {
1129        WDTOSC_PD_W { w: self }
1130    }
1131    #[doc = "Bit 7 - System PLL wake-up configuration"]
1132    #[inline(always)]
1133    pub fn syspll_pd(&mut self) -> SYSPLL_PD_W {
1134        SYSPLL_PD_W { w: self }
1135    }
1136    #[doc = "Bit 10 - VREF2 wake-up configuration"]
1137    #[inline(always)]
1138    pub fn vref2_pd(&mut self) -> VREF2_PD_W {
1139        VREF2_PD_W { w: self }
1140    }
1141    #[doc = "Bit 13 - DAC0 wake-up configuration"]
1142    #[inline(always)]
1143    pub fn dac0(&mut self) -> DAC0_W {
1144        DAC0_W { w: self }
1145    }
1146    #[doc = "Bit 14 - DAC1 wake-up configuration"]
1147    #[inline(always)]
1148    pub fn dac1(&mut self) -> DAC1_W {
1149        DAC1_W { w: self }
1150    }
1151    #[doc = "Bit 15 - Analog comparator wake-up configuration"]
1152    #[inline(always)]
1153    pub fn acmp(&mut self) -> ACMP_W {
1154        ACMP_W { w: self }
1155    }
1156    #[doc = "Writes raw bits to the register."]
1157    #[inline(always)]
1158    pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
1159        self.0.bits(bits);
1160        self
1161    }
1162}
1163#[doc = "Wake-up configuration register\n\nThis register you can [`read`](crate::generic::Reg::read), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [pdawakecfg](index.html) module"]
1164pub struct PDAWAKECFG_SPEC;
1165impl crate::RegisterSpec for PDAWAKECFG_SPEC {
1166    type Ux = u32;
1167}
1168#[doc = "`read()` method returns [pdawakecfg::R](R) reader structure"]
1169impl crate::Readable for PDAWAKECFG_SPEC {
1170    type Reader = R;
1171}
1172#[doc = "`write(|w| ..)` method takes [pdawakecfg::W](W) writer structure"]
1173impl crate::Writable for PDAWAKECFG_SPEC {
1174    type Writer = W;
1175}
1176#[doc = "`reset()` method sets PDAWAKECFG to value 0xedf8"]
1177impl crate::Resettable for PDAWAKECFG_SPEC {
1178    #[inline(always)]
1179    fn reset_value() -> Self::Ux {
1180        0xedf8
1181    }
1182}