#[doc = "Register `RCMR` reader"] pub struct R(crate::R); impl core::ops::Deref for R { type Target = crate::R; #[inline(always)] fn deref(&self) -> &Self::Target { &self.0 } } impl From> for R { #[inline(always)] fn from(reader: crate::R) -> Self { R(reader) } } #[doc = "Register `RCMR` writer"] pub struct W(crate::W); impl core::ops::Deref for W { type Target = crate::W; #[inline(always)] fn deref(&self) -> &Self::Target { &self.0 } } impl core::ops::DerefMut for W { #[inline(always)] fn deref_mut(&mut self) -> &mut Self::Target { &mut self.0 } } impl From> for W { #[inline(always)] fn from(writer: crate::W) -> Self { W(writer) } } #[doc = "Field `CKS` reader - Receive Clock Selection"] pub type CKS_R = crate::FieldReader; #[doc = "Receive Clock Selection\n\nValue on reset: 0"] #[derive(Clone, Copy, Debug, PartialEq, Eq)] #[repr(u8)] pub enum CKSSELECT_A { #[doc = "0: Divided Clock"] MCK = 0, #[doc = "1: TK Clock signal"] TK = 1, #[doc = "2: RK pin"] RK = 2, } impl From for u8 { #[inline(always)] fn from(variant: CKSSELECT_A) -> Self { variant as _ } } impl CKS_R { #[doc = "Get enumerated values variant"] #[inline(always)] pub fn variant(&self) -> Option { match self.bits { 0 => Some(CKSSELECT_A::MCK), 1 => Some(CKSSELECT_A::TK), 2 => Some(CKSSELECT_A::RK), _ => None, } } #[doc = "Checks if the value of the field is `MCK`"] #[inline(always)] pub fn is_mck(&self) -> bool { *self == CKSSELECT_A::MCK } #[doc = "Checks if the value of the field is `TK`"] #[inline(always)] pub fn is_tk(&self) -> bool { *self == CKSSELECT_A::TK } #[doc = "Checks if the value of the field is `RK`"] #[inline(always)] pub fn is_rk(&self) -> bool { *self == CKSSELECT_A::RK } } #[doc = "Field `CKS` writer - Receive Clock Selection"] pub type CKS_W<'a, const O: u8> = crate::FieldWriter<'a, u32, RCMR_SPEC, u8, CKSSELECT_A, 2, O>; impl<'a, const O: u8> CKS_W<'a, O> { #[doc = "Divided Clock"] #[inline(always)] pub fn mck(self) -> &'a mut W { self.variant(CKSSELECT_A::MCK) } #[doc = "TK Clock signal"] #[inline(always)] pub fn tk(self) -> &'a mut W { self.variant(CKSSELECT_A::TK) } #[doc = "RK pin"] #[inline(always)] pub fn rk(self) -> &'a mut W { self.variant(CKSSELECT_A::RK) } } #[doc = "Field `CKO` reader - Receive Clock Output Mode Selection"] pub type CKO_R = crate::FieldReader; #[doc = "Receive Clock Output Mode Selection\n\nValue on reset: 0"] #[derive(Clone, Copy, Debug, PartialEq, Eq)] #[repr(u8)] pub enum CKOSELECT_A { #[doc = "0: None, RK pin is an input"] NONE = 0, #[doc = "1: Continuous Receive Clock, RK pin is an output"] CONTINUOUS = 1, #[doc = "2: Receive Clock only during data transfers, RK pin is an output"] TRANSFER = 2, } impl From for u8 { #[inline(always)] fn from(variant: CKOSELECT_A) -> Self { variant as _ } } impl CKO_R { #[doc = "Get enumerated values variant"] #[inline(always)] pub fn variant(&self) -> Option { match self.bits { 0 => Some(CKOSELECT_A::NONE), 1 => Some(CKOSELECT_A::CONTINUOUS), 2 => Some(CKOSELECT_A::TRANSFER), _ => None, } } #[doc = "Checks if the value of the field is `NONE`"] #[inline(always)] pub fn is_none(&self) -> bool { *self == CKOSELECT_A::NONE } #[doc = "Checks if the value of the field is `CONTINUOUS`"] #[inline(always)] pub fn is_continuous(&self) -> bool { *self == CKOSELECT_A::CONTINUOUS } #[doc = "Checks if the value of the field is `TRANSFER`"] #[inline(always)] pub fn is_transfer(&self) -> bool { *self == CKOSELECT_A::TRANSFER } } #[doc = "Field `CKO` writer - Receive Clock Output Mode Selection"] pub type CKO_W<'a, const O: u8> = crate::FieldWriter<'a, u32, RCMR_SPEC, u8, CKOSELECT_A, 3, O>; impl<'a, const O: u8> CKO_W<'a, O> { #[doc = "None, RK pin is an input"] #[inline(always)] pub fn none(self) -> &'a mut W { self.variant(CKOSELECT_A::NONE) } #[doc = "Continuous Receive Clock, RK pin is an output"] #[inline(always)] pub fn continuous(self) -> &'a mut W { self.variant(CKOSELECT_A::CONTINUOUS) } #[doc = "Receive Clock only during data transfers, RK pin is an output"] #[inline(always)] pub fn transfer(self) -> &'a mut W { self.variant(CKOSELECT_A::TRANSFER) } } #[doc = "Field `CKI` reader - Receive Clock Inversion"] pub type CKI_R = crate::BitReader; #[doc = "Field `CKI` writer - Receive Clock Inversion"] pub type CKI_W<'a, const O: u8> = crate::BitWriter<'a, u32, RCMR_SPEC, bool, O>; #[doc = "Field `CKG` reader - Receive Clock Gating Selection"] pub type CKG_R = crate::FieldReader; #[doc = "Receive Clock Gating Selection\n\nValue on reset: 0"] #[derive(Clone, Copy, Debug, PartialEq, Eq)] #[repr(u8)] pub enum CKGSELECT_A { #[doc = "0: None"] CONTINUOUS = 0, #[doc = "1: Receive Clock enabled only if RF Low"] EN_RF_LOW = 1, #[doc = "2: Receive Clock enabled only if RF High"] EN_RF_HIGH = 2, } impl From for u8 { #[inline(always)] fn from(variant: CKGSELECT_A) -> Self { variant as _ } } impl CKG_R { #[doc = "Get enumerated values variant"] #[inline(always)] pub fn variant(&self) -> Option { match self.bits { 0 => Some(CKGSELECT_A::CONTINUOUS), 1 => Some(CKGSELECT_A::EN_RF_LOW), 2 => Some(CKGSELECT_A::EN_RF_HIGH), _ => None, } } #[doc = "Checks if the value of the field is `CONTINUOUS`"] #[inline(always)] pub fn is_continuous(&self) -> bool { *self == CKGSELECT_A::CONTINUOUS } #[doc = "Checks if the value of the field is `EN_RF_LOW`"] #[inline(always)] pub fn is_en_rf_low(&self) -> bool { *self == CKGSELECT_A::EN_RF_LOW } #[doc = "Checks if the value of the field is `EN_RF_HIGH`"] #[inline(always)] pub fn is_en_rf_high(&self) -> bool { *self == CKGSELECT_A::EN_RF_HIGH } } #[doc = "Field `CKG` writer - Receive Clock Gating Selection"] pub type CKG_W<'a, const O: u8> = crate::FieldWriter<'a, u32, RCMR_SPEC, u8, CKGSELECT_A, 2, O>; impl<'a, const O: u8> CKG_W<'a, O> { #[doc = "None"] #[inline(always)] pub fn continuous(self) -> &'a mut W { self.variant(CKGSELECT_A::CONTINUOUS) } #[doc = "Receive Clock enabled only if RF Low"] #[inline(always)] pub fn en_rf_low(self) -> &'a mut W { self.variant(CKGSELECT_A::EN_RF_LOW) } #[doc = "Receive Clock enabled only if RF High"] #[inline(always)] pub fn en_rf_high(self) -> &'a mut W { self.variant(CKGSELECT_A::EN_RF_HIGH) } } #[doc = "Field `START` reader - Receive Start Selection"] pub type START_R = crate::FieldReader; #[doc = "Receive Start Selection\n\nValue on reset: 0"] #[derive(Clone, Copy, Debug, PartialEq, Eq)] #[repr(u8)] pub enum STARTSELECT_A { #[doc = "0: Continuous, as soon as the receiver is enabled, and immediately after the end of transfer of the previous data."] CONTINUOUS = 0, #[doc = "1: Transmit start"] TRANSMIT = 1, #[doc = "2: Detection of a low level on RF signal"] RF_LOW = 2, #[doc = "3: Detection of a high level on RF signal"] RF_HIGH = 3, #[doc = "4: Detection of a falling edge on RF signal"] RF_FALLING = 4, #[doc = "5: Detection of a rising edge on RF signal"] RF_RISING = 5, #[doc = "6: Detection of any level change on RF signal"] RF_LEVEL = 6, #[doc = "7: Detection of any edge on RF signal"] RF_EDGE = 7, #[doc = "8: Compare 0"] CMP_0 = 8, } impl From for u8 { #[inline(always)] fn from(variant: STARTSELECT_A) -> Self { variant as _ } } impl START_R { #[doc = "Get enumerated values variant"] #[inline(always)] pub fn variant(&self) -> Option { match self.bits { 0 => Some(STARTSELECT_A::CONTINUOUS), 1 => Some(STARTSELECT_A::TRANSMIT), 2 => Some(STARTSELECT_A::RF_LOW), 3 => Some(STARTSELECT_A::RF_HIGH), 4 => Some(STARTSELECT_A::RF_FALLING), 5 => Some(STARTSELECT_A::RF_RISING), 6 => Some(STARTSELECT_A::RF_LEVEL), 7 => Some(STARTSELECT_A::RF_EDGE), 8 => Some(STARTSELECT_A::CMP_0), _ => None, } } #[doc = "Checks if the value of the field is `CONTINUOUS`"] #[inline(always)] pub fn is_continuous(&self) -> bool { *self == STARTSELECT_A::CONTINUOUS } #[doc = "Checks if the value of the field is `TRANSMIT`"] #[inline(always)] pub fn is_transmit(&self) -> bool { *self == STARTSELECT_A::TRANSMIT } #[doc = "Checks if the value of the field is `RF_LOW`"] #[inline(always)] pub fn is_rf_low(&self) -> bool { *self == STARTSELECT_A::RF_LOW } #[doc = "Checks if the value of the field is `RF_HIGH`"] #[inline(always)] pub fn is_rf_high(&self) -> bool { *self == STARTSELECT_A::RF_HIGH } #[doc = "Checks if the value of the field is `RF_FALLING`"] #[inline(always)] pub fn is_rf_falling(&self) -> bool { *self == STARTSELECT_A::RF_FALLING } #[doc = "Checks if the value of the field is `RF_RISING`"] #[inline(always)] pub fn is_rf_rising(&self) -> bool { *self == STARTSELECT_A::RF_RISING } #[doc = "Checks if the value of the field is `RF_LEVEL`"] #[inline(always)] pub fn is_rf_level(&self) -> bool { *self == STARTSELECT_A::RF_LEVEL } #[doc = "Checks if the value of the field is `RF_EDGE`"] #[inline(always)] pub fn is_rf_edge(&self) -> bool { *self == STARTSELECT_A::RF_EDGE } #[doc = "Checks if the value of the field is `CMP_0`"] #[inline(always)] pub fn is_cmp_0(&self) -> bool { *self == STARTSELECT_A::CMP_0 } } #[doc = "Field `START` writer - Receive Start Selection"] pub type START_W<'a, const O: u8> = crate::FieldWriter<'a, u32, RCMR_SPEC, u8, STARTSELECT_A, 4, O>; impl<'a, const O: u8> START_W<'a, O> { #[doc = "Continuous, as soon as the receiver is enabled, and immediately after the end of transfer of the previous data."] #[inline(always)] pub fn continuous(self) -> &'a mut W { self.variant(STARTSELECT_A::CONTINUOUS) } #[doc = "Transmit start"] #[inline(always)] pub fn transmit(self) -> &'a mut W { self.variant(STARTSELECT_A::TRANSMIT) } #[doc = "Detection of a low level on RF signal"] #[inline(always)] pub fn rf_low(self) -> &'a mut W { self.variant(STARTSELECT_A::RF_LOW) } #[doc = "Detection of a high level on RF signal"] #[inline(always)] pub fn rf_high(self) -> &'a mut W { self.variant(STARTSELECT_A::RF_HIGH) } #[doc = "Detection of a falling edge on RF signal"] #[inline(always)] pub fn rf_falling(self) -> &'a mut W { self.variant(STARTSELECT_A::RF_FALLING) } #[doc = "Detection of a rising edge on RF signal"] #[inline(always)] pub fn rf_rising(self) -> &'a mut W { self.variant(STARTSELECT_A::RF_RISING) } #[doc = "Detection of any level change on RF signal"] #[inline(always)] pub fn rf_level(self) -> &'a mut W { self.variant(STARTSELECT_A::RF_LEVEL) } #[doc = "Detection of any edge on RF signal"] #[inline(always)] pub fn rf_edge(self) -> &'a mut W { self.variant(STARTSELECT_A::RF_EDGE) } #[doc = "Compare 0"] #[inline(always)] pub fn cmp_0(self) -> &'a mut W { self.variant(STARTSELECT_A::CMP_0) } } #[doc = "Field `STOP` reader - Receive Stop Selection"] pub type STOP_R = crate::BitReader; #[doc = "Field `STOP` writer - Receive Stop Selection"] pub type STOP_W<'a, const O: u8> = crate::BitWriter<'a, u32, RCMR_SPEC, bool, O>; #[doc = "Field `STTDLY` reader - Receive Start Delay"] pub type STTDLY_R = crate::FieldReader; #[doc = "Field `STTDLY` writer - Receive Start Delay"] pub type STTDLY_W<'a, const O: u8> = crate::FieldWriter<'a, u32, RCMR_SPEC, u8, u8, 8, O>; #[doc = "Field `PERIOD` reader - Receive Period Divider Selection"] pub type PERIOD_R = crate::FieldReader; #[doc = "Field `PERIOD` writer - Receive Period Divider Selection"] pub type PERIOD_W<'a, const O: u8> = crate::FieldWriter<'a, u32, RCMR_SPEC, u8, u8, 8, O>; impl R { #[doc = "Bits 0:1 - Receive Clock Selection"] #[inline(always)] pub fn cks(&self) -> CKS_R { CKS_R::new((self.bits & 3) as u8) } #[doc = "Bits 2:4 - Receive Clock Output Mode Selection"] #[inline(always)] pub fn cko(&self) -> CKO_R { CKO_R::new(((self.bits >> 2) & 7) as u8) } #[doc = "Bit 5 - Receive Clock Inversion"] #[inline(always)] pub fn cki(&self) -> CKI_R { CKI_R::new(((self.bits >> 5) & 1) != 0) } #[doc = "Bits 6:7 - Receive Clock Gating Selection"] #[inline(always)] pub fn ckg(&self) -> CKG_R { CKG_R::new(((self.bits >> 6) & 3) as u8) } #[doc = "Bits 8:11 - Receive Start Selection"] #[inline(always)] pub fn start(&self) -> START_R { START_R::new(((self.bits >> 8) & 0x0f) as u8) } #[doc = "Bit 12 - Receive Stop Selection"] #[inline(always)] pub fn stop(&self) -> STOP_R { STOP_R::new(((self.bits >> 12) & 1) != 0) } #[doc = "Bits 16:23 - Receive Start Delay"] #[inline(always)] pub fn sttdly(&self) -> STTDLY_R { STTDLY_R::new(((self.bits >> 16) & 0xff) as u8) } #[doc = "Bits 24:31 - Receive Period Divider Selection"] #[inline(always)] pub fn period(&self) -> PERIOD_R { PERIOD_R::new(((self.bits >> 24) & 0xff) as u8) } } impl W { #[doc = "Bits 0:1 - Receive Clock Selection"] #[inline(always)] #[must_use] pub fn cks(&mut self) -> CKS_W<0> { CKS_W::new(self) } #[doc = "Bits 2:4 - Receive Clock Output Mode Selection"] #[inline(always)] #[must_use] pub fn cko(&mut self) -> CKO_W<2> { CKO_W::new(self) } #[doc = "Bit 5 - Receive Clock Inversion"] #[inline(always)] #[must_use] pub fn cki(&mut self) -> CKI_W<5> { CKI_W::new(self) } #[doc = "Bits 6:7 - Receive Clock Gating Selection"] #[inline(always)] #[must_use] pub fn ckg(&mut self) -> CKG_W<6> { CKG_W::new(self) } #[doc = "Bits 8:11 - Receive Start Selection"] #[inline(always)] #[must_use] pub fn start(&mut self) -> START_W<8> { START_W::new(self) } #[doc = "Bit 12 - Receive Stop Selection"] #[inline(always)] #[must_use] pub fn stop(&mut self) -> STOP_W<12> { STOP_W::new(self) } #[doc = "Bits 16:23 - Receive Start Delay"] #[inline(always)] #[must_use] pub fn sttdly(&mut self) -> STTDLY_W<16> { STTDLY_W::new(self) } #[doc = "Bits 24:31 - Receive Period Divider Selection"] #[inline(always)] #[must_use] pub fn period(&mut self) -> PERIOD_W<24> { PERIOD_W::new(self) } #[doc = "Writes raw bits to the register."] #[inline(always)] pub unsafe fn bits(&mut self, bits: u32) -> &mut Self { self.0.bits(bits); self } } #[doc = "Receive Clock Mode Register\n\nThis register you can [`read`](crate::generic::Reg::read), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [rcmr](index.html) module"] pub struct RCMR_SPEC; impl crate::RegisterSpec for RCMR_SPEC { type Ux = u32; } #[doc = "`read()` method returns [rcmr::R](R) reader structure"] impl crate::Readable for RCMR_SPEC { type Reader = R; } #[doc = "`write(|w| ..)` method takes [rcmr::W](W) writer structure"] impl crate::Writable for RCMR_SPEC { type Writer = W; const ZERO_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0; const ONE_TO_MODIFY_FIELDS_BITMAP: Self::Ux = 0; } #[doc = "`reset()` method sets RCMR to value 0"] impl crate::Resettable for RCMR_SPEC { const RESET_VALUE: Self::Ux = 0; }