pub type R = crate::R<CCMR2_INPUTrs>;
pub type W = crate::W<CCMR2_INPUTrs>;
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
#[repr(u8)]
pub enum CC3S {
Ti3 = 1,
Ti4 = 2,
Trc = 3,
}
impl From<CC3S> for u8 {
#[inline(always)]
fn from(variant: CC3S) -> Self {
variant as _
}
}
impl crate::FieldSpec for CC3S {
type Ux = u8;
}
impl crate::IsEnum for CC3S {}
pub type CC3S_R = crate::FieldReader<CC3S>;
impl CC3S_R {
#[inline(always)]
pub const fn variant(&self) -> Option<CC3S> {
match self.bits {
1 => Some(CC3S::Ti3),
2 => Some(CC3S::Ti4),
3 => Some(CC3S::Trc),
_ => None,
}
}
#[inline(always)]
pub fn is_ti3(&self) -> bool {
*self == CC3S::Ti3
}
#[inline(always)]
pub fn is_ti4(&self) -> bool {
*self == CC3S::Ti4
}
#[inline(always)]
pub fn is_trc(&self) -> bool {
*self == CC3S::Trc
}
}
pub type CC3S_W<'a, REG> = crate::FieldWriter<'a, REG, 2, CC3S>;
impl<'a, REG> CC3S_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
REG::Ux: From<u8>,
{
#[inline(always)]
pub fn ti3(self) -> &'a mut crate::W<REG> {
self.variant(CC3S::Ti3)
}
#[inline(always)]
pub fn ti4(self) -> &'a mut crate::W<REG> {
self.variant(CC3S::Ti4)
}
#[inline(always)]
pub fn trc(self) -> &'a mut crate::W<REG> {
self.variant(CC3S::Trc)
}
}
pub use super::ccmr1_input::ICFILTER;
pub use super::ccmr1_input::ICF_R;
pub use super::ccmr1_input::ICF_W;
pub use super::ccmr1_input::ICPRESCALER;
pub use super::ccmr1_input::ICPSC_R;
pub use super::ccmr1_input::ICPSC_W;
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
#[repr(u8)]
pub enum CC4S {
Ti4 = 1,
Ti3 = 2,
Trc = 3,
}
impl From<CC4S> for u8 {
#[inline(always)]
fn from(variant: CC4S) -> Self {
variant as _
}
}
impl crate::FieldSpec for CC4S {
type Ux = u8;
}
impl crate::IsEnum for CC4S {}
pub type CC4S_R = crate::FieldReader<CC4S>;
impl CC4S_R {
#[inline(always)]
pub const fn variant(&self) -> Option<CC4S> {
match self.bits {
1 => Some(CC4S::Ti4),
2 => Some(CC4S::Ti3),
3 => Some(CC4S::Trc),
_ => None,
}
}
#[inline(always)]
pub fn is_ti4(&self) -> bool {
*self == CC4S::Ti4
}
#[inline(always)]
pub fn is_ti3(&self) -> bool {
*self == CC4S::Ti3
}
#[inline(always)]
pub fn is_trc(&self) -> bool {
*self == CC4S::Trc
}
}
pub type CC4S_W<'a, REG> = crate::FieldWriter<'a, REG, 2, CC4S>;
impl<'a, REG> CC4S_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
REG::Ux: From<u8>,
{
#[inline(always)]
pub fn ti4(self) -> &'a mut crate::W<REG> {
self.variant(CC4S::Ti4)
}
#[inline(always)]
pub fn ti3(self) -> &'a mut crate::W<REG> {
self.variant(CC4S::Ti3)
}
#[inline(always)]
pub fn trc(self) -> &'a mut crate::W<REG> {
self.variant(CC4S::Trc)
}
}
impl R {
#[inline(always)]
pub fn cc3s(&self) -> CC3S_R {
CC3S_R::new((self.bits & 3) as u8)
}
#[inline(always)]
pub fn icpsc(&self, n: u8) -> ICPSC_R {
#[allow(clippy::no_effect)]
[(); 2][n as usize];
ICPSC_R::new(((self.bits >> (n * 8 + 2)) & 3) as u8)
}
#[inline(always)]
pub fn icpsc_iter(&self) -> impl Iterator<Item = ICPSC_R> + '_ {
(0..2).map(move |n| ICPSC_R::new(((self.bits >> (n * 8 + 2)) & 3) as u8))
}
#[inline(always)]
pub fn ic3psc(&self) -> ICPSC_R {
ICPSC_R::new(((self.bits >> 2) & 3) as u8)
}
#[inline(always)]
pub fn ic4psc(&self) -> ICPSC_R {
ICPSC_R::new(((self.bits >> 10) & 3) as u8)
}
#[inline(always)]
pub fn icf(&self, n: u8) -> ICF_R {
#[allow(clippy::no_effect)]
[(); 2][n as usize];
ICF_R::new(((self.bits >> (n * 8 + 4)) & 0x0f) as u8)
}
#[inline(always)]
pub fn icf_iter(&self) -> impl Iterator<Item = ICF_R> + '_ {
(0..2).map(move |n| ICF_R::new(((self.bits >> (n * 8 + 4)) & 0x0f) as u8))
}
#[inline(always)]
pub fn ic3f(&self) -> ICF_R {
ICF_R::new(((self.bits >> 4) & 0x0f) as u8)
}
#[inline(always)]
pub fn ic4f(&self) -> ICF_R {
ICF_R::new(((self.bits >> 12) & 0x0f) as u8)
}
#[inline(always)]
pub fn cc4s(&self) -> CC4S_R {
CC4S_R::new(((self.bits >> 8) & 3) as u8)
}
}
impl core::fmt::Debug for R {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("CCMR2_Input")
.field("ic3f", &self.ic3f())
.field("ic4f", &self.ic4f())
.field("ic3psc", &self.ic3psc())
.field("ic4psc", &self.ic4psc())
.field("cc4s", &self.cc4s())
.field("cc3s", &self.cc3s())
.finish()
}
}
impl W {
#[inline(always)]
pub fn cc3s(&mut self) -> CC3S_W<CCMR2_INPUTrs> {
CC3S_W::new(self, 0)
}
#[inline(always)]
pub fn icpsc(&mut self, n: u8) -> ICPSC_W<CCMR2_INPUTrs> {
#[allow(clippy::no_effect)]
[(); 2][n as usize];
ICPSC_W::new(self, n * 8 + 2)
}
#[inline(always)]
pub fn ic3psc(&mut self) -> ICPSC_W<CCMR2_INPUTrs> {
ICPSC_W::new(self, 2)
}
#[inline(always)]
pub fn ic4psc(&mut self) -> ICPSC_W<CCMR2_INPUTrs> {
ICPSC_W::new(self, 10)
}
#[inline(always)]
pub fn icf(&mut self, n: u8) -> ICF_W<CCMR2_INPUTrs> {
#[allow(clippy::no_effect)]
[(); 2][n as usize];
ICF_W::new(self, n * 8 + 4)
}
#[inline(always)]
pub fn ic3f(&mut self) -> ICF_W<CCMR2_INPUTrs> {
ICF_W::new(self, 4)
}
#[inline(always)]
pub fn ic4f(&mut self) -> ICF_W<CCMR2_INPUTrs> {
ICF_W::new(self, 12)
}
#[inline(always)]
pub fn cc4s(&mut self) -> CC4S_W<CCMR2_INPUTrs> {
CC4S_W::new(self, 8)
}
}
pub struct CCMR2_INPUTrs;
impl crate::RegisterSpec for CCMR2_INPUTrs {
type Ux = u32;
}
impl crate::Readable for CCMR2_INPUTrs {}
impl crate::Writable for CCMR2_INPUTrs {
type Safety = crate::Unsafe;
}
impl crate::Resettable for CCMR2_INPUTrs {}