s32k118.rs/src/adc0/sc1.rs

544 lines
17 KiB
Rust

#[doc = "Reader of register SC1%s"]
pub type R = crate::R<u32, super::SC1>;
#[doc = "Writer for register SC1%s"]
pub type W = crate::W<u32, super::SC1>;
#[doc = "Register SC1%s `reset()`'s with value 0x1f"]
impl crate::ResetValue for super::SC1 {
type Type = u32;
#[inline(always)]
fn reset_value() -> Self::Type {
0x1f
}
}
#[doc = "Input channel select\n\nValue on reset: 31"]
#[derive(Clone, Copy, Debug, PartialEq)]
#[repr(u8)]
pub enum ADCH_A {
#[doc = "0: Exernal channel 0 is selected as input."]
_00000 = 0,
#[doc = "1: Exernal channel 1 is selected as input."]
_00001 = 1,
#[doc = "2: Exernal channel 2 is selected as input."]
_00010 = 2,
#[doc = "3: Exernal channel 3 is selected as input."]
_00011 = 3,
#[doc = "4: Exernal channel 4 is selected as input."]
_00100 = 4,
#[doc = "5: Exernal channel 5 is selected as input."]
_00101 = 5,
#[doc = "6: Exernal channel 6 is selected as input."]
_00110 = 6,
#[doc = "7: Exernal channel 7 is selected as input."]
_00111 = 7,
#[doc = "8: Exernal channel 8 is selected as input."]
_01000 = 8,
#[doc = "9: Exernal channel 9 is selected as input."]
_01001 = 9,
#[doc = "10: Exernal channel 10 is selected as input."]
_01010 = 10,
#[doc = "11: Exernal channel 11 is selected as input."]
_01011 = 11,
#[doc = "12: Exernal channel 12 is selected as input."]
_01100 = 12,
#[doc = "13: Exernal channel 13 is selected as input."]
_01101 = 13,
#[doc = "14: Exernal channel 14 is selected as input."]
_01110 = 14,
#[doc = "15: Exernal channel 15 is selected as input."]
_01111 = 15,
#[doc = "18: Exernal channel 18 is selected as input."]
_10010 = 18,
#[doc = "19: Exernal channel 19 is selected as input."]
_10011 = 19,
#[doc = "21: Internal channel 0 is selected as input."]
_10101 = 21,
#[doc = "22: Internal channel 1 is selected as input."]
_10110 = 22,
#[doc = "23: Internal channel 2 is selected as input."]
_10111 = 23,
#[doc = "26: Temp Sensor"]
_11010 = 26,
#[doc = "27: Band Gap"]
_11011 = 27,
#[doc = "28: Internal channel 3 is selected as input."]
_11100 = 28,
#[doc = "29: VREFSH is selected as input. Voltage reference selected is determined by SC2\\[REFSEL\\]."]
_11101 = 29,
#[doc = "30: VREFSL is selected as input. Voltage reference selected is determined by SC2\\[REFSEL\\]."]
_11110 = 30,
#[doc = "31: Module is disabled"]
_11111 = 31,
}
impl From<ADCH_A> for u8 {
#[inline(always)]
fn from(variant: ADCH_A) -> Self {
variant as _
}
}
#[doc = "Reader of field `ADCH`"]
pub type ADCH_R = crate::R<u8, ADCH_A>;
impl ADCH_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<u8, ADCH_A> {
use crate::Variant::*;
match self.bits {
0 => Val(ADCH_A::_00000),
1 => Val(ADCH_A::_00001),
2 => Val(ADCH_A::_00010),
3 => Val(ADCH_A::_00011),
4 => Val(ADCH_A::_00100),
5 => Val(ADCH_A::_00101),
6 => Val(ADCH_A::_00110),
7 => Val(ADCH_A::_00111),
8 => Val(ADCH_A::_01000),
9 => Val(ADCH_A::_01001),
10 => Val(ADCH_A::_01010),
11 => Val(ADCH_A::_01011),
12 => Val(ADCH_A::_01100),
13 => Val(ADCH_A::_01101),
14 => Val(ADCH_A::_01110),
15 => Val(ADCH_A::_01111),
18 => Val(ADCH_A::_10010),
19 => Val(ADCH_A::_10011),
21 => Val(ADCH_A::_10101),
22 => Val(ADCH_A::_10110),
23 => Val(ADCH_A::_10111),
26 => Val(ADCH_A::_11010),
27 => Val(ADCH_A::_11011),
28 => Val(ADCH_A::_11100),
29 => Val(ADCH_A::_11101),
30 => Val(ADCH_A::_11110),
31 => Val(ADCH_A::_11111),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `_00000`"]
#[inline(always)]
pub fn is_00000(&self) -> bool {
*self == ADCH_A::_00000
}
#[doc = "Checks if the value of the field is `_00001`"]
#[inline(always)]
pub fn is_00001(&self) -> bool {
*self == ADCH_A::_00001
}
#[doc = "Checks if the value of the field is `_00010`"]
#[inline(always)]
pub fn is_00010(&self) -> bool {
*self == ADCH_A::_00010
}
#[doc = "Checks if the value of the field is `_00011`"]
#[inline(always)]
pub fn is_00011(&self) -> bool {
*self == ADCH_A::_00011
}
#[doc = "Checks if the value of the field is `_00100`"]
#[inline(always)]
pub fn is_00100(&self) -> bool {
*self == ADCH_A::_00100
}
#[doc = "Checks if the value of the field is `_00101`"]
#[inline(always)]
pub fn is_00101(&self) -> bool {
*self == ADCH_A::_00101
}
#[doc = "Checks if the value of the field is `_00110`"]
#[inline(always)]
pub fn is_00110(&self) -> bool {
*self == ADCH_A::_00110
}
#[doc = "Checks if the value of the field is `_00111`"]
#[inline(always)]
pub fn is_00111(&self) -> bool {
*self == ADCH_A::_00111
}
#[doc = "Checks if the value of the field is `_01000`"]
#[inline(always)]
pub fn is_01000(&self) -> bool {
*self == ADCH_A::_01000
}
#[doc = "Checks if the value of the field is `_01001`"]
#[inline(always)]
pub fn is_01001(&self) -> bool {
*self == ADCH_A::_01001
}
#[doc = "Checks if the value of the field is `_01010`"]
#[inline(always)]
pub fn is_01010(&self) -> bool {
*self == ADCH_A::_01010
}
#[doc = "Checks if the value of the field is `_01011`"]
#[inline(always)]
pub fn is_01011(&self) -> bool {
*self == ADCH_A::_01011
}
#[doc = "Checks if the value of the field is `_01100`"]
#[inline(always)]
pub fn is_01100(&self) -> bool {
*self == ADCH_A::_01100
}
#[doc = "Checks if the value of the field is `_01101`"]
#[inline(always)]
pub fn is_01101(&self) -> bool {
*self == ADCH_A::_01101
}
#[doc = "Checks if the value of the field is `_01110`"]
#[inline(always)]
pub fn is_01110(&self) -> bool {
*self == ADCH_A::_01110
}
#[doc = "Checks if the value of the field is `_01111`"]
#[inline(always)]
pub fn is_01111(&self) -> bool {
*self == ADCH_A::_01111
}
#[doc = "Checks if the value of the field is `_10010`"]
#[inline(always)]
pub fn is_10010(&self) -> bool {
*self == ADCH_A::_10010
}
#[doc = "Checks if the value of the field is `_10011`"]
#[inline(always)]
pub fn is_10011(&self) -> bool {
*self == ADCH_A::_10011
}
#[doc = "Checks if the value of the field is `_10101`"]
#[inline(always)]
pub fn is_10101(&self) -> bool {
*self == ADCH_A::_10101
}
#[doc = "Checks if the value of the field is `_10110`"]
#[inline(always)]
pub fn is_10110(&self) -> bool {
*self == ADCH_A::_10110
}
#[doc = "Checks if the value of the field is `_10111`"]
#[inline(always)]
pub fn is_10111(&self) -> bool {
*self == ADCH_A::_10111
}
#[doc = "Checks if the value of the field is `_11010`"]
#[inline(always)]
pub fn is_11010(&self) -> bool {
*self == ADCH_A::_11010
}
#[doc = "Checks if the value of the field is `_11011`"]
#[inline(always)]
pub fn is_11011(&self) -> bool {
*self == ADCH_A::_11011
}
#[doc = "Checks if the value of the field is `_11100`"]
#[inline(always)]
pub fn is_11100(&self) -> bool {
*self == ADCH_A::_11100
}
#[doc = "Checks if the value of the field is `_11101`"]
#[inline(always)]
pub fn is_11101(&self) -> bool {
*self == ADCH_A::_11101
}
#[doc = "Checks if the value of the field is `_11110`"]
#[inline(always)]
pub fn is_11110(&self) -> bool {
*self == ADCH_A::_11110
}
#[doc = "Checks if the value of the field is `_11111`"]
#[inline(always)]
pub fn is_11111(&self) -> bool {
*self == ADCH_A::_11111
}
}
#[doc = "Write proxy for field `ADCH`"]
pub struct ADCH_W<'a> {
w: &'a mut W,
}
impl<'a> ADCH_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ADCH_A) -> &'a mut W {
unsafe { self.bits(variant.into()) }
}
#[doc = "Exernal channel 0 is selected as input."]
#[inline(always)]
pub fn _00000(self) -> &'a mut W {
self.variant(ADCH_A::_00000)
}
#[doc = "Exernal channel 1 is selected as input."]
#[inline(always)]
pub fn _00001(self) -> &'a mut W {
self.variant(ADCH_A::_00001)
}
#[doc = "Exernal channel 2 is selected as input."]
#[inline(always)]
pub fn _00010(self) -> &'a mut W {
self.variant(ADCH_A::_00010)
}
#[doc = "Exernal channel 3 is selected as input."]
#[inline(always)]
pub fn _00011(self) -> &'a mut W {
self.variant(ADCH_A::_00011)
}
#[doc = "Exernal channel 4 is selected as input."]
#[inline(always)]
pub fn _00100(self) -> &'a mut W {
self.variant(ADCH_A::_00100)
}
#[doc = "Exernal channel 5 is selected as input."]
#[inline(always)]
pub fn _00101(self) -> &'a mut W {
self.variant(ADCH_A::_00101)
}
#[doc = "Exernal channel 6 is selected as input."]
#[inline(always)]
pub fn _00110(self) -> &'a mut W {
self.variant(ADCH_A::_00110)
}
#[doc = "Exernal channel 7 is selected as input."]
#[inline(always)]
pub fn _00111(self) -> &'a mut W {
self.variant(ADCH_A::_00111)
}
#[doc = "Exernal channel 8 is selected as input."]
#[inline(always)]
pub fn _01000(self) -> &'a mut W {
self.variant(ADCH_A::_01000)
}
#[doc = "Exernal channel 9 is selected as input."]
#[inline(always)]
pub fn _01001(self) -> &'a mut W {
self.variant(ADCH_A::_01001)
}
#[doc = "Exernal channel 10 is selected as input."]
#[inline(always)]
pub fn _01010(self) -> &'a mut W {
self.variant(ADCH_A::_01010)
}
#[doc = "Exernal channel 11 is selected as input."]
#[inline(always)]
pub fn _01011(self) -> &'a mut W {
self.variant(ADCH_A::_01011)
}
#[doc = "Exernal channel 12 is selected as input."]
#[inline(always)]
pub fn _01100(self) -> &'a mut W {
self.variant(ADCH_A::_01100)
}
#[doc = "Exernal channel 13 is selected as input."]
#[inline(always)]
pub fn _01101(self) -> &'a mut W {
self.variant(ADCH_A::_01101)
}
#[doc = "Exernal channel 14 is selected as input."]
#[inline(always)]
pub fn _01110(self) -> &'a mut W {
self.variant(ADCH_A::_01110)
}
#[doc = "Exernal channel 15 is selected as input."]
#[inline(always)]
pub fn _01111(self) -> &'a mut W {
self.variant(ADCH_A::_01111)
}
#[doc = "Exernal channel 18 is selected as input."]
#[inline(always)]
pub fn _10010(self) -> &'a mut W {
self.variant(ADCH_A::_10010)
}
#[doc = "Exernal channel 19 is selected as input."]
#[inline(always)]
pub fn _10011(self) -> &'a mut W {
self.variant(ADCH_A::_10011)
}
#[doc = "Internal channel 0 is selected as input."]
#[inline(always)]
pub fn _10101(self) -> &'a mut W {
self.variant(ADCH_A::_10101)
}
#[doc = "Internal channel 1 is selected as input."]
#[inline(always)]
pub fn _10110(self) -> &'a mut W {
self.variant(ADCH_A::_10110)
}
#[doc = "Internal channel 2 is selected as input."]
#[inline(always)]
pub fn _10111(self) -> &'a mut W {
self.variant(ADCH_A::_10111)
}
#[doc = "Temp Sensor"]
#[inline(always)]
pub fn _11010(self) -> &'a mut W {
self.variant(ADCH_A::_11010)
}
#[doc = "Band Gap"]
#[inline(always)]
pub fn _11011(self) -> &'a mut W {
self.variant(ADCH_A::_11011)
}
#[doc = "Internal channel 3 is selected as input."]
#[inline(always)]
pub fn _11100(self) -> &'a mut W {
self.variant(ADCH_A::_11100)
}
#[doc = "VREFSH is selected as input. Voltage reference selected is determined by SC2\\[REFSEL\\]."]
#[inline(always)]
pub fn _11101(self) -> &'a mut W {
self.variant(ADCH_A::_11101)
}
#[doc = "VREFSL is selected as input. Voltage reference selected is determined by SC2\\[REFSEL\\]."]
#[inline(always)]
pub fn _11110(self) -> &'a mut W {
self.variant(ADCH_A::_11110)
}
#[doc = "Module is disabled"]
#[inline(always)]
pub fn _11111(self) -> &'a mut W {
self.variant(ADCH_A::_11111)
}
#[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 & !0x1f) | ((value as u32) & 0x1f);
self.w
}
}
#[doc = "Interrupt Enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum AIEN_A {
#[doc = "0: Conversion complete interrupt is disabled."]
_0 = 0,
#[doc = "1: Conversion complete interrupt is enabled."]
_1 = 1,
}
impl From<AIEN_A> for bool {
#[inline(always)]
fn from(variant: AIEN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `AIEN`"]
pub type AIEN_R = crate::R<bool, AIEN_A>;
impl AIEN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> AIEN_A {
match self.bits {
false => AIEN_A::_0,
true => AIEN_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == AIEN_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == AIEN_A::_1
}
}
#[doc = "Write proxy for field `AIEN`"]
pub struct AIEN_W<'a> {
w: &'a mut W,
}
impl<'a> AIEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: AIEN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Conversion complete interrupt is disabled."]
#[inline(always)]
pub fn _0(self) -> &'a mut W {
self.variant(AIEN_A::_0)
}
#[doc = "Conversion complete interrupt is enabled."]
#[inline(always)]
pub fn _1(self) -> &'a mut W {
self.variant(AIEN_A::_1)
}
#[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 << 6)) | (((value as u32) & 0x01) << 6);
self.w
}
}
#[doc = "Conversion Complete Flag\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum COCO_A {
#[doc = "0: Conversion is not completed."]
_0 = 0,
#[doc = "1: Conversion is completed."]
_1 = 1,
}
impl From<COCO_A> for bool {
#[inline(always)]
fn from(variant: COCO_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `COCO`"]
pub type COCO_R = crate::R<bool, COCO_A>;
impl COCO_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> COCO_A {
match self.bits {
false => COCO_A::_0,
true => COCO_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == COCO_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == COCO_A::_1
}
}
impl R {
#[doc = "Bits 0:4 - Input channel select"]
#[inline(always)]
pub fn adch(&self) -> ADCH_R {
ADCH_R::new((self.bits & 0x1f) as u8)
}
#[doc = "Bit 6 - Interrupt Enable"]
#[inline(always)]
pub fn aien(&self) -> AIEN_R {
AIEN_R::new(((self.bits >> 6) & 0x01) != 0)
}
#[doc = "Bit 7 - Conversion Complete Flag"]
#[inline(always)]
pub fn coco(&self) -> COCO_R {
COCO_R::new(((self.bits >> 7) & 0x01) != 0)
}
}
impl W {
#[doc = "Bits 0:4 - Input channel select"]
#[inline(always)]
pub fn adch(&mut self) -> ADCH_W {
ADCH_W { w: self }
}
#[doc = "Bit 6 - Interrupt Enable"]
#[inline(always)]
pub fn aien(&mut self) -> AIEN_W {
AIEN_W { w: self }
}
}