pub type R = crate::R<SQR1rs>;
pub type W = crate::W<SQR1rs>;
pub type SQ_R = crate::FieldReader;
pub type SQ_W<'a, REG> = crate::FieldWriter<'a, REG, 5>;
pub type L_R = crate::FieldReader;
pub type L_W<'a, REG> = crate::FieldWriter<'a, REG, 4, u8, crate::Safe>;
impl R {
#[inline(always)]
pub fn sq(&self, n: u8) -> SQ_R {
#[allow(clippy::no_effect)]
[(); 4][n as usize];
SQ_R::new(((self.bits >> (n * 5)) & 0x1f) as u8)
}
#[inline(always)]
pub fn sq_iter(&self) -> impl Iterator<Item = SQ_R> + '_ {
(0..4).map(move |n| SQ_R::new(((self.bits >> (n * 5)) & 0x1f) as u8))
}
#[inline(always)]
pub fn sq13(&self) -> SQ_R {
SQ_R::new((self.bits & 0x1f) as u8)
}
#[inline(always)]
pub fn sq14(&self) -> SQ_R {
SQ_R::new(((self.bits >> 5) & 0x1f) as u8)
}
#[inline(always)]
pub fn sq15(&self) -> SQ_R {
SQ_R::new(((self.bits >> 10) & 0x1f) as u8)
}
#[inline(always)]
pub fn sq16(&self) -> SQ_R {
SQ_R::new(((self.bits >> 15) & 0x1f) as u8)
}
#[inline(always)]
pub fn l(&self) -> L_R {
L_R::new(((self.bits >> 20) & 0x0f) as u8)
}
}
impl core::fmt::Debug for R {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SQR1")
.field("l", &self.l())
.field("sq13", &self.sq13())
.field("sq14", &self.sq14())
.field("sq15", &self.sq15())
.field("sq16", &self.sq16())
.finish()
}
}
impl W {
#[inline(always)]
pub fn sq(&mut self, n: u8) -> SQ_W<SQR1rs> {
#[allow(clippy::no_effect)]
[(); 4][n as usize];
SQ_W::new(self, n * 5)
}
#[inline(always)]
pub fn sq13(&mut self) -> SQ_W<SQR1rs> {
SQ_W::new(self, 0)
}
#[inline(always)]
pub fn sq14(&mut self) -> SQ_W<SQR1rs> {
SQ_W::new(self, 5)
}
#[inline(always)]
pub fn sq15(&mut self) -> SQ_W<SQR1rs> {
SQ_W::new(self, 10)
}
#[inline(always)]
pub fn sq16(&mut self) -> SQ_W<SQR1rs> {
SQ_W::new(self, 15)
}
#[inline(always)]
pub fn l(&mut self) -> L_W<SQR1rs> {
L_W::new(self, 20)
}
}
pub struct SQR1rs;
impl crate::RegisterSpec for SQR1rs {
type Ux = u32;
}
impl crate::Readable for SQR1rs {}
impl crate::Writable for SQR1rs {
type Safety = crate::Unsafe;
}
impl crate::Resettable for SQR1rs {}