#![doc = "Peripheral access API for ATSAMD11C14A microcontrollers (generated using svd2rust v0.16.1)\n\nYou can find an overview of the API [here].\n\n[here]: https://docs.rs/svd2rust/0.16.1/svd2rust/#peripheral-api"]
#![deny(missing_docs)]
#![deny(warnings)]
#![allow(non_camel_case_types)]
#![no_std]
extern crate bare_metal;
extern crate cortex_m;
#[cfg(feature = "rt")]
extern crate cortex_m_rt;
extern crate vcell;
use core::marker::PhantomData;
use core::ops::Deref;
#[doc = r"Number available in the NVIC for configuring priority"]
pub const NVIC_PRIO_BITS: u8 = 2;
#[cfg(feature = "rt")]
extern "C" {
fn PM();
fn SYSCTRL();
fn WDT();
fn RTC();
fn EIC();
fn NVMCTRL();
fn DMAC();
fn USB();
fn EVSYS();
fn SERCOM0();
fn SERCOM1();
fn TCC0();
fn TC1();
fn TC2();
fn ADC();
fn AC();
fn DAC();
}
#[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; 18] = [
Vector { _handler: PM },
Vector { _handler: SYSCTRL },
Vector { _handler: WDT },
Vector { _handler: RTC },
Vector { _handler: EIC },
Vector { _handler: NVMCTRL },
Vector { _handler: DMAC },
Vector { _handler: USB },
Vector { _handler: EVSYS },
Vector { _handler: SERCOM0 },
Vector { _handler: SERCOM1 },
Vector { _reserved: 0 },
Vector { _handler: TCC0 },
Vector { _handler: TC1 },
Vector { _handler: TC2 },
Vector { _handler: ADC },
Vector { _handler: AC },
Vector { _handler: DAC },
];
#[doc = r"Enumeration of all the interrupts"]
#[derive(Copy, Clone, Debug)]
pub enum Interrupt {
#[doc = "0 - PM"]
PM,
#[doc = "1 - SYSCTRL"]
SYSCTRL,
#[doc = "2 - WDT"]
WDT,
#[doc = "3 - RTC"]
RTC,
#[doc = "4 - EIC"]
EIC,
#[doc = "5 - NVMCTRL"]
NVMCTRL,
#[doc = "6 - DMAC"]
DMAC,
#[doc = "7 - USB"]
USB,
#[doc = "8 - EVSYS"]
EVSYS,
#[doc = "9 - SERCOM0"]
SERCOM0,
#[doc = "10 - SERCOM1"]
SERCOM1,
#[doc = "12 - TCC0"]
TCC0,
#[doc = "13 - TC1"]
TC1,
#[doc = "14 - TC2"]
TC2,
#[doc = "15 - ADC"]
ADC,
#[doc = "16 - AC"]
AC,
#[doc = "17 - DAC"]
DAC,
}
unsafe impl bare_metal::Nr for Interrupt {
#[inline]
fn nr(&self) -> u8 {
match *self {
Interrupt::PM => 0,
Interrupt::SYSCTRL => 1,
Interrupt::WDT => 2,
Interrupt::RTC => 3,
Interrupt::EIC => 4,
Interrupt::NVMCTRL => 5,
Interrupt::DMAC => 6,
Interrupt::USB => 7,
Interrupt::EVSYS => 8,
Interrupt::SERCOM0 => 9,
Interrupt::SERCOM1 => 10,
Interrupt::TCC0 => 12,
Interrupt::TC1 => 13,
Interrupt::TC2 => 14,
Interrupt::ADC => 15,
Interrupt::AC => 16,
Interrupt::DAC => 17,
}
}
}
#[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, 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;
#[doc = "Analog Comparators"]
pub struct AC {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for AC {}
impl AC {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const ac::RegisterBlock {
0x4200_2400 as *const _
}
}
impl Deref for AC {
type Target = ac::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*AC::ptr() }
}
}
#[doc = "Analog Comparators"]
pub mod ac;
#[doc = "Analog Digital Converter"]
pub struct ADC {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for ADC {}
impl ADC {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const adc::RegisterBlock {
0x4200_2000 as *const _
}
}
impl Deref for ADC {
type Target = adc::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*ADC::ptr() }
}
}
#[doc = "Analog Digital Converter"]
pub mod adc;
#[doc = "Digital Analog Converter"]
pub struct DAC {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for DAC {}
impl DAC {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const dac::RegisterBlock {
0x4200_2800 as *const _
}
}
impl Deref for DAC {
type Target = dac::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*DAC::ptr() }
}
}
#[doc = "Digital Analog Converter"]
pub mod dac;
#[doc = "Direct Memory Access Controller"]
pub struct DMAC {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for DMAC {}
impl DMAC {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const dmac::RegisterBlock {
0x4100_4800 as *const _
}
}
impl Deref for DMAC {
type Target = dmac::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*DMAC::ptr() }
}
}
#[doc = "Direct Memory Access Controller"]
pub mod dmac;
#[doc = "Device Service Unit"]
pub struct DSU {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for DSU {}
impl DSU {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const dsu::RegisterBlock {
0x4100_2000 as *const _
}
}
impl Deref for DSU {
type Target = dsu::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*DSU::ptr() }
}
}
#[doc = "Device Service Unit"]
pub mod dsu;
#[doc = "External Interrupt Controller"]
pub struct EIC {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for EIC {}
impl EIC {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const eic::RegisterBlock {
0x4000_1800 as *const _
}
}
impl Deref for EIC {
type Target = eic::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*EIC::ptr() }
}
}
#[doc = "External Interrupt Controller"]
pub mod eic;
#[doc = "Event System Interface"]
pub struct EVSYS {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for EVSYS {}
impl EVSYS {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const evsys::RegisterBlock {
0x4200_0400 as *const _
}
}
impl Deref for EVSYS {
type Target = evsys::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*EVSYS::ptr() }
}
}
#[doc = "Event System Interface"]
pub mod evsys;
#[doc = "Generic Clock Generator"]
pub struct GCLK {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for GCLK {}
impl GCLK {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const gclk::RegisterBlock {
0x4000_0c00 as *const _
}
}
impl Deref for GCLK {
type Target = gclk::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*GCLK::ptr() }
}
}
#[doc = "Generic Clock Generator"]
pub mod gclk;
#[doc = "HSB Matrix"]
pub struct HMATRIX {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for HMATRIX {}
impl HMATRIX {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const hmatrix::RegisterBlock {
0x4100_7000 as *const _
}
}
impl Deref for HMATRIX {
type Target = hmatrix::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*HMATRIX::ptr() }
}
}
#[doc = "HSB Matrix"]
pub mod hmatrix;
#[doc = "Cortex-M0+ Micro-Trace Buffer"]
pub struct MTB {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for MTB {}
impl MTB {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const mtb::RegisterBlock {
0x4100_6000 as *const _
}
}
impl Deref for MTB {
type Target = mtb::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*MTB::ptr() }
}
}
#[doc = "Cortex-M0+ Micro-Trace Buffer"]
pub mod mtb;
#[doc = "Non-Volatile Memory Controller"]
pub struct NVMCTRL {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for NVMCTRL {}
impl NVMCTRL {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const nvmctrl::RegisterBlock {
0x4100_4000 as *const _
}
}
impl Deref for NVMCTRL {
type Target = nvmctrl::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*NVMCTRL::ptr() }
}
}
#[doc = "Non-Volatile Memory Controller"]
pub mod nvmctrl;
#[doc = "Peripheral Access Controller 0"]
pub struct PAC0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PAC0 {}
impl PAC0 {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const pac0::RegisterBlock {
0x4000_0000 as *const _
}
}
impl Deref for PAC0 {
type Target = pac0::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*PAC0::ptr() }
}
}
#[doc = "Peripheral Access Controller 0"]
pub mod pac0;
#[doc = "Peripheral Access Controller 1"]
pub struct PAC1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PAC1 {}
impl PAC1 {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const pac0::RegisterBlock {
0x4100_0000 as *const _
}
}
impl Deref for PAC1 {
type Target = pac0::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*PAC1::ptr() }
}
}
#[doc = "Peripheral Access Controller 2"]
pub struct PAC2 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PAC2 {}
impl PAC2 {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const pac0::RegisterBlock {
0x4200_0000 as *const _
}
}
impl Deref for PAC2 {
type Target = pac0::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*PAC2::ptr() }
}
}
#[doc = "Power Manager"]
pub struct PM {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PM {}
impl PM {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const pm::RegisterBlock {
0x4000_0400 as *const _
}
}
impl Deref for PM {
type Target = pm::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*PM::ptr() }
}
}
#[doc = "Power Manager"]
pub mod pm;
#[doc = "Port Module"]
pub struct PORT {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PORT {}
impl PORT {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const port::RegisterBlock {
0x4100_4400 as *const _
}
}
impl Deref for PORT {
type Target = port::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*PORT::ptr() }
}
}
#[doc = "Port Module"]
pub mod port;
#[doc = "Port Module (IOBUS)"]
pub struct PORT_IOBUS {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for PORT_IOBUS {}
impl PORT_IOBUS {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const port::RegisterBlock {
0x6000_0000 as *const _
}
}
impl Deref for PORT_IOBUS {
type Target = port::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*PORT_IOBUS::ptr() }
}
}
#[doc = "Real-Time Counter"]
pub struct RTC {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for RTC {}
impl RTC {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const rtc::RegisterBlock {
0x4000_1400 as *const _
}
}
impl Deref for RTC {
type Target = rtc::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*RTC::ptr() }
}
}
#[doc = "Real-Time Counter"]
pub mod rtc;
#[doc = "Serial Communication Interface 0"]
pub struct SERCOM0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SERCOM0 {}
impl SERCOM0 {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const sercom0::RegisterBlock {
0x4200_0800 as *const _
}
}
impl Deref for SERCOM0 {
type Target = sercom0::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*SERCOM0::ptr() }
}
}
#[doc = "Serial Communication Interface 0"]
pub mod sercom0;
#[doc = "Serial Communication Interface 1"]
pub struct SERCOM1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SERCOM1 {}
impl SERCOM1 {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const sercom0::RegisterBlock {
0x4200_0c00 as *const _
}
}
impl Deref for SERCOM1 {
type Target = sercom0::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*SERCOM1::ptr() }
}
}
#[doc = "System Control"]
pub struct SYSCTRL {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for SYSCTRL {}
impl SYSCTRL {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const sysctrl::RegisterBlock {
0x4000_0800 as *const _
}
}
impl Deref for SYSCTRL {
type Target = sysctrl::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*SYSCTRL::ptr() }
}
}
#[doc = "System Control"]
pub mod sysctrl;
#[doc = "Basic Timer Counter 1"]
pub struct TC1 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TC1 {}
impl TC1 {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const tc1::RegisterBlock {
0x4200_1800 as *const _
}
}
impl Deref for TC1 {
type Target = tc1::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*TC1::ptr() }
}
}
#[doc = "Basic Timer Counter 1"]
pub mod tc1;
#[doc = "Basic Timer Counter 2"]
pub struct TC2 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TC2 {}
impl TC2 {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const tc1::RegisterBlock {
0x4200_1c00 as *const _
}
}
impl Deref for TC2 {
type Target = tc1::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*TC2::ptr() }
}
}
#[doc = "Timer Counter Control"]
pub struct TCC0 {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for TCC0 {}
impl TCC0 {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const tcc0::RegisterBlock {
0x4200_1400 as *const _
}
}
impl Deref for TCC0 {
type Target = tcc0::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*TCC0::ptr() }
}
}
#[doc = "Timer Counter Control"]
pub mod tcc0;
#[doc = "Universal Serial Bus"]
pub struct USB {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for USB {}
impl USB {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const usb::RegisterBlock {
0x4100_5000 as *const _
}
}
impl Deref for USB {
type Target = usb::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*USB::ptr() }
}
}
#[doc = "Universal Serial Bus"]
pub mod usb;
#[doc = "Watchdog Timer"]
pub struct WDT {
_marker: PhantomData<*const ()>,
}
unsafe impl Send for WDT {}
impl WDT {
#[doc = r"Returns a pointer to the register block"]
#[inline(always)]
pub const fn ptr() -> *const wdt::RegisterBlock {
0x4000_1000 as *const _
}
}
impl Deref for WDT {
type Target = wdt::RegisterBlock;
fn deref(&self) -> &Self::Target {
unsafe { &*WDT::ptr() }
}
}
#[doc = "Watchdog Timer"]
pub mod wdt;
#[no_mangle]
static mut DEVICE_PERIPHERALS: bool = false;
#[doc = r"All the peripherals"]
#[allow(non_snake_case)]
pub struct Peripherals {
#[doc = "AC"]
pub AC: AC,
#[doc = "ADC"]
pub ADC: ADC,
#[doc = "DAC"]
pub DAC: DAC,
#[doc = "DMAC"]
pub DMAC: DMAC,
#[doc = "DSU"]
pub DSU: DSU,
#[doc = "EIC"]
pub EIC: EIC,
#[doc = "EVSYS"]
pub EVSYS: EVSYS,
#[doc = "GCLK"]
pub GCLK: GCLK,
#[doc = "HMATRIX"]
pub HMATRIX: HMATRIX,
#[doc = "MTB"]
pub MTB: MTB,
#[doc = "NVMCTRL"]
pub NVMCTRL: NVMCTRL,
#[doc = "PAC0"]
pub PAC0: PAC0,
#[doc = "PAC1"]
pub PAC1: PAC1,
#[doc = "PAC2"]
pub PAC2: PAC2,
#[doc = "PM"]
pub PM: PM,
#[doc = "PORT"]
pub PORT: PORT,
#[doc = "PORT_IOBUS"]
pub PORT_IOBUS: PORT_IOBUS,
#[doc = "RTC"]
pub RTC: RTC,
#[doc = "SERCOM0"]
pub SERCOM0: SERCOM0,
#[doc = "SERCOM1"]
pub SERCOM1: SERCOM1,
#[doc = "SYSCTRL"]
pub SYSCTRL: SYSCTRL,
#[doc = "TC1"]
pub TC1: TC1,
#[doc = "TC2"]
pub TC2: TC2,
#[doc = "TCC0"]
pub TCC0: TCC0,
#[doc = "USB"]
pub USB: USB,
#[doc = "WDT"]
pub WDT: WDT,
}
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`"]
pub unsafe fn steal() -> Self {
DEVICE_PERIPHERALS = true;
Peripherals {
AC: AC {
_marker: PhantomData,
},
ADC: ADC {
_marker: PhantomData,
},
DAC: DAC {
_marker: PhantomData,
},
DMAC: DMAC {
_marker: PhantomData,
},
DSU: DSU {
_marker: PhantomData,
},
EIC: EIC {
_marker: PhantomData,
},
EVSYS: EVSYS {
_marker: PhantomData,
},
GCLK: GCLK {
_marker: PhantomData,
},
HMATRIX: HMATRIX {
_marker: PhantomData,
},
MTB: MTB {
_marker: PhantomData,
},
NVMCTRL: NVMCTRL {
_marker: PhantomData,
},
PAC0: PAC0 {
_marker: PhantomData,
},
PAC1: PAC1 {
_marker: PhantomData,
},
PAC2: PAC2 {
_marker: PhantomData,
},
PM: PM {
_marker: PhantomData,
},
PORT: PORT {
_marker: PhantomData,
},
PORT_IOBUS: PORT_IOBUS {
_marker: PhantomData,
},
RTC: RTC {
_marker: PhantomData,
},
SERCOM0: SERCOM0 {
_marker: PhantomData,
},
SERCOM1: SERCOM1 {
_marker: PhantomData,
},
SYSCTRL: SYSCTRL {
_marker: PhantomData,
},
TC1: TC1 {
_marker: PhantomData,
},
TC2: TC2 {
_marker: PhantomData,
},
TCC0: TCC0 {
_marker: PhantomData,
},
USB: USB {
_marker: PhantomData,
},
WDT: WDT {
_marker: PhantomData,
},
}
}
}