pub type R = crate::R<SMCRrs>;
pub type W = crate::W<SMCRrs>;
pub type SMS_R = crate::FieldReader;
pub type SMS_W<'a, REG> = crate::FieldWriter<'a, REG, 3>;
pub type OCCS_R = crate::BitReader;
pub type OCCS_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type TS_R = crate::FieldReader;
pub type TS_W<'a, REG> = crate::FieldWriter<'a, REG, 3>;
#[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>;
pub type TS2_R = crate::FieldReader;
pub type TS2_W<'a, REG> = crate::FieldWriter<'a, REG, 2>;
pub type SMSPE_R = crate::BitReader;
pub type SMSPE_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type SMSPS_R = crate::BitReader;
pub type SMSPS_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 occs(&self) -> OCCS_R {
OCCS_R::new(((self.bits >> 3) & 1) != 0)
}
#[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)
}
#[inline(always)]
pub fn ts2(&self) -> TS2_R {
TS2_R::new(((self.bits >> 20) & 3) as u8)
}
#[inline(always)]
pub fn smspe(&self) -> SMSPE_R {
SMSPE_R::new(((self.bits >> 24) & 1) != 0)
}
#[inline(always)]
pub fn smsps(&self) -> SMSPS_R {
SMSPS_R::new(((self.bits >> 25) & 1) != 0)
}
}
impl core::fmt::Debug for R {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SMCR")
.field("smsps", &self.smsps())
.field("smspe", &self.smspe())
.field("ts2", &self.ts2())
.field("sms_3", &self.sms_3())
.field("etp", &self.etp())
.field("ece", &self.ece())
.field("etps", &self.etps())
.field("etf", &self.etf())
.field("msm", &self.msm())
.field("ts", &self.ts())
.field("occs", &self.occs())
.field("sms", &self.sms())
.finish()
}
}
impl W {
#[inline(always)]
pub fn sms(&mut self) -> SMS_W<SMCRrs> {
SMS_W::new(self, 0)
}
#[inline(always)]
pub fn occs(&mut self) -> OCCS_W<SMCRrs> {
OCCS_W::new(self, 3)
}
#[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)
}
#[inline(always)]
pub fn ts2(&mut self) -> TS2_W<SMCRrs> {
TS2_W::new(self, 20)
}
#[inline(always)]
pub fn smspe(&mut self) -> SMSPE_W<SMCRrs> {
SMSPE_W::new(self, 24)
}
#[inline(always)]
pub fn smsps(&mut self) -> SMSPS_W<SMCRrs> {
SMSPS_W::new(self, 25)
}
}
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 {}