avr_device/devices/atmega4809/adc0/
muxpos.rs1#[doc = "Register `MUXPOS` reader"]
2pub struct R(crate::R<MUXPOS_SPEC>);
3impl core::ops::Deref for R {
4 type Target = crate::R<MUXPOS_SPEC>;
5 #[inline(always)]
6 fn deref(&self) -> &Self::Target {
7 &self.0
8 }
9}
10impl From<crate::R<MUXPOS_SPEC>> for R {
11 #[inline(always)]
12 fn from(reader: crate::R<MUXPOS_SPEC>) -> Self {
13 R(reader)
14 }
15}
16#[doc = "Register `MUXPOS` writer"]
17pub struct W(crate::W<MUXPOS_SPEC>);
18impl core::ops::Deref for W {
19 type Target = crate::W<MUXPOS_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<MUXPOS_SPEC>> for W {
32 #[inline(always)]
33 fn from(writer: crate::W<MUXPOS_SPEC>) -> Self {
34 W(writer)
35 }
36}
37#[doc = "Field `MUXPOS` reader - Analog Channel Selection Bits"]
38pub type MUXPOS_R = crate::FieldReader<u8, MUXPOS_A>;
39#[doc = "Analog Channel Selection Bits\n\nValue on reset: 0"]
40#[derive(Clone, Copy, Debug, PartialEq, Eq)]
41#[repr(u8)]
42pub enum MUXPOS_A {
43 #[doc = "0: ADC input pin 0"]
44 AIN0 = 0,
45 #[doc = "1: ADC input pin 1"]
46 AIN1 = 1,
47 #[doc = "2: ADC input pin 2"]
48 AIN2 = 2,
49 #[doc = "3: ADC input pin 3"]
50 AIN3 = 3,
51 #[doc = "4: ADC input pin 4"]
52 AIN4 = 4,
53 #[doc = "5: ADC input pin 5"]
54 AIN5 = 5,
55 #[doc = "6: ADC input pin 6"]
56 AIN6 = 6,
57 #[doc = "7: ADC input pin 7"]
58 AIN7 = 7,
59 #[doc = "8: ADC input pin 8"]
60 AIN8 = 8,
61 #[doc = "9: ADC input pin 9"]
62 AIN9 = 9,
63 #[doc = "10: ADC input pin 10"]
64 AIN10 = 10,
65 #[doc = "11: ADC input pin 11"]
66 AIN11 = 11,
67 #[doc = "12: ADC input pin 12"]
68 AIN12 = 12,
69 #[doc = "13: ADC input pin 13"]
70 AIN13 = 13,
71 #[doc = "14: ADC input pin 14"]
72 AIN14 = 14,
73 #[doc = "15: ADC input pin 15"]
74 AIN15 = 15,
75 #[doc = "28: AC DAC Reference"]
76 DACREF = 28,
77 #[doc = "30: Temperature sensor"]
78 TEMPSENSE = 30,
79 #[doc = "31: 0V (GND)"]
80 GND = 31,
81}
82impl From<MUXPOS_A> for u8 {
83 #[inline(always)]
84 fn from(variant: MUXPOS_A) -> Self {
85 variant as _
86 }
87}
88impl MUXPOS_R {
89 #[doc = "Get enumerated values variant"]
90 #[inline(always)]
91 pub fn variant(&self) -> Option<MUXPOS_A> {
92 match self.bits {
93 0 => Some(MUXPOS_A::AIN0),
94 1 => Some(MUXPOS_A::AIN1),
95 2 => Some(MUXPOS_A::AIN2),
96 3 => Some(MUXPOS_A::AIN3),
97 4 => Some(MUXPOS_A::AIN4),
98 5 => Some(MUXPOS_A::AIN5),
99 6 => Some(MUXPOS_A::AIN6),
100 7 => Some(MUXPOS_A::AIN7),
101 8 => Some(MUXPOS_A::AIN8),
102 9 => Some(MUXPOS_A::AIN9),
103 10 => Some(MUXPOS_A::AIN10),
104 11 => Some(MUXPOS_A::AIN11),
105 12 => Some(MUXPOS_A::AIN12),
106 13 => Some(MUXPOS_A::AIN13),
107 14 => Some(MUXPOS_A::AIN14),
108 15 => Some(MUXPOS_A::AIN15),
109 28 => Some(MUXPOS_A::DACREF),
110 30 => Some(MUXPOS_A::TEMPSENSE),
111 31 => Some(MUXPOS_A::GND),
112 _ => None,
113 }
114 }
115 #[doc = "Checks if the value of the field is `AIN0`"]
116 #[inline(always)]
117 pub fn is_ain0(&self) -> bool {
118 *self == MUXPOS_A::AIN0
119 }
120 #[doc = "Checks if the value of the field is `AIN1`"]
121 #[inline(always)]
122 pub fn is_ain1(&self) -> bool {
123 *self == MUXPOS_A::AIN1
124 }
125 #[doc = "Checks if the value of the field is `AIN2`"]
126 #[inline(always)]
127 pub fn is_ain2(&self) -> bool {
128 *self == MUXPOS_A::AIN2
129 }
130 #[doc = "Checks if the value of the field is `AIN3`"]
131 #[inline(always)]
132 pub fn is_ain3(&self) -> bool {
133 *self == MUXPOS_A::AIN3
134 }
135 #[doc = "Checks if the value of the field is `AIN4`"]
136 #[inline(always)]
137 pub fn is_ain4(&self) -> bool {
138 *self == MUXPOS_A::AIN4
139 }
140 #[doc = "Checks if the value of the field is `AIN5`"]
141 #[inline(always)]
142 pub fn is_ain5(&self) -> bool {
143 *self == MUXPOS_A::AIN5
144 }
145 #[doc = "Checks if the value of the field is `AIN6`"]
146 #[inline(always)]
147 pub fn is_ain6(&self) -> bool {
148 *self == MUXPOS_A::AIN6
149 }
150 #[doc = "Checks if the value of the field is `AIN7`"]
151 #[inline(always)]
152 pub fn is_ain7(&self) -> bool {
153 *self == MUXPOS_A::AIN7
154 }
155 #[doc = "Checks if the value of the field is `AIN8`"]
156 #[inline(always)]
157 pub fn is_ain8(&self) -> bool {
158 *self == MUXPOS_A::AIN8
159 }
160 #[doc = "Checks if the value of the field is `AIN9`"]
161 #[inline(always)]
162 pub fn is_ain9(&self) -> bool {
163 *self == MUXPOS_A::AIN9
164 }
165 #[doc = "Checks if the value of the field is `AIN10`"]
166 #[inline(always)]
167 pub fn is_ain10(&self) -> bool {
168 *self == MUXPOS_A::AIN10
169 }
170 #[doc = "Checks if the value of the field is `AIN11`"]
171 #[inline(always)]
172 pub fn is_ain11(&self) -> bool {
173 *self == MUXPOS_A::AIN11
174 }
175 #[doc = "Checks if the value of the field is `AIN12`"]
176 #[inline(always)]
177 pub fn is_ain12(&self) -> bool {
178 *self == MUXPOS_A::AIN12
179 }
180 #[doc = "Checks if the value of the field is `AIN13`"]
181 #[inline(always)]
182 pub fn is_ain13(&self) -> bool {
183 *self == MUXPOS_A::AIN13
184 }
185 #[doc = "Checks if the value of the field is `AIN14`"]
186 #[inline(always)]
187 pub fn is_ain14(&self) -> bool {
188 *self == MUXPOS_A::AIN14
189 }
190 #[doc = "Checks if the value of the field is `AIN15`"]
191 #[inline(always)]
192 pub fn is_ain15(&self) -> bool {
193 *self == MUXPOS_A::AIN15
194 }
195 #[doc = "Checks if the value of the field is `DACREF`"]
196 #[inline(always)]
197 pub fn is_dacref(&self) -> bool {
198 *self == MUXPOS_A::DACREF
199 }
200 #[doc = "Checks if the value of the field is `TEMPSENSE`"]
201 #[inline(always)]
202 pub fn is_tempsense(&self) -> bool {
203 *self == MUXPOS_A::TEMPSENSE
204 }
205 #[doc = "Checks if the value of the field is `GND`"]
206 #[inline(always)]
207 pub fn is_gnd(&self) -> bool {
208 *self == MUXPOS_A::GND
209 }
210}
211#[doc = "Field `MUXPOS` writer - Analog Channel Selection Bits"]
212pub type MUXPOS_W<'a, const O: u8> = crate::FieldWriter<'a, u8, MUXPOS_SPEC, u8, MUXPOS_A, 5, O>;
213impl<'a, const O: u8> MUXPOS_W<'a, O> {
214 #[doc = "ADC input pin 0"]
215 #[inline(always)]
216 pub fn ain0(self) -> &'a mut W {
217 self.variant(MUXPOS_A::AIN0)
218 }
219 #[doc = "ADC input pin 1"]
220 #[inline(always)]
221 pub fn ain1(self) -> &'a mut W {
222 self.variant(MUXPOS_A::AIN1)
223 }
224 #[doc = "ADC input pin 2"]
225 #[inline(always)]
226 pub fn ain2(self) -> &'a mut W {
227 self.variant(MUXPOS_A::AIN2)
228 }
229 #[doc = "ADC input pin 3"]
230 #[inline(always)]
231 pub fn ain3(self) -> &'a mut W {
232 self.variant(MUXPOS_A::AIN3)
233 }
234 #[doc = "ADC input pin 4"]
235 #[inline(always)]
236 pub fn ain4(self) -> &'a mut W {
237 self.variant(MUXPOS_A::AIN4)
238 }
239 #[doc = "ADC input pin 5"]
240 #[inline(always)]
241 pub fn ain5(self) -> &'a mut W {
242 self.variant(MUXPOS_A::AIN5)
243 }
244 #[doc = "ADC input pin 6"]
245 #[inline(always)]
246 pub fn ain6(self) -> &'a mut W {
247 self.variant(MUXPOS_A::AIN6)
248 }
249 #[doc = "ADC input pin 7"]
250 #[inline(always)]
251 pub fn ain7(self) -> &'a mut W {
252 self.variant(MUXPOS_A::AIN7)
253 }
254 #[doc = "ADC input pin 8"]
255 #[inline(always)]
256 pub fn ain8(self) -> &'a mut W {
257 self.variant(MUXPOS_A::AIN8)
258 }
259 #[doc = "ADC input pin 9"]
260 #[inline(always)]
261 pub fn ain9(self) -> &'a mut W {
262 self.variant(MUXPOS_A::AIN9)
263 }
264 #[doc = "ADC input pin 10"]
265 #[inline(always)]
266 pub fn ain10(self) -> &'a mut W {
267 self.variant(MUXPOS_A::AIN10)
268 }
269 #[doc = "ADC input pin 11"]
270 #[inline(always)]
271 pub fn ain11(self) -> &'a mut W {
272 self.variant(MUXPOS_A::AIN11)
273 }
274 #[doc = "ADC input pin 12"]
275 #[inline(always)]
276 pub fn ain12(self) -> &'a mut W {
277 self.variant(MUXPOS_A::AIN12)
278 }
279 #[doc = "ADC input pin 13"]
280 #[inline(always)]
281 pub fn ain13(self) -> &'a mut W {
282 self.variant(MUXPOS_A::AIN13)
283 }
284 #[doc = "ADC input pin 14"]
285 #[inline(always)]
286 pub fn ain14(self) -> &'a mut W {
287 self.variant(MUXPOS_A::AIN14)
288 }
289 #[doc = "ADC input pin 15"]
290 #[inline(always)]
291 pub fn ain15(self) -> &'a mut W {
292 self.variant(MUXPOS_A::AIN15)
293 }
294 #[doc = "AC DAC Reference"]
295 #[inline(always)]
296 pub fn dacref(self) -> &'a mut W {
297 self.variant(MUXPOS_A::DACREF)
298 }
299 #[doc = "Temperature sensor"]
300 #[inline(always)]
301 pub fn tempsense(self) -> &'a mut W {
302 self.variant(MUXPOS_A::TEMPSENSE)
303 }
304 #[doc = "0V (GND)"]
305 #[inline(always)]
306 pub fn gnd(self) -> &'a mut W {
307 self.variant(MUXPOS_A::GND)
308 }
309}
310impl R {
311 #[doc = "Bits 0:4 - Analog Channel Selection Bits"]
312 #[inline(always)]
313 pub fn muxpos(&self) -> MUXPOS_R {
314 MUXPOS_R::new(self.bits & 0x1f)
315 }
316}
317impl W {
318 #[doc = "Bits 0:4 - Analog Channel Selection Bits"]
319 #[inline(always)]
320 #[must_use]
321 pub fn muxpos(&mut self) -> MUXPOS_W<0> {
322 MUXPOS_W::new(self)
323 }
324 #[doc = "Writes raw bits to the register."]
325 #[inline(always)]
326 pub unsafe fn bits(&mut self, bits: u8) -> &mut Self {
327 self.0.bits(bits);
328 self
329 }
330}
331#[doc = "Positive mux input\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 [muxpos](index.html) module"]
332pub struct MUXPOS_SPEC;
333impl crate::RegisterSpec for MUXPOS_SPEC {
334 type Ux = u8;
335}
336#[doc = "`read()` method returns [muxpos::R](R) reader structure"]
337impl crate::Readable for MUXPOS_SPEC {
338 type Reader = R;
339}
340#[doc = "`write(|w| ..)` method takes [muxpos::W](W) writer structure"]
341impl crate::Writable for MUXPOS_SPEC {
342 type Writer = W;
343 const ZERO_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0;
344 const ONE_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0;
345}
346#[doc = "`reset()` method sets MUXPOS to value 0"]
347impl crate::Resettable for MUXPOS_SPEC {
348 const RESET_VALUE: Self::Ux = 0;
349}