stm32f0/stm32f0x0/gpiof/
ospeedr.rs1#[doc = "Register `OSPEEDR` reader"]
2pub struct R(crate::R<OSPEEDR_SPEC>);
3impl core::ops::Deref for R {
4 type Target = crate::R<OSPEEDR_SPEC>;
5 #[inline(always)]
6 fn deref(&self) -> &Self::Target {
7 &self.0
8 }
9}
10impl From<crate::R<OSPEEDR_SPEC>> for R {
11 #[inline(always)]
12 fn from(reader: crate::R<OSPEEDR_SPEC>) -> Self {
13 R(reader)
14 }
15}
16#[doc = "Register `OSPEEDR` writer"]
17pub struct W(crate::W<OSPEEDR_SPEC>);
18impl core::ops::Deref for W {
19 type Target = crate::W<OSPEEDR_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<OSPEEDR_SPEC>> for W {
32 #[inline(always)]
33 fn from(writer: crate::W<OSPEEDR_SPEC>) -> Self {
34 W(writer)
35 }
36}
37#[doc = "Port x configuration bits (y = 0..15)"]
38pub use OSPEEDR0_A as OSPEEDR15_A;
39#[doc = "Port x configuration bits (y = 0..15)"]
40pub use OSPEEDR0_A as OSPEEDR14_A;
41#[doc = "Port x configuration bits (y = 0..15)"]
42pub use OSPEEDR0_A as OSPEEDR13_A;
43#[doc = "Port x configuration bits (y = 0..15)"]
44pub use OSPEEDR0_A as OSPEEDR12_A;
45#[doc = "Port x configuration bits (y = 0..15)"]
46pub use OSPEEDR0_A as OSPEEDR11_A;
47#[doc = "Port x configuration bits (y = 0..15)"]
48pub use OSPEEDR0_A as OSPEEDR10_A;
49#[doc = "Port x configuration bits (y = 0..15)"]
50pub use OSPEEDR0_A as OSPEEDR9_A;
51#[doc = "Port x configuration bits (y = 0..15)"]
52pub use OSPEEDR0_A as OSPEEDR8_A;
53#[doc = "Port x configuration bits (y = 0..15)"]
54pub use OSPEEDR0_A as OSPEEDR7_A;
55#[doc = "Port x configuration bits (y = 0..15)"]
56pub use OSPEEDR0_A as OSPEEDR6_A;
57#[doc = "Port x configuration bits (y = 0..15)"]
58pub use OSPEEDR0_A as OSPEEDR5_A;
59#[doc = "Port x configuration bits (y = 0..15)"]
60pub use OSPEEDR0_A as OSPEEDR4_A;
61#[doc = "Port x configuration bits (y = 0..15)"]
62pub use OSPEEDR0_A as OSPEEDR3_A;
63#[doc = "Port x configuration bits (y = 0..15)"]
64pub use OSPEEDR0_A as OSPEEDR2_A;
65#[doc = "Port x configuration bits (y = 0..15)"]
66pub use OSPEEDR0_A as OSPEEDR1_A;
67#[doc = "Field `OSPEEDR15` reader - Port x configuration bits (y = 0..15)"]
68pub use OSPEEDR0_R as OSPEEDR15_R;
69#[doc = "Field `OSPEEDR14` reader - Port x configuration bits (y = 0..15)"]
70pub use OSPEEDR0_R as OSPEEDR14_R;
71#[doc = "Field `OSPEEDR13` reader - Port x configuration bits (y = 0..15)"]
72pub use OSPEEDR0_R as OSPEEDR13_R;
73#[doc = "Field `OSPEEDR12` reader - Port x configuration bits (y = 0..15)"]
74pub use OSPEEDR0_R as OSPEEDR12_R;
75#[doc = "Field `OSPEEDR11` reader - Port x configuration bits (y = 0..15)"]
76pub use OSPEEDR0_R as OSPEEDR11_R;
77#[doc = "Field `OSPEEDR10` reader - Port x configuration bits (y = 0..15)"]
78pub use OSPEEDR0_R as OSPEEDR10_R;
79#[doc = "Field `OSPEEDR9` reader - Port x configuration bits (y = 0..15)"]
80pub use OSPEEDR0_R as OSPEEDR9_R;
81#[doc = "Field `OSPEEDR8` reader - Port x configuration bits (y = 0..15)"]
82pub use OSPEEDR0_R as OSPEEDR8_R;
83#[doc = "Field `OSPEEDR7` reader - Port x configuration bits (y = 0..15)"]
84pub use OSPEEDR0_R as OSPEEDR7_R;
85#[doc = "Field `OSPEEDR6` reader - Port x configuration bits (y = 0..15)"]
86pub use OSPEEDR0_R as OSPEEDR6_R;
87#[doc = "Field `OSPEEDR5` reader - Port x configuration bits (y = 0..15)"]
88pub use OSPEEDR0_R as OSPEEDR5_R;
89#[doc = "Field `OSPEEDR4` reader - Port x configuration bits (y = 0..15)"]
90pub use OSPEEDR0_R as OSPEEDR4_R;
91#[doc = "Field `OSPEEDR3` reader - Port x configuration bits (y = 0..15)"]
92pub use OSPEEDR0_R as OSPEEDR3_R;
93#[doc = "Field `OSPEEDR2` reader - Port x configuration bits (y = 0..15)"]
94pub use OSPEEDR0_R as OSPEEDR2_R;
95#[doc = "Field `OSPEEDR1` reader - Port x configuration bits (y = 0..15)"]
96pub use OSPEEDR0_R as OSPEEDR1_R;
97#[doc = "Field `OSPEEDR15` writer - Port x configuration bits (y = 0..15)"]
98pub use OSPEEDR0_W as OSPEEDR15_W;
99#[doc = "Field `OSPEEDR14` writer - Port x configuration bits (y = 0..15)"]
100pub use OSPEEDR0_W as OSPEEDR14_W;
101#[doc = "Field `OSPEEDR13` writer - Port x configuration bits (y = 0..15)"]
102pub use OSPEEDR0_W as OSPEEDR13_W;
103#[doc = "Field `OSPEEDR12` writer - Port x configuration bits (y = 0..15)"]
104pub use OSPEEDR0_W as OSPEEDR12_W;
105#[doc = "Field `OSPEEDR11` writer - Port x configuration bits (y = 0..15)"]
106pub use OSPEEDR0_W as OSPEEDR11_W;
107#[doc = "Field `OSPEEDR10` writer - Port x configuration bits (y = 0..15)"]
108pub use OSPEEDR0_W as OSPEEDR10_W;
109#[doc = "Field `OSPEEDR9` writer - Port x configuration bits (y = 0..15)"]
110pub use OSPEEDR0_W as OSPEEDR9_W;
111#[doc = "Field `OSPEEDR8` writer - Port x configuration bits (y = 0..15)"]
112pub use OSPEEDR0_W as OSPEEDR8_W;
113#[doc = "Field `OSPEEDR7` writer - Port x configuration bits (y = 0..15)"]
114pub use OSPEEDR0_W as OSPEEDR7_W;
115#[doc = "Field `OSPEEDR6` writer - Port x configuration bits (y = 0..15)"]
116pub use OSPEEDR0_W as OSPEEDR6_W;
117#[doc = "Field `OSPEEDR5` writer - Port x configuration bits (y = 0..15)"]
118pub use OSPEEDR0_W as OSPEEDR5_W;
119#[doc = "Field `OSPEEDR4` writer - Port x configuration bits (y = 0..15)"]
120pub use OSPEEDR0_W as OSPEEDR4_W;
121#[doc = "Field `OSPEEDR3` writer - Port x configuration bits (y = 0..15)"]
122pub use OSPEEDR0_W as OSPEEDR3_W;
123#[doc = "Field `OSPEEDR2` writer - Port x configuration bits (y = 0..15)"]
124pub use OSPEEDR0_W as OSPEEDR2_W;
125#[doc = "Field `OSPEEDR1` writer - Port x configuration bits (y = 0..15)"]
126pub use OSPEEDR0_W as OSPEEDR1_W;
127#[doc = "Port x configuration bits (y = 0..15)\n\nValue on reset: 0"]
128#[derive(Clone, Copy, Debug, PartialEq)]
129#[repr(u8)]
130pub enum OSPEEDR0_A {
131 #[doc = "0: Low speed"]
132 LowSpeed = 0,
133 #[doc = "1: Medium speed"]
134 MediumSpeed = 1,
135 #[doc = "2: High speed"]
136 HighSpeed = 2,
137 #[doc = "3: Very high speed"]
138 VeryHighSpeed = 3,
139}
140impl From<OSPEEDR0_A> for u8 {
141 #[inline(always)]
142 fn from(variant: OSPEEDR0_A) -> Self {
143 variant as _
144 }
145}
146#[doc = "Field `OSPEEDR0` reader - Port x configuration bits (y = 0..15)"]
147pub type OSPEEDR0_R = crate::FieldReader<u8, OSPEEDR0_A>;
148impl OSPEEDR0_R {
149 #[doc = "Get enumerated values variant"]
150 #[inline(always)]
151 pub fn variant(&self) -> OSPEEDR0_A {
152 match self.bits {
153 0 => OSPEEDR0_A::LowSpeed,
154 1 => OSPEEDR0_A::MediumSpeed,
155 2 => OSPEEDR0_A::HighSpeed,
156 3 => OSPEEDR0_A::VeryHighSpeed,
157 _ => unreachable!(),
158 }
159 }
160 #[doc = "Checks if the value of the field is `LowSpeed`"]
161 #[inline(always)]
162 pub fn is_low_speed(&self) -> bool {
163 *self == OSPEEDR0_A::LowSpeed
164 }
165 #[doc = "Checks if the value of the field is `MediumSpeed`"]
166 #[inline(always)]
167 pub fn is_medium_speed(&self) -> bool {
168 *self == OSPEEDR0_A::MediumSpeed
169 }
170 #[doc = "Checks if the value of the field is `HighSpeed`"]
171 #[inline(always)]
172 pub fn is_high_speed(&self) -> bool {
173 *self == OSPEEDR0_A::HighSpeed
174 }
175 #[doc = "Checks if the value of the field is `VeryHighSpeed`"]
176 #[inline(always)]
177 pub fn is_very_high_speed(&self) -> bool {
178 *self == OSPEEDR0_A::VeryHighSpeed
179 }
180}
181#[doc = "Field `OSPEEDR0` writer - Port x configuration bits (y = 0..15)"]
182pub type OSPEEDR0_W<'a, const O: u8> =
183 crate::FieldWriterSafe<'a, u32, OSPEEDR_SPEC, u8, OSPEEDR0_A, 2, O>;
184impl<'a, const O: u8> OSPEEDR0_W<'a, O> {
185 #[doc = "Low speed"]
186 #[inline(always)]
187 pub fn low_speed(self) -> &'a mut W {
188 self.variant(OSPEEDR0_A::LowSpeed)
189 }
190 #[doc = "Medium speed"]
191 #[inline(always)]
192 pub fn medium_speed(self) -> &'a mut W {
193 self.variant(OSPEEDR0_A::MediumSpeed)
194 }
195 #[doc = "High speed"]
196 #[inline(always)]
197 pub fn high_speed(self) -> &'a mut W {
198 self.variant(OSPEEDR0_A::HighSpeed)
199 }
200 #[doc = "Very high speed"]
201 #[inline(always)]
202 pub fn very_high_speed(self) -> &'a mut W {
203 self.variant(OSPEEDR0_A::VeryHighSpeed)
204 }
205}
206impl R {
207 #[doc = "Bits 30:31 - Port x configuration bits (y = 0..15)"]
208 #[inline(always)]
209 pub fn ospeedr15(&self) -> OSPEEDR15_R {
210 OSPEEDR15_R::new(((self.bits >> 30) & 3) as u8)
211 }
212 #[doc = "Bits 28:29 - Port x configuration bits (y = 0..15)"]
213 #[inline(always)]
214 pub fn ospeedr14(&self) -> OSPEEDR14_R {
215 OSPEEDR14_R::new(((self.bits >> 28) & 3) as u8)
216 }
217 #[doc = "Bits 26:27 - Port x configuration bits (y = 0..15)"]
218 #[inline(always)]
219 pub fn ospeedr13(&self) -> OSPEEDR13_R {
220 OSPEEDR13_R::new(((self.bits >> 26) & 3) as u8)
221 }
222 #[doc = "Bits 24:25 - Port x configuration bits (y = 0..15)"]
223 #[inline(always)]
224 pub fn ospeedr12(&self) -> OSPEEDR12_R {
225 OSPEEDR12_R::new(((self.bits >> 24) & 3) as u8)
226 }
227 #[doc = "Bits 22:23 - Port x configuration bits (y = 0..15)"]
228 #[inline(always)]
229 pub fn ospeedr11(&self) -> OSPEEDR11_R {
230 OSPEEDR11_R::new(((self.bits >> 22) & 3) as u8)
231 }
232 #[doc = "Bits 20:21 - Port x configuration bits (y = 0..15)"]
233 #[inline(always)]
234 pub fn ospeedr10(&self) -> OSPEEDR10_R {
235 OSPEEDR10_R::new(((self.bits >> 20) & 3) as u8)
236 }
237 #[doc = "Bits 18:19 - Port x configuration bits (y = 0..15)"]
238 #[inline(always)]
239 pub fn ospeedr9(&self) -> OSPEEDR9_R {
240 OSPEEDR9_R::new(((self.bits >> 18) & 3) as u8)
241 }
242 #[doc = "Bits 16:17 - Port x configuration bits (y = 0..15)"]
243 #[inline(always)]
244 pub fn ospeedr8(&self) -> OSPEEDR8_R {
245 OSPEEDR8_R::new(((self.bits >> 16) & 3) as u8)
246 }
247 #[doc = "Bits 14:15 - Port x configuration bits (y = 0..15)"]
248 #[inline(always)]
249 pub fn ospeedr7(&self) -> OSPEEDR7_R {
250 OSPEEDR7_R::new(((self.bits >> 14) & 3) as u8)
251 }
252 #[doc = "Bits 12:13 - Port x configuration bits (y = 0..15)"]
253 #[inline(always)]
254 pub fn ospeedr6(&self) -> OSPEEDR6_R {
255 OSPEEDR6_R::new(((self.bits >> 12) & 3) as u8)
256 }
257 #[doc = "Bits 10:11 - Port x configuration bits (y = 0..15)"]
258 #[inline(always)]
259 pub fn ospeedr5(&self) -> OSPEEDR5_R {
260 OSPEEDR5_R::new(((self.bits >> 10) & 3) as u8)
261 }
262 #[doc = "Bits 8:9 - Port x configuration bits (y = 0..15)"]
263 #[inline(always)]
264 pub fn ospeedr4(&self) -> OSPEEDR4_R {
265 OSPEEDR4_R::new(((self.bits >> 8) & 3) as u8)
266 }
267 #[doc = "Bits 6:7 - Port x configuration bits (y = 0..15)"]
268 #[inline(always)]
269 pub fn ospeedr3(&self) -> OSPEEDR3_R {
270 OSPEEDR3_R::new(((self.bits >> 6) & 3) as u8)
271 }
272 #[doc = "Bits 4:5 - Port x configuration bits (y = 0..15)"]
273 #[inline(always)]
274 pub fn ospeedr2(&self) -> OSPEEDR2_R {
275 OSPEEDR2_R::new(((self.bits >> 4) & 3) as u8)
276 }
277 #[doc = "Bits 2:3 - Port x configuration bits (y = 0..15)"]
278 #[inline(always)]
279 pub fn ospeedr1(&self) -> OSPEEDR1_R {
280 OSPEEDR1_R::new(((self.bits >> 2) & 3) as u8)
281 }
282 #[doc = "Bits 0:1 - Port x configuration bits (y = 0..15)"]
283 #[inline(always)]
284 pub fn ospeedr0(&self) -> OSPEEDR0_R {
285 OSPEEDR0_R::new((self.bits & 3) as u8)
286 }
287}
288impl W {
289 #[doc = "Bits 30:31 - Port x configuration bits (y = 0..15)"]
290 #[inline(always)]
291 pub fn ospeedr15(&mut self) -> OSPEEDR15_W<30> {
292 OSPEEDR15_W::new(self)
293 }
294 #[doc = "Bits 28:29 - Port x configuration bits (y = 0..15)"]
295 #[inline(always)]
296 pub fn ospeedr14(&mut self) -> OSPEEDR14_W<28> {
297 OSPEEDR14_W::new(self)
298 }
299 #[doc = "Bits 26:27 - Port x configuration bits (y = 0..15)"]
300 #[inline(always)]
301 pub fn ospeedr13(&mut self) -> OSPEEDR13_W<26> {
302 OSPEEDR13_W::new(self)
303 }
304 #[doc = "Bits 24:25 - Port x configuration bits (y = 0..15)"]
305 #[inline(always)]
306 pub fn ospeedr12(&mut self) -> OSPEEDR12_W<24> {
307 OSPEEDR12_W::new(self)
308 }
309 #[doc = "Bits 22:23 - Port x configuration bits (y = 0..15)"]
310 #[inline(always)]
311 pub fn ospeedr11(&mut self) -> OSPEEDR11_W<22> {
312 OSPEEDR11_W::new(self)
313 }
314 #[doc = "Bits 20:21 - Port x configuration bits (y = 0..15)"]
315 #[inline(always)]
316 pub fn ospeedr10(&mut self) -> OSPEEDR10_W<20> {
317 OSPEEDR10_W::new(self)
318 }
319 #[doc = "Bits 18:19 - Port x configuration bits (y = 0..15)"]
320 #[inline(always)]
321 pub fn ospeedr9(&mut self) -> OSPEEDR9_W<18> {
322 OSPEEDR9_W::new(self)
323 }
324 #[doc = "Bits 16:17 - Port x configuration bits (y = 0..15)"]
325 #[inline(always)]
326 pub fn ospeedr8(&mut self) -> OSPEEDR8_W<16> {
327 OSPEEDR8_W::new(self)
328 }
329 #[doc = "Bits 14:15 - Port x configuration bits (y = 0..15)"]
330 #[inline(always)]
331 pub fn ospeedr7(&mut self) -> OSPEEDR7_W<14> {
332 OSPEEDR7_W::new(self)
333 }
334 #[doc = "Bits 12:13 - Port x configuration bits (y = 0..15)"]
335 #[inline(always)]
336 pub fn ospeedr6(&mut self) -> OSPEEDR6_W<12> {
337 OSPEEDR6_W::new(self)
338 }
339 #[doc = "Bits 10:11 - Port x configuration bits (y = 0..15)"]
340 #[inline(always)]
341 pub fn ospeedr5(&mut self) -> OSPEEDR5_W<10> {
342 OSPEEDR5_W::new(self)
343 }
344 #[doc = "Bits 8:9 - Port x configuration bits (y = 0..15)"]
345 #[inline(always)]
346 pub fn ospeedr4(&mut self) -> OSPEEDR4_W<8> {
347 OSPEEDR4_W::new(self)
348 }
349 #[doc = "Bits 6:7 - Port x configuration bits (y = 0..15)"]
350 #[inline(always)]
351 pub fn ospeedr3(&mut self) -> OSPEEDR3_W<6> {
352 OSPEEDR3_W::new(self)
353 }
354 #[doc = "Bits 4:5 - Port x configuration bits (y = 0..15)"]
355 #[inline(always)]
356 pub fn ospeedr2(&mut self) -> OSPEEDR2_W<4> {
357 OSPEEDR2_W::new(self)
358 }
359 #[doc = "Bits 2:3 - Port x configuration bits (y = 0..15)"]
360 #[inline(always)]
361 pub fn ospeedr1(&mut self) -> OSPEEDR1_W<2> {
362 OSPEEDR1_W::new(self)
363 }
364 #[doc = "Bits 0:1 - Port x configuration bits (y = 0..15)"]
365 #[inline(always)]
366 pub fn ospeedr0(&mut self) -> OSPEEDR0_W<0> {
367 OSPEEDR0_W::new(self)
368 }
369 #[doc = "Writes raw bits to the register."]
370 #[inline(always)]
371 pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
372 self.0.bits(bits);
373 self
374 }
375}
376#[doc = "GPIO port output speed 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 [ospeedr](index.html) module"]
377pub struct OSPEEDR_SPEC;
378impl crate::RegisterSpec for OSPEEDR_SPEC {
379 type Ux = u32;
380}
381#[doc = "`read()` method returns [ospeedr::R](R) reader structure"]
382impl crate::Readable for OSPEEDR_SPEC {
383 type Reader = R;
384}
385#[doc = "`write(|w| ..)` method takes [ospeedr::W](W) writer structure"]
386impl crate::Writable for OSPEEDR_SPEC {
387 type Writer = W;
388}
389#[doc = "`reset()` method sets OSPEEDR to value 0"]
390impl crate::Resettable for OSPEEDR_SPEC {
391 #[inline(always)]
392 fn reset_value() -> Self::Ux {
393 0
394 }
395}