stm32f1_staging/stm32f107/can1/
fs1r.rs

1///Register `FS1R` reader
2pub type R = crate::R<FS1Rrs>;
3///Register `FS1R` writer
4pub type W = crate::W<FS1Rrs>;
5///Field `FSC(0-27)` reader - Filter scale configuration
6pub type FSC_R = crate::BitReader;
7///Field `FSC(0-27)` writer - Filter scale configuration
8pub type FSC_W<'a, REG> = crate::BitWriter<'a, REG>;
9impl R {
10    ///Filter scale configuration
11    ///
12    ///<div class="warning">`n` is number of field in register. `n == 0` corresponds to `FSC0` field.</div>
13    #[inline(always)]
14    pub fn fsc(&self, n: u8) -> FSC_R {
15        #[allow(clippy::no_effect)] [(); 28][n as usize];
16        FSC_R::new(((self.bits >> n) & 1) != 0)
17    }
18    ///Iterator for array of:
19    ///Filter scale configuration
20    #[inline(always)]
21    pub fn fsc_iter(&self) -> impl Iterator<Item = FSC_R> + '_ {
22        (0..28).map(move |n| FSC_R::new(((self.bits >> n) & 1) != 0))
23    }
24    ///Bit 0 - Filter scale configuration
25    #[inline(always)]
26    pub fn fsc0(&self) -> FSC_R {
27        FSC_R::new((self.bits & 1) != 0)
28    }
29    ///Bit 1 - Filter scale configuration
30    #[inline(always)]
31    pub fn fsc1(&self) -> FSC_R {
32        FSC_R::new(((self.bits >> 1) & 1) != 0)
33    }
34    ///Bit 2 - Filter scale configuration
35    #[inline(always)]
36    pub fn fsc2(&self) -> FSC_R {
37        FSC_R::new(((self.bits >> 2) & 1) != 0)
38    }
39    ///Bit 3 - Filter scale configuration
40    #[inline(always)]
41    pub fn fsc3(&self) -> FSC_R {
42        FSC_R::new(((self.bits >> 3) & 1) != 0)
43    }
44    ///Bit 4 - Filter scale configuration
45    #[inline(always)]
46    pub fn fsc4(&self) -> FSC_R {
47        FSC_R::new(((self.bits >> 4) & 1) != 0)
48    }
49    ///Bit 5 - Filter scale configuration
50    #[inline(always)]
51    pub fn fsc5(&self) -> FSC_R {
52        FSC_R::new(((self.bits >> 5) & 1) != 0)
53    }
54    ///Bit 6 - Filter scale configuration
55    #[inline(always)]
56    pub fn fsc6(&self) -> FSC_R {
57        FSC_R::new(((self.bits >> 6) & 1) != 0)
58    }
59    ///Bit 7 - Filter scale configuration
60    #[inline(always)]
61    pub fn fsc7(&self) -> FSC_R {
62        FSC_R::new(((self.bits >> 7) & 1) != 0)
63    }
64    ///Bit 8 - Filter scale configuration
65    #[inline(always)]
66    pub fn fsc8(&self) -> FSC_R {
67        FSC_R::new(((self.bits >> 8) & 1) != 0)
68    }
69    ///Bit 9 - Filter scale configuration
70    #[inline(always)]
71    pub fn fsc9(&self) -> FSC_R {
72        FSC_R::new(((self.bits >> 9) & 1) != 0)
73    }
74    ///Bit 10 - Filter scale configuration
75    #[inline(always)]
76    pub fn fsc10(&self) -> FSC_R {
77        FSC_R::new(((self.bits >> 10) & 1) != 0)
78    }
79    ///Bit 11 - Filter scale configuration
80    #[inline(always)]
81    pub fn fsc11(&self) -> FSC_R {
82        FSC_R::new(((self.bits >> 11) & 1) != 0)
83    }
84    ///Bit 12 - Filter scale configuration
85    #[inline(always)]
86    pub fn fsc12(&self) -> FSC_R {
87        FSC_R::new(((self.bits >> 12) & 1) != 0)
88    }
89    ///Bit 13 - Filter scale configuration
90    #[inline(always)]
91    pub fn fsc13(&self) -> FSC_R {
92        FSC_R::new(((self.bits >> 13) & 1) != 0)
93    }
94    ///Bit 14 - Filter scale configuration
95    #[inline(always)]
96    pub fn fsc14(&self) -> FSC_R {
97        FSC_R::new(((self.bits >> 14) & 1) != 0)
98    }
99    ///Bit 15 - Filter scale configuration
100    #[inline(always)]
101    pub fn fsc15(&self) -> FSC_R {
102        FSC_R::new(((self.bits >> 15) & 1) != 0)
103    }
104    ///Bit 16 - Filter scale configuration
105    #[inline(always)]
106    pub fn fsc16(&self) -> FSC_R {
107        FSC_R::new(((self.bits >> 16) & 1) != 0)
108    }
109    ///Bit 17 - Filter scale configuration
110    #[inline(always)]
111    pub fn fsc17(&self) -> FSC_R {
112        FSC_R::new(((self.bits >> 17) & 1) != 0)
113    }
114    ///Bit 18 - Filter scale configuration
115    #[inline(always)]
116    pub fn fsc18(&self) -> FSC_R {
117        FSC_R::new(((self.bits >> 18) & 1) != 0)
118    }
119    ///Bit 19 - Filter scale configuration
120    #[inline(always)]
121    pub fn fsc19(&self) -> FSC_R {
122        FSC_R::new(((self.bits >> 19) & 1) != 0)
123    }
124    ///Bit 20 - Filter scale configuration
125    #[inline(always)]
126    pub fn fsc20(&self) -> FSC_R {
127        FSC_R::new(((self.bits >> 20) & 1) != 0)
128    }
129    ///Bit 21 - Filter scale configuration
130    #[inline(always)]
131    pub fn fsc21(&self) -> FSC_R {
132        FSC_R::new(((self.bits >> 21) & 1) != 0)
133    }
134    ///Bit 22 - Filter scale configuration
135    #[inline(always)]
136    pub fn fsc22(&self) -> FSC_R {
137        FSC_R::new(((self.bits >> 22) & 1) != 0)
138    }
139    ///Bit 23 - Filter scale configuration
140    #[inline(always)]
141    pub fn fsc23(&self) -> FSC_R {
142        FSC_R::new(((self.bits >> 23) & 1) != 0)
143    }
144    ///Bit 24 - Filter scale configuration
145    #[inline(always)]
146    pub fn fsc24(&self) -> FSC_R {
147        FSC_R::new(((self.bits >> 24) & 1) != 0)
148    }
149    ///Bit 25 - Filter scale configuration
150    #[inline(always)]
151    pub fn fsc25(&self) -> FSC_R {
152        FSC_R::new(((self.bits >> 25) & 1) != 0)
153    }
154    ///Bit 26 - Filter scale configuration
155    #[inline(always)]
156    pub fn fsc26(&self) -> FSC_R {
157        FSC_R::new(((self.bits >> 26) & 1) != 0)
158    }
159    ///Bit 27 - Filter scale configuration
160    #[inline(always)]
161    pub fn fsc27(&self) -> FSC_R {
162        FSC_R::new(((self.bits >> 27) & 1) != 0)
163    }
164}
165impl core::fmt::Debug for R {
166    fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
167        f.debug_struct("FS1R")
168            .field("fsc0", &self.fsc0())
169            .field("fsc1", &self.fsc1())
170            .field("fsc2", &self.fsc2())
171            .field("fsc3", &self.fsc3())
172            .field("fsc4", &self.fsc4())
173            .field("fsc5", &self.fsc5())
174            .field("fsc6", &self.fsc6())
175            .field("fsc7", &self.fsc7())
176            .field("fsc8", &self.fsc8())
177            .field("fsc9", &self.fsc9())
178            .field("fsc10", &self.fsc10())
179            .field("fsc11", &self.fsc11())
180            .field("fsc12", &self.fsc12())
181            .field("fsc13", &self.fsc13())
182            .field("fsc14", &self.fsc14())
183            .field("fsc15", &self.fsc15())
184            .field("fsc16", &self.fsc16())
185            .field("fsc17", &self.fsc17())
186            .field("fsc18", &self.fsc18())
187            .field("fsc19", &self.fsc19())
188            .field("fsc20", &self.fsc20())
189            .field("fsc21", &self.fsc21())
190            .field("fsc22", &self.fsc22())
191            .field("fsc23", &self.fsc23())
192            .field("fsc24", &self.fsc24())
193            .field("fsc25", &self.fsc25())
194            .field("fsc26", &self.fsc26())
195            .field("fsc27", &self.fsc27())
196            .finish()
197    }
198}
199impl W {
200    ///Filter scale configuration
201    ///
202    ///<div class="warning">`n` is number of field in register. `n == 0` corresponds to `FSC0` field.</div>
203    #[inline(always)]
204    pub fn fsc(&mut self, n: u8) -> FSC_W<FS1Rrs> {
205        #[allow(clippy::no_effect)] [(); 28][n as usize];
206        FSC_W::new(self, n)
207    }
208    ///Bit 0 - Filter scale configuration
209    #[inline(always)]
210    pub fn fsc0(&mut self) -> FSC_W<FS1Rrs> {
211        FSC_W::new(self, 0)
212    }
213    ///Bit 1 - Filter scale configuration
214    #[inline(always)]
215    pub fn fsc1(&mut self) -> FSC_W<FS1Rrs> {
216        FSC_W::new(self, 1)
217    }
218    ///Bit 2 - Filter scale configuration
219    #[inline(always)]
220    pub fn fsc2(&mut self) -> FSC_W<FS1Rrs> {
221        FSC_W::new(self, 2)
222    }
223    ///Bit 3 - Filter scale configuration
224    #[inline(always)]
225    pub fn fsc3(&mut self) -> FSC_W<FS1Rrs> {
226        FSC_W::new(self, 3)
227    }
228    ///Bit 4 - Filter scale configuration
229    #[inline(always)]
230    pub fn fsc4(&mut self) -> FSC_W<FS1Rrs> {
231        FSC_W::new(self, 4)
232    }
233    ///Bit 5 - Filter scale configuration
234    #[inline(always)]
235    pub fn fsc5(&mut self) -> FSC_W<FS1Rrs> {
236        FSC_W::new(self, 5)
237    }
238    ///Bit 6 - Filter scale configuration
239    #[inline(always)]
240    pub fn fsc6(&mut self) -> FSC_W<FS1Rrs> {
241        FSC_W::new(self, 6)
242    }
243    ///Bit 7 - Filter scale configuration
244    #[inline(always)]
245    pub fn fsc7(&mut self) -> FSC_W<FS1Rrs> {
246        FSC_W::new(self, 7)
247    }
248    ///Bit 8 - Filter scale configuration
249    #[inline(always)]
250    pub fn fsc8(&mut self) -> FSC_W<FS1Rrs> {
251        FSC_W::new(self, 8)
252    }
253    ///Bit 9 - Filter scale configuration
254    #[inline(always)]
255    pub fn fsc9(&mut self) -> FSC_W<FS1Rrs> {
256        FSC_W::new(self, 9)
257    }
258    ///Bit 10 - Filter scale configuration
259    #[inline(always)]
260    pub fn fsc10(&mut self) -> FSC_W<FS1Rrs> {
261        FSC_W::new(self, 10)
262    }
263    ///Bit 11 - Filter scale configuration
264    #[inline(always)]
265    pub fn fsc11(&mut self) -> FSC_W<FS1Rrs> {
266        FSC_W::new(self, 11)
267    }
268    ///Bit 12 - Filter scale configuration
269    #[inline(always)]
270    pub fn fsc12(&mut self) -> FSC_W<FS1Rrs> {
271        FSC_W::new(self, 12)
272    }
273    ///Bit 13 - Filter scale configuration
274    #[inline(always)]
275    pub fn fsc13(&mut self) -> FSC_W<FS1Rrs> {
276        FSC_W::new(self, 13)
277    }
278    ///Bit 14 - Filter scale configuration
279    #[inline(always)]
280    pub fn fsc14(&mut self) -> FSC_W<FS1Rrs> {
281        FSC_W::new(self, 14)
282    }
283    ///Bit 15 - Filter scale configuration
284    #[inline(always)]
285    pub fn fsc15(&mut self) -> FSC_W<FS1Rrs> {
286        FSC_W::new(self, 15)
287    }
288    ///Bit 16 - Filter scale configuration
289    #[inline(always)]
290    pub fn fsc16(&mut self) -> FSC_W<FS1Rrs> {
291        FSC_W::new(self, 16)
292    }
293    ///Bit 17 - Filter scale configuration
294    #[inline(always)]
295    pub fn fsc17(&mut self) -> FSC_W<FS1Rrs> {
296        FSC_W::new(self, 17)
297    }
298    ///Bit 18 - Filter scale configuration
299    #[inline(always)]
300    pub fn fsc18(&mut self) -> FSC_W<FS1Rrs> {
301        FSC_W::new(self, 18)
302    }
303    ///Bit 19 - Filter scale configuration
304    #[inline(always)]
305    pub fn fsc19(&mut self) -> FSC_W<FS1Rrs> {
306        FSC_W::new(self, 19)
307    }
308    ///Bit 20 - Filter scale configuration
309    #[inline(always)]
310    pub fn fsc20(&mut self) -> FSC_W<FS1Rrs> {
311        FSC_W::new(self, 20)
312    }
313    ///Bit 21 - Filter scale configuration
314    #[inline(always)]
315    pub fn fsc21(&mut self) -> FSC_W<FS1Rrs> {
316        FSC_W::new(self, 21)
317    }
318    ///Bit 22 - Filter scale configuration
319    #[inline(always)]
320    pub fn fsc22(&mut self) -> FSC_W<FS1Rrs> {
321        FSC_W::new(self, 22)
322    }
323    ///Bit 23 - Filter scale configuration
324    #[inline(always)]
325    pub fn fsc23(&mut self) -> FSC_W<FS1Rrs> {
326        FSC_W::new(self, 23)
327    }
328    ///Bit 24 - Filter scale configuration
329    #[inline(always)]
330    pub fn fsc24(&mut self) -> FSC_W<FS1Rrs> {
331        FSC_W::new(self, 24)
332    }
333    ///Bit 25 - Filter scale configuration
334    #[inline(always)]
335    pub fn fsc25(&mut self) -> FSC_W<FS1Rrs> {
336        FSC_W::new(self, 25)
337    }
338    ///Bit 26 - Filter scale configuration
339    #[inline(always)]
340    pub fn fsc26(&mut self) -> FSC_W<FS1Rrs> {
341        FSC_W::new(self, 26)
342    }
343    ///Bit 27 - Filter scale configuration
344    #[inline(always)]
345    pub fn fsc27(&mut self) -> FSC_W<FS1Rrs> {
346        FSC_W::new(self, 27)
347    }
348}
349/**CAN_FS1R
350
351You can [`read`](crate::Reg::read) this register and get [`fs1r::R`](R). You can [`reset`](crate::Reg::reset), [`write`](crate::Reg::write), [`write_with_zero`](crate::Reg::write_with_zero) this register using [`fs1r::W`](W). You can also [`modify`](crate::Reg::modify) this register. See [API](https://docs.rs/svd2rust/#read--modify--write-api).
352
353See register [structure](https://stm32-rs.github.io/stm32-rs/STM32F107.html#CAN1:FS1R)*/
354pub struct FS1Rrs;
355impl crate::RegisterSpec for FS1Rrs {
356    type Ux = u32;
357}
358///`read()` method returns [`fs1r::R`](R) reader structure
359impl crate::Readable for FS1Rrs {}
360///`write(|w| ..)` method takes [`fs1r::W`](W) writer structure
361impl crate::Writable for FS1Rrs {
362    type Safety = crate::Unsafe;
363}
364///`reset()` method sets FS1R to value 0
365impl crate::Resettable for FS1Rrs {}