stm32f0/stm32f0x0/gpiof/
ospeedr.rs

1#[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}