#[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 = "DAC channel2 DMA underrun interrupt enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum DMAUDRIE2_A {
#[doc = "0: DAC channel X DMA Underrun Interrupt disabled"]
DISABLED = 0,
#[doc = "1: DAC channel X DMA Underrun Interrupt enabled"]
ENABLED = 1,
}
impl From<DMAUDRIE2_A> for bool {
#[inline(always)]
fn from(variant: DMAUDRIE2_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `DMAUDRIE2`"]
pub type DMAUDRIE2_R = crate::R<bool, DMAUDRIE2_A>;
impl DMAUDRIE2_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> DMAUDRIE2_A {
match self.bits {
false => DMAUDRIE2_A::DISABLED,
true => DMAUDRIE2_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == DMAUDRIE2_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == DMAUDRIE2_A::ENABLED
}
}
#[doc = "Write proxy for field `DMAUDRIE2`"]
pub struct DMAUDRIE2_W<'a> {
w: &'a mut W,
}
impl<'a> DMAUDRIE2_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: DMAUDRIE2_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "DAC channel X DMA Underrun Interrupt disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(DMAUDRIE2_A::DISABLED)
}
#[doc = "DAC channel X DMA Underrun Interrupt enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(DMAUDRIE2_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 << 29)) | (((value as u32) & 0x01) << 29);
self.w
}
}
#[doc = "DAC channel2 DMA enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum DMAEN2_A {
#[doc = "0: DAC channel X DMA mode disabled"]
DISABLED = 0,
#[doc = "1: DAC channel X DMA mode enabled"]
ENABLED = 1,
}
impl From<DMAEN2_A> for bool {
#[inline(always)]
fn from(variant: DMAEN2_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `DMAEN2`"]
pub type DMAEN2_R = crate::R<bool, DMAEN2_A>;
impl DMAEN2_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> DMAEN2_A {
match self.bits {
false => DMAEN2_A::DISABLED,
true => DMAEN2_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == DMAEN2_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == DMAEN2_A::ENABLED
}
}
#[doc = "Write proxy for field `DMAEN2`"]
pub struct DMAEN2_W<'a> {
w: &'a mut W,
}
impl<'a> DMAEN2_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: DMAEN2_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "DAC channel X DMA mode disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(DMAEN2_A::DISABLED)
}
#[doc = "DAC channel X DMA mode enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(DMAEN2_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 << 28)) | (((value as u32) & 0x01) << 28);
self.w
}
}
#[doc = "Reader of field `MAMP2`"]
pub type MAMP2_R = crate::R<u8, u8>;
#[doc = "Write proxy for field `MAMP2`"]
pub struct MAMP2_W<'a> {
w: &'a mut W,
}
impl<'a> MAMP2_W<'a> {
#[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 & !(0x0f << 24)) | (((value as u32) & 0x0f) << 24);
self.w
}
}
#[doc = "DAC channel2 noise/triangle wave generation enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
#[repr(u8)]
pub enum WAVE2_A {
#[doc = "0: Wave generation disabled"]
DISABLED = 0,
#[doc = "1: Noise wave generation enabled"]
NOISE = 1,
#[doc = "2: Triangle wave generation enabled"]
TRIANGLE = 2,
}
impl From<WAVE2_A> for u8 {
#[inline(always)]
fn from(variant: WAVE2_A) -> Self {
variant as _
}
}
#[doc = "Reader of field `WAVE2`"]
pub type WAVE2_R = crate::R<u8, WAVE2_A>;
impl WAVE2_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<u8, WAVE2_A> {
use crate::Variant::*;
match self.bits {
0 => Val(WAVE2_A::DISABLED),
1 => Val(WAVE2_A::NOISE),
2 => Val(WAVE2_A::TRIANGLE),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == WAVE2_A::DISABLED
}
#[doc = "Checks if the value of the field is `NOISE`"]
#[inline(always)]
pub fn is_noise(&self) -> bool {
*self == WAVE2_A::NOISE
}
#[doc = "Checks if the value of the field is `TRIANGLE`"]
#[inline(always)]
pub fn is_triangle(&self) -> bool {
*self == WAVE2_A::TRIANGLE
}
}
#[doc = "Write proxy for field `WAVE2`"]
pub struct WAVE2_W<'a> {
w: &'a mut W,
}
impl<'a> WAVE2_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: WAVE2_A) -> &'a mut W {
unsafe { self.bits(variant.into()) }
}
#[doc = "Wave generation disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(WAVE2_A::DISABLED)
}
#[doc = "Noise wave generation enabled"]
#[inline(always)]
pub fn noise(self) -> &'a mut W {
self.variant(WAVE2_A::NOISE)
}
#[doc = "Triangle wave generation enabled"]
#[inline(always)]
pub fn triangle(self) -> &'a mut W {
self.variant(WAVE2_A::TRIANGLE)
}
#[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 << 22)) | (((value as u32) & 0x03) << 22);
self.w
}
}
#[doc = "DAC channel2 trigger selection\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
#[repr(u8)]
pub enum TSEL2_A {
#[doc = "0: Timer 6 TRGO event"]
TIM6_TRGO = 0,
#[doc = "1: Timer 8 TRGO event"]
TIM8_TRGO = 1,
#[doc = "2: Timer 7 TRGO event"]
TIM7_TRGO = 2,
#[doc = "3: Timer 5 TRGO event"]
TIM5_TRGO = 3,
#[doc = "4: Timer 2 TRGO event"]
TIM2_TRGO = 4,
#[doc = "5: Timer 4 TRGO event"]
TIM4_TRGO = 5,
#[doc = "6: EXTI line9"]
EXTI9 = 6,
#[doc = "7: Software trigger"]
SOFTWARE = 7,
}
impl From<TSEL2_A> for u8 {
#[inline(always)]
fn from(variant: TSEL2_A) -> Self {
variant as _
}
}
#[doc = "Reader of field `TSEL2`"]
pub type TSEL2_R = crate::R<u8, TSEL2_A>;
impl TSEL2_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> TSEL2_A {
match self.bits {
0 => TSEL2_A::TIM6_TRGO,
1 => TSEL2_A::TIM8_TRGO,
2 => TSEL2_A::TIM7_TRGO,
3 => TSEL2_A::TIM5_TRGO,
4 => TSEL2_A::TIM2_TRGO,
5 => TSEL2_A::TIM4_TRGO,
6 => TSEL2_A::EXTI9,
7 => TSEL2_A::SOFTWARE,
_ => unreachable!(),
}
}
#[doc = "Checks if the value of the field is `TIM6_TRGO`"]
#[inline(always)]
pub fn is_tim6_trgo(&self) -> bool {
*self == TSEL2_A::TIM6_TRGO
}
#[doc = "Checks if the value of the field is `TIM8_TRGO`"]
#[inline(always)]
pub fn is_tim8_trgo(&self) -> bool {
*self == TSEL2_A::TIM8_TRGO
}
#[doc = "Checks if the value of the field is `TIM7_TRGO`"]
#[inline(always)]
pub fn is_tim7_trgo(&self) -> bool {
*self == TSEL2_A::TIM7_TRGO
}
#[doc = "Checks if the value of the field is `TIM5_TRGO`"]
#[inline(always)]
pub fn is_tim5_trgo(&self) -> bool {
*self == TSEL2_A::TIM5_TRGO
}
#[doc = "Checks if the value of the field is `TIM2_TRGO`"]
#[inline(always)]
pub fn is_tim2_trgo(&self) -> bool {
*self == TSEL2_A::TIM2_TRGO
}
#[doc = "Checks if the value of the field is `TIM4_TRGO`"]
#[inline(always)]
pub fn is_tim4_trgo(&self) -> bool {
*self == TSEL2_A::TIM4_TRGO
}
#[doc = "Checks if the value of the field is `EXTI9`"]
#[inline(always)]
pub fn is_exti9(&self) -> bool {
*self == TSEL2_A::EXTI9
}
#[doc = "Checks if the value of the field is `SOFTWARE`"]
#[inline(always)]
pub fn is_software(&self) -> bool {
*self == TSEL2_A::SOFTWARE
}
}
#[doc = "Write proxy for field `TSEL2`"]
pub struct TSEL2_W<'a> {
w: &'a mut W,
}
impl<'a> TSEL2_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: TSEL2_A) -> &'a mut W {
{
self.bits(variant.into())
}
}
#[doc = "Timer 6 TRGO event"]
#[inline(always)]
pub fn tim6_trgo(self) -> &'a mut W {
self.variant(TSEL2_A::TIM6_TRGO)
}
#[doc = "Timer 8 TRGO event"]
#[inline(always)]
pub fn tim8_trgo(self) -> &'a mut W {
self.variant(TSEL2_A::TIM8_TRGO)
}
#[doc = "Timer 7 TRGO event"]
#[inline(always)]
pub fn tim7_trgo(self) -> &'a mut W {
self.variant(TSEL2_A::TIM7_TRGO)
}
#[doc = "Timer 5 TRGO event"]
#[inline(always)]
pub fn tim5_trgo(self) -> &'a mut W {
self.variant(TSEL2_A::TIM5_TRGO)
}
#[doc = "Timer 2 TRGO event"]
#[inline(always)]
pub fn tim2_trgo(self) -> &'a mut W {
self.variant(TSEL2_A::TIM2_TRGO)
}
#[doc = "Timer 4 TRGO event"]
#[inline(always)]
pub fn tim4_trgo(self) -> &'a mut W {
self.variant(TSEL2_A::TIM4_TRGO)
}
#[doc = "EXTI line9"]
#[inline(always)]
pub fn exti9(self) -> &'a mut W {
self.variant(TSEL2_A::EXTI9)
}
#[doc = "Software trigger"]
#[inline(always)]
pub fn software(self) -> &'a mut W {
self.variant(TSEL2_A::SOFTWARE)
}
#[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 & !(0x07 << 19)) | (((value as u32) & 0x07) << 19);
self.w
}
}
#[doc = "DAC channel2 trigger enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum TEN2_A {
#[doc = "0: DAC channel X trigger disabled"]
DISABLED = 0,
#[doc = "1: DAC channel X trigger enabled"]
ENABLED = 1,
}
impl From<TEN2_A> for bool {
#[inline(always)]
fn from(variant: TEN2_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `TEN2`"]
pub type TEN2_R = crate::R<bool, TEN2_A>;
impl TEN2_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> TEN2_A {
match self.bits {
false => TEN2_A::DISABLED,
true => TEN2_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == TEN2_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == TEN2_A::ENABLED
}
}
#[doc = "Write proxy for field `TEN2`"]
pub struct TEN2_W<'a> {
w: &'a mut W,
}
impl<'a> TEN2_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: TEN2_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "DAC channel X trigger disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(TEN2_A::DISABLED)
}
#[doc = "DAC channel X trigger enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(TEN2_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 << 18)) | (((value as u32) & 0x01) << 18);
self.w
}
}
#[doc = "DAC channel2 output buffer disable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum BOFF2_A {
#[doc = "0: DAC channel X output buffer enabled"]
ENABLED = 0,
#[doc = "1: DAC channel X output buffer disabled"]
DISABLED = 1,
}
impl From<BOFF2_A> for bool {
#[inline(always)]
fn from(variant: BOFF2_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `BOFF2`"]
pub type BOFF2_R = crate::R<bool, BOFF2_A>;
impl BOFF2_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> BOFF2_A {
match self.bits {
false => BOFF2_A::ENABLED,
true => BOFF2_A::DISABLED,
}
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == BOFF2_A::ENABLED
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == BOFF2_A::DISABLED
}
}
#[doc = "Write proxy for field `BOFF2`"]
pub struct BOFF2_W<'a> {
w: &'a mut W,
}
impl<'a> BOFF2_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: BOFF2_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "DAC channel X output buffer enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(BOFF2_A::ENABLED)
}
#[doc = "DAC channel X output buffer disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(BOFF2_A::DISABLED)
}
#[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 = "DAC channel2 enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum EN2_A {
#[doc = "0: DAC channel X disabled"]
DISABLED = 0,
#[doc = "1: DAC channel X enabled"]
ENABLED = 1,
}
impl From<EN2_A> for bool {
#[inline(always)]
fn from(variant: EN2_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `EN2`"]
pub type EN2_R = crate::R<bool, EN2_A>;
impl EN2_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> EN2_A {
match self.bits {
false => EN2_A::DISABLED,
true => EN2_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == EN2_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == EN2_A::ENABLED
}
}
#[doc = "Write proxy for field `EN2`"]
pub struct EN2_W<'a> {
w: &'a mut W,
}
impl<'a> EN2_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: EN2_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "DAC channel X disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(EN2_A::DISABLED)
}
#[doc = "DAC channel X enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(EN2_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 << 16)) | (((value as u32) & 0x01) << 16);
self.w
}
}
#[doc = "DAC channel1 DMA Underrun Interrupt enable"]
pub type DMAUDRIE1_A = DMAUDRIE2_A;
#[doc = "Reader of field `DMAUDRIE1`"]
pub type DMAUDRIE1_R = crate::R<bool, DMAUDRIE2_A>;
#[doc = "Write proxy for field `DMAUDRIE1`"]
pub struct DMAUDRIE1_W<'a> {
w: &'a mut W,
}
impl<'a> DMAUDRIE1_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: DMAUDRIE1_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "DAC channel X DMA Underrun Interrupt disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(DMAUDRIE2_A::DISABLED)
}
#[doc = "DAC channel X DMA Underrun Interrupt enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(DMAUDRIE2_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 << 13)) | (((value as u32) & 0x01) << 13);
self.w
}
}
#[doc = "DAC channel1 DMA enable"]
pub type DMAEN1_A = DMAEN2_A;
#[doc = "Reader of field `DMAEN1`"]
pub type DMAEN1_R = crate::R<bool, DMAEN2_A>;
#[doc = "Write proxy for field `DMAEN1`"]
pub struct DMAEN1_W<'a> {
w: &'a mut W,
}
impl<'a> DMAEN1_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: DMAEN1_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "DAC channel X DMA mode disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(DMAEN2_A::DISABLED)
}
#[doc = "DAC channel X DMA mode enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(DMAEN2_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 = "Reader of field `MAMP1`"]
pub type MAMP1_R = crate::R<u8, u8>;
#[doc = "Write proxy for field `MAMP1`"]
pub struct MAMP1_W<'a> {
w: &'a mut W,
}
impl<'a> MAMP1_W<'a> {
#[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 & !(0x0f << 8)) | (((value as u32) & 0x0f) << 8);
self.w
}
}
#[doc = "DAC channel1 noise/triangle wave generation enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
#[repr(u8)]
pub enum WAVE1_A {
#[doc = "0: Wave generation disabled"]
DISABLED = 0,
#[doc = "1: Noise wave generation enabled"]
NOISE = 1,
#[doc = "2: Triangle wave generation enabled"]
TRIANGLE = 2,
}
impl From<WAVE1_A> for u8 {
#[inline(always)]
fn from(variant: WAVE1_A) -> Self {
variant as _
}
}
#[doc = "Reader of field `WAVE1`"]
pub type WAVE1_R = crate::R<u8, WAVE1_A>;
impl WAVE1_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<u8, WAVE1_A> {
use crate::Variant::*;
match self.bits {
0 => Val(WAVE1_A::DISABLED),
1 => Val(WAVE1_A::NOISE),
2 => Val(WAVE1_A::TRIANGLE),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == WAVE1_A::DISABLED
}
#[doc = "Checks if the value of the field is `NOISE`"]
#[inline(always)]
pub fn is_noise(&self) -> bool {
*self == WAVE1_A::NOISE
}
#[doc = "Checks if the value of the field is `TRIANGLE`"]
#[inline(always)]
pub fn is_triangle(&self) -> bool {
*self == WAVE1_A::TRIANGLE
}
}
#[doc = "Write proxy for field `WAVE1`"]
pub struct WAVE1_W<'a> {
w: &'a mut W,
}
impl<'a> WAVE1_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: WAVE1_A) -> &'a mut W {
unsafe { self.bits(variant.into()) }
}
#[doc = "Wave generation disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(WAVE1_A::DISABLED)
}
#[doc = "Noise wave generation enabled"]
#[inline(always)]
pub fn noise(self) -> &'a mut W {
self.variant(WAVE1_A::NOISE)
}
#[doc = "Triangle wave generation enabled"]
#[inline(always)]
pub fn triangle(self) -> &'a mut W {
self.variant(WAVE1_A::TRIANGLE)
}
#[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 << 6)) | (((value as u32) & 0x03) << 6);
self.w
}
}
#[doc = "DAC channel1 trigger selection\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
#[repr(u8)]
pub enum TSEL1_A {
#[doc = "0: Timer 6 TRGO event"]
TIM6_TRGO = 0,
#[doc = "1: Timer 3 TRGO event"]
TIM3_TRGO = 1,
#[doc = "2: Timer 7 TRGO event"]
TIM7_TRGO = 2,
#[doc = "3: Timer 15 TRGO event"]
TIM15_TRGO = 3,
#[doc = "4: Timer 2 TRGO event"]
TIM2_TRGO = 4,
#[doc = "6: EXTI line9"]
EXTI9 = 6,
#[doc = "7: Software trigger"]
SOFTWARE = 7,
}
impl From<TSEL1_A> for u8 {
#[inline(always)]
fn from(variant: TSEL1_A) -> Self {
variant as _
}
}
#[doc = "Reader of field `TSEL1`"]
pub type TSEL1_R = crate::R<u8, TSEL1_A>;
impl TSEL1_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<u8, TSEL1_A> {
use crate::Variant::*;
match self.bits {
0 => Val(TSEL1_A::TIM6_TRGO),
1 => Val(TSEL1_A::TIM3_TRGO),
2 => Val(TSEL1_A::TIM7_TRGO),
3 => Val(TSEL1_A::TIM15_TRGO),
4 => Val(TSEL1_A::TIM2_TRGO),
6 => Val(TSEL1_A::EXTI9),
7 => Val(TSEL1_A::SOFTWARE),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `TIM6_TRGO`"]
#[inline(always)]
pub fn is_tim6_trgo(&self) -> bool {
*self == TSEL1_A::TIM6_TRGO
}
#[doc = "Checks if the value of the field is `TIM3_TRGO`"]
#[inline(always)]
pub fn is_tim3_trgo(&self) -> bool {
*self == TSEL1_A::TIM3_TRGO
}
#[doc = "Checks if the value of the field is `TIM7_TRGO`"]
#[inline(always)]
pub fn is_tim7_trgo(&self) -> bool {
*self == TSEL1_A::TIM7_TRGO
}
#[doc = "Checks if the value of the field is `TIM15_TRGO`"]
#[inline(always)]
pub fn is_tim15_trgo(&self) -> bool {
*self == TSEL1_A::TIM15_TRGO
}
#[doc = "Checks if the value of the field is `TIM2_TRGO`"]
#[inline(always)]
pub fn is_tim2_trgo(&self) -> bool {
*self == TSEL1_A::TIM2_TRGO
}
#[doc = "Checks if the value of the field is `EXTI9`"]
#[inline(always)]
pub fn is_exti9(&self) -> bool {
*self == TSEL1_A::EXTI9
}
#[doc = "Checks if the value of the field is `SOFTWARE`"]
#[inline(always)]
pub fn is_software(&self) -> bool {
*self == TSEL1_A::SOFTWARE
}
}
#[doc = "Write proxy for field `TSEL1`"]
pub struct TSEL1_W<'a> {
w: &'a mut W,
}
impl<'a> TSEL1_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: TSEL1_A) -> &'a mut W {
unsafe { self.bits(variant.into()) }
}
#[doc = "Timer 6 TRGO event"]
#[inline(always)]
pub fn tim6_trgo(self) -> &'a mut W {
self.variant(TSEL1_A::TIM6_TRGO)
}
#[doc = "Timer 3 TRGO event"]
#[inline(always)]
pub fn tim3_trgo(self) -> &'a mut W {
self.variant(TSEL1_A::TIM3_TRGO)
}
#[doc = "Timer 7 TRGO event"]
#[inline(always)]
pub fn tim7_trgo(self) -> &'a mut W {
self.variant(TSEL1_A::TIM7_TRGO)
}
#[doc = "Timer 15 TRGO event"]
#[inline(always)]
pub fn tim15_trgo(self) -> &'a mut W {
self.variant(TSEL1_A::TIM15_TRGO)
}
#[doc = "Timer 2 TRGO event"]
#[inline(always)]
pub fn tim2_trgo(self) -> &'a mut W {
self.variant(TSEL1_A::TIM2_TRGO)
}
#[doc = "EXTI line9"]
#[inline(always)]
pub fn exti9(self) -> &'a mut W {
self.variant(TSEL1_A::EXTI9)
}
#[doc = "Software trigger"]
#[inline(always)]
pub fn software(self) -> &'a mut W {
self.variant(TSEL1_A::SOFTWARE)
}
#[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 << 3)) | (((value as u32) & 0x07) << 3);
self.w
}
}
#[doc = "DAC channel1 trigger enable"]
pub type TEN1_A = TEN2_A;
#[doc = "Reader of field `TEN1`"]
pub type TEN1_R = crate::R<bool, TEN2_A>;
#[doc = "Write proxy for field `TEN1`"]
pub struct TEN1_W<'a> {
w: &'a mut W,
}
impl<'a> TEN1_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: TEN1_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "DAC channel X trigger disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(TEN2_A::DISABLED)
}
#[doc = "DAC channel X trigger enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(TEN2_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 << 2)) | (((value as u32) & 0x01) << 2);
self.w
}
}
#[doc = "DAC channel1 output buffer disable"]
pub type BOFF1_A = BOFF2_A;
#[doc = "Reader of field `BOFF1`"]
pub type BOFF1_R = crate::R<bool, BOFF2_A>;
#[doc = "Write proxy for field `BOFF1`"]
pub struct BOFF1_W<'a> {
w: &'a mut W,
}
impl<'a> BOFF1_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: BOFF1_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "DAC channel X output buffer enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(BOFF2_A::ENABLED)
}
#[doc = "DAC channel X output buffer disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(BOFF2_A::DISABLED)
}
#[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 = "DAC channel1 enable"]
pub type EN1_A = EN2_A;
#[doc = "Reader of field `EN1`"]
pub type EN1_R = crate::R<bool, EN2_A>;
#[doc = "Write proxy for field `EN1`"]
pub struct EN1_W<'a> {
w: &'a mut W,
}
impl<'a> EN1_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: EN1_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "DAC channel X disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(EN2_A::DISABLED)
}
#[doc = "DAC channel X enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(EN2_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 29 - DAC channel2 DMA underrun interrupt enable"]
#[inline(always)]
pub fn dmaudrie2(&self) -> DMAUDRIE2_R {
DMAUDRIE2_R::new(((self.bits >> 29) & 0x01) != 0)
}
#[doc = "Bit 28 - DAC channel2 DMA enable"]
#[inline(always)]
pub fn dmaen2(&self) -> DMAEN2_R {
DMAEN2_R::new(((self.bits >> 28) & 0x01) != 0)
}
#[doc = "Bits 24:27 - DAC channel2 mask/amplitude selector"]
#[inline(always)]
pub fn mamp2(&self) -> MAMP2_R {
MAMP2_R::new(((self.bits >> 24) & 0x0f) as u8)
}
#[doc = "Bits 22:23 - DAC channel2 noise/triangle wave generation enable"]
#[inline(always)]
pub fn wave2(&self) -> WAVE2_R {
WAVE2_R::new(((self.bits >> 22) & 0x03) as u8)
}
#[doc = "Bits 19:21 - DAC channel2 trigger selection"]
#[inline(always)]
pub fn tsel2(&self) -> TSEL2_R {
TSEL2_R::new(((self.bits >> 19) & 0x07) as u8)
}
#[doc = "Bit 18 - DAC channel2 trigger enable"]
#[inline(always)]
pub fn ten2(&self) -> TEN2_R {
TEN2_R::new(((self.bits >> 18) & 0x01) != 0)
}
#[doc = "Bit 17 - DAC channel2 output buffer disable"]
#[inline(always)]
pub fn boff2(&self) -> BOFF2_R {
BOFF2_R::new(((self.bits >> 17) & 0x01) != 0)
}
#[doc = "Bit 16 - DAC channel2 enable"]
#[inline(always)]
pub fn en2(&self) -> EN2_R {
EN2_R::new(((self.bits >> 16) & 0x01) != 0)
}
#[doc = "Bit 13 - DAC channel1 DMA Underrun Interrupt enable"]
#[inline(always)]
pub fn dmaudrie1(&self) -> DMAUDRIE1_R {
DMAUDRIE1_R::new(((self.bits >> 13) & 0x01) != 0)
}
#[doc = "Bit 12 - DAC channel1 DMA enable"]
#[inline(always)]
pub fn dmaen1(&self) -> DMAEN1_R {
DMAEN1_R::new(((self.bits >> 12) & 0x01) != 0)
}
#[doc = "Bits 8:11 - DAC channel1 mask/amplitude selector"]
#[inline(always)]
pub fn mamp1(&self) -> MAMP1_R {
MAMP1_R::new(((self.bits >> 8) & 0x0f) as u8)
}
#[doc = "Bits 6:7 - DAC channel1 noise/triangle wave generation enable"]
#[inline(always)]
pub fn wave1(&self) -> WAVE1_R {
WAVE1_R::new(((self.bits >> 6) & 0x03) as u8)
}
#[doc = "Bits 3:5 - DAC channel1 trigger selection"]
#[inline(always)]
pub fn tsel1(&self) -> TSEL1_R {
TSEL1_R::new(((self.bits >> 3) & 0x07) as u8)
}
#[doc = "Bit 2 - DAC channel1 trigger enable"]
#[inline(always)]
pub fn ten1(&self) -> TEN1_R {
TEN1_R::new(((self.bits >> 2) & 0x01) != 0)
}
#[doc = "Bit 1 - DAC channel1 output buffer disable"]
#[inline(always)]
pub fn boff1(&self) -> BOFF1_R {
BOFF1_R::new(((self.bits >> 1) & 0x01) != 0)
}
#[doc = "Bit 0 - DAC channel1 enable"]
#[inline(always)]
pub fn en1(&self) -> EN1_R {
EN1_R::new((self.bits & 0x01) != 0)
}
}
impl W {
#[doc = "Bit 29 - DAC channel2 DMA underrun interrupt enable"]
#[inline(always)]
pub fn dmaudrie2(&mut self) -> DMAUDRIE2_W {
DMAUDRIE2_W { w: self }
}
#[doc = "Bit 28 - DAC channel2 DMA enable"]
#[inline(always)]
pub fn dmaen2(&mut self) -> DMAEN2_W {
DMAEN2_W { w: self }
}
#[doc = "Bits 24:27 - DAC channel2 mask/amplitude selector"]
#[inline(always)]
pub fn mamp2(&mut self) -> MAMP2_W {
MAMP2_W { w: self }
}
#[doc = "Bits 22:23 - DAC channel2 noise/triangle wave generation enable"]
#[inline(always)]
pub fn wave2(&mut self) -> WAVE2_W {
WAVE2_W { w: self }
}
#[doc = "Bits 19:21 - DAC channel2 trigger selection"]
#[inline(always)]
pub fn tsel2(&mut self) -> TSEL2_W {
TSEL2_W { w: self }
}
#[doc = "Bit 18 - DAC channel2 trigger enable"]
#[inline(always)]
pub fn ten2(&mut self) -> TEN2_W {
TEN2_W { w: self }
}
#[doc = "Bit 17 - DAC channel2 output buffer disable"]
#[inline(always)]
pub fn boff2(&mut self) -> BOFF2_W {
BOFF2_W { w: self }
}
#[doc = "Bit 16 - DAC channel2 enable"]
#[inline(always)]
pub fn en2(&mut self) -> EN2_W {
EN2_W { w: self }
}
#[doc = "Bit 13 - DAC channel1 DMA Underrun Interrupt enable"]
#[inline(always)]
pub fn dmaudrie1(&mut self) -> DMAUDRIE1_W {
DMAUDRIE1_W { w: self }
}
#[doc = "Bit 12 - DAC channel1 DMA enable"]
#[inline(always)]
pub fn dmaen1(&mut self) -> DMAEN1_W {
DMAEN1_W { w: self }
}
#[doc = "Bits 8:11 - DAC channel1 mask/amplitude selector"]
#[inline(always)]
pub fn mamp1(&mut self) -> MAMP1_W {
MAMP1_W { w: self }
}
#[doc = "Bits 6:7 - DAC channel1 noise/triangle wave generation enable"]
#[inline(always)]
pub fn wave1(&mut self) -> WAVE1_W {
WAVE1_W { w: self }
}
#[doc = "Bits 3:5 - DAC channel1 trigger selection"]
#[inline(always)]
pub fn tsel1(&mut self) -> TSEL1_W {
TSEL1_W { w: self }
}
#[doc = "Bit 2 - DAC channel1 trigger enable"]
#[inline(always)]
pub fn ten1(&mut self) -> TEN1_W {
TEN1_W { w: self }
}
#[doc = "Bit 1 - DAC channel1 output buffer disable"]
#[inline(always)]
pub fn boff1(&mut self) -> BOFF1_W {
BOFF1_W { w: self }
}
#[doc = "Bit 0 - DAC channel1 enable"]
#[inline(always)]
pub fn en1(&mut self) -> EN1_W {
EN1_W { w: self }
}
}