#[doc = "Reader of register CR"]
pub type R = crate::R<u32, super::CR>;
#[doc = "Writer for register CR"]
pub type W = crate::W<u32, super::CR>;
#[doc = "Register CR `reset()`'s with value 0"]
impl crate::ResetValue for super::CR {
type Type = u32;
#[inline(always)]
fn reset_value() -> Self::Type {
0
}
}
#[doc = "Enable DMA management of data output phase\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum DMAOUTEN_A {
#[doc = "0: Disable DMA Output"]
DISABLED,
#[doc = "1: Enabled DMA Output"]
ENABLED,
}
impl From<DMAOUTEN_A> for bool {
#[inline(always)]
fn from(variant: DMAOUTEN_A) -> Self {
match variant {
DMAOUTEN_A::DISABLED => false,
DMAOUTEN_A::ENABLED => true,
}
}
}
#[doc = "Reader of field `DMAOUTEN`"]
pub type DMAOUTEN_R = crate::R<bool, DMAOUTEN_A>;
impl DMAOUTEN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> DMAOUTEN_A {
match self.bits {
false => DMAOUTEN_A::DISABLED,
true => DMAOUTEN_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == DMAOUTEN_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == DMAOUTEN_A::ENABLED
}
}
#[doc = "Write proxy for field `DMAOUTEN`"]
pub struct DMAOUTEN_W<'a> {
w: &'a mut W,
}
impl<'a> DMAOUTEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: DMAOUTEN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Disable DMA Output"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(DMAOUTEN_A::DISABLED)
}
#[doc = "Enabled DMA Output"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(DMAOUTEN_A::ENABLED)
}
#[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 = "Enable DMA management of data input phase\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum DMAINEN_A {
#[doc = "0: Disable DMA Input"]
DISABLED,
#[doc = "1: Enable DMA Input"]
ENABLED,
}
impl From<DMAINEN_A> for bool {
#[inline(always)]
fn from(variant: DMAINEN_A) -> Self {
match variant {
DMAINEN_A::DISABLED => false,
DMAINEN_A::ENABLED => true,
}
}
}
#[doc = "Reader of field `DMAINEN`"]
pub type DMAINEN_R = crate::R<bool, DMAINEN_A>;
impl DMAINEN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> DMAINEN_A {
match self.bits {
false => DMAINEN_A::DISABLED,
true => DMAINEN_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == DMAINEN_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == DMAINEN_A::ENABLED
}
}
#[doc = "Write proxy for field `DMAINEN`"]
pub struct DMAINEN_W<'a> {
w: &'a mut W,
}
impl<'a> DMAINEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: DMAINEN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Disable DMA Input"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(DMAINEN_A::DISABLED)
}
#[doc = "Enable DMA Input"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(DMAINEN_A::ENABLED)
}
#[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 << 11)) | (((value as u32) & 0x01) << 11);
self.w
}
}
#[doc = "Error interrupt enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum ERRIE_A {
#[doc = "0: Disable (mask) error interrupt"]
DISABLED,
#[doc = "1: Enable error interrupt"]
ENABLED,
}
impl From<ERRIE_A> for bool {
#[inline(always)]
fn from(variant: ERRIE_A) -> Self {
match variant {
ERRIE_A::DISABLED => false,
ERRIE_A::ENABLED => true,
}
}
}
#[doc = "Reader of field `ERRIE`"]
pub type ERRIE_R = crate::R<bool, ERRIE_A>;
impl ERRIE_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> ERRIE_A {
match self.bits {
false => ERRIE_A::DISABLED,
true => ERRIE_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == ERRIE_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == ERRIE_A::ENABLED
}
}
#[doc = "Write proxy for field `ERRIE`"]
pub struct ERRIE_W<'a> {
w: &'a mut W,
}
impl<'a> ERRIE_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ERRIE_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Disable (mask) error interrupt"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(ERRIE_A::DISABLED)
}
#[doc = "Enable error interrupt"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(ERRIE_A::ENABLED)
}
#[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 << 10)) | (((value as u32) & 0x01) << 10);
self.w
}
}
#[doc = "CCF flag interrupt enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum CCFIE_A {
#[doc = "0: Disable (mask) CCF interrupt"]
DISABLED,
#[doc = "1: Enable CCF interrupt"]
ENABLED,
}
impl From<CCFIE_A> for bool {
#[inline(always)]
fn from(variant: CCFIE_A) -> Self {
match variant {
CCFIE_A::DISABLED => false,
CCFIE_A::ENABLED => true,
}
}
}
#[doc = "Reader of field `CCFIE`"]
pub type CCFIE_R = crate::R<bool, CCFIE_A>;
impl CCFIE_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> CCFIE_A {
match self.bits {
false => CCFIE_A::DISABLED,
true => CCFIE_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == CCFIE_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == CCFIE_A::ENABLED
}
}
#[doc = "Write proxy for field `CCFIE`"]
pub struct CCFIE_W<'a> {
w: &'a mut W,
}
impl<'a> CCFIE_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: CCFIE_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Disable (mask) CCF interrupt"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(CCFIE_A::DISABLED)
}
#[doc = "Enable CCF interrupt"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(CCFIE_A::ENABLED)
}
#[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 << 9)) | (((value as u32) & 0x01) << 9);
self.w
}
}
#[doc = "Error clear\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum ERRC_A {
#[doc = "1: Clear RDERR and WRERR flags"]
CLEAR,
}
impl From<ERRC_A> for bool {
#[inline(always)]
fn from(variant: ERRC_A) -> Self {
match variant {
ERRC_A::CLEAR => true,
}
}
}
#[doc = "Reader of field `ERRC`"]
pub type ERRC_R = crate::R<bool, ERRC_A>;
impl ERRC_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<bool, ERRC_A> {
use crate::Variant::*;
match self.bits {
true => Val(ERRC_A::CLEAR),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `CLEAR`"]
#[inline(always)]
pub fn is_clear(&self) -> bool {
*self == ERRC_A::CLEAR
}
}
#[doc = "Write proxy for field `ERRC`"]
pub struct ERRC_W<'a> {
w: &'a mut W,
}
impl<'a> ERRC_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ERRC_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Clear RDERR and WRERR flags"]
#[inline(always)]
pub fn clear(self) -> &'a mut W {
self.variant(ERRC_A::CLEAR)
}
#[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 = "Computation Complete Flag Clear\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum CCFC_A {
#[doc = "1: Clear computation complete flag"]
CLEAR,
}
impl From<CCFC_A> for bool {
#[inline(always)]
fn from(variant: CCFC_A) -> Self {
match variant {
CCFC_A::CLEAR => true,
}
}
}
#[doc = "Reader of field `CCFC`"]
pub type CCFC_R = crate::R<bool, CCFC_A>;
impl CCFC_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<bool, CCFC_A> {
use crate::Variant::*;
match self.bits {
true => Val(CCFC_A::CLEAR),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `CLEAR`"]
#[inline(always)]
pub fn is_clear(&self) -> bool {
*self == CCFC_A::CLEAR
}
}
#[doc = "Write proxy for field `CCFC`"]
pub struct CCFC_W<'a> {
w: &'a mut W,
}
impl<'a> CCFC_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: CCFC_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Clear computation complete flag"]
#[inline(always)]
pub fn clear(self) -> &'a mut W {
self.variant(CCFC_A::CLEAR)
}
#[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 = "AES chaining mode\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum CHMOD_A {
#[doc = "0: Electronic codebook (ECB)"]
ECB,
#[doc = "1: Cipher-Block Chaining (CBC)"]
CBC,
#[doc = "2: Counter Mode (CTR)"]
CTR,
}
impl From<CHMOD_A> for u8 {
#[inline(always)]
fn from(variant: CHMOD_A) -> Self {
match variant {
CHMOD_A::ECB => 0,
CHMOD_A::CBC => 1,
CHMOD_A::CTR => 2,
}
}
}
#[doc = "Reader of field `CHMOD`"]
pub type CHMOD_R = crate::R<u8, CHMOD_A>;
impl CHMOD_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<u8, CHMOD_A> {
use crate::Variant::*;
match self.bits {
0 => Val(CHMOD_A::ECB),
1 => Val(CHMOD_A::CBC),
2 => Val(CHMOD_A::CTR),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `ECB`"]
#[inline(always)]
pub fn is_ecb(&self) -> bool {
*self == CHMOD_A::ECB
}
#[doc = "Checks if the value of the field is `CBC`"]
#[inline(always)]
pub fn is_cbc(&self) -> bool {
*self == CHMOD_A::CBC
}
#[doc = "Checks if the value of the field is `CTR`"]
#[inline(always)]
pub fn is_ctr(&self) -> bool {
*self == CHMOD_A::CTR
}
}
#[doc = "Write proxy for field `CHMOD`"]
pub struct CHMOD_W<'a> {
w: &'a mut W,
}
impl<'a> CHMOD_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: CHMOD_A) -> &'a mut W {
unsafe { self.bits(variant.into()) }
}
#[doc = "Electronic codebook (ECB)"]
#[inline(always)]
pub fn ecb(self) -> &'a mut W {
self.variant(CHMOD_A::ECB)
}
#[doc = "Cipher-Block Chaining (CBC)"]
#[inline(always)]
pub fn cbc(self) -> &'a mut W {
self.variant(CHMOD_A::CBC)
}
#[doc = "Counter Mode (CTR)"]
#[inline(always)]
pub fn ctr(self) -> &'a mut W {
self.variant(CHMOD_A::CTR)
}
#[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 & !(0x03 << 5)) | (((value as u32) & 0x03) << 5);
self.w
}
}
#[doc = "AES operating mode\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum MODE_A {
#[doc = "0: Mode 1: encryption"]
MODE1,
#[doc = "1: Mode 2: key derivation (or key preparation for ECB/CBC decryption)"]
MODE2,
#[doc = "2: Mode 3: decryption"]
MODE3,
#[doc = "3: Mode 4: key derivation then single decryption"]
MODE4,
}
impl From<MODE_A> for u8 {
#[inline(always)]
fn from(variant: MODE_A) -> Self {
match variant {
MODE_A::MODE1 => 0,
MODE_A::MODE2 => 1,
MODE_A::MODE3 => 2,
MODE_A::MODE4 => 3,
}
}
}
#[doc = "Reader of field `MODE`"]
pub type MODE_R = crate::R<u8, MODE_A>;
impl MODE_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> MODE_A {
match self.bits {
0 => MODE_A::MODE1,
1 => MODE_A::MODE2,
2 => MODE_A::MODE3,
3 => MODE_A::MODE4,
_ => unreachable!(),
}
}
#[doc = "Checks if the value of the field is `MODE1`"]
#[inline(always)]
pub fn is_mode1(&self) -> bool {
*self == MODE_A::MODE1
}
#[doc = "Checks if the value of the field is `MODE2`"]
#[inline(always)]
pub fn is_mode2(&self) -> bool {
*self == MODE_A::MODE2
}
#[doc = "Checks if the value of the field is `MODE3`"]
#[inline(always)]
pub fn is_mode3(&self) -> bool {
*self == MODE_A::MODE3
}
#[doc = "Checks if the value of the field is `MODE4`"]
#[inline(always)]
pub fn is_mode4(&self) -> bool {
*self == MODE_A::MODE4
}
}
#[doc = "Write proxy for field `MODE`"]
pub struct MODE_W<'a> {
w: &'a mut W,
}
impl<'a> MODE_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: MODE_A) -> &'a mut W {
{
self.bits(variant.into())
}
}
#[doc = "Mode 1: encryption"]
#[inline(always)]
pub fn mode1(self) -> &'a mut W {
self.variant(MODE_A::MODE1)
}
#[doc = "Mode 2: key derivation (or key preparation for ECB/CBC decryption)"]
#[inline(always)]
pub fn mode2(self) -> &'a mut W {
self.variant(MODE_A::MODE2)
}
#[doc = "Mode 3: decryption"]
#[inline(always)]
pub fn mode3(self) -> &'a mut W {
self.variant(MODE_A::MODE3)
}
#[doc = "Mode 4: key derivation then single decryption"]
#[inline(always)]
pub fn mode4(self) -> &'a mut W {
self.variant(MODE_A::MODE4)
}
#[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 = "Data type selection (for data in and data out to/from the cryptographic block)\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum DATATYPE_A {
#[doc = "0: Word"]
NONE,
#[doc = "1: Half-word (16-bit)"]
HALFWORD,
#[doc = "2: Byte (8-bit)"]
BYTE,
#[doc = "3: Bit"]
BIT,
}
impl From<DATATYPE_A> for u8 {
#[inline(always)]
fn from(variant: DATATYPE_A) -> Self {
match variant {
DATATYPE_A::NONE => 0,
DATATYPE_A::HALFWORD => 1,
DATATYPE_A::BYTE => 2,
DATATYPE_A::BIT => 3,
}
}
}
#[doc = "Reader of field `DATATYPE`"]
pub type DATATYPE_R = crate::R<u8, DATATYPE_A>;
impl DATATYPE_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> DATATYPE_A {
match self.bits {
0 => DATATYPE_A::NONE,
1 => DATATYPE_A::HALFWORD,
2 => DATATYPE_A::BYTE,
3 => DATATYPE_A::BIT,
_ => unreachable!(),
}
}
#[doc = "Checks if the value of the field is `NONE`"]
#[inline(always)]
pub fn is_none(&self) -> bool {
*self == DATATYPE_A::NONE
}
#[doc = "Checks if the value of the field is `HALFWORD`"]
#[inline(always)]
pub fn is_half_word(&self) -> bool {
*self == DATATYPE_A::HALFWORD
}
#[doc = "Checks if the value of the field is `BYTE`"]
#[inline(always)]
pub fn is_byte(&self) -> bool {
*self == DATATYPE_A::BYTE
}
#[doc = "Checks if the value of the field is `BIT`"]
#[inline(always)]
pub fn is_bit_(&self) -> bool {
*self == DATATYPE_A::BIT
}
}
#[doc = "Write proxy for field `DATATYPE`"]
pub struct DATATYPE_W<'a> {
w: &'a mut W,
}
impl<'a> DATATYPE_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: DATATYPE_A) -> &'a mut W {
{
self.bits(variant.into())
}
}
#[doc = "Word"]
#[inline(always)]
pub fn none(self) -> &'a mut W {
self.variant(DATATYPE_A::NONE)
}
#[doc = "Half-word (16-bit)"]
#[inline(always)]
pub fn half_word(self) -> &'a mut W {
self.variant(DATATYPE_A::HALFWORD)
}
#[doc = "Byte (8-bit)"]
#[inline(always)]
pub fn byte(self) -> &'a mut W {
self.variant(DATATYPE_A::BYTE)
}
#[doc = "Bit"]
#[inline(always)]
pub fn bit_(self) -> &'a mut W {
self.variant(DATATYPE_A::BIT)
}
#[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 << 1)) | (((value as u32) & 0x03) << 1);
self.w
}
}
#[doc = "AES enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum EN_A {
#[doc = "0: Disable AES"]
DISABLED,
#[doc = "1: Enable AES"]
ENABLED,
}
impl From<EN_A> for bool {
#[inline(always)]
fn from(variant: EN_A) -> Self {
match variant {
EN_A::DISABLED => false,
EN_A::ENABLED => true,
}
}
}
#[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::DISABLED,
true => EN_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == EN_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == EN_A::ENABLED
}
}
#[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 = "Disable AES"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(EN_A::DISABLED)
}
#[doc = "Enable AES"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(EN_A::ENABLED)
}
#[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
}
}
impl R {
#[doc = "Bit 12 - Enable DMA management of data output phase"]
#[inline(always)]
pub fn dmaouten(&self) -> DMAOUTEN_R {
DMAOUTEN_R::new(((self.bits >> 12) & 0x01) != 0)
}
#[doc = "Bit 11 - Enable DMA management of data input phase"]
#[inline(always)]
pub fn dmainen(&self) -> DMAINEN_R {
DMAINEN_R::new(((self.bits >> 11) & 0x01) != 0)
}
#[doc = "Bit 10 - Error interrupt enable"]
#[inline(always)]
pub fn errie(&self) -> ERRIE_R {
ERRIE_R::new(((self.bits >> 10) & 0x01) != 0)
}
#[doc = "Bit 9 - CCF flag interrupt enable"]
#[inline(always)]
pub fn ccfie(&self) -> CCFIE_R {
CCFIE_R::new(((self.bits >> 9) & 0x01) != 0)
}
#[doc = "Bit 8 - Error clear"]
#[inline(always)]
pub fn errc(&self) -> ERRC_R {
ERRC_R::new(((self.bits >> 8) & 0x01) != 0)
}
#[doc = "Bit 7 - Computation Complete Flag Clear"]
#[inline(always)]
pub fn ccfc(&self) -> CCFC_R {
CCFC_R::new(((self.bits >> 7) & 0x01) != 0)
}
#[doc = "Bits 5:6 - AES chaining mode"]
#[inline(always)]
pub fn chmod(&self) -> CHMOD_R {
CHMOD_R::new(((self.bits >> 5) & 0x03) as u8)
}
#[doc = "Bits 3:4 - AES operating mode"]
#[inline(always)]
pub fn mode(&self) -> MODE_R {
MODE_R::new(((self.bits >> 3) & 0x03) as u8)
}
#[doc = "Bits 1:2 - Data type selection (for data in and data out to/from the cryptographic block)"]
#[inline(always)]
pub fn datatype(&self) -> DATATYPE_R {
DATATYPE_R::new(((self.bits >> 1) & 0x03) as u8)
}
#[doc = "Bit 0 - AES enable"]
#[inline(always)]
pub fn en(&self) -> EN_R {
EN_R::new((self.bits & 0x01) != 0)
}
}
impl W {
#[doc = "Bit 12 - Enable DMA management of data output phase"]
#[inline(always)]
pub fn dmaouten(&mut self) -> DMAOUTEN_W {
DMAOUTEN_W { w: self }
}
#[doc = "Bit 11 - Enable DMA management of data input phase"]
#[inline(always)]
pub fn dmainen(&mut self) -> DMAINEN_W {
DMAINEN_W { w: self }
}
#[doc = "Bit 10 - Error interrupt enable"]
#[inline(always)]
pub fn errie(&mut self) -> ERRIE_W {
ERRIE_W { w: self }
}
#[doc = "Bit 9 - CCF flag interrupt enable"]
#[inline(always)]
pub fn ccfie(&mut self) -> CCFIE_W {
CCFIE_W { w: self }
}
#[doc = "Bit 8 - Error clear"]
#[inline(always)]
pub fn errc(&mut self) -> ERRC_W {
ERRC_W { w: self }
}
#[doc = "Bit 7 - Computation Complete Flag Clear"]
#[inline(always)]
pub fn ccfc(&mut self) -> CCFC_W {
CCFC_W { w: self }
}
#[doc = "Bits 5:6 - AES chaining mode"]
#[inline(always)]
pub fn chmod(&mut self) -> CHMOD_W {
CHMOD_W { w: self }
}
#[doc = "Bits 3:4 - AES operating mode"]
#[inline(always)]
pub fn mode(&mut self) -> MODE_W {
MODE_W { w: self }
}
#[doc = "Bits 1:2 - Data type selection (for data in and data out to/from the cryptographic block)"]
#[inline(always)]
pub fn datatype(&mut self) -> DATATYPE_W {
DATATYPE_W { w: self }
}
#[doc = "Bit 0 - AES enable"]
#[inline(always)]
pub fn en(&mut self) -> EN_W {
EN_W { w: self }
}
}