stm32wb 0.16.0

Device support crates for STM32WB devices
Documentation
///Register `C2MISR` reader
pub type R = crate::R<C2MISRrs>;
/**Masked interrupt semaphore %s status bit after enable (mask)

Value on reset: 0*/
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
pub enum MISF0 {
    ///0: No interrupt pending after masking
    NotPending = 0,
    ///1: Interrupt pending after masking
    Pending = 1,
}
impl From<MISF0> for bool {
    #[inline(always)]
    fn from(variant: MISF0) -> Self {
        variant as u8 != 0
    }
}
///Field `MISF(0-31)` reader - Masked interrupt semaphore %s status bit after enable (mask)
pub type MISF_R = crate::BitReader<MISF0>;
impl MISF_R {
    ///Get enumerated values variant
    #[inline(always)]
    pub const fn variant(&self) -> MISF0 {
        match self.bits {
            false => MISF0::NotPending,
            true => MISF0::Pending,
        }
    }
    ///No interrupt pending after masking
    #[inline(always)]
    pub fn is_not_pending(&self) -> bool {
        *self == MISF0::NotPending
    }
    ///Interrupt pending after masking
    #[inline(always)]
    pub fn is_pending(&self) -> bool {
        *self == MISF0::Pending
    }
}
impl R {
    ///Masked interrupt semaphore (0-31) status bit after enable (mask)
    ///
    ///<div class="warning">`n` is number of field in register. `n == 0` corresponds to `MISF0` field.</div>
    #[inline(always)]
    pub fn misf(&self, n: u8) -> MISF_R {
        #[allow(clippy::no_effect)]
        [(); 32][n as usize];
        MISF_R::new(((self.bits >> n) & 1) != 0)
    }
    ///Iterator for array of:
    ///Masked interrupt semaphore (0-31) status bit after enable (mask)
    #[inline(always)]
    pub fn misf_iter(&self) -> impl Iterator<Item = MISF_R> + '_ {
        (0..32).map(move |n| MISF_R::new(((self.bits >> n) & 1) != 0))
    }
    ///Bit 0 - Masked interrupt semaphore 0 status bit after enable (mask)
    #[inline(always)]
    pub fn misf0(&self) -> MISF_R {
        MISF_R::new((self.bits & 1) != 0)
    }
    ///Bit 1 - Masked interrupt semaphore 1 status bit after enable (mask)
    #[inline(always)]
    pub fn misf1(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 1) & 1) != 0)
    }
    ///Bit 2 - Masked interrupt semaphore 2 status bit after enable (mask)
    #[inline(always)]
    pub fn misf2(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 2) & 1) != 0)
    }
    ///Bit 3 - Masked interrupt semaphore 3 status bit after enable (mask)
    #[inline(always)]
    pub fn misf3(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 3) & 1) != 0)
    }
    ///Bit 4 - Masked interrupt semaphore 4 status bit after enable (mask)
    #[inline(always)]
    pub fn misf4(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 4) & 1) != 0)
    }
    ///Bit 5 - Masked interrupt semaphore 5 status bit after enable (mask)
    #[inline(always)]
    pub fn misf5(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 5) & 1) != 0)
    }
    ///Bit 6 - Masked interrupt semaphore 6 status bit after enable (mask)
    #[inline(always)]
    pub fn misf6(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 6) & 1) != 0)
    }
    ///Bit 7 - Masked interrupt semaphore 7 status bit after enable (mask)
    #[inline(always)]
    pub fn misf7(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 7) & 1) != 0)
    }
    ///Bit 8 - Masked interrupt semaphore 8 status bit after enable (mask)
    #[inline(always)]
    pub fn misf8(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 8) & 1) != 0)
    }
    ///Bit 9 - Masked interrupt semaphore 9 status bit after enable (mask)
    #[inline(always)]
    pub fn misf9(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 9) & 1) != 0)
    }
    ///Bit 10 - Masked interrupt semaphore 10 status bit after enable (mask)
    #[inline(always)]
    pub fn misf10(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 10) & 1) != 0)
    }
    ///Bit 11 - Masked interrupt semaphore 11 status bit after enable (mask)
    #[inline(always)]
    pub fn misf11(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 11) & 1) != 0)
    }
    ///Bit 12 - Masked interrupt semaphore 12 status bit after enable (mask)
    #[inline(always)]
    pub fn misf12(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 12) & 1) != 0)
    }
    ///Bit 13 - Masked interrupt semaphore 13 status bit after enable (mask)
    #[inline(always)]
    pub fn misf13(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 13) & 1) != 0)
    }
    ///Bit 14 - Masked interrupt semaphore 14 status bit after enable (mask)
    #[inline(always)]
    pub fn misf14(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 14) & 1) != 0)
    }
    ///Bit 15 - Masked interrupt semaphore 15 status bit after enable (mask)
    #[inline(always)]
    pub fn misf15(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 15) & 1) != 0)
    }
    ///Bit 16 - Masked interrupt semaphore 16 status bit after enable (mask)
    #[inline(always)]
    pub fn misf16(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 16) & 1) != 0)
    }
    ///Bit 17 - Masked interrupt semaphore 17 status bit after enable (mask)
    #[inline(always)]
    pub fn misf17(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 17) & 1) != 0)
    }
    ///Bit 18 - Masked interrupt semaphore 18 status bit after enable (mask)
    #[inline(always)]
    pub fn misf18(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 18) & 1) != 0)
    }
    ///Bit 19 - Masked interrupt semaphore 19 status bit after enable (mask)
    #[inline(always)]
    pub fn misf19(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 19) & 1) != 0)
    }
    ///Bit 20 - Masked interrupt semaphore 20 status bit after enable (mask)
    #[inline(always)]
    pub fn misf20(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 20) & 1) != 0)
    }
    ///Bit 21 - Masked interrupt semaphore 21 status bit after enable (mask)
    #[inline(always)]
    pub fn misf21(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 21) & 1) != 0)
    }
    ///Bit 22 - Masked interrupt semaphore 22 status bit after enable (mask)
    #[inline(always)]
    pub fn misf22(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 22) & 1) != 0)
    }
    ///Bit 23 - Masked interrupt semaphore 23 status bit after enable (mask)
    #[inline(always)]
    pub fn misf23(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 23) & 1) != 0)
    }
    ///Bit 24 - Masked interrupt semaphore 24 status bit after enable (mask)
    #[inline(always)]
    pub fn misf24(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 24) & 1) != 0)
    }
    ///Bit 25 - Masked interrupt semaphore 25 status bit after enable (mask)
    #[inline(always)]
    pub fn misf25(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 25) & 1) != 0)
    }
    ///Bit 26 - Masked interrupt semaphore 26 status bit after enable (mask)
    #[inline(always)]
    pub fn misf26(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 26) & 1) != 0)
    }
    ///Bit 27 - Masked interrupt semaphore 27 status bit after enable (mask)
    #[inline(always)]
    pub fn misf27(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 27) & 1) != 0)
    }
    ///Bit 28 - Masked interrupt semaphore 28 status bit after enable (mask)
    #[inline(always)]
    pub fn misf28(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 28) & 1) != 0)
    }
    ///Bit 29 - Masked interrupt semaphore 29 status bit after enable (mask)
    #[inline(always)]
    pub fn misf29(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 29) & 1) != 0)
    }
    ///Bit 30 - Masked interrupt semaphore 30 status bit after enable (mask)
    #[inline(always)]
    pub fn misf30(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 30) & 1) != 0)
    }
    ///Bit 31 - Masked interrupt semaphore 31 status bit after enable (mask)
    #[inline(always)]
    pub fn misf31(&self) -> MISF_R {
        MISF_R::new(((self.bits >> 31) & 1) != 0)
    }
}
impl core::fmt::Debug for R {
    fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
        f.debug_struct("C2MISR")
            .field("misf0", &self.misf0())
            .field("misf1", &self.misf1())
            .field("misf2", &self.misf2())
            .field("misf3", &self.misf3())
            .field("misf4", &self.misf4())
            .field("misf5", &self.misf5())
            .field("misf6", &self.misf6())
            .field("misf7", &self.misf7())
            .field("misf8", &self.misf8())
            .field("misf9", &self.misf9())
            .field("misf10", &self.misf10())
            .field("misf11", &self.misf11())
            .field("misf12", &self.misf12())
            .field("misf13", &self.misf13())
            .field("misf14", &self.misf14())
            .field("misf15", &self.misf15())
            .field("misf16", &self.misf16())
            .field("misf17", &self.misf17())
            .field("misf18", &self.misf18())
            .field("misf19", &self.misf19())
            .field("misf20", &self.misf20())
            .field("misf21", &self.misf21())
            .field("misf22", &self.misf22())
            .field("misf23", &self.misf23())
            .field("misf24", &self.misf24())
            .field("misf25", &self.misf25())
            .field("misf26", &self.misf26())
            .field("misf27", &self.misf27())
            .field("misf28", &self.misf28())
            .field("misf29", &self.misf29())
            .field("misf30", &self.misf30())
            .field("misf31", &self.misf31())
            .finish()
    }
}
/**HSEM Masked interrupt status register

You can [`read`](crate::Reg::read) this register and get [`c2misr::R`](R). See [API](https://docs.rs/svd2rust/#read--modify--write-api).

See register [structure](https://stm32-rs.github.io/stm32-rs/STM32WB55.html#HSEM:C2MISR)*/
pub struct C2MISRrs;
impl crate::RegisterSpec for C2MISRrs {
    type Ux = u32;
}
///`read()` method returns [`c2misr::R`](R) reader structure
impl crate::Readable for C2MISRrs {}
///`reset()` method sets C2MISR to value 0
impl crate::Resettable for C2MISRrs {}