2021-03-29 02:11:32 +00:00
|
|
|
#![no_std]
|
2022-09-22 14:28:56 +00:00
|
|
|
#![cfg_attr(feature = "nightly", feature(type_alias_impl_trait))]
|
2021-03-29 02:11:32 +00:00
|
|
|
|
|
|
|
// This mod MUST go first, so that the others see its macros.
|
|
|
|
pub(crate) mod fmt;
|
|
|
|
|
2022-09-23 04:38:47 +00:00
|
|
|
mod intrinsics;
|
|
|
|
|
2021-03-29 02:11:32 +00:00
|
|
|
pub mod dma;
|
|
|
|
pub mod gpio;
|
2022-08-19 09:51:42 +00:00
|
|
|
pub mod i2c;
|
2022-06-11 03:08:57 +00:00
|
|
|
pub mod interrupt;
|
2022-09-23 04:38:47 +00:00
|
|
|
pub mod rom_data;
|
2022-09-16 04:45:27 +00:00
|
|
|
pub mod rtc;
|
2021-06-25 04:23:46 +00:00
|
|
|
pub mod spi;
|
2022-09-09 10:45:03 +00:00
|
|
|
#[cfg(feature = "time-driver")]
|
2021-07-12 00:45:42 +00:00
|
|
|
pub mod timer;
|
2021-03-29 02:11:32 +00:00
|
|
|
pub mod uart;
|
2022-08-24 21:46:07 +00:00
|
|
|
#[cfg(feature = "nightly")]
|
|
|
|
pub mod usb;
|
2021-03-29 02:11:32 +00:00
|
|
|
|
2021-06-25 01:38:03 +00:00
|
|
|
mod clocks;
|
2022-09-16 10:40:39 +00:00
|
|
|
pub mod flash;
|
2021-06-25 01:38:03 +00:00
|
|
|
mod reset;
|
|
|
|
|
2022-06-11 03:08:57 +00:00
|
|
|
// Reexports
|
|
|
|
|
2022-06-12 20:15:44 +00:00
|
|
|
pub use embassy_cortex_m::executor;
|
2022-08-17 16:49:55 +00:00
|
|
|
pub use embassy_cortex_m::interrupt::_export::interrupt;
|
2022-07-23 12:00:19 +00:00
|
|
|
pub use embassy_hal_common::{into_ref, Peripheral, PeripheralRef};
|
2022-06-11 03:08:57 +00:00
|
|
|
#[cfg(feature = "unstable-pac")]
|
|
|
|
pub use rp2040_pac2 as pac;
|
|
|
|
#[cfg(not(feature = "unstable-pac"))]
|
|
|
|
pub(crate) use rp2040_pac2 as pac;
|
|
|
|
|
2021-07-29 11:44:51 +00:00
|
|
|
embassy_hal_common::peripherals! {
|
2021-03-29 02:11:32 +00:00
|
|
|
PIN_0,
|
|
|
|
PIN_1,
|
|
|
|
PIN_2,
|
|
|
|
PIN_3,
|
|
|
|
PIN_4,
|
|
|
|
PIN_5,
|
|
|
|
PIN_6,
|
|
|
|
PIN_7,
|
|
|
|
PIN_8,
|
|
|
|
PIN_9,
|
|
|
|
PIN_10,
|
|
|
|
PIN_11,
|
|
|
|
PIN_12,
|
|
|
|
PIN_13,
|
|
|
|
PIN_14,
|
|
|
|
PIN_15,
|
|
|
|
PIN_16,
|
|
|
|
PIN_17,
|
|
|
|
PIN_18,
|
|
|
|
PIN_19,
|
|
|
|
PIN_20,
|
|
|
|
PIN_21,
|
|
|
|
PIN_22,
|
|
|
|
PIN_23,
|
|
|
|
PIN_24,
|
|
|
|
PIN_25,
|
|
|
|
PIN_26,
|
|
|
|
PIN_27,
|
|
|
|
PIN_28,
|
|
|
|
PIN_29,
|
|
|
|
PIN_QSPI_SCLK,
|
|
|
|
PIN_QSPI_SS,
|
|
|
|
PIN_QSPI_SD0,
|
|
|
|
PIN_QSPI_SD1,
|
|
|
|
PIN_QSPI_SD2,
|
|
|
|
PIN_QSPI_SD3,
|
|
|
|
|
|
|
|
UART0,
|
|
|
|
UART1,
|
|
|
|
|
2021-06-25 04:23:46 +00:00
|
|
|
SPI0,
|
|
|
|
SPI1,
|
|
|
|
|
2022-08-19 09:51:42 +00:00
|
|
|
I2C0,
|
|
|
|
I2C1,
|
|
|
|
|
2021-03-29 02:11:32 +00:00
|
|
|
DMA_CH0,
|
|
|
|
DMA_CH1,
|
|
|
|
DMA_CH2,
|
|
|
|
DMA_CH3,
|
|
|
|
DMA_CH4,
|
|
|
|
DMA_CH5,
|
|
|
|
DMA_CH6,
|
|
|
|
DMA_CH7,
|
|
|
|
DMA_CH8,
|
|
|
|
DMA_CH9,
|
|
|
|
DMA_CH10,
|
|
|
|
DMA_CH11,
|
2022-08-24 21:46:07 +00:00
|
|
|
|
|
|
|
USB,
|
2022-09-16 04:45:27 +00:00
|
|
|
|
|
|
|
RTC,
|
2022-10-26 08:01:52 +00:00
|
|
|
|
|
|
|
FLASH,
|
2021-03-29 02:11:32 +00:00
|
|
|
}
|
2021-05-11 23:57:01 +00:00
|
|
|
|
|
|
|
#[link_section = ".boot2"]
|
|
|
|
#[used]
|
|
|
|
static BOOT2: [u8; 256] = *include_bytes!("boot2.bin");
|
|
|
|
|
|
|
|
pub mod config {
|
|
|
|
#[non_exhaustive]
|
|
|
|
pub struct Config {}
|
|
|
|
|
|
|
|
impl Default for Config {
|
|
|
|
fn default() -> Self {
|
|
|
|
Self {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-18 12:11:20 +00:00
|
|
|
pub fn init(_config: config::Config) -> Peripherals {
|
2021-05-11 23:57:01 +00:00
|
|
|
// Do this first, so that it panics if user is calling `init` a second time
|
|
|
|
// before doing anything important.
|
|
|
|
let peripherals = Peripherals::take();
|
|
|
|
|
|
|
|
unsafe {
|
2021-06-25 01:38:03 +00:00
|
|
|
clocks::init();
|
2022-09-09 10:45:03 +00:00
|
|
|
#[cfg(feature = "time-driver")]
|
2021-07-12 00:45:42 +00:00
|
|
|
timer::init();
|
2022-08-23 10:28:17 +00:00
|
|
|
dma::init();
|
2021-05-11 23:57:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
peripherals
|
|
|
|
}
|
2022-08-24 21:46:07 +00:00
|
|
|
|
|
|
|
/// Extension trait for PAC regs, adding atomic xor/bitset/bitclear writes.
|
|
|
|
trait RegExt<T: Copy> {
|
|
|
|
unsafe fn write_xor<R>(&self, f: impl FnOnce(&mut T) -> R) -> R;
|
|
|
|
unsafe fn write_set<R>(&self, f: impl FnOnce(&mut T) -> R) -> R;
|
|
|
|
unsafe fn write_clear<R>(&self, f: impl FnOnce(&mut T) -> R) -> R;
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T: Default + Copy, A: pac::common::Write> RegExt<T> for pac::common::Reg<T, A> {
|
|
|
|
unsafe fn write_xor<R>(&self, f: impl FnOnce(&mut T) -> R) -> R {
|
|
|
|
let mut val = Default::default();
|
|
|
|
let res = f(&mut val);
|
|
|
|
let ptr = (self.ptr() as *mut u8).add(0x1000) as *mut T;
|
|
|
|
ptr.write_volatile(val);
|
|
|
|
res
|
|
|
|
}
|
|
|
|
|
|
|
|
unsafe fn write_set<R>(&self, f: impl FnOnce(&mut T) -> R) -> R {
|
|
|
|
let mut val = Default::default();
|
|
|
|
let res = f(&mut val);
|
|
|
|
let ptr = (self.ptr() as *mut u8).add(0x2000) as *mut T;
|
|
|
|
ptr.write_volatile(val);
|
|
|
|
res
|
|
|
|
}
|
|
|
|
|
|
|
|
unsafe fn write_clear<R>(&self, f: impl FnOnce(&mut T) -> R) -> R {
|
|
|
|
let mut val = Default::default();
|
|
|
|
let res = f(&mut val);
|
|
|
|
let ptr = (self.ptr() as *mut u8).add(0x3000) as *mut T;
|
|
|
|
ptr.write_volatile(val);
|
|
|
|
res
|
|
|
|
}
|
|
|
|
}
|