nrf52840_pac/uarte0/
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 = "3862528: 14400 baud (actual rate: 14401)"]
52 BAUD14400 = 3862528,
53 #[doc = "5152768: 19200 baud (actual rate: 19208)"]
54 BAUD19200 = 5152768,
55 #[doc = "7716864: 28800 baud (actual rate: 28777)"]
56 BAUD28800 = 7716864,
57 #[doc = "8388608: 31250 baud"]
58 BAUD31250 = 8388608,
59 #[doc = "10289152: 38400 baud (actual rate: 38369)"]
60 BAUD38400 = 10289152,
61 #[doc = "15007744: 56000 baud (actual rate: 55944)"]
62 BAUD56000 = 15007744,
63 #[doc = "15400960: 57600 baud (actual rate: 57554)"]
64 BAUD57600 = 15400960,
65 #[doc = "20615168: 76800 baud (actual rate: 76923)"]
66 BAUD76800 = 20615168,
67 #[doc = "30801920: 115200 baud (actual rate: 115108)"]
68 BAUD115200 = 30801920,
69 #[doc = "61865984: 230400 baud (actual rate: 231884)"]
70 BAUD230400 = 61865984,
71 #[doc = "67108864: 250000 baud"]
72 BAUD250000 = 67108864,
73 #[doc = "121634816: 460800 baud (actual rate: 457143)"]
74 BAUD460800 = 121634816,
75 #[doc = "251658240: 921600 baud (actual rate: 941176)"]
76 BAUD921600 = 251658240,
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 3862528 => Some(BAUDRATE_A::BAUD14400),
96 5152768 => Some(BAUDRATE_A::BAUD19200),
97 7716864 => Some(BAUDRATE_A::BAUD28800),
98 8388608 => Some(BAUDRATE_A::BAUD31250),
99 10289152 => Some(BAUDRATE_A::BAUD38400),
100 15007744 => Some(BAUDRATE_A::BAUD56000),
101 15400960 => Some(BAUDRATE_A::BAUD57600),
102 20615168 => Some(BAUDRATE_A::BAUD76800),
103 30801920 => Some(BAUDRATE_A::BAUD115200),
104 61865984 => Some(BAUDRATE_A::BAUD230400),
105 67108864 => Some(BAUDRATE_A::BAUD250000),
106 121634816 => Some(BAUDRATE_A::BAUD460800),
107 251658240 => 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: 14401)"]
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: 28777)"]
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: 38369)"]
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: 57554)"]
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: 115108)"]
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: 457143)"]
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}