stm32f1_staging/stm32f100/dbgmcu/
cr.rspub type R = crate::R<CRrs>;
pub type W = crate::W<CRrs>;
pub type DBG_SLEEP_R = crate::BitReader;
pub type DBG_SLEEP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_STOP_R = crate::BitReader;
pub type DBG_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_STANDBY_R = crate::BitReader;
pub type DBG_STANDBY_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type TRACE_IOEN_R = crate::BitReader;
pub type TRACE_IOEN_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type TRACE_MODE_R = crate::FieldReader;
pub type TRACE_MODE_W<'a, REG> = crate::FieldWriter<'a, REG, 2>;
pub type DBG_IWDG_STOP_R = crate::BitReader;
pub type DBG_IWDG_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_WWDG_STOP_R = crate::BitReader;
pub type DBG_WWDG_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM1_STOP_R = crate::BitReader;
pub type DBG_TIM1_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM2_STOP_R = crate::BitReader;
pub type DBG_TIM2_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM3_STOP_R = crate::BitReader;
pub type DBG_TIM3_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM4_STOP_R = crate::BitReader;
pub type DBG_TIM4_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_I2C1_SMBUS_TIMEOUT_R = crate::BitReader;
pub type DBG_I2C1_SMBUS_TIMEOUT_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_I2C2_SMBUS_TIMEOUT_R = crate::BitReader;
pub type DBG_I2C2_SMBUS_TIMEOUT_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM5_STOP_R = crate::BitReader;
pub type DBG_TIM5_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM6_STOP_R = crate::BitReader;
pub type DBG_TIM6_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM7_STOP_R = crate::BitReader;
pub type DBG_TIM7_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM15_STOP_R = crate::BitReader;
pub type DBG_TIM15_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM16_STOP_R = crate::BitReader;
pub type DBG_TIM16_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM17_STOP_R = crate::BitReader;
pub type DBG_TIM17_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM12_STOP_R = crate::BitReader;
pub type DBG_TIM12_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM13_STOP_R = crate::BitReader;
pub type DBG_TIM13_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
pub type DBG_TIM14_STOP_R = crate::BitReader;
pub type DBG_TIM14_STOP_W<'a, REG> = crate::BitWriter<'a, REG>;
impl R {
    #[inline(always)]
    pub fn dbg_sleep(&self) -> DBG_SLEEP_R {
        DBG_SLEEP_R::new((self.bits & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_stop(&self) -> DBG_STOP_R {
        DBG_STOP_R::new(((self.bits >> 1) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_standby(&self) -> DBG_STANDBY_R {
        DBG_STANDBY_R::new(((self.bits >> 2) & 1) != 0)
    }
    #[inline(always)]
    pub fn trace_ioen(&self) -> TRACE_IOEN_R {
        TRACE_IOEN_R::new(((self.bits >> 5) & 1) != 0)
    }
    #[inline(always)]
    pub fn trace_mode(&self) -> TRACE_MODE_R {
        TRACE_MODE_R::new(((self.bits >> 6) & 3) as u8)
    }
    #[inline(always)]
    pub fn dbg_iwdg_stop(&self) -> DBG_IWDG_STOP_R {
        DBG_IWDG_STOP_R::new(((self.bits >> 8) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_wwdg_stop(&self) -> DBG_WWDG_STOP_R {
        DBG_WWDG_STOP_R::new(((self.bits >> 9) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim1_stop(&self) -> DBG_TIM1_STOP_R {
        DBG_TIM1_STOP_R::new(((self.bits >> 10) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim2_stop(&self) -> DBG_TIM2_STOP_R {
        DBG_TIM2_STOP_R::new(((self.bits >> 11) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim3_stop(&self) -> DBG_TIM3_STOP_R {
        DBG_TIM3_STOP_R::new(((self.bits >> 12) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim4_stop(&self) -> DBG_TIM4_STOP_R {
        DBG_TIM4_STOP_R::new(((self.bits >> 13) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_i2c1_smbus_timeout(&self) -> DBG_I2C1_SMBUS_TIMEOUT_R {
        DBG_I2C1_SMBUS_TIMEOUT_R::new(((self.bits >> 15) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_i2c2_smbus_timeout(&self) -> DBG_I2C2_SMBUS_TIMEOUT_R {
        DBG_I2C2_SMBUS_TIMEOUT_R::new(((self.bits >> 16) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim5_stop(&self) -> DBG_TIM5_STOP_R {
        DBG_TIM5_STOP_R::new(((self.bits >> 18) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim6_stop(&self) -> DBG_TIM6_STOP_R {
        DBG_TIM6_STOP_R::new(((self.bits >> 19) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim7_stop(&self) -> DBG_TIM7_STOP_R {
        DBG_TIM7_STOP_R::new(((self.bits >> 20) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim15_stop(&self) -> DBG_TIM15_STOP_R {
        DBG_TIM15_STOP_R::new(((self.bits >> 22) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim16_stop(&self) -> DBG_TIM16_STOP_R {
        DBG_TIM16_STOP_R::new(((self.bits >> 23) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim17_stop(&self) -> DBG_TIM17_STOP_R {
        DBG_TIM17_STOP_R::new(((self.bits >> 24) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim12_stop(&self) -> DBG_TIM12_STOP_R {
        DBG_TIM12_STOP_R::new(((self.bits >> 25) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim13_stop(&self) -> DBG_TIM13_STOP_R {
        DBG_TIM13_STOP_R::new(((self.bits >> 26) & 1) != 0)
    }
    #[inline(always)]
    pub fn dbg_tim14_stop(&self) -> DBG_TIM14_STOP_R {
        DBG_TIM14_STOP_R::new(((self.bits >> 27) & 1) != 0)
    }
}
impl core::fmt::Debug for R {
    fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
        f.debug_struct("CR")
            .field("dbg_sleep", &self.dbg_sleep())
            .field("dbg_stop", &self.dbg_stop())
            .field("dbg_standby", &self.dbg_standby())
            .field("trace_ioen", &self.trace_ioen())
            .field("trace_mode", &self.trace_mode())
            .field("dbg_iwdg_stop", &self.dbg_iwdg_stop())
            .field("dbg_wwdg_stop", &self.dbg_wwdg_stop())
            .field("dbg_tim1_stop", &self.dbg_tim1_stop())
            .field("dbg_tim2_stop", &self.dbg_tim2_stop())
            .field("dbg_tim3_stop", &self.dbg_tim3_stop())
            .field("dbg_tim4_stop", &self.dbg_tim4_stop())
            .field("dbg_i2c1_smbus_timeout", &self.dbg_i2c1_smbus_timeout())
            .field("dbg_i2c2_smbus_timeout", &self.dbg_i2c2_smbus_timeout())
            .field("dbg_tim5_stop", &self.dbg_tim5_stop())
            .field("dbg_tim6_stop", &self.dbg_tim6_stop())
            .field("dbg_tim7_stop", &self.dbg_tim7_stop())
            .field("dbg_tim15_stop", &self.dbg_tim15_stop())
            .field("dbg_tim16_stop", &self.dbg_tim16_stop())
            .field("dbg_tim17_stop", &self.dbg_tim17_stop())
            .field("dbg_tim12_stop", &self.dbg_tim12_stop())
            .field("dbg_tim13_stop", &self.dbg_tim13_stop())
            .field("dbg_tim14_stop", &self.dbg_tim14_stop())
            .finish()
    }
}
impl W {
    #[inline(always)]
    #[must_use]
    pub fn dbg_sleep(&mut self) -> DBG_SLEEP_W<CRrs> {
        DBG_SLEEP_W::new(self, 0)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_stop(&mut self) -> DBG_STOP_W<CRrs> {
        DBG_STOP_W::new(self, 1)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_standby(&mut self) -> DBG_STANDBY_W<CRrs> {
        DBG_STANDBY_W::new(self, 2)
    }
    #[inline(always)]
    #[must_use]
    pub fn trace_ioen(&mut self) -> TRACE_IOEN_W<CRrs> {
        TRACE_IOEN_W::new(self, 5)
    }
    #[inline(always)]
    #[must_use]
    pub fn trace_mode(&mut self) -> TRACE_MODE_W<CRrs> {
        TRACE_MODE_W::new(self, 6)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_iwdg_stop(&mut self) -> DBG_IWDG_STOP_W<CRrs> {
        DBG_IWDG_STOP_W::new(self, 8)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_wwdg_stop(&mut self) -> DBG_WWDG_STOP_W<CRrs> {
        DBG_WWDG_STOP_W::new(self, 9)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim1_stop(&mut self) -> DBG_TIM1_STOP_W<CRrs> {
        DBG_TIM1_STOP_W::new(self, 10)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim2_stop(&mut self) -> DBG_TIM2_STOP_W<CRrs> {
        DBG_TIM2_STOP_W::new(self, 11)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim3_stop(&mut self) -> DBG_TIM3_STOP_W<CRrs> {
        DBG_TIM3_STOP_W::new(self, 12)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim4_stop(&mut self) -> DBG_TIM4_STOP_W<CRrs> {
        DBG_TIM4_STOP_W::new(self, 13)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_i2c1_smbus_timeout(&mut self) -> DBG_I2C1_SMBUS_TIMEOUT_W<CRrs> {
        DBG_I2C1_SMBUS_TIMEOUT_W::new(self, 15)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_i2c2_smbus_timeout(&mut self) -> DBG_I2C2_SMBUS_TIMEOUT_W<CRrs> {
        DBG_I2C2_SMBUS_TIMEOUT_W::new(self, 16)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim5_stop(&mut self) -> DBG_TIM5_STOP_W<CRrs> {
        DBG_TIM5_STOP_W::new(self, 18)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim6_stop(&mut self) -> DBG_TIM6_STOP_W<CRrs> {
        DBG_TIM6_STOP_W::new(self, 19)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim7_stop(&mut self) -> DBG_TIM7_STOP_W<CRrs> {
        DBG_TIM7_STOP_W::new(self, 20)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim15_stop(&mut self) -> DBG_TIM15_STOP_W<CRrs> {
        DBG_TIM15_STOP_W::new(self, 22)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim16_stop(&mut self) -> DBG_TIM16_STOP_W<CRrs> {
        DBG_TIM16_STOP_W::new(self, 23)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim17_stop(&mut self) -> DBG_TIM17_STOP_W<CRrs> {
        DBG_TIM17_STOP_W::new(self, 24)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim12_stop(&mut self) -> DBG_TIM12_STOP_W<CRrs> {
        DBG_TIM12_STOP_W::new(self, 25)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim13_stop(&mut self) -> DBG_TIM13_STOP_W<CRrs> {
        DBG_TIM13_STOP_W::new(self, 26)
    }
    #[inline(always)]
    #[must_use]
    pub fn dbg_tim14_stop(&mut self) -> DBG_TIM14_STOP_W<CRrs> {
        DBG_TIM14_STOP_W::new(self, 27)
    }
}
pub struct CRrs;
impl crate::RegisterSpec for CRrs {
    type Ux = u32;
}
impl crate::Readable for CRrs {}
impl crate::Writable for CRrs {
    type Safety = crate::Unsafe;
    const ZERO_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
    const ONE_TO_MODIFY_FIELDS_BITMAP: u32 = 0;
}
impl crate::Resettable for CRrs {
    const RESET_VALUE: u32 = 0;
}