swm341_pac/sys/
clken0.rs

1#[doc = "Register `CLKEN0` reader"]
2pub struct R(crate::R<CLKEN0_SPEC>);
3impl core::ops::Deref for R {
4    type Target = crate::R<CLKEN0_SPEC>;
5    #[inline(always)]
6    fn deref(&self) -> &Self::Target {
7        &self.0
8    }
9}
10impl From<crate::R<CLKEN0_SPEC>> for R {
11    #[inline(always)]
12    fn from(reader: crate::R<CLKEN0_SPEC>) -> Self {
13        R(reader)
14    }
15}
16#[doc = "Register `CLKEN0` writer"]
17pub struct W(crate::W<CLKEN0_SPEC>);
18impl core::ops::Deref for W {
19    type Target = crate::W<CLKEN0_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<CLKEN0_SPEC>> for W {
32    #[inline(always)]
33    fn from(writer: crate::W<CLKEN0_SPEC>) -> Self {
34        W(writer)
35    }
36}
37#[doc = "Field `GPIOA` reader - GPIOA field"]
38pub type GPIOA_R = crate::BitReader<bool>;
39#[doc = "Field `GPIOA` writer - GPIOA field"]
40pub type GPIOA_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
41#[doc = "Field `GPIOB` reader - GPIOB field"]
42pub type GPIOB_R = crate::BitReader<bool>;
43#[doc = "Field `GPIOB` writer - GPIOB field"]
44pub type GPIOB_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
45#[doc = "Field `GPIOC` reader - GPIOC field"]
46pub type GPIOC_R = crate::BitReader<bool>;
47#[doc = "Field `GPIOC` writer - GPIOC field"]
48pub type GPIOC_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
49#[doc = "Field `GPIOD` reader - GPIOD field"]
50pub type GPIOD_R = crate::BitReader<bool>;
51#[doc = "Field `GPIOD` writer - GPIOD field"]
52pub type GPIOD_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
53#[doc = "Field `GPIOM` reader - GPIOM field"]
54pub type GPIOM_R = crate::BitReader<bool>;
55#[doc = "Field `GPIOM` writer - GPIOM field"]
56pub type GPIOM_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
57#[doc = "Field `GPION` reader - GPION field"]
58pub type GPION_R = crate::BitReader<bool>;
59#[doc = "Field `GPION` writer - GPION field"]
60pub type GPION_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
61#[doc = "Field `UART0` reader - UART0 field"]
62pub type UART0_R = crate::BitReader<bool>;
63#[doc = "Field `UART0` writer - UART0 field"]
64pub type UART0_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
65#[doc = "Field `UART1` reader - UART1 field"]
66pub type UART1_R = crate::BitReader<bool>;
67#[doc = "Field `UART1` writer - UART1 field"]
68pub type UART1_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
69#[doc = "Field `UART2` reader - UART2 field"]
70pub type UART2_R = crate::BitReader<bool>;
71#[doc = "Field `UART2` writer - UART2 field"]
72pub type UART2_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
73#[doc = "Field `UART3` reader - UART3 field"]
74pub type UART3_R = crate::BitReader<bool>;
75#[doc = "Field `UART3` writer - UART3 field"]
76pub type UART3_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
77#[doc = "Field `WDT` reader - WDT field"]
78pub type WDT_R = crate::BitReader<bool>;
79#[doc = "Field `WDT` writer - WDT field"]
80pub type WDT_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
81#[doc = "Field `TIMR` reader - TIMR field"]
82pub type TIMR_R = crate::BitReader<bool>;
83#[doc = "Field `TIMR` writer - TIMR field"]
84pub type TIMR_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
85#[doc = "Field `PWM` reader - PWM field"]
86pub type PWM_R = crate::BitReader<bool>;
87#[doc = "Field `PWM` writer - PWM field"]
88pub type PWM_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
89#[doc = "Field `SPI0` reader - SPI0 field"]
90pub type SPI0_R = crate::BitReader<bool>;
91#[doc = "Field `SPI0` writer - SPI0 field"]
92pub type SPI0_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
93#[doc = "Field `SPI1` reader - SPI1 field"]
94pub type SPI1_R = crate::BitReader<bool>;
95#[doc = "Field `SPI1` writer - SPI1 field"]
96pub type SPI1_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
97#[doc = "Field `I2C0` reader - I2C0 field"]
98pub type I2C0_R = crate::BitReader<bool>;
99#[doc = "Field `I2C0` writer - I2C0 field"]
100pub type I2C0_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
101#[doc = "Field `I2C1` reader - I2C1 field"]
102pub type I2C1_R = crate::BitReader<bool>;
103#[doc = "Field `I2C1` writer - I2C1 field"]
104pub type I2C1_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
105#[doc = "Field `CRC` reader - CRC field"]
106pub type CRC_R = crate::BitReader<bool>;
107#[doc = "Field `CRC` writer - CRC field"]
108pub type CRC_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
109#[doc = "Field `CORDIC` reader - CORDIC field"]
110pub type CORDIC_R = crate::BitReader<bool>;
111#[doc = "Field `CORDIC` writer - CORDIC field"]
112pub type CORDIC_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
113#[doc = "Field `DIV` reader - DIV field"]
114pub type DIV_R = crate::BitReader<bool>;
115#[doc = "Field `DIV` writer - DIV field"]
116pub type DIV_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
117#[doc = "Field `SDIO` reader - SDIO field"]
118pub type SDIO_R = crate::BitReader<bool>;
119#[doc = "Field `SDIO` writer - SDIO field"]
120pub type SDIO_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
121#[doc = "Field `USB` reader - USB field"]
122pub type USB_R = crate::BitReader<bool>;
123#[doc = "Field `USB` writer - USB field"]
124pub type USB_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
125#[doc = "Field `ANAC` reader - ANAC field"]
126pub type ANAC_R = crate::BitReader<bool>;
127#[doc = "Field `ANAC` writer - ANAC field"]
128pub type ANAC_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
129#[doc = "Field `ADC0` reader - ADC0 field"]
130pub type ADC0_R = crate::BitReader<bool>;
131#[doc = "Field `ADC0` writer - ADC0 field"]
132pub type ADC0_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
133#[doc = "Field `CAN0` reader - CAN0 field"]
134pub type CAN0_R = crate::BitReader<bool>;
135#[doc = "Field `CAN0` writer - CAN0 field"]
136pub type CAN0_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
137#[doc = "Field `DMA2D` reader - DMA2D field"]
138pub type DMA2D_R = crate::BitReader<bool>;
139#[doc = "Field `DMA2D` writer - DMA2D field"]
140pub type DMA2D_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
141#[doc = "Field `LCD` reader - LCD field"]
142pub type LCD_R = crate::BitReader<bool>;
143#[doc = "Field `LCD` writer - LCD field"]
144pub type LCD_W<'a, const O: u8> = crate::BitWriter<'a, u32, CLKEN0_SPEC, bool, O>;
145impl R {
146    #[doc = "Bit 0 - GPIOA field"]
147    #[inline(always)]
148    pub fn gpioa(&self) -> GPIOA_R {
149        GPIOA_R::new((self.bits & 1) != 0)
150    }
151    #[doc = "Bit 1 - GPIOB field"]
152    #[inline(always)]
153    pub fn gpiob(&self) -> GPIOB_R {
154        GPIOB_R::new(((self.bits >> 1) & 1) != 0)
155    }
156    #[doc = "Bit 2 - GPIOC field"]
157    #[inline(always)]
158    pub fn gpioc(&self) -> GPIOC_R {
159        GPIOC_R::new(((self.bits >> 2) & 1) != 0)
160    }
161    #[doc = "Bit 3 - GPIOD field"]
162    #[inline(always)]
163    pub fn gpiod(&self) -> GPIOD_R {
164        GPIOD_R::new(((self.bits >> 3) & 1) != 0)
165    }
166    #[doc = "Bit 4 - GPIOM field"]
167    #[inline(always)]
168    pub fn gpiom(&self) -> GPIOM_R {
169        GPIOM_R::new(((self.bits >> 4) & 1) != 0)
170    }
171    #[doc = "Bit 5 - GPION field"]
172    #[inline(always)]
173    pub fn gpion(&self) -> GPION_R {
174        GPION_R::new(((self.bits >> 5) & 1) != 0)
175    }
176    #[doc = "Bit 6 - UART0 field"]
177    #[inline(always)]
178    pub fn uart0(&self) -> UART0_R {
179        UART0_R::new(((self.bits >> 6) & 1) != 0)
180    }
181    #[doc = "Bit 7 - UART1 field"]
182    #[inline(always)]
183    pub fn uart1(&self) -> UART1_R {
184        UART1_R::new(((self.bits >> 7) & 1) != 0)
185    }
186    #[doc = "Bit 8 - UART2 field"]
187    #[inline(always)]
188    pub fn uart2(&self) -> UART2_R {
189        UART2_R::new(((self.bits >> 8) & 1) != 0)
190    }
191    #[doc = "Bit 9 - UART3 field"]
192    #[inline(always)]
193    pub fn uart3(&self) -> UART3_R {
194        UART3_R::new(((self.bits >> 9) & 1) != 0)
195    }
196    #[doc = "Bit 10 - WDT field"]
197    #[inline(always)]
198    pub fn wdt(&self) -> WDT_R {
199        WDT_R::new(((self.bits >> 10) & 1) != 0)
200    }
201    #[doc = "Bit 11 - TIMR field"]
202    #[inline(always)]
203    pub fn timr(&self) -> TIMR_R {
204        TIMR_R::new(((self.bits >> 11) & 1) != 0)
205    }
206    #[doc = "Bit 12 - PWM field"]
207    #[inline(always)]
208    pub fn pwm(&self) -> PWM_R {
209        PWM_R::new(((self.bits >> 12) & 1) != 0)
210    }
211    #[doc = "Bit 13 - SPI0 field"]
212    #[inline(always)]
213    pub fn spi0(&self) -> SPI0_R {
214        SPI0_R::new(((self.bits >> 13) & 1) != 0)
215    }
216    #[doc = "Bit 14 - SPI1 field"]
217    #[inline(always)]
218    pub fn spi1(&self) -> SPI1_R {
219        SPI1_R::new(((self.bits >> 14) & 1) != 0)
220    }
221    #[doc = "Bit 15 - I2C0 field"]
222    #[inline(always)]
223    pub fn i2c0(&self) -> I2C0_R {
224        I2C0_R::new(((self.bits >> 15) & 1) != 0)
225    }
226    #[doc = "Bit 16 - I2C1 field"]
227    #[inline(always)]
228    pub fn i2c1(&self) -> I2C1_R {
229        I2C1_R::new(((self.bits >> 16) & 1) != 0)
230    }
231    #[doc = "Bit 19 - CRC field"]
232    #[inline(always)]
233    pub fn crc(&self) -> CRC_R {
234        CRC_R::new(((self.bits >> 19) & 1) != 0)
235    }
236    #[doc = "Bit 20 - CORDIC field"]
237    #[inline(always)]
238    pub fn cordic(&self) -> CORDIC_R {
239        CORDIC_R::new(((self.bits >> 20) & 1) != 0)
240    }
241    #[doc = "Bit 21 - DIV field"]
242    #[inline(always)]
243    pub fn div(&self) -> DIV_R {
244        DIV_R::new(((self.bits >> 21) & 1) != 0)
245    }
246    #[doc = "Bit 22 - SDIO field"]
247    #[inline(always)]
248    pub fn sdio(&self) -> SDIO_R {
249        SDIO_R::new(((self.bits >> 22) & 1) != 0)
250    }
251    #[doc = "Bit 24 - USB field"]
252    #[inline(always)]
253    pub fn usb(&self) -> USB_R {
254        USB_R::new(((self.bits >> 24) & 1) != 0)
255    }
256    #[doc = "Bit 25 - ANAC field"]
257    #[inline(always)]
258    pub fn anac(&self) -> ANAC_R {
259        ANAC_R::new(((self.bits >> 25) & 1) != 0)
260    }
261    #[doc = "Bit 26 - ADC0 field"]
262    #[inline(always)]
263    pub fn adc0(&self) -> ADC0_R {
264        ADC0_R::new(((self.bits >> 26) & 1) != 0)
265    }
266    #[doc = "Bit 28 - CAN0 field"]
267    #[inline(always)]
268    pub fn can0(&self) -> CAN0_R {
269        CAN0_R::new(((self.bits >> 28) & 1) != 0)
270    }
271    #[doc = "Bit 29 - DMA2D field"]
272    #[inline(always)]
273    pub fn dma2d(&self) -> DMA2D_R {
274        DMA2D_R::new(((self.bits >> 29) & 1) != 0)
275    }
276    #[doc = "Bit 30 - LCD field"]
277    #[inline(always)]
278    pub fn lcd(&self) -> LCD_R {
279        LCD_R::new(((self.bits >> 30) & 1) != 0)
280    }
281}
282impl W {
283    #[doc = "Bit 0 - GPIOA field"]
284    #[inline(always)]
285    pub fn gpioa(&mut self) -> GPIOA_W<0> {
286        GPIOA_W::new(self)
287    }
288    #[doc = "Bit 1 - GPIOB field"]
289    #[inline(always)]
290    pub fn gpiob(&mut self) -> GPIOB_W<1> {
291        GPIOB_W::new(self)
292    }
293    #[doc = "Bit 2 - GPIOC field"]
294    #[inline(always)]
295    pub fn gpioc(&mut self) -> GPIOC_W<2> {
296        GPIOC_W::new(self)
297    }
298    #[doc = "Bit 3 - GPIOD field"]
299    #[inline(always)]
300    pub fn gpiod(&mut self) -> GPIOD_W<3> {
301        GPIOD_W::new(self)
302    }
303    #[doc = "Bit 4 - GPIOM field"]
304    #[inline(always)]
305    pub fn gpiom(&mut self) -> GPIOM_W<4> {
306        GPIOM_W::new(self)
307    }
308    #[doc = "Bit 5 - GPION field"]
309    #[inline(always)]
310    pub fn gpion(&mut self) -> GPION_W<5> {
311        GPION_W::new(self)
312    }
313    #[doc = "Bit 6 - UART0 field"]
314    #[inline(always)]
315    pub fn uart0(&mut self) -> UART0_W<6> {
316        UART0_W::new(self)
317    }
318    #[doc = "Bit 7 - UART1 field"]
319    #[inline(always)]
320    pub fn uart1(&mut self) -> UART1_W<7> {
321        UART1_W::new(self)
322    }
323    #[doc = "Bit 8 - UART2 field"]
324    #[inline(always)]
325    pub fn uart2(&mut self) -> UART2_W<8> {
326        UART2_W::new(self)
327    }
328    #[doc = "Bit 9 - UART3 field"]
329    #[inline(always)]
330    pub fn uart3(&mut self) -> UART3_W<9> {
331        UART3_W::new(self)
332    }
333    #[doc = "Bit 10 - WDT field"]
334    #[inline(always)]
335    pub fn wdt(&mut self) -> WDT_W<10> {
336        WDT_W::new(self)
337    }
338    #[doc = "Bit 11 - TIMR field"]
339    #[inline(always)]
340    pub fn timr(&mut self) -> TIMR_W<11> {
341        TIMR_W::new(self)
342    }
343    #[doc = "Bit 12 - PWM field"]
344    #[inline(always)]
345    pub fn pwm(&mut self) -> PWM_W<12> {
346        PWM_W::new(self)
347    }
348    #[doc = "Bit 13 - SPI0 field"]
349    #[inline(always)]
350    pub fn spi0(&mut self) -> SPI0_W<13> {
351        SPI0_W::new(self)
352    }
353    #[doc = "Bit 14 - SPI1 field"]
354    #[inline(always)]
355    pub fn spi1(&mut self) -> SPI1_W<14> {
356        SPI1_W::new(self)
357    }
358    #[doc = "Bit 15 - I2C0 field"]
359    #[inline(always)]
360    pub fn i2c0(&mut self) -> I2C0_W<15> {
361        I2C0_W::new(self)
362    }
363    #[doc = "Bit 16 - I2C1 field"]
364    #[inline(always)]
365    pub fn i2c1(&mut self) -> I2C1_W<16> {
366        I2C1_W::new(self)
367    }
368    #[doc = "Bit 19 - CRC field"]
369    #[inline(always)]
370    pub fn crc(&mut self) -> CRC_W<19> {
371        CRC_W::new(self)
372    }
373    #[doc = "Bit 20 - CORDIC field"]
374    #[inline(always)]
375    pub fn cordic(&mut self) -> CORDIC_W<20> {
376        CORDIC_W::new(self)
377    }
378    #[doc = "Bit 21 - DIV field"]
379    #[inline(always)]
380    pub fn div(&mut self) -> DIV_W<21> {
381        DIV_W::new(self)
382    }
383    #[doc = "Bit 22 - SDIO field"]
384    #[inline(always)]
385    pub fn sdio(&mut self) -> SDIO_W<22> {
386        SDIO_W::new(self)
387    }
388    #[doc = "Bit 24 - USB field"]
389    #[inline(always)]
390    pub fn usb(&mut self) -> USB_W<24> {
391        USB_W::new(self)
392    }
393    #[doc = "Bit 25 - ANAC field"]
394    #[inline(always)]
395    pub fn anac(&mut self) -> ANAC_W<25> {
396        ANAC_W::new(self)
397    }
398    #[doc = "Bit 26 - ADC0 field"]
399    #[inline(always)]
400    pub fn adc0(&mut self) -> ADC0_W<26> {
401        ADC0_W::new(self)
402    }
403    #[doc = "Bit 28 - CAN0 field"]
404    #[inline(always)]
405    pub fn can0(&mut self) -> CAN0_W<28> {
406        CAN0_W::new(self)
407    }
408    #[doc = "Bit 29 - DMA2D field"]
409    #[inline(always)]
410    pub fn dma2d(&mut self) -> DMA2D_W<29> {
411        DMA2D_W::new(self)
412    }
413    #[doc = "Bit 30 - LCD field"]
414    #[inline(always)]
415    pub fn lcd(&mut self) -> LCD_W<30> {
416        LCD_W::new(self)
417    }
418    #[doc = "Writes raw bits to the register."]
419    #[inline(always)]
420    pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
421        self.0.bits(bits);
422        self
423    }
424}
425#[doc = "CLKEN0 register\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 [clken0](index.html) module"]
426pub struct CLKEN0_SPEC;
427impl crate::RegisterSpec for CLKEN0_SPEC {
428    type Ux = u32;
429}
430#[doc = "`read()` method returns [clken0::R](R) reader structure"]
431impl crate::Readable for CLKEN0_SPEC {
432    type Reader = R;
433}
434#[doc = "`write(|w| ..)` method takes [clken0::W](W) writer structure"]
435impl crate::Writable for CLKEN0_SPEC {
436    type Writer = W;
437}
438#[doc = "`reset()` method sets CLKEN0 to value 0"]
439impl crate::Resettable for CLKEN0_SPEC {
440    #[inline(always)]
441    fn reset_value() -> Self::Ux {
442        0
443    }
444}