#[doc = "Reader of register CR"]
pub type R = crate::R<u32, super::CR>;
#[doc = "Writer for register CR"]
pub type W = crate::W<u32, super::CR>;
#[doc = "Register CR `reset()`'s with value 0"]
impl crate::ResetValue for super::CR {
type Type = u32;
#[inline(always)]
fn reset_value() -> Self::Type {
0
}
}
#[doc = "ADCAL\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum ADCAL_A {
#[doc = "0: Calibration complete"]
COMPLETE,
#[doc = "1: Start the calibration of the ADC"]
CALIBRATION,
}
impl From<ADCAL_A> for bool {
#[inline(always)]
fn from(variant: ADCAL_A) -> Self {
match variant {
ADCAL_A::COMPLETE => false,
ADCAL_A::CALIBRATION => true,
}
}
}
#[doc = "Reader of field `ADCAL`"]
pub type ADCAL_R = crate::R<bool, ADCAL_A>;
impl ADCAL_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> ADCAL_A {
match self.bits {
false => ADCAL_A::COMPLETE,
true => ADCAL_A::CALIBRATION,
}
}
#[doc = "Checks if the value of the field is `COMPLETE`"]
#[inline(always)]
pub fn is_complete(&self) -> bool {
*self == ADCAL_A::COMPLETE
}
#[doc = "Checks if the value of the field is `CALIBRATION`"]
#[inline(always)]
pub fn is_calibration(&self) -> bool {
*self == ADCAL_A::CALIBRATION
}
}
#[doc = "Write proxy for field `ADCAL`"]
pub struct ADCAL_W<'a> {
w: &'a mut W,
}
impl<'a> ADCAL_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ADCAL_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Calibration complete"]
#[inline(always)]
pub fn complete(self) -> &'a mut W {
self.variant(ADCAL_A::COMPLETE)
}
#[doc = "Start the calibration of the ADC"]
#[inline(always)]
pub fn calibration(self) -> &'a mut W {
self.variant(ADCAL_A::CALIBRATION)
}
#[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 << 31)) | (((value as u32) & 0x01) << 31);
self.w
}
}
#[doc = "ADCALDIF\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum ADCALDIF_A {
#[doc = "0: Calibration for single-ended mode"]
SINGLEENDED,
#[doc = "1: Calibration for differential mode"]
DIFFERENTIAL,
}
impl From<ADCALDIF_A> for bool {
#[inline(always)]
fn from(variant: ADCALDIF_A) -> Self {
match variant {
ADCALDIF_A::SINGLEENDED => false,
ADCALDIF_A::DIFFERENTIAL => true,
}
}
}
#[doc = "Reader of field `ADCALDIF`"]
pub type ADCALDIF_R = crate::R<bool, ADCALDIF_A>;
impl ADCALDIF_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> ADCALDIF_A {
match self.bits {
false => ADCALDIF_A::SINGLEENDED,
true => ADCALDIF_A::DIFFERENTIAL,
}
}
#[doc = "Checks if the value of the field is `SINGLEENDED`"]
#[inline(always)]
pub fn is_single_ended(&self) -> bool {
*self == ADCALDIF_A::SINGLEENDED
}
#[doc = "Checks if the value of the field is `DIFFERENTIAL`"]
#[inline(always)]
pub fn is_differential(&self) -> bool {
*self == ADCALDIF_A::DIFFERENTIAL
}
}
#[doc = "Write proxy for field `ADCALDIF`"]
pub struct ADCALDIF_W<'a> {
w: &'a mut W,
}
impl<'a> ADCALDIF_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ADCALDIF_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Calibration for single-ended mode"]
#[inline(always)]
pub fn single_ended(self) -> &'a mut W {
self.variant(ADCALDIF_A::SINGLEENDED)
}
#[doc = "Calibration for differential mode"]
#[inline(always)]
pub fn differential(self) -> &'a mut W {
self.variant(ADCALDIF_A::DIFFERENTIAL)
}
#[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 << 30)) | (((value as u32) & 0x01) << 30);
self.w
}
}
#[doc = "ADVREGEN\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum ADVREGEN_A {
#[doc = "0: Intermediate state required when moving the ADC voltage regulator between states"]
INTERMEDIATE,
#[doc = "1: ADC voltage regulator enabled"]
ENABLED,
#[doc = "2: ADC voltage regulator disabled"]
DISABLED,
}
impl From<ADVREGEN_A> for u8 {
#[inline(always)]
fn from(variant: ADVREGEN_A) -> Self {
match variant {
ADVREGEN_A::INTERMEDIATE => 0,
ADVREGEN_A::ENABLED => 1,
ADVREGEN_A::DISABLED => 2,
}
}
}
#[doc = "Reader of field `ADVREGEN`"]
pub type ADVREGEN_R = crate::R<u8, ADVREGEN_A>;
impl ADVREGEN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<u8, ADVREGEN_A> {
use crate::Variant::*;
match self.bits {
0 => Val(ADVREGEN_A::INTERMEDIATE),
1 => Val(ADVREGEN_A::ENABLED),
2 => Val(ADVREGEN_A::DISABLED),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `INTERMEDIATE`"]
#[inline(always)]
pub fn is_intermediate(&self) -> bool {
*self == ADVREGEN_A::INTERMEDIATE
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == ADVREGEN_A::ENABLED
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == ADVREGEN_A::DISABLED
}
}
#[doc = "Write proxy for field `ADVREGEN`"]
pub struct ADVREGEN_W<'a> {
w: &'a mut W,
}
impl<'a> ADVREGEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ADVREGEN_A) -> &'a mut W {
unsafe { self.bits(variant.into()) }
}
#[doc = "Intermediate state required when moving the ADC voltage regulator between states"]
#[inline(always)]
pub fn intermediate(self) -> &'a mut W {
self.variant(ADVREGEN_A::INTERMEDIATE)
}
#[doc = "ADC voltage regulator enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(ADVREGEN_A::ENABLED)
}
#[doc = "ADC voltage regulator disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(ADVREGEN_A::DISABLED)
}
#[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 << 28)) | (((value as u32) & 0x03) << 28);
self.w
}
}
#[doc = "JADSTP\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum JADSTP_A {
#[doc = "1: Stop conversion of channel"]
STOP,
}
impl From<JADSTP_A> for bool {
#[inline(always)]
fn from(variant: JADSTP_A) -> Self {
match variant {
JADSTP_A::STOP => true,
}
}
}
#[doc = "Reader of field `JADSTP`"]
pub type JADSTP_R = crate::R<bool, JADSTP_A>;
impl JADSTP_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<bool, JADSTP_A> {
use crate::Variant::*;
match self.bits {
true => Val(JADSTP_A::STOP),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `STOP`"]
#[inline(always)]
pub fn is_stop(&self) -> bool {
*self == JADSTP_A::STOP
}
}
#[doc = "Write proxy for field `JADSTP`"]
pub struct JADSTP_W<'a> {
w: &'a mut W,
}
impl<'a> JADSTP_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: JADSTP_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Stop conversion of channel"]
#[inline(always)]
pub fn stop(self) -> &'a mut W {
self.variant(JADSTP_A::STOP)
}
#[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 << 5)) | (((value as u32) & 0x01) << 5);
self.w
}
}
#[doc = "ADSTP"]
pub type ADSTP_A = JADSTP_A;
#[doc = "Reader of field `ADSTP`"]
pub type ADSTP_R = crate::R<bool, JADSTP_A>;
#[doc = "Write proxy for field `ADSTP`"]
pub struct ADSTP_W<'a> {
w: &'a mut W,
}
impl<'a> ADSTP_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ADSTP_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Stop conversion of channel"]
#[inline(always)]
pub fn stop(self) -> &'a mut W {
self.variant(JADSTP_A::STOP)
}
#[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 << 4)) | (((value as u32) & 0x01) << 4);
self.w
}
}
#[doc = "JADSTART\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum JADSTART_A {
#[doc = "1: Starts conversion of channel"]
START,
}
impl From<JADSTART_A> for bool {
#[inline(always)]
fn from(variant: JADSTART_A) -> Self {
match variant {
JADSTART_A::START => true,
}
}
}
#[doc = "Reader of field `JADSTART`"]
pub type JADSTART_R = crate::R<bool, JADSTART_A>;
impl JADSTART_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<bool, JADSTART_A> {
use crate::Variant::*;
match self.bits {
true => Val(JADSTART_A::START),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `START`"]
#[inline(always)]
pub fn is_start(&self) -> bool {
*self == JADSTART_A::START
}
}
#[doc = "Write proxy for field `JADSTART`"]
pub struct JADSTART_W<'a> {
w: &'a mut W,
}
impl<'a> JADSTART_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: JADSTART_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Starts conversion of channel"]
#[inline(always)]
pub fn start(self) -> &'a mut W {
self.variant(JADSTART_A::START)
}
#[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 << 3)) | (((value as u32) & 0x01) << 3);
self.w
}
}
#[doc = "ADSTART"]
pub type ADSTART_A = JADSTART_A;
#[doc = "Reader of field `ADSTART`"]
pub type ADSTART_R = crate::R<bool, JADSTART_A>;
#[doc = "Write proxy for field `ADSTART`"]
pub struct ADSTART_W<'a> {
w: &'a mut W,
}
impl<'a> ADSTART_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ADSTART_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Starts conversion of channel"]
#[inline(always)]
pub fn start(self) -> &'a mut W {
self.variant(JADSTART_A::START)
}
#[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 << 2)) | (((value as u32) & 0x01) << 2);
self.w
}
}
#[doc = "ADDIS\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum ADDIS_A {
#[doc = "0: Disable ADC conversion and go to power down mode"]
DISABLE,
}
impl From<ADDIS_A> for bool {
#[inline(always)]
fn from(variant: ADDIS_A) -> Self {
match variant {
ADDIS_A::DISABLE => false,
}
}
}
#[doc = "Reader of field `ADDIS`"]
pub type ADDIS_R = crate::R<bool, ADDIS_A>;
impl ADDIS_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<bool, ADDIS_A> {
use crate::Variant::*;
match self.bits {
false => Val(ADDIS_A::DISABLE),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `DISABLE`"]
#[inline(always)]
pub fn is_disable(&self) -> bool {
*self == ADDIS_A::DISABLE
}
}
#[doc = "Write proxy for field `ADDIS`"]
pub struct ADDIS_W<'a> {
w: &'a mut W,
}
impl<'a> ADDIS_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ADDIS_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Disable ADC conversion and go to power down mode"]
#[inline(always)]
pub fn disable(self) -> &'a mut W {
self.variant(ADDIS_A::DISABLE)
}
#[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 << 1)) | (((value as u32) & 0x01) << 1);
self.w
}
}
#[doc = "ADEN\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum ADEN_A {
#[doc = "1: Enable ADC"]
ENABLE,
}
impl From<ADEN_A> for bool {
#[inline(always)]
fn from(variant: ADEN_A) -> Self {
match variant {
ADEN_A::ENABLE => true,
}
}
}
#[doc = "Reader of field `ADEN`"]
pub type ADEN_R = crate::R<bool, ADEN_A>;
impl ADEN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<bool, ADEN_A> {
use crate::Variant::*;
match self.bits {
true => Val(ADEN_A::ENABLE),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `ENABLE`"]
#[inline(always)]
pub fn is_enable(&self) -> bool {
*self == ADEN_A::ENABLE
}
}
#[doc = "Write proxy for field `ADEN`"]
pub struct ADEN_W<'a> {
w: &'a mut W,
}
impl<'a> ADEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ADEN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Enable ADC"]
#[inline(always)]
pub fn enable(self) -> &'a mut W {
self.variant(ADEN_A::ENABLE)
}
#[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
}
}
impl R {
#[doc = "Bit 31 - ADCAL"]
#[inline(always)]
pub fn adcal(&self) -> ADCAL_R {
ADCAL_R::new(((self.bits >> 31) & 0x01) != 0)
}
#[doc = "Bit 30 - ADCALDIF"]
#[inline(always)]
pub fn adcaldif(&self) -> ADCALDIF_R {
ADCALDIF_R::new(((self.bits >> 30) & 0x01) != 0)
}
#[doc = "Bits 28:29 - ADVREGEN"]
#[inline(always)]
pub fn advregen(&self) -> ADVREGEN_R {
ADVREGEN_R::new(((self.bits >> 28) & 0x03) as u8)
}
#[doc = "Bit 5 - JADSTP"]
#[inline(always)]
pub fn jadstp(&self) -> JADSTP_R {
JADSTP_R::new(((self.bits >> 5) & 0x01) != 0)
}
#[doc = "Bit 4 - ADSTP"]
#[inline(always)]
pub fn adstp(&self) -> ADSTP_R {
ADSTP_R::new(((self.bits >> 4) & 0x01) != 0)
}
#[doc = "Bit 3 - JADSTART"]
#[inline(always)]
pub fn jadstart(&self) -> JADSTART_R {
JADSTART_R::new(((self.bits >> 3) & 0x01) != 0)
}
#[doc = "Bit 2 - ADSTART"]
#[inline(always)]
pub fn adstart(&self) -> ADSTART_R {
ADSTART_R::new(((self.bits >> 2) & 0x01) != 0)
}
#[doc = "Bit 1 - ADDIS"]
#[inline(always)]
pub fn addis(&self) -> ADDIS_R {
ADDIS_R::new(((self.bits >> 1) & 0x01) != 0)
}
#[doc = "Bit 0 - ADEN"]
#[inline(always)]
pub fn aden(&self) -> ADEN_R {
ADEN_R::new((self.bits & 0x01) != 0)
}
}
impl W {
#[doc = "Bit 31 - ADCAL"]
#[inline(always)]
pub fn adcal(&mut self) -> ADCAL_W {
ADCAL_W { w: self }
}
#[doc = "Bit 30 - ADCALDIF"]
#[inline(always)]
pub fn adcaldif(&mut self) -> ADCALDIF_W {
ADCALDIF_W { w: self }
}
#[doc = "Bits 28:29 - ADVREGEN"]
#[inline(always)]
pub fn advregen(&mut self) -> ADVREGEN_W {
ADVREGEN_W { w: self }
}
#[doc = "Bit 5 - JADSTP"]
#[inline(always)]
pub fn jadstp(&mut self) -> JADSTP_W {
JADSTP_W { w: self }
}
#[doc = "Bit 4 - ADSTP"]
#[inline(always)]
pub fn adstp(&mut self) -> ADSTP_W {
ADSTP_W { w: self }
}
#[doc = "Bit 3 - JADSTART"]
#[inline(always)]
pub fn jadstart(&mut self) -> JADSTART_W {
JADSTART_W { w: self }
}
#[doc = "Bit 2 - ADSTART"]
#[inline(always)]
pub fn adstart(&mut self) -> ADSTART_W {
ADSTART_W { w: self }
}
#[doc = "Bit 1 - ADDIS"]
#[inline(always)]
pub fn addis(&mut self) -> ADDIS_W {
ADDIS_W { w: self }
}
#[doc = "Bit 0 - ADEN"]
#[inline(always)]
pub fn aden(&mut self) -> ADEN_W {
ADEN_W { w: self }
}
}