pub type R = crate::R<JSQRrs>;
pub type W = crate::W<JSQRrs>;
pub type JSQ_R = crate::FieldReader;
pub type JSQ_W<'a, REG> = crate::FieldWriter<'a, REG, 5>;
pub type JL_R = crate::FieldReader;
pub type JL_W<'a, REG> = crate::FieldWriter<'a, REG, 2, u8, crate::Safe>;
impl R {
#[inline(always)]
pub fn jsq(&self, n: u8) -> JSQ_R {
#[allow(clippy::no_effect)]
[(); 4][n as usize];
JSQ_R::new(((self.bits >> (n * 5)) & 0x1f) as u8)
}
#[inline(always)]
pub fn jsq_iter(&self) -> impl Iterator<Item = JSQ_R> + '_ {
(0..4).map(move |n| JSQ_R::new(((self.bits >> (n * 5)) & 0x1f) as u8))
}
#[inline(always)]
pub fn jsq1(&self) -> JSQ_R {
JSQ_R::new((self.bits & 0x1f) as u8)
}
#[inline(always)]
pub fn jsq2(&self) -> JSQ_R {
JSQ_R::new(((self.bits >> 5) & 0x1f) as u8)
}
#[inline(always)]
pub fn jsq3(&self) -> JSQ_R {
JSQ_R::new(((self.bits >> 10) & 0x1f) as u8)
}
#[inline(always)]
pub fn jsq4(&self) -> JSQ_R {
JSQ_R::new(((self.bits >> 15) & 0x1f) as u8)
}
#[inline(always)]
pub fn jl(&self) -> JL_R {
JL_R::new(((self.bits >> 20) & 3) as u8)
}
}
impl core::fmt::Debug for R {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("JSQR")
.field("jl", &self.jl())
.field("jsq1", &self.jsq1())
.field("jsq2", &self.jsq2())
.field("jsq3", &self.jsq3())
.field("jsq4", &self.jsq4())
.finish()
}
}
impl W {
#[inline(always)]
pub fn jsq(&mut self, n: u8) -> JSQ_W<JSQRrs> {
#[allow(clippy::no_effect)]
[(); 4][n as usize];
JSQ_W::new(self, n * 5)
}
#[inline(always)]
pub fn jsq1(&mut self) -> JSQ_W<JSQRrs> {
JSQ_W::new(self, 0)
}
#[inline(always)]
pub fn jsq2(&mut self) -> JSQ_W<JSQRrs> {
JSQ_W::new(self, 5)
}
#[inline(always)]
pub fn jsq3(&mut self) -> JSQ_W<JSQRrs> {
JSQ_W::new(self, 10)
}
#[inline(always)]
pub fn jsq4(&mut self) -> JSQ_W<JSQRrs> {
JSQ_W::new(self, 15)
}
#[inline(always)]
pub fn jl(&mut self) -> JL_W<JSQRrs> {
JL_W::new(self, 20)
}
}
pub struct JSQRrs;
impl crate::RegisterSpec for JSQRrs {
type Ux = u32;
}
impl crate::Readable for JSQRrs {}
impl crate::Writable for JSQRrs {
type Safety = crate::Unsafe;
}
impl crate::Resettable for JSQRrs {}