efm32gg_pac/efm32gg995/prs/
swpulse.rs

1#[doc = "Register `SWPULSE` writer"]
2pub struct W(crate::W<SWPULSE_SPEC>);
3impl core::ops::Deref for W {
4    type Target = crate::W<SWPULSE_SPEC>;
5    #[inline(always)]
6    fn deref(&self) -> &Self::Target {
7        &self.0
8    }
9}
10impl core::ops::DerefMut for W {
11    #[inline(always)]
12    fn deref_mut(&mut self) -> &mut Self::Target {
13        &mut self.0
14    }
15}
16impl From<crate::W<SWPULSE_SPEC>> for W {
17    #[inline(always)]
18    fn from(writer: crate::W<SWPULSE_SPEC>) -> Self {
19        W(writer)
20    }
21}
22#[doc = "Field `CH0PULSE` writer - Channel 0 Pulse Generation"]
23pub type CH0PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
24#[doc = "Field `CH1PULSE` writer - Channel 1 Pulse Generation"]
25pub type CH1PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
26#[doc = "Field `CH2PULSE` writer - Channel 2 Pulse Generation"]
27pub type CH2PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
28#[doc = "Field `CH3PULSE` writer - Channel 3 Pulse Generation"]
29pub type CH3PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
30#[doc = "Field `CH4PULSE` writer - Channel 4 Pulse Generation"]
31pub type CH4PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
32#[doc = "Field `CH5PULSE` writer - Channel 5 Pulse Generation"]
33pub type CH5PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
34#[doc = "Field `CH6PULSE` writer - Channel 6 Pulse Generation"]
35pub type CH6PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
36#[doc = "Field `CH7PULSE` writer - Channel 7 Pulse Generation"]
37pub type CH7PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
38#[doc = "Field `CH8PULSE` writer - Channel 8 Pulse Generation"]
39pub type CH8PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
40#[doc = "Field `CH9PULSE` writer - Channel 9 Pulse Generation"]
41pub type CH9PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
42#[doc = "Field `CH10PULSE` writer - Channel 10 Pulse Generation"]
43pub type CH10PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
44#[doc = "Field `CH11PULSE` writer - Channel 11 Pulse Generation"]
45pub type CH11PULSE_W<'a, const O: u8> = crate::BitWriter<'a, u32, SWPULSE_SPEC, bool, O>;
46impl W {
47    #[doc = "Bit 0 - Channel 0 Pulse Generation"]
48    #[inline(always)]
49    #[must_use]
50    pub fn ch0pulse(&mut self) -> CH0PULSE_W<0> {
51        CH0PULSE_W::new(self)
52    }
53    #[doc = "Bit 1 - Channel 1 Pulse Generation"]
54    #[inline(always)]
55    #[must_use]
56    pub fn ch1pulse(&mut self) -> CH1PULSE_W<1> {
57        CH1PULSE_W::new(self)
58    }
59    #[doc = "Bit 2 - Channel 2 Pulse Generation"]
60    #[inline(always)]
61    #[must_use]
62    pub fn ch2pulse(&mut self) -> CH2PULSE_W<2> {
63        CH2PULSE_W::new(self)
64    }
65    #[doc = "Bit 3 - Channel 3 Pulse Generation"]
66    #[inline(always)]
67    #[must_use]
68    pub fn ch3pulse(&mut self) -> CH3PULSE_W<3> {
69        CH3PULSE_W::new(self)
70    }
71    #[doc = "Bit 4 - Channel 4 Pulse Generation"]
72    #[inline(always)]
73    #[must_use]
74    pub fn ch4pulse(&mut self) -> CH4PULSE_W<4> {
75        CH4PULSE_W::new(self)
76    }
77    #[doc = "Bit 5 - Channel 5 Pulse Generation"]
78    #[inline(always)]
79    #[must_use]
80    pub fn ch5pulse(&mut self) -> CH5PULSE_W<5> {
81        CH5PULSE_W::new(self)
82    }
83    #[doc = "Bit 6 - Channel 6 Pulse Generation"]
84    #[inline(always)]
85    #[must_use]
86    pub fn ch6pulse(&mut self) -> CH6PULSE_W<6> {
87        CH6PULSE_W::new(self)
88    }
89    #[doc = "Bit 7 - Channel 7 Pulse Generation"]
90    #[inline(always)]
91    #[must_use]
92    pub fn ch7pulse(&mut self) -> CH7PULSE_W<7> {
93        CH7PULSE_W::new(self)
94    }
95    #[doc = "Bit 8 - Channel 8 Pulse Generation"]
96    #[inline(always)]
97    #[must_use]
98    pub fn ch8pulse(&mut self) -> CH8PULSE_W<8> {
99        CH8PULSE_W::new(self)
100    }
101    #[doc = "Bit 9 - Channel 9 Pulse Generation"]
102    #[inline(always)]
103    #[must_use]
104    pub fn ch9pulse(&mut self) -> CH9PULSE_W<9> {
105        CH9PULSE_W::new(self)
106    }
107    #[doc = "Bit 10 - Channel 10 Pulse Generation"]
108    #[inline(always)]
109    #[must_use]
110    pub fn ch10pulse(&mut self) -> CH10PULSE_W<10> {
111        CH10PULSE_W::new(self)
112    }
113    #[doc = "Bit 11 - Channel 11 Pulse Generation"]
114    #[inline(always)]
115    #[must_use]
116    pub fn ch11pulse(&mut self) -> CH11PULSE_W<11> {
117        CH11PULSE_W::new(self)
118    }
119    #[doc = "Writes raw bits to the register."]
120    #[inline(always)]
121    pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
122        self.0.bits(bits);
123        self
124    }
125}
126#[doc = "Software Pulse Register\n\nThis register you can [`write_with_zero`](crate::generic::Reg::write_with_zero), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [swpulse](index.html) module"]
127pub struct SWPULSE_SPEC;
128impl crate::RegisterSpec for SWPULSE_SPEC {
129    type Ux = u32;
130}
131#[doc = "`write(|w| ..)` method takes [swpulse::W](W) writer structure"]
132impl crate::Writable for SWPULSE_SPEC {
133    type Writer = W;
134    const ZERO_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0;
135    const ONE_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0;
136}
137#[doc = "`reset()` method sets SWPULSE to value 0"]
138impl crate::Resettable for SWPULSE_SPEC {
139    const RESET_VALUE: Self::Ux = 0;
140}