pub type R = crate::R<SMCRrs>;
pub type W = crate::W<SMCRrs>;
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
#[repr(u8)]
pub enum SMS {
Disabled = 0,
EncoderMode1 = 1,
EncoderMode2 = 2,
EncoderMode3 = 3,
ResetMode = 4,
GatedMode = 5,
TriggerMode = 6,
ExtClockMode = 7,
}
impl From<SMS> for u8 {
#[inline(always)]
fn from(variant: SMS) -> Self {
variant as _
}
}
impl crate::FieldSpec for SMS {
type Ux = u8;
}
impl crate::IsEnum for SMS {}
pub type SMS_R = crate::FieldReader<SMS>;
impl SMS_R {
#[inline(always)]
pub const fn variant(&self) -> SMS {
match self.bits {
0 => SMS::Disabled,
1 => SMS::EncoderMode1,
2 => SMS::EncoderMode2,
3 => SMS::EncoderMode3,
4 => SMS::ResetMode,
5 => SMS::GatedMode,
6 => SMS::TriggerMode,
7 => SMS::ExtClockMode,
_ => unreachable!(),
}
}
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == SMS::Disabled
}
#[inline(always)]
pub fn is_encoder_mode_1(&self) -> bool {
*self == SMS::EncoderMode1
}
#[inline(always)]
pub fn is_encoder_mode_2(&self) -> bool {
*self == SMS::EncoderMode2
}
#[inline(always)]
pub fn is_encoder_mode_3(&self) -> bool {
*self == SMS::EncoderMode3
}
#[inline(always)]
pub fn is_reset_mode(&self) -> bool {
*self == SMS::ResetMode
}
#[inline(always)]
pub fn is_gated_mode(&self) -> bool {
*self == SMS::GatedMode
}
#[inline(always)]
pub fn is_trigger_mode(&self) -> bool {
*self == SMS::TriggerMode
}
#[inline(always)]
pub fn is_ext_clock_mode(&self) -> bool {
*self == SMS::ExtClockMode
}
}
pub type SMS_W<'a, REG> = crate::FieldWriter<'a, REG, 3, SMS, crate::Safe>;
impl<'a, REG> SMS_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
REG::Ux: From<u8>,
{
#[inline(always)]
pub fn disabled(self) -> &'a mut crate::W<REG> {
self.variant(SMS::Disabled)
}
#[inline(always)]
pub fn encoder_mode_1(self) -> &'a mut crate::W<REG> {
self.variant(SMS::EncoderMode1)
}
#[inline(always)]
pub fn encoder_mode_2(self) -> &'a mut crate::W<REG> {
self.variant(SMS::EncoderMode2)
}
#[inline(always)]
pub fn encoder_mode_3(self) -> &'a mut crate::W<REG> {
self.variant(SMS::EncoderMode3)
}
#[inline(always)]
pub fn reset_mode(self) -> &'a mut crate::W<REG> {
self.variant(SMS::ResetMode)
}
#[inline(always)]
pub fn gated_mode(self) -> &'a mut crate::W<REG> {
self.variant(SMS::GatedMode)
}
#[inline(always)]
pub fn trigger_mode(self) -> &'a mut crate::W<REG> {
self.variant(SMS::TriggerMode)
}
#[inline(always)]
pub fn ext_clock_mode(self) -> &'a mut crate::W<REG> {
self.variant(SMS::ExtClockMode)
}
}
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
#[repr(u8)]
pub enum TS {
Itr0 = 0,
Itr1 = 1,
Itr2 = 2,
Ti1fEd = 4,
Ti1fp1 = 5,
Ti2fp2 = 6,
Etrf = 7,
}
impl From<TS> for u8 {
#[inline(always)]
fn from(variant: TS) -> Self {
variant as _
}
}
impl crate::FieldSpec for TS {
type Ux = u8;
}
impl crate::IsEnum for TS {}
pub type TS_R = crate::FieldReader<TS>;
impl TS_R {
#[inline(always)]
pub const fn variant(&self) -> Option<TS> {
match self.bits {
0 => Some(TS::Itr0),
1 => Some(TS::Itr1),
2 => Some(TS::Itr2),
4 => Some(TS::Ti1fEd),
5 => Some(TS::Ti1fp1),
6 => Some(TS::Ti2fp2),
7 => Some(TS::Etrf),
_ => None,
}
}
#[inline(always)]
pub fn is_itr0(&self) -> bool {
*self == TS::Itr0
}
#[inline(always)]
pub fn is_itr1(&self) -> bool {
*self == TS::Itr1
}
#[inline(always)]
pub fn is_itr2(&self) -> bool {
*self == TS::Itr2
}
#[inline(always)]
pub fn is_ti1f_ed(&self) -> bool {
*self == TS::Ti1fEd
}
#[inline(always)]
pub fn is_ti1fp1(&self) -> bool {
*self == TS::Ti1fp1
}
#[inline(always)]
pub fn is_ti2fp2(&self) -> bool {
*self == TS::Ti2fp2
}
#[inline(always)]
pub fn is_etrf(&self) -> bool {
*self == TS::Etrf
}
}
pub type TS_W<'a, REG> = crate::FieldWriter<'a, REG, 3, TS>;
impl<'a, REG> TS_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
REG::Ux: From<u8>,
{
#[inline(always)]
pub fn itr0(self) -> &'a mut crate::W<REG> {
self.variant(TS::Itr0)
}
#[inline(always)]
pub fn itr1(self) -> &'a mut crate::W<REG> {
self.variant(TS::Itr1)
}
#[inline(always)]
pub fn itr2(self) -> &'a mut crate::W<REG> {
self.variant(TS::Itr2)
}
#[inline(always)]
pub fn ti1f_ed(self) -> &'a mut crate::W<REG> {
self.variant(TS::Ti1fEd)
}
#[inline(always)]
pub fn ti1fp1(self) -> &'a mut crate::W<REG> {
self.variant(TS::Ti1fp1)
}
#[inline(always)]
pub fn ti2fp2(self) -> &'a mut crate::W<REG> {
self.variant(TS::Ti2fp2)
}
#[inline(always)]
pub fn etrf(self) -> &'a mut crate::W<REG> {
self.variant(TS::Etrf)
}
}
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
pub enum MSM {
NoSync = 0,
Sync = 1,
}
impl From<MSM> for bool {
#[inline(always)]
fn from(variant: MSM) -> Self {
variant as u8 != 0
}
}
pub type MSM_R = crate::BitReader<MSM>;
impl MSM_R {
#[inline(always)]
pub const fn variant(&self) -> MSM {
match self.bits {
false => MSM::NoSync,
true => MSM::Sync,
}
}
#[inline(always)]
pub fn is_no_sync(&self) -> bool {
*self == MSM::NoSync
}
#[inline(always)]
pub fn is_sync(&self) -> bool {
*self == MSM::Sync
}
}
pub type MSM_W<'a, REG> = crate::BitWriter<'a, REG, MSM>;
impl<'a, REG> MSM_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
{
#[inline(always)]
pub fn no_sync(self) -> &'a mut crate::W<REG> {
self.variant(MSM::NoSync)
}
#[inline(always)]
pub fn sync(self) -> &'a mut crate::W<REG> {
self.variant(MSM::Sync)
}
}
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
#[repr(u8)]
pub enum ETF {
NoFilter = 0,
FckIntN2 = 1,
FckIntN4 = 2,
FckIntN8 = 3,
FdtsDiv2N6 = 4,
FdtsDiv2N8 = 5,
FdtsDiv4N6 = 6,
FdtsDiv4N8 = 7,
FdtsDiv8N6 = 8,
FdtsDiv8N8 = 9,
FdtsDiv16N5 = 10,
FdtsDiv16N6 = 11,
FdtsDiv16N8 = 12,
FdtsDiv32N5 = 13,
FdtsDiv32N6 = 14,
FdtsDiv32N8 = 15,
}
impl From<ETF> for u8 {
#[inline(always)]
fn from(variant: ETF) -> Self {
variant as _
}
}
impl crate::FieldSpec for ETF {
type Ux = u8;
}
impl crate::IsEnum for ETF {}
pub type ETF_R = crate::FieldReader<ETF>;
impl ETF_R {
#[inline(always)]
pub const fn variant(&self) -> ETF {
match self.bits {
0 => ETF::NoFilter,
1 => ETF::FckIntN2,
2 => ETF::FckIntN4,
3 => ETF::FckIntN8,
4 => ETF::FdtsDiv2N6,
5 => ETF::FdtsDiv2N8,
6 => ETF::FdtsDiv4N6,
7 => ETF::FdtsDiv4N8,
8 => ETF::FdtsDiv8N6,
9 => ETF::FdtsDiv8N8,
10 => ETF::FdtsDiv16N5,
11 => ETF::FdtsDiv16N6,
12 => ETF::FdtsDiv16N8,
13 => ETF::FdtsDiv32N5,
14 => ETF::FdtsDiv32N6,
15 => ETF::FdtsDiv32N8,
_ => unreachable!(),
}
}
#[inline(always)]
pub fn is_no_filter(&self) -> bool {
*self == ETF::NoFilter
}
#[inline(always)]
pub fn is_fck_int_n2(&self) -> bool {
*self == ETF::FckIntN2
}
#[inline(always)]
pub fn is_fck_int_n4(&self) -> bool {
*self == ETF::FckIntN4
}
#[inline(always)]
pub fn is_fck_int_n8(&self) -> bool {
*self == ETF::FckIntN8
}
#[inline(always)]
pub fn is_fdts_div2_n6(&self) -> bool {
*self == ETF::FdtsDiv2N6
}
#[inline(always)]
pub fn is_fdts_div2_n8(&self) -> bool {
*self == ETF::FdtsDiv2N8
}
#[inline(always)]
pub fn is_fdts_div4_n6(&self) -> bool {
*self == ETF::FdtsDiv4N6
}
#[inline(always)]
pub fn is_fdts_div4_n8(&self) -> bool {
*self == ETF::FdtsDiv4N8
}
#[inline(always)]
pub fn is_fdts_div8_n6(&self) -> bool {
*self == ETF::FdtsDiv8N6
}
#[inline(always)]
pub fn is_fdts_div8_n8(&self) -> bool {
*self == ETF::FdtsDiv8N8
}
#[inline(always)]
pub fn is_fdts_div16_n5(&self) -> bool {
*self == ETF::FdtsDiv16N5
}
#[inline(always)]
pub fn is_fdts_div16_n6(&self) -> bool {
*self == ETF::FdtsDiv16N6
}
#[inline(always)]
pub fn is_fdts_div16_n8(&self) -> bool {
*self == ETF::FdtsDiv16N8
}
#[inline(always)]
pub fn is_fdts_div32_n5(&self) -> bool {
*self == ETF::FdtsDiv32N5
}
#[inline(always)]
pub fn is_fdts_div32_n6(&self) -> bool {
*self == ETF::FdtsDiv32N6
}
#[inline(always)]
pub fn is_fdts_div32_n8(&self) -> bool {
*self == ETF::FdtsDiv32N8
}
}
pub type ETF_W<'a, REG> = crate::FieldWriter<'a, REG, 4, ETF, crate::Safe>;
impl<'a, REG> ETF_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
REG::Ux: From<u8>,
{
#[inline(always)]
pub fn no_filter(self) -> &'a mut crate::W<REG> {
self.variant(ETF::NoFilter)
}
#[inline(always)]
pub fn fck_int_n2(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FckIntN2)
}
#[inline(always)]
pub fn fck_int_n4(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FckIntN4)
}
#[inline(always)]
pub fn fck_int_n8(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FckIntN8)
}
#[inline(always)]
pub fn fdts_div2_n6(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv2N6)
}
#[inline(always)]
pub fn fdts_div2_n8(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv2N8)
}
#[inline(always)]
pub fn fdts_div4_n6(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv4N6)
}
#[inline(always)]
pub fn fdts_div4_n8(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv4N8)
}
#[inline(always)]
pub fn fdts_div8_n6(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv8N6)
}
#[inline(always)]
pub fn fdts_div8_n8(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv8N8)
}
#[inline(always)]
pub fn fdts_div16_n5(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv16N5)
}
#[inline(always)]
pub fn fdts_div16_n6(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv16N6)
}
#[inline(always)]
pub fn fdts_div16_n8(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv16N8)
}
#[inline(always)]
pub fn fdts_div32_n5(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv32N5)
}
#[inline(always)]
pub fn fdts_div32_n6(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv32N6)
}
#[inline(always)]
pub fn fdts_div32_n8(self) -> &'a mut crate::W<REG> {
self.variant(ETF::FdtsDiv32N8)
}
}
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
#[repr(u8)]
pub enum ETPS {
Div1 = 0,
Div2 = 1,
Div4 = 2,
Div8 = 3,
}
impl From<ETPS> for u8 {
#[inline(always)]
fn from(variant: ETPS) -> Self {
variant as _
}
}
impl crate::FieldSpec for ETPS {
type Ux = u8;
}
impl crate::IsEnum for ETPS {}
pub type ETPS_R = crate::FieldReader<ETPS>;
impl ETPS_R {
#[inline(always)]
pub const fn variant(&self) -> ETPS {
match self.bits {
0 => ETPS::Div1,
1 => ETPS::Div2,
2 => ETPS::Div4,
3 => ETPS::Div8,
_ => unreachable!(),
}
}
#[inline(always)]
pub fn is_div1(&self) -> bool {
*self == ETPS::Div1
}
#[inline(always)]
pub fn is_div2(&self) -> bool {
*self == ETPS::Div2
}
#[inline(always)]
pub fn is_div4(&self) -> bool {
*self == ETPS::Div4
}
#[inline(always)]
pub fn is_div8(&self) -> bool {
*self == ETPS::Div8
}
}
pub type ETPS_W<'a, REG> = crate::FieldWriter<'a, REG, 2, ETPS, crate::Safe>;
impl<'a, REG> ETPS_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
REG::Ux: From<u8>,
{
#[inline(always)]
pub fn div1(self) -> &'a mut crate::W<REG> {
self.variant(ETPS::Div1)
}
#[inline(always)]
pub fn div2(self) -> &'a mut crate::W<REG> {
self.variant(ETPS::Div2)
}
#[inline(always)]
pub fn div4(self) -> &'a mut crate::W<REG> {
self.variant(ETPS::Div4)
}
#[inline(always)]
pub fn div8(self) -> &'a mut crate::W<REG> {
self.variant(ETPS::Div8)
}
}
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
pub enum ECE {
Disabled = 0,
Enabled = 1,
}
impl From<ECE> for bool {
#[inline(always)]
fn from(variant: ECE) -> Self {
variant as u8 != 0
}
}
pub type ECE_R = crate::BitReader<ECE>;
impl ECE_R {
#[inline(always)]
pub const fn variant(&self) -> ECE {
match self.bits {
false => ECE::Disabled,
true => ECE::Enabled,
}
}
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == ECE::Disabled
}
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == ECE::Enabled
}
}
pub type ECE_W<'a, REG> = crate::BitWriter<'a, REG, ECE>;
impl<'a, REG> ECE_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
{
#[inline(always)]
pub fn disabled(self) -> &'a mut crate::W<REG> {
self.variant(ECE::Disabled)
}
#[inline(always)]
pub fn enabled(self) -> &'a mut crate::W<REG> {
self.variant(ECE::Enabled)
}
}
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
pub enum ETP {
NotInverted = 0,
Inverted = 1,
}
impl From<ETP> for bool {
#[inline(always)]
fn from(variant: ETP) -> Self {
variant as u8 != 0
}
}
pub type ETP_R = crate::BitReader<ETP>;
impl ETP_R {
#[inline(always)]
pub const fn variant(&self) -> ETP {
match self.bits {
false => ETP::NotInverted,
true => ETP::Inverted,
}
}
#[inline(always)]
pub fn is_not_inverted(&self) -> bool {
*self == ETP::NotInverted
}
#[inline(always)]
pub fn is_inverted(&self) -> bool {
*self == ETP::Inverted
}
}
pub type ETP_W<'a, REG> = crate::BitWriter<'a, REG, ETP>;
impl<'a, REG> ETP_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
{
#[inline(always)]
pub fn not_inverted(self) -> &'a mut crate::W<REG> {
self.variant(ETP::NotInverted)
}
#[inline(always)]
pub fn inverted(self) -> &'a mut crate::W<REG> {
self.variant(ETP::Inverted)
}
}
pub type SMS_3_R = crate::BitReader;
pub type SMS_3_W<'a, REG> = crate::BitWriter<'a, REG>;
impl R {
#[inline(always)]
pub fn sms(&self) -> SMS_R {
SMS_R::new((self.bits & 7) as u8)
}
#[inline(always)]
pub fn ts(&self) -> TS_R {
TS_R::new(((self.bits >> 4) & 7) as u8)
}
#[inline(always)]
pub fn msm(&self) -> MSM_R {
MSM_R::new(((self.bits >> 7) & 1) != 0)
}
#[inline(always)]
pub fn etf(&self) -> ETF_R {
ETF_R::new(((self.bits >> 8) & 0x0f) as u8)
}
#[inline(always)]
pub fn etps(&self) -> ETPS_R {
ETPS_R::new(((self.bits >> 12) & 3) as u8)
}
#[inline(always)]
pub fn ece(&self) -> ECE_R {
ECE_R::new(((self.bits >> 14) & 1) != 0)
}
#[inline(always)]
pub fn etp(&self) -> ETP_R {
ETP_R::new(((self.bits >> 15) & 1) != 0)
}
#[inline(always)]
pub fn sms_3(&self) -> SMS_3_R {
SMS_3_R::new(((self.bits >> 16) & 1) != 0)
}
}
impl core::fmt::Debug for R {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SMCR")
.field("sms", &self.sms())
.field("ts", &self.ts())
.field("msm", &self.msm())
.field("etf", &self.etf())
.field("etps", &self.etps())
.field("ece", &self.ece())
.field("etp", &self.etp())
.field("sms_3", &self.sms_3())
.finish()
}
}
impl W {
#[inline(always)]
pub fn sms(&mut self) -> SMS_W<SMCRrs> {
SMS_W::new(self, 0)
}
#[inline(always)]
pub fn ts(&mut self) -> TS_W<SMCRrs> {
TS_W::new(self, 4)
}
#[inline(always)]
pub fn msm(&mut self) -> MSM_W<SMCRrs> {
MSM_W::new(self, 7)
}
#[inline(always)]
pub fn etf(&mut self) -> ETF_W<SMCRrs> {
ETF_W::new(self, 8)
}
#[inline(always)]
pub fn etps(&mut self) -> ETPS_W<SMCRrs> {
ETPS_W::new(self, 12)
}
#[inline(always)]
pub fn ece(&mut self) -> ECE_W<SMCRrs> {
ECE_W::new(self, 14)
}
#[inline(always)]
pub fn etp(&mut self) -> ETP_W<SMCRrs> {
ETP_W::new(self, 15)
}
#[inline(always)]
pub fn sms_3(&mut self) -> SMS_3_W<SMCRrs> {
SMS_3_W::new(self, 16)
}
}
pub struct SMCRrs;
impl crate::RegisterSpec for SMCRrs {
type Ux = u32;
}
impl crate::Readable for SMCRrs {}
impl crate::Writable for SMCRrs {
type Safety = crate::Unsafe;
}
impl crate::Resettable for SMCRrs {}