efm32pg12_pac/smu/
ppupatd1.rs1#[doc = "Reader of register PPUPATD1"]
2pub type R = crate::R<u32, super::PPUPATD1>;
3#[doc = "Writer for register PPUPATD1"]
4pub type W = crate::W<u32, super::PPUPATD1>;
5#[doc = "Register PPUPATD1 `reset()`'s with value 0"]
6impl crate::ResetValue for super::PPUPATD1 {
7 type Type = u32;
8 #[inline(always)]
9 fn reset_value() -> Self::Type {
10 0
11 }
12}
13#[doc = "Reader of field `RMU`"]
14pub type RMU_R = crate::R<bool, bool>;
15#[doc = "Write proxy for field `RMU`"]
16pub struct RMU_W<'a> {
17 w: &'a mut W,
18}
19impl<'a> RMU_W<'a> {
20 #[doc = r"Sets the field bit"]
21 #[inline(always)]
22 pub fn set_bit(self) -> &'a mut W {
23 self.bit(true)
24 }
25 #[doc = r"Clears the field bit"]
26 #[inline(always)]
27 pub fn clear_bit(self) -> &'a mut W {
28 self.bit(false)
29 }
30 #[doc = r"Writes raw bits to the field"]
31 #[inline(always)]
32 pub fn bit(self, value: bool) -> &'a mut W {
33 self.w.bits = (self.w.bits & !(0x01 << 1)) | (((value as u32) & 0x01) << 1);
34 self.w
35 }
36}
37#[doc = "Reader of field `RTCC`"]
38pub type RTCC_R = crate::R<bool, bool>;
39#[doc = "Write proxy for field `RTCC`"]
40pub struct RTCC_W<'a> {
41 w: &'a mut W,
42}
43impl<'a> RTCC_W<'a> {
44 #[doc = r"Sets the field bit"]
45 #[inline(always)]
46 pub fn set_bit(self) -> &'a mut W {
47 self.bit(true)
48 }
49 #[doc = r"Clears the field bit"]
50 #[inline(always)]
51 pub fn clear_bit(self) -> &'a mut W {
52 self.bit(false)
53 }
54 #[doc = r"Writes raw bits to the field"]
55 #[inline(always)]
56 pub fn bit(self, value: bool) -> &'a mut W {
57 self.w.bits = (self.w.bits & !(0x01 << 2)) | (((value as u32) & 0x01) << 2);
58 self.w
59 }
60}
61#[doc = "Reader of field `SMU`"]
62pub type SMU_R = crate::R<bool, bool>;
63#[doc = "Write proxy for field `SMU`"]
64pub struct SMU_W<'a> {
65 w: &'a mut W,
66}
67impl<'a> SMU_W<'a> {
68 #[doc = r"Sets the field bit"]
69 #[inline(always)]
70 pub fn set_bit(self) -> &'a mut W {
71 self.bit(true)
72 }
73 #[doc = r"Clears the field bit"]
74 #[inline(always)]
75 pub fn clear_bit(self) -> &'a mut W {
76 self.bit(false)
77 }
78 #[doc = r"Writes raw bits to the field"]
79 #[inline(always)]
80 pub fn bit(self, value: bool) -> &'a mut W {
81 self.w.bits = (self.w.bits & !(0x01 << 3)) | (((value as u32) & 0x01) << 3);
82 self.w
83 }
84}
85#[doc = "Reader of field `TIMER0`"]
86pub type TIMER0_R = crate::R<bool, bool>;
87#[doc = "Write proxy for field `TIMER0`"]
88pub struct TIMER0_W<'a> {
89 w: &'a mut W,
90}
91impl<'a> TIMER0_W<'a> {
92 #[doc = r"Sets the field bit"]
93 #[inline(always)]
94 pub fn set_bit(self) -> &'a mut W {
95 self.bit(true)
96 }
97 #[doc = r"Clears the field bit"]
98 #[inline(always)]
99 pub fn clear_bit(self) -> &'a mut W {
100 self.bit(false)
101 }
102 #[doc = r"Writes raw bits to the field"]
103 #[inline(always)]
104 pub fn bit(self, value: bool) -> &'a mut W {
105 self.w.bits = (self.w.bits & !(0x01 << 5)) | (((value as u32) & 0x01) << 5);
106 self.w
107 }
108}
109#[doc = "Reader of field `TIMER1`"]
110pub type TIMER1_R = crate::R<bool, bool>;
111#[doc = "Write proxy for field `TIMER1`"]
112pub struct TIMER1_W<'a> {
113 w: &'a mut W,
114}
115impl<'a> TIMER1_W<'a> {
116 #[doc = r"Sets the field bit"]
117 #[inline(always)]
118 pub fn set_bit(self) -> &'a mut W {
119 self.bit(true)
120 }
121 #[doc = r"Clears the field bit"]
122 #[inline(always)]
123 pub fn clear_bit(self) -> &'a mut W {
124 self.bit(false)
125 }
126 #[doc = r"Writes raw bits to the field"]
127 #[inline(always)]
128 pub fn bit(self, value: bool) -> &'a mut W {
129 self.w.bits = (self.w.bits & !(0x01 << 6)) | (((value as u32) & 0x01) << 6);
130 self.w
131 }
132}
133#[doc = "Reader of field `TRNG0`"]
134pub type TRNG0_R = crate::R<bool, bool>;
135#[doc = "Write proxy for field `TRNG0`"]
136pub struct TRNG0_W<'a> {
137 w: &'a mut W,
138}
139impl<'a> TRNG0_W<'a> {
140 #[doc = r"Sets the field bit"]
141 #[inline(always)]
142 pub fn set_bit(self) -> &'a mut W {
143 self.bit(true)
144 }
145 #[doc = r"Clears the field bit"]
146 #[inline(always)]
147 pub fn clear_bit(self) -> &'a mut W {
148 self.bit(false)
149 }
150 #[doc = r"Writes raw bits to the field"]
151 #[inline(always)]
152 pub fn bit(self, value: bool) -> &'a mut W {
153 self.w.bits = (self.w.bits & !(0x01 << 7)) | (((value as u32) & 0x01) << 7);
154 self.w
155 }
156}
157#[doc = "Reader of field `USART0`"]
158pub type USART0_R = crate::R<bool, bool>;
159#[doc = "Write proxy for field `USART0`"]
160pub struct USART0_W<'a> {
161 w: &'a mut W,
162}
163impl<'a> USART0_W<'a> {
164 #[doc = r"Sets the field bit"]
165 #[inline(always)]
166 pub fn set_bit(self) -> &'a mut W {
167 self.bit(true)
168 }
169 #[doc = r"Clears the field bit"]
170 #[inline(always)]
171 pub fn clear_bit(self) -> &'a mut W {
172 self.bit(false)
173 }
174 #[doc = r"Writes raw bits to the field"]
175 #[inline(always)]
176 pub fn bit(self, value: bool) -> &'a mut W {
177 self.w.bits = (self.w.bits & !(0x01 << 8)) | (((value as u32) & 0x01) << 8);
178 self.w
179 }
180}
181#[doc = "Reader of field `USART1`"]
182pub type USART1_R = crate::R<bool, bool>;
183#[doc = "Write proxy for field `USART1`"]
184pub struct USART1_W<'a> {
185 w: &'a mut W,
186}
187impl<'a> USART1_W<'a> {
188 #[doc = r"Sets the field bit"]
189 #[inline(always)]
190 pub fn set_bit(self) -> &'a mut W {
191 self.bit(true)
192 }
193 #[doc = r"Clears the field bit"]
194 #[inline(always)]
195 pub fn clear_bit(self) -> &'a mut W {
196 self.bit(false)
197 }
198 #[doc = r"Writes raw bits to the field"]
199 #[inline(always)]
200 pub fn bit(self, value: bool) -> &'a mut W {
201 self.w.bits = (self.w.bits & !(0x01 << 9)) | (((value as u32) & 0x01) << 9);
202 self.w
203 }
204}
205#[doc = "Reader of field `USART2`"]
206pub type USART2_R = crate::R<bool, bool>;
207#[doc = "Write proxy for field `USART2`"]
208pub struct USART2_W<'a> {
209 w: &'a mut W,
210}
211impl<'a> USART2_W<'a> {
212 #[doc = r"Sets the field bit"]
213 #[inline(always)]
214 pub fn set_bit(self) -> &'a mut W {
215 self.bit(true)
216 }
217 #[doc = r"Clears the field bit"]
218 #[inline(always)]
219 pub fn clear_bit(self) -> &'a mut W {
220 self.bit(false)
221 }
222 #[doc = r"Writes raw bits to the field"]
223 #[inline(always)]
224 pub fn bit(self, value: bool) -> &'a mut W {
225 self.w.bits = (self.w.bits & !(0x01 << 10)) | (((value as u32) & 0x01) << 10);
226 self.w
227 }
228}
229#[doc = "Reader of field `USART3`"]
230pub type USART3_R = crate::R<bool, bool>;
231#[doc = "Write proxy for field `USART3`"]
232pub struct USART3_W<'a> {
233 w: &'a mut W,
234}
235impl<'a> USART3_W<'a> {
236 #[doc = r"Sets the field bit"]
237 #[inline(always)]
238 pub fn set_bit(self) -> &'a mut W {
239 self.bit(true)
240 }
241 #[doc = r"Clears the field bit"]
242 #[inline(always)]
243 pub fn clear_bit(self) -> &'a mut W {
244 self.bit(false)
245 }
246 #[doc = r"Writes raw bits to the field"]
247 #[inline(always)]
248 pub fn bit(self, value: bool) -> &'a mut W {
249 self.w.bits = (self.w.bits & !(0x01 << 11)) | (((value as u32) & 0x01) << 11);
250 self.w
251 }
252}
253#[doc = "Reader of field `WDOG0`"]
254pub type WDOG0_R = crate::R<bool, bool>;
255#[doc = "Write proxy for field `WDOG0`"]
256pub struct WDOG0_W<'a> {
257 w: &'a mut W,
258}
259impl<'a> WDOG0_W<'a> {
260 #[doc = r"Sets the field bit"]
261 #[inline(always)]
262 pub fn set_bit(self) -> &'a mut W {
263 self.bit(true)
264 }
265 #[doc = r"Clears the field bit"]
266 #[inline(always)]
267 pub fn clear_bit(self) -> &'a mut W {
268 self.bit(false)
269 }
270 #[doc = r"Writes raw bits to the field"]
271 #[inline(always)]
272 pub fn bit(self, value: bool) -> &'a mut W {
273 self.w.bits = (self.w.bits & !(0x01 << 12)) | (((value as u32) & 0x01) << 12);
274 self.w
275 }
276}
277#[doc = "Reader of field `WDOG1`"]
278pub type WDOG1_R = crate::R<bool, bool>;
279#[doc = "Write proxy for field `WDOG1`"]
280pub struct WDOG1_W<'a> {
281 w: &'a mut W,
282}
283impl<'a> WDOG1_W<'a> {
284 #[doc = r"Sets the field bit"]
285 #[inline(always)]
286 pub fn set_bit(self) -> &'a mut W {
287 self.bit(true)
288 }
289 #[doc = r"Clears the field bit"]
290 #[inline(always)]
291 pub fn clear_bit(self) -> &'a mut W {
292 self.bit(false)
293 }
294 #[doc = r"Writes raw bits to the field"]
295 #[inline(always)]
296 pub fn bit(self, value: bool) -> &'a mut W {
297 self.w.bits = (self.w.bits & !(0x01 << 13)) | (((value as u32) & 0x01) << 13);
298 self.w
299 }
300}
301#[doc = "Reader of field `WTIMER0`"]
302pub type WTIMER0_R = crate::R<bool, bool>;
303#[doc = "Write proxy for field `WTIMER0`"]
304pub struct WTIMER0_W<'a> {
305 w: &'a mut W,
306}
307impl<'a> WTIMER0_W<'a> {
308 #[doc = r"Sets the field bit"]
309 #[inline(always)]
310 pub fn set_bit(self) -> &'a mut W {
311 self.bit(true)
312 }
313 #[doc = r"Clears the field bit"]
314 #[inline(always)]
315 pub fn clear_bit(self) -> &'a mut W {
316 self.bit(false)
317 }
318 #[doc = r"Writes raw bits to the field"]
319 #[inline(always)]
320 pub fn bit(self, value: bool) -> &'a mut W {
321 self.w.bits = (self.w.bits & !(0x01 << 14)) | (((value as u32) & 0x01) << 14);
322 self.w
323 }
324}
325#[doc = "Reader of field `WTIMER1`"]
326pub type WTIMER1_R = crate::R<bool, bool>;
327#[doc = "Write proxy for field `WTIMER1`"]
328pub struct WTIMER1_W<'a> {
329 w: &'a mut W,
330}
331impl<'a> WTIMER1_W<'a> {
332 #[doc = r"Sets the field bit"]
333 #[inline(always)]
334 pub fn set_bit(self) -> &'a mut W {
335 self.bit(true)
336 }
337 #[doc = r"Clears the field bit"]
338 #[inline(always)]
339 pub fn clear_bit(self) -> &'a mut W {
340 self.bit(false)
341 }
342 #[doc = r"Writes raw bits to the field"]
343 #[inline(always)]
344 pub fn bit(self, value: bool) -> &'a mut W {
345 self.w.bits = (self.w.bits & !(0x01 << 15)) | (((value as u32) & 0x01) << 15);
346 self.w
347 }
348}
349impl R {
350 #[doc = "Bit 1 - Reset Management Unit access control bit"]
351 #[inline(always)]
352 pub fn rmu(&self) -> RMU_R {
353 RMU_R::new(((self.bits >> 1) & 0x01) != 0)
354 }
355 #[doc = "Bit 2 - Real-Time Counter and Calendar access control bit"]
356 #[inline(always)]
357 pub fn rtcc(&self) -> RTCC_R {
358 RTCC_R::new(((self.bits >> 2) & 0x01) != 0)
359 }
360 #[doc = "Bit 3 - Security Management Unit access control bit"]
361 #[inline(always)]
362 pub fn smu(&self) -> SMU_R {
363 SMU_R::new(((self.bits >> 3) & 0x01) != 0)
364 }
365 #[doc = "Bit 5 - Timer 0 access control bit"]
366 #[inline(always)]
367 pub fn timer0(&self) -> TIMER0_R {
368 TIMER0_R::new(((self.bits >> 5) & 0x01) != 0)
369 }
370 #[doc = "Bit 6 - Timer 1 access control bit"]
371 #[inline(always)]
372 pub fn timer1(&self) -> TIMER1_R {
373 TIMER1_R::new(((self.bits >> 6) & 0x01) != 0)
374 }
375 #[doc = "Bit 7 - True Random Number Generator 0 access control bit"]
376 #[inline(always)]
377 pub fn trng0(&self) -> TRNG0_R {
378 TRNG0_R::new(((self.bits >> 7) & 0x01) != 0)
379 }
380 #[doc = "Bit 8 - Universal Synchronous/Asynchronous Receiver/Transmitter 0 access control bit"]
381 #[inline(always)]
382 pub fn usart0(&self) -> USART0_R {
383 USART0_R::new(((self.bits >> 8) & 0x01) != 0)
384 }
385 #[doc = "Bit 9 - Universal Synchronous/Asynchronous Receiver/Transmitter 1 access control bit"]
386 #[inline(always)]
387 pub fn usart1(&self) -> USART1_R {
388 USART1_R::new(((self.bits >> 9) & 0x01) != 0)
389 }
390 #[doc = "Bit 10 - Universal Synchronous/Asynchronous Receiver/Transmitter 2 access control bit"]
391 #[inline(always)]
392 pub fn usart2(&self) -> USART2_R {
393 USART2_R::new(((self.bits >> 10) & 0x01) != 0)
394 }
395 #[doc = "Bit 11 - Universal Synchronous/Asynchronous Receiver/Transmitter 3 access control bit"]
396 #[inline(always)]
397 pub fn usart3(&self) -> USART3_R {
398 USART3_R::new(((self.bits >> 11) & 0x01) != 0)
399 }
400 #[doc = "Bit 12 - Watchdog 0 access control bit"]
401 #[inline(always)]
402 pub fn wdog0(&self) -> WDOG0_R {
403 WDOG0_R::new(((self.bits >> 12) & 0x01) != 0)
404 }
405 #[doc = "Bit 13 - Watchdog 1 access control bit"]
406 #[inline(always)]
407 pub fn wdog1(&self) -> WDOG1_R {
408 WDOG1_R::new(((self.bits >> 13) & 0x01) != 0)
409 }
410 #[doc = "Bit 14 - Wide Timer 0 access control bit"]
411 #[inline(always)]
412 pub fn wtimer0(&self) -> WTIMER0_R {
413 WTIMER0_R::new(((self.bits >> 14) & 0x01) != 0)
414 }
415 #[doc = "Bit 15 - Wide Timer 1 access control bit"]
416 #[inline(always)]
417 pub fn wtimer1(&self) -> WTIMER1_R {
418 WTIMER1_R::new(((self.bits >> 15) & 0x01) != 0)
419 }
420}
421impl W {
422 #[doc = "Bit 1 - Reset Management Unit access control bit"]
423 #[inline(always)]
424 pub fn rmu(&mut self) -> RMU_W {
425 RMU_W { w: self }
426 }
427 #[doc = "Bit 2 - Real-Time Counter and Calendar access control bit"]
428 #[inline(always)]
429 pub fn rtcc(&mut self) -> RTCC_W {
430 RTCC_W { w: self }
431 }
432 #[doc = "Bit 3 - Security Management Unit access control bit"]
433 #[inline(always)]
434 pub fn smu(&mut self) -> SMU_W {
435 SMU_W { w: self }
436 }
437 #[doc = "Bit 5 - Timer 0 access control bit"]
438 #[inline(always)]
439 pub fn timer0(&mut self) -> TIMER0_W {
440 TIMER0_W { w: self }
441 }
442 #[doc = "Bit 6 - Timer 1 access control bit"]
443 #[inline(always)]
444 pub fn timer1(&mut self) -> TIMER1_W {
445 TIMER1_W { w: self }
446 }
447 #[doc = "Bit 7 - True Random Number Generator 0 access control bit"]
448 #[inline(always)]
449 pub fn trng0(&mut self) -> TRNG0_W {
450 TRNG0_W { w: self }
451 }
452 #[doc = "Bit 8 - Universal Synchronous/Asynchronous Receiver/Transmitter 0 access control bit"]
453 #[inline(always)]
454 pub fn usart0(&mut self) -> USART0_W {
455 USART0_W { w: self }
456 }
457 #[doc = "Bit 9 - Universal Synchronous/Asynchronous Receiver/Transmitter 1 access control bit"]
458 #[inline(always)]
459 pub fn usart1(&mut self) -> USART1_W {
460 USART1_W { w: self }
461 }
462 #[doc = "Bit 10 - Universal Synchronous/Asynchronous Receiver/Transmitter 2 access control bit"]
463 #[inline(always)]
464 pub fn usart2(&mut self) -> USART2_W {
465 USART2_W { w: self }
466 }
467 #[doc = "Bit 11 - Universal Synchronous/Asynchronous Receiver/Transmitter 3 access control bit"]
468 #[inline(always)]
469 pub fn usart3(&mut self) -> USART3_W {
470 USART3_W { w: self }
471 }
472 #[doc = "Bit 12 - Watchdog 0 access control bit"]
473 #[inline(always)]
474 pub fn wdog0(&mut self) -> WDOG0_W {
475 WDOG0_W { w: self }
476 }
477 #[doc = "Bit 13 - Watchdog 1 access control bit"]
478 #[inline(always)]
479 pub fn wdog1(&mut self) -> WDOG1_W {
480 WDOG1_W { w: self }
481 }
482 #[doc = "Bit 14 - Wide Timer 0 access control bit"]
483 #[inline(always)]
484 pub fn wtimer0(&mut self) -> WTIMER0_W {
485 WTIMER0_W { w: self }
486 }
487 #[doc = "Bit 15 - Wide Timer 1 access control bit"]
488 #[inline(always)]
489 pub fn wtimer1(&mut self) -> WTIMER1_W {
490 WTIMER1_W { w: self }
491 }
492}