cyt4bf_d/m7/crypto/
vu_ctl0.rs

1#[doc = "Register `VU_CTL0` reader"]
2pub struct R(crate::R<VU_CTL0_SPEC>);
3impl core::ops::Deref for R {
4    type Target = crate::R<VU_CTL0_SPEC>;
5    #[inline(always)]
6    fn deref(&self) -> &Self::Target {
7        &self.0
8    }
9}
10impl From<crate::R<VU_CTL0_SPEC>> for R {
11    #[inline(always)]
12    fn from(reader: crate::R<VU_CTL0_SPEC>) -> Self {
13        R(reader)
14    }
15}
16#[doc = "Register `VU_CTL0` writer"]
17pub struct W(crate::W<VU_CTL0_SPEC>);
18impl core::ops::Deref for W {
19    type Target = crate::W<VU_CTL0_SPEC>;
20    #[inline(always)]
21    fn deref(&self) -> &Self::Target {
22        &self.0
23    }
24}
25impl core::ops::DerefMut for W {
26    #[inline(always)]
27    fn deref_mut(&mut self) -> &mut Self::Target {
28        &mut self.0
29    }
30}
31impl From<crate::W<VU_CTL0_SPEC>> for W {
32    #[inline(always)]
33    fn from(writer: crate::W<VU_CTL0_SPEC>) -> Self {
34        W(writer)
35    }
36}
37#[doc = "Field `ALWAYS_EXECUTE` reader - Specifies if a conditional instruction is executed or not, when its condition code evaluates to false/'0'. '0': The instruction is NOT executed. As a result, the instruction may be handled faster than when it is executed. '1': The instruction is executed, but the execution result (including status field information) is not reflected in the IP. The instruction is handled just as fast as when it is executed. Note: a conditional instruction with a condition code that evaluates to false/'0' does not affect the architectural state: VU_STATUS fields, memory or register-file data. Note: Always execution is useful to prevent/complicate differential timing and differential power attacks."]
38pub type ALWAYS_EXECUTE_R = crate::BitReader<bool>;
39#[doc = "Field `ALWAYS_EXECUTE` writer - Specifies if a conditional instruction is executed or not, when its condition code evaluates to false/'0'. '0': The instruction is NOT executed. As a result, the instruction may be handled faster than when it is executed. '1': The instruction is executed, but the execution result (including status field information) is not reflected in the IP. The instruction is handled just as fast as when it is executed. Note: a conditional instruction with a condition code that evaluates to false/'0' does not affect the architectural state: VU_STATUS fields, memory or register-file data. Note: Always execution is useful to prevent/complicate differential timing and differential power attacks."]
40pub type ALWAYS_EXECUTE_W<'a, const O: u8> = crate::BitWriter<'a, u32, VU_CTL0_SPEC, bool, O>;
41impl R {
42    #[doc = "Bit 0 - Specifies if a conditional instruction is executed or not, when its condition code evaluates to false/'0'. '0': The instruction is NOT executed. As a result, the instruction may be handled faster than when it is executed. '1': The instruction is executed, but the execution result (including status field information) is not reflected in the IP. The instruction is handled just as fast as when it is executed. Note: a conditional instruction with a condition code that evaluates to false/'0' does not affect the architectural state: VU_STATUS fields, memory or register-file data. Note: Always execution is useful to prevent/complicate differential timing and differential power attacks."]
43    #[inline(always)]
44    pub fn always_execute(&self) -> ALWAYS_EXECUTE_R {
45        ALWAYS_EXECUTE_R::new((self.bits & 1) != 0)
46    }
47}
48impl W {
49    #[doc = "Bit 0 - Specifies if a conditional instruction is executed or not, when its condition code evaluates to false/'0'. '0': The instruction is NOT executed. As a result, the instruction may be handled faster than when it is executed. '1': The instruction is executed, but the execution result (including status field information) is not reflected in the IP. The instruction is handled just as fast as when it is executed. Note: a conditional instruction with a condition code that evaluates to false/'0' does not affect the architectural state: VU_STATUS fields, memory or register-file data. Note: Always execution is useful to prevent/complicate differential timing and differential power attacks."]
50    #[inline(always)]
51    #[must_use]
52    pub fn always_execute(&mut self) -> ALWAYS_EXECUTE_W<0> {
53        ALWAYS_EXECUTE_W::new(self)
54    }
55    #[doc = "Writes raw bits to the register."]
56    #[inline(always)]
57    pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
58        self.0.bits(bits);
59        self
60    }
61}
62#[doc = "Vector unit control 0\n\nThis register you can [`read`](crate::generic::Reg::read), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [vu_ctl0](index.html) module"]
63pub struct VU_CTL0_SPEC;
64impl crate::RegisterSpec for VU_CTL0_SPEC {
65    type Ux = u32;
66}
67#[doc = "`read()` method returns [vu_ctl0::R](R) reader structure"]
68impl crate::Readable for VU_CTL0_SPEC {
69    type Reader = R;
70}
71#[doc = "`write(|w| ..)` method takes [vu_ctl0::W](W) writer structure"]
72impl crate::Writable for VU_CTL0_SPEC {
73    type Writer = W;
74    const ZERO_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0;
75    const ONE_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0;
76}
77#[doc = "`reset()` method sets VU_CTL0 to value 0"]
78impl crate::Resettable for VU_CTL0_SPEC {
79    const RESET_VALUE: Self::Ux = 0;
80}