stm32f7_staging/stm32f733/tim5/
smcr.rs1pub type R = crate::R<SMCRrs>;
3pub type W = crate::W<SMCRrs>;
5pub use crate::stm32f733::tim2::smcr::SMS;
7pub use crate::stm32f733::tim2::smcr::SMS_R;
9pub use crate::stm32f733::tim2::smcr::SMS_W;
11#[cfg_attr(feature = "defmt", derive(defmt::Format))]
15#[derive(Clone, Copy, Debug, PartialEq, Eq)]
16#[repr(u8)]
17pub enum TS {
18 Itr0 = 0,
20 Itr1 = 1,
22 Itr2 = 2,
24 Ti1fEd = 4,
26 Ti1fp1 = 5,
28 Ti2fp2 = 6,
30 Etrf = 7,
32}
33impl From<TS> for u8 {
34 #[inline(always)]
35 fn from(variant: TS) -> Self {
36 variant as _
37 }
38}
39impl crate::FieldSpec for TS {
40 type Ux = u8;
41}
42impl crate::IsEnum for TS {}
43pub type TS_R = crate::FieldReader<TS>;
45impl TS_R {
46 #[inline(always)]
48 pub const fn variant(&self) -> Option<TS> {
49 match self.bits {
50 0 => Some(TS::Itr0),
51 1 => Some(TS::Itr1),
52 2 => Some(TS::Itr2),
53 4 => Some(TS::Ti1fEd),
54 5 => Some(TS::Ti1fp1),
55 6 => Some(TS::Ti2fp2),
56 7 => Some(TS::Etrf),
57 _ => None,
58 }
59 }
60 #[inline(always)]
62 pub fn is_itr0(&self) -> bool {
63 *self == TS::Itr0
64 }
65 #[inline(always)]
67 pub fn is_itr1(&self) -> bool {
68 *self == TS::Itr1
69 }
70 #[inline(always)]
72 pub fn is_itr2(&self) -> bool {
73 *self == TS::Itr2
74 }
75 #[inline(always)]
77 pub fn is_ti1f_ed(&self) -> bool {
78 *self == TS::Ti1fEd
79 }
80 #[inline(always)]
82 pub fn is_ti1fp1(&self) -> bool {
83 *self == TS::Ti1fp1
84 }
85 #[inline(always)]
87 pub fn is_ti2fp2(&self) -> bool {
88 *self == TS::Ti2fp2
89 }
90 #[inline(always)]
92 pub fn is_etrf(&self) -> bool {
93 *self == TS::Etrf
94 }
95}
96pub type TS_W<'a, REG> = crate::FieldWriter<'a, REG, 3, TS>;
98impl<'a, REG> TS_W<'a, REG>
99where
100 REG: crate::Writable + crate::RegisterSpec,
101 REG::Ux: From<u8>,
102{
103 #[inline(always)]
105 pub fn itr0(self) -> &'a mut crate::W<REG> {
106 self.variant(TS::Itr0)
107 }
108 #[inline(always)]
110 pub fn itr1(self) -> &'a mut crate::W<REG> {
111 self.variant(TS::Itr1)
112 }
113 #[inline(always)]
115 pub fn itr2(self) -> &'a mut crate::W<REG> {
116 self.variant(TS::Itr2)
117 }
118 #[inline(always)]
120 pub fn ti1f_ed(self) -> &'a mut crate::W<REG> {
121 self.variant(TS::Ti1fEd)
122 }
123 #[inline(always)]
125 pub fn ti1fp1(self) -> &'a mut crate::W<REG> {
126 self.variant(TS::Ti1fp1)
127 }
128 #[inline(always)]
130 pub fn ti2fp2(self) -> &'a mut crate::W<REG> {
131 self.variant(TS::Ti2fp2)
132 }
133 #[inline(always)]
135 pub fn etrf(self) -> &'a mut crate::W<REG> {
136 self.variant(TS::Etrf)
137 }
138}
139pub use crate::stm32f733::tim2::smcr::ECE;
141pub use crate::stm32f733::tim2::smcr::ECE_R;
143pub use crate::stm32f733::tim2::smcr::ECE_W;
145pub use crate::stm32f733::tim2::smcr::ETF;
147pub use crate::stm32f733::tim2::smcr::ETF_R;
149pub use crate::stm32f733::tim2::smcr::ETF_W;
151pub use crate::stm32f733::tim2::smcr::ETP;
153pub use crate::stm32f733::tim2::smcr::ETPS;
155pub use crate::stm32f733::tim2::smcr::ETPS_R;
157pub use crate::stm32f733::tim2::smcr::ETPS_W;
159pub use crate::stm32f733::tim2::smcr::ETP_R;
161pub use crate::stm32f733::tim2::smcr::ETP_W;
163pub use crate::stm32f733::tim2::smcr::MSM;
165pub use crate::stm32f733::tim2::smcr::MSM_R;
167pub use crate::stm32f733::tim2::smcr::MSM_W;
169pub type SMS_3_R = crate::BitReader;
171pub type SMS_3_W<'a, REG> = crate::BitWriter<'a, REG>;
173impl R {
174 #[inline(always)]
176 pub fn sms(&self) -> SMS_R {
177 SMS_R::new((self.bits & 7) as u8)
178 }
179 #[inline(always)]
181 pub fn ts(&self) -> TS_R {
182 TS_R::new(((self.bits >> 4) & 7) as u8)
183 }
184 #[inline(always)]
186 pub fn msm(&self) -> MSM_R {
187 MSM_R::new(((self.bits >> 7) & 1) != 0)
188 }
189 #[inline(always)]
191 pub fn etf(&self) -> ETF_R {
192 ETF_R::new(((self.bits >> 8) & 0x0f) as u8)
193 }
194 #[inline(always)]
196 pub fn etps(&self) -> ETPS_R {
197 ETPS_R::new(((self.bits >> 12) & 3) as u8)
198 }
199 #[inline(always)]
201 pub fn ece(&self) -> ECE_R {
202 ECE_R::new(((self.bits >> 14) & 1) != 0)
203 }
204 #[inline(always)]
206 pub fn etp(&self) -> ETP_R {
207 ETP_R::new(((self.bits >> 15) & 1) != 0)
208 }
209 #[inline(always)]
211 pub fn sms_3(&self) -> SMS_3_R {
212 SMS_3_R::new(((self.bits >> 16) & 1) != 0)
213 }
214}
215impl core::fmt::Debug for R {
216 fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
217 f.debug_struct("SMCR")
218 .field("sms", &self.sms())
219 .field("ts", &self.ts())
220 .field("msm", &self.msm())
221 .field("etf", &self.etf())
222 .field("etps", &self.etps())
223 .field("ece", &self.ece())
224 .field("etp", &self.etp())
225 .field("sms_3", &self.sms_3())
226 .finish()
227 }
228}
229impl W {
230 #[inline(always)]
232 pub fn sms(&mut self) -> SMS_W<SMCRrs> {
233 SMS_W::new(self, 0)
234 }
235 #[inline(always)]
237 pub fn ts(&mut self) -> TS_W<SMCRrs> {
238 TS_W::new(self, 4)
239 }
240 #[inline(always)]
242 pub fn msm(&mut self) -> MSM_W<SMCRrs> {
243 MSM_W::new(self, 7)
244 }
245 #[inline(always)]
247 pub fn etf(&mut self) -> ETF_W<SMCRrs> {
248 ETF_W::new(self, 8)
249 }
250 #[inline(always)]
252 pub fn etps(&mut self) -> ETPS_W<SMCRrs> {
253 ETPS_W::new(self, 12)
254 }
255 #[inline(always)]
257 pub fn ece(&mut self) -> ECE_W<SMCRrs> {
258 ECE_W::new(self, 14)
259 }
260 #[inline(always)]
262 pub fn etp(&mut self) -> ETP_W<SMCRrs> {
263 ETP_W::new(self, 15)
264 }
265 #[inline(always)]
267 pub fn sms_3(&mut self) -> SMS_3_W<SMCRrs> {
268 SMS_3_W::new(self, 16)
269 }
270}
271pub struct SMCRrs;
277impl crate::RegisterSpec for SMCRrs {
278 type Ux = u32;
279}
280impl crate::Readable for SMCRrs {}
282impl crate::Writable for SMCRrs {
284 type Safety = crate::Unsafe;
285}
286impl crate::Resettable for SMCRrs {}