va416xx/can0/
cnstat_cmb13.rs

1#[doc = "Register `CNSTAT_CMB13` reader"]
2pub type R = crate::R<CnstatCmb13Spec>;
3#[doc = "Register `CNSTAT_CMB13` writer"]
4pub type W = crate::W<CnstatCmb13Spec>;
5#[doc = "Field `ST` reader - Buffer Status"]
6pub type StR = crate::FieldReader;
7#[doc = "Field `ST` writer - Buffer Status"]
8pub type StW<'a, REG> = crate::FieldWriter<'a, REG, 4>;
9#[doc = "Field `PRI` reader - Transmit Priority Code"]
10pub type PriR = crate::FieldReader;
11#[doc = "Field `PRI` writer - Transmit Priority Code"]
12pub type PriW<'a, REG> = crate::FieldWriter<'a, REG, 4>;
13#[doc = "Field `DLC` reader - Data Length Code"]
14pub type DlcR = crate::FieldReader;
15#[doc = "Field `DLC` writer - Data Length Code"]
16pub type DlcW<'a, REG> = crate::FieldWriter<'a, REG, 4>;
17impl R {
18    #[doc = "Bits 0:3 - Buffer Status"]
19    #[inline(always)]
20    pub fn st(&self) -> StR {
21        StR::new((self.bits & 0x0f) as u8)
22    }
23    #[doc = "Bits 4:7 - Transmit Priority Code"]
24    #[inline(always)]
25    pub fn pri(&self) -> PriR {
26        PriR::new(((self.bits >> 4) & 0x0f) as u8)
27    }
28    #[doc = "Bits 12:15 - Data Length Code"]
29    #[inline(always)]
30    pub fn dlc(&self) -> DlcR {
31        DlcR::new(((self.bits >> 12) & 0x0f) as u8)
32    }
33}
34impl W {
35    #[doc = "Bits 0:3 - Buffer Status"]
36    #[inline(always)]
37    pub fn st(&mut self) -> StW<'_, CnstatCmb13Spec> {
38        StW::new(self, 0)
39    }
40    #[doc = "Bits 4:7 - Transmit Priority Code"]
41    #[inline(always)]
42    pub fn pri(&mut self) -> PriW<'_, CnstatCmb13Spec> {
43        PriW::new(self, 4)
44    }
45    #[doc = "Bits 12:15 - Data Length Code"]
46    #[inline(always)]
47    pub fn dlc(&mut self) -> DlcW<'_, CnstatCmb13Spec> {
48        DlcW::new(self, 12)
49    }
50}
51#[doc = "Buffer Status / Control Register\n\nYou can [`read`](crate::Reg::read) this register and get [`cnstat_cmb13::R`](R). You can [`reset`](crate::Reg::reset), [`write`](crate::Reg::write), [`write_with_zero`](crate::Reg::write_with_zero) this register using [`cnstat_cmb13::W`](W). You can also [`modify`](crate::Reg::modify) this register. See [API](https://docs.rs/svd2rust/#read--modify--write-api)."]
52pub struct CnstatCmb13Spec;
53impl crate::RegisterSpec for CnstatCmb13Spec {
54    type Ux = u32;
55}
56#[doc = "`read()` method returns [`cnstat_cmb13::R`](R) reader structure"]
57impl crate::Readable for CnstatCmb13Spec {}
58#[doc = "`write(|w| ..)` method takes [`cnstat_cmb13::W`](W) writer structure"]
59impl crate::Writable for CnstatCmb13Spec {
60    type Safety = crate::Unsafe;
61}
62#[doc = "`reset()` method sets CNSTAT_CMB13 to value 0"]
63impl crate::Resettable for CnstatCmb13Spec {}