Merge #461
461: nrf: add initial nrf5340 support r=Dirbaio a=Dirbaio Thanks to `@diondokter's` work on DPPI this was quite easy! :) TODO: - [ ] Add config option to enable 128mhz - [ ] Add config option to unlock APPROTECT automatically. - [ ] Add a way to boot net (config option or API?) - [ ] Support WDT (there's WDT0, WDT1. Needs some refactor) - [ ] Support NVMC - [ ] Support TEMP Co-authored-by: Dario Nieuwenhuis <dirbaio@dirbaio.net>
This commit is contained in:
commit
5322e293bd
9
.github/workflows/rust.yml
vendored
9
.github/workflows/rust.yml
vendored
@ -60,6 +60,15 @@ jobs:
|
|||||||
- package: embassy-nrf
|
- package: embassy-nrf
|
||||||
target: thumbv8m.main-none-eabihf
|
target: thumbv8m.main-none-eabihf
|
||||||
features: nrf9160-ns
|
features: nrf9160-ns
|
||||||
|
- package: embassy-nrf
|
||||||
|
target: thumbv8m.main-none-eabihf
|
||||||
|
features: nrf5340-app-s
|
||||||
|
- package: embassy-nrf
|
||||||
|
target: thumbv8m.main-none-eabihf
|
||||||
|
features: nrf5340-app-ns
|
||||||
|
- package: embassy-nrf
|
||||||
|
target: thumbv8m.main-none-eabihf
|
||||||
|
features: nrf5340-net
|
||||||
- package: embassy-nrf
|
- package: embassy-nrf
|
||||||
target: thumbv7em-none-eabi
|
target: thumbv7em-none-eabi
|
||||||
features: nrf52840
|
features: nrf52840
|
||||||
|
@ -75,6 +75,7 @@ impl Stack {
|
|||||||
f(stack)
|
f(stack)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[allow(clippy::absurd_extreme_comparisons)]
|
||||||
pub fn get_local_port(&mut self) -> u16 {
|
pub fn get_local_port(&mut self) -> u16 {
|
||||||
let res = self.next_local_port;
|
let res = self.next_local_port;
|
||||||
self.next_local_port = if res >= LOCAL_PORT_MAX {
|
self.next_local_port = if res >= LOCAL_PORT_MAX {
|
||||||
|
@ -23,21 +23,30 @@ nrf52810 = ["nrf52810-pac", "_ppi"]
|
|||||||
nrf52811 = ["nrf52811-pac", "_ppi"]
|
nrf52811 = ["nrf52811-pac", "_ppi"]
|
||||||
nrf52820 = ["nrf52820-pac", "_ppi"]
|
nrf52820 = ["nrf52820-pac", "_ppi"]
|
||||||
nrf52832 = ["nrf52832-pac", "_ppi"]
|
nrf52832 = ["nrf52832-pac", "_ppi"]
|
||||||
nrf52833 = ["nrf52833-pac", "_ppi"]
|
nrf52833 = ["nrf52833-pac", "_ppi", "_gpio-p1"]
|
||||||
nrf52840 = ["nrf52840-pac", "_ppi"]
|
nrf52840 = ["nrf52840-pac", "_ppi", "_gpio-p1"]
|
||||||
|
nrf5340-app-s = ["_nrf5340-app"]
|
||||||
|
nrf5340-app-ns = ["_nrf5340-app"]
|
||||||
|
nrf5340-net = ["_nrf5340-net"]
|
||||||
nrf9160-s = ["_nrf9160"]
|
nrf9160-s = ["_nrf9160"]
|
||||||
nrf9160-ns = ["_nrf9160"]
|
nrf9160-ns = ["_nrf9160"]
|
||||||
|
|
||||||
|
gpiote = []
|
||||||
|
time-driver-rtc1 = ["_time-driver"]
|
||||||
|
|
||||||
# Features starting with `_` are for internal use only. They're not intended
|
# Features starting with `_` are for internal use only. They're not intended
|
||||||
# to be enabled by other crates, and are not covered by semver guarantees.
|
# to be enabled by other crates, and are not covered by semver guarantees.
|
||||||
|
|
||||||
|
_nrf5340-app = ["_nrf5340", "nrf5340-app-pac"]
|
||||||
|
_nrf5340-net = ["_nrf5340", "nrf5340-net-pac"]
|
||||||
|
_nrf5340 = ["_gpio-p1", "_dppi"]
|
||||||
_nrf9160 = ["nrf9160-pac", "_dppi"]
|
_nrf9160 = ["nrf9160-pac", "_dppi"]
|
||||||
|
|
||||||
_time-driver = ["embassy/time-tick-32768hz"]
|
_time-driver = ["embassy/time-tick-32768hz"]
|
||||||
|
|
||||||
_ppi = []
|
_ppi = []
|
||||||
_dppi = []
|
_dppi = []
|
||||||
|
_gpio-p1 = []
|
||||||
gpiote = []
|
|
||||||
time-driver-rtc1 = ["_time-driver"]
|
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
embassy = { version = "0.1.0", path = "../embassy" }
|
embassy = { version = "0.1.0", path = "../embassy" }
|
||||||
@ -55,6 +64,7 @@ critical-section = "0.2.5"
|
|||||||
rand_core = "0.6.3"
|
rand_core = "0.6.3"
|
||||||
fixed = "1.10.0"
|
fixed = "1.10.0"
|
||||||
embedded-storage = "0.2.0"
|
embedded-storage = "0.2.0"
|
||||||
|
cfg-if = "1.0.0"
|
||||||
|
|
||||||
nrf52805-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
nrf52805-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
||||||
nrf52810-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
nrf52810-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
||||||
@ -63,4 +73,6 @@ nrf52820-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
|||||||
nrf52832-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
nrf52832-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
||||||
nrf52833-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
nrf52833-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
||||||
nrf52840-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
nrf52840-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
||||||
|
nrf5340-app-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
||||||
|
nrf5340-net-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
||||||
nrf9160-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
nrf9160-pac = { version = "0.10.1", optional = true, features = [ "rt" ] }
|
||||||
|
506
embassy-nrf/src/chips/nrf5340_app.rs
Normal file
506
embassy-nrf/src/chips/nrf5340_app.rs
Normal file
@ -0,0 +1,506 @@
|
|||||||
|
#[allow(unused_imports)]
|
||||||
|
#[rustfmt::skip]
|
||||||
|
pub mod pac {
|
||||||
|
// The nRF5340 has a secure and non-secure (NS) mode.
|
||||||
|
// To avoid cfg spam, we remove _ns or _s suffixes here.
|
||||||
|
|
||||||
|
pub use nrf5340_app_pac::{
|
||||||
|
interrupt,
|
||||||
|
Interrupt,
|
||||||
|
Peripherals,
|
||||||
|
|
||||||
|
cache_s as cache,
|
||||||
|
cachedata_s as cachedata,
|
||||||
|
cacheinfo_s as cacheinfo,
|
||||||
|
clock_ns as clock,
|
||||||
|
comp_ns as comp,
|
||||||
|
cryptocell_s as cryptocell,
|
||||||
|
cti_s as cti,
|
||||||
|
ctrlap_ns as ctrlap,
|
||||||
|
dcnf_ns as dcnf,
|
||||||
|
dppic_ns as dppic,
|
||||||
|
egu0_ns as egu0,
|
||||||
|
ficr_s as ficr,
|
||||||
|
fpu_ns as fpu,
|
||||||
|
gpiote0_s as gpiote,
|
||||||
|
i2s0_ns as i2s0,
|
||||||
|
ipc_ns as ipc,
|
||||||
|
kmu_ns as kmu,
|
||||||
|
lpcomp_ns as lpcomp,
|
||||||
|
mutex_ns as mutex,
|
||||||
|
nfct_ns as nfct,
|
||||||
|
nvmc_ns as nvmc,
|
||||||
|
oscillators_ns as oscillators,
|
||||||
|
p0_ns as p0,
|
||||||
|
pdm0_ns as pdm0,
|
||||||
|
power_ns as power,
|
||||||
|
pwm0_ns as pwm0,
|
||||||
|
qdec0_ns as qdec0,
|
||||||
|
qspi_ns as qspi,
|
||||||
|
regulators_ns as regulators,
|
||||||
|
reset_ns as reset,
|
||||||
|
rtc0_ns as rtc0,
|
||||||
|
saadc_ns as saadc,
|
||||||
|
spim0_ns as spim0,
|
||||||
|
spis0_ns as spis0,
|
||||||
|
spu_s as spu,
|
||||||
|
tad_s as tad,
|
||||||
|
timer0_ns as timer0,
|
||||||
|
twim0_ns as twim0,
|
||||||
|
twis0_ns as twis0,
|
||||||
|
uarte0_ns as uarte0,
|
||||||
|
uicr_s as uicr,
|
||||||
|
usbd_ns as usbd,
|
||||||
|
usbregulator_ns as usbregulator,
|
||||||
|
vmc_ns as vmc,
|
||||||
|
wdt0_ns as wdt0,
|
||||||
|
};
|
||||||
|
|
||||||
|
#[cfg(feature = "nrf5340-app-ns")]
|
||||||
|
pub use nrf5340_app_pac::{
|
||||||
|
CLOCK_NS as CLOCK,
|
||||||
|
COMP_NS as COMP,
|
||||||
|
CTRLAP_NS as CTRLAP,
|
||||||
|
DCNF_NS as DCNF,
|
||||||
|
DPPIC_NS as DPPIC,
|
||||||
|
EGU0_NS as EGU0,
|
||||||
|
EGU1_NS as EGU1,
|
||||||
|
EGU2_NS as EGU2,
|
||||||
|
EGU3_NS as EGU3,
|
||||||
|
EGU4_NS as EGU4,
|
||||||
|
EGU5_NS as EGU5,
|
||||||
|
FPU_NS as FPU,
|
||||||
|
GPIOTE1_NS as GPIOTE1,
|
||||||
|
I2S0_NS as I2S0,
|
||||||
|
IPC_NS as IPC,
|
||||||
|
KMU_NS as KMU,
|
||||||
|
LPCOMP_NS as LPCOMP,
|
||||||
|
MUTEX_NS as MUTEX,
|
||||||
|
NFCT_NS as NFCT,
|
||||||
|
NVMC_NS as NVMC,
|
||||||
|
OSCILLATORS_NS as OSCILLATORS,
|
||||||
|
P0_NS as P0,
|
||||||
|
P1_NS as P1,
|
||||||
|
PDM0_NS as PDM0,
|
||||||
|
POWER_NS as POWER,
|
||||||
|
PWM0_NS as PWM0,
|
||||||
|
PWM1_NS as PWM1,
|
||||||
|
PWM2_NS as PWM2,
|
||||||
|
PWM3_NS as PWM3,
|
||||||
|
QDEC0_NS as QDEC0,
|
||||||
|
QDEC1_NS as QDEC1,
|
||||||
|
QSPI_NS as QSPI,
|
||||||
|
REGULATORS_NS as REGULATORS,
|
||||||
|
RESET_NS as RESET,
|
||||||
|
RTC0_NS as RTC0,
|
||||||
|
RTC1_NS as RTC1,
|
||||||
|
SAADC_NS as SAADC,
|
||||||
|
SPIM0_NS as SPIM0,
|
||||||
|
SPIM1_NS as SPIM1,
|
||||||
|
SPIM2_NS as SPIM2,
|
||||||
|
SPIM3_NS as SPIM3,
|
||||||
|
SPIM4_NS as SPIM4,
|
||||||
|
SPIS0_NS as SPIS0,
|
||||||
|
SPIS1_NS as SPIS1,
|
||||||
|
SPIS2_NS as SPIS2,
|
||||||
|
SPIS3_NS as SPIS3,
|
||||||
|
TIMER0_NS as TIMER0,
|
||||||
|
TIMER1_NS as TIMER1,
|
||||||
|
TIMER2_NS as TIMER2,
|
||||||
|
TWIM0_NS as TWIM0,
|
||||||
|
TWIM1_NS as TWIM1,
|
||||||
|
TWIM2_NS as TWIM2,
|
||||||
|
TWIM3_NS as TWIM3,
|
||||||
|
TWIS0_NS as TWIS0,
|
||||||
|
TWIS1_NS as TWIS1,
|
||||||
|
TWIS2_NS as TWIS2,
|
||||||
|
TWIS3_NS as TWIS3,
|
||||||
|
UARTE0_NS as UARTE0,
|
||||||
|
UARTE1_NS as UARTE1,
|
||||||
|
UARTE2_NS as UARTE2,
|
||||||
|
UARTE3_NS as UARTE3,
|
||||||
|
USBD_NS as USBD,
|
||||||
|
USBREGULATOR_NS as USBREGULATOR,
|
||||||
|
VMC_NS as VMC,
|
||||||
|
WDT0_NS as WDT0,
|
||||||
|
WDT1_NS as WDT1,
|
||||||
|
};
|
||||||
|
|
||||||
|
#[cfg(feature = "nrf5340-app-s")]
|
||||||
|
pub use nrf5340_app_pac::{
|
||||||
|
CACHEDATA_S as CACHEDATA,
|
||||||
|
CACHEINFO_S as CACHEINFO,
|
||||||
|
CACHE_S as CACHE,
|
||||||
|
CLOCK_S as CLOCK,
|
||||||
|
COMP_S as COMP,
|
||||||
|
CRYPTOCELL_S as CRYPTOCELL,
|
||||||
|
CTI_S as CTI,
|
||||||
|
CTRLAP_S as CTRLAP,
|
||||||
|
DCNF_S as DCNF,
|
||||||
|
DPPIC_S as DPPIC,
|
||||||
|
EGU0_S as EGU0,
|
||||||
|
EGU1_S as EGU1,
|
||||||
|
EGU2_S as EGU2,
|
||||||
|
EGU3_S as EGU3,
|
||||||
|
EGU4_S as EGU4,
|
||||||
|
EGU5_S as EGU5,
|
||||||
|
FICR_S as FICR,
|
||||||
|
FPU_S as FPU,
|
||||||
|
GPIOTE0_S as GPIOTE0,
|
||||||
|
I2S0_S as I2S0,
|
||||||
|
IPC_S as IPC,
|
||||||
|
KMU_S as KMU,
|
||||||
|
LPCOMP_S as LPCOMP,
|
||||||
|
MUTEX_S as MUTEX,
|
||||||
|
NFCT_S as NFCT,
|
||||||
|
NVMC_S as NVMC,
|
||||||
|
OSCILLATORS_S as OSCILLATORS,
|
||||||
|
P0_S as P0,
|
||||||
|
P1_S as P1,
|
||||||
|
PDM0_S as PDM0,
|
||||||
|
POWER_S as POWER,
|
||||||
|
PWM0_S as PWM0,
|
||||||
|
PWM1_S as PWM1,
|
||||||
|
PWM2_S as PWM2,
|
||||||
|
PWM3_S as PWM3,
|
||||||
|
QDEC0_S as QDEC0,
|
||||||
|
QDEC1_S as QDEC1,
|
||||||
|
QSPI_S as QSPI,
|
||||||
|
REGULATORS_S as REGULATORS,
|
||||||
|
RESET_S as RESET,
|
||||||
|
RTC0_S as RTC0,
|
||||||
|
RTC1_S as RTC1,
|
||||||
|
SAADC_S as SAADC,
|
||||||
|
SPIM0_S as SPIM0,
|
||||||
|
SPIM1_S as SPIM1,
|
||||||
|
SPIM2_S as SPIM2,
|
||||||
|
SPIM3_S as SPIM3,
|
||||||
|
SPIM4_S as SPIM4,
|
||||||
|
SPIS0_S as SPIS0,
|
||||||
|
SPIS1_S as SPIS1,
|
||||||
|
SPIS2_S as SPIS2,
|
||||||
|
SPIS3_S as SPIS3,
|
||||||
|
SPU_S as SPU,
|
||||||
|
TAD_S as TAD,
|
||||||
|
TIMER0_S as TIMER0,
|
||||||
|
TIMER1_S as TIMER1,
|
||||||
|
TIMER2_S as TIMER2,
|
||||||
|
TWIM0_S as TWIM0,
|
||||||
|
TWIM1_S as TWIM1,
|
||||||
|
TWIM2_S as TWIM2,
|
||||||
|
TWIM3_S as TWIM3,
|
||||||
|
TWIS0_S as TWIS0,
|
||||||
|
TWIS1_S as TWIS1,
|
||||||
|
TWIS2_S as TWIS2,
|
||||||
|
TWIS3_S as TWIS3,
|
||||||
|
UARTE0_S as UARTE0,
|
||||||
|
UARTE1_S as UARTE1,
|
||||||
|
UARTE2_S as UARTE2,
|
||||||
|
UARTE3_S as UARTE3,
|
||||||
|
UICR_S as UICR,
|
||||||
|
USBD_S as USBD,
|
||||||
|
USBREGULATOR_S as USBREGULATOR,
|
||||||
|
VMC_S as VMC,
|
||||||
|
WDT0_S as WDT0,
|
||||||
|
WDT1_S as WDT1,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/// The maximum buffer size that the EasyDMA can send/recv in one operation.
|
||||||
|
pub const EASY_DMA_SIZE: usize = (1 << 16) - 1;
|
||||||
|
pub const FORCE_COPY_BUFFER_SIZE: usize = 1024;
|
||||||
|
|
||||||
|
embassy_hal_common::peripherals! {
|
||||||
|
// RTC
|
||||||
|
RTC0,
|
||||||
|
RTC1,
|
||||||
|
|
||||||
|
// WDT
|
||||||
|
WDT,
|
||||||
|
|
||||||
|
// UARTE, TWI & SPI
|
||||||
|
UARTETWISPI0,
|
||||||
|
UARTETWISPI1,
|
||||||
|
UARTETWISPI2,
|
||||||
|
UARTETWISPI3,
|
||||||
|
|
||||||
|
// SAADC
|
||||||
|
SAADC,
|
||||||
|
|
||||||
|
// PWM
|
||||||
|
PWM0,
|
||||||
|
PWM1,
|
||||||
|
PWM2,
|
||||||
|
PWM3,
|
||||||
|
|
||||||
|
// TIMER
|
||||||
|
TIMER0,
|
||||||
|
TIMER1,
|
||||||
|
TIMER2,
|
||||||
|
|
||||||
|
// GPIOTE
|
||||||
|
GPIOTE_CH0,
|
||||||
|
GPIOTE_CH1,
|
||||||
|
GPIOTE_CH2,
|
||||||
|
GPIOTE_CH3,
|
||||||
|
GPIOTE_CH4,
|
||||||
|
GPIOTE_CH5,
|
||||||
|
GPIOTE_CH6,
|
||||||
|
GPIOTE_CH7,
|
||||||
|
|
||||||
|
// PPI
|
||||||
|
PPI_CH0,
|
||||||
|
PPI_CH1,
|
||||||
|
PPI_CH2,
|
||||||
|
PPI_CH3,
|
||||||
|
PPI_CH4,
|
||||||
|
PPI_CH5,
|
||||||
|
PPI_CH6,
|
||||||
|
PPI_CH7,
|
||||||
|
PPI_CH8,
|
||||||
|
PPI_CH9,
|
||||||
|
PPI_CH10,
|
||||||
|
PPI_CH11,
|
||||||
|
PPI_CH12,
|
||||||
|
PPI_CH13,
|
||||||
|
PPI_CH14,
|
||||||
|
PPI_CH15,
|
||||||
|
PPI_CH16,
|
||||||
|
PPI_CH17,
|
||||||
|
PPI_CH18,
|
||||||
|
PPI_CH19,
|
||||||
|
PPI_CH20,
|
||||||
|
PPI_CH21,
|
||||||
|
PPI_CH22,
|
||||||
|
PPI_CH23,
|
||||||
|
PPI_CH24,
|
||||||
|
PPI_CH25,
|
||||||
|
PPI_CH26,
|
||||||
|
PPI_CH27,
|
||||||
|
PPI_CH28,
|
||||||
|
PPI_CH29,
|
||||||
|
PPI_CH30,
|
||||||
|
PPI_CH31,
|
||||||
|
|
||||||
|
PPI_GROUP0,
|
||||||
|
PPI_GROUP1,
|
||||||
|
PPI_GROUP2,
|
||||||
|
PPI_GROUP3,
|
||||||
|
PPI_GROUP4,
|
||||||
|
PPI_GROUP5,
|
||||||
|
|
||||||
|
// GPIO port 0
|
||||||
|
P0_00,
|
||||||
|
P0_01,
|
||||||
|
P0_02,
|
||||||
|
P0_03,
|
||||||
|
P0_04,
|
||||||
|
P0_05,
|
||||||
|
P0_06,
|
||||||
|
P0_07,
|
||||||
|
P0_08,
|
||||||
|
P0_09,
|
||||||
|
P0_10,
|
||||||
|
P0_11,
|
||||||
|
P0_12,
|
||||||
|
P0_13,
|
||||||
|
P0_14,
|
||||||
|
P0_15,
|
||||||
|
P0_16,
|
||||||
|
P0_17,
|
||||||
|
P0_18,
|
||||||
|
P0_19,
|
||||||
|
P0_20,
|
||||||
|
P0_21,
|
||||||
|
P0_22,
|
||||||
|
P0_23,
|
||||||
|
P0_24,
|
||||||
|
P0_25,
|
||||||
|
P0_26,
|
||||||
|
P0_27,
|
||||||
|
P0_28,
|
||||||
|
P0_29,
|
||||||
|
P0_30,
|
||||||
|
P0_31,
|
||||||
|
|
||||||
|
// GPIO port 1
|
||||||
|
P1_00,
|
||||||
|
P1_01,
|
||||||
|
P1_02,
|
||||||
|
P1_03,
|
||||||
|
P1_04,
|
||||||
|
P1_05,
|
||||||
|
P1_06,
|
||||||
|
P1_07,
|
||||||
|
P1_08,
|
||||||
|
P1_09,
|
||||||
|
P1_10,
|
||||||
|
P1_11,
|
||||||
|
P1_12,
|
||||||
|
P1_13,
|
||||||
|
P1_14,
|
||||||
|
P1_15,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl_uarte!(UARTETWISPI0, UARTE0, SERIAL0);
|
||||||
|
impl_uarte!(UARTETWISPI1, UARTE1, SERIAL1);
|
||||||
|
impl_uarte!(UARTETWISPI2, UARTE2, SERIAL2);
|
||||||
|
impl_uarte!(UARTETWISPI3, UARTE3, SERIAL3);
|
||||||
|
|
||||||
|
impl_spim!(UARTETWISPI0, SPIM0, SERIAL0);
|
||||||
|
impl_spim!(UARTETWISPI1, SPIM1, SERIAL1);
|
||||||
|
impl_spim!(UARTETWISPI2, SPIM2, SERIAL2);
|
||||||
|
impl_spim!(UARTETWISPI3, SPIM3, SERIAL3);
|
||||||
|
|
||||||
|
impl_twim!(UARTETWISPI0, TWIM0, SERIAL0);
|
||||||
|
impl_twim!(UARTETWISPI1, TWIM1, SERIAL1);
|
||||||
|
impl_twim!(UARTETWISPI2, TWIM2, SERIAL2);
|
||||||
|
impl_twim!(UARTETWISPI3, TWIM3, SERIAL3);
|
||||||
|
|
||||||
|
impl_pwm!(PWM0, PWM0, PWM0);
|
||||||
|
impl_pwm!(PWM1, PWM1, PWM1);
|
||||||
|
impl_pwm!(PWM2, PWM2, PWM2);
|
||||||
|
impl_pwm!(PWM3, PWM3, PWM3);
|
||||||
|
|
||||||
|
impl_timer!(TIMER0, TIMER0, TIMER0);
|
||||||
|
impl_timer!(TIMER1, TIMER1, TIMER1);
|
||||||
|
impl_timer!(TIMER2, TIMER2, TIMER2);
|
||||||
|
|
||||||
|
impl_pin!(P0_00, 0, 0);
|
||||||
|
impl_pin!(P0_01, 0, 1);
|
||||||
|
impl_pin!(P0_02, 0, 2);
|
||||||
|
impl_pin!(P0_03, 0, 3);
|
||||||
|
impl_pin!(P0_04, 0, 4);
|
||||||
|
impl_pin!(P0_05, 0, 5);
|
||||||
|
impl_pin!(P0_06, 0, 6);
|
||||||
|
impl_pin!(P0_07, 0, 7);
|
||||||
|
impl_pin!(P0_08, 0, 8);
|
||||||
|
impl_pin!(P0_09, 0, 9);
|
||||||
|
impl_pin!(P0_10, 0, 10);
|
||||||
|
impl_pin!(P0_11, 0, 11);
|
||||||
|
impl_pin!(P0_12, 0, 12);
|
||||||
|
impl_pin!(P0_13, 0, 13);
|
||||||
|
impl_pin!(P0_14, 0, 14);
|
||||||
|
impl_pin!(P0_15, 0, 15);
|
||||||
|
impl_pin!(P0_16, 0, 16);
|
||||||
|
impl_pin!(P0_17, 0, 17);
|
||||||
|
impl_pin!(P0_18, 0, 18);
|
||||||
|
impl_pin!(P0_19, 0, 19);
|
||||||
|
impl_pin!(P0_20, 0, 20);
|
||||||
|
impl_pin!(P0_21, 0, 21);
|
||||||
|
impl_pin!(P0_22, 0, 22);
|
||||||
|
impl_pin!(P0_23, 0, 23);
|
||||||
|
impl_pin!(P0_24, 0, 24);
|
||||||
|
impl_pin!(P0_25, 0, 25);
|
||||||
|
impl_pin!(P0_26, 0, 26);
|
||||||
|
impl_pin!(P0_27, 0, 27);
|
||||||
|
impl_pin!(P0_28, 0, 28);
|
||||||
|
impl_pin!(P0_29, 0, 29);
|
||||||
|
impl_pin!(P0_30, 0, 30);
|
||||||
|
impl_pin!(P0_31, 0, 31);
|
||||||
|
|
||||||
|
impl_pin!(P1_00, 1, 0);
|
||||||
|
impl_pin!(P1_01, 1, 1);
|
||||||
|
impl_pin!(P1_02, 1, 2);
|
||||||
|
impl_pin!(P1_03, 1, 3);
|
||||||
|
impl_pin!(P1_04, 1, 4);
|
||||||
|
impl_pin!(P1_05, 1, 5);
|
||||||
|
impl_pin!(P1_06, 1, 6);
|
||||||
|
impl_pin!(P1_07, 1, 7);
|
||||||
|
impl_pin!(P1_08, 1, 8);
|
||||||
|
impl_pin!(P1_09, 1, 9);
|
||||||
|
impl_pin!(P1_10, 1, 10);
|
||||||
|
impl_pin!(P1_11, 1, 11);
|
||||||
|
impl_pin!(P1_12, 1, 12);
|
||||||
|
impl_pin!(P1_13, 1, 13);
|
||||||
|
impl_pin!(P1_14, 1, 14);
|
||||||
|
impl_pin!(P1_15, 1, 15);
|
||||||
|
|
||||||
|
impl_ppi_channel!(PPI_CH0, 0 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH1, 1 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH2, 2 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH3, 3 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH4, 4 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH5, 5 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH6, 6 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH7, 7 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH8, 8 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH9, 9 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH10, 10 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH11, 11 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH12, 12 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH13, 13 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH14, 14 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH15, 15 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH16, 16 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH17, 17 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH18, 18 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH19, 19 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH20, 20 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH21, 21 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH22, 22 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH23, 23 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH24, 24 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH25, 25 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH26, 26 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH27, 27 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH28, 28 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH29, 29 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH30, 30 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH31, 31 => configurable);
|
||||||
|
|
||||||
|
impl_saadc_input!(P0_13, ANALOGINPUT0);
|
||||||
|
impl_saadc_input!(P0_14, ANALOGINPUT1);
|
||||||
|
impl_saadc_input!(P0_15, ANALOGINPUT2);
|
||||||
|
impl_saadc_input!(P0_16, ANALOGINPUT3);
|
||||||
|
impl_saadc_input!(P0_17, ANALOGINPUT4);
|
||||||
|
impl_saadc_input!(P0_18, ANALOGINPUT5);
|
||||||
|
impl_saadc_input!(P0_19, ANALOGINPUT6);
|
||||||
|
impl_saadc_input!(P0_20, ANALOGINPUT7);
|
||||||
|
|
||||||
|
pub mod irqs {
|
||||||
|
use crate::pac::Interrupt as InterruptEnum;
|
||||||
|
use embassy_macros::interrupt_declare as declare;
|
||||||
|
|
||||||
|
declare!(FPU);
|
||||||
|
declare!(CACHE);
|
||||||
|
declare!(SPU);
|
||||||
|
declare!(CLOCK_POWER);
|
||||||
|
declare!(SERIAL0);
|
||||||
|
declare!(SERIAL1);
|
||||||
|
declare!(SPIM4);
|
||||||
|
declare!(SERIAL2);
|
||||||
|
declare!(SERIAL3);
|
||||||
|
declare!(GPIOTE0);
|
||||||
|
declare!(SAADC);
|
||||||
|
declare!(TIMER0);
|
||||||
|
declare!(TIMER1);
|
||||||
|
declare!(TIMER2);
|
||||||
|
declare!(RTC0);
|
||||||
|
declare!(RTC1);
|
||||||
|
declare!(WDT0);
|
||||||
|
declare!(WDT1);
|
||||||
|
declare!(COMP_LPCOMP);
|
||||||
|
declare!(EGU0);
|
||||||
|
declare!(EGU1);
|
||||||
|
declare!(EGU2);
|
||||||
|
declare!(EGU3);
|
||||||
|
declare!(EGU4);
|
||||||
|
declare!(EGU5);
|
||||||
|
declare!(PWM0);
|
||||||
|
declare!(PWM1);
|
||||||
|
declare!(PWM2);
|
||||||
|
declare!(PWM3);
|
||||||
|
declare!(PDM0);
|
||||||
|
declare!(I2S0);
|
||||||
|
declare!(IPC);
|
||||||
|
declare!(QSPI);
|
||||||
|
declare!(NFCT);
|
||||||
|
declare!(GPIOTE1);
|
||||||
|
declare!(QDEC0);
|
||||||
|
declare!(QDEC1);
|
||||||
|
declare!(USBD);
|
||||||
|
declare!(USBREGULATOR);
|
||||||
|
declare!(KMU);
|
||||||
|
declare!(CRYPTOCELL);
|
||||||
|
}
|
353
embassy-nrf/src/chips/nrf5340_net.rs
Normal file
353
embassy-nrf/src/chips/nrf5340_net.rs
Normal file
@ -0,0 +1,353 @@
|
|||||||
|
#[allow(unused_imports)]
|
||||||
|
#[rustfmt::skip]
|
||||||
|
pub mod pac {
|
||||||
|
// The nRF5340 has a secure and non-secure (NS) mode.
|
||||||
|
// To avoid cfg spam, we remove _ns or _s suffixes here.
|
||||||
|
|
||||||
|
pub use nrf5340_net_pac::{
|
||||||
|
interrupt,
|
||||||
|
Interrupt,
|
||||||
|
Peripherals,
|
||||||
|
|
||||||
|
aar_ns as aar,
|
||||||
|
acl_ns as acl,
|
||||||
|
appmutex_ns as appmutex,
|
||||||
|
ccm_ns as ccm,
|
||||||
|
clock_ns as clock,
|
||||||
|
cti_ns as cti,
|
||||||
|
ctrlap_ns as ctrlap,
|
||||||
|
dcnf_ns as dcnf,
|
||||||
|
dppic_ns as dppic,
|
||||||
|
ecb_ns as ecb,
|
||||||
|
egu0_ns as egu0,
|
||||||
|
ficr_ns as ficr,
|
||||||
|
gpiote_ns as gpiote,
|
||||||
|
ipc_ns as ipc,
|
||||||
|
nvmc_ns as nvmc,
|
||||||
|
p0_ns as p0,
|
||||||
|
power_ns as power,
|
||||||
|
radio_ns as radio,
|
||||||
|
reset_ns as reset,
|
||||||
|
rng_ns as rng,
|
||||||
|
rtc0_ns as rtc0,
|
||||||
|
spim0_ns as spim0,
|
||||||
|
spis0_ns as spis0,
|
||||||
|
swi0_ns as swi0,
|
||||||
|
temp_ns as temp,
|
||||||
|
timer0_ns as timer0,
|
||||||
|
twim0_ns as twim0,
|
||||||
|
twis0_ns as twis0,
|
||||||
|
uarte0_ns as uarte0,
|
||||||
|
uicr_ns as uicr,
|
||||||
|
vmc_ns as vmc,
|
||||||
|
vreqctrl_ns as vreqctrl,
|
||||||
|
wdt_ns as wdt,
|
||||||
|
|
||||||
|
AAR_NS as AAR,
|
||||||
|
ACL_NS as ACL,
|
||||||
|
APPMUTEX_NS as APPMUTEX,
|
||||||
|
APPMUTEX_S as APPMUTEX_S,
|
||||||
|
CBP as CBP,
|
||||||
|
CCM_NS as CCM,
|
||||||
|
CLOCK_NS as CLOCK,
|
||||||
|
CPUID as CPUID,
|
||||||
|
CTI_NS as CTI,
|
||||||
|
CTRLAP_NS as CTRLAP,
|
||||||
|
DCB as DCB,
|
||||||
|
DCNF_NS as DCNF,
|
||||||
|
DPPIC_NS as DPPIC,
|
||||||
|
DWT as DWT,
|
||||||
|
ECB_NS as ECB,
|
||||||
|
EGU0_NS as EGU0,
|
||||||
|
FICR_NS as FICR,
|
||||||
|
FPB as FPB,
|
||||||
|
GPIOTE_NS as GPIOTE,
|
||||||
|
IPC_NS as IPC,
|
||||||
|
ITM as ITM,
|
||||||
|
MPU as MPU,
|
||||||
|
NVIC as NVIC,
|
||||||
|
NVMC_NS as NVMC,
|
||||||
|
P0_NS as P0,
|
||||||
|
P1_NS as P1,
|
||||||
|
POWER_NS as POWER,
|
||||||
|
RADIO_NS as RADIO,
|
||||||
|
RESET_NS as RESET,
|
||||||
|
RNG_NS as RNG,
|
||||||
|
RTC0_NS as RTC0,
|
||||||
|
RTC1_NS as RTC1,
|
||||||
|
SCB as SCB,
|
||||||
|
SPIM0_NS as SPIM0,
|
||||||
|
SPIS0_NS as SPIS0,
|
||||||
|
SWI0_NS as SWI0,
|
||||||
|
SWI1_NS as SWI1,
|
||||||
|
SWI2_NS as SWI2,
|
||||||
|
SWI3_NS as SWI3,
|
||||||
|
SYST as SYST,
|
||||||
|
TEMP_NS as TEMP,
|
||||||
|
TIMER0_NS as TIMER0,
|
||||||
|
TIMER1_NS as TIMER1,
|
||||||
|
TIMER2_NS as TIMER2,
|
||||||
|
TPIU as TPIU,
|
||||||
|
TWIM0_NS as TWIM0,
|
||||||
|
TWIS0_NS as TWIS0,
|
||||||
|
UARTE0_NS as UARTE0,
|
||||||
|
UICR_NS as UICR,
|
||||||
|
VMC_NS as VMC,
|
||||||
|
VREQCTRL_NS as VREQCTRL,
|
||||||
|
WDT_NS as WDT,
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/// The maximum buffer size that the EasyDMA can send/recv in one operation.
|
||||||
|
pub const EASY_DMA_SIZE: usize = (1 << 16) - 1;
|
||||||
|
pub const FORCE_COPY_BUFFER_SIZE: usize = 1024;
|
||||||
|
|
||||||
|
embassy_hal_common::peripherals! {
|
||||||
|
// RTC
|
||||||
|
RTC0,
|
||||||
|
RTC1,
|
||||||
|
|
||||||
|
// WDT
|
||||||
|
WDT,
|
||||||
|
|
||||||
|
// UARTE, TWI & SPI
|
||||||
|
UARTETWISPI0,
|
||||||
|
UARTETWISPI1,
|
||||||
|
UARTETWISPI2,
|
||||||
|
UARTETWISPI3,
|
||||||
|
|
||||||
|
// SAADC
|
||||||
|
SAADC,
|
||||||
|
|
||||||
|
// PWM
|
||||||
|
PWM0,
|
||||||
|
PWM1,
|
||||||
|
PWM2,
|
||||||
|
PWM3,
|
||||||
|
|
||||||
|
// TIMER
|
||||||
|
TIMER0,
|
||||||
|
TIMER1,
|
||||||
|
TIMER2,
|
||||||
|
|
||||||
|
// GPIOTE
|
||||||
|
GPIOTE_CH0,
|
||||||
|
GPIOTE_CH1,
|
||||||
|
GPIOTE_CH2,
|
||||||
|
GPIOTE_CH3,
|
||||||
|
GPIOTE_CH4,
|
||||||
|
GPIOTE_CH5,
|
||||||
|
GPIOTE_CH6,
|
||||||
|
GPIOTE_CH7,
|
||||||
|
|
||||||
|
// PPI
|
||||||
|
PPI_CH0,
|
||||||
|
PPI_CH1,
|
||||||
|
PPI_CH2,
|
||||||
|
PPI_CH3,
|
||||||
|
PPI_CH4,
|
||||||
|
PPI_CH5,
|
||||||
|
PPI_CH6,
|
||||||
|
PPI_CH7,
|
||||||
|
PPI_CH8,
|
||||||
|
PPI_CH9,
|
||||||
|
PPI_CH10,
|
||||||
|
PPI_CH11,
|
||||||
|
PPI_CH12,
|
||||||
|
PPI_CH13,
|
||||||
|
PPI_CH14,
|
||||||
|
PPI_CH15,
|
||||||
|
PPI_CH16,
|
||||||
|
PPI_CH17,
|
||||||
|
PPI_CH18,
|
||||||
|
PPI_CH19,
|
||||||
|
PPI_CH20,
|
||||||
|
PPI_CH21,
|
||||||
|
PPI_CH22,
|
||||||
|
PPI_CH23,
|
||||||
|
PPI_CH24,
|
||||||
|
PPI_CH25,
|
||||||
|
PPI_CH26,
|
||||||
|
PPI_CH27,
|
||||||
|
PPI_CH28,
|
||||||
|
PPI_CH29,
|
||||||
|
PPI_CH30,
|
||||||
|
PPI_CH31,
|
||||||
|
|
||||||
|
PPI_GROUP0,
|
||||||
|
PPI_GROUP1,
|
||||||
|
PPI_GROUP2,
|
||||||
|
PPI_GROUP3,
|
||||||
|
PPI_GROUP4,
|
||||||
|
PPI_GROUP5,
|
||||||
|
|
||||||
|
// GPIO port 0
|
||||||
|
P0_00,
|
||||||
|
P0_01,
|
||||||
|
P0_02,
|
||||||
|
P0_03,
|
||||||
|
P0_04,
|
||||||
|
P0_05,
|
||||||
|
P0_06,
|
||||||
|
P0_07,
|
||||||
|
P0_08,
|
||||||
|
P0_09,
|
||||||
|
P0_10,
|
||||||
|
P0_11,
|
||||||
|
P0_12,
|
||||||
|
P0_13,
|
||||||
|
P0_14,
|
||||||
|
P0_15,
|
||||||
|
P0_16,
|
||||||
|
P0_17,
|
||||||
|
P0_18,
|
||||||
|
P0_19,
|
||||||
|
P0_20,
|
||||||
|
P0_21,
|
||||||
|
P0_22,
|
||||||
|
P0_23,
|
||||||
|
P0_24,
|
||||||
|
P0_25,
|
||||||
|
P0_26,
|
||||||
|
P0_27,
|
||||||
|
P0_28,
|
||||||
|
P0_29,
|
||||||
|
P0_30,
|
||||||
|
P0_31,
|
||||||
|
|
||||||
|
// GPIO port 1
|
||||||
|
P1_00,
|
||||||
|
P1_01,
|
||||||
|
P1_02,
|
||||||
|
P1_03,
|
||||||
|
P1_04,
|
||||||
|
P1_05,
|
||||||
|
P1_06,
|
||||||
|
P1_07,
|
||||||
|
P1_08,
|
||||||
|
P1_09,
|
||||||
|
P1_10,
|
||||||
|
P1_11,
|
||||||
|
P1_12,
|
||||||
|
P1_13,
|
||||||
|
P1_14,
|
||||||
|
P1_15,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl_uarte!(UARTETWISPI0, UARTE0, SERIAL0);
|
||||||
|
impl_spim!(UARTETWISPI0, SPIM0, SERIAL0);
|
||||||
|
impl_twim!(UARTETWISPI0, TWIM0, SERIAL0);
|
||||||
|
|
||||||
|
impl_timer!(TIMER0, TIMER0, TIMER0);
|
||||||
|
impl_timer!(TIMER1, TIMER1, TIMER1);
|
||||||
|
impl_timer!(TIMER2, TIMER2, TIMER2);
|
||||||
|
|
||||||
|
impl_pin!(P0_00, 0, 0);
|
||||||
|
impl_pin!(P0_01, 0, 1);
|
||||||
|
impl_pin!(P0_02, 0, 2);
|
||||||
|
impl_pin!(P0_03, 0, 3);
|
||||||
|
impl_pin!(P0_04, 0, 4);
|
||||||
|
impl_pin!(P0_05, 0, 5);
|
||||||
|
impl_pin!(P0_06, 0, 6);
|
||||||
|
impl_pin!(P0_07, 0, 7);
|
||||||
|
impl_pin!(P0_08, 0, 8);
|
||||||
|
impl_pin!(P0_09, 0, 9);
|
||||||
|
impl_pin!(P0_10, 0, 10);
|
||||||
|
impl_pin!(P0_11, 0, 11);
|
||||||
|
impl_pin!(P0_12, 0, 12);
|
||||||
|
impl_pin!(P0_13, 0, 13);
|
||||||
|
impl_pin!(P0_14, 0, 14);
|
||||||
|
impl_pin!(P0_15, 0, 15);
|
||||||
|
impl_pin!(P0_16, 0, 16);
|
||||||
|
impl_pin!(P0_17, 0, 17);
|
||||||
|
impl_pin!(P0_18, 0, 18);
|
||||||
|
impl_pin!(P0_19, 0, 19);
|
||||||
|
impl_pin!(P0_20, 0, 20);
|
||||||
|
impl_pin!(P0_21, 0, 21);
|
||||||
|
impl_pin!(P0_22, 0, 22);
|
||||||
|
impl_pin!(P0_23, 0, 23);
|
||||||
|
impl_pin!(P0_24, 0, 24);
|
||||||
|
impl_pin!(P0_25, 0, 25);
|
||||||
|
impl_pin!(P0_26, 0, 26);
|
||||||
|
impl_pin!(P0_27, 0, 27);
|
||||||
|
impl_pin!(P0_28, 0, 28);
|
||||||
|
impl_pin!(P0_29, 0, 29);
|
||||||
|
impl_pin!(P0_30, 0, 30);
|
||||||
|
impl_pin!(P0_31, 0, 31);
|
||||||
|
|
||||||
|
impl_pin!(P1_00, 1, 0);
|
||||||
|
impl_pin!(P1_01, 1, 1);
|
||||||
|
impl_pin!(P1_02, 1, 2);
|
||||||
|
impl_pin!(P1_03, 1, 3);
|
||||||
|
impl_pin!(P1_04, 1, 4);
|
||||||
|
impl_pin!(P1_05, 1, 5);
|
||||||
|
impl_pin!(P1_06, 1, 6);
|
||||||
|
impl_pin!(P1_07, 1, 7);
|
||||||
|
impl_pin!(P1_08, 1, 8);
|
||||||
|
impl_pin!(P1_09, 1, 9);
|
||||||
|
impl_pin!(P1_10, 1, 10);
|
||||||
|
impl_pin!(P1_11, 1, 11);
|
||||||
|
impl_pin!(P1_12, 1, 12);
|
||||||
|
impl_pin!(P1_13, 1, 13);
|
||||||
|
impl_pin!(P1_14, 1, 14);
|
||||||
|
impl_pin!(P1_15, 1, 15);
|
||||||
|
|
||||||
|
impl_ppi_channel!(PPI_CH0, 0 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH1, 1 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH2, 2 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH3, 3 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH4, 4 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH5, 5 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH6, 6 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH7, 7 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH8, 8 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH9, 9 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH10, 10 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH11, 11 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH12, 12 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH13, 13 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH14, 14 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH15, 15 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH16, 16 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH17, 17 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH18, 18 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH19, 19 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH20, 20 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH21, 21 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH22, 22 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH23, 23 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH24, 24 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH25, 25 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH26, 26 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH27, 27 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH28, 28 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH29, 29 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH30, 30 => configurable);
|
||||||
|
impl_ppi_channel!(PPI_CH31, 31 => configurable);
|
||||||
|
|
||||||
|
pub mod irqs {
|
||||||
|
use crate::pac::Interrupt as InterruptEnum;
|
||||||
|
use embassy_macros::interrupt_declare as declare;
|
||||||
|
|
||||||
|
declare!(CLOCK_POWER);
|
||||||
|
declare!(RADIO);
|
||||||
|
declare!(RNG);
|
||||||
|
declare!(GPIOTE);
|
||||||
|
declare!(WDT);
|
||||||
|
declare!(TIMER0);
|
||||||
|
declare!(ECB);
|
||||||
|
declare!(AAR_CCM);
|
||||||
|
declare!(TEMP);
|
||||||
|
declare!(RTC0);
|
||||||
|
declare!(IPC);
|
||||||
|
declare!(SERIAL0);
|
||||||
|
declare!(EGU0);
|
||||||
|
declare!(RTC1);
|
||||||
|
declare!(TIMER1);
|
||||||
|
declare!(TIMER2);
|
||||||
|
declare!(SWI0);
|
||||||
|
declare!(SWI1);
|
||||||
|
declare!(SWI2);
|
||||||
|
declare!(SWI3);
|
||||||
|
}
|
@ -2,27 +2,49 @@
|
|||||||
#[rustfmt::skip]
|
#[rustfmt::skip]
|
||||||
pub mod pac {
|
pub mod pac {
|
||||||
// The nRF9160 has a secure and non-secure (NS) mode.
|
// The nRF9160 has a secure and non-secure (NS) mode.
|
||||||
// For now we only support the NS mode, but those peripherals have `_ns` appended to them.
|
// To avoid cfg spam, we remove _ns or _s suffixes here.
|
||||||
// To avoid cfg spam, weŕe going to rename the ones we use here.
|
|
||||||
|
|
||||||
pub use nrf9160_pac::{
|
pub use nrf9160_pac::{
|
||||||
interrupt,
|
interrupt,
|
||||||
Interrupt,
|
Interrupt,
|
||||||
|
|
||||||
|
cc_host_rgf_s as cc_host_rgf,
|
||||||
|
clock_ns as clock,
|
||||||
|
cryptocell_s as cryptocell,
|
||||||
|
ctrl_ap_peri_s as ctrl_ap_peri,
|
||||||
|
dppic_ns as dppic,
|
||||||
|
egu0_ns as egu0,
|
||||||
|
ficr_s as ficr,
|
||||||
|
fpu_ns as fpu,
|
||||||
|
gpiote0_s as gpiote0,
|
||||||
|
i2s_ns as i2s,
|
||||||
|
ipc_ns as ipc,
|
||||||
|
kmu_ns as kmu,
|
||||||
|
nvmc_ns as nvmc,
|
||||||
p0_ns as p0,
|
p0_ns as p0,
|
||||||
|
pdm_ns as pdm,
|
||||||
|
power_ns as power,
|
||||||
pwm0_ns as pwm0,
|
pwm0_ns as pwm0,
|
||||||
|
regulators_ns as regulators,
|
||||||
rtc0_ns as rtc0,
|
rtc0_ns as rtc0,
|
||||||
|
saadc_ns as saadc,
|
||||||
spim0_ns as spim0,
|
spim0_ns as spim0,
|
||||||
|
spis0_ns as spis0,
|
||||||
|
spu_s as spu,
|
||||||
|
tad_s as tad,
|
||||||
timer0_ns as timer0,
|
timer0_ns as timer0,
|
||||||
twim0_ns as twim0,
|
twim0_ns as twim0,
|
||||||
|
twis0_ns as twis0,
|
||||||
uarte0_ns as uarte0,
|
uarte0_ns as uarte0,
|
||||||
saadc_ns as saadc,
|
uicr_s as uicr,
|
||||||
|
vmc_ns as vmc,
|
||||||
|
wdt_ns as wdt,
|
||||||
};
|
};
|
||||||
|
|
||||||
#[cfg(feature = "nrf9160-ns")]
|
#[cfg(feature = "nrf9160-ns")]
|
||||||
pub use nrf9160_pac::{
|
pub use nrf9160_pac::{
|
||||||
CLOCK_NS as CLOCK,
|
CLOCK_NS as CLOCK,
|
||||||
DPPIC_NS as PPI,
|
DPPIC_NS as DPPIC,
|
||||||
EGU0_NS as EGU0,
|
EGU0_NS as EGU0,
|
||||||
EGU1_NS as EGU1,
|
EGU1_NS as EGU1,
|
||||||
EGU2_NS as EGU2,
|
EGU2_NS as EGU2,
|
||||||
@ -79,7 +101,7 @@ pub mod pac {
|
|||||||
CLOCK_S as CLOCK,
|
CLOCK_S as CLOCK,
|
||||||
CRYPTOCELL_S as CRYPTOCELL,
|
CRYPTOCELL_S as CRYPTOCELL,
|
||||||
CTRL_AP_PERI_S as CTRL_AP_PERI,
|
CTRL_AP_PERI_S as CTRL_AP_PERI,
|
||||||
DPPIC_S as PPI,
|
DPPIC_S as DPPIC,
|
||||||
EGU0_S as EGU0,
|
EGU0_S as EGU0,
|
||||||
EGU1_S as EGU1,
|
EGU1_S as EGU1,
|
||||||
EGU2_S as EGU2,
|
EGU2_S as EGU2,
|
||||||
|
@ -4,6 +4,7 @@ use core::convert::Infallible;
|
|||||||
use core::hint::unreachable_unchecked;
|
use core::hint::unreachable_unchecked;
|
||||||
use core::marker::PhantomData;
|
use core::marker::PhantomData;
|
||||||
|
|
||||||
|
use cfg_if::cfg_if;
|
||||||
use embassy::util::Unborrow;
|
use embassy::util::Unborrow;
|
||||||
use embassy_hal_common::{unborrow, unsafe_impl_unborrow};
|
use embassy_hal_common::{unborrow, unsafe_impl_unborrow};
|
||||||
use embedded_hal::digital::v2::{InputPin, OutputPin, StatefulOutputPin};
|
use embedded_hal::digital::v2::{InputPin, OutputPin, StatefulOutputPin};
|
||||||
@ -20,8 +21,8 @@ pub enum Port {
|
|||||||
/// Port 0, available on nRF9160 and all nRF52 and nRF51 MCUs.
|
/// Port 0, available on nRF9160 and all nRF52 and nRF51 MCUs.
|
||||||
Port0,
|
Port0,
|
||||||
|
|
||||||
/// Port 1, only available on some nRF52 MCUs.
|
/// Port 1, only available on some MCUs.
|
||||||
#[cfg(any(feature = "nrf52833", feature = "nrf52840"))]
|
#[cfg(feature = "_gpio-p1")]
|
||||||
Port1,
|
Port1,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -284,23 +285,21 @@ pub(crate) mod sealed {
|
|||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
fn _pin(&self) -> u8 {
|
fn _pin(&self) -> u8 {
|
||||||
#[cfg(any(feature = "nrf52833", feature = "nrf52840"))]
|
cfg_if! {
|
||||||
{
|
if #[cfg(feature = "_gpio-p1")] {
|
||||||
self.pin_port() % 32
|
self.pin_port() % 32
|
||||||
}
|
} else {
|
||||||
|
|
||||||
#[cfg(not(any(feature = "nrf52833", feature = "nrf52840")))]
|
|
||||||
{
|
|
||||||
self.pin_port()
|
self.pin_port()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[inline]
|
#[inline]
|
||||||
fn block(&self) -> &gpio::RegisterBlock {
|
fn block(&self) -> &gpio::RegisterBlock {
|
||||||
unsafe {
|
unsafe {
|
||||||
match self.pin_port() / 32 {
|
match self.pin_port() / 32 {
|
||||||
0 => &*pac::P0::ptr(),
|
0 => &*pac::P0::ptr(),
|
||||||
#[cfg(any(feature = "nrf52833", feature = "nrf52840"))]
|
#[cfg(feature = "_gpio-p1")]
|
||||||
1 => &*pac::P1::ptr(),
|
1 => &*pac::P1::ptr(),
|
||||||
_ => unreachable_unchecked(),
|
_ => unreachable_unchecked(),
|
||||||
}
|
}
|
||||||
@ -344,7 +343,7 @@ pub trait Pin: Unborrow<Target = Self> + sealed::Pin + Sized + 'static {
|
|||||||
fn port(&self) -> Port {
|
fn port(&self) -> Port {
|
||||||
match self.pin_port() / 32 {
|
match self.pin_port() / 32 {
|
||||||
0 => Port::Port0,
|
0 => Port::Port0,
|
||||||
#[cfg(any(feature = "nrf52833", feature = "nrf52840"))]
|
#[cfg(feature = "_gpio-p1")]
|
||||||
1 => Port::Port1,
|
1 => Port::Port1,
|
||||||
_ => unsafe { unreachable_unchecked() },
|
_ => unsafe { unreachable_unchecked() },
|
||||||
}
|
}
|
||||||
|
@ -41,6 +41,18 @@ pub enum OutputChannelPolarity {
|
|||||||
Toggle,
|
Toggle,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn regs() -> &'static pac::gpiote::RegisterBlock {
|
||||||
|
cfg_if::cfg_if! {
|
||||||
|
if #[cfg(any(feature="nrf5340-app-s", feature="nrf9160-s"))] {
|
||||||
|
unsafe { &*pac::GPIOTE0::ptr() }
|
||||||
|
} else if #[cfg(any(feature="nrf5340-app-ns", feature="nrf9160-ns"))] {
|
||||||
|
unsafe { &*pac::GPIOTE1::ptr() }
|
||||||
|
} else {
|
||||||
|
unsafe { &*pac::GPIOTE::ptr() }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub(crate) fn init(irq_prio: crate::interrupt::Priority) {
|
pub(crate) fn init(irq_prio: crate::interrupt::Priority) {
|
||||||
#[cfg(any(feature = "nrf52833", feature = "nrf52840"))]
|
#[cfg(any(feature = "nrf52833", feature = "nrf52840"))]
|
||||||
let ports = unsafe { &[&*pac::P0::ptr(), &*pac::P1::ptr()] };
|
let ports = unsafe { &[&*pac::P0::ptr(), &*pac::P1::ptr()] };
|
||||||
@ -55,35 +67,46 @@ pub(crate) fn init(irq_prio: crate::interrupt::Priority) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Enable interrupts
|
// Enable interrupts
|
||||||
|
cfg_if::cfg_if! {
|
||||||
#[cfg(not(feature = "_nrf9160"))]
|
if #[cfg(any(feature="nrf5340-app-s", feature="nrf9160-s"))] {
|
||||||
let irq = unsafe { interrupt::GPIOTE::steal() };
|
let irq = unsafe { interrupt::GPIOTE0::steal() };
|
||||||
#[cfg(feature = "_nrf9160")]
|
} else if #[cfg(any(feature="nrf5340-app-ns", feature="nrf9160-ns"))] {
|
||||||
let irq = unsafe { interrupt::GPIOTE1::steal() };
|
let irq = unsafe { interrupt::GPIOTE1::steal() };
|
||||||
|
} else {
|
||||||
|
let irq = unsafe { interrupt::GPIOTE::steal() };
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
irq.unpend();
|
irq.unpend();
|
||||||
irq.set_priority(irq_prio);
|
irq.set_priority(irq_prio);
|
||||||
irq.enable();
|
irq.enable();
|
||||||
|
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
g.events_port.write(|w| w);
|
g.events_port.write(|w| w);
|
||||||
g.intenset.write(|w| w.port().set());
|
g.intenset.write(|w| w.port().set());
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(not(feature = "_nrf9160"))]
|
cfg_if::cfg_if! {
|
||||||
#[interrupt]
|
if #[cfg(any(feature="nrf5340-app-s", feature="nrf9160-s"))] {
|
||||||
fn GPIOTE() {
|
#[interrupt]
|
||||||
|
fn GPIOTE0() {
|
||||||
unsafe { handle_gpiote_interrupt() };
|
unsafe { handle_gpiote_interrupt() };
|
||||||
}
|
}
|
||||||
|
} else if #[cfg(any(feature="nrf5340-app-ns", feature="nrf9160-ns"))] {
|
||||||
#[cfg(feature = "_nrf9160")]
|
#[interrupt]
|
||||||
#[interrupt]
|
fn GPIOTE1() {
|
||||||
fn GPIOTE1() {
|
|
||||||
unsafe { handle_gpiote_interrupt() };
|
unsafe { handle_gpiote_interrupt() };
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
#[interrupt]
|
||||||
|
fn GPIOTE() {
|
||||||
|
unsafe { handle_gpiote_interrupt() };
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe fn handle_gpiote_interrupt() {
|
unsafe fn handle_gpiote_interrupt() {
|
||||||
let g = &*pac::GPIOTE::ptr();
|
let g = regs();
|
||||||
|
|
||||||
for i in 0..CHANNEL_COUNT {
|
for i in 0..CHANNEL_COUNT {
|
||||||
if g.events_in[i].read().bits() != 0 {
|
if g.events_in[i].read().bits() != 0 {
|
||||||
@ -135,7 +158,7 @@ pub struct InputChannel<'d, C: Channel, T: GpioPin> {
|
|||||||
|
|
||||||
impl<'d, C: Channel, T: GpioPin> Drop for InputChannel<'d, C, T> {
|
impl<'d, C: Channel, T: GpioPin> Drop for InputChannel<'d, C, T> {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
let num = self.ch.number();
|
let num = self.ch.number();
|
||||||
g.config[num].write(|w| w.mode().disabled());
|
g.config[num].write(|w| w.mode().disabled());
|
||||||
g.intenclr.write(|w| unsafe { w.bits(1 << num) });
|
g.intenclr.write(|w| unsafe { w.bits(1 << num) });
|
||||||
@ -144,7 +167,7 @@ impl<'d, C: Channel, T: GpioPin> Drop for InputChannel<'d, C, T> {
|
|||||||
|
|
||||||
impl<'d, C: Channel, T: GpioPin> InputChannel<'d, C, T> {
|
impl<'d, C: Channel, T: GpioPin> InputChannel<'d, C, T> {
|
||||||
pub fn new(ch: C, pin: Input<'d, T>, polarity: InputChannelPolarity) -> Self {
|
pub fn new(ch: C, pin: Input<'d, T>, polarity: InputChannelPolarity) -> Self {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
let num = ch.number();
|
let num = ch.number();
|
||||||
|
|
||||||
g.config[num].write(|w| {
|
g.config[num].write(|w| {
|
||||||
@ -168,7 +191,7 @@ impl<'d, C: Channel, T: GpioPin> InputChannel<'d, C, T> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub async fn wait(&self) {
|
pub async fn wait(&self) {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
let num = self.ch.number();
|
let num = self.ch.number();
|
||||||
|
|
||||||
// Enable interrupt
|
// Enable interrupt
|
||||||
@ -189,7 +212,7 @@ impl<'d, C: Channel, T: GpioPin> InputChannel<'d, C, T> {
|
|||||||
|
|
||||||
/// Returns the IN event, for use with PPI.
|
/// Returns the IN event, for use with PPI.
|
||||||
pub fn event_in(&self) -> Event {
|
pub fn event_in(&self) -> Event {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
Event::from_reg(&g.events_in[self.ch.number()])
|
Event::from_reg(&g.events_in[self.ch.number()])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -214,7 +237,7 @@ pub struct OutputChannel<'d, C: Channel, T: GpioPin> {
|
|||||||
|
|
||||||
impl<'d, C: Channel, T: GpioPin> Drop for OutputChannel<'d, C, T> {
|
impl<'d, C: Channel, T: GpioPin> Drop for OutputChannel<'d, C, T> {
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
let num = self.ch.number();
|
let num = self.ch.number();
|
||||||
g.config[num].write(|w| w.mode().disabled());
|
g.config[num].write(|w| w.mode().disabled());
|
||||||
g.intenclr.write(|w| unsafe { w.bits(1 << num) });
|
g.intenclr.write(|w| unsafe { w.bits(1 << num) });
|
||||||
@ -223,7 +246,7 @@ impl<'d, C: Channel, T: GpioPin> Drop for OutputChannel<'d, C, T> {
|
|||||||
|
|
||||||
impl<'d, C: Channel, T: GpioPin> OutputChannel<'d, C, T> {
|
impl<'d, C: Channel, T: GpioPin> OutputChannel<'d, C, T> {
|
||||||
pub fn new(ch: C, pin: Output<'d, T>, polarity: OutputChannelPolarity) -> Self {
|
pub fn new(ch: C, pin: Output<'d, T>, polarity: OutputChannelPolarity) -> Self {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
let num = ch.number();
|
let num = ch.number();
|
||||||
|
|
||||||
g.config[num].write(|w| {
|
g.config[num].write(|w| {
|
||||||
@ -250,41 +273,41 @@ impl<'d, C: Channel, T: GpioPin> OutputChannel<'d, C, T> {
|
|||||||
|
|
||||||
/// Triggers `task out` (as configured with task_out_polarity, defaults to Toggle).
|
/// Triggers `task out` (as configured with task_out_polarity, defaults to Toggle).
|
||||||
pub fn out(&self) {
|
pub fn out(&self) {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
g.tasks_out[self.ch.number()].write(|w| unsafe { w.bits(1) });
|
g.tasks_out[self.ch.number()].write(|w| unsafe { w.bits(1) });
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Triggers `task set` (set associated pin high).
|
/// Triggers `task set` (set associated pin high).
|
||||||
#[cfg(not(feature = "nrf51"))]
|
#[cfg(not(feature = "nrf51"))]
|
||||||
pub fn set(&self) {
|
pub fn set(&self) {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
g.tasks_set[self.ch.number()].write(|w| unsafe { w.bits(1) });
|
g.tasks_set[self.ch.number()].write(|w| unsafe { w.bits(1) });
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Triggers `task clear` (set associated pin low).
|
/// Triggers `task clear` (set associated pin low).
|
||||||
#[cfg(not(feature = "nrf51"))]
|
#[cfg(not(feature = "nrf51"))]
|
||||||
pub fn clear(&self) {
|
pub fn clear(&self) {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
g.tasks_clr[self.ch.number()].write(|w| unsafe { w.bits(1) });
|
g.tasks_clr[self.ch.number()].write(|w| unsafe { w.bits(1) });
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the OUT task, for use with PPI.
|
/// Returns the OUT task, for use with PPI.
|
||||||
pub fn task_out(&self) -> Task {
|
pub fn task_out(&self) -> Task {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
Task::from_reg(&g.tasks_out[self.ch.number()])
|
Task::from_reg(&g.tasks_out[self.ch.number()])
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the CLR task, for use with PPI.
|
/// Returns the CLR task, for use with PPI.
|
||||||
#[cfg(not(feature = "nrf51"))]
|
#[cfg(not(feature = "nrf51"))]
|
||||||
pub fn task_clr(&self) -> Task {
|
pub fn task_clr(&self) -> Task {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
Task::from_reg(&g.tasks_clr[self.ch.number()])
|
Task::from_reg(&g.tasks_clr[self.ch.number()])
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the SET task, for use with PPI.
|
/// Returns the SET task, for use with PPI.
|
||||||
#[cfg(not(feature = "nrf51"))]
|
#[cfg(not(feature = "nrf51"))]
|
||||||
pub fn task_set(&self) -> Task {
|
pub fn task_set(&self) -> Task {
|
||||||
let g = unsafe { &*pac::GPIOTE::ptr() };
|
let g = regs();
|
||||||
Task::from_reg(&g.tasks_set[self.ch.number()])
|
Task::from_reg(&g.tasks_set[self.ch.number()])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -12,7 +12,8 @@
|
|||||||
feature = "nrf52832",
|
feature = "nrf52832",
|
||||||
feature = "nrf52833",
|
feature = "nrf52833",
|
||||||
feature = "nrf52840",
|
feature = "nrf52840",
|
||||||
feature = "nrf5340-app",
|
feature = "nrf5340-app-s",
|
||||||
|
feature = "nrf5340-app-ns",
|
||||||
feature = "nrf5340-net",
|
feature = "nrf5340-net",
|
||||||
feature = "nrf9160-s",
|
feature = "nrf9160-s",
|
||||||
feature = "nrf9160-ns",
|
feature = "nrf9160-ns",
|
||||||
@ -30,23 +31,24 @@ pub mod buffered_uarte;
|
|||||||
pub mod gpio;
|
pub mod gpio;
|
||||||
#[cfg(feature = "gpiote")]
|
#[cfg(feature = "gpiote")]
|
||||||
pub mod gpiote;
|
pub mod gpiote;
|
||||||
#[cfg(not(feature = "_nrf9160"))]
|
#[cfg(not(any(feature = "_nrf5340", feature = "_nrf9160")))]
|
||||||
pub mod nvmc;
|
pub mod nvmc;
|
||||||
pub mod ppi;
|
pub mod ppi;
|
||||||
#[cfg(not(any(feature = "nrf52805", feature = "nrf52820")))]
|
#[cfg(not(any(feature = "nrf52805", feature = "nrf52820", feature = "_nrf5340-net")))]
|
||||||
pub mod pwm;
|
pub mod pwm;
|
||||||
#[cfg(feature = "nrf52840")]
|
#[cfg(feature = "nrf52840")]
|
||||||
pub mod qspi;
|
pub mod qspi;
|
||||||
#[cfg(not(feature = "_nrf9160"))]
|
#[cfg(not(any(feature = "_nrf5340", feature = "_nrf9160")))]
|
||||||
pub mod rng;
|
pub mod rng;
|
||||||
#[cfg(not(feature = "nrf52820"))]
|
#[cfg(not(any(feature = "nrf52820", feature = "_nrf5340-net")))]
|
||||||
pub mod saadc;
|
pub mod saadc;
|
||||||
pub mod spim;
|
pub mod spim;
|
||||||
#[cfg(not(feature = "_nrf9160"))]
|
#[cfg(not(any(feature = "_nrf5340", feature = "_nrf9160")))]
|
||||||
pub mod temp;
|
pub mod temp;
|
||||||
pub mod timer;
|
pub mod timer;
|
||||||
pub mod twim;
|
pub mod twim;
|
||||||
pub mod uarte;
|
pub mod uarte;
|
||||||
|
#[cfg(not(feature = "_nrf5340"))]
|
||||||
pub mod wdt;
|
pub mod wdt;
|
||||||
|
|
||||||
// This mod MUST go last, so that it sees all the `impl_foo!` macros
|
// This mod MUST go last, so that it sees all the `impl_foo!` macros
|
||||||
@ -57,6 +59,8 @@ pub mod wdt;
|
|||||||
#[cfg_attr(feature = "nrf52832", path = "chips/nrf52832.rs")]
|
#[cfg_attr(feature = "nrf52832", path = "chips/nrf52832.rs")]
|
||||||
#[cfg_attr(feature = "nrf52833", path = "chips/nrf52833.rs")]
|
#[cfg_attr(feature = "nrf52833", path = "chips/nrf52833.rs")]
|
||||||
#[cfg_attr(feature = "nrf52840", path = "chips/nrf52840.rs")]
|
#[cfg_attr(feature = "nrf52840", path = "chips/nrf52840.rs")]
|
||||||
|
#[cfg_attr(feature = "_nrf5340-app", path = "chips/nrf5340_app.rs")]
|
||||||
|
#[cfg_attr(feature = "_nrf5340-net", path = "chips/nrf5340_net.rs")]
|
||||||
#[cfg_attr(feature = "_nrf9160", path = "chips/nrf9160.rs")]
|
#[cfg_attr(feature = "_nrf9160", path = "chips/nrf9160.rs")]
|
||||||
mod chip;
|
mod chip;
|
||||||
|
|
||||||
@ -67,7 +71,6 @@ pub use chip::pac;
|
|||||||
#[cfg(not(feature = "unstable-pac"))]
|
#[cfg(not(feature = "unstable-pac"))]
|
||||||
pub(crate) use chip::pac;
|
pub(crate) use chip::pac;
|
||||||
|
|
||||||
use crate::pac::CLOCK;
|
|
||||||
pub use chip::{peripherals, Peripherals};
|
pub use chip::{peripherals, Peripherals};
|
||||||
|
|
||||||
pub mod interrupt {
|
pub mod interrupt {
|
||||||
@ -86,12 +89,12 @@ pub mod config {
|
|||||||
|
|
||||||
pub enum LfclkSource {
|
pub enum LfclkSource {
|
||||||
InternalRC,
|
InternalRC,
|
||||||
#[cfg(not(feature = "_nrf9160"))]
|
#[cfg(not(any(feature = "_nrf5340", feature = "_nrf9160")))]
|
||||||
Synthesized,
|
Synthesized,
|
||||||
ExternalXtal,
|
ExternalXtal,
|
||||||
#[cfg(not(feature = "_nrf9160"))]
|
#[cfg(not(any(feature = "_nrf5340", feature = "_nrf9160")))]
|
||||||
ExternalLowSwing,
|
ExternalLowSwing,
|
||||||
#[cfg(not(feature = "_nrf9160"))]
|
#[cfg(not(any(feature = "_nrf5340", feature = "_nrf9160")))]
|
||||||
ExternalFullSwing,
|
ExternalFullSwing,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -127,7 +130,7 @@ pub fn init(config: config::Config) -> Peripherals {
|
|||||||
// before doing anything important.
|
// before doing anything important.
|
||||||
let peripherals = Peripherals::take();
|
let peripherals = Peripherals::take();
|
||||||
|
|
||||||
let r = unsafe { &*CLOCK::ptr() };
|
let r = unsafe { &*pac::CLOCK::ptr() };
|
||||||
|
|
||||||
// Start HFCLK.
|
// Start HFCLK.
|
||||||
match config.hfclk_source {
|
match config.hfclk_source {
|
||||||
@ -141,7 +144,7 @@ pub fn init(config: config::Config) -> Peripherals {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Configure LFCLK.
|
// Configure LFCLK.
|
||||||
#[cfg(not(feature = "_nrf9160"))]
|
#[cfg(not(any(feature = "_nrf5340", feature = "_nrf9160")))]
|
||||||
match config.lfclk_source {
|
match config.lfclk_source {
|
||||||
config::LfclkSource::InternalRC => r.lfclksrc.write(|w| w.src().rc()),
|
config::LfclkSource::InternalRC => r.lfclksrc.write(|w| w.src().rc()),
|
||||||
config::LfclkSource::Synthesized => r.lfclksrc.write(|w| w.src().synth()),
|
config::LfclkSource::Synthesized => r.lfclksrc.write(|w| w.src().synth()),
|
||||||
|
@ -3,11 +3,17 @@ use core::marker::PhantomData;
|
|||||||
use embassy::util::Unborrow;
|
use embassy::util::Unborrow;
|
||||||
use embassy_hal_common::unborrow;
|
use embassy_hal_common::unborrow;
|
||||||
|
|
||||||
|
use crate::pac;
|
||||||
|
|
||||||
use super::{Channel, ConfigurableChannel, Event, Ppi, Task};
|
use super::{Channel, ConfigurableChannel, Event, Ppi, Task};
|
||||||
|
|
||||||
const DPPI_ENABLE_BIT: u32 = 0x8000_0000;
|
const DPPI_ENABLE_BIT: u32 = 0x8000_0000;
|
||||||
const DPPI_CHANNEL_MASK: u32 = 0x0000_00FF;
|
const DPPI_CHANNEL_MASK: u32 = 0x0000_00FF;
|
||||||
|
|
||||||
|
fn regs() -> &'static pac::dppic::RegisterBlock {
|
||||||
|
unsafe { &*pac::DPPIC::ptr() }
|
||||||
|
}
|
||||||
|
|
||||||
impl<'d, C: ConfigurableChannel> Ppi<'d, C, 1, 1> {
|
impl<'d, C: ConfigurableChannel> Ppi<'d, C, 1, 1> {
|
||||||
pub fn new_one_to_one(ch: impl Unborrow<Target = C> + 'd, event: Event, task: Task) -> Self {
|
pub fn new_one_to_one(ch: impl Unborrow<Target = C> + 'd, event: Event, task: Task) -> Self {
|
||||||
Ppi::new_many_to_many(ch, [event], [task])
|
Ppi::new_many_to_many(ch, [event], [task])
|
||||||
@ -58,6 +64,22 @@ impl<'d, C: ConfigurableChannel, const EVENT_COUNT: usize, const TASK_COUNT: usi
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl<'d, C: Channel, const EVENT_COUNT: usize, const TASK_COUNT: usize>
|
||||||
|
Ppi<'d, C, EVENT_COUNT, TASK_COUNT>
|
||||||
|
{
|
||||||
|
/// Enables the channel.
|
||||||
|
pub fn enable(&mut self) {
|
||||||
|
let n = self.ch.number();
|
||||||
|
regs().chenset.write(|w| unsafe { w.bits(1 << n) });
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Disables the channel.
|
||||||
|
pub fn disable(&mut self) {
|
||||||
|
let n = self.ch.number();
|
||||||
|
regs().chenclr.write(|w| unsafe { w.bits(1 << n) });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl<'d, C: Channel, const EVENT_COUNT: usize, const TASK_COUNT: usize> Drop
|
impl<'d, C: Channel, const EVENT_COUNT: usize, const TASK_COUNT: usize> Drop
|
||||||
for Ppi<'d, C, EVENT_COUNT, TASK_COUNT>
|
for Ppi<'d, C, EVENT_COUNT, TASK_COUNT>
|
||||||
{
|
{
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
//! many tasks and events, but any single task or event can only be coupled with one channel.
|
//! many tasks and events, but any single task or event can only be coupled with one channel.
|
||||||
//!
|
//!
|
||||||
|
|
||||||
use crate::{pac, peripherals};
|
use crate::peripherals;
|
||||||
use core::marker::PhantomData;
|
use core::marker::PhantomData;
|
||||||
use core::ptr::NonNull;
|
use core::ptr::NonNull;
|
||||||
use embassy::util::Unborrow;
|
use embassy::util::Unborrow;
|
||||||
@ -35,24 +35,6 @@ pub struct Ppi<'d, C: Channel, const EVENT_COUNT: usize, const TASK_COUNT: usize
|
|||||||
phantom: PhantomData<&'d mut C>,
|
phantom: PhantomData<&'d mut C>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'d, C: Channel + 'd, const EVENT_COUNT: usize, const TASK_COUNT: usize>
|
|
||||||
Ppi<'d, C, EVENT_COUNT, TASK_COUNT>
|
|
||||||
{
|
|
||||||
/// Enables the channel.
|
|
||||||
pub fn enable(&mut self) {
|
|
||||||
let r = unsafe { &*pac::PPI::ptr() };
|
|
||||||
r.chenset
|
|
||||||
.write(|w| unsafe { w.bits(1 << self.ch.number()) });
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Disables the channel.
|
|
||||||
pub fn disable(&mut self) {
|
|
||||||
let r = unsafe { &*pac::PPI::ptr() };
|
|
||||||
r.chenclr
|
|
||||||
.write(|w| unsafe { w.bits(1 << self.ch.number()) });
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const REGISTER_DPPI_CONFIG_OFFSET: usize = 0x80 / core::mem::size_of::<u32>();
|
const REGISTER_DPPI_CONFIG_OFFSET: usize = 0x80 / core::mem::size_of::<u32>();
|
||||||
|
|
||||||
/// Represents a task that a peripheral can do.
|
/// Represents a task that a peripheral can do.
|
||||||
|
@ -17,12 +17,16 @@ impl Event {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn regs() -> &'static pac::ppi::RegisterBlock {
|
||||||
|
unsafe { &*pac::PPI::ptr() }
|
||||||
|
}
|
||||||
|
|
||||||
#[cfg(not(feature = "nrf51"))] // Not for nrf51 because of the fork task
|
#[cfg(not(feature = "nrf51"))] // Not for nrf51 because of the fork task
|
||||||
impl<'d, C: StaticChannel> Ppi<'d, C, 0, 1> {
|
impl<'d, C: StaticChannel> Ppi<'d, C, 0, 1> {
|
||||||
pub fn new_zero_to_one(ch: impl Unborrow<Target = C> + 'd, task: Task) -> Self {
|
pub fn new_zero_to_one(ch: impl Unborrow<Target = C> + 'd, task: Task) -> Self {
|
||||||
unborrow!(ch);
|
unborrow!(ch);
|
||||||
|
|
||||||
let r = unsafe { &*pac::PPI::ptr() };
|
let r = regs();
|
||||||
let n = ch.number();
|
let n = ch.number();
|
||||||
r.fork[n].tep.write(|w| unsafe { w.bits(task.reg_val()) });
|
r.fork[n].tep.write(|w| unsafe { w.bits(task.reg_val()) });
|
||||||
|
|
||||||
@ -37,7 +41,7 @@ impl<'d, C: ConfigurableChannel> Ppi<'d, C, 1, 1> {
|
|||||||
pub fn new_one_to_one(ch: impl Unborrow<Target = C> + 'd, event: Event, task: Task) -> Self {
|
pub fn new_one_to_one(ch: impl Unborrow<Target = C> + 'd, event: Event, task: Task) -> Self {
|
||||||
unborrow!(ch);
|
unborrow!(ch);
|
||||||
|
|
||||||
let r = unsafe { &*pac::PPI::ptr() };
|
let r = regs();
|
||||||
let n = ch.number();
|
let n = ch.number();
|
||||||
r.ch[n].eep.write(|w| unsafe { w.bits(event.reg_val()) });
|
r.ch[n].eep.write(|w| unsafe { w.bits(event.reg_val()) });
|
||||||
r.ch[n].tep.write(|w| unsafe { w.bits(task.reg_val()) });
|
r.ch[n].tep.write(|w| unsafe { w.bits(task.reg_val()) });
|
||||||
@ -59,7 +63,7 @@ impl<'d, C: ConfigurableChannel> Ppi<'d, C, 1, 2> {
|
|||||||
) -> Self {
|
) -> Self {
|
||||||
unborrow!(ch);
|
unborrow!(ch);
|
||||||
|
|
||||||
let r = unsafe { &*pac::PPI::ptr() };
|
let r = regs();
|
||||||
let n = ch.number();
|
let n = ch.number();
|
||||||
r.ch[n].eep.write(|w| unsafe { w.bits(event.reg_val()) });
|
r.ch[n].eep.write(|w| unsafe { w.bits(event.reg_val()) });
|
||||||
r.ch[n].tep.write(|w| unsafe { w.bits(task1.reg_val()) });
|
r.ch[n].tep.write(|w| unsafe { w.bits(task1.reg_val()) });
|
||||||
@ -72,13 +76,29 @@ impl<'d, C: ConfigurableChannel> Ppi<'d, C, 1, 2> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl<'d, C: Channel, const EVENT_COUNT: usize, const TASK_COUNT: usize>
|
||||||
|
Ppi<'d, C, EVENT_COUNT, TASK_COUNT>
|
||||||
|
{
|
||||||
|
/// Enables the channel.
|
||||||
|
pub fn enable(&mut self) {
|
||||||
|
let n = self.ch.number();
|
||||||
|
regs().chenset.write(|w| unsafe { w.bits(1 << n) });
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Disables the channel.
|
||||||
|
pub fn disable(&mut self) {
|
||||||
|
let n = self.ch.number();
|
||||||
|
regs().chenclr.write(|w| unsafe { w.bits(1 << n) });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl<'d, C: Channel, const EVENT_COUNT: usize, const TASK_COUNT: usize> Drop
|
impl<'d, C: Channel, const EVENT_COUNT: usize, const TASK_COUNT: usize> Drop
|
||||||
for Ppi<'d, C, EVENT_COUNT, TASK_COUNT>
|
for Ppi<'d, C, EVENT_COUNT, TASK_COUNT>
|
||||||
{
|
{
|
||||||
fn drop(&mut self) {
|
fn drop(&mut self) {
|
||||||
self.disable();
|
self.disable();
|
||||||
|
|
||||||
let r = unsafe { &*pac::PPI::ptr() };
|
let r = regs();
|
||||||
let n = self.ch.number();
|
let n = self.ch.number();
|
||||||
r.ch[n].eep.write(|w| unsafe { w.bits(0) });
|
r.ch[n].eep.write(|w| unsafe { w.bits(0) });
|
||||||
r.ch[n].tep.write(|w| unsafe { w.bits(0) });
|
r.ch[n].tep.write(|w| unsafe { w.bits(0) });
|
||||||
|
Loading…
Reference in New Issue
Block a user