#[doc = "Register `ELSR` reader"]
pub struct R(crate::R<ELSR_SPEC>);
impl core::ops::Deref for R {
    type Target = crate::R<ELSR_SPEC>;
    #[inline(always)]
    fn deref(&self) -> &Self::Target {
        &self.0
    }
}
impl From<crate::R<ELSR_SPEC>> for R {
    #[inline(always)]
    fn from(reader: crate::R<ELSR_SPEC>) -> Self {
        R(reader)
    }
}
#[doc = "Field `P0` reader - Edge/Level Interrupt Source Selection"]
pub type P0_R = crate::BitReader<bool>;
#[doc = "Field `P1` reader - Edge/Level Interrupt Source Selection"]
pub type P1_R = crate::BitReader<bool>;
#[doc = "Field `P2` reader - Edge/Level Interrupt Source Selection"]
pub type P2_R = crate::BitReader<bool>;
#[doc = "Field `P3` reader - Edge/Level Interrupt Source Selection"]
pub type P3_R = crate::BitReader<bool>;
#[doc = "Field `P4` reader - Edge/Level Interrupt Source Selection"]
pub type P4_R = crate::BitReader<bool>;
#[doc = "Field `P5` reader - Edge/Level Interrupt Source Selection"]
pub type P5_R = crate::BitReader<bool>;
#[doc = "Field `P6` reader - Edge/Level Interrupt Source Selection"]
pub type P6_R = crate::BitReader<bool>;
#[doc = "Field `P7` reader - Edge/Level Interrupt Source Selection"]
pub type P7_R = crate::BitReader<bool>;
#[doc = "Field `P8` reader - Edge/Level Interrupt Source Selection"]
pub type P8_R = crate::BitReader<bool>;
#[doc = "Field `P9` reader - Edge/Level Interrupt Source Selection"]
pub type P9_R = crate::BitReader<bool>;
#[doc = "Field `P10` reader - Edge/Level Interrupt Source Selection"]
pub type P10_R = crate::BitReader<bool>;
#[doc = "Field `P11` reader - Edge/Level Interrupt Source Selection"]
pub type P11_R = crate::BitReader<bool>;
#[doc = "Field `P12` reader - Edge/Level Interrupt Source Selection"]
pub type P12_R = crate::BitReader<bool>;
#[doc = "Field `P13` reader - Edge/Level Interrupt Source Selection"]
pub type P13_R = crate::BitReader<bool>;
#[doc = "Field `P14` reader - Edge/Level Interrupt Source Selection"]
pub type P14_R = crate::BitReader<bool>;
#[doc = "Field `P15` reader - Edge/Level Interrupt Source Selection"]
pub type P15_R = crate::BitReader<bool>;
#[doc = "Field `P16` reader - Edge/Level Interrupt Source Selection"]
pub type P16_R = crate::BitReader<bool>;
#[doc = "Field `P17` reader - Edge/Level Interrupt Source Selection"]
pub type P17_R = crate::BitReader<bool>;
#[doc = "Field `P18` reader - Edge/Level Interrupt Source Selection"]
pub type P18_R = crate::BitReader<bool>;
#[doc = "Field `P19` reader - Edge/Level Interrupt Source Selection"]
pub type P19_R = crate::BitReader<bool>;
#[doc = "Field `P20` reader - Edge/Level Interrupt Source Selection"]
pub type P20_R = crate::BitReader<bool>;
#[doc = "Field `P21` reader - Edge/Level Interrupt Source Selection"]
pub type P21_R = crate::BitReader<bool>;
#[doc = "Field `P22` reader - Edge/Level Interrupt Source Selection"]
pub type P22_R = crate::BitReader<bool>;
#[doc = "Field `P23` reader - Edge/Level Interrupt Source Selection"]
pub type P23_R = crate::BitReader<bool>;
#[doc = "Field `P24` reader - Edge/Level Interrupt Source Selection"]
pub type P24_R = crate::BitReader<bool>;
#[doc = "Field `P25` reader - Edge/Level Interrupt Source Selection"]
pub type P25_R = crate::BitReader<bool>;
#[doc = "Field `P26` reader - Edge/Level Interrupt Source Selection"]
pub type P26_R = crate::BitReader<bool>;
#[doc = "Field `P27` reader - Edge/Level Interrupt Source Selection"]
pub type P27_R = crate::BitReader<bool>;
#[doc = "Field `P28` reader - Edge/Level Interrupt Source Selection"]
pub type P28_R = crate::BitReader<bool>;
#[doc = "Field `P29` reader - Edge/Level Interrupt Source Selection"]
pub type P29_R = crate::BitReader<bool>;
#[doc = "Field `P30` reader - Edge/Level Interrupt Source Selection"]
pub type P30_R = crate::BitReader<bool>;
#[doc = "Field `P31` reader - Edge/Level Interrupt Source Selection"]
pub type P31_R = crate::BitReader<bool>;
impl R {
    #[doc = "Bit 0 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p0(&self) -> P0_R {
        P0_R::new((self.bits & 1) != 0)
    }
    #[doc = "Bit 1 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p1(&self) -> P1_R {
        P1_R::new(((self.bits >> 1) & 1) != 0)
    }
    #[doc = "Bit 2 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p2(&self) -> P2_R {
        P2_R::new(((self.bits >> 2) & 1) != 0)
    }
    #[doc = "Bit 3 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p3(&self) -> P3_R {
        P3_R::new(((self.bits >> 3) & 1) != 0)
    }
    #[doc = "Bit 4 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p4(&self) -> P4_R {
        P4_R::new(((self.bits >> 4) & 1) != 0)
    }
    #[doc = "Bit 5 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p5(&self) -> P5_R {
        P5_R::new(((self.bits >> 5) & 1) != 0)
    }
    #[doc = "Bit 6 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p6(&self) -> P6_R {
        P6_R::new(((self.bits >> 6) & 1) != 0)
    }
    #[doc = "Bit 7 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p7(&self) -> P7_R {
        P7_R::new(((self.bits >> 7) & 1) != 0)
    }
    #[doc = "Bit 8 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p8(&self) -> P8_R {
        P8_R::new(((self.bits >> 8) & 1) != 0)
    }
    #[doc = "Bit 9 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p9(&self) -> P9_R {
        P9_R::new(((self.bits >> 9) & 1) != 0)
    }
    #[doc = "Bit 10 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p10(&self) -> P10_R {
        P10_R::new(((self.bits >> 10) & 1) != 0)
    }
    #[doc = "Bit 11 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p11(&self) -> P11_R {
        P11_R::new(((self.bits >> 11) & 1) != 0)
    }
    #[doc = "Bit 12 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p12(&self) -> P12_R {
        P12_R::new(((self.bits >> 12) & 1) != 0)
    }
    #[doc = "Bit 13 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p13(&self) -> P13_R {
        P13_R::new(((self.bits >> 13) & 1) != 0)
    }
    #[doc = "Bit 14 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p14(&self) -> P14_R {
        P14_R::new(((self.bits >> 14) & 1) != 0)
    }
    #[doc = "Bit 15 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p15(&self) -> P15_R {
        P15_R::new(((self.bits >> 15) & 1) != 0)
    }
    #[doc = "Bit 16 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p16(&self) -> P16_R {
        P16_R::new(((self.bits >> 16) & 1) != 0)
    }
    #[doc = "Bit 17 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p17(&self) -> P17_R {
        P17_R::new(((self.bits >> 17) & 1) != 0)
    }
    #[doc = "Bit 18 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p18(&self) -> P18_R {
        P18_R::new(((self.bits >> 18) & 1) != 0)
    }
    #[doc = "Bit 19 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p19(&self) -> P19_R {
        P19_R::new(((self.bits >> 19) & 1) != 0)
    }
    #[doc = "Bit 20 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p20(&self) -> P20_R {
        P20_R::new(((self.bits >> 20) & 1) != 0)
    }
    #[doc = "Bit 21 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p21(&self) -> P21_R {
        P21_R::new(((self.bits >> 21) & 1) != 0)
    }
    #[doc = "Bit 22 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p22(&self) -> P22_R {
        P22_R::new(((self.bits >> 22) & 1) != 0)
    }
    #[doc = "Bit 23 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p23(&self) -> P23_R {
        P23_R::new(((self.bits >> 23) & 1) != 0)
    }
    #[doc = "Bit 24 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p24(&self) -> P24_R {
        P24_R::new(((self.bits >> 24) & 1) != 0)
    }
    #[doc = "Bit 25 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p25(&self) -> P25_R {
        P25_R::new(((self.bits >> 25) & 1) != 0)
    }
    #[doc = "Bit 26 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p26(&self) -> P26_R {
        P26_R::new(((self.bits >> 26) & 1) != 0)
    }
    #[doc = "Bit 27 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p27(&self) -> P27_R {
        P27_R::new(((self.bits >> 27) & 1) != 0)
    }
    #[doc = "Bit 28 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p28(&self) -> P28_R {
        P28_R::new(((self.bits >> 28) & 1) != 0)
    }
    #[doc = "Bit 29 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p29(&self) -> P29_R {
        P29_R::new(((self.bits >> 29) & 1) != 0)
    }
    #[doc = "Bit 30 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p30(&self) -> P30_R {
        P30_R::new(((self.bits >> 30) & 1) != 0)
    }
    #[doc = "Bit 31 - Edge/Level Interrupt Source Selection"]
    #[inline(always)]
    pub fn p31(&self) -> P31_R {
        P31_R::new(((self.bits >> 31) & 1) != 0)
    }
}
#[doc = "Edge/Level Status Register\n\nThis register you can [`read`](crate::generic::Reg::read). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [elsr](index.html) module"]
pub struct ELSR_SPEC;
impl crate::RegisterSpec for ELSR_SPEC {
    type Ux = u32;
}
#[doc = "`read()` method returns [elsr::R](R) reader structure"]
impl crate::Readable for ELSR_SPEC {
    type Reader = R;
}
#[doc = "`reset()` method sets ELSR to value 0"]
impl crate::Resettable for ELSR_SPEC {
    const RESET_VALUE: Self::Ux = 0;
}