mimxrt685s_pac/ahb_secure_ctrl/
security_ctrl_mem_rule0.rs

1#[doc = "Register `SECURITY_CTRL_MEM_RULE0` reader"]
2pub type R = crate::R<SecurityCtrlMemRule0Spec>;
3#[doc = "Register `SECURITY_CTRL_MEM_RULE0` writer"]
4pub type W = crate::W<SecurityCtrlMemRule0Spec>;
5#[doc = "Field `RULE0` reader - secure control rule0. it can be set when check_reg's write_lock is '0'"]
6pub type Rule0R = crate::FieldReader;
7#[doc = "Field `RULE0` writer - secure control rule0. it can be set when check_reg's write_lock is '0'"]
8pub type Rule0W<'a, REG> = crate::FieldWriter<'a, REG, 2>;
9#[doc = "Field `RULE1` reader - secure control rule0. it can be set when check_reg's write_lock is '0'"]
10pub type Rule1R = crate::FieldReader;
11#[doc = "Field `RULE1` writer - secure control rule0. it can be set when check_reg's write_lock is '0'"]
12pub type Rule1W<'a, REG> = crate::FieldWriter<'a, REG, 2>;
13#[doc = "Field `RULE2` reader - secure control rule0. it can be set when check_reg's write_lock is '0'"]
14pub type Rule2R = crate::FieldReader;
15#[doc = "Field `RULE2` writer - secure control rule0. it can be set when check_reg's write_lock is '0'"]
16pub type Rule2W<'a, REG> = crate::FieldWriter<'a, REG, 2>;
17#[doc = "Field `RULE3` reader - secure control rule0. it can be set when check_reg's write_lock is '0'"]
18pub type Rule3R = crate::FieldReader;
19#[doc = "Field `RULE3` writer - secure control rule0. it can be set when check_reg's write_lock is '0'"]
20pub type Rule3W<'a, REG> = crate::FieldWriter<'a, REG, 2>;
21impl R {
22    #[doc = "Bits 0:1 - secure control rule0. it can be set when check_reg's write_lock is '0'"]
23    #[inline(always)]
24    pub fn rule0(&self) -> Rule0R {
25        Rule0R::new((self.bits & 3) as u8)
26    }
27    #[doc = "Bits 4:5 - secure control rule0. it can be set when check_reg's write_lock is '0'"]
28    #[inline(always)]
29    pub fn rule1(&self) -> Rule1R {
30        Rule1R::new(((self.bits >> 4) & 3) as u8)
31    }
32    #[doc = "Bits 8:9 - secure control rule0. it can be set when check_reg's write_lock is '0'"]
33    #[inline(always)]
34    pub fn rule2(&self) -> Rule2R {
35        Rule2R::new(((self.bits >> 8) & 3) as u8)
36    }
37    #[doc = "Bits 12:13 - secure control rule0. it can be set when check_reg's write_lock is '0'"]
38    #[inline(always)]
39    pub fn rule3(&self) -> Rule3R {
40        Rule3R::new(((self.bits >> 12) & 3) as u8)
41    }
42}
43#[cfg(feature = "debug")]
44impl core::fmt::Debug for R {
45    fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
46        f.debug_struct("SECURITY_CTRL_MEM_RULE0")
47            .field("rule0", &self.rule0())
48            .field("rule1", &self.rule1())
49            .field("rule2", &self.rule2())
50            .field("rule3", &self.rule3())
51            .finish()
52    }
53}
54impl W {
55    #[doc = "Bits 0:1 - secure control rule0. it can be set when check_reg's write_lock is '0'"]
56    #[inline(always)]
57    pub fn rule0(&mut self) -> Rule0W<SecurityCtrlMemRule0Spec> {
58        Rule0W::new(self, 0)
59    }
60    #[doc = "Bits 4:5 - secure control rule0. it can be set when check_reg's write_lock is '0'"]
61    #[inline(always)]
62    pub fn rule1(&mut self) -> Rule1W<SecurityCtrlMemRule0Spec> {
63        Rule1W::new(self, 4)
64    }
65    #[doc = "Bits 8:9 - secure control rule0. it can be set when check_reg's write_lock is '0'"]
66    #[inline(always)]
67    pub fn rule2(&mut self) -> Rule2W<SecurityCtrlMemRule0Spec> {
68        Rule2W::new(self, 8)
69    }
70    #[doc = "Bits 12:13 - secure control rule0. it can be set when check_reg's write_lock is '0'"]
71    #[inline(always)]
72    pub fn rule3(&mut self) -> Rule3W<SecurityCtrlMemRule0Spec> {
73        Rule3W::new(self, 12)
74    }
75}
76#[doc = "0x40148000--0x4014BFFF\n\nYou can [`read`](crate::Reg::read) this register and get [`security_ctrl_mem_rule0::R`](R). You can [`reset`](crate::Reg::reset), [`write`](crate::Reg::write), [`write_with_zero`](crate::Reg::write_with_zero) this register using [`security_ctrl_mem_rule0::W`](W). You can also [`modify`](crate::Reg::modify) this register. See [API](https://docs.rs/svd2rust/#read--modify--write-api)."]
77pub struct SecurityCtrlMemRule0Spec;
78impl crate::RegisterSpec for SecurityCtrlMemRule0Spec {
79    type Ux = u32;
80}
81#[doc = "`read()` method returns [`security_ctrl_mem_rule0::R`](R) reader structure"]
82impl crate::Readable for SecurityCtrlMemRule0Spec {}
83#[doc = "`write(|w| ..)` method takes [`security_ctrl_mem_rule0::W`](W) writer structure"]
84impl crate::Writable for SecurityCtrlMemRule0Spec {
85    type Safety = crate::Unsafe;
86    const ZERO_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
87    const ONE_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
88}
89#[doc = "`reset()` method sets SECURITY_CTRL_MEM_RULE0 to value 0"]
90impl crate::Resettable for SecurityCtrlMemRule0Spec {
91    const RESET_VALUE: u32 = 0;
92}