#[doc = "Reader of register OPTR"]
pub type R = crate::R<u32, super::OPTR>;
#[doc = "Writer for register OPTR"]
pub type W = crate::W<u32, super::OPTR>;
#[doc = "Register OPTR `reset()`'s with value 0"]
impl crate::ResetValue for super::OPTR {
type Type = u32;
#[inline(always)]
fn reset_value() -> Self::Type {
0
}
}
#[doc = "Reader of field `RDP`"]
pub type RDP_R = crate::R<u8, u8>;
#[doc = "Write proxy for field `RDP`"]
pub struct RDP_W<'a> {
w: &'a mut W,
}
impl<'a> RDP_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 & !0xff) | ((value as u32) & 0xff);
self.w
}
}
#[doc = "Reader of field `BOR_LEV`"]
pub type BOR_LEV_R = crate::R<u8, u8>;
#[doc = "Write proxy for field `BOR_LEV`"]
pub struct BOR_LEV_W<'a> {
w: &'a mut W,
}
impl<'a> BOR_LEV_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 << 8)) | (((value as u32) & 0x07) << 8);
self.w
}
}
#[doc = "Reader of field `nRST_STOP`"]
pub type NRST_STOP_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `nRST_STOP`"]
pub struct NRST_STOP_W<'a> {
w: &'a mut W,
}
impl<'a> NRST_STOP_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 << 12)) | (((value as u32) & 0x01) << 12);
self.w
}
}
#[doc = "Reader of field `nRST_STDBY`"]
pub type NRST_STDBY_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `nRST_STDBY`"]
pub struct NRST_STDBY_W<'a> {
w: &'a mut W,
}
impl<'a> NRST_STDBY_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 << 13)) | (((value as u32) & 0x01) << 13);
self.w
}
}
#[doc = "Reader of field `nRST_SHDW`"]
pub type NRST_SHDW_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `nRST_SHDW`"]
pub struct NRST_SHDW_W<'a> {
w: &'a mut W,
}
impl<'a> NRST_SHDW_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 << 14)) | (((value as u32) & 0x01) << 14);
self.w
}
}
#[doc = "Reader of field `IWDG_SW`"]
pub type IWDG_SW_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `IWDG_SW`"]
pub struct IWDG_SW_W<'a> {
w: &'a mut W,
}
impl<'a> IWDG_SW_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 << 16)) | (((value as u32) & 0x01) << 16);
self.w
}
}
#[doc = "Reader of field `IWDG_STOP`"]
pub type IWDG_STOP_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `IWDG_STOP`"]
pub struct IWDG_STOP_W<'a> {
w: &'a mut W,
}
impl<'a> IWDG_STOP_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 << 17)) | (((value as u32) & 0x01) << 17);
self.w
}
}
#[doc = "Reader of field `IWDG_STDBY`"]
pub type IWDG_STDBY_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `IWDG_STDBY`"]
pub struct IWDG_STDBY_W<'a> {
w: &'a mut W,
}
impl<'a> IWDG_STDBY_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 << 18)) | (((value as u32) & 0x01) << 18);
self.w
}
}
#[doc = "Reader of field `WWDG_SW`"]
pub type WWDG_SW_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `WWDG_SW`"]
pub struct WWDG_SW_W<'a> {
w: &'a mut W,
}
impl<'a> WWDG_SW_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 << 19)) | (((value as u32) & 0x01) << 19);
self.w
}
}
#[doc = "Reader of field `SWAP_BANK`"]
pub type SWAP_BANK_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `SWAP_BANK`"]
pub struct SWAP_BANK_W<'a> {
w: &'a mut W,
}
impl<'a> SWAP_BANK_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 << 20)) | (((value as u32) & 0x01) << 20);
self.w
}
}
#[doc = "Reader of field `DB256K`"]
pub type DB256K_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `DB256K`"]
pub struct DB256K_W<'a> {
w: &'a mut W,
}
impl<'a> DB256K_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 << 21)) | (((value as u32) & 0x01) << 21);
self.w
}
}
#[doc = "Reader of field `DBANK`"]
pub type DBANK_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `DBANK`"]
pub struct DBANK_W<'a> {
w: &'a mut W,
}
impl<'a> DBANK_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 << 22)) | (((value as u32) & 0x01) << 22);
self.w
}
}
#[doc = "Reader of field `SRAM2_PE`"]
pub type SRAM2_PE_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `SRAM2_PE`"]
pub struct SRAM2_PE_W<'a> {
w: &'a mut W,
}
impl<'a> SRAM2_PE_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 << 24)) | (((value as u32) & 0x01) << 24);
self.w
}
}
#[doc = "Reader of field `SRAM2_RST`"]
pub type SRAM2_RST_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `SRAM2_RST`"]
pub struct SRAM2_RST_W<'a> {
w: &'a mut W,
}
impl<'a> SRAM2_RST_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 << 25)) | (((value as u32) & 0x01) << 25);
self.w
}
}
#[doc = "Reader of field `nSWBOOT0`"]
pub type NSWBOOT0_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `nSWBOOT0`"]
pub struct NSWBOOT0_W<'a> {
w: &'a mut W,
}
impl<'a> NSWBOOT0_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 << 26)) | (((value as u32) & 0x01) << 26);
self.w
}
}
#[doc = "Reader of field `nBOOT0`"]
pub type NBOOT0_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `nBOOT0`"]
pub struct NBOOT0_W<'a> {
w: &'a mut W,
}
impl<'a> NBOOT0_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 << 27)) | (((value as u32) & 0x01) << 27);
self.w
}
}
#[doc = "Reader of field `PA15_PUPEN`"]
pub type PA15_PUPEN_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `PA15_PUPEN`"]
pub struct PA15_PUPEN_W<'a> {
w: &'a mut W,
}
impl<'a> PA15_PUPEN_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 << 28)) | (((value as u32) & 0x01) << 28);
self.w
}
}
#[doc = "Reader of field `TZEN`"]
pub type TZEN_R = crate::R<bool, bool>;
#[doc = "Write proxy for field `TZEN`"]
pub struct TZEN_W<'a> {
w: &'a mut W,
}
impl<'a> TZEN_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 << 31)) | (((value as u32) & 0x01) << 31);
self.w
}
}
impl R {
#[doc = "Bits 0:7 - Read protection level"]
#[inline(always)]
pub fn rdp(&self) -> RDP_R {
RDP_R::new((self.bits & 0xff) as u8)
}
#[doc = "Bits 8:10 - BOR reset Level"]
#[inline(always)]
pub fn bor_lev(&self) -> BOR_LEV_R {
BOR_LEV_R::new(((self.bits >> 8) & 0x07) as u8)
}
#[doc = "Bit 12 - nRST_STOP"]
#[inline(always)]
pub fn n_rst_stop(&self) -> NRST_STOP_R {
NRST_STOP_R::new(((self.bits >> 12) & 0x01) != 0)
}
#[doc = "Bit 13 - nRST_STDBY"]
#[inline(always)]
pub fn n_rst_stdby(&self) -> NRST_STDBY_R {
NRST_STDBY_R::new(((self.bits >> 13) & 0x01) != 0)
}
#[doc = "Bit 14 - nRST_SHDW"]
#[inline(always)]
pub fn n_rst_shdw(&self) -> NRST_SHDW_R {
NRST_SHDW_R::new(((self.bits >> 14) & 0x01) != 0)
}
#[doc = "Bit 16 - Independent watchdog selection"]
#[inline(always)]
pub fn iwdg_sw(&self) -> IWDG_SW_R {
IWDG_SW_R::new(((self.bits >> 16) & 0x01) != 0)
}
#[doc = "Bit 17 - Independent watchdog counter freeze in Stop mode"]
#[inline(always)]
pub fn iwdg_stop(&self) -> IWDG_STOP_R {
IWDG_STOP_R::new(((self.bits >> 17) & 0x01) != 0)
}
#[doc = "Bit 18 - Independent watchdog counter freeze in Standby mode"]
#[inline(always)]
pub fn iwdg_stdby(&self) -> IWDG_STDBY_R {
IWDG_STDBY_R::new(((self.bits >> 18) & 0x01) != 0)
}
#[doc = "Bit 19 - Window watchdog selection"]
#[inline(always)]
pub fn wwdg_sw(&self) -> WWDG_SW_R {
WWDG_SW_R::new(((self.bits >> 19) & 0x01) != 0)
}
#[doc = "Bit 20 - SWAP_BANK"]
#[inline(always)]
pub fn swap_bank(&self) -> SWAP_BANK_R {
SWAP_BANK_R::new(((self.bits >> 20) & 0x01) != 0)
}
#[doc = "Bit 21 - DB256K"]
#[inline(always)]
pub fn db256k(&self) -> DB256K_R {
DB256K_R::new(((self.bits >> 21) & 0x01) != 0)
}
#[doc = "Bit 22 - DBANK"]
#[inline(always)]
pub fn dbank(&self) -> DBANK_R {
DBANK_R::new(((self.bits >> 22) & 0x01) != 0)
}
#[doc = "Bit 24 - SRAM2 parity check enable"]
#[inline(always)]
pub fn sram2_pe(&self) -> SRAM2_PE_R {
SRAM2_PE_R::new(((self.bits >> 24) & 0x01) != 0)
}
#[doc = "Bit 25 - SRAM2 Erase when system reset"]
#[inline(always)]
pub fn sram2_rst(&self) -> SRAM2_RST_R {
SRAM2_RST_R::new(((self.bits >> 25) & 0x01) != 0)
}
#[doc = "Bit 26 - nSWBOOT0"]
#[inline(always)]
pub fn n_swboot0(&self) -> NSWBOOT0_R {
NSWBOOT0_R::new(((self.bits >> 26) & 0x01) != 0)
}
#[doc = "Bit 27 - nBOOT0"]
#[inline(always)]
pub fn n_boot0(&self) -> NBOOT0_R {
NBOOT0_R::new(((self.bits >> 27) & 0x01) != 0)
}
#[doc = "Bit 28 - PA15_PUPEN"]
#[inline(always)]
pub fn pa15_pupen(&self) -> PA15_PUPEN_R {
PA15_PUPEN_R::new(((self.bits >> 28) & 0x01) != 0)
}
#[doc = "Bit 31 - TZEN"]
#[inline(always)]
pub fn tzen(&self) -> TZEN_R {
TZEN_R::new(((self.bits >> 31) & 0x01) != 0)
}
}
impl W {
#[doc = "Bits 0:7 - Read protection level"]
#[inline(always)]
pub fn rdp(&mut self) -> RDP_W {
RDP_W { w: self }
}
#[doc = "Bits 8:10 - BOR reset Level"]
#[inline(always)]
pub fn bor_lev(&mut self) -> BOR_LEV_W {
BOR_LEV_W { w: self }
}
#[doc = "Bit 12 - nRST_STOP"]
#[inline(always)]
pub fn n_rst_stop(&mut self) -> NRST_STOP_W {
NRST_STOP_W { w: self }
}
#[doc = "Bit 13 - nRST_STDBY"]
#[inline(always)]
pub fn n_rst_stdby(&mut self) -> NRST_STDBY_W {
NRST_STDBY_W { w: self }
}
#[doc = "Bit 14 - nRST_SHDW"]
#[inline(always)]
pub fn n_rst_shdw(&mut self) -> NRST_SHDW_W {
NRST_SHDW_W { w: self }
}
#[doc = "Bit 16 - Independent watchdog selection"]
#[inline(always)]
pub fn iwdg_sw(&mut self) -> IWDG_SW_W {
IWDG_SW_W { w: self }
}
#[doc = "Bit 17 - Independent watchdog counter freeze in Stop mode"]
#[inline(always)]
pub fn iwdg_stop(&mut self) -> IWDG_STOP_W {
IWDG_STOP_W { w: self }
}
#[doc = "Bit 18 - Independent watchdog counter freeze in Standby mode"]
#[inline(always)]
pub fn iwdg_stdby(&mut self) -> IWDG_STDBY_W {
IWDG_STDBY_W { w: self }
}
#[doc = "Bit 19 - Window watchdog selection"]
#[inline(always)]
pub fn wwdg_sw(&mut self) -> WWDG_SW_W {
WWDG_SW_W { w: self }
}
#[doc = "Bit 20 - SWAP_BANK"]
#[inline(always)]
pub fn swap_bank(&mut self) -> SWAP_BANK_W {
SWAP_BANK_W { w: self }
}
#[doc = "Bit 21 - DB256K"]
#[inline(always)]
pub fn db256k(&mut self) -> DB256K_W {
DB256K_W { w: self }
}
#[doc = "Bit 22 - DBANK"]
#[inline(always)]
pub fn dbank(&mut self) -> DBANK_W {
DBANK_W { w: self }
}
#[doc = "Bit 24 - SRAM2 parity check enable"]
#[inline(always)]
pub fn sram2_pe(&mut self) -> SRAM2_PE_W {
SRAM2_PE_W { w: self }
}
#[doc = "Bit 25 - SRAM2 Erase when system reset"]
#[inline(always)]
pub fn sram2_rst(&mut self) -> SRAM2_RST_W {
SRAM2_RST_W { w: self }
}
#[doc = "Bit 26 - nSWBOOT0"]
#[inline(always)]
pub fn n_swboot0(&mut self) -> NSWBOOT0_W {
NSWBOOT0_W { w: self }
}
#[doc = "Bit 27 - nBOOT0"]
#[inline(always)]
pub fn n_boot0(&mut self) -> NBOOT0_W {
NBOOT0_W { w: self }
}
#[doc = "Bit 28 - PA15_PUPEN"]
#[inline(always)]
pub fn pa15_pupen(&mut self) -> PA15_PUPEN_W {
PA15_PUPEN_W { w: self }
}
#[doc = "Bit 31 - TZEN"]
#[inline(always)]
pub fn tzen(&mut self) -> TZEN_W {
TZEN_W { w: self }
}
}