stm32f1_staging/stm32f101/spi1/
i2spr.rspub type R = crate::R<I2SPRrs>;
pub type W = crate::W<I2SPRrs>;
pub type I2SDIV_R = crate::FieldReader;
pub type I2SDIV_W<'a, REG> = crate::FieldWriter<'a, REG, 8>;
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
pub enum ODD {
Even = 0,
Odd = 1,
}
impl From<ODD> for bool {
#[inline(always)]
fn from(variant: ODD) -> Self {
variant as u8 != 0
}
}
pub type ODD_R = crate::BitReader<ODD>;
impl ODD_R {
#[inline(always)]
pub const fn variant(&self) -> ODD {
match self.bits {
false => ODD::Even,
true => ODD::Odd,
}
}
#[inline(always)]
pub fn is_even(&self) -> bool {
*self == ODD::Even
}
#[inline(always)]
pub fn is_odd(&self) -> bool {
*self == ODD::Odd
}
}
pub type ODD_W<'a, REG> = crate::BitWriter<'a, REG, ODD>;
impl<'a, REG> ODD_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
{
#[inline(always)]
pub fn even(self) -> &'a mut crate::W<REG> {
self.variant(ODD::Even)
}
#[inline(always)]
pub fn odd(self) -> &'a mut crate::W<REG> {
self.variant(ODD::Odd)
}
}
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
pub enum MCKOE {
Disabled = 0,
Enabled = 1,
}
impl From<MCKOE> for bool {
#[inline(always)]
fn from(variant: MCKOE) -> Self {
variant as u8 != 0
}
}
pub type MCKOE_R = crate::BitReader<MCKOE>;
impl MCKOE_R {
#[inline(always)]
pub const fn variant(&self) -> MCKOE {
match self.bits {
false => MCKOE::Disabled,
true => MCKOE::Enabled,
}
}
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == MCKOE::Disabled
}
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == MCKOE::Enabled
}
}
pub type MCKOE_W<'a, REG> = crate::BitWriter<'a, REG, MCKOE>;
impl<'a, REG> MCKOE_W<'a, REG>
where
REG: crate::Writable + crate::RegisterSpec,
{
#[inline(always)]
pub fn disabled(self) -> &'a mut crate::W<REG> {
self.variant(MCKOE::Disabled)
}
#[inline(always)]
pub fn enabled(self) -> &'a mut crate::W<REG> {
self.variant(MCKOE::Enabled)
}
}
impl R {
#[inline(always)]
pub fn i2sdiv(&self) -> I2SDIV_R {
I2SDIV_R::new((self.bits & 0xff) as u8)
}
#[inline(always)]
pub fn odd(&self) -> ODD_R {
ODD_R::new(((self.bits >> 8) & 1) != 0)
}
#[inline(always)]
pub fn mckoe(&self) -> MCKOE_R {
MCKOE_R::new(((self.bits >> 9) & 1) != 0)
}
}
impl core::fmt::Debug for R {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("I2SPR")
.field("mckoe", &self.mckoe())
.field("odd", &self.odd())
.field("i2sdiv", &self.i2sdiv())
.finish()
}
}
impl W {
#[inline(always)]
#[must_use]
pub fn i2sdiv(&mut self) -> I2SDIV_W<I2SPRrs> {
I2SDIV_W::new(self, 0)
}
#[inline(always)]
#[must_use]
pub fn odd(&mut self) -> ODD_W<I2SPRrs> {
ODD_W::new(self, 8)
}
#[inline(always)]
#[must_use]
pub fn mckoe(&mut self) -> MCKOE_W<I2SPRrs> {
MCKOE_W::new(self, 9)
}
}
pub struct I2SPRrs;
impl crate::RegisterSpec for I2SPRrs {
type Ux = u16;
}
impl crate::Readable for I2SPRrs {}
impl crate::Writable for I2SPRrs {
type Safety = crate::Unsafe;
const ZERO_TO_MODIFY_FIELDS_BITMAP: u16 = 0;
const ONE_TO_MODIFY_FIELDS_BITMAP: u16 = 0;
}
impl crate::Resettable for I2SPRrs {
const RESET_VALUE: u16 = 0x0a;
}