stm32mp1 0.15.1

Device support crates for STM32MP1 devices
Documentation
#[doc = "Register `GPIOI_OSPEEDR` reader"]
pub struct R(crate::R<GPIOI_OSPEEDR_SPEC>);
impl core::ops::Deref for R {
    type Target = crate::R<GPIOI_OSPEEDR_SPEC>;
    #[inline(always)]
    fn deref(&self) -> &Self::Target {
        &self.0
    }
}
impl From<crate::R<GPIOI_OSPEEDR_SPEC>> for R {
    #[inline(always)]
    fn from(reader: crate::R<GPIOI_OSPEEDR_SPEC>) -> Self {
        R(reader)
    }
}
#[doc = "Register `GPIOI_OSPEEDR` writer"]
pub struct W(crate::W<GPIOI_OSPEEDR_SPEC>);
impl core::ops::Deref for W {
    type Target = crate::W<GPIOI_OSPEEDR_SPEC>;
    #[inline(always)]
    fn deref(&self) -> &Self::Target {
        &self.0
    }
}
impl core::ops::DerefMut for W {
    #[inline(always)]
    fn deref_mut(&mut self) -> &mut Self::Target {
        &mut self.0
    }
}
impl From<crate::W<GPIOI_OSPEEDR_SPEC>> for W {
    #[inline(always)]
    fn from(writer: crate::W<GPIOI_OSPEEDR_SPEC>) -> Self {
        W(writer)
    }
}
#[doc = "Field `OSPEEDR0` reader - OSPEEDR0"]
pub type OSPEEDR0_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR0` writer - OSPEEDR0"]
pub type OSPEEDR0_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR1` reader - OSPEEDR1"]
pub type OSPEEDR1_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR1` writer - OSPEEDR1"]
pub type OSPEEDR1_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR2` reader - OSPEEDR2"]
pub type OSPEEDR2_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR2` writer - OSPEEDR2"]
pub type OSPEEDR2_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR3` reader - OSPEEDR3"]
pub type OSPEEDR3_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR3` writer - OSPEEDR3"]
pub type OSPEEDR3_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR4` reader - OSPEEDR4"]
pub type OSPEEDR4_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR4` writer - OSPEEDR4"]
pub type OSPEEDR4_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR5` reader - OSPEEDR5"]
pub type OSPEEDR5_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR5` writer - OSPEEDR5"]
pub type OSPEEDR5_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR6` reader - OSPEEDR6"]
pub type OSPEEDR6_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR6` writer - OSPEEDR6"]
pub type OSPEEDR6_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR7` reader - OSPEEDR7"]
pub type OSPEEDR7_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR7` writer - OSPEEDR7"]
pub type OSPEEDR7_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR8` reader - OSPEEDR8"]
pub type OSPEEDR8_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR8` writer - OSPEEDR8"]
pub type OSPEEDR8_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR9` reader - OSPEEDR9"]
pub type OSPEEDR9_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR9` writer - OSPEEDR9"]
pub type OSPEEDR9_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR10` reader - OSPEEDR10"]
pub type OSPEEDR10_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR10` writer - OSPEEDR10"]
pub type OSPEEDR10_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR11` reader - OSPEEDR11"]
pub type OSPEEDR11_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR11` writer - OSPEEDR11"]
pub type OSPEEDR11_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR12` reader - OSPEEDR12"]
pub type OSPEEDR12_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR12` writer - OSPEEDR12"]
pub type OSPEEDR12_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR13` reader - OSPEEDR13"]
pub type OSPEEDR13_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR13` writer - OSPEEDR13"]
pub type OSPEEDR13_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR14` reader - OSPEEDR14"]
pub type OSPEEDR14_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR14` writer - OSPEEDR14"]
pub type OSPEEDR14_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
#[doc = "Field `OSPEEDR15` reader - OSPEEDR15"]
pub type OSPEEDR15_R = crate::FieldReader<u8, u8>;
#[doc = "Field `OSPEEDR15` writer - OSPEEDR15"]
pub type OSPEEDR15_W<'a, const O: u8> =
    crate::FieldWriter<'a, u32, GPIOI_OSPEEDR_SPEC, u8, u8, 2, O>;
impl R {
    #[doc = "Bits 0:1 - OSPEEDR0"]
    #[inline(always)]
    pub fn ospeedr0(&self) -> OSPEEDR0_R {
        OSPEEDR0_R::new((self.bits & 3) as u8)
    }
    #[doc = "Bits 2:3 - OSPEEDR1"]
    #[inline(always)]
    pub fn ospeedr1(&self) -> OSPEEDR1_R {
        OSPEEDR1_R::new(((self.bits >> 2) & 3) as u8)
    }
    #[doc = "Bits 4:5 - OSPEEDR2"]
    #[inline(always)]
    pub fn ospeedr2(&self) -> OSPEEDR2_R {
        OSPEEDR2_R::new(((self.bits >> 4) & 3) as u8)
    }
    #[doc = "Bits 6:7 - OSPEEDR3"]
    #[inline(always)]
    pub fn ospeedr3(&self) -> OSPEEDR3_R {
        OSPEEDR3_R::new(((self.bits >> 6) & 3) as u8)
    }
    #[doc = "Bits 8:9 - OSPEEDR4"]
    #[inline(always)]
    pub fn ospeedr4(&self) -> OSPEEDR4_R {
        OSPEEDR4_R::new(((self.bits >> 8) & 3) as u8)
    }
    #[doc = "Bits 10:11 - OSPEEDR5"]
    #[inline(always)]
    pub fn ospeedr5(&self) -> OSPEEDR5_R {
        OSPEEDR5_R::new(((self.bits >> 10) & 3) as u8)
    }
    #[doc = "Bits 12:13 - OSPEEDR6"]
    #[inline(always)]
    pub fn ospeedr6(&self) -> OSPEEDR6_R {
        OSPEEDR6_R::new(((self.bits >> 12) & 3) as u8)
    }
    #[doc = "Bits 14:15 - OSPEEDR7"]
    #[inline(always)]
    pub fn ospeedr7(&self) -> OSPEEDR7_R {
        OSPEEDR7_R::new(((self.bits >> 14) & 3) as u8)
    }
    #[doc = "Bits 16:17 - OSPEEDR8"]
    #[inline(always)]
    pub fn ospeedr8(&self) -> OSPEEDR8_R {
        OSPEEDR8_R::new(((self.bits >> 16) & 3) as u8)
    }
    #[doc = "Bits 18:19 - OSPEEDR9"]
    #[inline(always)]
    pub fn ospeedr9(&self) -> OSPEEDR9_R {
        OSPEEDR9_R::new(((self.bits >> 18) & 3) as u8)
    }
    #[doc = "Bits 20:21 - OSPEEDR10"]
    #[inline(always)]
    pub fn ospeedr10(&self) -> OSPEEDR10_R {
        OSPEEDR10_R::new(((self.bits >> 20) & 3) as u8)
    }
    #[doc = "Bits 22:23 - OSPEEDR11"]
    #[inline(always)]
    pub fn ospeedr11(&self) -> OSPEEDR11_R {
        OSPEEDR11_R::new(((self.bits >> 22) & 3) as u8)
    }
    #[doc = "Bits 24:25 - OSPEEDR12"]
    #[inline(always)]
    pub fn ospeedr12(&self) -> OSPEEDR12_R {
        OSPEEDR12_R::new(((self.bits >> 24) & 3) as u8)
    }
    #[doc = "Bits 26:27 - OSPEEDR13"]
    #[inline(always)]
    pub fn ospeedr13(&self) -> OSPEEDR13_R {
        OSPEEDR13_R::new(((self.bits >> 26) & 3) as u8)
    }
    #[doc = "Bits 28:29 - OSPEEDR14"]
    #[inline(always)]
    pub fn ospeedr14(&self) -> OSPEEDR14_R {
        OSPEEDR14_R::new(((self.bits >> 28) & 3) as u8)
    }
    #[doc = "Bits 30:31 - OSPEEDR15"]
    #[inline(always)]
    pub fn ospeedr15(&self) -> OSPEEDR15_R {
        OSPEEDR15_R::new(((self.bits >> 30) & 3) as u8)
    }
}
impl W {
    #[doc = "Bits 0:1 - OSPEEDR0"]
    #[inline(always)]
    pub fn ospeedr0(&mut self) -> OSPEEDR0_W<0> {
        OSPEEDR0_W::new(self)
    }
    #[doc = "Bits 2:3 - OSPEEDR1"]
    #[inline(always)]
    pub fn ospeedr1(&mut self) -> OSPEEDR1_W<2> {
        OSPEEDR1_W::new(self)
    }
    #[doc = "Bits 4:5 - OSPEEDR2"]
    #[inline(always)]
    pub fn ospeedr2(&mut self) -> OSPEEDR2_W<4> {
        OSPEEDR2_W::new(self)
    }
    #[doc = "Bits 6:7 - OSPEEDR3"]
    #[inline(always)]
    pub fn ospeedr3(&mut self) -> OSPEEDR3_W<6> {
        OSPEEDR3_W::new(self)
    }
    #[doc = "Bits 8:9 - OSPEEDR4"]
    #[inline(always)]
    pub fn ospeedr4(&mut self) -> OSPEEDR4_W<8> {
        OSPEEDR4_W::new(self)
    }
    #[doc = "Bits 10:11 - OSPEEDR5"]
    #[inline(always)]
    pub fn ospeedr5(&mut self) -> OSPEEDR5_W<10> {
        OSPEEDR5_W::new(self)
    }
    #[doc = "Bits 12:13 - OSPEEDR6"]
    #[inline(always)]
    pub fn ospeedr6(&mut self) -> OSPEEDR6_W<12> {
        OSPEEDR6_W::new(self)
    }
    #[doc = "Bits 14:15 - OSPEEDR7"]
    #[inline(always)]
    pub fn ospeedr7(&mut self) -> OSPEEDR7_W<14> {
        OSPEEDR7_W::new(self)
    }
    #[doc = "Bits 16:17 - OSPEEDR8"]
    #[inline(always)]
    pub fn ospeedr8(&mut self) -> OSPEEDR8_W<16> {
        OSPEEDR8_W::new(self)
    }
    #[doc = "Bits 18:19 - OSPEEDR9"]
    #[inline(always)]
    pub fn ospeedr9(&mut self) -> OSPEEDR9_W<18> {
        OSPEEDR9_W::new(self)
    }
    #[doc = "Bits 20:21 - OSPEEDR10"]
    #[inline(always)]
    pub fn ospeedr10(&mut self) -> OSPEEDR10_W<20> {
        OSPEEDR10_W::new(self)
    }
    #[doc = "Bits 22:23 - OSPEEDR11"]
    #[inline(always)]
    pub fn ospeedr11(&mut self) -> OSPEEDR11_W<22> {
        OSPEEDR11_W::new(self)
    }
    #[doc = "Bits 24:25 - OSPEEDR12"]
    #[inline(always)]
    pub fn ospeedr12(&mut self) -> OSPEEDR12_W<24> {
        OSPEEDR12_W::new(self)
    }
    #[doc = "Bits 26:27 - OSPEEDR13"]
    #[inline(always)]
    pub fn ospeedr13(&mut self) -> OSPEEDR13_W<26> {
        OSPEEDR13_W::new(self)
    }
    #[doc = "Bits 28:29 - OSPEEDR14"]
    #[inline(always)]
    pub fn ospeedr14(&mut self) -> OSPEEDR14_W<28> {
        OSPEEDR14_W::new(self)
    }
    #[doc = "Bits 30:31 - OSPEEDR15"]
    #[inline(always)]
    pub fn ospeedr15(&mut self) -> OSPEEDR15_W<30> {
        OSPEEDR15_W::new(self)
    }
    #[doc = "Writes raw bits to the register."]
    #[inline(always)]
    pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
        self.0.bits(bits);
        self
    }
}
#[doc = "GPIO port output speed register\n\nThis register you can [`read`](crate::generic::Reg::read), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [gpioi_ospeedr](index.html) module"]
pub struct GPIOI_OSPEEDR_SPEC;
impl crate::RegisterSpec for GPIOI_OSPEEDR_SPEC {
    type Ux = u32;
}
#[doc = "`read()` method returns [gpioi_ospeedr::R](R) reader structure"]
impl crate::Readable for GPIOI_OSPEEDR_SPEC {
    type Reader = R;
}
#[doc = "`write(|w| ..)` method takes [gpioi_ospeedr::W](W) writer structure"]
impl crate::Writable for GPIOI_OSPEEDR_SPEC {
    type Writer = W;
}
#[doc = "`reset()` method sets GPIOI_OSPEEDR to value 0"]
impl crate::Resettable for GPIOI_OSPEEDR_SPEC {
    #[inline(always)]
    fn reset_value() -> Self::Ux {
        0
    }
}