1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#[doc = "Register `WPSR` reader"]
pub struct R(crate::R<WPSR_SPEC>);
impl core::ops::Deref for R {
    type Target = crate::R<WPSR_SPEC>;
    #[inline(always)]
    fn deref(&self) -> &Self::Target {
        &self.0
    }
}
impl From<crate::R<WPSR_SPEC>> for R {
    #[inline(always)]
    fn from(reader: crate::R<WPSR_SPEC>) -> Self {
        R(reader)
    }
}
#[doc = "Field `WPVS` reader - Write Protection Violation Status"]
pub type WPVS_R = crate::FieldReader<u8, WPVSSELECT_A>;
#[doc = "Write Protection Violation Status\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
#[repr(u8)]
pub enum WPVSSELECT_A {
    #[doc = "1: The Write Protection has blocked a Write access to a protected register (since the last read)."]
    WRITE_WITH_WP = 1,
    #[doc = "2: Software Reset has been performed while Write Protection was enabled (since the last read or since the last write access on MR, IER, IDR or CSRx)."]
    SWRST_WITH_WP = 2,
    #[doc = "4: Write accesses have been detected on MR (while a chip select was active) or on CSRi (while the Chip Select \"i\" was active) since the last read."]
    UNEXPECTED_WRITE = 4,
}
impl From<WPVSSELECT_A> for u8 {
    #[inline(always)]
    fn from(variant: WPVSSELECT_A) -> Self {
        variant as _
    }
}
impl WPVS_R {
    #[doc = "Get enumerated values variant"]
    #[inline(always)]
    pub fn variant(&self) -> Option<WPVSSELECT_A> {
        match self.bits {
            1 => Some(WPVSSELECT_A::WRITE_WITH_WP),
            2 => Some(WPVSSELECT_A::SWRST_WITH_WP),
            4 => Some(WPVSSELECT_A::UNEXPECTED_WRITE),
            _ => None,
        }
    }
    #[doc = "Checks if the value of the field is `WRITE_WITH_WP`"]
    #[inline(always)]
    pub fn is_write_with_wp(&self) -> bool {
        *self == WPVSSELECT_A::WRITE_WITH_WP
    }
    #[doc = "Checks if the value of the field is `SWRST_WITH_WP`"]
    #[inline(always)]
    pub fn is_swrst_with_wp(&self) -> bool {
        *self == WPVSSELECT_A::SWRST_WITH_WP
    }
    #[doc = "Checks if the value of the field is `UNEXPECTED_WRITE`"]
    #[inline(always)]
    pub fn is_unexpected_write(&self) -> bool {
        *self == WPVSSELECT_A::UNEXPECTED_WRITE
    }
}
#[doc = "Field `WPVSRC` reader - Write Protection Violation Source"]
pub type WPVSRC_R = crate::FieldReader<u8, u8>;
impl R {
    #[doc = "Bits 0:2 - Write Protection Violation Status"]
    #[inline(always)]
    pub fn wpvs(&self) -> WPVS_R {
        WPVS_R::new((self.bits & 7) as u8)
    }
    #[doc = "Bits 8:15 - Write Protection Violation Source"]
    #[inline(always)]
    pub fn wpvsrc(&self) -> WPVSRC_R {
        WPVSRC_R::new(((self.bits >> 8) & 0xff) as u8)
    }
}
#[doc = "Write Protection status 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 [wpsr](index.html) module"]
pub struct WPSR_SPEC;
impl crate::RegisterSpec for WPSR_SPEC {
    type Ux = u32;
}
#[doc = "`read()` method returns [wpsr::R](R) reader structure"]
impl crate::Readable for WPSR_SPEC {
    type Reader = R;
}
#[doc = "`reset()` method sets WPSR to value 0"]
impl crate::Resettable for WPSR_SPEC {
    const RESET_VALUE: Self::Ux = 0;
}