1#[doc = "Register `MB%s_D0` reader"]
2pub struct R(crate::R<MB_D0_SPEC>);
3impl core::ops::Deref for R {
4 type Target = crate::R<MB_D0_SPEC>;
5 #[inline(always)]
6 fn deref(&self) -> &Self::Target {
7 &self.0
8 }
9}
10impl From<crate::R<MB_D0_SPEC>> for R {
11 #[inline(always)]
12 fn from(reader: crate::R<MB_D0_SPEC>) -> Self {
13 R(reader)
14 }
15}
16#[doc = "Register `MB%s_D0` writer"]
17pub struct W(crate::W<MB_D0_SPEC>);
18impl core::ops::Deref for W {
19 type Target = crate::W<MB_D0_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<MB_D0_SPEC>> for W {
32 #[inline(always)]
33 fn from(writer: crate::W<MB_D0_SPEC>) -> Self {
34 W(writer)
35 }
36}
37#[doc = "Field `DATA0` reader - Data Bytes 0.DATA0 store the transmitted or received CAN message data. Transmission or reception starts from DATA0. The bit order on the CAN bus is MSB first, and transmission or reception starts from bit 7."]
38pub type DATA0_R = crate::FieldReader<u8, u8>;
39#[doc = "Field `DATA0` writer - Data Bytes 0.DATA0 store the transmitted or received CAN message data. Transmission or reception starts from DATA0. The bit order on the CAN bus is MSB first, and transmission or reception starts from bit 7."]
40pub type DATA0_W<'a, const O: u8> = crate::FieldWriter<'a, u8, MB_D0_SPEC, u8, u8, 8, O>;
41impl R {
42 #[doc = "Bits 0:7 - Data Bytes 0.DATA0 store the transmitted or received CAN message data. Transmission or reception starts from DATA0. The bit order on the CAN bus is MSB first, and transmission or reception starts from bit 7."]
43 #[inline(always)]
44 pub fn data0(&self) -> DATA0_R {
45 DATA0_R::new(self.bits)
46 }
47}
48impl W {
49 #[doc = "Bits 0:7 - Data Bytes 0.DATA0 store the transmitted or received CAN message data. Transmission or reception starts from DATA0. The bit order on the CAN bus is MSB first, and transmission or reception starts from bit 7."]
50 #[inline(always)]
51 #[must_use]
52 pub fn data0(&mut self) -> DATA0_W<0> {
53 DATA0_W::new(self)
54 }
55 #[doc = "Writes raw bits to the register."]
56 #[inline(always)]
57 pub unsafe fn bits(&mut self, bits: u8) -> &mut Self {
58 self.0.bits(bits);
59 self
60 }
61}
62#[doc = "Mailbox Register\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 [mb_d0](index.html) module"]
63pub struct MB_D0_SPEC;
64impl crate::RegisterSpec for MB_D0_SPEC {
65 type Ux = u8;
66}
67#[doc = "`read()` method returns [mb_d0::R](R) reader structure"]
68impl crate::Readable for MB_D0_SPEC {
69 type Reader = R;
70}
71#[doc = "`write(|w| ..)` method takes [mb_d0::W](W) writer structure"]
72impl crate::Writable for MB_D0_SPEC {
73 type Writer = W;
74 const ZERO_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0;
75 const ONE_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0;
76}
77#[doc = "`reset()` method sets MB%s_D0 to value 0"]
78impl crate::Resettable for MB_D0_SPEC {
79 const RESET_VALUE: Self::Ux = 0;
80}