stm32f3/stm32f302/rcc/
apb1enr.rs1pub type R = crate::R<APB1ENRrs>;
3pub type W = crate::W<APB1ENRrs>;
5#[cfg_attr(feature = "defmt", derive(defmt::Format))]
9#[derive(Clone, Copy, Debug, PartialEq, Eq)]
10pub enum TIM2EN {
11 Disabled = 0,
13 Enabled = 1,
15}
16impl From<TIM2EN> for bool {
17 #[inline(always)]
18 fn from(variant: TIM2EN) -> Self {
19 variant as u8 != 0
20 }
21}
22pub type TIM2EN_R = crate::BitReader<TIM2EN>;
24impl TIM2EN_R {
25 #[inline(always)]
27 pub const fn variant(&self) -> TIM2EN {
28 match self.bits {
29 false => TIM2EN::Disabled,
30 true => TIM2EN::Enabled,
31 }
32 }
33 #[inline(always)]
35 pub fn is_disabled(&self) -> bool {
36 *self == TIM2EN::Disabled
37 }
38 #[inline(always)]
40 pub fn is_enabled(&self) -> bool {
41 *self == TIM2EN::Enabled
42 }
43}
44pub type TIM2EN_W<'a, REG> = crate::BitWriter<'a, REG, TIM2EN>;
46impl<'a, REG> TIM2EN_W<'a, REG>
47where
48 REG: crate::Writable + crate::RegisterSpec,
49{
50 #[inline(always)]
52 pub fn disabled(self) -> &'a mut crate::W<REG> {
53 self.variant(TIM2EN::Disabled)
54 }
55 #[inline(always)]
57 pub fn enabled(self) -> &'a mut crate::W<REG> {
58 self.variant(TIM2EN::Enabled)
59 }
60}
61pub use TIM2EN_R as TIM3EN_R;
63pub use TIM2EN_R as TIM4EN_R;
65pub use TIM2EN_R as TIM6EN_R;
67pub use TIM2EN_R as WWDGEN_R;
69pub use TIM2EN_R as SPI2EN_R;
71pub use TIM2EN_R as SPI3EN_R;
73pub use TIM2EN_R as USART2EN_R;
75pub use TIM2EN_R as USART3EN_R;
77pub use TIM2EN_R as UART4EN_R;
79pub use TIM2EN_R as UART5EN_R;
81pub use TIM2EN_R as I2C1EN_R;
83pub use TIM2EN_R as I2C2EN_R;
85pub use TIM2EN_R as USBEN_R;
87pub use TIM2EN_R as CANEN_R;
89pub use TIM2EN_R as PWREN_R;
91pub use TIM2EN_R as DAC1EN_R;
93pub use TIM2EN_R as I2C3EN_R;
95pub use TIM2EN_W as TIM3EN_W;
97pub use TIM2EN_W as TIM4EN_W;
99pub use TIM2EN_W as TIM6EN_W;
101pub use TIM2EN_W as WWDGEN_W;
103pub use TIM2EN_W as SPI2EN_W;
105pub use TIM2EN_W as SPI3EN_W;
107pub use TIM2EN_W as USART2EN_W;
109pub use TIM2EN_W as USART3EN_W;
111pub use TIM2EN_W as UART4EN_W;
113pub use TIM2EN_W as UART5EN_W;
115pub use TIM2EN_W as I2C1EN_W;
117pub use TIM2EN_W as I2C2EN_W;
119pub use TIM2EN_W as USBEN_W;
121pub use TIM2EN_W as CANEN_W;
123pub use TIM2EN_W as PWREN_W;
125pub use TIM2EN_W as DAC1EN_W;
127pub use TIM2EN_W as I2C3EN_W;
129impl R {
130 #[inline(always)]
132 pub fn tim2en(&self) -> TIM2EN_R {
133 TIM2EN_R::new((self.bits & 1) != 0)
134 }
135 #[inline(always)]
137 pub fn tim3en(&self) -> TIM3EN_R {
138 TIM3EN_R::new(((self.bits >> 1) & 1) != 0)
139 }
140 #[inline(always)]
142 pub fn tim4en(&self) -> TIM4EN_R {
143 TIM4EN_R::new(((self.bits >> 2) & 1) != 0)
144 }
145 #[inline(always)]
147 pub fn tim6en(&self) -> TIM6EN_R {
148 TIM6EN_R::new(((self.bits >> 4) & 1) != 0)
149 }
150 #[inline(always)]
152 pub fn wwdgen(&self) -> WWDGEN_R {
153 WWDGEN_R::new(((self.bits >> 11) & 1) != 0)
154 }
155 #[inline(always)]
157 pub fn spi2en(&self) -> SPI2EN_R {
158 SPI2EN_R::new(((self.bits >> 14) & 1) != 0)
159 }
160 #[inline(always)]
162 pub fn spi3en(&self) -> SPI3EN_R {
163 SPI3EN_R::new(((self.bits >> 15) & 1) != 0)
164 }
165 #[inline(always)]
167 pub fn usart2en(&self) -> USART2EN_R {
168 USART2EN_R::new(((self.bits >> 17) & 1) != 0)
169 }
170 #[inline(always)]
172 pub fn usart3en(&self) -> USART3EN_R {
173 USART3EN_R::new(((self.bits >> 18) & 1) != 0)
174 }
175 #[inline(always)]
177 pub fn uart4en(&self) -> UART4EN_R {
178 UART4EN_R::new(((self.bits >> 19) & 1) != 0)
179 }
180 #[inline(always)]
182 pub fn uart5en(&self) -> UART5EN_R {
183 UART5EN_R::new(((self.bits >> 20) & 1) != 0)
184 }
185 #[inline(always)]
187 pub fn i2c1en(&self) -> I2C1EN_R {
188 I2C1EN_R::new(((self.bits >> 21) & 1) != 0)
189 }
190 #[inline(always)]
192 pub fn i2c2en(&self) -> I2C2EN_R {
193 I2C2EN_R::new(((self.bits >> 22) & 1) != 0)
194 }
195 #[inline(always)]
197 pub fn usben(&self) -> USBEN_R {
198 USBEN_R::new(((self.bits >> 23) & 1) != 0)
199 }
200 #[inline(always)]
202 pub fn canen(&self) -> CANEN_R {
203 CANEN_R::new(((self.bits >> 25) & 1) != 0)
204 }
205 #[inline(always)]
207 pub fn pwren(&self) -> PWREN_R {
208 PWREN_R::new(((self.bits >> 28) & 1) != 0)
209 }
210 #[inline(always)]
212 pub fn dac1en(&self) -> DAC1EN_R {
213 DAC1EN_R::new(((self.bits >> 29) & 1) != 0)
214 }
215 #[inline(always)]
217 pub fn i2c3en(&self) -> I2C3EN_R {
218 I2C3EN_R::new(((self.bits >> 30) & 1) != 0)
219 }
220}
221impl core::fmt::Debug for R {
222 fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
223 f.debug_struct("APB1ENR")
224 .field("tim2en", &self.tim2en())
225 .field("tim3en", &self.tim3en())
226 .field("tim4en", &self.tim4en())
227 .field("tim6en", &self.tim6en())
228 .field("wwdgen", &self.wwdgen())
229 .field("spi2en", &self.spi2en())
230 .field("spi3en", &self.spi3en())
231 .field("usart2en", &self.usart2en())
232 .field("i2c1en", &self.i2c1en())
233 .field("i2c2en", &self.i2c2en())
234 .field("usben", &self.usben())
235 .field("canen", &self.canen())
236 .field("pwren", &self.pwren())
237 .field("dac1en", &self.dac1en())
238 .field("usart3en", &self.usart3en())
239 .field("uart4en", &self.uart4en())
240 .field("uart5en", &self.uart5en())
241 .field("i2c3en", &self.i2c3en())
242 .finish()
243 }
244}
245impl W {
246 #[inline(always)]
248 pub fn tim2en(&mut self) -> TIM2EN_W<APB1ENRrs> {
249 TIM2EN_W::new(self, 0)
250 }
251 #[inline(always)]
253 pub fn tim3en(&mut self) -> TIM3EN_W<APB1ENRrs> {
254 TIM3EN_W::new(self, 1)
255 }
256 #[inline(always)]
258 pub fn tim4en(&mut self) -> TIM4EN_W<APB1ENRrs> {
259 TIM4EN_W::new(self, 2)
260 }
261 #[inline(always)]
263 pub fn tim6en(&mut self) -> TIM6EN_W<APB1ENRrs> {
264 TIM6EN_W::new(self, 4)
265 }
266 #[inline(always)]
268 pub fn wwdgen(&mut self) -> WWDGEN_W<APB1ENRrs> {
269 WWDGEN_W::new(self, 11)
270 }
271 #[inline(always)]
273 pub fn spi2en(&mut self) -> SPI2EN_W<APB1ENRrs> {
274 SPI2EN_W::new(self, 14)
275 }
276 #[inline(always)]
278 pub fn spi3en(&mut self) -> SPI3EN_W<APB1ENRrs> {
279 SPI3EN_W::new(self, 15)
280 }
281 #[inline(always)]
283 pub fn usart2en(&mut self) -> USART2EN_W<APB1ENRrs> {
284 USART2EN_W::new(self, 17)
285 }
286 #[inline(always)]
288 pub fn usart3en(&mut self) -> USART3EN_W<APB1ENRrs> {
289 USART3EN_W::new(self, 18)
290 }
291 #[inline(always)]
293 pub fn uart4en(&mut self) -> UART4EN_W<APB1ENRrs> {
294 UART4EN_W::new(self, 19)
295 }
296 #[inline(always)]
298 pub fn uart5en(&mut self) -> UART5EN_W<APB1ENRrs> {
299 UART5EN_W::new(self, 20)
300 }
301 #[inline(always)]
303 pub fn i2c1en(&mut self) -> I2C1EN_W<APB1ENRrs> {
304 I2C1EN_W::new(self, 21)
305 }
306 #[inline(always)]
308 pub fn i2c2en(&mut self) -> I2C2EN_W<APB1ENRrs> {
309 I2C2EN_W::new(self, 22)
310 }
311 #[inline(always)]
313 pub fn usben(&mut self) -> USBEN_W<APB1ENRrs> {
314 USBEN_W::new(self, 23)
315 }
316 #[inline(always)]
318 pub fn canen(&mut self) -> CANEN_W<APB1ENRrs> {
319 CANEN_W::new(self, 25)
320 }
321 #[inline(always)]
323 pub fn pwren(&mut self) -> PWREN_W<APB1ENRrs> {
324 PWREN_W::new(self, 28)
325 }
326 #[inline(always)]
328 pub fn dac1en(&mut self) -> DAC1EN_W<APB1ENRrs> {
329 DAC1EN_W::new(self, 29)
330 }
331 #[inline(always)]
333 pub fn i2c3en(&mut self) -> I2C3EN_W<APB1ENRrs> {
334 I2C3EN_W::new(self, 30)
335 }
336}
337pub struct APB1ENRrs;
343impl crate::RegisterSpec for APB1ENRrs {
344 type Ux = u32;
345}
346impl crate::Readable for APB1ENRrs {}
348impl crate::Writable for APB1ENRrs {
350 type Safety = crate::Unsafe;
351}
352impl crate::Resettable for APB1ENRrs {}