atsam4lc4b-pac 0.3.2

Peripheral access crate for the ATSAM4LC4B microcontroller
Documentation
#[doc = r"Register block"]
#[repr(C)]
pub struct RegisterBlock {
    _reserved_0_lin_mode_cr_lin: [u8; 0x04],
    _reserved_1_usart_mode_mr: [u8; 0x04],
    _reserved_2_lin_mode_ier_lin: [u8; 0x04],
    _reserved_3_lin_mode_idr_lin: [u8; 0x04],
    _reserved_4_lin_mode_imr_lin: [u8; 0x04],
    _reserved_5_lin_mode_csr_lin: [u8; 0x04],
    #[doc = "0x18 - Receiver Holding Register"]
    pub rhr: RHR,
    #[doc = "0x1c - Transmitter Holding Register"]
    pub thr: THR,
    #[doc = "0x20 - Baud Rate Generator Register"]
    pub brgr: BRGR,
    #[doc = "0x24 - Receiver Time-out Register"]
    pub rtor: RTOR,
    #[doc = "0x28 - Transmitter Timeguard Register"]
    pub ttgr: TTGR,
    _reserved11: [u8; 0x14],
    #[doc = "0x40 - FI DI Ratio Register"]
    pub fidi: FIDI,
    #[doc = "0x44 - Number of Errors Register"]
    pub ner: NER,
    _reserved13: [u8; 0x04],
    #[doc = "0x4c - IrDA Filter Register"]
    pub ifr: IFR,
    #[doc = "0x50 - Manchester Configuration Register"]
    pub man: MAN,
    #[doc = "0x54 - LIN Mode Register"]
    pub linmr: LINMR,
    #[doc = "0x58 - LIN Identifier Register"]
    pub linir: LINIR,
    #[doc = "0x5c - LIN Baud Rate Register"]
    pub linbrr: LINBRR,
    _reserved18: [u8; 0x84],
    #[doc = "0xe4 - Write Protect Mode Register"]
    pub wpmr: WPMR,
    #[doc = "0xe8 - Write Protect Status Register"]
    pub wpsr: WPSR,
    _reserved20: [u8; 0x10],
    #[doc = "0xfc - Version Register"]
    pub version: VERSION,
}
impl RegisterBlock {
    #[doc = "0x00 - Control Register"]
    #[inline(always)]
    pub const fn usart_mode_cr_usart(&self) -> &USART_MODE_CR_USART {
        unsafe { &*(self as *const Self).cast::<u8>().add(0usize).cast() }
    }
    #[doc = "0x00 - Control Register"]
    #[inline(always)]
    pub const fn spi_master_mode_cr_spi(&self) -> &SPI_MASTER_MODE_CR_SPI {
        unsafe { &*(self as *const Self).cast::<u8>().add(0usize).cast() }
    }
    #[doc = "0x00 - Control Register"]
    #[inline(always)]
    pub const fn lin_mode_cr_lin(&self) -> &LIN_MODE_CR_LIN {
        unsafe { &*(self as *const Self).cast::<u8>().add(0usize).cast() }
    }
    #[doc = "0x04 - Mode Register"]
    #[inline(always)]
    pub const fn usart_mode_mr(&self) -> &USART_MODE_MR {
        unsafe { &*(self as *const Self).cast::<u8>().add(4usize).cast() }
    }
    #[doc = "0x04 - Mode Register"]
    #[inline(always)]
    pub const fn spi_mode_mr_spi(&self) -> &SPI_MODE_MR_SPI {
        unsafe { &*(self as *const Self).cast::<u8>().add(4usize).cast() }
    }
    #[doc = "0x08 - Interrupt Enable Register"]
    #[inline(always)]
    pub const fn usart_mode_ier_usart(&self) -> &USART_MODE_IER_USART {
        unsafe { &*(self as *const Self).cast::<u8>().add(8usize).cast() }
    }
    #[doc = "0x08 - Interrupt Enable Register"]
    #[inline(always)]
    pub const fn spi_slave_mode_ier_spi(&self) -> &SPI_SLAVE_MODE_IER_SPI {
        unsafe { &*(self as *const Self).cast::<u8>().add(8usize).cast() }
    }
    #[doc = "0x08 - Interrupt Enable Register"]
    #[inline(always)]
    pub const fn lin_mode_ier_lin(&self) -> &LIN_MODE_IER_LIN {
        unsafe { &*(self as *const Self).cast::<u8>().add(8usize).cast() }
    }
    #[doc = "0x0c - Interrupt Disable Register"]
    #[inline(always)]
    pub const fn usart_mode_idr_usart(&self) -> &USART_MODE_IDR_USART {
        unsafe { &*(self as *const Self).cast::<u8>().add(12usize).cast() }
    }
    #[doc = "0x0c - Interrupt Disable Register"]
    #[inline(always)]
    pub const fn spi_slave_mode_idr_spi(&self) -> &SPI_SLAVE_MODE_IDR_SPI {
        unsafe { &*(self as *const Self).cast::<u8>().add(12usize).cast() }
    }
    #[doc = "0x0c - Interrupt Disable Register"]
    #[inline(always)]
    pub const fn lin_mode_idr_lin(&self) -> &LIN_MODE_IDR_LIN {
        unsafe { &*(self as *const Self).cast::<u8>().add(12usize).cast() }
    }
    #[doc = "0x10 - Interrupt Mask Register"]
    #[inline(always)]
    pub const fn usart_mode_imr_usart(&self) -> &USART_MODE_IMR_USART {
        unsafe { &*(self as *const Self).cast::<u8>().add(16usize).cast() }
    }
    #[doc = "0x10 - Interrupt Mask Register"]
    #[inline(always)]
    pub const fn spi_slave_mode_mr_usart(&self) -> &SPI_SLAVE_MODE_MR_USART {
        unsafe { &*(self as *const Self).cast::<u8>().add(16usize).cast() }
    }
    #[doc = "0x10 - Interrupt Mask Register"]
    #[inline(always)]
    pub const fn lin_mode_imr_lin(&self) -> &LIN_MODE_IMR_LIN {
        unsafe { &*(self as *const Self).cast::<u8>().add(16usize).cast() }
    }
    #[doc = "0x14 - Channel Status Register"]
    #[inline(always)]
    pub const fn usart_mode_csr_usart(&self) -> &USART_MODE_CSR_USART {
        unsafe { &*(self as *const Self).cast::<u8>().add(20usize).cast() }
    }
    #[doc = "0x14 - Channel Status Register"]
    #[inline(always)]
    pub const fn spi_slave_mode_csr_spi(&self) -> &SPI_SLAVE_MODE_CSR_SPI {
        unsafe { &*(self as *const Self).cast::<u8>().add(20usize).cast() }
    }
    #[doc = "0x14 - Channel Status Register"]
    #[inline(always)]
    pub const fn lin_mode_csr_lin(&self) -> &LIN_MODE_CSR_LIN {
        unsafe { &*(self as *const Self).cast::<u8>().add(20usize).cast() }
    }
}
#[doc = "BRGR (rw) register accessor: an alias for `Reg<BRGR_SPEC>`"]
pub type BRGR = crate::Reg<brgr::BRGR_SPEC>;
#[doc = "Baud Rate Generator Register"]
pub mod brgr;
#[doc = "LIN_MODE_CR_LIN (w) register accessor: an alias for `Reg<LIN_MODE_CR_LIN_SPEC>`"]
pub type LIN_MODE_CR_LIN = crate::Reg<lin_mode_cr_lin::LIN_MODE_CR_LIN_SPEC>;
#[doc = "Control Register"]
pub mod lin_mode_cr_lin;
#[doc = "SPI_MASTER_MODE_CR_SPI (w) register accessor: an alias for `Reg<SPI_MASTER_MODE_CR_SPI_SPEC>`"]
pub type SPI_MASTER_MODE_CR_SPI = crate::Reg<spi_master_mode_cr_spi::SPI_MASTER_MODE_CR_SPI_SPEC>;
#[doc = "Control Register"]
pub mod spi_master_mode_cr_spi;
#[doc = "USART_MODE_CR_USART (w) register accessor: an alias for `Reg<USART_MODE_CR_USART_SPEC>`"]
pub type USART_MODE_CR_USART = crate::Reg<usart_mode_cr_usart::USART_MODE_CR_USART_SPEC>;
#[doc = "Control Register"]
pub mod usart_mode_cr_usart;
#[doc = "LIN_MODE_CSR_LIN (r) register accessor: an alias for `Reg<LIN_MODE_CSR_LIN_SPEC>`"]
pub type LIN_MODE_CSR_LIN = crate::Reg<lin_mode_csr_lin::LIN_MODE_CSR_LIN_SPEC>;
#[doc = "Channel Status Register"]
pub mod lin_mode_csr_lin;
#[doc = "SPI_SLAVE_MODE_CSR_SPI (r) register accessor: an alias for `Reg<SPI_SLAVE_MODE_CSR_SPI_SPEC>`"]
pub type SPI_SLAVE_MODE_CSR_SPI = crate::Reg<spi_slave_mode_csr_spi::SPI_SLAVE_MODE_CSR_SPI_SPEC>;
#[doc = "Channel Status Register"]
pub mod spi_slave_mode_csr_spi;
#[doc = "USART_MODE_CSR_USART (r) register accessor: an alias for `Reg<USART_MODE_CSR_USART_SPEC>`"]
pub type USART_MODE_CSR_USART = crate::Reg<usart_mode_csr_usart::USART_MODE_CSR_USART_SPEC>;
#[doc = "Channel Status Register"]
pub mod usart_mode_csr_usart;
#[doc = "FIDI (rw) register accessor: an alias for `Reg<FIDI_SPEC>`"]
pub type FIDI = crate::Reg<fidi::FIDI_SPEC>;
#[doc = "FI DI Ratio Register"]
pub mod fidi;
#[doc = "LIN_MODE_IDR_LIN (w) register accessor: an alias for `Reg<LIN_MODE_IDR_LIN_SPEC>`"]
pub type LIN_MODE_IDR_LIN = crate::Reg<lin_mode_idr_lin::LIN_MODE_IDR_LIN_SPEC>;
#[doc = "Interrupt Disable Register"]
pub mod lin_mode_idr_lin;
#[doc = "SPI_SLAVE_MODE_IDR_SPI (w) register accessor: an alias for `Reg<SPI_SLAVE_MODE_IDR_SPI_SPEC>`"]
pub type SPI_SLAVE_MODE_IDR_SPI = crate::Reg<spi_slave_mode_idr_spi::SPI_SLAVE_MODE_IDR_SPI_SPEC>;
#[doc = "Interrupt Disable Register"]
pub mod spi_slave_mode_idr_spi;
#[doc = "USART_MODE_IDR_USART (w) register accessor: an alias for `Reg<USART_MODE_IDR_USART_SPEC>`"]
pub type USART_MODE_IDR_USART = crate::Reg<usart_mode_idr_usart::USART_MODE_IDR_USART_SPEC>;
#[doc = "Interrupt Disable Register"]
pub mod usart_mode_idr_usart;
#[doc = "LIN_MODE_IER_LIN (w) register accessor: an alias for `Reg<LIN_MODE_IER_LIN_SPEC>`"]
pub type LIN_MODE_IER_LIN = crate::Reg<lin_mode_ier_lin::LIN_MODE_IER_LIN_SPEC>;
#[doc = "Interrupt Enable Register"]
pub mod lin_mode_ier_lin;
#[doc = "SPI_SLAVE_MODE_IER_SPI (w) register accessor: an alias for `Reg<SPI_SLAVE_MODE_IER_SPI_SPEC>`"]
pub type SPI_SLAVE_MODE_IER_SPI = crate::Reg<spi_slave_mode_ier_spi::SPI_SLAVE_MODE_IER_SPI_SPEC>;
#[doc = "Interrupt Enable Register"]
pub mod spi_slave_mode_ier_spi;
#[doc = "USART_MODE_IER_USART (w) register accessor: an alias for `Reg<USART_MODE_IER_USART_SPEC>`"]
pub type USART_MODE_IER_USART = crate::Reg<usart_mode_ier_usart::USART_MODE_IER_USART_SPEC>;
#[doc = "Interrupt Enable Register"]
pub mod usart_mode_ier_usart;
#[doc = "IFR (rw) register accessor: an alias for `Reg<IFR_SPEC>`"]
pub type IFR = crate::Reg<ifr::IFR_SPEC>;
#[doc = "IrDA Filter Register"]
pub mod ifr;
#[doc = "LIN_MODE_IMR_LIN (r) register accessor: an alias for `Reg<LIN_MODE_IMR_LIN_SPEC>`"]
pub type LIN_MODE_IMR_LIN = crate::Reg<lin_mode_imr_lin::LIN_MODE_IMR_LIN_SPEC>;
#[doc = "Interrupt Mask Register"]
pub mod lin_mode_imr_lin;
#[doc = "SPI_SLAVE_MODE_MR_USART (r) register accessor: an alias for `Reg<SPI_SLAVE_MODE_MR_USART_SPEC>`"]
pub type SPI_SLAVE_MODE_MR_USART =
    crate::Reg<spi_slave_mode_mr_usart::SPI_SLAVE_MODE_MR_USART_SPEC>;
