pub type R = crate::R<CRrs>;
pub type W = crate::W<CRrs>;
pub type COREID_R = crate::FieldReader;
pub type COREID_W<'a, REG> = crate::FieldWriter<'a, REG, 4, u8, crate::Safe>;
pub type KEY_R = crate::FieldReader<u16>;
pub type KEY_W<'a, REG> = crate::FieldWriter<'a, REG, 16, u16, crate::Safe>;
impl R {
        #[inline(always)]
    pub fn coreid(&self) -> COREID_R {
        COREID_R::new(((self.bits >> 8) & 0x0f) as u8)
    }
        #[inline(always)]
    pub fn key(&self) -> KEY_R {
        KEY_R::new(((self.bits >> 16) & 0xffff) as u16)
    }
}
impl core::fmt::Debug for R {
    fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
        f.debug_struct("CR")
            .field("key", &self.key())
            .field("coreid", &self.coreid())
            .finish()
    }
}
impl W {
        #[inline(always)]
    pub fn coreid(&mut self) -> COREID_W<CRrs> {
        COREID_W::new(self, 8)
    }
        #[inline(always)]
    pub fn key(&mut self) -> KEY_W<CRrs> {
        KEY_W::new(self, 16)
    }
}
pub struct CRrs;
impl crate::RegisterSpec for CRrs {
    type Ux = u32;
}
impl crate::Readable for CRrs {}
impl crate::Writable for CRrs {
    type Safety = crate::Unsafe;
}
impl crate::Resettable for CRrs {}