s32k118.rs/src/wdog/cs.rs

1159 lines
32 KiB
Rust

#[doc = "Reader of register CS"]
pub type R = crate::R<u32, super::CS>;
#[doc = "Writer for register CS"]
pub type W = crate::W<u32, super::CS>;
#[doc = "Register CS `reset()`'s with value 0x2980"]
impl crate::ResetValue for super::CS {
type Type = u32;
#[inline(always)]
fn reset_value() -> Self::Type {
0x2980
}
}
#[doc = "Stop Enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum STOP_A {
#[doc = "0: Watchdog disabled in chip stop mode."]
_0 = 0,
#[doc = "1: Watchdog enabled in chip stop mode."]
_1 = 1,
}
impl From<STOP_A> for bool {
#[inline(always)]
fn from(variant: STOP_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `STOP`"]
pub type STOP_R = crate::R<bool, STOP_A>;
impl STOP_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> STOP_A {
match self.bits {
false => STOP_A::_0,
true => STOP_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == STOP_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == STOP_A::_1
}
}
#[doc = "Write proxy for field `STOP`"]
pub struct STOP_W<'a> {
w: &'a mut W,
}
impl<'a> STOP_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: STOP_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Watchdog disabled in chip stop mode."]
#[inline(always)]
pub fn _0(self) -> &'a mut W {
self.variant(STOP_A::_0)
}
#[doc = "Watchdog enabled in chip stop mode."]
#[inline(always)]
pub fn _1(self) -> &'a mut W {
self.variant(STOP_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) | ((value as u32) & 0x01);
self.w
}
}
#[doc = "Wait Enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum WAIT_A {
#[doc = "0: Watchdog disabled in chip wait mode."]
_0 = 0,
#[doc = "1: Watchdog enabled in chip wait mode."]
_1 = 1,
}
impl From<WAIT_A> for bool {
#[inline(always)]
fn from(variant: WAIT_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `WAIT`"]
pub type WAIT_R = crate::R<bool, WAIT_A>;
impl WAIT_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> WAIT_A {
match self.bits {
false => WAIT_A::_0,
true => WAIT_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == WAIT_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == WAIT_A::_1
}
}
#[doc = "Write proxy for field `WAIT`"]
pub struct WAIT_W<'a> {
w: &'a mut W,
}
impl<'a> WAIT_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: WAIT_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Watchdog disabled in chip wait mode."]
#[inline(always)]
pub fn _0(self) -> &'a mut W {
self.variant(WAIT_A::_0)
}
#[doc = "Watchdog enabled in chip wait mode."]
#[inline(always)]
pub fn _1(self) -> &'a mut W {
self.variant(WAIT_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 << 1)) | (((value as u32) & 0x01) << 1);
self.w
}
}
#[doc = "Debug Enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum DBG_A {
#[doc = "0: Watchdog disabled in chip debug mode."]
_0 = 0,
#[doc = "1: Watchdog enabled in chip debug mode."]
_1 = 1,
}
impl From<DBG_A> for bool {
#[inline(always)]
fn from(variant: DBG_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `DBG`"]
pub type DBG_R = crate::R<bool, DBG_A>;
impl DBG_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> DBG_A {
match self.bits {
false => DBG_A::_0,
true => DBG_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == DBG_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == DBG_A::_1
}
}
#[doc = "Write proxy for field `DBG`"]
pub struct DBG_W<'a> {
w: &'a mut W,
}
impl<'a> DBG_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: DBG_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Watchdog disabled in chip debug mode."]
#[inline(always)]
pub fn _0(self) -> &'a mut W {
self.variant(DBG_A::_0)
}
#[doc = "Watchdog enabled in chip debug mode."]
#[inline(always)]
pub fn _1(self) -> &'a mut W {
self.variant(DBG_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 << 2)) | (((value as u32) & 0x01) << 2);
self.w
}
}
#[doc = "Watchdog Test\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
#[repr(u8)]
pub enum TST_A {
#[doc = "0: Watchdog test mode disabled."]
_00 = 0,
#[doc = "1: Watchdog user mode enabled. (Watchdog test mode disabled.) After testing the watchdog, software should use this setting to indicate that the watchdog is functioning normally in user mode."]
_01 = 1,
#[doc = "2: Watchdog test mode enabled, only the low byte is used. CNT\\[CNTLOW\\]
is compared with TOVAL\\[TOVALLOW\\]."]
_10 = 2,
#[doc = "3: Watchdog test mode enabled, only the high byte is used. CNT\\[CNTHIGH\\]
is compared with TOVAL\\[TOVALHIGH\\]."]
_11 = 3,
}
impl From<TST_A> for u8 {
#[inline(always)]
fn from(variant: TST_A) -> Self {
variant as _
}
}
#[doc = "Reader of field `TST`"]
pub type TST_R = crate::R<u8, TST_A>;
impl TST_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> TST_A {
match self.bits {
0 => TST_A::_00,
1 => TST_A::_01,
2 => TST_A::_10,
3 => TST_A::_11,
_ => unreachable!(),
}
}
#[doc = "Checks if the value of the field is `_00`"]
#[inline(always)]
pub fn is_00(&self) -> bool {
*self == TST_A::_00
}
#[doc = "Checks if the value of the field is `_01`"]
#[inline(always)]
pub fn is_01(&self) -> bool {
*self == TST_A::_01
}
#[doc = "Checks if the value of the field is `_10`"]
#[inline(always)]
pub fn is_10(&self) -> bool {
*self == TST_A::_10
}
#[doc = "Checks if the value of the field is `_11`"]
#[inline(always)]
pub fn is_11(&self) -> bool {
*self == TST_A::_11
}
}
#[doc = "Write proxy for field `TST`"]
pub struct TST_W<'a> {
w: &'a mut W,
}
impl<'a> TST_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: TST_A) -> &'a mut W {
{
self.bits(variant.into())
}
}
#[doc = "Watchdog test mode disabled."]
#[inline(always)]
pub fn _00(self) -> &'a mut W {
self.variant(TST_A::_00)
}
#[doc = "Watchdog user mode enabled. (Watchdog test mode disabled.) After testing the watchdog, software should use this setting to indicate that the watchdog is functioning normally in user mode."]
#[inline(always)]
pub fn _01(self) -> &'a mut W {
self.variant(TST_A::_01)
}
#[doc = "Watchdog test mode enabled, only the low byte is used. CNT\\[CNTLOW\\]
is compared with TOVAL\\[TOVALLOW\\]."]
#[inline(always)]
pub fn _10(self) -> &'a mut W {
self.variant(TST_A::_10)
}
#[doc = "Watchdog test mode enabled, only the high byte is used. CNT\\[CNTHIGH\\]
is compared with TOVAL\\[TOVALHIGH\\]."]
#[inline(always)]
pub fn _11(self) -> &'a mut W {
self.variant(TST_A::_11)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bits(self, value: u8) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x03 << 3)) | (((value as u32) & 0x03) << 3);
self.w
}
}
#[doc = "Allow updates\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum UPDATE_A {
#[doc = "0: Updates not allowed. After the initial configuration, the watchdog cannot be later modified without forcing a reset."]
_0 = 0,
#[doc = "1: Updates allowed. Software can modify the watchdog configuration registers within 8'd128 bus clocks after performing the unlock write sequence."]
_1 = 1,
}
impl From<UPDATE_A> for bool {
#[inline(always)]
fn from(variant: UPDATE_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `UPDATE`"]
pub type UPDATE_R = crate::R<bool, UPDATE_A>;
impl UPDATE_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> UPDATE_A {
match self.bits {
false => UPDATE_A::_0,
true => UPDATE_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == UPDATE_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == UPDATE_A::_1
}
}
#[doc = "Write proxy for field `UPDATE`"]
pub struct UPDATE_W<'a> {
w: &'a mut W,
}
impl<'a> UPDATE_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: UPDATE_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Updates not allowed. After the initial configuration, the watchdog cannot be later modified without forcing a reset."]
#[inline(always)]
pub fn _0(self) -> &'a mut W {
self.variant(UPDATE_A::_0)
}
#[doc = "Updates allowed. Software can modify the watchdog configuration registers within 8'd128 bus clocks after performing the unlock write sequence."]
#[inline(always)]
pub fn _1(self) -> &'a mut W {
self.variant(UPDATE_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 << 5)) | (((value as u32) & 0x01) << 5);
self.w
}
}
#[doc = "Watchdog Interrupt\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum INT_A {
#[doc = "0: Watchdog interrupts are disabled. Watchdog resets are not delayed."]
_0 = 0,
#[doc = "1: Watchdog interrupts are enabled. Watchdog resets are delayed by 8'd128 bus clocks from the interrupt vector fetch."]
_1 = 1,
}
impl From<INT_A> for bool {
#[inline(always)]
fn from(variant: INT_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `INT`"]
pub type INT_R = crate::R<bool, INT_A>;
impl INT_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> INT_A {
match self.bits {
false => INT_A::_0,
true => INT_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == INT_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == INT_A::_1
}
}
#[doc = "Write proxy for field `INT`"]
pub struct INT_W<'a> {
w: &'a mut W,
}
impl<'a> INT_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: INT_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Watchdog interrupts are disabled. Watchdog resets are not delayed."]
#[inline(always)]
pub fn _0(self) -> &'a mut W {
self.variant(INT_A::_0)
}
#[doc = "Watchdog interrupts are enabled. Watchdog resets are delayed by 8'd128 bus clocks from the interrupt vector fetch."]
#[inline(always)]
pub fn _1(self) -> &'a mut W {
self.variant(INT_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 = "Watchdog Enable\n\nValue on reset: 1"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum EN_A {
#[doc = "0: Watchdog disabled."]
_0 = 0,
#[doc = "1: Watchdog enabled."]
_1 = 1,
}
impl From<EN_A> for bool {
#[inline(always)]
fn from(variant: EN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `EN`"]
pub type EN_R = crate::R<bool, EN_A>;
impl EN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> EN_A {
match self.bits {
false => EN_A::_0,
true => EN_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == EN_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == EN_A::_1
}
}
#[doc = "Write proxy for field `EN`"]
pub struct EN_W<'a> {
w: &'a mut W,
}
impl<'a> EN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: EN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Watchdog disabled."]
#[inline(always)]
pub fn _0(self) -> &'a mut W {
self.variant(EN_A::_0)
}
#[doc = "Watchdog enabled."]
#[inline(always)]
pub fn _1(self) -> &'a mut W {
self.variant(EN_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 << 7)) | (((value as u32) & 0x01) << 7);
self.w
}
}
#[doc = "Watchdog Clock\n\nValue on reset: 1"]
#[derive(Clone, Copy, Debug, PartialEq)]
#[repr(u8)]
pub enum CLK_A {
#[doc = "0: Bus clock"]
_00 = 0,
#[doc = "1: LPO clock"]
_01 = 1,
#[doc = "2: INTCLK (internal clock)"]
_10 = 2,
#[doc = "3: ERCLK (external reference clock)"]
_11 = 3,
}
impl From<CLK_A> for u8 {
#[inline(always)]
fn from(variant: CLK_A) -> Self {
variant as _
}
}
#[doc = "Reader of field `CLK`"]
pub type CLK_R = crate::R<u8, CLK_A>;
impl CLK_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> CLK_A {
match self.bits {
0 => CLK_A::_00,
1 => CLK_A::_01,
2 => CLK_A::_10,
3 => CLK_A::_11,
_ => unreachable!(),
}
}
#[doc = "Checks if the value of the field is `_00`"]
#[inline(always)]
pub fn is_00(&self) -> bool {
*self == CLK_A::_00
}
#[doc = "Checks if the value of the field is `_01`"]
#[inline(always)]
pub fn is_01(&self) -> bool {
*self == CLK_A::_01
}
#[doc = "Checks if the value of the field is `_10`"]
#[inline(always)]
pub fn is_10(&self) -> bool {
*self == CLK_A::_10
}
#[doc = "Checks if the value of the field is `_11`"]
#[inline(always)]
pub fn is_11(&self) -> bool {
*self == CLK_A::_11
}
}
#[doc = "Write proxy for field `CLK`"]
pub struct CLK_W<'a> {
w: &'a mut W,
}
impl<'a> CLK_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: CLK_A) -> &'a mut W {
{
self.bits(variant.into())
}
}
#[doc = "Bus clock"]
#[inline(always)]
pub fn _00(self) -> &'a mut W {
self.variant(CLK_A::_00)
}
#[doc = "LPO clock"]
#[inline(always)]
pub fn _01(self) -> &'a mut W {
self.variant(CLK_A::_01)
}
#[doc = "INTCLK (internal clock)"]
#[inline(always)]
pub fn _10(self) -> &'a mut W {
self.variant(CLK_A::_10)
}
#[doc = "ERCLK (external reference clock)"]
#[inline(always)]
pub fn _11(self) -> &'a mut W {
self.variant(CLK_A::_11)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bits(self, value: u8) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x03 << 8)) | (((value as u32) & 0x03) << 8);
self.w
}
}
#[doc = "Reconfiguration Success\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum RCS_A {
#[doc = "0: Reconfiguring WDOG."]
_0 = 0,
#[doc = "1: Reconfiguration is successful."]
_1 = 1,
}
impl From<RCS_A> for bool {
#[inline(always)]
fn from(variant: RCS_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `RCS`"]
pub type RCS_R = crate::R<bool, RCS_A>;
impl RCS_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> RCS_A {
match self.bits {
false => RCS_A::_0,
true => RCS_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == RCS_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == RCS_A::_1
}
}
#[doc = "Unlock status\n\nValue on reset: 1"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum ULK_A {
#[doc = "0: WDOG is locked."]
_0 = 0,
#[doc = "1: WDOG is unlocked."]
_1 = 1,
}
impl From<ULK_A> for bool {
#[inline(always)]
fn from(variant: ULK_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `ULK`"]
pub type ULK_R = crate::R<bool, ULK_A>;
impl ULK_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> ULK_A {
match self.bits {
false => ULK_A::_0,
true => ULK_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == ULK_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == ULK_A::_1
}
}
#[doc = "Watchdog prescaler\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum PRES_A {
#[doc = "0: 256 prescaler disabled."]
_0 = 0,
#[doc = "1: 256 prescaler enabled."]
_1 = 1,
}
impl From<PRES_A> for bool {
#[inline(always)]
fn from(variant: PRES_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `PRES`"]
pub type PRES_R = crate::R<bool, PRES_A>;
impl PRES_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> PRES_A {
match self.bits {
false => PRES_A::_0,
true => PRES_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == PRES_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == PRES_A::_1
}
}
#[doc = "Write proxy for field `PRES`"]
pub struct PRES_W<'a> {
w: &'a mut W,
}
impl<'a> PRES_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: PRES_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "256 prescaler disabled."]
#[inline(always)]
pub fn _0(self) -> &'a mut W {
self.variant(PRES_A::_0)
}
#[doc = "256 prescaler enabled."]
#[inline(always)]
pub fn _1(self) -> &'a mut W {
self.variant(PRES_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 << 12)) | (((value as u32) & 0x01) << 12);
self.w
}
}
#[doc = "Enables or disables WDOG support for 32-bit (otherwise 16-bit or 8-bit) refresh/unlock command write words\n\nValue on reset: 1"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum CMD32EN_A {
#[doc = "0: Disables support for 32-bit refresh/unlock command write words. Only 16-bit or 8-bit is supported."]
_0 = 0,
#[doc = "1: Enables support for 32-bit refresh/unlock command write words. 16-bit or 8-bit is NOT supported."]
_1 = 1,
}
impl From<CMD32EN_A> for bool {
#[inline(always)]
fn from(variant: CMD32EN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `CMD32EN`"]
pub type CMD32EN_R = crate::R<bool, CMD32EN_A>;
impl CMD32EN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> CMD32EN_A {
match self.bits {
false => CMD32EN_A::_0,
true => CMD32EN_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == CMD32EN_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == CMD32EN_A::_1
}
}
#[doc = "Write proxy for field `CMD32EN`"]
pub struct CMD32EN_W<'a> {
w: &'a mut W,
}
impl<'a> CMD32EN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: CMD32EN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Disables support for 32-bit refresh/unlock command write words. Only 16-bit or 8-bit is supported."]
#[inline(always)]
pub fn _0(self) -> &'a mut W {
self.variant(CMD32EN_A::_0)
}
#[doc = "Enables support for 32-bit refresh/unlock command write words. 16-bit or 8-bit is NOT supported."]
#[inline(always)]
pub fn _1(self) -> &'a mut W {
self.variant(CMD32EN_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 << 13)) | (((value as u32) & 0x01) << 13);
self.w
}
}
#[doc = "Watchdog Interrupt Flag\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum FLG_A {
#[doc = "0: No interrupt occurred."]
_0 = 0,
#[doc = "1: An interrupt occurred."]
_1 = 1,
}
impl From<FLG_A> for bool {
#[inline(always)]
fn from(variant: FLG_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `FLG`"]
pub type FLG_R = crate::R<bool, FLG_A>;
impl FLG_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> FLG_A {
match self.bits {
false => FLG_A::_0,
true => FLG_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == FLG_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == FLG_A::_1
}
}
#[doc = "Write proxy for field `FLG`"]
pub struct FLG_W<'a> {
w: &'a mut W,
}
impl<'a> FLG_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: FLG_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "No interrupt occurred."]
#[inline(always)]
pub fn _0(self) -> &'a mut W {
self.variant(FLG_A::_0)
}
#[doc = "An interrupt occurred."]
#[inline(always)]
pub fn _1(self) -> &'a mut W {
self.variant(FLG_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 << 14)) | (((value as u32) & 0x01) << 14);
self.w
}
}
#[doc = "Watchdog Window\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum WIN_A {
#[doc = "0: Window mode disabled."]
_0 = 0,
#[doc = "1: Window mode enabled."]
_1 = 1,
}
impl From<WIN_A> for bool {
#[inline(always)]
fn from(variant: WIN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `WIN`"]
pub type WIN_R = crate::R<bool, WIN_A>;
impl WIN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> WIN_A {
match self.bits {
false => WIN_A::_0,
true => WIN_A::_1,
}
}
#[doc = "Checks if the value of the field is `_0`"]
#[inline(always)]
pub fn is_0(&self) -> bool {
*self == WIN_A::_0
}
#[doc = "Checks if the value of the field is `_1`"]
#[inline(always)]
pub fn is_1(&self) -> bool {
*self == WIN_A::_1
}
}
#[doc = "Write proxy for field `WIN`"]
pub struct WIN_W<'a> {
w: &'a mut W,
}
impl<'a> WIN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: WIN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Window mode disabled."]
#[inline(always)]
pub fn _0(self) -> &'a mut W {
self.variant(WIN_A::_0)
}
#[doc = "Window mode enabled."]
#[inline(always)]
pub fn _1(self) -> &'a mut W {
self.variant(WIN_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 << 15)) | (((value as u32) & 0x01) << 15);
self.w
}
}
impl R {
#[doc = "Bit 0 - Stop Enable"]
#[inline(always)]
pub fn stop(&self) -> STOP_R {
STOP_R::new((self.bits & 0x01) != 0)
}
#[doc = "Bit 1 - Wait Enable"]
#[inline(always)]
pub fn wait(&self) -> WAIT_R {
WAIT_R::new(((self.bits >> 1) & 0x01) != 0)
}
#[doc = "Bit 2 - Debug Enable"]
#[inline(always)]
pub fn dbg(&self) -> DBG_R {
DBG_R::new(((self.bits >> 2) & 0x01) != 0)
}
#[doc = "Bits 3:4 - Watchdog Test"]
#[inline(always)]
pub fn tst(&self) -> TST_R {
TST_R::new(((self.bits >> 3) & 0x03) as u8)
}
#[doc = "Bit 5 - Allow updates"]
#[inline(always)]
pub fn update(&self) -> UPDATE_R {
UPDATE_R::new(((self.bits >> 5) & 0x01) != 0)
}
#[doc = "Bit 6 - Watchdog Interrupt"]
#[inline(always)]
pub fn int(&self) -> INT_R {
INT_R::new(((self.bits >> 6) & 0x01) != 0)
}
#[doc = "Bit 7 - Watchdog Enable"]
#[inline(always)]
pub fn en(&self) -> EN_R {
EN_R::new(((self.bits >> 7) & 0x01) != 0)
}
#[doc = "Bits 8:9 - Watchdog Clock"]
#[inline(always)]
pub fn clk(&self) -> CLK_R {
CLK_R::new(((self.bits >> 8) & 0x03) as u8)
}
#[doc = "Bit 10 - Reconfiguration Success"]
#[inline(always)]
pub fn rcs(&self) -> RCS_R {
RCS_R::new(((self.bits >> 10) & 0x01) != 0)
}
#[doc = "Bit 11 - Unlock status"]
#[inline(always)]
pub fn ulk(&self) -> ULK_R {
ULK_R::new(((self.bits >> 11) & 0x01) != 0)
}
#[doc = "Bit 12 - Watchdog prescaler"]
#[inline(always)]
pub fn pres(&self) -> PRES_R {
PRES_R::new(((self.bits >> 12) & 0x01) != 0)
}
#[doc = "Bit 13 - Enables or disables WDOG support for 32-bit (otherwise 16-bit or 8-bit) refresh/unlock command write words"]
#[inline(always)]
pub fn cmd32en(&self) -> CMD32EN_R {
CMD32EN_R::new(((self.bits >> 13) & 0x01) != 0)
}
#[doc = "Bit 14 - Watchdog Interrupt Flag"]
#[inline(always)]
pub fn flg(&self) -> FLG_R {
FLG_R::new(((self.bits >> 14) & 0x01) != 0)
}
#[doc = "Bit 15 - Watchdog Window"]
#[inline(always)]
pub fn win(&self) -> WIN_R {
WIN_R::new(((self.bits >> 15) & 0x01) != 0)
}
}
impl W {
#[doc = "Bit 0 - Stop Enable"]
#[inline(always)]
pub fn stop(&mut self) -> STOP_W {
STOP_W { w: self }
}
#[doc = "Bit 1 - Wait Enable"]
#[inline(always)]
pub fn wait(&mut self) -> WAIT_W {
WAIT_W { w: self }
}
#[doc = "Bit 2 - Debug Enable"]
#[inline(always)]
pub fn dbg(&mut self) -> DBG_W {
DBG_W { w: self }
}
#[doc = "Bits 3:4 - Watchdog Test"]
#[inline(always)]
pub fn tst(&mut self) -> TST_W {
TST_W { w: self }
}
#[doc = "Bit 5 - Allow updates"]
#[inline(always)]
pub fn update(&mut self) -> UPDATE_W {
UPDATE_W { w: self }
}
#[doc = "Bit 6 - Watchdog Interrupt"]
#[inline(always)]
pub fn int(&mut self) -> INT_W {
INT_W { w: self }
}
#[doc = "Bit 7 - Watchdog Enable"]
#[inline(always)]
pub fn en(&mut self) -> EN_W {
EN_W { w: self }
}
#[doc = "Bits 8:9 - Watchdog Clock"]
#[inline(always)]
pub fn clk(&mut self) -> CLK_W {
CLK_W { w: self }
}
#[doc = "Bit 12 - Watchdog prescaler"]
#[inline(always)]
pub fn pres(&mut self) -> PRES_W {
PRES_W { w: self }
}
#[doc = "Bit 13 - Enables or disables WDOG support for 32-bit (otherwise 16-bit or 8-bit) refresh/unlock command write words"]
#[inline(always)]
pub fn cmd32en(&mut self) -> CMD32EN_W {
CMD32EN_W { w: self }
}
#[doc = "Bit 14 - Watchdog Interrupt Flag"]
#[inline(always)]
pub fn flg(&mut self) -> FLG_W {
FLG_W { w: self }
}
#[doc = "Bit 15 - Watchdog Window"]
#[inline(always)]
pub fn win(&mut self) -> WIN_W {
WIN_W { w: self }
}
}