stm32f1/stm32f103/exti/
rtsr.rs1pub type R = crate::R<RTSRrs>;
3pub type W = crate::W<RTSRrs>;
5#[cfg_attr(feature = "defmt", derive(defmt::Format))]
9#[derive(Clone, Copy, Debug, PartialEq, Eq)]
10pub enum RISING_TRIGGER {
11 Disabled = 0,
13 Enabled = 1,
15}
16impl From<RISING_TRIGGER> for bool {
17 #[inline(always)]
18 fn from(variant: RISING_TRIGGER) -> Self {
19 variant as u8 != 0
20 }
21}
22pub type TR_R = crate::BitReader<RISING_TRIGGER>;
24impl TR_R {
25 #[inline(always)]
27 pub const fn variant(&self) -> RISING_TRIGGER {
28 match self.bits {
29 false => RISING_TRIGGER::Disabled,
30 true => RISING_TRIGGER::Enabled,
31 }
32 }
33 #[inline(always)]
35 pub fn is_disabled(&self) -> bool {
36 *self == RISING_TRIGGER::Disabled
37 }
38 #[inline(always)]
40 pub fn is_enabled(&self) -> bool {
41 *self == RISING_TRIGGER::Enabled
42 }
43}
44pub type TR_W<'a, REG> = crate::BitWriter<'a, REG, RISING_TRIGGER>;
46impl<'a, REG> TR_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(RISING_TRIGGER::Disabled)
54 }
55 #[inline(always)]
57 pub fn enabled(self) -> &'a mut crate::W<REG> {
58 self.variant(RISING_TRIGGER::Enabled)
59 }
60}
61impl R {
62 #[inline(always)]
66 pub fn tr(&self, n: u8) -> TR_R {
67 #[allow(clippy::no_effect)]
68 [(); 19][n as usize];
69 TR_R::new(((self.bits >> n) & 1) != 0)
70 }
71 #[inline(always)]
74 pub fn tr_iter(&self) -> impl Iterator<Item = TR_R> + '_ {
75 (0..19).map(move |n| TR_R::new(((self.bits >> n) & 1) != 0))
76 }
77 #[inline(always)]
79 pub fn tr0(&self) -> TR_R {
80 TR_R::new((self.bits & 1) != 0)
81 }
82 #[inline(always)]
84 pub fn tr1(&self) -> TR_R {
85 TR_R::new(((self.bits >> 1) & 1) != 0)
86 }
87 #[inline(always)]
89 pub fn tr2(&self) -> TR_R {
90 TR_R::new(((self.bits >> 2) & 1) != 0)
91 }
92 #[inline(always)]
94 pub fn tr3(&self) -> TR_R {
95 TR_R::new(((self.bits >> 3) & 1) != 0)
96 }
97 #[inline(always)]
99 pub fn tr4(&self) -> TR_R {
100 TR_R::new(((self.bits >> 4) & 1) != 0)
101 }
102 #[inline(always)]
104 pub fn tr5(&self) -> TR_R {
105 TR_R::new(((self.bits >> 5) & 1) != 0)
106 }
107 #[inline(always)]
109 pub fn tr6(&self) -> TR_R {
110 TR_R::new(((self.bits >> 6) & 1) != 0)
111 }
112 #[inline(always)]
114 pub fn tr7(&self) -> TR_R {
115 TR_R::new(((self.bits >> 7) & 1) != 0)
116 }
117 #[inline(always)]
119 pub fn tr8(&self) -> TR_R {
120 TR_R::new(((self.bits >> 8) & 1) != 0)
121 }
122 #[inline(always)]
124 pub fn tr9(&self) -> TR_R {
125 TR_R::new(((self.bits >> 9) & 1) != 0)
126 }
127 #[inline(always)]
129 pub fn tr10(&self) -> TR_R {
130 TR_R::new(((self.bits >> 10) & 1) != 0)
131 }
132 #[inline(always)]
134 pub fn tr11(&self) -> TR_R {
135 TR_R::new(((self.bits >> 11) & 1) != 0)
136 }
137 #[inline(always)]
139 pub fn tr12(&self) -> TR_R {
140 TR_R::new(((self.bits >> 12) & 1) != 0)
141 }
142 #[inline(always)]
144 pub fn tr13(&self) -> TR_R {
145 TR_R::new(((self.bits >> 13) & 1) != 0)
146 }
147 #[inline(always)]
149 pub fn tr14(&self) -> TR_R {
150 TR_R::new(((self.bits >> 14) & 1) != 0)
151 }
152 #[inline(always)]
154 pub fn tr15(&self) -> TR_R {
155 TR_R::new(((self.bits >> 15) & 1) != 0)
156 }
157 #[inline(always)]
159 pub fn tr16(&self) -> TR_R {
160 TR_R::new(((self.bits >> 16) & 1) != 0)
161 }
162 #[inline(always)]
164 pub fn tr17(&self) -> TR_R {
165 TR_R::new(((self.bits >> 17) & 1) != 0)
166 }
167 #[inline(always)]
169 pub fn tr18(&self) -> TR_R {
170 TR_R::new(((self.bits >> 18) & 1) != 0)
171 }
172}
173impl core::fmt::Debug for R {
174 fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
175 f.debug_struct("RTSR")
176 .field("tr0", &self.tr0())
177 .field("tr1", &self.tr1())
178 .field("tr2", &self.tr2())
179 .field("tr3", &self.tr3())
180 .field("tr4", &self.tr4())
181 .field("tr5", &self.tr5())
182 .field("tr6", &self.tr6())
183 .field("tr7", &self.tr7())
184 .field("tr8", &self.tr8())
185 .field("tr9", &self.tr9())
186 .field("tr10", &self.tr10())
187 .field("tr11", &self.tr11())
188 .field("tr12", &self.tr12())
189 .field("tr13", &self.tr13())
190 .field("tr14", &self.tr14())
191 .field("tr15", &self.tr15())
192 .field("tr16", &self.tr16())
193 .field("tr17", &self.tr17())
194 .field("tr18", &self.tr18())
195 .finish()
196 }
197}
198impl W {
199 #[inline(always)]
203 pub fn tr(&mut self, n: u8) -> TR_W<RTSRrs> {
204 #[allow(clippy::no_effect)]
205 [(); 19][n as usize];
206 TR_W::new(self, n)
207 }
208 #[inline(always)]
210 pub fn tr0(&mut self) -> TR_W<RTSRrs> {
211 TR_W::new(self, 0)
212 }
213 #[inline(always)]
215 pub fn tr1(&mut self) -> TR_W<RTSRrs> {
216 TR_W::new(self, 1)
217 }
218 #[inline(always)]
220 pub fn tr2(&mut self) -> TR_W<RTSRrs> {
221 TR_W::new(self, 2)
222 }
223 #[inline(always)]
225 pub fn tr3(&mut self) -> TR_W<RTSRrs> {
226 TR_W::new(self, 3)
227 }
228 #[inline(always)]
230 pub fn tr4(&mut self) -> TR_W<RTSRrs> {
231 TR_W::new(self, 4)
232 }
233 #[inline(always)]
235 pub fn tr5(&mut self) -> TR_W<RTSRrs> {
236 TR_W::new(self, 5)
237 }
238 #[inline(always)]
240 pub fn tr6(&mut self) -> TR_W<RTSRrs> {
241 TR_W::new(self, 6)
242 }
243 #[inline(always)]
245 pub fn tr7(&mut self) -> TR_W<RTSRrs> {
246 TR_W::new(self, 7)
247 }
248 #[inline(always)]
250 pub fn tr8(&mut self) -> TR_W<RTSRrs> {
251 TR_W::new(self, 8)
252 }
253 #[inline(always)]
255 pub fn tr9(&mut self) -> TR_W<RTSRrs> {
256 TR_W::new(self, 9)
257 }
258 #[inline(always)]
260 pub fn tr10(&mut self) -> TR_W<RTSRrs> {
261 TR_W::new(self, 10)
262 }
263 #[inline(always)]
265 pub fn tr11(&mut self) -> TR_W<RTSRrs> {
266 TR_W::new(self, 11)
267 }
268 #[inline(always)]
270 pub fn tr12(&mut self) -> TR_W<RTSRrs> {
271 TR_W::new(self, 12)
272 }
273 #[inline(always)]
275 pub fn tr13(&mut self) -> TR_W<RTSRrs> {
276 TR_W::new(self, 13)
277 }
278 #[inline(always)]
280 pub fn tr14(&mut self) -> TR_W<RTSRrs> {
281 TR_W::new(self, 14)
282 }
283 #[inline(always)]
285 pub fn tr15(&mut self) -> TR_W<RTSRrs> {
286 TR_W::new(self, 15)
287 }
288 #[inline(always)]
290 pub fn tr16(&mut self) -> TR_W<RTSRrs> {
291 TR_W::new(self, 16)
292 }
293 #[inline(always)]
295 pub fn tr17(&mut self) -> TR_W<RTSRrs> {
296 TR_W::new(self, 17)
297 }
298 #[inline(always)]
300 pub fn tr18(&mut self) -> TR_W<RTSRrs> {
301 TR_W::new(self, 18)
302 }
303}
304pub struct RTSRrs;
310impl crate::RegisterSpec for RTSRrs {
311 type Ux = u32;
312}
313impl crate::Readable for RTSRrs {}
315impl crate::Writable for RTSRrs {
317 type Safety = crate::Unsafe;
318}
319impl crate::Resettable for RTSRrs {}