pub type R = crate::R<AHB2RSTRrs>;
pub type W = crate::W<AHB2RSTRrs>;
#[cfg_attr(feature = "defmt", derive(defmt::Format))]
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
pub enum GPIOARST {
        Reset = 1,
}
impl From<GPIOARST> for bool {
    #[inline(always)]
    fn from(variant: GPIOARST) -> Self {
        variant as u8 != 0
    }
}
pub type GPIOARST_R = crate::BitReader<GPIOARST>;
impl GPIOARST_R {
        #[inline(always)]
    pub const fn variant(&self) -> Option<GPIOARST> {
        match self.bits {
            true => Some(GPIOARST::Reset),
            _ => None,
        }
    }
        #[inline(always)]
    pub fn is_reset(&self) -> bool {
        *self == GPIOARST::Reset
    }
}
pub type GPIOARST_W<'a, REG> = crate::BitWriter<'a, REG, GPIOARST>;
impl<'a, REG> GPIOARST_W<'a, REG>
where
    REG: crate::Writable + crate::RegisterSpec,
{
        #[inline(always)]
    pub fn reset(self) -> &'a mut crate::W<REG> {
        self.variant(GPIOARST::Reset)
    }
}
pub use GPIOARST_R as GPIOBRST_R;
pub use GPIOARST_R as GPIOCRST_R;
pub use GPIOARST_R as GPIODRST_R;
pub use GPIOARST_R as GPIOERST_R;
pub use GPIOARST_R as GPIOFRST_R;
pub use GPIOARST_R as GPIOGRST_R;
pub use GPIOARST_R as ADC12RST_R;
pub use GPIOARST_R as ADC345RST_R;
pub use GPIOARST_R as DAC1RST_R;
pub use GPIOARST_R as DAC2RST_R;
pub use GPIOARST_R as DAC3RST_R;
pub use GPIOARST_R as DAC4RST_R;
pub use GPIOARST_R as AESRST_R;
pub use GPIOARST_R as RNGRST_R;
pub use GPIOARST_W as GPIOBRST_W;
pub use GPIOARST_W as GPIOCRST_W;
pub use GPIOARST_W as GPIODRST_W;
pub use GPIOARST_W as GPIOERST_W;
pub use GPIOARST_W as GPIOFRST_W;
pub use GPIOARST_W as GPIOGRST_W;
pub use GPIOARST_W as ADC12RST_W;
pub use GPIOARST_W as ADC345RST_W;
pub use GPIOARST_W as DAC1RST_W;
pub use GPIOARST_W as DAC2RST_W;
pub use GPIOARST_W as DAC3RST_W;
pub use GPIOARST_W as DAC4RST_W;
pub use GPIOARST_W as AESRST_W;
pub use GPIOARST_W as RNGRST_W;
impl R {
        #[inline(always)]
    pub fn gpioarst(&self) -> GPIOARST_R {
        GPIOARST_R::new((self.bits & 1) != 0)
    }
        #[inline(always)]
    pub fn gpiobrst(&self) -> GPIOBRST_R {
        GPIOBRST_R::new(((self.bits >> 1) & 1) != 0)
    }
        #[inline(always)]
    pub fn gpiocrst(&self) -> GPIOCRST_R {
        GPIOCRST_R::new(((self.bits >> 2) & 1) != 0)
    }
        #[inline(always)]
    pub fn gpiodrst(&self) -> GPIODRST_R {
        GPIODRST_R::new(((self.bits >> 3) & 1) != 0)
    }
        #[inline(always)]
    pub fn gpioerst(&self) -> GPIOERST_R {
        GPIOERST_R::new(((self.bits >> 4) & 1) != 0)
    }
        #[inline(always)]
    pub fn gpiofrst(&self) -> GPIOFRST_R {
        GPIOFRST_R::new(((self.bits >> 5) & 1) != 0)
    }
        #[inline(always)]
    pub fn gpiogrst(&self) -> GPIOGRST_R {
        GPIOGRST_R::new(((self.bits >> 6) & 1) != 0)
    }
        #[inline(always)]
    pub fn adc12rst(&self) -> ADC12RST_R {
        ADC12RST_R::new(((self.bits >> 13) & 1) != 0)
    }
        #[inline(always)]
    pub fn adc345rst(&self) -> ADC345RST_R {
        ADC345RST_R::new(((self.bits >> 14) & 1) != 0)
    }
        #[inline(always)]
    pub fn dac1rst(&self) -> DAC1RST_R {
        DAC1RST_R::new(((self.bits >> 16) & 1) != 0)
    }
        #[inline(always)]
    pub fn dac2rst(&self) -> DAC2RST_R {
        DAC2RST_R::new(((self.bits >> 17) & 1) != 0)
    }
        #[inline(always)]
    pub fn dac3rst(&self) -> DAC3RST_R {
        DAC3RST_R::new(((self.bits >> 18) & 1) != 0)
    }
        #[inline(always)]
    pub fn dac4rst(&self) -> DAC4RST_R {
        DAC4RST_R::new(((self.bits >> 19) & 1) != 0)
    }
        #[inline(always)]
    pub fn aesrst(&self) -> AESRST_R {
        AESRST_R::new(((self.bits >> 24) & 1) != 0)
    }
        #[inline(always)]
    pub fn rngrst(&self) -> RNGRST_R {
        RNGRST_R::new(((self.bits >> 26) & 1) != 0)
    }
}
impl core::fmt::Debug for R {
    fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
        f.debug_struct("AHB2RSTR")
            .field("gpioarst", &self.gpioarst())
            .field("gpiobrst", &self.gpiobrst())
            .field("gpiocrst", &self.gpiocrst())
            .field("gpiodrst", &self.gpiodrst())
            .field("gpioerst", &self.gpioerst())
            .field("gpiofrst", &self.gpiofrst())
            .field("gpiogrst", &self.gpiogrst())
            .field("adc12rst", &self.adc12rst())
            .field("adc345rst", &self.adc345rst())
            .field("dac1rst", &self.dac1rst())
            .field("dac2rst", &self.dac2rst())
            .field("dac3rst", &self.dac3rst())
            .field("dac4rst", &self.dac4rst())
            .field("aesrst", &self.aesrst())
            .field("rngrst", &self.rngrst())
            .finish()
    }
}
impl W {
        #[inline(always)]
    pub fn gpioarst(&mut self) -> GPIOARST_W<AHB2RSTRrs> {
        GPIOARST_W::new(self, 0)
    }
        #[inline(always)]
    pub fn gpiobrst(&mut self) -> GPIOBRST_W<AHB2RSTRrs> {
        GPIOBRST_W::new(self, 1)
    }
        #[inline(always)]
    pub fn gpiocrst(&mut self) -> GPIOCRST_W<AHB2RSTRrs> {
        GPIOCRST_W::new(self, 2)
    }
        #[inline(always)]
    pub fn gpiodrst(&mut self) -> GPIODRST_W<AHB2RSTRrs> {
        GPIODRST_W::new(self, 3)
    }
        #[inline(always)]
    pub fn gpioerst(&mut self) -> GPIOERST_W<AHB2RSTRrs> {
        GPIOERST_W::new(self, 4)
    }
        #[inline(always)]
    pub fn gpiofrst(&mut self) -> GPIOFRST_W<AHB2RSTRrs> {
        GPIOFRST_W::new(self, 5)
    }
        #[inline(always)]
    pub fn gpiogrst(&mut self) -> GPIOGRST_W<AHB2RSTRrs> {
        GPIOGRST_W::new(self, 6)
    }
        #[inline(always)]
    pub fn adc12rst(&mut self) -> ADC12RST_W<AHB2RSTRrs> {
        ADC12RST_W::new(self, 13)
    }
        #[inline(always)]
    pub fn adc345rst(&mut self) -> ADC345RST_W<AHB2RSTRrs> {
        ADC345RST_W::new(self, 14)
    }
        #[inline(always)]
    pub fn dac1rst(&mut self) -> DAC1RST_W<AHB2RSTRrs> {
        DAC1RST_W::new(self, 16)
    }
        #[inline(always)]
    pub fn dac2rst(&mut self) -> DAC2RST_W<AHB2RSTRrs> {
        DAC2RST_W::new(self, 17)
    }
        #[inline(always)]
    pub fn dac3rst(&mut self) -> DAC3RST_W<AHB2RSTRrs> {
        DAC3RST_W::new(self, 18)
    }
        #[inline(always)]
    pub fn dac4rst(&mut self) -> DAC4RST_W<AHB2RSTRrs> {
        DAC4RST_W::new(self, 19)
    }
        #[inline(always)]
    pub fn aesrst(&mut self) -> AESRST_W<AHB2RSTRrs> {
        AESRST_W::new(self, 24)
    }
        #[inline(always)]
    pub fn rngrst(&mut self) -> RNGRST_W<AHB2RSTRrs> {
        RNGRST_W::new(self, 26)
    }
}
pub struct AHB2RSTRrs;
impl crate::RegisterSpec for AHB2RSTRrs {
    type Ux = u32;
}
impl crate::Readable for AHB2RSTRrs {}
impl crate::Writable for AHB2RSTRrs {
    type Safety = crate::Unsafe;
}
impl crate::Resettable for AHB2RSTRrs {}