lpc54606_pac/sdif/
rintsts.rs1#[doc = "Reader of register RINTSTS"]
2pub type R = crate::R<u32, super::RINTSTS>;
3#[doc = "Writer for register RINTSTS"]
4pub type W = crate::W<u32, super::RINTSTS>;
5#[doc = "Register RINTSTS `reset()`'s with value 0"]
6impl crate::ResetValue for super::RINTSTS {
7 type Type = u32;
8 #[inline(always)]
9 fn reset_value() -> Self::Type {
10 0
11 }
12}
13#[doc = "Reader of field `CDET`"]
14pub type CDET_R = crate::R<bool, bool>;
15#[doc = "Write proxy for field `CDET`"]
16pub struct CDET_W<'a> {
17 w: &'a mut W,
18}
19impl<'a> CDET_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) | ((value as u32) & 0x01);
34 self.w
35 }
36}
37#[doc = "Reader of field `RE`"]
38pub type RE_R = crate::R<bool, bool>;
39#[doc = "Write proxy for field `RE`"]
40pub struct RE_W<'a> {
41 w: &'a mut W,
42}
43impl<'a> RE_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 << 1)) | (((value as u32) & 0x01) << 1);
58 self.w
59 }
60}
61#[doc = "Reader of field `CDONE`"]
62pub type CDONE_R = crate::R<bool, bool>;
63#[doc = "Write proxy for field `CDONE`"]
64pub struct CDONE_W<'a> {
65 w: &'a mut W,
66}
67impl<'a> CDONE_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 << 2)) | (((value as u32) & 0x01) << 2);
82 self.w
83 }
84}
85#[doc = "Reader of field `DTO`"]
86pub type DTO_R = crate::R<bool, bool>;
87#[doc = "Write proxy for field `DTO`"]
88pub struct DTO_W<'a> {
89 w: &'a mut W,
90}
91impl<'a> DTO_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 << 3)) | (((value as u32) & 0x01) << 3);
106 self.w
107 }
108}
109#[doc = "Reader of field `TXDR`"]
110pub type TXDR_R = crate::R<bool, bool>;
111#[doc = "Write proxy for field `TXDR`"]
112pub struct TXDR_W<'a> {
113 w: &'a mut W,
114}
115impl<'a> TXDR_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 << 4)) | (((value as u32) & 0x01) << 4);
130 self.w
131 }
132}
133#[doc = "Reader of field `RXDR`"]
134pub type RXDR_R = crate::R<bool, bool>;
135#[doc = "Write proxy for field `RXDR`"]
136pub struct RXDR_W<'a> {
137 w: &'a mut W,
138}
139impl<'a> RXDR_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 << 5)) | (((value as u32) & 0x01) << 5);
154 self.w
155 }
156}
157#[doc = "Reader of field `RCRC`"]
158pub type RCRC_R = crate::R<bool, bool>;
159#[doc = "Write proxy for field `RCRC`"]
160pub struct RCRC_W<'a> {
161 w: &'a mut W,
162}
163impl<'a> RCRC_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 << 6)) | (((value as u32) & 0x01) << 6);
178 self.w
179 }
180}
181#[doc = "Reader of field `DCRC`"]
182pub type DCRC_R = crate::R<bool, bool>;
183#[doc = "Write proxy for field `DCRC`"]
184pub struct DCRC_W<'a> {
185 w: &'a mut W,
186}
187impl<'a> DCRC_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 << 7)) | (((value as u32) & 0x01) << 7);
202 self.w
203 }
204}
205#[doc = "Reader of field `RTO_BAR`"]
206pub type RTO_BAR_R = crate::R<bool, bool>;
207#[doc = "Write proxy for field `RTO_BAR`"]
208pub struct RTO_BAR_W<'a> {
209 w: &'a mut W,
210}
211impl<'a> RTO_BAR_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 << 8)) | (((value as u32) & 0x01) << 8);
226 self.w
227 }
228}
229#[doc = "Reader of field `DRTO_BDS`"]
230pub type DRTO_BDS_R = crate::R<bool, bool>;
231#[doc = "Write proxy for field `DRTO_BDS`"]
232pub struct DRTO_BDS_W<'a> {
233 w: &'a mut W,
234}
235impl<'a> DRTO_BDS_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 << 9)) | (((value as u32) & 0x01) << 9);
250 self.w
251 }
252}
253#[doc = "Reader of field `HTO`"]
254pub type HTO_R = crate::R<bool, bool>;
255#[doc = "Write proxy for field `HTO`"]
256pub struct HTO_W<'a> {
257 w: &'a mut W,
258}
259impl<'a> HTO_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 << 10)) | (((value as u32) & 0x01) << 10);
274 self.w
275 }
276}
277#[doc = "Reader of field `FRUN`"]
278pub type FRUN_R = crate::R<bool, bool>;
279#[doc = "Write proxy for field `FRUN`"]
280pub struct FRUN_W<'a> {
281 w: &'a mut W,
282}
283impl<'a> FRUN_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 << 11)) | (((value as u32) & 0x01) << 11);
298 self.w
299 }
300}
301#[doc = "Reader of field `HLE`"]
302pub type HLE_R = crate::R<bool, bool>;
303#[doc = "Write proxy for field `HLE`"]
304pub struct HLE_W<'a> {
305 w: &'a mut W,
306}
307impl<'a> HLE_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 << 12)) | (((value as u32) & 0x01) << 12);
322 self.w
323 }
324}
325#[doc = "Reader of field `SBE`"]
326pub type SBE_R = crate::R<bool, bool>;
327#[doc = "Write proxy for field `SBE`"]
328pub struct SBE_W<'a> {
329 w: &'a mut W,
330}
331impl<'a> SBE_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 << 13)) | (((value as u32) & 0x01) << 13);
346 self.w
347 }
348}
349#[doc = "Reader of field `ACD`"]
350pub type ACD_R = crate::R<bool, bool>;
351#[doc = "Write proxy for field `ACD`"]
352pub struct ACD_W<'a> {
353 w: &'a mut W,
354}
355impl<'a> ACD_W<'a> {
356 #[doc = r"Sets the field bit"]
357 #[inline(always)]
358 pub fn set_bit(self) -> &'a mut W {
359 self.bit(true)
360 }
361 #[doc = r"Clears the field bit"]
362 #[inline(always)]
363 pub fn clear_bit(self) -> &'a mut W {
364 self.bit(false)
365 }
366 #[doc = r"Writes raw bits to the field"]
367 #[inline(always)]
368 pub fn bit(self, value: bool) -> &'a mut W {
369 self.w.bits = (self.w.bits & !(0x01 << 14)) | (((value as u32) & 0x01) << 14);
370 self.w
371 }
372}
373#[doc = "Reader of field `EBE`"]
374pub type EBE_R = crate::R<bool, bool>;
375#[doc = "Write proxy for field `EBE`"]
376pub struct EBE_W<'a> {
377 w: &'a mut W,
378}
379impl<'a> EBE_W<'a> {
380 #[doc = r"Sets the field bit"]
381 #[inline(always)]
382 pub fn set_bit(self) -> &'a mut W {
383 self.bit(true)
384 }
385 #[doc = r"Clears the field bit"]
386 #[inline(always)]
387 pub fn clear_bit(self) -> &'a mut W {
388 self.bit(false)
389 }
390 #[doc = r"Writes raw bits to the field"]
391 #[inline(always)]
392 pub fn bit(self, value: bool) -> &'a mut W {
393 self.w.bits = (self.w.bits & !(0x01 << 15)) | (((value as u32) & 0x01) << 15);
394 self.w
395 }
396}
397#[doc = "Reader of field `SDIO_INTERRUPT`"]
398pub type SDIO_INTERRUPT_R = crate::R<bool, bool>;
399#[doc = "Write proxy for field `SDIO_INTERRUPT`"]
400pub struct SDIO_INTERRUPT_W<'a> {
401 w: &'a mut W,
402}
403impl<'a> SDIO_INTERRUPT_W<'a> {
404 #[doc = r"Sets the field bit"]
405 #[inline(always)]
406 pub fn set_bit(self) -> &'a mut W {
407 self.bit(true)
408 }
409 #[doc = r"Clears the field bit"]
410 #[inline(always)]
411 pub fn clear_bit(self) -> &'a mut W {
412 self.bit(false)
413 }
414 #[doc = r"Writes raw bits to the field"]
415 #[inline(always)]
416 pub fn bit(self, value: bool) -> &'a mut W {
417 self.w.bits = (self.w.bits & !(0x01 << 16)) | (((value as u32) & 0x01) << 16);
418 self.w
419 }
420}
421impl R {
422 #[doc = "Bit 0 - Card detect."]
423 #[inline(always)]
424 pub fn cdet(&self) -> CDET_R {
425 CDET_R::new((self.bits & 0x01) != 0)
426 }
427 #[doc = "Bit 1 - Response error."]
428 #[inline(always)]
429 pub fn re(&self) -> RE_R {
430 RE_R::new(((self.bits >> 1) & 0x01) != 0)
431 }
432 #[doc = "Bit 2 - Command done."]
433 #[inline(always)]
434 pub fn cdone(&self) -> CDONE_R {
435 CDONE_R::new(((self.bits >> 2) & 0x01) != 0)
436 }
437 #[doc = "Bit 3 - Data transfer over."]
438 #[inline(always)]
439 pub fn dto(&self) -> DTO_R {
440 DTO_R::new(((self.bits >> 3) & 0x01) != 0)
441 }
442 #[doc = "Bit 4 - Transmit FIFO data request."]
443 #[inline(always)]
444 pub fn txdr(&self) -> TXDR_R {
445 TXDR_R::new(((self.bits >> 4) & 0x01) != 0)
446 }
447 #[doc = "Bit 5 - Receive FIFO data request."]
448 #[inline(always)]
449 pub fn rxdr(&self) -> RXDR_R {
450 RXDR_R::new(((self.bits >> 5) & 0x01) != 0)
451 }
452 #[doc = "Bit 6 - Response CRC error."]
453 #[inline(always)]
454 pub fn rcrc(&self) -> RCRC_R {
455 RCRC_R::new(((self.bits >> 6) & 0x01) != 0)
456 }
457 #[doc = "Bit 7 - Data CRC error."]
458 #[inline(always)]
459 pub fn dcrc(&self) -> DCRC_R {
460 DCRC_R::new(((self.bits >> 7) & 0x01) != 0)
461 }
462 #[doc = "Bit 8 - Response time-out (RTO)/Boot Ack Received (BAR)."]
463 #[inline(always)]
464 pub fn rto_bar(&self) -> RTO_BAR_R {
465 RTO_BAR_R::new(((self.bits >> 8) & 0x01) != 0)
466 }
467 #[doc = "Bit 9 - Data read time-out (DRTO)/Boot Data Start (BDS)."]
468 #[inline(always)]
469 pub fn drto_bds(&self) -> DRTO_BDS_R {
470 DRTO_BDS_R::new(((self.bits >> 9) & 0x01) != 0)
471 }
472 #[doc = "Bit 10 - Data starvation-by-host time-out (HTO)."]
473 #[inline(always)]
474 pub fn hto(&self) -> HTO_R {
475 HTO_R::new(((self.bits >> 10) & 0x01) != 0)
476 }
477 #[doc = "Bit 11 - FIFO underrun/overrun error."]
478 #[inline(always)]
479 pub fn frun(&self) -> FRUN_R {
480 FRUN_R::new(((self.bits >> 11) & 0x01) != 0)
481 }
482 #[doc = "Bit 12 - Hardware locked write error."]
483 #[inline(always)]
484 pub fn hle(&self) -> HLE_R {
485 HLE_R::new(((self.bits >> 12) & 0x01) != 0)
486 }
487 #[doc = "Bit 13 - Start-bit error."]
488 #[inline(always)]
489 pub fn sbe(&self) -> SBE_R {
490 SBE_R::new(((self.bits >> 13) & 0x01) != 0)
491 }
492 #[doc = "Bit 14 - Auto command done."]
493 #[inline(always)]
494 pub fn acd(&self) -> ACD_R {
495 ACD_R::new(((self.bits >> 14) & 0x01) != 0)
496 }
497 #[doc = "Bit 15 - End-bit error (read)/write no CRC."]
498 #[inline(always)]
499 pub fn ebe(&self) -> EBE_R {
500 EBE_R::new(((self.bits >> 15) & 0x01) != 0)
501 }
502 #[doc = "Bit 16 - Interrupt from SDIO card."]
503 #[inline(always)]
504 pub fn sdio_interrupt(&self) -> SDIO_INTERRUPT_R {
505 SDIO_INTERRUPT_R::new(((self.bits >> 16) & 0x01) != 0)
506 }
507}
508impl W {
509 #[doc = "Bit 0 - Card detect."]
510 #[inline(always)]
511 pub fn cdet(&mut self) -> CDET_W {
512 CDET_W { w: self }
513 }
514 #[doc = "Bit 1 - Response error."]
515 #[inline(always)]
516 pub fn re(&mut self) -> RE_W {
517 RE_W { w: self }
518 }
519 #[doc = "Bit 2 - Command done."]
520 #[inline(always)]
521 pub fn cdone(&mut self) -> CDONE_W {
522 CDONE_W { w: self }
523 }
524 #[doc = "Bit 3 - Data transfer over."]
525 #[inline(always)]
526 pub fn dto(&mut self) -> DTO_W {
527 DTO_W { w: self }
528 }
529 #[doc = "Bit 4 - Transmit FIFO data request."]
530 #[inline(always)]
531 pub fn txdr(&mut self) -> TXDR_W {
532 TXDR_W { w: self }
533 }
534 #[doc = "Bit 5 - Receive FIFO data request."]
535 #[inline(always)]
536 pub fn rxdr(&mut self) -> RXDR_W {
537 RXDR_W { w: self }
538 }
539 #[doc = "Bit 6 - Response CRC error."]
540 #[inline(always)]
541 pub fn rcrc(&mut self) -> RCRC_W {
542 RCRC_W { w: self }
543 }
544 #[doc = "Bit 7 - Data CRC error."]
545 #[inline(always)]
546 pub fn dcrc(&mut self) -> DCRC_W {
547 DCRC_W { w: self }
548 }
549 #[doc = "Bit 8 - Response time-out (RTO)/Boot Ack Received (BAR)."]
550 #[inline(always)]
551 pub fn rto_bar(&mut self) -> RTO_BAR_W {
552 RTO_BAR_W { w: self }
553 }
554 #[doc = "Bit 9 - Data read time-out (DRTO)/Boot Data Start (BDS)."]
555 #[inline(always)]
556 pub fn drto_bds(&mut self) -> DRTO_BDS_W {
557 DRTO_BDS_W { w: self }
558 }
559 #[doc = "Bit 10 - Data starvation-by-host time-out (HTO)."]
560 #[inline(always)]
561 pub fn hto(&mut self) -> HTO_W {
562 HTO_W { w: self }
563 }
564 #[doc = "Bit 11 - FIFO underrun/overrun error."]
565 #[inline(always)]
566 pub fn frun(&mut self) -> FRUN_W {
567 FRUN_W { w: self }
568 }
569 #[doc = "Bit 12 - Hardware locked write error."]
570 #[inline(always)]
571 pub fn hle(&mut self) -> HLE_W {
572 HLE_W { w: self }
573 }
574 #[doc = "Bit 13 - Start-bit error."]
575 #[inline(always)]
576 pub fn sbe(&mut self) -> SBE_W {
577 SBE_W { w: self }
578 }
579 #[doc = "Bit 14 - Auto command done."]
580 #[inline(always)]
581 pub fn acd(&mut self) -> ACD_W {
582 ACD_W { w: self }
583 }
584 #[doc = "Bit 15 - End-bit error (read)/write no CRC."]
585 #[inline(always)]
586 pub fn ebe(&mut self) -> EBE_W {
587 EBE_W { w: self }
588 }
589 #[doc = "Bit 16 - Interrupt from SDIO card."]
590 #[inline(always)]
591 pub fn sdio_interrupt(&mut self) -> SDIO_INTERRUPT_W {
592 SDIO_INTERRUPT_W { w: self }
593 }
594}