rp2040_pac/pwm/
en.rs

1#[doc = "Register `EN` reader"]
2pub type R = crate::R<EN_SPEC>;
3#[doc = "Register `EN` writer"]
4pub type W = crate::W<EN_SPEC>;
5#[doc = "Field `CH0` reader - "]
6pub type CH0_R = crate::BitReader;
7#[doc = "Field `CH0` writer - "]
8pub type CH0_W<'a, REG> = crate::BitWriter<'a, REG>;
9#[doc = "Field `CH1` reader - "]
10pub type CH1_R = crate::BitReader;
11#[doc = "Field `CH1` writer - "]
12pub type CH1_W<'a, REG> = crate::BitWriter<'a, REG>;
13#[doc = "Field `CH2` reader - "]
14pub type CH2_R = crate::BitReader;
15#[doc = "Field `CH2` writer - "]
16pub type CH2_W<'a, REG> = crate::BitWriter<'a, REG>;
17#[doc = "Field `CH3` reader - "]
18pub type CH3_R = crate::BitReader;
19#[doc = "Field `CH3` writer - "]
20pub type CH3_W<'a, REG> = crate::BitWriter<'a, REG>;
21#[doc = "Field `CH4` reader - "]
22pub type CH4_R = crate::BitReader;
23#[doc = "Field `CH4` writer - "]
24pub type CH4_W<'a, REG> = crate::BitWriter<'a, REG>;
25#[doc = "Field `CH5` reader - "]
26pub type CH5_R = crate::BitReader;
27#[doc = "Field `CH5` writer - "]
28pub type CH5_W<'a, REG> = crate::BitWriter<'a, REG>;
29#[doc = "Field `CH6` reader - "]
30pub type CH6_R = crate::BitReader;
31#[doc = "Field `CH6` writer - "]
32pub type CH6_W<'a, REG> = crate::BitWriter<'a, REG>;
33#[doc = "Field `CH7` reader - "]
34pub type CH7_R = crate::BitReader;
35#[doc = "Field `CH7` writer - "]
36pub type CH7_W<'a, REG> = crate::BitWriter<'a, REG>;
37impl R {
38    #[doc = "Bit 0"]
39    #[inline(always)]
40    pub fn ch0(&self) -> CH0_R {
41        CH0_R::new((self.bits & 1) != 0)
42    }
43    #[doc = "Bit 1"]
44    #[inline(always)]
45    pub fn ch1(&self) -> CH1_R {
46        CH1_R::new(((self.bits >> 1) & 1) != 0)
47    }
48    #[doc = "Bit 2"]
49    #[inline(always)]
50    pub fn ch2(&self) -> CH2_R {
51        CH2_R::new(((self.bits >> 2) & 1) != 0)
52    }
53    #[doc = "Bit 3"]
54    #[inline(always)]
55    pub fn ch3(&self) -> CH3_R {
56        CH3_R::new(((self.bits >> 3) & 1) != 0)
57    }
58    #[doc = "Bit 4"]
59    #[inline(always)]
60    pub fn ch4(&self) -> CH4_R {
61        CH4_R::new(((self.bits >> 4) & 1) != 0)
62    }
63    #[doc = "Bit 5"]
64    #[inline(always)]
65    pub fn ch5(&self) -> CH5_R {
66        CH5_R::new(((self.bits >> 5) & 1) != 0)
67    }
68    #[doc = "Bit 6"]
69    #[inline(always)]
70    pub fn ch6(&self) -> CH6_R {
71        CH6_R::new(((self.bits >> 6) & 1) != 0)
72    }
73    #[doc = "Bit 7"]
74    #[inline(always)]
75    pub fn ch7(&self) -> CH7_R {
76        CH7_R::new(((self.bits >> 7) & 1) != 0)
77    }
78}
79impl W {
80    #[doc = "Bit 0"]
81    #[inline(always)]
82    #[must_use]
83    pub fn ch0(&mut self) -> CH0_W<EN_SPEC> {
84        CH0_W::new(self, 0)
85    }
86    #[doc = "Bit 1"]
87    #[inline(always)]
88    #[must_use]
89    pub fn ch1(&mut self) -> CH1_W<EN_SPEC> {
90        CH1_W::new(self, 1)
91    }
92    #[doc = "Bit 2"]
93    #[inline(always)]
94    #[must_use]
95    pub fn ch2(&mut self) -> CH2_W<EN_SPEC> {
96        CH2_W::new(self, 2)
97    }
98    #[doc = "Bit 3"]
99    #[inline(always)]
100    #[must_use]
101    pub fn ch3(&mut self) -> CH3_W<EN_SPEC> {
102        CH3_W::new(self, 3)
103    }
104    #[doc = "Bit 4"]
105    #[inline(always)]
106    #[must_use]
107    pub fn ch4(&mut self) -> CH4_W<EN_SPEC> {
108        CH4_W::new(self, 4)
109    }
110    #[doc = "Bit 5"]
111    #[inline(always)]
112    #[must_use]
113    pub fn ch5(&mut self) -> CH5_W<EN_SPEC> {
114        CH5_W::new(self, 5)
115    }
116    #[doc = "Bit 6"]
117    #[inline(always)]
118    #[must_use]
119    pub fn ch6(&mut self) -> CH6_W<EN_SPEC> {
120        CH6_W::new(self, 6)
121    }
122    #[doc = "Bit 7"]
123    #[inline(always)]
124    #[must_use]
125    pub fn ch7(&mut self) -> CH7_W<EN_SPEC> {
126        CH7_W::new(self, 7)
127    }
128    #[doc = r" Writes raw bits to the register."]
129    #[doc = r""]
130    #[doc = r" # Safety"]
131    #[doc = r""]
132    #[doc = r" Passing incorrect value can cause undefined behaviour. See reference manual"]
133    #[inline(always)]
134    pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
135        self.bits = bits;
136        self
137    }
138}
139#[doc = "This register aliases the CSR_EN bits for all channels.  
140 Writing to this register allows multiple channels to be enabled  
141 or disabled simultaneously, so they can run in perfect sync.  
142 For each channel, there is only one physical EN register bit,  
143 which can be accessed through here or CHx_CSR.  
144
145You can [`read`](crate::generic::Reg::read) this register and get [`en::R`](R).  You can [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`write_with_zero`](crate::generic::Reg::write_with_zero) this register using [`en::W`](W). You can also [`modify`](crate::generic::Reg::modify) this register. See [API](https://docs.rs/svd2rust/#read--modify--write-api)."]
146pub struct EN_SPEC;
147impl crate::RegisterSpec for EN_SPEC {
148    type Ux = u32;
149}
150#[doc = "`read()` method returns [`en::R`](R) reader structure"]
151impl crate::Readable for EN_SPEC {}
152#[doc = "`write(|w| ..)` method takes [`en::W`](W) writer structure"]
153impl crate::Writable for EN_SPEC {
154    const ZERO_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
155    const ONE_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
156}
157#[doc = "`reset()` method sets EN to value 0"]
158impl crate::Resettable for EN_SPEC {
159    const RESET_VALUE: u32 = 0;
160}