efm32pg12_pac/cmu/
routeloc1.rs

1#[doc = "Reader of register ROUTELOC1"]
2pub type R = crate::R<u32, super::ROUTELOC1>;
3#[doc = "Writer for register ROUTELOC1"]
4pub type W = crate::W<u32, super::ROUTELOC1>;
5#[doc = "Register ROUTELOC1 `reset()`'s with value 0"]
6impl crate::ResetValue for super::ROUTELOC1 {
7    type Type = u32;
8    #[inline(always)]
9    fn reset_value() -> Self::Type {
10        0
11    }
12}
13#[doc = "I/O Location\n\nValue on reset: 0"]
14#[derive(Clone, Copy, Debug, PartialEq)]
15#[repr(u8)]
16pub enum CLKIN0LOC_A {
17    #[doc = "0: Location 0"]
18    LOC0 = 0,
19    #[doc = "1: Location 1"]
20    LOC1 = 1,
21    #[doc = "2: Location 2"]
22    LOC2 = 2,
23    #[doc = "3: Location 3"]
24    LOC3 = 3,
25    #[doc = "4: Location 4"]
26    LOC4 = 4,
27}
28impl From<CLKIN0LOC_A> for u8 {
29    #[inline(always)]
30    fn from(variant: CLKIN0LOC_A) -> Self {
31        variant as _
32    }
33}
34#[doc = "Reader of field `CLKIN0LOC`"]
35pub type CLKIN0LOC_R = crate::R<u8, CLKIN0LOC_A>;
36impl CLKIN0LOC_R {
37    #[doc = r"Get enumerated values variant"]
38    #[inline(always)]
39    pub fn variant(&self) -> crate::Variant<u8, CLKIN0LOC_A> {
40        use crate::Variant::*;
41        match self.bits {
42            0 => Val(CLKIN0LOC_A::LOC0),
43            1 => Val(CLKIN0LOC_A::LOC1),
44            2 => Val(CLKIN0LOC_A::LOC2),
45            3 => Val(CLKIN0LOC_A::LOC3),
46            4 => Val(CLKIN0LOC_A::LOC4),
47            i => Res(i),
48        }
49    }
50    #[doc = "Checks if the value of the field is `LOC0`"]
51    #[inline(always)]
52    pub fn is_loc0(&self) -> bool {
53        *self == CLKIN0LOC_A::LOC0
54    }
55    #[doc = "Checks if the value of the field is `LOC1`"]
56    #[inline(always)]
57    pub fn is_loc1(&self) -> bool {
58        *self == CLKIN0LOC_A::LOC1
59    }
60    #[doc = "Checks if the value of the field is `LOC2`"]
61    #[inline(always)]
62    pub fn is_loc2(&self) -> bool {
63        *self == CLKIN0LOC_A::LOC2
64    }
65    #[doc = "Checks if the value of the field is `LOC3`"]
66    #[inline(always)]
67    pub fn is_loc3(&self) -> bool {
68        *self == CLKIN0LOC_A::LOC3
69    }
70    #[doc = "Checks if the value of the field is `LOC4`"]
71    #[inline(always)]
72    pub fn is_loc4(&self) -> bool {
73        *self == CLKIN0LOC_A::LOC4
74    }
75}
76#[doc = "Write proxy for field `CLKIN0LOC`"]
77pub struct CLKIN0LOC_W<'a> {
78    w: &'a mut W,
79}
80impl<'a> CLKIN0LOC_W<'a> {
81    #[doc = r"Writes `variant` to the field"]
82    #[inline(always)]
83    pub fn variant(self, variant: CLKIN0LOC_A) -> &'a mut W {
84        unsafe { self.bits(variant.into()) }
85    }
86    #[doc = "Location 0"]
87    #[inline(always)]
88    pub fn loc0(self) -> &'a mut W {
89        self.variant(CLKIN0LOC_A::LOC0)
90    }
91    #[doc = "Location 1"]
92    #[inline(always)]
93    pub fn loc1(self) -> &'a mut W {
94        self.variant(CLKIN0LOC_A::LOC1)
95    }
96    #[doc = "Location 2"]
97    #[inline(always)]
98    pub fn loc2(self) -> &'a mut W {
99        self.variant(CLKIN0LOC_A::LOC2)
100    }
101    #[doc = "Location 3"]
102    #[inline(always)]
103    pub fn loc3(self) -> &'a mut W {
104        self.variant(CLKIN0LOC_A::LOC3)
105    }
106    #[doc = "Location 4"]
107    #[inline(always)]
108    pub fn loc4(self) -> &'a mut W {
109        self.variant(CLKIN0LOC_A::LOC4)
110    }
111    #[doc = r"Writes raw bits to the field"]
112    #[inline(always)]
113    pub unsafe fn bits(self, value: u8) -> &'a mut W {
114        self.w.bits = (self.w.bits & !0x3f) | ((value as u32) & 0x3f);
115        self.w
116    }
117}
118impl R {
119    #[doc = "Bits 0:5 - I/O Location"]
120    #[inline(always)]
121    pub fn clkin0loc(&self) -> CLKIN0LOC_R {
122        CLKIN0LOC_R::new((self.bits & 0x3f) as u8)
123    }
124}
125impl W {
126    #[doc = "Bits 0:5 - I/O Location"]
127    #[inline(always)]
128    pub fn clkin0loc(&mut self) -> CLKIN0LOC_W {
129        CLKIN0LOC_W { w: self }
130    }
131}