#[doc = "Reader of register CTL1"]
pub type R = crate::R<u32, super::CTL1>;
#[doc = "Writer for register CTL1"]
pub type W = crate::W<u32, super::CTL1>;
#[doc = "Register CTL1 `reset()`'s with value 0"]
impl crate::ResetValue for super::CTL1 {
type Type = u32;
#[inline(always)]
fn reset_value() -> Self::Type {
0
}
}
#[doc = "Reader of field `ADDR`"]
pub type ADDR_R = crate::R<u8, u8>;
#[doc = "Write proxy for field `ADDR`"]
pub struct ADDR_W<'a> {
w: &'a mut W,
}
impl<'a> ADDR_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 & !(0xff << 24)) | (((value as u32) & 0xff) << 24);
self.w
}
}
#[doc = "Receiver timeout enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum RTEN_A {
#[doc = "0: Receiver timeout feature disabled"]
DISABLED = 0,
#[doc = "1: Receiver timeout feature enabled"]
ENABLED = 1,
}
impl From<RTEN_A> for bool {
#[inline(always)]
fn from(variant: RTEN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `RTEN`"]
pub type RTEN_R = crate::R<bool, RTEN_A>;
impl RTEN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> RTEN_A {
match self.bits {
false => RTEN_A::DISABLED,
true => RTEN_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == RTEN_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == RTEN_A::ENABLED
}
}
#[doc = "Write proxy for field `RTEN`"]
pub struct RTEN_W<'a> {
w: &'a mut W,
}
impl<'a> RTEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: RTEN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Receiver timeout feature disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(RTEN_A::DISABLED)
}
#[doc = "Receiver timeout feature enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(RTEN_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 << 23)) | (((value as u32) & 0x01) << 23);
self.w
}
}
#[doc = "Auto baud rate mode\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
#[repr(u8)]
pub enum ABDM_A {
#[doc = "0: Measurement of the start bit is used to detect the baud rate"]
START = 0,
#[doc = "1: Falling edge to falling edge measurement"]
EDGE = 1,
}
impl From<ABDM_A> for u8 {
#[inline(always)]
fn from(variant: ABDM_A) -> Self {
variant as _
}
}
#[doc = "Reader of field `ABDM`"]
pub type ABDM_R = crate::R<u8, ABDM_A>;
impl ABDM_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> crate::Variant<u8, ABDM_A> {
use crate::Variant::*;
match self.bits {
0 => Val(ABDM_A::START),
1 => Val(ABDM_A::EDGE),
i => Res(i),
}
}
#[doc = "Checks if the value of the field is `START`"]
#[inline(always)]
pub fn is_start(&self) -> bool {
*self == ABDM_A::START
}
#[doc = "Checks if the value of the field is `EDGE`"]
#[inline(always)]
pub fn is_edge(&self) -> bool {
*self == ABDM_A::EDGE
}
}
#[doc = "Write proxy for field `ABDM`"]
pub struct ABDM_W<'a> {
w: &'a mut W,
}
impl<'a> ABDM_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ABDM_A) -> &'a mut W {
unsafe { self.bits(variant.into()) }
}
#[doc = "Measurement of the start bit is used to detect the baud rate"]
#[inline(always)]
pub fn start(self) -> &'a mut W {
self.variant(ABDM_A::START)
}
#[doc = "Falling edge to falling edge measurement"]
#[inline(always)]
pub fn edge(self) -> &'a mut W {
self.variant(ABDM_A::EDGE)
}
#[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 << 21)) | (((value as u32) & 0x03) << 21);
self.w
}
}
#[doc = "Auto baud rate enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum ABDEN_A {
#[doc = "0: Auto baud rate detection is disabled"]
DISABLED = 0,
#[doc = "1: Auto baud rate detection is enabled"]
ENABLED = 1,
}
impl From<ABDEN_A> for bool {
#[inline(always)]
fn from(variant: ABDEN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `ABDEN`"]
pub type ABDEN_R = crate::R<bool, ABDEN_A>;
impl ABDEN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> ABDEN_A {
match self.bits {
false => ABDEN_A::DISABLED,
true => ABDEN_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == ABDEN_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == ABDEN_A::ENABLED
}
}
#[doc = "Write proxy for field `ABDEN`"]
pub struct ABDEN_W<'a> {
w: &'a mut W,
}
impl<'a> ABDEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ABDEN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Auto baud rate detection is disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(ABDEN_A::DISABLED)
}
#[doc = "Auto baud rate detection is enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(ABDEN_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 << 20)) | (((value as u32) & 0x01) << 20);
self.w
}
}
#[doc = "Most significant bit first\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum MSBF_A {
#[doc = "0: Data is transmitted/received with data bit 0 first, following the start bit"]
LSB = 0,
#[doc = "1: Data is transmitted/received with MSB (bit 7/8/9) first, following the start bit"]
MSB = 1,
}
impl From<MSBF_A> for bool {
#[inline(always)]
fn from(variant: MSBF_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `MSBF`"]
pub type MSBF_R = crate::R<bool, MSBF_A>;
impl MSBF_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> MSBF_A {
match self.bits {
false => MSBF_A::LSB,
true => MSBF_A::MSB,
}
}
#[doc = "Checks if the value of the field is `LSB`"]
#[inline(always)]
pub fn is_lsb(&self) -> bool {
*self == MSBF_A::LSB
}
#[doc = "Checks if the value of the field is `MSB`"]
#[inline(always)]
pub fn is_msb(&self) -> bool {
*self == MSBF_A::MSB
}
}
#[doc = "Write proxy for field `MSBF`"]
pub struct MSBF_W<'a> {
w: &'a mut W,
}
impl<'a> MSBF_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: MSBF_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Data is transmitted/received with data bit 0 first, following the start bit"]
#[inline(always)]
pub fn lsb(self) -> &'a mut W {
self.variant(MSBF_A::LSB)
}
#[doc = "Data is transmitted/received with MSB (bit 7/8/9) first, following the start bit"]
#[inline(always)]
pub fn msb(self) -> &'a mut W {
self.variant(MSBF_A::MSB)
}
#[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 = "Data bit level inversion\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum DINV_A {
#[doc = "0: Logical data from the data register are send/received in positive/direct logic"]
POSITIVE = 0,
#[doc = "1: Logical data from the data register are send/received in negative/inverse logic"]
NEGATIVE = 1,
}
impl From<DINV_A> for bool {
#[inline(always)]
fn from(variant: DINV_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `DINV`"]
pub type DINV_R = crate::R<bool, DINV_A>;
impl DINV_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> DINV_A {
match self.bits {
false => DINV_A::POSITIVE,
true => DINV_A::NEGATIVE,
}
}
#[doc = "Checks if the value of the field is `POSITIVE`"]
#[inline(always)]
pub fn is_positive(&self) -> bool {
*self == DINV_A::POSITIVE
}
#[doc = "Checks if the value of the field is `NEGATIVE`"]
#[inline(always)]
pub fn is_negative(&self) -> bool {
*self == DINV_A::NEGATIVE
}
}
#[doc = "Write proxy for field `DINV`"]
pub struct DINV_W<'a> {
w: &'a mut W,
}
impl<'a> DINV_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: DINV_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Logical data from the data register are send/received in positive/direct logic"]
#[inline(always)]
pub fn positive(self) -> &'a mut W {
self.variant(DINV_A::POSITIVE)
}
#[doc = "Logical data from the data register are send/received in negative/inverse logic"]
#[inline(always)]
pub fn negative(self) -> &'a mut W {
self.variant(DINV_A::NEGATIVE)
}
#[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 = "TX pin level inversion\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum TINV_A {
#[doc = "0: TX pin signal works using the standard logic levels"]
STANDARD = 0,
#[doc = "1: TX pin signal values are inverted"]
INVERTED = 1,
}
impl From<TINV_A> for bool {
#[inline(always)]
fn from(variant: TINV_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `TINV`"]
pub type TINV_R = crate::R<bool, TINV_A>;
impl TINV_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> TINV_A {
match self.bits {
false => TINV_A::STANDARD,
true => TINV_A::INVERTED,
}
}
#[doc = "Checks if the value of the field is `STANDARD`"]
#[inline(always)]
pub fn is_standard(&self) -> bool {
*self == TINV_A::STANDARD
}
#[doc = "Checks if the value of the field is `INVERTED`"]
#[inline(always)]
pub fn is_inverted(&self) -> bool {
*self == TINV_A::INVERTED
}
}
#[doc = "Write proxy for field `TINV`"]
pub struct TINV_W<'a> {
w: &'a mut W,
}
impl<'a> TINV_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: TINV_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "TX pin signal works using the standard logic levels"]
#[inline(always)]
pub fn standard(self) -> &'a mut W {
self.variant(TINV_A::STANDARD)
}
#[doc = "TX pin signal values are inverted"]
#[inline(always)]
pub fn inverted(self) -> &'a mut W {
self.variant(TINV_A::INVERTED)
}
#[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 = "RX pin level inversion\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum RINV_A {
#[doc = "0: RX pin signal works using the standard logic levels"]
STANDARD = 0,
#[doc = "1: RX pin signal values are inverted"]
INVERTED = 1,
}
impl From<RINV_A> for bool {
#[inline(always)]
fn from(variant: RINV_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `RINV`"]
pub type RINV_R = crate::R<bool, RINV_A>;
impl RINV_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> RINV_A {
match self.bits {
false => RINV_A::STANDARD,
true => RINV_A::INVERTED,
}
}
#[doc = "Checks if the value of the field is `STANDARD`"]
#[inline(always)]
pub fn is_standard(&self) -> bool {
*self == RINV_A::STANDARD
}
#[doc = "Checks if the value of the field is `INVERTED`"]
#[inline(always)]
pub fn is_inverted(&self) -> bool {
*self == RINV_A::INVERTED
}
}
#[doc = "Write proxy for field `RINV`"]
pub struct RINV_W<'a> {
w: &'a mut W,
}
impl<'a> RINV_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: RINV_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "RX pin signal works using the standard logic levels"]
#[inline(always)]
pub fn standard(self) -> &'a mut W {
self.variant(RINV_A::STANDARD)
}
#[doc = "RX pin signal values are inverted"]
#[inline(always)]
pub fn inverted(self) -> &'a mut W {
self.variant(RINV_A::INVERTED)
}
#[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 = "Swap TX/RX pins\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum STRP_A {
#[doc = "0: TX/RX pins are used as defined in standard pinout"]
STANDARD = 0,
#[doc = "1: The TX and RX pins functions are swapped"]
SWAPPED = 1,
}
impl From<STRP_A> for bool {
#[inline(always)]
fn from(variant: STRP_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `STRP`"]
pub type STRP_R = crate::R<bool, STRP_A>;
impl STRP_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> STRP_A {
match self.bits {
false => STRP_A::STANDARD,
true => STRP_A::SWAPPED,
}
}
#[doc = "Checks if the value of the field is `STANDARD`"]
#[inline(always)]
pub fn is_standard(&self) -> bool {
*self == STRP_A::STANDARD
}
#[doc = "Checks if the value of the field is `SWAPPED`"]
#[inline(always)]
pub fn is_swapped(&self) -> bool {
*self == STRP_A::SWAPPED
}
}
#[doc = "Write proxy for field `STRP`"]
pub struct STRP_W<'a> {
w: &'a mut W,
}
impl<'a> STRP_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: STRP_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "TX/RX pins are used as defined in standard pinout"]
#[inline(always)]
pub fn standard(self) -> &'a mut W {
self.variant(STRP_A::STANDARD)
}
#[doc = "The TX and RX pins functions are swapped"]
#[inline(always)]
pub fn swapped(self) -> &'a mut W {
self.variant(STRP_A::SWAPPED)
}
#[doc = r"Sets the field bit"]
#[inline(always)]
pub fn set_bit(self) -> &'a mut W {
self.bit(true)
}
#[doc = r"Clears the field bit"]
#[inline(always)]
pub fn clear_bit(self) -> &'a mut W {
self.bit(false)
}
#[doc = r"Writes raw bits to the field"]
#[inline(always)]
pub fn bit(self, value: bool) -> &'a mut W {
self.w.bits = (self.w.bits & !(0x01 << 15)) | (((value as u32) & 0x01) << 15);
self.w
}
}
#[doc = "LIN mode enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum LMEN_A {
#[doc = "0: LIN mode disabled"]
DISABLED = 0,
#[doc = "1: LIN mode enabled"]
ENABLED = 1,
}
impl From<LMEN_A> for bool {
#[inline(always)]
fn from(variant: LMEN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `LMEN`"]
pub type LMEN_R = crate::R<bool, LMEN_A>;
impl LMEN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> LMEN_A {
match self.bits {
false => LMEN_A::DISABLED,
true => LMEN_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == LMEN_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == LMEN_A::ENABLED
}
}
#[doc = "Write proxy for field `LMEN`"]
pub struct LMEN_W<'a> {
w: &'a mut W,
}
impl<'a> LMEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: LMEN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "LIN mode disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(LMEN_A::DISABLED)
}
#[doc = "LIN mode enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(LMEN_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 << 14)) | (((value as u32) & 0x01) << 14);
self.w
}
}
#[doc = "STOP bits length\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
#[repr(u8)]
pub enum STB_A {
#[doc = "0: 1 stop bit"]
STOP1 = 0,
#[doc = "1: 0.5 stop bit"]
STOP0P5 = 1,
#[doc = "2: 2 stop bit"]
STOP2 = 2,
#[doc = "3: 1.5 stop bit"]
STOP1P5 = 3,
}
impl From<STB_A> for u8 {
#[inline(always)]
fn from(variant: STB_A) -> Self {
variant as _
}
}
#[doc = "Reader of field `STB`"]
pub type STB_R = crate::R<u8, STB_A>;
impl STB_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> STB_A {
match self.bits {
0 => STB_A::STOP1,
1 => STB_A::STOP0P5,
2 => STB_A::STOP2,
3 => STB_A::STOP1P5,
_ => unreachable!(),
}
}
#[doc = "Checks if the value of the field is `STOP1`"]
#[inline(always)]
pub fn is_stop1(&self) -> bool {
*self == STB_A::STOP1
}
#[doc = "Checks if the value of the field is `STOP0P5`"]
#[inline(always)]
pub fn is_stop0p5(&self) -> bool {
*self == STB_A::STOP0P5
}
#[doc = "Checks if the value of the field is `STOP2`"]
#[inline(always)]
pub fn is_stop2(&self) -> bool {
*self == STB_A::STOP2
}
#[doc = "Checks if the value of the field is `STOP1P5`"]
#[inline(always)]
pub fn is_stop1p5(&self) -> bool {
*self == STB_A::STOP1P5
}
}
#[doc = "Write proxy for field `STB`"]
pub struct STB_W<'a> {
w: &'a mut W,
}
impl<'a> STB_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: STB_A) -> &'a mut W {
{
self.bits(variant.into())
}
}
#[doc = "1 stop bit"]
#[inline(always)]
pub fn stop1(self) -> &'a mut W {
self.variant(STB_A::STOP1)
}
#[doc = "0.5 stop bit"]
#[inline(always)]
pub fn stop0p5(self) -> &'a mut W {
self.variant(STB_A::STOP0P5)
}
#[doc = "2 stop bit"]
#[inline(always)]
pub fn stop2(self) -> &'a mut W {
self.variant(STB_A::STOP2)
}
#[doc = "1.5 stop bit"]
#[inline(always)]
pub fn stop1p5(self) -> &'a mut W {
self.variant(STB_A::STOP1P5)
}
#[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 << 12)) | (((value as u32) & 0x03) << 12);
self.w
}
}
#[doc = "CK pin enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum CKEN_A {
#[doc = "0: CK pin disabled"]
DISABLED = 0,
#[doc = "1: CK pin enabled"]
ENABLED = 1,
}
impl From<CKEN_A> for bool {
#[inline(always)]
fn from(variant: CKEN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `CKEN`"]
pub type CKEN_R = crate::R<bool, CKEN_A>;
impl CKEN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> CKEN_A {
match self.bits {
false => CKEN_A::DISABLED,
true => CKEN_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == CKEN_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == CKEN_A::ENABLED
}
}
#[doc = "Write proxy for field `CKEN`"]
pub struct CKEN_W<'a> {
w: &'a mut W,
}
impl<'a> CKEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: CKEN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "CK pin disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(CKEN_A::DISABLED)
}
#[doc = "CK pin enabled"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(CKEN_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 = "Clock polarity\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum CPL_A {
#[doc = "0: Steady low value on CK pin outside tranmission window"]
NOTINVERTED = 0,
#[doc = "1: Steady high value on CK pin outside tranmission window"]
INVERTED = 1,
}
impl From<CPL_A> for bool {
#[inline(always)]
fn from(variant: CPL_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `CPL`"]
pub type CPL_R = crate::R<bool, CPL_A>;
impl CPL_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> CPL_A {
match self.bits {
false => CPL_A::NOTINVERTED,
true => CPL_A::INVERTED,
}
}
#[doc = "Checks if the value of the field is `NOTINVERTED`"]
#[inline(always)]
pub fn is_not_inverted(&self) -> bool {
*self == CPL_A::NOTINVERTED
}
#[doc = "Checks if the value of the field is `INVERTED`"]
#[inline(always)]
pub fn is_inverted(&self) -> bool {
*self == CPL_A::INVERTED
}
}
#[doc = "Write proxy for field `CPL`"]
pub struct CPL_W<'a> {
w: &'a mut W,
}
impl<'a> CPL_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: CPL_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Steady low value on CK pin outside tranmission window"]
#[inline(always)]
pub fn not_inverted(self) -> &'a mut W {
self.variant(CPL_A::NOTINVERTED)
}
#[doc = "Steady high value on CK pin outside tranmission window"]
#[inline(always)]
pub fn inverted(self) -> &'a mut W {
self.variant(CPL_A::INVERTED)
}
#[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 = "Clock phase\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum CPH_A {
#[doc = "0: The first clock transition is the first data capture edge"]
FIRST = 0,
#[doc = "1: The second clock transition is the first data capture edge"]
SECOND = 1,
}
impl From<CPH_A> for bool {
#[inline(always)]
fn from(variant: CPH_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `CPH`"]
pub type CPH_R = crate::R<bool, CPH_A>;
impl CPH_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> CPH_A {
match self.bits {
false => CPH_A::FIRST,
true => CPH_A::SECOND,
}
}
#[doc = "Checks if the value of the field is `FIRST`"]
#[inline(always)]
pub fn is_first(&self) -> bool {
*self == CPH_A::FIRST
}
#[doc = "Checks if the value of the field is `SECOND`"]
#[inline(always)]
pub fn is_second(&self) -> bool {
*self == CPH_A::SECOND
}
}
#[doc = "Write proxy for field `CPH`"]
pub struct CPH_W<'a> {
w: &'a mut W,
}
impl<'a> CPH_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: CPH_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "The first clock transition is the first data capture edge"]
#[inline(always)]
pub fn first(self) -> &'a mut W {
self.variant(CPH_A::FIRST)
}
#[doc = "The second clock transition is the first data capture edge"]
#[inline(always)]
pub fn second(self) -> &'a mut W {
self.variant(CPH_A::SECOND)
}
#[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 = "CK length\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum CLEN_A {
#[doc = "0: The clock pulse of the last data bit is not output to the CK pin"]
NOTOUTPUT = 0,
#[doc = "1: The clock pulse of the last data bit is output to the CK pin"]
OUTPUT = 1,
}
impl From<CLEN_A> for bool {
#[inline(always)]
fn from(variant: CLEN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `CLEN`"]
pub type CLEN_R = crate::R<bool, CLEN_A>;
impl CLEN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> CLEN_A {
match self.bits {
false => CLEN_A::NOTOUTPUT,
true => CLEN_A::OUTPUT,
}
}
#[doc = "Checks if the value of the field is `NOTOUTPUT`"]
#[inline(always)]
pub fn is_not_output(&self) -> bool {
*self == CLEN_A::NOTOUTPUT
}
#[doc = "Checks if the value of the field is `OUTPUT`"]
#[inline(always)]
pub fn is_output(&self) -> bool {
*self == CLEN_A::OUTPUT
}
}
#[doc = "Write proxy for field `CLEN`"]
pub struct CLEN_W<'a> {
w: &'a mut W,
}
impl<'a> CLEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: CLEN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "The clock pulse of the last data bit is not output to the CK pin"]
#[inline(always)]
pub fn not_output(self) -> &'a mut W {
self.variant(CLEN_A::NOTOUTPUT)
}
#[doc = "The clock pulse of the last data bit is output to the CK pin"]
#[inline(always)]
pub fn output(self) -> &'a mut W {
self.variant(CLEN_A::OUTPUT)
}
#[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 = "LIN break detection interrupt enable\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum LBDIE_A {
#[doc = "0: Interrupt is disabled"]
DISABLED = 0,
#[doc = "1: An interrupt is generated whenever LBDF=1 in the STAT register"]
ENABLED = 1,
}
impl From<LBDIE_A> for bool {
#[inline(always)]
fn from(variant: LBDIE_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `LBDIE`"]
pub type LBDIE_R = crate::R<bool, LBDIE_A>;
impl LBDIE_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> LBDIE_A {
match self.bits {
false => LBDIE_A::DISABLED,
true => LBDIE_A::ENABLED,
}
}
#[doc = "Checks if the value of the field is `DISABLED`"]
#[inline(always)]
pub fn is_disabled(&self) -> bool {
*self == LBDIE_A::DISABLED
}
#[doc = "Checks if the value of the field is `ENABLED`"]
#[inline(always)]
pub fn is_enabled(&self) -> bool {
*self == LBDIE_A::ENABLED
}
}
#[doc = "Write proxy for field `LBDIE`"]
pub struct LBDIE_W<'a> {
w: &'a mut W,
}
impl<'a> LBDIE_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: LBDIE_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "Interrupt is disabled"]
#[inline(always)]
pub fn disabled(self) -> &'a mut W {
self.variant(LBDIE_A::DISABLED)
}
#[doc = "An interrupt is generated whenever LBDF=1 in the STAT register"]
#[inline(always)]
pub fn enabled(self) -> &'a mut W {
self.variant(LBDIE_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 << 6)) | (((value as u32) & 0x01) << 6);
self.w
}
}
#[doc = "LIN break frame length\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum LBLEN_A {
#[doc = "0: 10-bit break detection"]
BIT10 = 0,
#[doc = "1: 11-bit break detection"]
BIT11 = 1,
}
impl From<LBLEN_A> for bool {
#[inline(always)]
fn from(variant: LBLEN_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `LBLEN`"]
pub type LBLEN_R = crate::R<bool, LBLEN_A>;
impl LBLEN_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> LBLEN_A {
match self.bits {
false => LBLEN_A::BIT10,
true => LBLEN_A::BIT11,
}
}
#[doc = "Checks if the value of the field is `BIT10`"]
#[inline(always)]
pub fn is_bit10(&self) -> bool {
*self == LBLEN_A::BIT10
}
#[doc = "Checks if the value of the field is `BIT11`"]
#[inline(always)]
pub fn is_bit11(&self) -> bool {
*self == LBLEN_A::BIT11
}
}
#[doc = "Write proxy for field `LBLEN`"]
pub struct LBLEN_W<'a> {
w: &'a mut W,
}
impl<'a> LBLEN_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: LBLEN_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "10-bit break detection"]
#[inline(always)]
pub fn bit10(self) -> &'a mut W {
self.variant(LBLEN_A::BIT10)
}
#[doc = "11-bit break detection"]
#[inline(always)]
pub fn bit11(self) -> &'a mut W {
self.variant(LBLEN_A::BIT11)
}
#[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 = "Address detection mode\n\nValue on reset: 0"]
#[derive(Clone, Copy, Debug, PartialEq)]
pub enum ADDM_A {
#[doc = "0: 4-bit address detection"]
BIT4 = 0,
#[doc = "1: Full-bit address detection"]
FULL = 1,
}
impl From<ADDM_A> for bool {
#[inline(always)]
fn from(variant: ADDM_A) -> Self {
variant as u8 != 0
}
}
#[doc = "Reader of field `ADDM`"]
pub type ADDM_R = crate::R<bool, ADDM_A>;
impl ADDM_R {
#[doc = r"Get enumerated values variant"]
#[inline(always)]
pub fn variant(&self) -> ADDM_A {
match self.bits {
false => ADDM_A::BIT4,
true => ADDM_A::FULL,
}
}
#[doc = "Checks if the value of the field is `BIT4`"]
#[inline(always)]
pub fn is_bit4(&self) -> bool {
*self == ADDM_A::BIT4
}
#[doc = "Checks if the value of the field is `FULL`"]
#[inline(always)]
pub fn is_full(&self) -> bool {
*self == ADDM_A::FULL
}
}
#[doc = "Write proxy for field `ADDM`"]
pub struct ADDM_W<'a> {
w: &'a mut W,
}
impl<'a> ADDM_W<'a> {
#[doc = r"Writes `variant` to the field"]
#[inline(always)]
pub fn variant(self, variant: ADDM_A) -> &'a mut W {
{
self.bit(variant.into())
}
}
#[doc = "4-bit address detection"]
#[inline(always)]
pub fn bit4(self) -> &'a mut W {
self.variant(ADDM_A::BIT4)
}
#[doc = "Full-bit address detection"]
#[inline(always)]
pub fn full(self) -> &'a mut W {
self.variant(ADDM_A::FULL)
}
#[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
}
}
impl R {
#[doc = "Bits 24:31 - Address of the USART terminal"]
#[inline(always)]
pub fn addr(&self) -> ADDR_R {
ADDR_R::new(((self.bits >> 24) & 0xff) as u8)
}
#[doc = "Bit 23 - Receiver timeout enable"]
#[inline(always)]
pub fn rten(&self) -> RTEN_R {
RTEN_R::new(((self.bits >> 23) & 0x01) != 0)
}
#[doc = "Bits 21:22 - Auto baud rate mode"]
#[inline(always)]
pub fn abdm(&self) -> ABDM_R {
ABDM_R::new(((self.bits >> 21) & 0x03) as u8)
}
#[doc = "Bit 20 - Auto baud rate enable"]
#[inline(always)]
pub fn abden(&self) -> ABDEN_R {
ABDEN_R::new(((self.bits >> 20) & 0x01) != 0)
}
#[doc = "Bit 19 - Most significant bit first"]
#[inline(always)]
pub fn msbf(&self) -> MSBF_R {
MSBF_R::new(((self.bits >> 19) & 0x01) != 0)
}
#[doc = "Bit 18 - Data bit level inversion"]
#[inline(always)]
pub fn dinv(&self) -> DINV_R {
DINV_R::new(((self.bits >> 18) & 0x01) != 0)
}
#[doc = "Bit 17 - TX pin level inversion"]
#[inline(always)]
pub fn tinv(&self) -> TINV_R {
TINV_R::new(((self.bits >> 17) & 0x01) != 0)
}
#[doc = "Bit 16 - RX pin level inversion"]
#[inline(always)]
pub fn rinv(&self) -> RINV_R {
RINV_R::new(((self.bits >> 16) & 0x01) != 0)
}
#[doc = "Bit 15 - Swap TX/RX pins"]
#[inline(always)]
pub fn strp(&self) -> STRP_R {
STRP_R::new(((self.bits >> 15) & 0x01) != 0)
}
#[doc = "Bit 14 - LIN mode enable"]
#[inline(always)]
pub fn lmen(&self) -> LMEN_R {
LMEN_R::new(((self.bits >> 14) & 0x01) != 0)
}
#[doc = "Bits 12:13 - STOP bits length"]
#[inline(always)]
pub fn stb(&self) -> STB_R {
STB_R::new(((self.bits >> 12) & 0x03) as u8)
}
#[doc = "Bit 11 - CK pin enable"]
#[inline(always)]
pub fn cken(&self) -> CKEN_R {
CKEN_R::new(((self.bits >> 11) & 0x01) != 0)
}
#[doc = "Bit 10 - Clock polarity"]
#[inline(always)]
pub fn cpl(&self) -> CPL_R {
CPL_R::new(((self.bits >> 10) & 0x01) != 0)
}
#[doc = "Bit 9 - Clock phase"]
#[inline(always)]
pub fn cph(&self) -> CPH_R {
CPH_R::new(((self.bits >> 9) & 0x01) != 0)
}
#[doc = "Bit 8 - CK length"]
#[inline(always)]
pub fn clen(&self) -> CLEN_R {
CLEN_R::new(((self.bits >> 8) & 0x01) != 0)
}
#[doc = "Bit 6 - LIN break detection interrupt enable"]
#[inline(always)]
pub fn lbdie(&self) -> LBDIE_R {
LBDIE_R::new(((self.bits >> 6) & 0x01) != 0)
}
#[doc = "Bit 5 - LIN break frame length"]
#[inline(always)]
pub fn lblen(&self) -> LBLEN_R {
LBLEN_R::new(((self.bits >> 5) & 0x01) != 0)
}
#[doc = "Bit 4 - Address detection mode"]
#[inline(always)]
pub fn addm(&self) -> ADDM_R {
ADDM_R::new(((self.bits >> 4) & 0x01) != 0)
}
}
impl W {
#[doc = "Bits 24:31 - Address of the USART terminal"]
#[inline(always)]
pub fn addr(&mut self) -> ADDR_W {
ADDR_W { w: self }
}
#[doc = "Bit 23 - Receiver timeout enable"]
#[inline(always)]
pub fn rten(&mut self) -> RTEN_W {
RTEN_W { w: self }
}
#[doc = "Bits 21:22 - Auto baud rate mode"]
#[inline(always)]
pub fn abdm(&mut self) -> ABDM_W {
ABDM_W { w: self }
}
#[doc = "Bit 20 - Auto baud rate enable"]
#[inline(always)]
pub fn abden(&mut self) -> ABDEN_W {
ABDEN_W { w: self }
}
#[doc = "Bit 19 - Most significant bit first"]
#[inline(always)]
pub fn msbf(&mut self) -> MSBF_W {
MSBF_W { w: self }
}
#[doc = "Bit 18 - Data bit level inversion"]
#[inline(always)]
pub fn dinv(&mut self) -> DINV_W {
DINV_W { w: self }
}
#[doc = "Bit 17 - TX pin level inversion"]
#[inline(always)]
pub fn tinv(&mut self) -> TINV_W {
TINV_W { w: self }
}
#[doc = "Bit 16 - RX pin level inversion"]
#[inline(always)]
pub fn rinv(&mut self) -> RINV_W {
RINV_W { w: self }
}
#[doc = "Bit 15 - Swap TX/RX pins"]
#[inline(always)]
pub fn strp(&mut self) -> STRP_W {
STRP_W { w: self }
}
#[doc = "Bit 14 - LIN mode enable"]
#[inline(always)]
pub fn lmen(&mut self) -> LMEN_W {
LMEN_W { w: self }
}
#[doc = "Bits 12:13 - STOP bits length"]
#[inline(always)]
pub fn stb(&mut self) -> STB_W {
STB_W { w: self }
}
#[doc = "Bit 11 - CK pin enable"]
#[inline(always)]
pub fn cken(&mut self) -> CKEN_W {
CKEN_W { w: self }
}
#[doc = "Bit 10 - Clock polarity"]
#[inline(always)]
pub fn cpl(&mut self) -> CPL_W {
CPL_W { w: self }
}
#[doc = "Bit 9 - Clock phase"]
#[inline(always)]
pub fn cph(&mut self) -> CPH_W {
CPH_W { w: self }
}
#[doc = "Bit 8 - CK length"]
#[inline(always)]
pub fn clen(&mut self) -> CLEN_W {
CLEN_W { w: self }
}
#[doc = "Bit 6 - LIN break detection interrupt enable"]
#[inline(always)]
pub fn lbdie(&mut self) -> LBDIE_W {
LBDIE_W { w: self }
}
#[doc = "Bit 5 - LIN break frame length"]
#[inline(always)]
pub fn lblen(&mut self) -> LBLEN_W {
LBLEN_W { w: self }
}
#[doc = "Bit 4 - Address detection mode"]
#[inline(always)]
pub fn addm(&mut self) -> ADDM_W {
ADDM_W { w: self }
}
}