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! { | ||||||
|  |     if #[cfg(any(feature="nrf5340-app-s", feature="nrf9160-s"))] { | ||||||
|         #[interrupt] |         #[interrupt] | ||||||
| fn GPIOTE() { |         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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user