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}