atsamd11c/ac/
statusc.rs

1#[doc = "Register `STATUSC` reader"]
2pub type R = crate::R<StatuscSpec>;
3#[doc = "Field `STATE0` reader - Comparator 0 Current State"]
4pub type State0R = crate::BitReader;
5#[doc = "Field `STATE1` reader - Comparator 1 Current State"]
6pub type State1R = crate::BitReader;
7#[doc = "Window 0 Current State\n\nValue on reset: 0"]
8#[derive(Clone, Copy, Debug, PartialEq, Eq)]
9#[repr(u8)]
10pub enum Wstate0select {
11    #[doc = "0: Signal is above window"]
12    Above = 0,
13    #[doc = "1: Signal is inside window"]
14    Inside = 1,
15    #[doc = "2: Signal is below window"]
16    Below = 2,
17}
18impl From<Wstate0select> for u8 {
19    #[inline(always)]
20    fn from(variant: Wstate0select) -> Self {
21        variant as _
22    }
23}
24impl crate::FieldSpec for Wstate0select {
25    type Ux = u8;
26}
27impl crate::IsEnum for Wstate0select {}
28#[doc = "Field `WSTATE0` reader - Window 0 Current State"]
29pub type Wstate0R = crate::FieldReader<Wstate0select>;
30impl Wstate0R {
31    #[doc = "Get enumerated values variant"]
32    #[inline(always)]
33    pub const fn variant(&self) -> Option<Wstate0select> {
34        match self.bits {
35            0 => Some(Wstate0select::Above),
36            1 => Some(Wstate0select::Inside),
37            2 => Some(Wstate0select::Below),
38            _ => None,
39        }
40    }
41    #[doc = "Signal is above window"]
42    #[inline(always)]
43    pub fn is_above(&self) -> bool {
44        *self == Wstate0select::Above
45    }
46    #[doc = "Signal is inside window"]
47    #[inline(always)]
48    pub fn is_inside(&self) -> bool {
49        *self == Wstate0select::Inside
50    }
51    #[doc = "Signal is below window"]
52    #[inline(always)]
53    pub fn is_below(&self) -> bool {
54        *self == Wstate0select::Below
55    }
56}
57impl R {
58    #[doc = "Bit 0 - Comparator 0 Current State"]
59    #[inline(always)]
60    pub fn state0(&self) -> State0R {
61        State0R::new((self.bits & 1) != 0)
62    }
63    #[doc = "Bit 1 - Comparator 1 Current State"]
64    #[inline(always)]
65    pub fn state1(&self) -> State1R {
66        State1R::new(((self.bits >> 1) & 1) != 0)
67    }
68    #[doc = "Bits 4:5 - Window 0 Current State"]
69    #[inline(always)]
70    pub fn wstate0(&self) -> Wstate0R {
71        Wstate0R::new((self.bits >> 4) & 3)
72    }
73}
74#[doc = "Status C\n\nYou can [`read`](crate::Reg::read) this register and get [`statusc::R`](R). See [API](https://docs.rs/svd2rust/#read--modify--write-api)."]
75pub struct StatuscSpec;
76impl crate::RegisterSpec for StatuscSpec {
77    type Ux = u8;
78}
79#[doc = "`read()` method returns [`statusc::R`](R) reader structure"]
80impl crate::Readable for StatuscSpec {}
81#[doc = "`reset()` method sets STATUSC to value 0"]
82impl crate::Resettable for StatuscSpec {
83    const RESET_VALUE: u8 = 0;
84}