1159 lines
32 KiB
Rust
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 }
|
|
}
|
|
}
|