nrf52840_pac/uart0/
baudrate.rs

1#[doc = "Register `BAUDRATE` reader"]
2pub struct R(crate::R<BAUDRATE_SPEC>);
3impl core::ops::Deref for R {
4    type Target = crate::R<BAUDRATE_SPEC>;
5    #[inline(always)]
6    fn deref(&self) -> &Self::Target {
7        &self.0
8    }
9}
10impl From<crate::R<BAUDRATE_SPEC>> for R {
11    #[inline(always)]
12    fn from(reader: crate::R<BAUDRATE_SPEC>) -> Self {
13        R(reader)
14    }
15}
16#[doc = "Register `BAUDRATE` writer"]
17pub struct W(crate::W<BAUDRATE_SPEC>);
18impl core::ops::Deref for W {
19    type Target = crate::W<BAUDRATE_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<BAUDRATE_SPEC>> for W {
32    #[inline(always)]
33    fn from(writer: crate::W<BAUDRATE_SPEC>) -> Self {
34        W(writer)
35    }
36}
37#[doc = "Field `BAUDRATE` reader - Baud rate"]
38pub type BAUDRATE_R = crate::FieldReader<u32, BAUDRATE_A>;
39#[doc = "Baud rate\n\nValue on reset: 67108864"]
40#[derive(Clone, Copy, Debug, PartialEq)]
41#[repr(u32)]
42pub enum BAUDRATE_A {
43    #[doc = "323584: 1200 baud (actual rate: 1205)"]
44    BAUD1200 = 323584,
45    #[doc = "643072: 2400 baud (actual rate: 2396)"]
46    BAUD2400 = 643072,
47    #[doc = "1290240: 4800 baud (actual rate: 4808)"]
48    BAUD4800 = 1290240,
49    #[doc = "2576384: 9600 baud (actual rate: 9598)"]
50    BAUD9600 = 2576384,
51    #[doc = "3866624: 14400 baud (actual rate: 14414)"]
52    BAUD14400 = 3866624,
53    #[doc = "5152768: 19200 baud (actual rate: 19208)"]
54    BAUD19200 = 5152768,
55    #[doc = "7729152: 28800 baud (actual rate: 28829)"]
56    BAUD28800 = 7729152,
57    #[doc = "8388608: 31250 baud"]
58    BAUD31250 = 8388608,
59    #[doc = "10309632: 38400 baud (actual rate: 38462)"]
60    BAUD38400 = 10309632,
61    #[doc = "15007744: 56000 baud (actual rate: 55944)"]
62    BAUD56000 = 15007744,
63    #[doc = "15462400: 57600 baud (actual rate: 57762)"]
64    BAUD57600 = 15462400,
65    #[doc = "20615168: 76800 baud (actual rate: 76923)"]
66    BAUD76800 = 20615168,
67    #[doc = "30924800: 115200 baud (actual rate: 115942)"]
68    BAUD115200 = 30924800,
69    #[doc = "61845504: 230400 baud (actual rate: 231884)"]
70    BAUD230400 = 61845504,
71    #[doc = "67108864: 250000 baud"]
72    BAUD250000 = 67108864,
73    #[doc = "123695104: 460800 baud (actual rate: 470588)"]
74    BAUD460800 = 123695104,
75    #[doc = "247386112: 921600 baud (actual rate: 941176)"]
76    BAUD921600 = 247386112,
77    #[doc = "268435456: 1Mega baud"]
78    BAUD1M = 268435456,
79}
80impl From<BAUDRATE_A> for u32 {
81    #[inline(always)]
82    fn from(variant: BAUDRATE_A) -> Self {
83        variant as _
84    }
85}
86impl BAUDRATE_R {
87    #[doc = "Get enumerated values variant"]
88    #[inline(always)]
89    pub fn variant(&self) -> Option<BAUDRATE_A> {
90        match self.bits {
91            323584 => Some(BAUDRATE_A::BAUD1200),
92            643072 => Some(BAUDRATE_A::BAUD2400),
93            1290240 => Some(BAUDRATE_A::BAUD4800),
94            2576384 => Some(BAUDRATE_A::BAUD9600),
95            3866624 => Some(BAUDRATE_A::BAUD14400),
96            5152768 => Some(BAUDRATE_A::BAUD19200),
97            7729152 => Some(BAUDRATE_A::BAUD28800),
98            8388608 => Some(BAUDRATE_A::BAUD31250),
99            10309632 => Some(BAUDRATE_A::BAUD38400),
100            15007744 => Some(BAUDRATE_A::BAUD56000),
101            15462400 => Some(BAUDRATE_A::BAUD57600),
102            20615168 => Some(BAUDRATE_A::BAUD76800),
103            30924800 => Some(BAUDRATE_A::BAUD115200),
104            61845504 => Some(BAUDRATE_A::BAUD230400),
105            67108864 => Some(BAUDRATE_A::BAUD250000),
106            123695104 => Some(BAUDRATE_A::BAUD460800),
107            247386112 => Some(BAUDRATE_A::BAUD921600),
108            268435456 => Some(BAUDRATE_A::BAUD1M),
109            _ => None,
110        }
111    }
112    #[doc = "Checks if the value of the field is `BAUD1200`"]
113    #[inline(always)]
114    pub fn is_baud1200(&self) -> bool {
115        *self == BAUDRATE_A::BAUD1200
116    }
117    #[doc = "Checks if the value of the field is `BAUD2400`"]
118    #[inline(always)]
119    pub fn is_baud2400(&self) -> bool {
120        *self == BAUDRATE_A::BAUD2400
121    }
122    #[doc = "Checks if the value of the field is `BAUD4800`"]
123    #[inline(always)]
124    pub fn is_baud4800(&self) -> bool {
125        *self == BAUDRATE_A::BAUD4800
126    }
127    #[doc = "Checks if the value of the field is `BAUD9600`"]
128    #[inline(always)]
129    pub fn is_baud9600(&self) -> bool {
130        *self == BAUDRATE_A::BAUD9600
131    }
132    #[doc = "Checks if the value of the field is `BAUD14400`"]
133    #[inline(always)]
134    pub fn is_baud14400(&self) -> bool {
135        *self == BAUDRATE_A::BAUD14400
136    }
137    #[doc = "Checks if the value of the field is `BAUD19200`"]
138    #[inline(always)]
139    pub fn is_baud19200(&self) -> bool {
140        *self == BAUDRATE_A::BAUD19200
141    }
142    #[doc = "Checks if the value of the field is `BAUD28800`"]
143    #[inline(always)]
144    pub fn is_baud28800(&self) -> bool {
145        *self == BAUDRATE_A::BAUD28800
146    }
147    #[doc = "Checks if the value of the field is `BAUD31250`"]
148    #[inline(always)]
149    pub fn is_baud31250(&self) -> bool {
150        *self == BAUDRATE_A::BAUD31250
151    }
152    #[doc = "Checks if the value of the field is `BAUD38400`"]
153    #[inline(always)]
154    pub fn is_baud38400(&self) -> bool {
155        *self == BAUDRATE_A::BAUD38400
156    }
157    #[doc = "Checks if the value of the field is `BAUD56000`"]
158    #[inline(always)]
159    pub fn is_baud56000(&self) -> bool {
160        *self == BAUDRATE_A::BAUD56000
161    }
162    #[doc = "Checks if the value of the field is `BAUD57600`"]
163    #[inline(always)]
164    pub fn is_baud57600(&self) -> bool {
165        *self == BAUDRATE_A::BAUD57600
166    }
167    #[doc = "Checks if the value of the field is `BAUD76800`"]
168    #[inline(always)]
169    pub fn is_baud76800(&self) -> bool {
170        *self == BAUDRATE_A::BAUD76800
171    }
172    #[doc = "Checks if the value of the field is `BAUD115200`"]
173    #[inline(always)]
174    pub fn is_baud115200(&self) -> bool {
175        *self == BAUDRATE_A::BAUD115200
176    }
177    #[doc = "Checks if the value of the field is `BAUD230400`"]
178    #[inline(always)]
179    pub fn is_baud230400(&self) -> bool {
180        *self == BAUDRATE_A::BAUD230400
181    }
182    #[doc = "Checks if the value of the field is `BAUD250000`"]
183    #[inline(always)]
184    pub fn is_baud250000(&self) -> bool {
185        *self == BAUDRATE_A::BAUD250000
186    }
187    #[doc = "Checks if the value of the field is `BAUD460800`"]
188    #[inline(always)]
189    pub fn is_baud460800(&self) -> bool {
190        *self == BAUDRATE_A::BAUD460800
191    }
192    #[doc = "Checks if the value of the field is `BAUD921600`"]
193    #[inline(always)]
194    pub fn is_baud921600(&self) -> bool {
195        *self == BAUDRATE_A::BAUD921600
196    }
197    #[doc = "Checks if the value of the field is `BAUD1M`"]
198    #[inline(always)]
199    pub fn is_baud1m(&self) -> bool {
200        *self == BAUDRATE_A::BAUD1M
201    }
202}
203#[doc = "Field `BAUDRATE` writer - Baud rate"]
204pub type BAUDRATE_W<'a, const O: u8> =
205    crate::FieldWriter<'a, u32, BAUDRATE_SPEC, u32, BAUDRATE_A, 32, O>;
206impl<'a, const O: u8> BAUDRATE_W<'a, O> {
207    #[doc = "1200 baud (actual rate: 1205)"]
208    #[inline(always)]
209    pub fn baud1200(self) -> &'a mut W {
210        self.variant(BAUDRATE_A::BAUD1200)
211    }
212    #[doc = "2400 baud (actual rate: 2396)"]
213    #[inline(always)]
214    pub fn baud2400(self) -> &'a mut W {
215        self.variant(BAUDRATE_A::BAUD2400)
216    }
217    #[doc = "4800 baud (actual rate: 4808)"]
218    #[inline(always)]
219    pub fn baud4800(self) -> &'a mut W {
220        self.variant(BAUDRATE_A::BAUD4800)
221    }
222    #[doc = "9600 baud (actual rate: 9598)"]
223    #[inline(always)]
224    pub fn baud9600(self) -> &'a mut W {
225        self.variant(BAUDRATE_A::BAUD9600)
226    }
227    #[doc = "14400 baud (actual rate: 14414)"]
228    #[inline(always)]
229    pub fn baud14400(self) -> &'a mut W {
230        self.variant(BAUDRATE_A::BAUD14400)
231    }
232    #[doc = "19200 baud (actual rate: 19208)"]
233    #[inline(always)]
234    pub fn baud19200(self) -> &'a mut W {
235        self.variant(BAUDRATE_A::BAUD19200)
236    }
237    #[doc = "28800 baud (actual rate: 28829)"]
238    #[inline(always)]
239    pub fn baud28800(self) -> &'a mut W {
240        self.variant(BAUDRATE_A::BAUD28800)
241    }
242    #[doc = "31250 baud"]
243    #[inline(always)]
244    pub fn baud31250(self) -> &'a mut W {
245        self.variant(BAUDRATE_A::BAUD31250)
246    }
247    #[doc = "38400 baud (actual rate: 38462)"]
248    #[inline(always)]
249    pub fn baud38400(self) -> &'a mut W {
250        self.variant(BAUDRATE_A::BAUD38400)
251    }
252    #[doc = "56000 baud (actual rate: 55944)"]
253    #[inline(always)]
254    pub fn baud56000(self) -> &'a mut W {
255        self.variant(BAUDRATE_A::BAUD56000)
256    }
257    #[doc = "57600 baud (actual rate: 57762)"]
258    #[inline(always)]
259    pub fn baud57600(self) -> &'a mut W {
260        self.variant(BAUDRATE_A::BAUD57600)
261    }
262    #[doc = "76800 baud (actual rate: 76923)"]
263    #[inline(always)]
264    pub fn baud76800(self) -> &'a mut W {
265        self.variant(BAUDRATE_A::BAUD76800)
266    }
267    #[doc = "115200 baud (actual rate: 115942)"]
268    #[inline(always)]
269    pub fn baud115200(self) -> &'a mut W {
270        self.variant(BAUDRATE_A::BAUD115200)
271    }
272    #[doc = "230400 baud (actual rate: 231884)"]
273    #[inline(always)]
274    pub fn baud230400(self) -> &'a mut W {
275        self.variant(BAUDRATE_A::BAUD230400)
276    }
277    #[doc = "250000 baud"]
278    #[inline(always)]
279    pub fn baud250000(self) -> &'a mut W {
280        self.variant(BAUDRATE_A::BAUD250000)
281    }
282    #[doc = "460800 baud (actual rate: 470588)"]
283    #[inline(always)]
284    pub fn baud460800(self) -> &'a mut W {
285        self.variant(BAUDRATE_A::BAUD460800)
286    }
287    #[doc = "921600 baud (actual rate: 941176)"]
288    #[inline(always)]
289    pub fn baud921600(self) -> &'a mut W {
290        self.variant(BAUDRATE_A::BAUD921600)
291    }
292    #[doc = "1Mega baud"]
293    #[inline(always)]
294    pub fn baud1m(self) -> &'a mut W {
295        self.variant(BAUDRATE_A::BAUD1M)
296    }
297}
298impl R {
299    #[doc = "Bits 0:31 - Baud rate"]
300    #[inline(always)]
301    pub fn baudrate(&self) -> BAUDRATE_R {
302        BAUDRATE_R::new(self.bits)
303    }
304}
305impl W {
306    #[doc = "Bits 0:31 - Baud rate"]
307    #[inline(always)]
308    pub fn baudrate(&mut self) -> BAUDRATE_W<0> {
309        BAUDRATE_W::new(self)
310    }
311    #[doc = "Writes raw bits to the register."]
312    #[inline(always)]
313    pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
314        self.0.bits(bits);
315        self
316    }
317}
318#[doc = "Baud rate. Accuracy depends on the HFCLK source selected.\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 [baudrate](index.html) module"]
319pub struct BAUDRATE_SPEC;
320impl crate::RegisterSpec for BAUDRATE_SPEC {
321    type Ux = u32;
322}
323#[doc = "`read()` method returns [baudrate::R](R) reader structure"]
324impl crate::Readable for BAUDRATE_SPEC {
325    type Reader = R;
326}
327#[doc = "`write(|w| ..)` method takes [baudrate::W](W) writer structure"]
328impl crate::Writable for BAUDRATE_SPEC {
329    type Writer = W;
330}
331#[doc = "`reset()` method sets BAUDRATE to value 0x0400_0000"]
332impl crate::Resettable for BAUDRATE_SPEC {
333    #[inline(always)]
334    fn reset_value() -> Self::Ux {
335        0x0400_0000
336    }
337}