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 {}