atsaml21j16b/dmac/
chstatus.rs

1#[doc = "Register `CHSTATUS` reader"]
2pub struct R(crate::R<CHSTATUS_SPEC>);
3impl core::ops::Deref for R {
4    type Target = crate::R<CHSTATUS_SPEC>;
5    #[inline(always)]
6    fn deref(&self) -> &Self::Target {
7        &self.0
8    }
9}
10impl From<crate::R<CHSTATUS_SPEC>> for R {
11    #[inline(always)]
12    fn from(reader: crate::R<CHSTATUS_SPEC>) -> Self {
13        R(reader)
14    }
15}
16#[doc = "Field `PEND` reader - Channel Pending"]
17pub type PEND_R = crate::BitReader<bool>;
18#[doc = "Field `BUSY` reader - Channel Busy"]
19pub type BUSY_R = crate::BitReader<bool>;
20#[doc = "Field `FERR` reader - Channel Fetch Error"]
21pub type FERR_R = crate::BitReader<bool>;
22impl R {
23    #[doc = "Bit 0 - Channel Pending"]
24    #[inline(always)]
25    pub fn pend(&self) -> PEND_R {
26        PEND_R::new((self.bits & 1) != 0)
27    }
28    #[doc = "Bit 1 - Channel Busy"]
29    #[inline(always)]
30    pub fn busy(&self) -> BUSY_R {
31        BUSY_R::new(((self.bits >> 1) & 1) != 0)
32    }
33    #[doc = "Bit 2 - Channel Fetch Error"]
34    #[inline(always)]
35    pub fn ferr(&self) -> FERR_R {
36        FERR_R::new(((self.bits >> 2) & 1) != 0)
37    }
38}
39#[doc = "Channel Status\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 [chstatus](index.html) module"]
40pub struct CHSTATUS_SPEC;
41impl crate::RegisterSpec for CHSTATUS_SPEC {
42    type Ux = u8;
43}
44#[doc = "`read()` method returns [chstatus::R](R) reader structure"]
45impl crate::Readable for CHSTATUS_SPEC {
46    type Reader = R;
47}
48#[doc = "`reset()` method sets CHSTATUS to value 0"]
49impl crate::Resettable for CHSTATUS_SPEC {
50    const RESET_VALUE: Self::Ux = 0;
51}