#[doc = "Register `OTG_FS_GCCFG` reader"]
pub struct R(crate::R<OTG_FS_GCCFG_SPEC>);
impl core::ops::Deref for R {
type Target = crate::R<OTG_FS_GCCFG_SPEC>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
impl From<crate::R<OTG_FS_GCCFG_SPEC>> for R {
#[inline(always)]
fn from(reader: crate::R<OTG_FS_GCCFG_SPEC>) -> Self {
R(reader)
}
}
#[doc = "Register `OTG_FS_GCCFG` writer"]
pub struct W(crate::W<OTG_FS_GCCFG_SPEC>);
impl core::ops::Deref for W {
type Target = crate::W<OTG_FS_GCCFG_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<OTG_FS_GCCFG_SPEC>> for W {
#[inline(always)]
fn from(writer: crate::W<OTG_FS_GCCFG_SPEC>) -> Self {
W(writer)
}
}
#[doc = "Field `PWRDWN` reader - Power down"]
pub type PWRDWN_R = crate::BitReader<bool>;
#[doc = "Field `PWRDWN` writer - Power down"]
pub type PWRDWN_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GCCFG_SPEC, bool, 16>;
#[doc = "Field `BCDEN` reader - Battery charging detector (BCD) enable"]
pub type BCDEN_R = crate::BitReader<bool>;
#[doc = "Field `BCDEN` writer - Battery charging detector (BCD) enable"]
pub type BCDEN_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GCCFG_SPEC, bool, 17>;
#[doc = "Field `DCDEN` reader - Data contact detection (DCD) mode enable"]
pub type DCDEN_R = crate::BitReader<bool>;
#[doc = "Field `DCDEN` writer - Data contact detection (DCD) mode enable"]
pub type DCDEN_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GCCFG_SPEC, bool, 18>;
#[doc = "Field `PDEN` reader - Primary detection (PD) mode enable"]
pub type PDEN_R = crate::BitReader<bool>;
#[doc = "Field `PDEN` writer - Primary detection (PD) mode enable"]
pub type PDEN_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GCCFG_SPEC, bool, 19>;
#[doc = "Field `SDEN` reader - Secondary detection (SD) mode enable"]
pub type SDEN_R = crate::BitReader<bool>;
#[doc = "Field `SDEN` writer - Secondary detection (SD) mode enable"]
pub type SDEN_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GCCFG_SPEC, bool, 20>;
#[doc = "Field `VBDEN` reader - USB VBUS detection enable"]
pub type VBDEN_R = crate::BitReader<bool>;
#[doc = "Field `VBDEN` writer - USB VBUS detection enable"]
pub type VBDEN_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GCCFG_SPEC, bool, 21>;
#[doc = "Field `DCDET` reader - Data contact detection (DCD) status"]
pub type DCDET_R = crate::BitReader<bool>;
#[doc = "Field `DCDET` writer - Data contact detection (DCD) status"]
pub type DCDET_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GCCFG_SPEC, bool, 0>;
#[doc = "Field `PDET` reader - Primary detection (PD) status"]
pub type PDET_R = crate::BitReader<bool>;
#[doc = "Field `PDET` writer - Primary detection (PD) status"]
pub type PDET_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GCCFG_SPEC, bool, 1>;
#[doc = "Field `SDET` reader - Secondary detection (SD) status"]
pub type SDET_R = crate::BitReader<bool>;
#[doc = "Field `SDET` writer - Secondary detection (SD) status"]
pub type SDET_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GCCFG_SPEC, bool, 2>;
#[doc = "Field `PS2DET` reader - DM pull-up detection status"]
pub type PS2DET_R = crate::BitReader<bool>;
#[doc = "Field `PS2DET` writer - DM pull-up detection status"]
pub type PS2DET_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GCCFG_SPEC, bool, 3>;
impl R {
#[doc = "Bit 16 - Power down"]
#[inline(always)]
pub fn pwrdwn(&self) -> PWRDWN_R {
PWRDWN_R::new(((self.bits >> 16) & 1) != 0)
}
#[doc = "Bit 17 - Battery charging detector (BCD) enable"]
#[inline(always)]
pub fn bcden(&self) -> BCDEN_R {
BCDEN_R::new(((self.bits >> 17) & 1) != 0)
}
#[doc = "Bit 18 - Data contact detection (DCD) mode enable"]
#[inline(always)]
pub fn dcden(&self) -> DCDEN_R {
DCDEN_R::new(((self.bits >> 18) & 1) != 0)
}
#[doc = "Bit 19 - Primary detection (PD) mode enable"]
#[inline(always)]
pub fn pden(&self) -> PDEN_R {
PDEN_R::new(((self.bits >> 19) & 1) != 0)
}
#[doc = "Bit 20 - Secondary detection (SD) mode enable"]
#[inline(always)]
pub fn sden(&self) -> SDEN_R {
SDEN_R::new(((self.bits >> 20) & 1) != 0)
}
#[doc = "Bit 21 - USB VBUS detection enable"]
#[inline(always)]
pub fn vbden(&self) -> VBDEN_R {
VBDEN_R::new(((self.bits >> 21) & 1) != 0)
}
#[doc = "Bit 0 - Data contact detection (DCD) status"]
#[inline(always)]
pub fn dcdet(&self) -> DCDET_R {
DCDET_R::new((self.bits & 1) != 0)
}
#[doc = "Bit 1 - Primary detection (PD) status"]
#[inline(always)]
pub fn pdet(&self) -> PDET_R {
PDET_R::new(((self.bits >> 1) & 1) != 0)
}
#[doc = "Bit 2 - Secondary detection (SD) status"]
#[inline(always)]
pub fn sdet(&self) -> SDET_R {
SDET_R::new(((self.bits >> 2) & 1) != 0)
}
#[doc = "Bit 3 - DM pull-up detection status"]
#[inline(always)]
pub fn ps2det(&self) -> PS2DET_R {
PS2DET_R::new(((self.bits >> 3) & 1) != 0)
}
}
impl W {
#[doc = "Bit 16 - Power down"]
#[inline(always)]
pub fn pwrdwn(&mut self) -> PWRDWN_W {
PWRDWN_W::new(self)
}
#[doc = "Bit 17 - Battery charging detector (BCD) enable"]
#[inline(always)]
pub fn bcden(&mut self) -> BCDEN_W {
BCDEN_W::new(self)
}
#[doc = "Bit 18 - Data contact detection (DCD) mode enable"]
#[inline(always)]
pub fn dcden(&mut self) -> DCDEN_W {
DCDEN_W::new(self)
}
#[doc = "Bit 19 - Primary detection (PD) mode enable"]
#[inline(always)]
pub fn pden(&mut self) -> PDEN_W {
PDEN_W::new(self)
}
#[doc = "Bit 20 - Secondary detection (SD) mode enable"]
#[inline(always)]
pub fn sden(&mut self) -> SDEN_W {
SDEN_W::new(self)
}
#[doc = "Bit 21 - USB VBUS detection enable"]
#[inline(always)]
pub fn vbden(&mut self) -> VBDEN_W {
VBDEN_W::new(self)
}
#[doc = "Bit 0 - Data contact detection (DCD) status"]
#[inline(always)]
pub fn dcdet(&mut self) -> DCDET_W {
DCDET_W::new(self)
}
#[doc = "Bit 1 - Primary detection (PD) status"]
#[inline(always)]
pub fn pdet(&mut self) -> PDET_W {
PDET_W::new(self)
}
#[doc = "Bit 2 - Secondary detection (SD) status"]
#[inline(always)]
pub fn sdet(&mut self) -> SDET_W {
SDET_W::new(self)
}
#[doc = "Bit 3 - DM pull-up detection status"]
#[inline(always)]
pub fn ps2det(&mut self) -> PS2DET_W {
PS2DET_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 = "OTG_FS general core configuration register (OTG_FS_GCCFG)\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 [otg_fs_gccfg](index.html) module"]
pub struct OTG_FS_GCCFG_SPEC;
impl crate::RegisterSpec for OTG_FS_GCCFG_SPEC {
type Ux = u32;
}
#[doc = "`read()` method returns [otg_fs_gccfg::R](R) reader structure"]
impl crate::Readable for OTG_FS_GCCFG_SPEC {
type Reader = R;
}
#[doc = "`write(|w| ..)` method takes [otg_fs_gccfg::W](W) writer structure"]
impl crate::Writable for OTG_FS_GCCFG_SPEC {
type Writer = W;
}
#[doc = "`reset()` method sets OTG_FS_GCCFG to value 0"]
impl crate::Resettable for OTG_FS_GCCFG_SPEC {
#[inline(always)]
fn reset_value() -> Self::Ux {
0
}
}