atsamd51n/pdec/
prescbuf.rs1#[doc = "Register `PRESCBUF` reader"]
2pub type R = crate::R<PrescbufSpec>;
3#[doc = "Register `PRESCBUF` writer"]
4pub type W = crate::W<PrescbufSpec>;
5#[doc = "Prescaler Buffer Value\n\nValue on reset: 0"]
6#[derive(Clone, Copy, Debug, PartialEq, Eq)]
7#[repr(u8)]
8pub enum Prescbufselect {
9 #[doc = "0: No division"]
10 Div1 = 0,
11 #[doc = "1: Divide by 2"]
12 Div2 = 1,
13 #[doc = "2: Divide by 4"]
14 Div4 = 2,
15 #[doc = "3: Divide by 8"]
16 Div8 = 3,
17 #[doc = "4: Divide by 16"]
18 Div16 = 4,
19 #[doc = "5: Divide by 32"]
20 Div32 = 5,
21 #[doc = "6: Divide by 64"]
22 Div64 = 6,
23 #[doc = "7: Divide by 128"]
24 Div128 = 7,
25 #[doc = "8: Divide by 256"]
26 Div256 = 8,
27 #[doc = "9: Divide by 512"]
28 Div512 = 9,
29 #[doc = "10: Divide by 1024"]
30 Div1024 = 10,
31}
32impl From<Prescbufselect> for u8 {
33 #[inline(always)]
34 fn from(variant: Prescbufselect) -> Self {
35 variant as _
36 }
37}
38impl crate::FieldSpec for Prescbufselect {
39 type Ux = u8;
40}
41impl crate::IsEnum for Prescbufselect {}
42#[doc = "Field `PRESCBUF` reader - Prescaler Buffer Value"]
43pub type PrescbufR = crate::FieldReader<Prescbufselect>;
44impl PrescbufR {
45 #[doc = "Get enumerated values variant"]
46 #[inline(always)]
47 pub const fn variant(&self) -> Option<Prescbufselect> {
48 match self.bits {
49 0 => Some(Prescbufselect::Div1),
50 1 => Some(Prescbufselect::Div2),
51 2 => Some(Prescbufselect::Div4),
52 3 => Some(Prescbufselect::Div8),
53 4 => Some(Prescbufselect::Div16),
54 5 => Some(Prescbufselect::Div32),
55 6 => Some(Prescbufselect::Div64),
56 7 => Some(Prescbufselect::Div128),
57 8 => Some(Prescbufselect::Div256),
58 9 => Some(Prescbufselect::Div512),
59 10 => Some(Prescbufselect::Div1024),
60 _ => None,
61 }
62 }
63 #[doc = "No division"]
64 #[inline(always)]
65 pub fn is_div1(&self) -> bool {
66 *self == Prescbufselect::Div1
67 }
68 #[doc = "Divide by 2"]
69 #[inline(always)]
70 pub fn is_div2(&self) -> bool {
71 *self == Prescbufselect::Div2
72 }
73 #[doc = "Divide by 4"]
74 #[inline(always)]
75 pub fn is_div4(&self) -> bool {
76 *self == Prescbufselect::Div4
77 }
78 #[doc = "Divide by 8"]
79 #[inline(always)]
80 pub fn is_div8(&self) -> bool {
81 *self == Prescbufselect::Div8
82 }
83 #[doc = "Divide by 16"]
84 #[inline(always)]
85 pub fn is_div16(&self) -> bool {
86 *self == Prescbufselect::Div16
87 }
88 #[doc = "Divide by 32"]
89 #[inline(always)]
90 pub fn is_div32(&self) -> bool {
91 *self == Prescbufselect::Div32
92 }
93 #[doc = "Divide by 64"]
94 #[inline(always)]
95 pub fn is_div64(&self) -> bool {
96 *self == Prescbufselect::Div64
97 }
98 #[doc = "Divide by 128"]
99 #[inline(always)]
100 pub fn is_div128(&self) -> bool {
101 *self == Prescbufselect::Div128
102 }
103 #[doc = "Divide by 256"]
104 #[inline(always)]
105 pub fn is_div256(&self) -> bool {
106 *self == Prescbufselect::Div256
107 }
108 #[doc = "Divide by 512"]
109 #[inline(always)]
110 pub fn is_div512(&self) -> bool {
111 *self == Prescbufselect::Div512
112 }
113 #[doc = "Divide by 1024"]
114 #[inline(always)]
115 pub fn is_div1024(&self) -> bool {
116 *self == Prescbufselect::Div1024
117 }
118}
119#[doc = "Field `PRESCBUF` writer - Prescaler Buffer Value"]
120pub type PrescbufW<'a, REG> = crate::FieldWriter<'a, REG, 4, Prescbufselect>;
121impl<'a, REG> PrescbufW<'a, REG>
122where
123 REG: crate::Writable + crate::RegisterSpec,
124 REG::Ux: From<u8>,
125{
126 #[doc = "No division"]
127 #[inline(always)]
128 pub fn div1(self) -> &'a mut crate::W<REG> {
129 self.variant(Prescbufselect::Div1)
130 }
131 #[doc = "Divide by 2"]
132 #[inline(always)]
133 pub fn div2(self) -> &'a mut crate::W<REG> {
134 self.variant(Prescbufselect::Div2)
135 }
136 #[doc = "Divide by 4"]
137 #[inline(always)]
138 pub fn div4(self) -> &'a mut crate::W<REG> {
139 self.variant(Prescbufselect::Div4)
140 }
141 #[doc = "Divide by 8"]
142 #[inline(always)]
143 pub fn div8(self) -> &'a mut crate::W<REG> {
144 self.variant(Prescbufselect::Div8)
145 }
146 #[doc = "Divide by 16"]
147 #[inline(always)]
148 pub fn div16(self) -> &'a mut crate::W<REG> {
149 self.variant(Prescbufselect::Div16)
150 }
151 #[doc = "Divide by 32"]
152 #[inline(always)]
153 pub fn div32(self) -> &'a mut crate::W<REG> {
154 self.variant(Prescbufselect::Div32)
155 }
156 #[doc = "Divide by 64"]
157 #[inline(always)]
158 pub fn div64(self) -> &'a mut crate::W<REG> {
159 self.variant(Prescbufselect::Div64)
160 }
161 #[doc = "Divide by 128"]
162 #[inline(always)]
163 pub fn div128(self) -> &'a mut crate::W<REG> {
164 self.variant(Prescbufselect::Div128)
165 }
166 #[doc = "Divide by 256"]
167 #[inline(always)]
168 pub fn div256(self) -> &'a mut crate::W<REG> {
169 self.variant(Prescbufselect::Div256)
170 }
171 #[doc = "Divide by 512"]
172 #[inline(always)]
173 pub fn div512(self) -> &'a mut crate::W<REG> {
174 self.variant(Prescbufselect::Div512)
175 }
176 #[doc = "Divide by 1024"]
177 #[inline(always)]
178 pub fn div1024(self) -> &'a mut crate::W<REG> {
179 self.variant(Prescbufselect::Div1024)
180 }
181}
182impl R {
183 #[doc = "Bits 0:3 - Prescaler Buffer Value"]
184 #[inline(always)]
185 pub fn prescbuf(&self) -> PrescbufR {
186 PrescbufR::new(self.bits & 0x0f)
187 }
188}
189impl W {
190 #[doc = "Bits 0:3 - Prescaler Buffer Value"]
191 #[inline(always)]
192 #[must_use]
193 pub fn prescbuf(&mut self) -> PrescbufW<PrescbufSpec> {
194 PrescbufW::new(self, 0)
195 }
196}
197#[doc = "Prescaler Buffer Value\n\nYou can [`read`](crate::Reg::read) this register and get [`prescbuf::R`](R). You can [`reset`](crate::Reg::reset), [`write`](crate::Reg::write), [`write_with_zero`](crate::Reg::write_with_zero) this register using [`prescbuf::W`](W). You can also [`modify`](crate::Reg::modify) this register. See [API](https://docs.rs/svd2rust/#read--modify--write-api)."]
198pub struct PrescbufSpec;
199impl crate::RegisterSpec for PrescbufSpec {
200 type Ux = u8;
201}
202#[doc = "`read()` method returns [`prescbuf::R`](R) reader structure"]
203impl crate::Readable for PrescbufSpec {}
204#[doc = "`write(|w| ..)` method takes [`prescbuf::W`](W) writer structure"]
205impl crate::Writable for PrescbufSpec {
206 type Safety = crate::Unsafe;
207 const ZERO_TO_MODIFY_FIELDS_BITMAP: u8 = 0;
208 const ONE_TO_MODIFY_FIELDS_BITMAP: u8 = 0;
209}
210#[doc = "`reset()` method sets PRESCBUF to value 0"]
211impl crate::Resettable for PrescbufSpec {
212 const RESET_VALUE: u8 = 0;
213}