#![doc = "Peripheral access API for NRF52840 microcontrollers (generated using svd2rust v0.25.1 ( ))\n\nYou can find an overview of the generated API [here].\n\nAPI features to be included in the [next]
svd2rust release can be generated by cloning the svd2rust [repository], checking out the above commit, and running `cargo doc --open`.\n\n[here]: https://docs.rs/svd2rust/0.25.1/svd2rust/#peripheral-api\n[next]: https://github.com/rust-embedded/svd2rust/blob/master/CHANGELOG.md#unreleased\n[repository]: https://github.com/rust-embedded/svd2rust"]
#![deny(const_err)]
#![deny(dead_code)]
#![deny(improper_ctypes)]
#![deny(missing_docs)]
#![deny(no_mangle_generic_items)]
#![deny(non_shorthand_field_patterns)]
#![deny(overflowing_literals)]
#![deny(path_statements)]
#![deny(patterns_in_fns_without_body)]
#![deny(private_in_public)]
#![deny(unconditional_recursion)]
#![deny(unused_allocation)]
#![deny(unused_comparisons)]
#![deny(unused_parens)]
#![deny(while_true)]
#![allow(non_camel_case_types)]
#![allow(non_snake_case)]
#![no_std]
use core::marker::PhantomData;
use core::ops::Deref;
#[doc = r"Number available in the NVIC for configuring priority"]
pub const NVIC_PRIO_BITS: u8 = 3;
#[cfg(feature = "rt")]
pub use self::Interrupt as interrupt;
pub use cortex_m::peripheral::Peripherals as CorePeripherals;
pub use cortex_m::peripheral::{CBP, CPUID, DCB, DWT, FPB, FPU, ITM, MPU, NVIC, SCB, SYST, TPIU};
#[cfg(feature = "rt")]
pub use cortex_m_rt::interrupt;
#[allow(unused_imports)]
use generic::*;
#[doc = r"Common register and bit access and modify traits"]
pub mod generic;
#[cfg(feature = "rt")]
extern "C" {
fn POWER_CLOCK();
fn RADIO();
fn UARTE0_UART0();
fn SPIM0_SPIS0_TWIM0_TWIS0_SPI0_TWI0();
fn SPIM1_SPIS1_TWIM1_TWIS1_SPI1_TWI1();
fn NFCT();
fn GPIOTE();
fn SAADC();
fn TIMER0();
fn TIMER1();
fn TIMER2();
fn RTC0();
fn TEMP();
fn RNG();
fn ECB();
fn CCM_AAR();
fn WDT();
fn RTC1();
fn QDEC();
fn COMP_LPCOMP();
fn SWI0_EGU0();
fn SWI1_EGU1();
fn SWI2_EGU2();
fn SWI3_EGU3();
fn SWI4_EGU4();
fn SWI5_EGU5();
fn TIMER3();
fn TIMER4();
fn PWM0();
fn PDM();
fn MWU();
fn PWM1();
fn PWM2();
fn SPIM2_SPIS2_SPI2();
fn RTC2();
fn I2S();
fn FPU();
fn USBD();
fn UARTE1();
fn QSPI();
fn CRYPTOCELL();
fn PWM3();
fn SPIM3();
}
#[doc(hidden)]
pub union Vector {
_handler: unsafe extern "C" fn(),
_reserved: u32,
}
#[cfg(feature = "rt")]
#[doc(hidden)]
#[link_section = ".vector_table.interrupts"]
#[no_mangle]
pub static __INTERRUPTS: [Vector; 48] = [
Vector {
_handler: POWER_CLOCK,
},
Vector { _handler: RADIO },
Vector {
_handler: UARTE0_UART0,
},
Vector {
_handler: SPIM0_SPIS0_TWIM0_TWIS0_SPI0_TWI0,
},
Vector {
_handler: SPIM1_SPIS1_TWIM1_TWIS1_SPI1_TWI1,
},
Vector { _handler: NFCT },
Vector { _handler: GPIOTE },
Vector { _handler: SAADC },
Vector { _handler: TIMER0 },
Vector { _handler: TIMER1 },
Vector { _handler: TIMER2 },
Vector { _handler: RTC0 },
Vector { _handler: TEMP },
Vector { _handler: RNG },
Vector { _handler: ECB },
Vector { _handler: CCM_AAR },
Vector { _handler: WDT },
Vector { _handler: RTC1 },
Vector { _handler: QDEC },
Vector {
_handler: COMP_LPCOMP,
},
Vector {
_handler: SWI0_EGU0,
},
Vector {
_handler: SWI1_EGU1,
},
Vector {
_handler: SWI2_EGU2,
},
Vector {
_handler: SWI3_EGU3,
},
Vector {
_handler: SWI4_EGU4,
},
Vector {
_handler: SWI5_EGU5,
},
Vector { _handler: TIMER3 },
Vector { _handler: TIMER4 },
Vector { _handler: PWM0 },
Vector { _handler: PDM },
Vector { _reserved: 0 },
Vector { _reserved: 0 },
Vector { _handler: MWU },
Vector { _handler: PWM1 },
Vector { _handler: PWM2 },
Vector {
_handler: SPIM2_SPIS2_SPI2,
},
Vector { _handler: RTC2 },
Vector { _handler: I2S },
Vector { _handler: FPU },
Vector { _handler: USBD },
Vector { _handler: UARTE1 },
Vector { _handler: QSPI },
Vector {
_handler: CRYPTOCELL,
},
Vector { _reserved: 0 },
Vector { _reserved: 0 },
Vector { _handler: PWM3 },
Vector { _reserved: 0 },
Vector { _handler: SPIM3 },
];
#[doc = r"Enumeration of all the interrupts."]
#[derive(Copy, Clone, Debug, PartialEq, Eq)]
#[repr(u16)]
pub enum Interrupt {
#[doc = "0 - POWER_CLOCK"]
POWER_CLOCK = 0,
#[doc = "1 - RADIO"]
RADIO = 1,
#[doc = "2 - UARTE0_UART0"]
UARTE0_UART0 = 2,
#[doc = "3 - SPIM0_SPIS0_TWIM0_TWIS0_SPI0_TWI0"]
SPIM0_SPIS0_TWIM0_TWIS0_SPI0_TWI0 = 3,
#[doc = "4 - SPIM1_SPIS1_TWIM1_TWIS1_SPI1_TWI1"]
SPIM1_SPIS1_TWIM1_TWIS1_SPI1_TWI1 = 4,
#[doc = "5 - NFCT"]
NFCT = 5,
#[doc = "6 - GPIOTE"]
GPIOTE = 6,
#[doc = "7 - SAADC"]
SAADC = 7,
#[doc = "8 - TIMER0"]
TIMER0 = 8,
#[doc = "9 - TIMER1"]
TIMER1 = 9,
#[doc = "10 - TIMER2"]
TIMER2 = 10,
#[doc = "11 - RTC0"]
RTC0 = 11,
#[doc = "12 - TEMP"]
TEMP = 12,
#[doc = "13 - RNG"]
RNG = 13,
#[doc = "14 - ECB"]
ECB = 14,
#[doc = "15 - CCM_AAR"]
CCM_AAR = 15,
#[doc = "16 - WDT"]
WDT = 16,
#[doc = "17 - RTC1"]
RTC1 = 17,
#[doc = "18 - QDEC"]
QDEC = 18,
#[doc = "19 - COMP_LPCOMP"]
COMP_LPCOMP = 19,
#[doc = "20 - SWI0_EGU0"]
SWI0_EGU0 = 20,
#[doc = "21 - SWI1_EGU1"]
SWI1_EGU1 = 21,
#[doc = "22 - SWI2_EGU2"]
SWI2_EGU2 = 22,
#[doc = "23 - SWI3_EGU3"]
SWI3_EGU3 = 23,
#[doc = "24 - SWI4_EGU4"]
SWI4_EGU4 = 24,
#[doc = "25 - SWI5_EGU5"]
SWI5_EGU5 = 25,
#[doc = "26 - TIMER3"]
TIMER3 = 26,
#[doc = "27 - TIMER4"]
TIMER4 = 27,
#[doc = "28 - PWM0"]
PWM0 = 28,
#[doc = "29 - PDM"]
PDM = 29,
#[doc = "32 - MWU"]
MWU = 32,
#[doc = "33 - PWM1"]
PWM1 = 33,
#[doc = "34 - PWM2"]
PWM2 = 34,
#[doc = "35 - SPIM2_SPIS2_SPI2"]
SPIM2_SPIS2_SPI2 = 35,
#[doc = "36 - RTC2"]
RTC2 = 36,
#[doc = "37 - I2S"]
I2S = 37,
#[doc = "38 - FPU"]
FPU = 38,
#[doc = "39 - USBD"]
USBD = 39,
#[doc = "40 - UARTE1"]
UARTE1 = 40,
#[doc = "41 - QSPI"]
QSPI = 41,
#[doc = "42 - CRYPTOCELL"]
CRYPTOCELL = 42,
#[doc = "45 - PWM3"]
PWM3 = 45,
#[doc = "47 - SPIM3"]
SPIM3 = 47,
}
unsafe impl cortex_m::interrupt::InterruptNumber for Interrupt {
#[inline(always)]
fn number(self) -> u16 {
self as u16
}
}
#[doc = "Factory information configuration registers"]
pub struct FICR {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for FICR {}
impl FICR {
#[doc = r"Pointer to the register block"]
pub const PTR: *const ficr::RegisterBlock = 0x1000_0000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const ficr::RegisterBlock {
Self::PTR
}
}
impl Deref for FICR {
type Target = ficr::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for FICR {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("FICR").finish()
}
}
#[doc = "Factory information configuration registers"]
pub mod ficr;
#[doc = "User information configuration registers"]
pub struct UICR {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for UICR {}
impl UICR {
#[doc = r"Pointer to the register block"]
pub const PTR: *const uicr::RegisterBlock = 0x1000_1000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const uicr::RegisterBlock {
Self::PTR
}
}
impl Deref for UICR {
type Target = uicr::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for UICR {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("UICR").finish()
}
}
#[doc = "User information configuration registers"]
pub mod uicr;
#[doc = "Clock control"]
pub struct CLOCK {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for CLOCK {}
impl CLOCK {
#[doc = r"Pointer to the register block"]
pub const PTR: *const clock::RegisterBlock = 0x4000_0000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const clock::RegisterBlock {
Self::PTR
}
}
impl Deref for CLOCK {
type Target = clock::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for CLOCK {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("CLOCK").finish()
}
}
#[doc = "Clock control"]
pub mod clock;
#[doc = "Power control"]
pub struct POWER {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for POWER {}
impl POWER {
#[doc = r"Pointer to the register block"]
pub const PTR: *const power::RegisterBlock = 0x4000_0000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const power::RegisterBlock {
Self::PTR
}
}
impl Deref for POWER {
type Target = power::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for POWER {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("POWER").finish()
}
}
#[doc = "Power control"]
pub mod power;
#[doc = "2.4 GHz radio"]
pub struct RADIO {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for RADIO {}
impl RADIO {
#[doc = r"Pointer to the register block"]
pub const PTR: *const radio::RegisterBlock = 0x4000_1000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const radio::RegisterBlock {
Self::PTR
}
}
impl Deref for RADIO {
type Target = radio::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for RADIO {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("RADIO").finish()
}
}
#[doc = "2.4 GHz radio"]
pub mod radio;
#[doc = "Universal Asynchronous Receiver/Transmitter"]
pub struct UART0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for UART0 {}
impl UART0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const uart0::RegisterBlock = 0x4000_2000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const uart0::RegisterBlock {
Self::PTR
}
}
impl Deref for UART0 {
type Target = uart0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for UART0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("UART0").finish()
}
}
#[doc = "Universal Asynchronous Receiver/Transmitter"]
pub mod uart0;
#[doc = "UART with EasyDMA 0"]
pub struct UARTE0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for UARTE0 {}
impl UARTE0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const uarte0::RegisterBlock = 0x4000_2000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const uarte0::RegisterBlock {
Self::PTR
}
}
impl Deref for UARTE0 {
type Target = uarte0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for UARTE0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("UARTE0").finish()
}
}
#[doc = "UART with EasyDMA 0"]
pub mod uarte0;
#[doc = "Serial Peripheral Interface 0"]
pub struct SPI0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SPI0 {}
impl SPI0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const spi0::RegisterBlock = 0x4000_3000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const spi0::RegisterBlock {
Self::PTR
}
}
impl Deref for SPI0 {
type Target = spi0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SPI0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SPI0").finish()
}
}
#[doc = "Serial Peripheral Interface 0"]
pub mod spi0;
#[doc = "Serial Peripheral Interface Master with EasyDMA 0"]
pub struct SPIM0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SPIM0 {}
impl SPIM0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const spim0::RegisterBlock = 0x4000_3000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const spim0::RegisterBlock {
Self::PTR
}
}
impl Deref for SPIM0 {
type Target = spim0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SPIM0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SPIM0").finish()
}
}
#[doc = "Serial Peripheral Interface Master with EasyDMA 0"]
pub mod spim0;
#[doc = "SPI Slave 0"]
pub struct SPIS0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SPIS0 {}
impl SPIS0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const spis0::RegisterBlock = 0x4000_3000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const spis0::RegisterBlock {
Self::PTR
}
}
impl Deref for SPIS0 {
type Target = spis0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SPIS0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SPIS0").finish()
}
}
#[doc = "SPI Slave 0"]
pub mod spis0;
#[doc = "I2C compatible Two-Wire Interface 0"]
pub struct TWI0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TWI0 {}
impl TWI0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const twi0::RegisterBlock = 0x4000_3000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const twi0::RegisterBlock {
Self::PTR
}
}
impl Deref for TWI0 {
type Target = twi0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TWI0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TWI0").finish()
}
}
#[doc = "I2C compatible Two-Wire Interface 0"]
pub mod twi0;
#[doc = "I2C compatible Two-Wire Master Interface with EasyDMA 0"]
pub struct TWIM0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TWIM0 {}
impl TWIM0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const twim0::RegisterBlock = 0x4000_3000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const twim0::RegisterBlock {
Self::PTR
}
}
impl Deref for TWIM0 {
type Target = twim0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TWIM0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TWIM0").finish()
}
}
#[doc = "I2C compatible Two-Wire Master Interface with EasyDMA 0"]
pub mod twim0;
#[doc = "I2C compatible Two-Wire Slave Interface with EasyDMA 0"]
pub struct TWIS0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TWIS0 {}
impl TWIS0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const twis0::RegisterBlock = 0x4000_3000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const twis0::RegisterBlock {
Self::PTR
}
}
impl Deref for TWIS0 {
type Target = twis0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TWIS0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TWIS0").finish()
}
}
#[doc = "I2C compatible Two-Wire Slave Interface with EasyDMA 0"]
pub mod twis0;
#[doc = "Serial Peripheral Interface 1"]
pub struct SPI1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SPI1 {}
impl SPI1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const spi0::RegisterBlock = 0x4000_4000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const spi0::RegisterBlock {
Self::PTR
}
}
impl Deref for SPI1 {
type Target = spi0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SPI1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SPI1").finish()
}
}
#[doc = "Serial Peripheral Interface 1"]
pub use spi0 as spi1;
#[doc = "Serial Peripheral Interface Master with EasyDMA 1"]
pub struct SPIM1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SPIM1 {}
impl SPIM1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const spim0::RegisterBlock = 0x4000_4000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const spim0::RegisterBlock {
Self::PTR
}
}
impl Deref for SPIM1 {
type Target = spim0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SPIM1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SPIM1").finish()
}
}
#[doc = "Serial Peripheral Interface Master with EasyDMA 1"]
pub use spim0 as spim1;
#[doc = "SPI Slave 1"]
pub struct SPIS1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SPIS1 {}
impl SPIS1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const spis0::RegisterBlock = 0x4000_4000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const spis0::RegisterBlock {
Self::PTR
}
}
impl Deref for SPIS1 {
type Target = spis0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SPIS1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SPIS1").finish()
}
}
#[doc = "SPI Slave 1"]
pub use spis0 as spis1;
#[doc = "I2C compatible Two-Wire Interface 1"]
pub struct TWI1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TWI1 {}
impl TWI1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const twi0::RegisterBlock = 0x4000_4000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const twi0::RegisterBlock {
Self::PTR
}
}
impl Deref for TWI1 {
type Target = twi0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TWI1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TWI1").finish()
}
}
#[doc = "I2C compatible Two-Wire Interface 1"]
pub use twi0 as twi1;
#[doc = "I2C compatible Two-Wire Master Interface with EasyDMA 1"]
pub struct TWIM1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TWIM1 {}
impl TWIM1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const twim0::RegisterBlock = 0x4000_4000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const twim0::RegisterBlock {
Self::PTR
}
}
impl Deref for TWIM1 {
type Target = twim0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TWIM1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TWIM1").finish()
}
}
#[doc = "I2C compatible Two-Wire Master Interface with EasyDMA 1"]
pub use twim0 as twim1;
#[doc = "I2C compatible Two-Wire Slave Interface with EasyDMA 1"]
pub struct TWIS1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TWIS1 {}
impl TWIS1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const twis0::RegisterBlock = 0x4000_4000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const twis0::RegisterBlock {
Self::PTR
}
}
impl Deref for TWIS1 {
type Target = twis0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TWIS1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TWIS1").finish()
}
}
#[doc = "I2C compatible Two-Wire Slave Interface with EasyDMA 1"]
pub use twis0 as twis1;
#[doc = "NFC-A compatible radio"]
pub struct NFCT {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for NFCT {}
impl NFCT {
#[doc = r"Pointer to the register block"]
pub const PTR: *const nfct::RegisterBlock = 0x4000_5000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const nfct::RegisterBlock {
Self::PTR
}
}
impl Deref for NFCT {
type Target = nfct::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for NFCT {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("NFCT").finish()
}
}
#[doc = "NFC-A compatible radio"]
pub mod nfct;
#[doc = "GPIO Tasks and Events"]
pub struct GPIOTE {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for GPIOTE {}
impl GPIOTE {
#[doc = r"Pointer to the register block"]
pub const PTR: *const gpiote::RegisterBlock = 0x4000_6000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const gpiote::RegisterBlock {
Self::PTR
}
}
impl Deref for GPIOTE {
type Target = gpiote::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for GPIOTE {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("GPIOTE").finish()
}
}
#[doc = "GPIO Tasks and Events"]
pub mod gpiote;
#[doc = "Successive approximation register (SAR) analog-to-digital converter"]
pub struct SAADC {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SAADC {}
impl SAADC {
#[doc = r"Pointer to the register block"]
pub const PTR: *const saadc::RegisterBlock = 0x4000_7000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const saadc::RegisterBlock {
Self::PTR
}
}
impl Deref for SAADC {
type Target = saadc::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SAADC {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SAADC").finish()
}
}
#[doc = "Successive approximation register (SAR) analog-to-digital converter"]
pub mod saadc;
#[doc = "Timer/Counter 0"]
pub struct TIMER0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TIMER0 {}
impl TIMER0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const timer0::RegisterBlock = 0x4000_8000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const timer0::RegisterBlock {
Self::PTR
}
}
impl Deref for TIMER0 {
type Target = timer0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TIMER0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TIMER0").finish()
}
}
#[doc = "Timer/Counter 0"]
pub mod timer0;
#[doc = "Timer/Counter 1"]
pub struct TIMER1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TIMER1 {}
impl TIMER1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const timer0::RegisterBlock = 0x4000_9000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const timer0::RegisterBlock {
Self::PTR
}
}
impl Deref for TIMER1 {
type Target = timer0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TIMER1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TIMER1").finish()
}
}
#[doc = "Timer/Counter 1"]
pub use timer0 as timer1;
#[doc = "Timer/Counter 2"]
pub struct TIMER2 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TIMER2 {}
impl TIMER2 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const timer0::RegisterBlock = 0x4000_a000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const timer0::RegisterBlock {
Self::PTR
}
}
impl Deref for TIMER2 {
type Target = timer0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TIMER2 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TIMER2").finish()
}
}
#[doc = "Timer/Counter 2"]
pub use timer0 as timer2;
#[doc = "Real time counter 0"]
pub struct RTC0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for RTC0 {}
impl RTC0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const rtc0::RegisterBlock = 0x4000_b000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const rtc0::RegisterBlock {
Self::PTR
}
}
impl Deref for RTC0 {
type Target = rtc0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for RTC0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("RTC0").finish()
}
}
#[doc = "Real time counter 0"]
pub mod rtc0;
#[doc = "Temperature Sensor"]
pub struct TEMP {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TEMP {}
impl TEMP {
#[doc = r"Pointer to the register block"]
pub const PTR: *const temp::RegisterBlock = 0x4000_c000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const temp::RegisterBlock {
Self::PTR
}
}
impl Deref for TEMP {
type Target = temp::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TEMP {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TEMP").finish()
}
}
#[doc = "Temperature Sensor"]
pub mod temp;
#[doc = "Random Number Generator"]
pub struct RNG {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for RNG {}
impl RNG {
#[doc = r"Pointer to the register block"]
pub const PTR: *const rng::RegisterBlock = 0x4000_d000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const rng::RegisterBlock {
Self::PTR
}
}
impl Deref for RNG {
type Target = rng::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for RNG {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("RNG").finish()
}
}
#[doc = "Random Number Generator"]
pub mod rng;
#[doc = "AES ECB Mode Encryption"]
pub struct ECB {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for ECB {}
impl ECB {
#[doc = r"Pointer to the register block"]
pub const PTR: *const ecb::RegisterBlock = 0x4000_e000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const ecb::RegisterBlock {
Self::PTR
}
}
impl Deref for ECB {
type Target = ecb::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for ECB {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("ECB").finish()
}
}
#[doc = "AES ECB Mode Encryption"]
pub mod ecb;
#[doc = "Accelerated Address Resolver"]
pub struct AAR {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for AAR {}
impl AAR {
#[doc = r"Pointer to the register block"]
pub const PTR: *const aar::RegisterBlock = 0x4000_f000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const aar::RegisterBlock {
Self::PTR
}
}
impl Deref for AAR {
type Target = aar::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for AAR {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("AAR").finish()
}
}
#[doc = "Accelerated Address Resolver"]
pub mod aar;
#[doc = "AES CCM Mode Encryption"]
pub struct CCM {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for CCM {}
impl CCM {
#[doc = r"Pointer to the register block"]
pub const PTR: *const ccm::RegisterBlock = 0x4000_f000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const ccm::RegisterBlock {
Self::PTR
}
}
impl Deref for CCM {
type Target = ccm::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for CCM {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("CCM").finish()
}
}
#[doc = "AES CCM Mode Encryption"]
pub mod ccm;
#[doc = "Watchdog Timer"]
pub struct WDT {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for WDT {}
impl WDT {
#[doc = r"Pointer to the register block"]
pub const PTR: *const wdt::RegisterBlock = 0x4001_0000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const wdt::RegisterBlock {
Self::PTR
}
}
impl Deref for WDT {
type Target = wdt::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for WDT {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("WDT").finish()
}
}
#[doc = "Watchdog Timer"]
pub mod wdt;
#[doc = "Real time counter 1"]
pub struct RTC1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for RTC1 {}
impl RTC1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const rtc0::RegisterBlock = 0x4001_1000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const rtc0::RegisterBlock {
Self::PTR
}
}
impl Deref for RTC1 {
type Target = rtc0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for RTC1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("RTC1").finish()
}
}
#[doc = "Real time counter 1"]
pub use rtc0 as rtc1;
#[doc = "Quadrature Decoder"]
pub struct QDEC {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for QDEC {}
impl QDEC {
#[doc = r"Pointer to the register block"]
pub const PTR: *const qdec::RegisterBlock = 0x4001_2000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const qdec::RegisterBlock {
Self::PTR
}
}
impl Deref for QDEC {
type Target = qdec::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for QDEC {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("QDEC").finish()
}
}
#[doc = "Quadrature Decoder"]
pub mod qdec;
#[doc = "Comparator"]
pub struct COMP {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for COMP {}
impl COMP {
#[doc = r"Pointer to the register block"]
pub const PTR: *const comp::RegisterBlock = 0x4001_3000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const comp::RegisterBlock {
Self::PTR
}
}
impl Deref for COMP {
type Target = comp::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for COMP {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("COMP").finish()
}
}
#[doc = "Comparator"]
pub mod comp;
#[doc = "Low Power Comparator"]
pub struct LPCOMP {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for LPCOMP {}
impl LPCOMP {
#[doc = r"Pointer to the register block"]
pub const PTR: *const lpcomp::RegisterBlock = 0x4001_3000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const lpcomp::RegisterBlock {
Self::PTR
}
}
impl Deref for LPCOMP {
type Target = lpcomp::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for LPCOMP {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("LPCOMP").finish()
}
}
#[doc = "Low Power Comparator"]
pub mod lpcomp;
#[doc = "Event Generator Unit 0"]
pub struct EGU0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for EGU0 {}
impl EGU0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const egu0::RegisterBlock = 0x4001_4000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const egu0::RegisterBlock {
Self::PTR
}
}
impl Deref for EGU0 {
type Target = egu0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for EGU0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("EGU0").finish()
}
}
#[doc = "Event Generator Unit 0"]
pub mod egu0;
#[doc = "Software interrupt 0"]
pub struct SWI0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SWI0 {}
impl SWI0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const swi0::RegisterBlock = 0x4001_4000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const swi0::RegisterBlock {
Self::PTR
}
}
impl Deref for SWI0 {
type Target = swi0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SWI0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SWI0").finish()
}
}
#[doc = "Software interrupt 0"]
pub mod swi0;
#[doc = "Event Generator Unit 1"]
pub struct EGU1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for EGU1 {}
impl EGU1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const egu0::RegisterBlock = 0x4001_5000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const egu0::RegisterBlock {
Self::PTR
}
}
impl Deref for EGU1 {
type Target = egu0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for EGU1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("EGU1").finish()
}
}
#[doc = "Event Generator Unit 1"]
pub use egu0 as egu1;
#[doc = "Software interrupt 1"]
pub struct SWI1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SWI1 {}
impl SWI1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const swi0::RegisterBlock = 0x4001_5000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const swi0::RegisterBlock {
Self::PTR
}
}
impl Deref for SWI1 {
type Target = swi0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SWI1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SWI1").finish()
}
}
#[doc = "Software interrupt 1"]
pub use swi0 as swi1;
#[doc = "Event Generator Unit 2"]
pub struct EGU2 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for EGU2 {}
impl EGU2 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const egu0::RegisterBlock = 0x4001_6000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const egu0::RegisterBlock {
Self::PTR
}
}
impl Deref for EGU2 {
type Target = egu0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for EGU2 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("EGU2").finish()
}
}
#[doc = "Event Generator Unit 2"]
pub use egu0 as egu2;
#[doc = "Software interrupt 2"]
pub struct SWI2 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SWI2 {}
impl SWI2 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const swi0::RegisterBlock = 0x4001_6000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const swi0::RegisterBlock {
Self::PTR
}
}
impl Deref for SWI2 {
type Target = swi0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SWI2 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SWI2").finish()
}
}
#[doc = "Software interrupt 2"]
pub use swi0 as swi2;
#[doc = "Event Generator Unit 3"]
pub struct EGU3 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for EGU3 {}
impl EGU3 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const egu0::RegisterBlock = 0x4001_7000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const egu0::RegisterBlock {
Self::PTR
}
}
impl Deref for EGU3 {
type Target = egu0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for EGU3 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("EGU3").finish()
}
}
#[doc = "Event Generator Unit 3"]
pub use egu0 as egu3;
#[doc = "Software interrupt 3"]
pub struct SWI3 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SWI3 {}
impl SWI3 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const swi0::RegisterBlock = 0x4001_7000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const swi0::RegisterBlock {
Self::PTR
}
}
impl Deref for SWI3 {
type Target = swi0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SWI3 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SWI3").finish()
}
}
#[doc = "Software interrupt 3"]
pub use swi0 as swi3;
#[doc = "Event Generator Unit 4"]
pub struct EGU4 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for EGU4 {}
impl EGU4 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const egu0::RegisterBlock = 0x4001_8000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const egu0::RegisterBlock {
Self::PTR
}
}
impl Deref for EGU4 {
type Target = egu0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for EGU4 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("EGU4").finish()
}
}
#[doc = "Event Generator Unit 4"]
pub use egu0 as egu4;
#[doc = "Software interrupt 4"]
pub struct SWI4 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SWI4 {}
impl SWI4 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const swi0::RegisterBlock = 0x4001_8000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const swi0::RegisterBlock {
Self::PTR
}
}
impl Deref for SWI4 {
type Target = swi0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SWI4 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SWI4").finish()
}
}
#[doc = "Software interrupt 4"]
pub use swi0 as swi4;
#[doc = "Event Generator Unit 5"]
pub struct EGU5 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for EGU5 {}
impl EGU5 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const egu0::RegisterBlock = 0x4001_9000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const egu0::RegisterBlock {
Self::PTR
}
}
impl Deref for EGU5 {
type Target = egu0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for EGU5 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("EGU5").finish()
}
}
#[doc = "Event Generator Unit 5"]
pub use egu0 as egu5;
#[doc = "Software interrupt 5"]
pub struct SWI5 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SWI5 {}
impl SWI5 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const swi0::RegisterBlock = 0x4001_9000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const swi0::RegisterBlock {
Self::PTR
}
}
impl Deref for SWI5 {
type Target = swi0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SWI5 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SWI5").finish()
}
}
#[doc = "Software interrupt 5"]
pub use swi0 as swi5;
#[doc = "Timer/Counter 3"]
pub struct TIMER3 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TIMER3 {}
impl TIMER3 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const timer3::RegisterBlock = 0x4001_a000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const timer3::RegisterBlock {
Self::PTR
}
}
impl Deref for TIMER3 {
type Target = timer3::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TIMER3 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TIMER3").finish()
}
}
#[doc = "Timer/Counter 3"]
pub mod timer3;
#[doc = "Timer/Counter 4"]
pub struct TIMER4 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TIMER4 {}
impl TIMER4 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const timer3::RegisterBlock = 0x4001_b000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const timer3::RegisterBlock {
Self::PTR
}
}
impl Deref for TIMER4 {
type Target = timer3::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for TIMER4 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("TIMER4").finish()
}
}
#[doc = "Timer/Counter 4"]
pub use timer3 as timer4;
#[doc = "Pulse width modulation unit 0"]
pub struct PWM0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PWM0 {}
impl PWM0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const pwm0::RegisterBlock = 0x4001_c000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const pwm0::RegisterBlock {
Self::PTR
}
}
impl Deref for PWM0 {
type Target = pwm0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for PWM0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("PWM0").finish()
}
}
#[doc = "Pulse width modulation unit 0"]
pub mod pwm0;
#[doc = "Pulse Density Modulation (Digital Microphone) Interface"]
pub struct PDM {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PDM {}
impl PDM {
#[doc = r"Pointer to the register block"]
pub const PTR: *const pdm::RegisterBlock = 0x4001_d000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const pdm::RegisterBlock {
Self::PTR
}
}
impl Deref for PDM {
type Target = pdm::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for PDM {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("PDM").finish()
}
}
#[doc = "Pulse Density Modulation (Digital Microphone) Interface"]
pub mod pdm;
#[doc = "Access control lists"]
pub struct ACL {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for ACL {}
impl ACL {
#[doc = r"Pointer to the register block"]
pub const PTR: *const acl::RegisterBlock = 0x4001_e000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const acl::RegisterBlock {
Self::PTR
}
}
impl Deref for ACL {
type Target = acl::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for ACL {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("ACL").finish()
}
}
#[doc = "Access control lists"]
pub mod acl;
#[doc = "Non Volatile Memory Controller"]
pub struct NVMC {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for NVMC {}
impl NVMC {
#[doc = r"Pointer to the register block"]
pub const PTR: *const nvmc::RegisterBlock = 0x4001_e000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const nvmc::RegisterBlock {
Self::PTR
}
}
impl Deref for NVMC {
type Target = nvmc::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for NVMC {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("NVMC").finish()
}
}
#[doc = "Non Volatile Memory Controller"]
pub mod nvmc;
#[doc = "Programmable Peripheral Interconnect"]
pub struct PPI {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PPI {}
impl PPI {
#[doc = r"Pointer to the register block"]
pub const PTR: *const ppi::RegisterBlock = 0x4001_f000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const ppi::RegisterBlock {
Self::PTR
}
}
impl Deref for PPI {
type Target = ppi::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for PPI {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("PPI").finish()
}
}
#[doc = "Programmable Peripheral Interconnect"]
pub mod ppi;
#[doc = "Memory Watch Unit"]
pub struct MWU {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for MWU {}
impl MWU {
#[doc = r"Pointer to the register block"]
pub const PTR: *const mwu::RegisterBlock = 0x4002_0000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const mwu::RegisterBlock {
Self::PTR
}
}
impl Deref for MWU {
type Target = mwu::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for MWU {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("MWU").finish()
}
}
#[doc = "Memory Watch Unit"]
pub mod mwu;
#[doc = "Pulse width modulation unit 1"]
pub struct PWM1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PWM1 {}
impl PWM1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const pwm0::RegisterBlock = 0x4002_1000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const pwm0::RegisterBlock {
Self::PTR
}
}
impl Deref for PWM1 {
type Target = pwm0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for PWM1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("PWM1").finish()
}
}
#[doc = "Pulse width modulation unit 1"]
pub use pwm0 as pwm1;
#[doc = "Pulse width modulation unit 2"]
pub struct PWM2 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PWM2 {}
impl PWM2 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const pwm0::RegisterBlock = 0x4002_2000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const pwm0::RegisterBlock {
Self::PTR
}
}
impl Deref for PWM2 {
type Target = pwm0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for PWM2 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("PWM2").finish()
}
}
#[doc = "Pulse width modulation unit 2"]
pub use pwm0 as pwm2;
#[doc = "Serial Peripheral Interface 2"]
pub struct SPI2 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SPI2 {}
impl SPI2 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const spi0::RegisterBlock = 0x4002_3000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const spi0::RegisterBlock {
Self::PTR
}
}
impl Deref for SPI2 {
type Target = spi0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SPI2 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SPI2").finish()
}
}
#[doc = "Serial Peripheral Interface 2"]
pub use spi0 as spi2;
#[doc = "Serial Peripheral Interface Master with EasyDMA 2"]
pub struct SPIM2 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SPIM2 {}
impl SPIM2 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const spim0::RegisterBlock = 0x4002_3000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const spim0::RegisterBlock {
Self::PTR
}
}
impl Deref for SPIM2 {
type Target = spim0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SPIM2 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SPIM2").finish()
}
}
#[doc = "Serial Peripheral Interface Master with EasyDMA 2"]
pub use spim0 as spim2;
#[doc = "SPI Slave 2"]
pub struct SPIS2 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SPIS2 {}
impl SPIS2 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const spis0::RegisterBlock = 0x4002_3000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const spis0::RegisterBlock {
Self::PTR
}
}
impl Deref for SPIS2 {
type Target = spis0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SPIS2 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SPIS2").finish()
}
}
#[doc = "SPI Slave 2"]
pub use spis0 as spis2;
#[doc = "Real time counter 2"]
pub struct RTC2 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for RTC2 {}
impl RTC2 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const rtc0::RegisterBlock = 0x4002_4000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const rtc0::RegisterBlock {
Self::PTR
}
}
impl Deref for RTC2 {
type Target = rtc0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for RTC2 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("RTC2").finish()
}
}
#[doc = "Real time counter 2"]
pub use rtc0 as rtc2;
#[doc = "Inter-IC Sound"]
pub struct I2S {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for I2S {}
impl I2S {
#[doc = r"Pointer to the register block"]
pub const PTR: *const i2s::RegisterBlock = 0x4002_5000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const i2s::RegisterBlock {
Self::PTR
}
}
impl Deref for I2S {
type Target = i2s::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for I2S {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("I2S").finish()
}
}
#[doc = "Inter-IC Sound"]
pub mod i2s;
#[doc = "Universal serial bus device"]
pub struct USBD {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for USBD {}
impl USBD {
#[doc = r"Pointer to the register block"]
pub const PTR: *const usbd::RegisterBlock = 0x4002_7000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const usbd::RegisterBlock {
Self::PTR
}
}
impl Deref for USBD {
type Target = usbd::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for USBD {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("USBD").finish()
}
}
#[doc = "Universal serial bus device"]
pub mod usbd;
#[doc = "UART with EasyDMA 1"]
pub struct UARTE1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for UARTE1 {}
impl UARTE1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const uarte0::RegisterBlock = 0x4002_8000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const uarte0::RegisterBlock {
Self::PTR
}
}
impl Deref for UARTE1 {
type Target = uarte0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for UARTE1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("UARTE1").finish()
}
}
#[doc = "UART with EasyDMA 1"]
pub use uarte0 as uarte1;
#[doc = "External flash interface"]
pub struct QSPI {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for QSPI {}
impl QSPI {
#[doc = r"Pointer to the register block"]
pub const PTR: *const qspi::RegisterBlock = 0x4002_9000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const qspi::RegisterBlock {
Self::PTR
}
}
impl Deref for QSPI {
type Target = qspi::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for QSPI {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("QSPI").finish()
}
}
#[doc = "External flash interface"]
pub mod qspi;
#[doc = "Pulse width modulation unit 3"]
pub struct PWM3 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PWM3 {}
impl PWM3 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const pwm0::RegisterBlock = 0x4002_d000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const pwm0::RegisterBlock {
Self::PTR
}
}
impl Deref for PWM3 {
type Target = pwm0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for PWM3 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("PWM3").finish()
}
}
#[doc = "Pulse width modulation unit 3"]
pub use pwm0 as pwm3;
#[doc = "Serial Peripheral Interface Master with EasyDMA 3"]
pub struct SPIM3 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SPIM3 {}
impl SPIM3 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const spim0::RegisterBlock = 0x4002_f000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const spim0::RegisterBlock {
Self::PTR
}
}
impl Deref for SPIM3 {
type Target = spim0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for SPIM3 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("SPIM3").finish()
}
}
#[doc = "Serial Peripheral Interface Master with EasyDMA 3"]
pub use spim0 as spim3;
#[doc = "GPIO Port 1"]
pub struct P0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for P0 {}
impl P0 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const p0::RegisterBlock = 0x5000_0000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const p0::RegisterBlock {
Self::PTR
}
}
impl Deref for P0 {
type Target = p0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for P0 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("P0").finish()
}
}
#[doc = "GPIO Port 1"]
pub mod p0;
#[doc = "GPIO Port 2"]
pub struct P1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for P1 {}
impl P1 {
#[doc = r"Pointer to the register block"]
pub const PTR: *const p0::RegisterBlock = 0x5000_0300 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const p0::RegisterBlock {
Self::PTR
}
}
impl Deref for P1 {
type Target = p0::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for P1 {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("P1").finish()
}
}
#[doc = "GPIO Port 2"]
pub use p0 as p1;
#[doc = "CRYPTOCELL HOST_RGF interface"]
pub struct CC_HOST_RGF {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for CC_HOST_RGF {}
impl CC_HOST_RGF {
#[doc = r"Pointer to the register block"]
pub const PTR: *const cc_host_rgf::RegisterBlock = 0x5002_a000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const cc_host_rgf::RegisterBlock {
Self::PTR
}
}
impl Deref for CC_HOST_RGF {
type Target = cc_host_rgf::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for CC_HOST_RGF {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("CC_HOST_RGF").finish()
}
}
#[doc = "CRYPTOCELL HOST_RGF interface"]
pub mod cc_host_rgf;
#[doc = "ARM TrustZone CryptoCell register interface"]
pub struct CRYPTOCELL {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for CRYPTOCELL {}
impl CRYPTOCELL {
#[doc = r"Pointer to the register block"]
pub const PTR: *const cryptocell::RegisterBlock = 0x5002_a000 as *const _;
#[doc = r"Return the pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const cryptocell::RegisterBlock {
Self::PTR
}
}
impl Deref for CRYPTOCELL {
type Target = cryptocell::RegisterBlock;
#[inline(always)]
fn deref(&self) -> &Self::Target {
unsafe { &*Self::PTR }
}
}
impl core::fmt::Debug for CRYPTOCELL {
fn fmt(&self, f: &mut core::fmt::Formatter) -> core::fmt::Result {
f.debug_struct("CRYPTOCELL").finish()
}
}
#[doc = "ARM TrustZone CryptoCell register interface"]
pub mod cryptocell;
#[no_mangle]
static mut DEVICE_PERIPHERALS: bool = false;
#[doc = r"All the peripherals"]
#[allow(non_snake_case)]
pub struct Peripherals {
#[doc = "FICR"]
pub FICR: FICR,
#[doc = "UICR"]
pub UICR: UICR,
#[doc = "CLOCK"]
pub CLOCK: CLOCK,
#[doc = "POWER"]
pub POWER: POWER,
#[doc = "RADIO"]
pub RADIO: RADIO,
#[doc = "UART0"]
pub UART0: UART0,
#[doc = "UARTE0"]
pub UARTE0: UARTE0,
#[doc = "SPI0"]
pub SPI0: SPI0,
#[doc = "SPIM0"]
pub SPIM0: SPIM0,
#[doc = "SPIS0"]
pub SPIS0: SPIS0,
#[doc = "TWI0"]
pub TWI0: TWI0,
#[doc = "TWIM0"]
pub TWIM0: TWIM0,
#[doc = "TWIS0"]
pub TWIS0: TWIS0,
#[doc = "SPI1"]
pub SPI1: SPI1,
#[doc = "SPIM1"]
pub SPIM1: SPIM1,
#[doc = "SPIS1"]
pub SPIS1: SPIS1,
#[doc = "TWI1"]
pub TWI1: TWI1,
#[doc = "TWIM1"]
pub TWIM1: TWIM1,
#[doc = "TWIS1"]
pub TWIS1: TWIS1,
#[doc = "NFCT"]
pub NFCT: NFCT,
#[doc = "GPIOTE"]
pub GPIOTE: GPIOTE,
#[doc = "SAADC"]
pub SAADC: SAADC,
#[doc = "TIMER0"]
pub TIMER0: TIMER0,
#[doc = "TIMER1"]
pub TIMER1: TIMER1,
#[doc = "TIMER2"]
pub TIMER2: TIMER2,
#[doc = "RTC0"]
pub RTC0: RTC0,
#[doc = "TEMP"]
pub TEMP: TEMP,
#[doc = "RNG"]
pub RNG: RNG,
#[doc = "ECB"]
pub ECB: ECB,
#[doc = "AAR"]
pub AAR: AAR,
#[doc = "CCM"]
pub CCM: CCM,
#[doc = "WDT"]
pub WDT: WDT,
#[doc = "RTC1"]
pub RTC1: RTC1,
#[doc = "QDEC"]
pub QDEC: QDEC,
#[doc = "COMP"]
pub COMP: COMP,
#[doc = "LPCOMP"]
pub LPCOMP: LPCOMP,
#[doc = "EGU0"]
pub EGU0: EGU0,
#[doc = "SWI0"]
pub SWI0: SWI0,
#[doc = "EGU1"]
pub EGU1: EGU1,
#[doc = "SWI1"]
pub SWI1: SWI1,
#[doc = "EGU2"]
pub EGU2: EGU2,
#[doc = "SWI2"]
pub SWI2: SWI2,
#[doc = "EGU3"]
pub EGU3: EGU3,
#[doc = "SWI3"]
pub SWI3: SWI3,
#[doc = "EGU4"]
pub EGU4: EGU4,
#[doc = "SWI4"]
pub SWI4: SWI4,
#[doc = "EGU5"]
pub EGU5: EGU5,
#[doc = "SWI5"]
pub SWI5: SWI5,
#[doc = "TIMER3"]
pub TIMER3: TIMER3,
#[doc = "TIMER4"]
pub TIMER4: TIMER4,
#[doc = "PWM0"]
pub PWM0: PWM0,
#[doc = "PDM"]
pub PDM: PDM,
#[doc = "ACL"]
pub ACL: ACL,
#[doc = "NVMC"]
pub NVMC: NVMC,
#[doc = "PPI"]
pub PPI: PPI,
#[doc = "MWU"]
pub MWU: MWU,
#[doc = "PWM1"]
pub PWM1: PWM1,
#[doc = "PWM2"]
pub PWM2: PWM2,
#[doc = "SPI2"]
pub SPI2: SPI2,
#[doc = "SPIM2"]
pub SPIM2: SPIM2,
#[doc = "SPIS2"]
pub SPIS2: SPIS2,
#[doc = "RTC2"]
pub RTC2: RTC2,
#[doc = "I2S"]
pub I2S: I2S,
#[doc = "USBD"]
pub USBD: USBD,
#[doc = "UARTE1"]
pub UARTE1: UARTE1,
#[doc = "QSPI"]
pub QSPI: QSPI,
#[doc = "PWM3"]
pub PWM3: PWM3,
#[doc = "SPIM3"]
pub SPIM3: SPIM3,
#[doc = "P0"]
pub P0: P0,
#[doc = "P1"]
pub P1: P1,
#[doc = "CC_HOST_RGF"]
pub CC_HOST_RGF: CC_HOST_RGF,
#[doc = "CRYPTOCELL"]
pub CRYPTOCELL: CRYPTOCELL,
}
impl Peripherals {
#[doc = r"Returns all the peripherals *once*"]
#[inline]
pub fn take() -> Option<Self> {
cortex_m::interrupt::free(|_| {
if unsafe { DEVICE_PERIPHERALS } {
None
} else {
Some(unsafe { Peripherals::steal() })
}
})
}
#[doc = r"Unchecked version of `Peripherals::take`"]
#[inline]
pub unsafe fn steal() -> Self {
DEVICE_PERIPHERALS = true;
Peripherals {
FICR: FICR {
_marker: PhantomData,
},
UICR: UICR {
_marker: PhantomData,
},
CLOCK: CLOCK {
_marker: PhantomData,
},
POWER: POWER {
_marker: PhantomData,
},
RADIO: RADIO {
_marker: PhantomData,
},
UART0: UART0 {
_marker: PhantomData,
},
UARTE0: UARTE0 {
_marker: PhantomData,
},
SPI0: SPI0 {
_marker: PhantomData,
},
SPIM0: SPIM0 {
_marker: PhantomData,
},
SPIS0: SPIS0 {
_marker: PhantomData,
},
TWI0: TWI0 {
_marker: PhantomData,
},
TWIM0: TWIM0 {
_marker: PhantomData,
},
TWIS0: TWIS0 {
_marker: PhantomData,
},
SPI1: SPI1 {
_marker: PhantomData,
},
SPIM1: SPIM1 {
_marker: PhantomData,
},
SPIS1: SPIS1 {
_marker: PhantomData,
},
TWI1: TWI1 {
_marker: PhantomData,
},
TWIM1: TWIM1 {
_marker: PhantomData,
},
TWIS1: TWIS1 {
_marker: PhantomData,
},
NFCT: NFCT {
_marker: PhantomData,
},
GPIOTE: GPIOTE {
_marker: PhantomData,
},
SAADC: SAADC {
_marker: PhantomData,
},
TIMER0: TIMER0 {
_marker: PhantomData,
},
TIMER1: TIMER1 {
_marker: PhantomData,
},
TIMER2: TIMER2 {
_marker: PhantomData,
},
RTC0: RTC0 {
_marker: PhantomData,
},
TEMP: TEMP {
_marker: PhantomData,
},
RNG: RNG {
_marker: PhantomData,
},
ECB: ECB {
_marker: PhantomData,
},
AAR: AAR {
_marker: PhantomData,
},
CCM: CCM {
_marker: PhantomData,
},
WDT: WDT {
_marker: PhantomData,
},
RTC1: RTC1 {
_marker: PhantomData,
},
QDEC: QDEC {
_marker: PhantomData,
},
COMP: COMP {
_marker: PhantomData,
},
LPCOMP: LPCOMP {
_marker: PhantomData,
},
EGU0: EGU0 {
_marker: PhantomData,
},
SWI0: SWI0 {
_marker: PhantomData,
},
EGU1: EGU1 {
_marker: PhantomData,
},
SWI1: SWI1 {
_marker: PhantomData,
},
EGU2: EGU2 {
_marker: PhantomData,
},
SWI2: SWI2 {
_marker: PhantomData,
},
EGU3: EGU3 {
_marker: PhantomData,
},
SWI3: SWI3 {
_marker: PhantomData,
},
EGU4: EGU4 {
_marker: PhantomData,
},
SWI4: SWI4 {
_marker: PhantomData,
},
EGU5: EGU5 {
_marker: PhantomData,
},
SWI5: SWI5 {
_marker: PhantomData,
},
TIMER3: TIMER3 {
_marker: PhantomData,
},
TIMER4: TIMER4 {
_marker: PhantomData,
},
PWM0: PWM0 {
_marker: PhantomData,
},
PDM: PDM {
_marker: PhantomData,
},
ACL: ACL {
_marker: PhantomData,
},
NVMC: NVMC {
_marker: PhantomData,
},
PPI: PPI {
_marker: PhantomData,
},
MWU: MWU {
_marker: PhantomData,
},
PWM1: PWM1 {
_marker: PhantomData,
},
PWM2: PWM2 {
_marker: PhantomData,
},
SPI2: SPI2 {
_marker: PhantomData,
},
SPIM2: SPIM2 {
_marker: PhantomData,
},
SPIS2: SPIS2 {
_marker: PhantomData,
},
RTC2: RTC2 {
_marker: PhantomData,
},
I2S: I2S {
_marker: PhantomData,
},
USBD: USBD {
_marker: PhantomData,
},
UARTE1: UARTE1 {
_marker: PhantomData,
},
QSPI: QSPI {
_marker: PhantomData,
},
PWM3: PWM3 {
_marker: PhantomData,
},
SPIM3: SPIM3 {
_marker: PhantomData,
},
P0: P0 {
_marker: PhantomData,
},
P1: P1 {
_marker: PhantomData,
},
CC_HOST_RGF: CC_HOST_RGF {
_marker: PhantomData,
},
CRYPTOCELL: CRYPTOCELL {
_marker: PhantomData,
},
}
}
}