pub type R = crate::R<GRXSTSP_DEVICErs>;
pub type EPNUM_R = crate::FieldReader;
pub type BCNT_R = crate::FieldReader<u16>;
pub type DPID_R = crate::FieldReader;
pub type PKTSTS_R = crate::FieldReader;
pub type FRMNUM_R = crate::FieldReader;
impl R {
#[inline(always)]
pub fn epnum(&self) -> EPNUM_R {
EPNUM_R::new((self.bits & 0x0f) as u8)
}
#[inline(always)]
pub fn bcnt(&self) -> BCNT_R {
BCNT_R::new(((self.bits >> 4) & 0x07ff) as u16)
}
#[inline(always)]
pub fn dpid(&self) -> DPID_R {
DPID_R::new(((self.bits >> 15) & 3) as u8)
}
#[inline(always)]
pub fn pktsts(&self) -> PKTSTS_R {
PKTSTS_R::new(((self.bits >> 17) & 0x0f) as u8)
}
#[inline(always)]
pub fn frmnum(&self) -> FRMNUM_R {
FRMNUM_R::new(((self.bits >> 21) & 0x0f) as u8)
}
}
impl core::fmt::Debug for R {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("GRXSTSP_Device")
.field("epnum", &self.epnum())
.field("bcnt", &self.bcnt())
.field("dpid", &self.dpid())
.field("pktsts", &self.pktsts())
.field("frmnum", &self.frmnum())
.finish()
}
}
pub struct GRXSTSP_DEVICErs;
impl crate::RegisterSpec for GRXSTSP_DEVICErs {
type Ux = u32;
}
impl crate::Readable for GRXSTSP_DEVICErs {}
impl crate::Resettable for GRXSTSP_DEVICErs {
const RESET_VALUE: u32 = 0x0200_0400;
}