#[doc = "Register `FNR` reader"]
pub struct R(crate::R<FNR_SPEC>);
impl core::ops::Deref for R {
type Target = crate::R<FNR_SPEC>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
impl From<crate::R<FNR_SPEC>> for R {
#[inline(always)]
fn from(reader: crate::R<FNR_SPEC>) -> Self {
R(reader)
}
}
#[doc = "RXDP\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum RXDP_A {
#[doc = "1: received data plus upstream port data line"]
Received = 1,
}
impl From<RXDP_A> for bool {
#[inline(always)]
fn from(variant: RXDP_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `RXDP` reader - RXDP"]
pub type RXDP_R = crate::BitReader<RXDP_A>;
impl RXDP_R {
#[doc = "Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> Option<RXDP_A> {
match self.bits {
true => Some(RXDP_A::Received),
_ => None,
}
}
#[doc = "Checks if the value of the field is `Received`"]
#[inline(always)]
pub fn is_received(&self) -> bool {
*self == RXDP_A::Received
}
}
#[doc = "RXDM\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum RXDM_A {
#[doc = "1: received data minus upstream port data line"]
Received = 1,
}
impl From<RXDM_A> for bool {
#[inline(always)]
fn from(variant: RXDM_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `RXDM` reader - RXDM"]
pub type RXDM_R = crate::BitReader<RXDM_A>;
impl RXDM_R {
#[doc = "Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> Option<RXDM_A> {
match self.bits {
true => Some(RXDM_A::Received),
_ => None,
}
}
#[doc = "Checks if the value of the field is `Received`"]
#[inline(always)]
pub fn is_received(&self) -> bool {
*self == RXDM_A::Received
}
}
#[doc = "LCK\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum LCK_A {
#[doc = "1: the frame timer remains in this state until an USB reset or USB suspend event occurs"]
Locked = 1,
}
impl From<LCK_A> for bool {
#[inline(always)]
fn from(variant: LCK_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `LCK` reader - LCK"]
pub type LCK_R = crate::BitReader<LCK_A>;
impl LCK_R {
#[doc = "Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> Option<LCK_A> {
match self.bits {
true => Some(LCK_A::Locked),
_ => None,
}
}
#[doc = "Checks if the value of the field is `Locked`"]
#[inline(always)]
pub fn is_locked(&self) -> bool {
*self == LCK_A::Locked
}
}
#[doc = "Field `LSOF` reader - LSOF"]
pub type LSOF_R = crate::FieldReader<u8, u8>;
#[doc = "Field `FN` reader - FN"]
pub type FN_R = crate::FieldReader<u16, u16>;
impl R {
#[doc = "Bit 15 - RXDP"]
#[inline(always)]
pub fn rxdp(&self) -> RXDP_R {
RXDP_R::new(((self.bits >> 15) & 1) != 0)
}
#[doc = "Bit 14 - RXDM"]
#[inline(always)]
pub fn rxdm(&self) -> RXDM_R {
RXDM_R::new(((self.bits >> 14) & 1) != 0)
}
#[doc = "Bit 13 - LCK"]
#[inline(always)]
pub fn lck(&self) -> LCK_R {
LCK_R::new(((self.bits >> 13) & 1) != 0)
}
#[doc = "Bits 11:12 - LSOF"]
#[inline(always)]
pub fn lsof(&self) -> LSOF_R {
LSOF_R::new(((self.bits >> 11) & 3) as u8)
}
#[doc = "Bits 0:10 - FN"]
#[inline(always)]
pub fn fn_(&self) -> FN_R {
FN_R::new((self.bits & 0x07ff) as u16)
}
}
#[doc = "frame number 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 [fnr](index.html) module"]
pub struct FNR_SPEC;
impl crate::RegisterSpec for FNR_SPEC {
type Ux = u32;
}
#[doc = "`read()` method returns [fnr::R](R) reader structure"]
impl crate::Readable for FNR_SPEC {
type Reader = R;
}
#[doc = "`reset()` method sets FNR to value 0"]
impl crate::Resettable for FNR_SPEC {
#[inline(always)]
fn reset_value() -> Self::Ux {
0
}
}