pub type R = crate::R<PLLI2SCFGRrs>;
pub type W = crate::W<PLLI2SCFGRrs>;
pub type PLLI2SN_R = crate::FieldReader<u16>;
pub type PLLI2SN_W<'a, REG> = crate::FieldWriter<'a, REG, 9, u16>;
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
#[repr(u8)]
pub enum PLLI2SP {
Div2 = 0,
Div4 = 1,
Div6 = 2,
Div8 = 3,
}
impl From<PLLI2SP> for u8 {
#[inline(always)]
fn from(variant: PLLI2SP) -> Self {
variant as _
}
}
impl crate::FieldSpec for PLLI2SP {
type Ux = u8;
}
impl crate::IsEnum for PLLI2SP {}
pub type PLLI2SP_R = crate::FieldReader<PLLI2SP>;
impl PLLI2SP_R {
#[inline(always)]
pub const fn variant(&self) -> PLLI2SP {
match self.bits {
0 => PLLI2SP::Div2,
1 => PLLI2SP::Div4,
2 => PLLI2SP::Div6,
3 => PLLI2SP::Div8,
_ => unreachable!(),
}
}
#[inline(always)]
pub fn is_div2(&self) -> bool {
*self == PLLI2SP::Div2
}
#[inline(always)]
pub fn is_div4(&self) -> bool {
*self == PLLI2SP::Div4
}
#[inline(always)]
pub fn is_div6(&self) -> bool {
*self == PLLI2SP::Div6
}
#[inline(always)]
pub fn is_div8(&self) -> bool {
*self == PLLI2SP::Div8
}
}
pub type PLLI2SP_W<'a, REG> = crate::FieldWriter<'a, REG, 2, PLLI2SP, crate::Safe>;
impl<'a, REG> PLLI2SP_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
REG::Ux: From<u8>,
{
#[inline(always)]
pub fn div2(self) -> &'a mut crate::W<REG> {
self.variant(PLLI2SP::Div2)
}
#[inline(always)]
pub fn div4(self) -> &'a mut crate::W<REG> {
self.variant(PLLI2SP::Div4)
}
#[inline(always)]
pub fn div6(self) -> &'a mut crate::W<REG> {
self.variant(PLLI2SP::Div6)
}
#[inline(always)]
pub fn div8(self) -> &'a mut crate::W<REG> {
self.variant(PLLI2SP::Div8)
}
}
pub type PLLI2SQ_R = crate::FieldReader;
pub type PLLI2SQ_W<'a, REG> = crate::FieldWriter<'a, REG, 4>;
pub type PLLI2SR_R = crate::FieldReader;
pub type PLLI2SR_W<'a, REG> = crate::FieldWriter<'a, REG, 3>;
impl R {
#[inline(always)]
pub fn plli2sn(&self) -> PLLI2SN_R {
PLLI2SN_R::new(((self.bits >> 6) & 0x01ff) as u16)
}
#[inline(always)]
pub fn plli2sp(&self) -> PLLI2SP_R {
PLLI2SP_R::new(((self.bits >> 16) & 3) as u8)
}
#[inline(always)]
pub fn plli2sq(&self) -> PLLI2SQ_R {
PLLI2SQ_R::new(((self.bits >> 24) & 0x0f) as u8)
}
#[inline(always)]
pub fn plli2sr(&self) -> PLLI2SR_R {
PLLI2SR_R::new(((self.bits >> 28) & 7) as u8)
}
}
impl core::fmt::Debug for R {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("PLLI2SCFGR")
.field("plli2sr", &self.plli2sr())
.field("plli2sq", &self.plli2sq())
.field("plli2sn", &self.plli2sn())
.field("plli2sp", &self.plli2sp())
.finish()
}
}
impl W {
#[inline(always)]
pub fn plli2sn(&mut self) -> PLLI2SN_W<PLLI2SCFGRrs> {
PLLI2SN_W::new(self, 6)
}
#[inline(always)]
pub fn plli2sp(&mut self) -> PLLI2SP_W<PLLI2SCFGRrs> {
PLLI2SP_W::new(self, 16)
}
#[inline(always)]
pub fn plli2sq(&mut self) -> PLLI2SQ_W<PLLI2SCFGRrs> {
PLLI2SQ_W::new(self, 24)
}
#[inline(always)]
pub fn plli2sr(&mut self) -> PLLI2SR_W<PLLI2SCFGRrs> {
PLLI2SR_W::new(self, 28)
}
}
pub struct PLLI2SCFGRrs;
impl crate::RegisterSpec for PLLI2SCFGRrs {
type Ux = u32;
}
impl crate::Readable for PLLI2SCFGRrs {}
impl crate::Writable for PLLI2SCFGRrs {
type Safety = crate::Unsafe;
}
impl crate::Resettable for PLLI2SCFGRrs {
const RESET_VALUE: u32 = 0x2000_3000;
}