#[doc = "Register `FPCCR` reader"]
pub struct R(crate::R<FPCCR_SPEC>);
impl core::ops::Deref for R {
type Target = crate::R<FPCCR_SPEC>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
impl From<crate::R<FPCCR_SPEC>> for R {
#[inline(always)]
fn from(reader: crate::R<FPCCR_SPEC>) -> Self {
R(reader)
}
}
#[doc = "Register `FPCCR` writer"]
pub struct W(crate::W<FPCCR_SPEC>);
impl core::ops::Deref for W {
type Target = crate::W<FPCCR_SPEC>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
impl core::ops::DerefMut for W {
#[inline(always)]
fn deref_mut(&mut self) -> &mut Self::Target {
&mut self.0
}
}
impl From<crate::W<FPCCR_SPEC>> for W {
#[inline(always)]
fn from(writer: crate::W<FPCCR_SPEC>) -> Self {
W(writer)
}
}
#[doc = "Lazy State Preservation Active\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum LSPACT_A {
#[doc = "0: Lazy state preservation is not active."]
VALUE1 = 0,
#[doc = "1: Lazy state preservation is active. floating-point stack frame has been allocated but saving state to it has been deferred."]
VALUE2 = 1,
}
impl From<LSPACT_A> for bool {
#[inline(always)]
fn from(variant: LSPACT_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `LSPACT` reader - Lazy State Preservation Active"]
pub struct LSPACT_R(crate::FieldReader<bool, LSPACT_A>);
impl LSPACT_R {
pub(crate) fn new(bits: bool) -> Self {
LSPACT_R(crate::FieldReader::new(bits))
}
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> LSPACT_A {
match self.bits {
false => LSPACT_A::VALUE1,
true => LSPACT_A::VALUE2,
}
}
#[doc = "Checks if the value of the field is `VALUE1`"]
#[inline(always)]
pub fn is_value1(&self) -> bool {
**self == LSPACT_A::VALUE1
}
#[doc = "Checks if the value of the field is `VALUE2`"]
#[inline(always)]
pub fn is_value2(&self) -> bool {
**self == LSPACT_A::VALUE2
}
}
impl core::ops::Deref for LSPACT_R {
type Target = crate::FieldReader<bool, LSPACT_A>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
#[doc = "Field `LSPACT` writer - Lazy State Preservation Active"]
pub struct LSPACT_W<'a> {
w: &'a mut W,
}
impl<'a> LSPACT_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: LSPACT_A) -> &'a mut W {
self.bit(variant.into())
}
#[doc = "Lazy state preservation is not active."]
#[inline(always)]
pub fn value1(self) -> &'a mut W {
self.variant(LSPACT_A::VALUE1)
}
#[doc = "Lazy state preservation is active. floating-point stack frame has been allocated but saving state to it has been deferred."]
#[inline(always)]
pub fn value2(self) -> &'a mut W {
self.variant(LSPACT_A::VALUE2)
}
#[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 = "User allocated Stack Frame\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum USER_A {
#[doc = "0: Privilege level was not user when the floating-point stack frame was allocated."]
VALUE1 = 0,
#[doc = "1: Privilege level was user when the floating-point stack frame was allocated."]
VALUE2 = 1,
}
impl From<USER_A> for bool {
#[inline(always)]
fn from(variant: USER_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `USER` reader - User allocated Stack Frame"]
pub struct USER_R(crate::FieldReader<bool, USER_A>);
impl USER_R {
pub(crate) fn new(bits: bool) -> Self {
USER_R(crate::FieldReader::new(bits))
}
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> USER_A {
match self.bits {
false => USER_A::VALUE1,
true => USER_A::VALUE2,
}
}
#[doc = "Checks if the value of the field is `VALUE1`"]
#[inline(always)]
pub fn is_value1(&self) -> bool {
**self == USER_A::VALUE1
}
#[doc = "Checks if the value of the field is `VALUE2`"]
#[inline(always)]
pub fn is_value2(&self) -> bool {
**self == USER_A::VALUE2
}
}
impl core::ops::Deref for USER_R {
type Target = crate::FieldReader<bool, USER_A>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
#[doc = "Field `USER` writer - User allocated Stack Frame"]
pub struct USER_W<'a> {
w: &'a mut W,
}
impl<'a> USER_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: USER_A) -> &'a mut W {
self.bit(variant.into())
}
#[doc = "Privilege level was not user when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value1(self) -> &'a mut W {
self.variant(USER_A::VALUE1)
}
#[doc = "Privilege level was user when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value2(self) -> &'a mut W {
self.variant(USER_A::VALUE2)
}
#[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 = "Thread Mode allocated Stack Frame\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum THREAD_A {
#[doc = "0: Mode was not Thread Mode when the floating-point stack frame was allocated."]
VALUE1 = 0,
#[doc = "1: Mode was Thread Mode when the floating-point stack frame was allocated."]
VALUE2 = 1,
}
impl From<THREAD_A> for bool {
#[inline(always)]
fn from(variant: THREAD_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `THREAD` reader - Thread Mode allocated Stack Frame"]
pub struct THREAD_R(crate::FieldReader<bool, THREAD_A>);
impl THREAD_R {
pub(crate) fn new(bits: bool) -> Self {
THREAD_R(crate::FieldReader::new(bits))
}
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> THREAD_A {
match self.bits {
false => THREAD_A::VALUE1,
true => THREAD_A::VALUE2,
}
}
#[doc = "Checks if the value of the field is `VALUE1`"]
#[inline(always)]
pub fn is_value1(&self) -> bool {
**self == THREAD_A::VALUE1
}
#[doc = "Checks if the value of the field is `VALUE2`"]
#[inline(always)]
pub fn is_value2(&self) -> bool {
**self == THREAD_A::VALUE2
}
}
impl core::ops::Deref for THREAD_R {
type Target = crate::FieldReader<bool, THREAD_A>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
#[doc = "Field `THREAD` writer - Thread Mode allocated Stack Frame"]
pub struct THREAD_W<'a> {
w: &'a mut W,
}
impl<'a> THREAD_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: THREAD_A) -> &'a mut W {
self.bit(variant.into())
}
#[doc = "Mode was not Thread Mode when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value1(self) -> &'a mut W {
self.variant(THREAD_A::VALUE1)
}
#[doc = "Mode was Thread Mode when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value2(self) -> &'a mut W {
self.variant(THREAD_A::VALUE2)
}
#[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 = "HardFault Ready\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum HFRDY_A {
#[doc = "0: Priority did not permit setting the HardFault handler to the pending state when the floating-point stack frame was allocated."]
VALUE1 = 0,
#[doc = "1: Priority permitted setting the HardFault handler to the pending state when the floating-point stack frame was allocated."]
VALUE2 = 1,
}
impl From<HFRDY_A> for bool {
#[inline(always)]
fn from(variant: HFRDY_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `HFRDY` reader - HardFault Ready"]
pub struct HFRDY_R(crate::FieldReader<bool, HFRDY_A>);
impl HFRDY_R {
pub(crate) fn new(bits: bool) -> Self {
HFRDY_R(crate::FieldReader::new(bits))
}
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> HFRDY_A {
match self.bits {
false => HFRDY_A::VALUE1,
true => HFRDY_A::VALUE2,
}
}
#[doc = "Checks if the value of the field is `VALUE1`"]
#[inline(always)]
pub fn is_value1(&self) -> bool {
**self == HFRDY_A::VALUE1
}
#[doc = "Checks if the value of the field is `VALUE2`"]
#[inline(always)]
pub fn is_value2(&self) -> bool {
**self == HFRDY_A::VALUE2
}
}
impl core::ops::Deref for HFRDY_R {
type Target = crate::FieldReader<bool, HFRDY_A>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
#[doc = "Field `HFRDY` writer - HardFault Ready"]
pub struct HFRDY_W<'a> {
w: &'a mut W,
}
impl<'a> HFRDY_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: HFRDY_A) -> &'a mut W {
self.bit(variant.into())
}
#[doc = "Priority did not permit setting the HardFault handler to the pending state when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value1(self) -> &'a mut W {
self.variant(HFRDY_A::VALUE1)
}
#[doc = "Priority permitted setting the HardFault handler to the pending state when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value2(self) -> &'a mut W {
self.variant(HFRDY_A::VALUE2)
}
#[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 = "MemManage Ready\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum MMRDY_A {
#[doc = "0: MemManage is disabled or priority did not permit setting the MemManage handler to the pending state when the floating-point stack frame was allocated."]
VALUE1 = 0,
#[doc = "1: MemManage is enabled and priority permitted setting the MemManage handler to the pending state when the floating-point stack frame was allocated."]
VALUE2 = 1,
}
impl From<MMRDY_A> for bool {
#[inline(always)]
fn from(variant: MMRDY_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `MMRDY` reader - MemManage Ready"]
pub struct MMRDY_R(crate::FieldReader<bool, MMRDY_A>);
impl MMRDY_R {
pub(crate) fn new(bits: bool) -> Self {
MMRDY_R(crate::FieldReader::new(bits))
}
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> MMRDY_A {
match self.bits {
false => MMRDY_A::VALUE1,
true => MMRDY_A::VALUE2,
}
}
#[doc = "Checks if the value of the field is `VALUE1`"]
#[inline(always)]
pub fn is_value1(&self) -> bool {
**self == MMRDY_A::VALUE1
}
#[doc = "Checks if the value of the field is `VALUE2`"]
#[inline(always)]
pub fn is_value2(&self) -> bool {
**self == MMRDY_A::VALUE2
}
}
impl core::ops::Deref for MMRDY_R {
type Target = crate::FieldReader<bool, MMRDY_A>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
#[doc = "Field `MMRDY` writer - MemManage Ready"]
pub struct MMRDY_W<'a> {
w: &'a mut W,
}
impl<'a> MMRDY_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: MMRDY_A) -> &'a mut W {
self.bit(variant.into())
}
#[doc = "MemManage is disabled or priority did not permit setting the MemManage handler to the pending state when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value1(self) -> &'a mut W {
self.variant(MMRDY_A::VALUE1)
}
#[doc = "MemManage is enabled and priority permitted setting the MemManage handler to the pending state when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value2(self) -> &'a mut W {
self.variant(MMRDY_A::VALUE2)
}
#[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 = "BusFault Ready\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum BFRDY_A {
#[doc = "0: BusFault is disabled or priority did not permit setting the BusFault handler to the pending state when the floating-point stack frame was allocated."]
VALUE1 = 0,
#[doc = "1: BusFault is enabled and priority permitted setting the BusFault handler to the pending state when the floating-point stack frame was allocated."]
VALUE2 = 1,
}
impl From<BFRDY_A> for bool {
#[inline(always)]
fn from(variant: BFRDY_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `BFRDY` reader - BusFault Ready"]
pub struct BFRDY_R(crate::FieldReader<bool, BFRDY_A>);
impl BFRDY_R {
pub(crate) fn new(bits: bool) -> Self {
BFRDY_R(crate::FieldReader::new(bits))
}
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> BFRDY_A {
match self.bits {
false => BFRDY_A::VALUE1,
true => BFRDY_A::VALUE2,
}
}
#[doc = "Checks if the value of the field is `VALUE1`"]
#[inline(always)]
pub fn is_value1(&self) -> bool {
**self == BFRDY_A::VALUE1
}
#[doc = "Checks if the value of the field is `VALUE2`"]
#[inline(always)]
pub fn is_value2(&self) -> bool {
**self == BFRDY_A::VALUE2
}
}
impl core::ops::Deref for BFRDY_R {
type Target = crate::FieldReader<bool, BFRDY_A>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
#[doc = "Field `BFRDY` writer - BusFault Ready"]
pub struct BFRDY_W<'a> {
w: &'a mut W,
}
impl<'a> BFRDY_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: BFRDY_A) -> &'a mut W {
self.bit(variant.into())
}
#[doc = "BusFault is disabled or priority did not permit setting the BusFault handler to the pending state when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value1(self) -> &'a mut W {
self.variant(BFRDY_A::VALUE1)
}
#[doc = "BusFault is enabled and priority permitted setting the BusFault handler to the pending state when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value2(self) -> &'a mut W {
self.variant(BFRDY_A::VALUE2)
}
#[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 = "Monitor Ready\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum MONRDY_A {
#[doc = "0: Debug Monitor is disabled or priority did not permit setting MON_PEND when the floating-point stack frame was allocated."]
VALUE1 = 0,
#[doc = "1: Debug Monitor is enabled and priority permits setting MON_PEND when the floating-point stack frame was allocated."]
VALUE2 = 1,
}
impl From<MONRDY_A> for bool {
#[inline(always)]
fn from(variant: MONRDY_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `MONRDY` reader - Monitor Ready"]
pub struct MONRDY_R(crate::FieldReader<bool, MONRDY_A>);
impl MONRDY_R {
pub(crate) fn new(bits: bool) -> Self {
MONRDY_R(crate::FieldReader::new(bits))
}
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> MONRDY_A {
match self.bits {
false => MONRDY_A::VALUE1,
true => MONRDY_A::VALUE2,
}
}
#[doc = "Checks if the value of the field is `VALUE1`"]
#[inline(always)]
pub fn is_value1(&self) -> bool {
**self == MONRDY_A::VALUE1
}
#[doc = "Checks if the value of the field is `VALUE2`"]
#[inline(always)]
pub fn is_value2(&self) -> bool {
**self == MONRDY_A::VALUE2
}
}
impl core::ops::Deref for MONRDY_R {
type Target = crate::FieldReader<bool, MONRDY_A>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
#[doc = "Field `MONRDY` writer - Monitor Ready"]
pub struct MONRDY_W<'a> {
w: &'a mut W,
}
impl<'a> MONRDY_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: MONRDY_A) -> &'a mut W {
self.bit(variant.into())
}
#[doc = "Debug Monitor is disabled or priority did not permit setting MON_PEND when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value1(self) -> &'a mut W {
self.variant(MONRDY_A::VALUE1)
}
#[doc = "Debug Monitor is enabled and priority permits setting MON_PEND when the floating-point stack frame was allocated."]
#[inline(always)]
pub fn value2(self) -> &'a mut W {
self.variant(MONRDY_A::VALUE2)
}
#[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 << 8)) | ((value as u32 & 0x01) << 8);
self.w
}
}
#[doc = "Lazy State Preservation Enabled\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum LSPEN_A {
#[doc = "0: Disable automatic lazy state preservation for floating-point context."]
VALUE1 = 0,
#[doc = "1: Enable automatic lazy state preservation for floating-point context."]
VALUE2 = 1,
}
impl From<LSPEN_A> for bool {
#[inline(always)]
fn from(variant: LSPEN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `LSPEN` reader - Lazy State Preservation Enabled"]
pub struct LSPEN_R(crate::FieldReader<bool, LSPEN_A>);
impl LSPEN_R {
pub(crate) fn new(bits: bool) -> Self {
LSPEN_R(crate::FieldReader::new(bits))
}
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> LSPEN_A {
match self.bits {
false => LSPEN_A::VALUE1,
true => LSPEN_A::VALUE2,
}
}
#[doc = "Checks if the value of the field is `VALUE1`"]
#[inline(always)]
pub fn is_value1(&self) -> bool {
**self == LSPEN_A::VALUE1
}
#[doc = "Checks if the value of the field is `VALUE2`"]
#[inline(always)]
pub fn is_value2(&self) -> bool {
**self == LSPEN_A::VALUE2
}
}
impl core::ops::Deref for LSPEN_R {
type Target = crate::FieldReader<bool, LSPEN_A>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
#[doc = "Field `LSPEN` writer - Lazy State Preservation Enabled"]
pub struct LSPEN_W<'a> {
w: &'a mut W,
}
impl<'a> LSPEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: LSPEN_A) -> &'a mut W {
self.bit(variant.into())
}
#[doc = "Disable automatic lazy state preservation for floating-point context."]
#[inline(always)]
pub fn value1(self) -> &'a mut W {
self.variant(LSPEN_A::VALUE1)
}
#[doc = "Enable automatic lazy state preservation for floating-point context."]
#[inline(always)]
pub fn value2(self) -> &'a mut W {
self.variant(LSPEN_A::VALUE2)
}
#[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 = "Automatic State Preservation\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum ASPEN_A {
#[doc = "0: Disable CONTROL setting on execution of a floating-point instruction."]
VALUE1 = 0,
#[doc = "1: Enable CONTROL setting on execution of a floating-point instruction."]
VALUE2 = 1,
}
impl From<ASPEN_A> for bool {
#[inline(always)]
fn from(variant: ASPEN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Field `ASPEN` reader - Automatic State Preservation"]
pub struct ASPEN_R(crate::FieldReader<bool, ASPEN_A>);
impl ASPEN_R {
pub(crate) fn new(bits: bool) -> Self {
ASPEN_R(crate::FieldReader::new(bits))
}
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> ASPEN_A {
match self.bits {
false => ASPEN_A::VALUE1,
true => ASPEN_A::VALUE2,
}
}
#[doc = "Checks if the value of the field is `VALUE1`"]
#[inline(always)]
pub fn is_value1(&self) -> bool {
**self == ASPEN_A::VALUE1
}
#[doc = "Checks if the value of the field is `VALUE2`"]
#[inline(always)]
pub fn is_value2(&self) -> bool {
**self == ASPEN_A::VALUE2
}
}
impl core::ops::Deref for ASPEN_R {
type Target = crate::FieldReader<bool, ASPEN_A>;
#[inline(always)]
fn deref(&self) -> &Self::Target {
&self.0
}
}
#[doc = "Field `ASPEN` writer - Automatic State Preservation"]
pub struct ASPEN_W<'a> {
w: &'a mut W,
}
impl<'a> ASPEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ASPEN_A) -> &'a mut W {
self.bit(variant.into())
}
#[doc = "Disable CONTROL setting on execution of a floating-point instruction."]
#[inline(always)]
pub fn value1(self) -> &'a mut W {
self.variant(ASPEN_A::VALUE1)
}
#[doc = "Enable CONTROL setting on execution of a floating-point instruction."]
#[inline(always)]
pub fn value2(self) -> &'a mut W {
self.variant(ASPEN_A::VALUE2)
}
#[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 = "Bit 0 - Lazy State Preservation Active"]
#[inline(always)]
pub fn lspact(&self) -> LSPACT_R {
LSPACT_R::new((self.bits & 0x01) != 0)
}
#[doc = "Bit 1 - User allocated Stack Frame"]
#[inline(always)]
pub fn user(&self) -> USER_R {
USER_R::new(((self.bits >> 1) & 0x01) != 0)
}
#[doc = "Bit 3 - Thread Mode allocated Stack Frame"]
#[inline(always)]
pub fn thread(&self) -> THREAD_R {
THREAD_R::new(((self.bits >> 3) & 0x01) != 0)
}
#[doc = "Bit 4 - HardFault Ready"]
#[inline(always)]
pub fn hfrdy(&self) -> HFRDY_R {
HFRDY_R::new(((self.bits >> 4) & 0x01) != 0)
}
#[doc = "Bit 5 - MemManage Ready"]
#[inline(always)]
pub fn mmrdy(&self) -> MMRDY_R {
MMRDY_R::new(((self.bits >> 5) & 0x01) != 0)
}
#[doc = "Bit 6 - BusFault Ready"]
#[inline(always)]
pub fn bfrdy(&self) -> BFRDY_R {
BFRDY_R::new(((self.bits >> 6) & 0x01) != 0)
}
#[doc = "Bit 8 - Monitor Ready"]
#[inline(always)]
pub fn monrdy(&self) -> MONRDY_R {
MONRDY_R::new(((self.bits >> 8) & 0x01) != 0)
}
#[doc = "Bit 30 - Lazy State Preservation Enabled"]
#[inline(always)]
pub fn lspen(&self) -> LSPEN_R {
LSPEN_R::new(((self.bits >> 30) & 0x01) != 0)
}
#[doc = "Bit 31 - Automatic State Preservation"]
#[inline(always)]
pub fn aspen(&self) -> ASPEN_R {
ASPEN_R::new(((self.bits >> 31) & 0x01) != 0)
}
}
impl W {
#[doc = "Bit 0 - Lazy State Preservation Active"]
#[inline(always)]
pub fn lspact(&mut self) -> LSPACT_W {
LSPACT_W { w: self }
}
#[doc = "Bit 1 - User allocated Stack Frame"]
#[inline(always)]
pub fn user(&mut self) -> USER_W {
USER_W { w: self }
}
#[doc = "Bit 3 - Thread Mode allocated Stack Frame"]
#[inline(always)]
pub fn thread(&mut self) -> THREAD_W {
THREAD_W { w: self }
}
#[doc = "Bit 4 - HardFault Ready"]
#[inline(always)]
pub fn hfrdy(&mut self) -> HFRDY_W {
HFRDY_W { w: self }
}
#[doc = "Bit 5 - MemManage Ready"]
#[inline(always)]
pub fn mmrdy(&mut self) -> MMRDY_W {
MMRDY_W { w: self }
}
#[doc = "Bit 6 - BusFault Ready"]
#[inline(always)]
pub fn bfrdy(&mut self) -> BFRDY_W {
BFRDY_W { w: self }
}
#[doc = "Bit 8 - Monitor Ready"]
#[inline(always)]
pub fn monrdy(&mut self) -> MONRDY_W {
MONRDY_W { w: self }
}
#[doc = "Bit 30 - Lazy State Preservation Enabled"]
#[inline(always)]
pub fn lspen(&mut self) -> LSPEN_W {
LSPEN_W { w: self }
}
#[doc = "Bit 31 - Automatic State Preservation"]
#[inline(always)]
pub fn aspen(&mut self) -> ASPEN_W {
ASPEN_W { w: self }
}
#[doc = "Writes raw bits to the register."]
#[inline(always)]
pub unsafe fn bits(&mut self, bits: u32) -> &mut Self {
self.0.bits(bits);
self
}
}
#[doc = "Floating-point Context Control Register\n\nThis register you can [`read`](crate::generic::Reg::read), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [fpccr](index.html) module"]
pub struct FPCCR_SPEC;
impl crate::RegisterSpec for FPCCR_SPEC {
type Ux = u32;
}
#[doc = "`read()` method returns [fpccr::R](R) reader structure"]
impl crate::Readable for FPCCR_SPEC {
type Reader = R;
}
#[doc = "`write(|w| ..)` method takes [fpccr::W](W) writer structure"]
impl crate::Writable for FPCCR_SPEC {
type Writer = W;
}
#[doc = "`reset()` method sets FPCCR to value 0"]
impl crate::Resettable for FPCCR_SPEC {
#[inline(always)]
fn reset_value() -> Self::Ux {
0
}
}