avr_device/devices/atmega4809/adc0/
muxpos.rs

1#[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}