#[doc = "Reader of register MR"]
pub type R = crate::R<u32, super::MR>;
#[doc = "Writer for register MR"]
pub type W = crate::W<u32, super::MR>;
#[doc = "Register MR `reset()`'s with value 0"]
impl crate::ResetValue for super::MR {
type Type = u32;
#[inline(always)]
fn reset_value() -> Self::Type {
0
}
}
#[doc = "Reader of field `PCEN`"]
pub type PCEN_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `PCEN`"]
pub struct PCEN_W<'a> {
w: &'a mut W,
}
impl<'a> PCEN_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !0x01) | ((value as u32) & 0x01);
self.w
}
}
#[doc = "Reader of field `DSIZE`"]
pub type DSIZE_R = crate::R<u8, u8>;
#[doc = "Write proxy for field `DSIZE`"]
pub struct DSIZE_W<'a> {
w: &'a mut W,
}
impl<'a> DSIZE_W<'a> {
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub unsafe fn bits(self, value: u8) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x03 << 4)) | (((value as u32) & 0x03) << 4);
self.w
}
}
#[doc = "Reader of field `SCALE`"]
pub type SCALE_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `SCALE`"]
pub struct SCALE_W<'a> {
w: &'a mut W,
}
impl<'a> SCALE_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 8)) | (((value as u32) & 0x01) << 8);
self.w
}
}
#[doc = "Reader of field `ALWYS`"]
pub type ALWYS_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `ALWYS`"]
pub struct ALWYS_W<'a> {
w: &'a mut W,
}
impl<'a> ALWYS_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 9)) | (((value as u32) & 0x01) << 9);
self.w
}
}
#[doc = "Reader of field `HALFS`"]
pub type HALFS_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `HALFS`"]
pub struct HALFS_W<'a> {
w: &'a mut W,
}
impl<'a> HALFS_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 10)) | (((value as u32) & 0x01) << 10);
self.w
}
}
#[doc = "Reader of field `FRSTS`"]
pub type FRSTS_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `FRSTS`"]
pub struct FRSTS_W<'a> {
w: &'a mut W,
}
impl<'a> FRSTS_W<'a> {
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 11)) | (((value as u32) & 0x01) << 11);
self.w
}
}
#[doc = "Reader of field `ISIZE`"]
pub type ISIZE_R = crate::R<u8, u8>;
#[doc = "Write proxy for field `ISIZE`"]
pub struct ISIZE_W<'a> {
w: &'a mut W,
}
impl<'a> ISIZE_W<'a> {
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub unsafe fn bits(self, value: u8) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x07 << 16)) | (((value as u32) & 0x07) << 16);
self.w
}
}
#[doc = "Reader of field `CID`"]
pub type CID_R = crate::R<u8, u8>;
#[doc = "Write proxy for field `CID`"]
pub struct CID_W<'a> {
w: &'a mut W,
}
impl<'a> CID_W<'a> {
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub unsafe fn bits(self, value: u8) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x03 << 30)) | (((value as u32) & 0x03) << 30);
self.w
}
}
impl R {
#[doc = "Bit 0 - Parallel Capture Enable"]
#[inline(always)]
pub fn pcen(&self) -> PCEN_R {
PCEN_R::new((self.bits & 0x01) != 0)
}
#[doc = "Bits 4:5 - Data size"]
#[inline(always)]
pub fn dsize(&self) -> DSIZE_R {
DSIZE_R::new(((self.bits >> 4) & 0x03) as u8)
}
#[doc = "Bit 8 - Scale data"]
#[inline(always)]
pub fn scale(&self) -> SCALE_R {
SCALE_R::new(((self.bits >> 8) & 0x01) != 0)
}
#[doc = "Bit 9 - Always Sampling"]
#[inline(always)]
pub fn alwys(&self) -> ALWYS_R {
ALWYS_R::new(((self.bits >> 9) & 0x01) != 0)
}
#[doc = "Bit 10 - Half Sampling"]
#[inline(always)]
pub fn halfs(&self) -> HALFS_R {
HALFS_R::new(((self.bits >> 10) & 0x01) != 0)
}
#[doc = "Bit 11 - First sample"]
#[inline(always)]
pub fn frsts(&self) -> FRSTS_R {
FRSTS_R::new(((self.bits >> 11) & 0x01) != 0)
}
#[doc = "Bits 16:18 - Input Data Size"]
#[inline(always)]
pub fn isize(&self) -> ISIZE_R {
ISIZE_R::new(((self.bits >> 16) & 0x07) as u8)
}
#[doc = "Bits 30:31 - Clear If Disabled"]
#[inline(always)]
pub fn cid(&self) -> CID_R {
CID_R::new(((self.bits >> 30) & 0x03) as u8)
}
}
impl W {
#[doc = "Bit 0 - Parallel Capture Enable"]
#[inline(always)]
pub fn pcen(&mut self) -> PCEN_W {
PCEN_W { w: self }
}
#[doc = "Bits 4:5 - Data size"]
#[inline(always)]
pub fn dsize(&mut self) -> DSIZE_W {
DSIZE_W { w: self }
}
#[doc = "Bit 8 - Scale data"]
#[inline(always)]
pub fn scale(&mut self) -> SCALE_W {
SCALE_W { w: self }
}
#[doc = "Bit 9 - Always Sampling"]
#[inline(always)]
pub fn alwys(&mut self) -> ALWYS_W {
ALWYS_W { w: self }
}
#[doc = "Bit 10 - Half Sampling"]
#[inline(always)]
pub fn halfs(&mut self) -> HALFS_W {
HALFS_W { w: self }
}
#[doc = "Bit 11 - First sample"]
#[inline(always)]
pub fn frsts(&mut self) -> FRSTS_W {
FRSTS_W { w: self }
}
#[doc = "Bits 16:18 - Input Data Size"]
#[inline(always)]
pub fn isize(&mut self) -> ISIZE_W {
ISIZE_W { w: self }
}
#[doc = "Bits 30:31 - Clear If Disabled"]
#[inline(always)]
pub fn cid(&mut self) -> CID_W {
CID_W { w: self }
}
}