#[doc = "Register `OTG_FS_GUSBCFG` reader"]
pub struct R(crate::R<OTG_FS_GUSBCFG_SPEC>);
impl core::ops::Deref for R {
type Target = crate::R<OTG_FS_GUSBCFG_SPEC>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
impl From<crate::R<OTG_FS_GUSBCFG_SPEC>> for R {
#[inline(always)]
fn from(reader: crate::R<OTG_FS_GUSBCFG_SPEC>) -> Self {
R(reader)
}
}
#[doc = "Register `OTG_FS_GUSBCFG` writer"]
pub struct W(crate::W<OTG_FS_GUSBCFG_SPEC>);
impl core::ops::Deref for W {
type Target = crate::W<OTG_FS_GUSBCFG_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_GUSBCFG_SPEC>> for W {
#[inline(always)]
fn from(writer: crate::W<OTG_FS_GUSBCFG_SPEC>) -> Self {
W(writer)
}
}
#[doc = "Field `TOCAL` reader - FS timeout calibration"]
pub type TOCAL_R = crate::FieldReader<u8, u8>;
#[doc = "Field `TOCAL` writer - FS timeout calibration"]
pub type TOCAL_W<'a> = crate::FieldWriter<'a, u32, OTG_FS_GUSBCFG_SPEC, u8, u8, 3, 0>;
#[doc = "Field `PHYSEL` writer - Full Speed serial transceiver select"]
pub type PHYSEL_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GUSBCFG_SPEC, bool, 6>;
#[doc = "Field `SRPCAP` reader - SRP-capable"]
pub type SRPCAP_R = crate::BitReader<bool>;
#[doc = "Field `SRPCAP` writer - SRP-capable"]
pub type SRPCAP_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GUSBCFG_SPEC, bool, 8>;
#[doc = "Field `HNPCAP` reader - HNP-capable"]
pub type HNPCAP_R = crate::BitReader<bool>;
#[doc = "Field `HNPCAP` writer - HNP-capable"]
pub type HNPCAP_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GUSBCFG_SPEC, bool, 9>;
#[doc = "Field `TRDT` reader - USB turnaround time"]
pub type TRDT_R = crate::FieldReader<u8, u8>;
#[doc = "Field `TRDT` writer - USB turnaround time"]
pub type TRDT_W<'a> = crate::FieldWriter<'a, u32, OTG_FS_GUSBCFG_SPEC, u8, u8, 4, 10>;
#[doc = "Field `FHMOD` reader - Force host mode"]
pub type FHMOD_R = crate::BitReader<bool>;
#[doc = "Field `FHMOD` writer - Force host mode"]
pub type FHMOD_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GUSBCFG_SPEC, bool, 29>;
#[doc = "Field `FDMOD` reader - Force device mode"]
pub type FDMOD_R = crate::BitReader<bool>;
#[doc = "Field `FDMOD` writer - Force device mode"]
pub type FDMOD_W<'a> = crate::BitWriter<'a, u32, OTG_FS_GUSBCFG_SPEC, bool, 30>;
impl R {
#[doc = "Bits 0:2 - FS timeout calibration"]
#[inline(always)]
pub fn tocal(&self) -> TOCAL_R {
TOCAL_R::new((self.bits & 7) as u8)
}
#[doc = "Bit 8 - SRP-capable"]
#[inline(always)]
pub fn srpcap(&self) -> SRPCAP_R {
SRPCAP_R::new(((self.bits >> 8) & 1) != 0)
}
#[doc = "Bit 9 - HNP-capable"]
#[inline(always)]
pub fn hnpcap(&self) -> HNPCAP_R {
HNPCAP_R::new(((self.bits >> 9) & 1) != 0)
}
#[doc = "Bits 10:13 - USB turnaround time"]
#[inline(always)]
pub fn trdt(&self) -> TRDT_R {
TRDT_R::new(((self.bits >> 10) & 0x0f) as u8)
}
#[doc = "Bit 29 - Force host mode"]
#[inline(always)]
pub fn fhmod(&self) -> FHMOD_R {
FHMOD_R::new(((self.bits >> 29) & 1) != 0)
}
#[doc = "Bit 30 - Force device mode"]
#[inline(always)]
pub fn fdmod(&self) -> FDMOD_R {
FDMOD_R::new(((self.bits >> 30) & 1) != 0)
}
}
impl W {
#[doc = "Bits 0:2 - FS timeout calibration"]
#[inline(always)]
pub fn tocal(&mut self) -> TOCAL_W {
TOCAL_W::new(self)
}
#[doc = "Bit 6 - Full Speed serial transceiver select"]
#[inline(always)]
pub fn physel(&mut self) -> PHYSEL_W {
PHYSEL_W::new(self)
}
#[doc = "Bit 8 - SRP-capable"]
#[inline(always)]
pub fn srpcap(&mut self) -> SRPCAP_W {
SRPCAP_W::new(self)
}
#[doc = "Bit 9 - HNP-capable"]
#[inline(always)]
pub fn hnpcap(&mut self) -> HNPCAP_W {
HNPCAP_W::new(self)
}
#[doc = "Bits 10:13 - USB turnaround time"]
#[inline(always)]
pub fn trdt(&mut self) -> TRDT_W {
TRDT_W::new(self)
}
#[doc = "Bit 29 - Force host mode"]
#[inline(always)]
pub fn fhmod(&mut self) -> FHMOD_W {
FHMOD_W::new(self)
}
#[doc = "Bit 30 - Force device mode"]
#[inline(always)]
pub fn fdmod(&mut self) -> FDMOD_W {
FDMOD_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 USB configuration register (OTG_FS_GUSBCFG)\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_gusbcfg](index.html) module"]
pub struct OTG_FS_GUSBCFG_SPEC;
impl crate::RegisterSpec for OTG_FS_GUSBCFG_SPEC {
type Ux = u32;
}
#[doc = "`read()` method returns [otg_fs_gusbcfg::R](R) reader structure"]
impl crate::Readable for OTG_FS_GUSBCFG_SPEC {
type Reader = R;
}
#[doc = "`write(|w| ..)` method takes [otg_fs_gusbcfg::W](W) writer structure"]
impl crate::Writable for OTG_FS_GUSBCFG_SPEC {
type Writer = W;
}
#[doc = "`reset()` method sets OTG_FS_GUSBCFG to value 0x0a00"]
impl crate::Resettable for OTG_FS_GUSBCFG_SPEC {
#[inline(always)]
fn reset_value() -> Self::Ux {
0x0a00
}
}