#[doc = "Interrupt Mask Register"]
pub mod spi_slave_mode_mr_usart;
#[doc = "USART_MODE_IMR_USART (r) register accessor: an alias for `Reg<USART_MODE_IMR_USART_SPEC>`"]
pub type USART_MODE_IMR_USART = crate::Reg<usart_mode_imr_usart::USART_MODE_IMR_USART_SPEC>;
#[doc = "Interrupt Mask Register"]
pub mod usart_mode_imr_usart;
#[doc = "LINBRR (r) register accessor: an alias for `Reg<LINBRR_SPEC>`"]
pub type LINBRR = crate::Reg<linbrr::LINBRR_SPEC>;
#[doc = "LIN Baud Rate Register"]
pub mod linbrr;
#[doc = "LINIR (rw) register accessor: an alias for `Reg<LINIR_SPEC>`"]
pub type LINIR = crate::Reg<linir::LINIR_SPEC>;
#[doc = "LIN Identifier Register"]
pub mod linir;
#[doc = "LINMR (rw) register accessor: an alias for `Reg<LINMR_SPEC>`"]
pub type LINMR = crate::Reg<linmr::LINMR_SPEC>;
#[doc = "LIN Mode Register"]
pub mod linmr;
#[doc = "MAN (rw) register accessor: an alias for `Reg<MAN_SPEC>`"]
pub type MAN = crate::Reg<man::MAN_SPEC>;
#[doc = "Manchester Configuration Register"]
pub mod man;
#[doc = "SPI_MODE_MR_SPI (rw) register accessor: an alias for `Reg<SPI_MODE_MR_SPI_SPEC>`"]
pub type SPI_MODE_MR_SPI = crate::Reg<spi_mode_mr_spi::SPI_MODE_MR_SPI_SPEC>;
#[doc = "Mode Register"]
pub mod spi_mode_mr_spi;
#[doc = "USART_MODE_MR (rw) register accessor: an alias for `Reg<USART_MODE_MR_SPEC>`"]
pub type USART_MODE_MR = crate::Reg<usart_mode_mr::USART_MODE_MR_SPEC>;
#[doc = "Mode Register"]
pub mod usart_mode_mr;
#[doc = "NER (r) register accessor: an alias for `Reg<NER_SPEC>`"]
pub type NER = crate::Reg<ner::NER_SPEC>;
#[doc = "Number of Errors Register"]
pub mod ner;
#[doc = "RHR (r) register accessor: an alias for `Reg<RHR_SPEC>`"]
pub type RHR = crate::Reg<rhr::RHR_SPEC>;
#[doc = "Receiver Holding Register"]
pub mod rhr;
#[doc = "RTOR (rw) register accessor: an alias for `Reg<RTOR_SPEC>`"]
pub type RTOR = crate::Reg<rtor::RTOR_SPEC>;
#[doc = "Receiver Time-out Register"]
pub mod rtor;
#[doc = "THR (w) register accessor: an alias for `Reg<THR_SPEC>`"]
pub type THR = crate::Reg<thr::THR_SPEC>;
#[doc = "Transmitter Holding Register"]
pub mod thr;
#[doc = "TTGR (rw) register accessor: an alias for `Reg<TTGR_SPEC>`"]
pub type TTGR = crate::Reg<ttgr::TTGR_SPEC>;
#[doc = "Transmitter Timeguard Register"]
pub mod ttgr;
#[doc = "VERSION (r) register accessor: an alias for `Reg<VERSION_SPEC>`"]
pub type VERSION = crate::Reg<version::VERSION_SPEC>;
#[doc = "Version Register"]
pub mod version;
#[doc = "WPMR (rw) register accessor: an alias for `Reg<WPMR_SPEC>`"]
pub type WPMR = crate::Reg<wpmr::WPMR_SPEC>;
#[doc = "Write Protect Mode Register"]
pub mod wpmr;
#[doc = "WPSR (r) register accessor: an alias for `Reg<WPSR_SPEC>`"]
pub type WPSR = crate::Reg<wpsr::WPSR_SPEC>;
#[doc = "Write Protect Status Register"]
pub mod wpsr;