efm32tg11b320_pac/can0/
errcnt.rs

1#[doc = "Register `ERRCNT` reader"]
2pub struct R(crate::R<ERRCNT_SPEC>);
3impl core::ops::Deref for R {
4    type Target = crate::R<ERRCNT_SPEC>;
5    #[inline(always)]
6    fn deref(&self) -> &Self::Target {
7        &self.0
8    }
9}
10impl From<crate::R<ERRCNT_SPEC>> for R {
11    #[inline(always)]
12    fn from(reader: crate::R<ERRCNT_SPEC>) -> Self {
13        R(reader)
14    }
15}
16#[doc = "Field `TEC` reader - Transmit Error Counter"]
17pub type TEC_R = crate::FieldReader<u8, u8>;
18#[doc = "Field `REC` reader - Receive Error Counter"]
19pub type REC_R = crate::FieldReader<u8, u8>;
20#[doc = "Field `RECERRP` reader - Receive Error Passive"]
21pub type RECERRP_R = crate::BitReader<bool>;
22impl R {
23    #[doc = "Bits 0:7 - Transmit Error Counter"]
24    #[inline(always)]
25    pub fn tec(&self) -> TEC_R {
26        TEC_R::new((self.bits & 0xff) as u8)
27    }
28    #[doc = "Bits 8:14 - Receive Error Counter"]
29    #[inline(always)]
30    pub fn rec(&self) -> REC_R {
31        REC_R::new(((self.bits >> 8) & 0x7f) as u8)
32    }
33    #[doc = "Bit 15 - Receive Error Passive"]
34    #[inline(always)]
35    pub fn recerrp(&self) -> RECERRP_R {
36        RECERRP_R::new(((self.bits >> 15) & 1) != 0)
37    }
38}
39#[doc = "Error Count Register\n\nThis register you can [`read`](crate::generic::Reg::read). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [errcnt](index.html) module"]
40pub struct ERRCNT_SPEC;
41impl crate::RegisterSpec for ERRCNT_SPEC {
42    type Ux = u32;
43}
44#[doc = "`read()` method returns [errcnt::R](R) reader structure"]
45impl crate::Readable for ERRCNT_SPEC {
46    type Reader = R;
47}
48#[doc = "`reset()` method sets ERRCNT to value 0"]
49impl crate::Resettable for ERRCNT_SPEC {
50    #[inline(always)]
51    fn reset_value() -> Self::Ux {
52        0
53    }
54}