Compare commits
	
		
			32 Commits
		
	
	
		
			stable2
			...
			jamesmunns
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 18e89d7410 | ||
|  | 5f7cd821b5 | ||
|  | d2dcbed920 | ||
|  | e9fa79bd77 | ||
|  | 334900752a | ||
|  | c7d6ea3c78 | ||
|  | a6f4538219 | ||
|  | d7eb067b4c | ||
|  | 2cba879afc | ||
|  | 03325ea81b | ||
|  | 52fabbfb46 | ||
|  | 09592ffa6a | ||
|  | b867f9b5b6 | ||
|  | 198ef8183e | ||
|  | 696c703b8c | ||
|  | 521cdef8a1 | ||
|  | 1dc31c4627 | ||
|  | 9fb2eb7470 | ||
|  | ca3891bb8c | ||
|  | 9ba3aeada4 | ||
|  | dd62bb16e5 | ||
|  | ea43d74780 | ||
|  | 22c39fd697 | ||
|  | 87c0f1525d | ||
|  | a31ae52d1a | ||
|  | 8c0e2748db | ||
|  | ce4dd67f3b | ||
|  | 929fd551de | ||
|  | c97f65ac60 | ||
|  | 33cfef871d | ||
|  | 270504d87d | ||
|  | fe8c46bce3 | 
| @@ -1,3 +0,0 @@ | ||||
| [patch.crates-io] | ||||
| embedded-storage = { git = "https://github.com/rust-embedded-community/embedded-storage", rev = "634302740f8d676538c3890748e7d7dfe372a040" } | ||||
| embedded-storage-async = { git = "https://github.com/rust-embedded-community/embedded-storage", rev = "634302740f8d676538c3890748e7d7dfe372a040" } | ||||
							
								
								
									
										1
									
								
								.github/ci/doc.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/ci/doc.sh
									
									
									
									
										vendored
									
									
								
							| @@ -22,7 +22,6 @@ docserver-builder -i ./embassy-boot/stm32 -o webroot/crates/embassy-boot-stm32/g | ||||
| docserver-builder -i ./embassy-embedded-hal -o webroot/crates/embassy-embedded-hal/git.zup | ||||
| docserver-builder -i ./embassy-executor -o webroot/crates/embassy-executor/git.zup | ||||
| docserver-builder -i ./embassy-futures -o webroot/crates/embassy-futures/git.zup | ||||
| docserver-builder -i ./embassy-lora -o webroot/crates/embassy-lora/git.zup | ||||
| docserver-builder -i ./embassy-net -o webroot/crates/embassy-net/git.zup | ||||
| docserver-builder -i ./embassy-net-driver -o webroot/crates/embassy-net-driver/git.zup | ||||
| docserver-builder -i ./embassy-net-driver-channel -o webroot/crates/embassy-net-driver-channel/git.zup | ||||
|   | ||||
							
								
								
									
										3
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							| @@ -3,6 +3,9 @@ | ||||
|   "[toml]": { | ||||
|     "editor.formatOnSave": false | ||||
|   }, | ||||
|   "[markdown]": { | ||||
|     "editor.formatOnSave": false | ||||
|   }, | ||||
|   "rust-analyzer.check.allTargets": false, | ||||
|   "rust-analyzer.check.noDefaultFeatures": true, | ||||
|   "rust-analyzer.cargo.noDefaultFeatures": true, | ||||
|   | ||||
| @@ -36,7 +36,7 @@ The <a href="https://github.com/embassy-rs/nrf-softdevice">nrf-softdevice</a> cr | ||||
| The <a href="https://github.com/embassy-rs/embassy/tree/main/embassy-stm32-wpan">embassy-stm32-wpan</a> crate provides Bluetooth Low Energy 5.x support for stm32wb microcontrollers. | ||||
|  | ||||
| - **LoRa** -  | ||||
| <a href="https://docs.embassy.dev/embassy-lora/">embassy-lora</a> supports LoRa networking. | ||||
| <a href="hthttps://github.com/lora-rs/lora-rs">The lora-rs project</a> provides an async LoRa and LoRaWAN stack that works well on Embassy. | ||||
|  | ||||
| - **USB** -  | ||||
| <a href="https://docs.embassy.dev/embassy-usb/">embassy-usb</a> implements a device-side USB stack. Implementations for common classes such as USB serial (CDC ACM) and USB HID are available, and a rich builder API allows building your own. | ||||
|   | ||||
| @@ -11,8 +11,8 @@ log = ["dep:log"] | ||||
| firmware-logs = [] | ||||
|  | ||||
| [dependencies] | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time"} | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync"} | ||||
| embassy-time = { version = "0.2", path = "../embassy-time"} | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync"} | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures"} | ||||
| embassy-net-driver-channel = { version = "0.2.0", path = "../embassy-net-driver-channel"} | ||||
|  | ||||
|   | ||||
| @@ -7,7 +7,7 @@ license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-executor = { version = "0.3.0", path = "../../../../../embassy-executor", features = ["defmt", "integrated-timers", "arch-cortex-m", "executor-thread"] } | ||||
| embassy-time = { version = "0.1.4", path = "../../../../../embassy-time", features = ["defmt"] } | ||||
| embassy-time = { version = "0.2.0", path = "../../../../../embassy-time", features = ["defmt"] } | ||||
| embassy-nrf = { version = "0.1.0", path = "../../../../../embassy-nrf", features = ["defmt", "nrf52840", "time-driver-rtc1", "gpiote"] } | ||||
|  | ||||
| defmt = "0.3" | ||||
|   | ||||
| @@ -6,13 +6,22 @@ So you've got one of the xref:examples.adoc[examples] running, but what now? Let | ||||
|  | ||||
| The full example can be found link:https://github.com/embassy-rs/embassy/tree/master/docs/modules/ROOT/examples/basic[here]. | ||||
|  | ||||
| === Rust Nightly | ||||
| === Bare metal | ||||
|  | ||||
| The first thing you'll notice is a few declarations stating that Embassy requires some nightly features: | ||||
| The first thing you'll notice is a few declarations, two of which indicate that Embassy is suitable for bare metal development: | ||||
|  | ||||
| [source,rust] | ||||
| ---- | ||||
| include::example$basic/src/main.rs[lines="1..3"] | ||||
| include::example$basic/src/main.rs[lines="1..2"] | ||||
| ---- | ||||
|  | ||||
| === Rust Nightly | ||||
|  | ||||
| The next declaration is a Rust Unstable feature, which means that Embassy requires Rust Nightly: | ||||
|  | ||||
| [source,rust] | ||||
| ---- | ||||
| include::example$basic/src/main.rs[lines="3"] | ||||
| ---- | ||||
|  | ||||
| === Dealing with errors | ||||
|   | ||||
| @@ -27,7 +27,7 @@ If you use the `#[embassy_executor::main]` macro in your application, it creates | ||||
|  | ||||
| Interrupts are a common way for peripherals to signal completion of some operation and fits well with the async execution model. The following diagram describes a typical application flow where (1) a task is polled and is attempting to make progress. The task then (2) instructs the peripheral to perform some operation, and awaits. After some time has passed, (3) an interrupt is raised, marking the completion of the operation. | ||||
|  | ||||
| The peripheral HAL then (4) ensures that interrupt signals are routed to to the peripheral and updating the peripheral state with the results of the operation. The executor is then (5) notified that the task should be polled, which it will do. | ||||
| The peripheral HAL then (4) ensures that interrupt signals are routed to the peripheral and updating the peripheral state with the results of the operation. The executor is then (5) notified that the task should be polled, which it will do. | ||||
|  | ||||
| image::embassy_irq.png[Interrupt handling] | ||||
|  | ||||
|   | ||||
| @@ -28,9 +28,9 @@ digest = "0.10" | ||||
| log = { version = "0.4", optional = true } | ||||
| ed25519-dalek = { version = "1.0.1", default_features = false, features = ["u32_backend"], optional = true } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../embassy-embedded-hal" } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync" } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage-async = { version = "0.4.0" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync" } | ||||
| embedded-storage = "0.3.1" | ||||
| embedded-storage-async = { version = "0.4.1" } | ||||
| salty = { git = "https://github.com/ycrypto/salty.git", rev = "a9f17911a5024698406b75c0fac56ab5ccf6a8c7", optional = true } | ||||
| signature = { version = "1.6.4", default-features = false } | ||||
|  | ||||
|   | ||||
| @@ -16,13 +16,13 @@ target = "thumbv7em-none-eabi" | ||||
| [dependencies] | ||||
| defmt = { version = "0.3", optional = true } | ||||
|  | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync" } | ||||
| embassy-nrf = { path = "../../embassy-nrf" } | ||||
| embassy-boot = { path = "../boot", default-features = false } | ||||
| cortex-m = { version = "0.7.6" } | ||||
| cortex-m-rt = { version = "0.7" } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage-async = { version = "0.4.0" } | ||||
| embedded-storage = "0.3.1" | ||||
| embedded-storage-async = { version = "0.4.1" } | ||||
| cfg-if = "1.0.0" | ||||
|  | ||||
| nrf-softdevice-mbr = { version = "0.1.0", git = "https://github.com/embassy-rs/nrf-softdevice.git", branch = "master", optional = true } | ||||
|   | ||||
| @@ -17,15 +17,15 @@ defmt = { version = "0.3", optional = true } | ||||
| defmt-rtt = { version = "0.4", optional = true } | ||||
| log = { version = "0.4", optional = true } | ||||
|  | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync" } | ||||
| embassy-rp = { path = "../../embassy-rp", default-features = false } | ||||
| embassy-boot = { path = "../boot", default-features = false } | ||||
| embassy-time = { path = "../../embassy-time" } | ||||
|  | ||||
| cortex-m = { version = "0.7.6" } | ||||
| cortex-m-rt = { version = "0.7" } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage-async = { version = "0.4.0" } | ||||
| embedded-storage = "0.3.1" | ||||
| embedded-storage-async = { version = "0.4.1" } | ||||
| cfg-if = "1.0.0" | ||||
|  | ||||
| [features] | ||||
|   | ||||
| @@ -18,13 +18,13 @@ defmt = { version = "0.3", optional = true } | ||||
| defmt-rtt = { version = "0.4", optional = true } | ||||
| log = { version = "0.4", optional = true } | ||||
|  | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync" } | ||||
| embassy-stm32 = { path = "../../embassy-stm32", default-features = false } | ||||
| embassy-boot = { path = "../boot", default-features = false } | ||||
| cortex-m = { version = "0.7.6" } | ||||
| cortex-m-rt = { version = "0.7" } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage-async = { version = "0.4.0" } | ||||
| embedded-storage = "0.3.1" | ||||
| embedded-storage-async = { version = "0.4.1" } | ||||
| cfg-if = "1.0.0" | ||||
|  | ||||
| [features] | ||||
|   | ||||
| @@ -18,15 +18,15 @@ default = ["time"] | ||||
|  | ||||
| [dependencies] | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync" } | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time", optional = true } | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync" } | ||||
| embassy-time = { version = "0.2", path = "../embassy-time", optional = true } | ||||
| embedded-hal-02 = { package = "embedded-hal", version = "0.2.6", features = [ | ||||
|     "unproven", | ||||
| ] } | ||||
| embedded-hal-1 = { package = "embedded-hal", version = "=1.0.0-rc.2" } | ||||
| embedded-hal-async = { version = "=1.0.0-rc.2" } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage-async = { version = "0.4.0" } | ||||
| embedded-storage = "0.3.1" | ||||
| embedded-storage-async = { version = "0.4.1" } | ||||
| nb = "1.0.0" | ||||
|  | ||||
| defmt = { version = "0.3", optional = true } | ||||
|   | ||||
| @@ -5,6 +5,10 @@ All notable changes to this project will be documented in this file. | ||||
| The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), | ||||
| and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). | ||||
|  | ||||
| ## Unreleased | ||||
|  | ||||
| - Removed `arch-xtensa`. Use the executor provided by the HAL crate (`esp-hal`, `esp32s3-hal`, etc...) instead.  | ||||
|  | ||||
| ## 0.3.3 - 2023-11-15 | ||||
|  | ||||
| - Add `main` macro reexport for Xtensa arch. | ||||
|   | ||||
| @@ -33,7 +33,7 @@ log = { version = "0.4.14", optional = true } | ||||
| rtos-trace = { version = "0.1.2", optional = true } | ||||
|  | ||||
| embassy-macros = { version = "0.2.1", path = "../embassy-macros" } | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time", optional = true} | ||||
| embassy-time = { version = "0.2", path = "../embassy-time", optional = true} | ||||
| critical-section = "1.1" | ||||
|  | ||||
| # needed for riscv | ||||
| @@ -57,7 +57,6 @@ critical-section = { version = "1.1", features = ["std"] } | ||||
| _arch = [] # some arch was picked | ||||
| arch-std = ["_arch", "critical-section/std"] | ||||
| arch-cortex-m = ["_arch", "dep:cortex-m"] | ||||
| arch-xtensa = ["_arch"] | ||||
| arch-riscv32 = ["_arch", "dep:portable-atomic"] | ||||
| arch-wasm = ["_arch", "dep:wasm-bindgen", "dep:js-sys"] | ||||
|  | ||||
|   | ||||
| @@ -1,89 +0,0 @@ | ||||
| #[cfg(feature = "executor-interrupt")] | ||||
| compile_error!("`executor-interrupt` is not supported with `arch-xtensa`."); | ||||
|  | ||||
| #[cfg(feature = "executor-thread")] | ||||
| pub use thread::*; | ||||
| #[cfg(feature = "executor-thread")] | ||||
| mod thread { | ||||
|     use core::marker::PhantomData; | ||||
|     use core::sync::atomic::{AtomicBool, Ordering}; | ||||
|  | ||||
|     pub use embassy_macros::main_riscv as main; | ||||
|  | ||||
|     use crate::{raw, Spawner}; | ||||
|  | ||||
|     /// global atomic used to keep track of whether there is work to do since sev() is not available on Xtensa | ||||
|     static SIGNAL_WORK_THREAD_MODE: AtomicBool = AtomicBool::new(false); | ||||
|  | ||||
|     #[export_name = "__pender"] | ||||
|     fn __pender(_context: *mut ()) { | ||||
|         SIGNAL_WORK_THREAD_MODE.store(true, Ordering::SeqCst); | ||||
|     } | ||||
|  | ||||
|     /// Xtensa Executor | ||||
|     pub struct Executor { | ||||
|         inner: raw::Executor, | ||||
|         not_send: PhantomData<*mut ()>, | ||||
|     } | ||||
|  | ||||
|     impl Executor { | ||||
|         /// Create a new Executor. | ||||
|         pub fn new() -> Self { | ||||
|             Self { | ||||
|                 inner: raw::Executor::new(core::ptr::null_mut()), | ||||
|                 not_send: PhantomData, | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         /// Run the executor. | ||||
|         /// | ||||
|         /// The `init` closure is called with a [`Spawner`] that spawns tasks on | ||||
|         /// this executor. Use it to spawn the initial task(s). After `init` returns, | ||||
|         /// the executor starts running the tasks. | ||||
|         /// | ||||
|         /// To spawn more tasks later, you may keep copies of the [`Spawner`] (it is `Copy`), | ||||
|         /// for example by passing it as an argument to the initial tasks. | ||||
|         /// | ||||
|         /// This function requires `&'static mut self`. This means you have to store the | ||||
|         /// Executor instance in a place where it'll live forever and grants you mutable | ||||
|         /// access. There's a few ways to do this: | ||||
|         /// | ||||
|         /// - a [StaticCell](https://docs.rs/static_cell/latest/static_cell/) (safe) | ||||
|         /// - a `static mut` (unsafe) | ||||
|         /// - a local variable in a function you know never returns (like `fn main() -> !`), upgrading its lifetime with `transmute`. (unsafe) | ||||
|         /// | ||||
|         /// This function never returns. | ||||
|         pub fn run(&'static mut self, init: impl FnOnce(Spawner)) -> ! { | ||||
|             init(self.inner.spawner()); | ||||
|  | ||||
|             loop { | ||||
|                 unsafe { | ||||
|                     self.inner.poll(); | ||||
|  | ||||
|                     // Manual critical section implementation that only masks interrupts handlers. | ||||
|                     // We must not acquire the cross-core on dual-core systems because that would | ||||
|                     // prevent the other core from doing useful work while this core is sleeping. | ||||
|                     let token: critical_section::RawRestoreState; | ||||
|                     core::arch::asm!("rsil {0}, 5", out(reg) token); | ||||
|  | ||||
|                     // we do not care about race conditions between the load and store operations, interrupts | ||||
|                     // will only set this value to true. | ||||
|                     // if there is work to do, loop back to polling | ||||
|                     if SIGNAL_WORK_THREAD_MODE.load(Ordering::SeqCst) { | ||||
|                         SIGNAL_WORK_THREAD_MODE.store(false, Ordering::SeqCst); | ||||
|  | ||||
|                         core::arch::asm!( | ||||
|                         "wsr.ps {0}", | ||||
|                         "rsync", in(reg) token) | ||||
|                     } else { | ||||
|                         // waiti sets the PS.INTLEVEL when slipping into sleep | ||||
|                         // because critical sections in Xtensa are implemented via increasing | ||||
|                         // PS.INTLEVEL the critical section ends here | ||||
|                         // take care not add code after `waiti` if it needs to be inside the CS | ||||
|                         core::arch::asm!("waiti 0"); // critical section ends here | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -1,5 +1,4 @@ | ||||
| #![cfg_attr(not(any(feature = "arch-std", feature = "arch-wasm")), no_std)] | ||||
| #![cfg_attr(feature = "arch-xtensa", feature(asm_experimental_arch))] | ||||
| #![allow(clippy::new_without_default)] | ||||
| #![doc = include_str!("../README.md")] | ||||
| #![warn(missing_docs)] | ||||
| @@ -21,12 +20,11 @@ macro_rules! check_at_most_one { | ||||
|         check_at_most_one!(@amo [$($f)*] [$($f)*] []); | ||||
|     }; | ||||
| } | ||||
| check_at_most_one!("arch-cortex-m", "arch-riscv32", "arch-xtensa", "arch-std", "arch-wasm",); | ||||
| check_at_most_one!("arch-cortex-m", "arch-riscv32", "arch-std", "arch-wasm",); | ||||
|  | ||||
| #[cfg(feature = "_arch")] | ||||
| #[cfg_attr(feature = "arch-cortex-m", path = "arch/cortex_m.rs")] | ||||
| #[cfg_attr(feature = "arch-riscv32", path = "arch/riscv32.rs")] | ||||
| #[cfg_attr(feature = "arch-xtensa", path = "arch/xtensa.rs")] | ||||
| #[cfg_attr(feature = "arch-std", path = "arch/std.rs")] | ||||
| #[cfg_attr(feature = "arch-wasm", path = "arch/wasm.rs")] | ||||
| mod arch; | ||||
|   | ||||
| @@ -17,7 +17,7 @@ embedded-hal-1 = { package = "embedded-hal", version = "=1.0.0-rc.2" } | ||||
| embedded-hal-async = { version = "=1.0.0-rc.2" } | ||||
| embedded-hal-bus = { version = "=0.1.0-rc.2", features = ["async"] } | ||||
| embassy-net-driver-channel = { version = "0.2.0", path = "../embassy-net-driver-channel" } | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time" } | ||||
| embassy-time = { version = "0.2", path = "../embassy-time" } | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | ||||
| bitfield = "0.14.0" | ||||
|  | ||||
|   | ||||
| @@ -24,6 +24,6 @@ features = ["defmt"] | ||||
| defmt = { version = "0.3", optional = true } | ||||
| log = { version = "0.4.14", optional = true } | ||||
|  | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync" } | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | ||||
| embassy-net-driver = { version = "0.2.0", path = "../embassy-net-driver" } | ||||
|   | ||||
| @@ -11,7 +11,7 @@ edition = "2021" | ||||
| embedded-hal = { version = "1.0.0-rc.2" } | ||||
| embedded-hal-async = { version = "=1.0.0-rc.2" } | ||||
| embassy-net-driver = { version = "0.2.0", path = "../embassy-net-driver" } | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time" } | ||||
| embassy-time = { version = "0.2", path = "../embassy-time" } | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | ||||
|  | ||||
| defmt = { version = "0.3", optional = true } | ||||
|   | ||||
| @@ -7,8 +7,8 @@ edition = "2021" | ||||
| defmt = { version = "0.3", optional = true } | ||||
| log = { version = "0.4.14", optional = true } | ||||
|  | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time" } | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync"} | ||||
| embassy-time = { version = "0.2", path = "../embassy-time" } | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync"} | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures"} | ||||
| embassy-net-driver-channel = { version = "0.2.0", path = "../embassy-net-driver-channel"} | ||||
|  | ||||
|   | ||||
| @@ -19,7 +19,7 @@ embedded-io-async = { version = "0.6.1" } | ||||
| embassy-net-driver-channel = { version = "0.2.0", path = "../embassy-net-driver-channel" } | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | ||||
| ppproto = { version = "0.1.2"} | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync" } | ||||
|  | ||||
| [package.metadata.embassy_docs] | ||||
| src_base = "https://github.com/embassy-rs/embassy/blob/embassy-net-ppp-v$VERSION/embassy-net-ppp/src/" | ||||
|   | ||||
| @@ -11,7 +11,7 @@ edition = "2021" | ||||
| embedded-hal = { version = "1.0.0-rc.2" } | ||||
| embedded-hal-async = { version = "=1.0.0-rc.2" } | ||||
| embassy-net-driver-channel = { version = "0.2.0", path = "../embassy-net-driver-channel" } | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time" } | ||||
| embassy-time = { version = "0.2", path = "../embassy-time" } | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | ||||
| defmt = { version = "0.3", optional = true } | ||||
|  | ||||
|   | ||||
| @@ -50,8 +50,8 @@ smoltcp = { git = "https://github.com/smoltcp-rs/smoltcp.git", rev = "b57e2f9e70 | ||||
| ] } | ||||
|  | ||||
| embassy-net-driver = { version = "0.2.0", path = "../embassy-net-driver" } | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time" } | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync" } | ||||
| embassy-time = { version = "0.2", path = "../embassy-time" } | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync" } | ||||
| embedded-io-async = { version = "0.6.1" } | ||||
|  | ||||
| managed = { version = "0.8.0", default-features = false, features = [ "map" ] } | ||||
|   | ||||
| @@ -87,8 +87,8 @@ _gpio-p1 = [] | ||||
| _nrf52832_anomaly_109 = [] | ||||
|  | ||||
| [dependencies] | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time", optional = true } | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync" } | ||||
| embassy-time = { version = "0.2", path = "../embassy-time", optional = true } | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync" } | ||||
| embassy-hal-internal = {version = "0.1.0", path = "../embassy-hal-internal", features = ["cortex-m", "prio-bits-3"] } | ||||
| embassy-embedded-hal = {version = "0.1.0", path = "../embassy-embedded-hal" } | ||||
| embassy-usb-driver = {version = "0.1.0", path = "../embassy-usb-driver" } | ||||
| @@ -106,7 +106,7 @@ cortex-m = "0.7.6" | ||||
| critical-section = "1.1" | ||||
| rand_core = "0.6.3" | ||||
| fixed = "1.10.0" | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| embedded-storage-async = "0.4.0" | ||||
| cfg-if = "1.0.0" | ||||
|  | ||||
|   | ||||
| @@ -7,6 +7,7 @@ pub const FORCE_COPY_BUFFER_SIZE: usize = 256; | ||||
| pub const FLASH_SIZE: usize = 192 * 1024; | ||||
|  | ||||
| pub const RESET_PIN: u32 = 21; | ||||
| pub const APPROTECT_MIN_BUILD_CODE: u8 = b'B'; | ||||
|  | ||||
| embassy_hal_internal::peripherals! { | ||||
|     // RTC | ||||
|   | ||||
| @@ -7,6 +7,7 @@ pub const FORCE_COPY_BUFFER_SIZE: usize = 256; | ||||
| pub const FLASH_SIZE: usize = 192 * 1024; | ||||
|  | ||||
| pub const RESET_PIN: u32 = 21; | ||||
| pub const APPROTECT_MIN_BUILD_CODE: u8 = b'E'; | ||||
|  | ||||
| embassy_hal_internal::peripherals! { | ||||
|     // RTC | ||||
|   | ||||
| @@ -7,6 +7,7 @@ pub const FORCE_COPY_BUFFER_SIZE: usize = 256; | ||||
| pub const FLASH_SIZE: usize = 192 * 1024; | ||||
|  | ||||
| pub const RESET_PIN: u32 = 21; | ||||
| pub const APPROTECT_MIN_BUILD_CODE: u8 = b'B'; | ||||
|  | ||||
| embassy_hal_internal::peripherals! { | ||||
|     // RTC | ||||
|   | ||||
| @@ -7,6 +7,7 @@ pub const FORCE_COPY_BUFFER_SIZE: usize = 512; | ||||
| pub const FLASH_SIZE: usize = 256 * 1024; | ||||
|  | ||||
| pub const RESET_PIN: u32 = 18; | ||||
| pub const APPROTECT_MIN_BUILD_CODE: u8 = b'D'; | ||||
|  | ||||
| embassy_hal_internal::peripherals! { | ||||
|     // USB | ||||
|   | ||||
| @@ -11,6 +11,7 @@ pub const FORCE_COPY_BUFFER_SIZE: usize = 255; | ||||
| pub const FLASH_SIZE: usize = 512 * 1024; | ||||
|  | ||||
| pub const RESET_PIN: u32 = 21; | ||||
| pub const APPROTECT_MIN_BUILD_CODE: u8 = b'G'; | ||||
|  | ||||
| embassy_hal_internal::peripherals! { | ||||
|     // RTC | ||||
|   | ||||
| @@ -7,6 +7,7 @@ pub const FORCE_COPY_BUFFER_SIZE: usize = 512; | ||||
| pub const FLASH_SIZE: usize = 512 * 1024; | ||||
|  | ||||
| pub const RESET_PIN: u32 = 18; | ||||
| pub const APPROTECT_MIN_BUILD_CODE: u8 = b'B'; | ||||
|  | ||||
| embassy_hal_internal::peripherals! { | ||||
|     // USB | ||||
|   | ||||
| @@ -7,6 +7,7 @@ pub const FORCE_COPY_BUFFER_SIZE: usize = 512; | ||||
| pub const FLASH_SIZE: usize = 1024 * 1024; | ||||
|  | ||||
| pub const RESET_PIN: u32 = 18; | ||||
| pub const APPROTECT_MIN_BUILD_CODE: u8 = b'F'; | ||||
|  | ||||
| embassy_hal_internal::peripherals! { | ||||
|     // USB | ||||
|   | ||||
| @@ -349,10 +349,11 @@ pub fn init(config: config::Config) -> Peripherals { | ||||
|                 // Get the letter for the build code (b'A' .. b'F') | ||||
|                 let build_code = (variant >> 8) as u8; | ||||
|  | ||||
|                 if build_code >= b'F' { | ||||
|                     // Chips with build code F and higher (revision 3 and higher) have an | ||||
|                 if build_code >= chip::APPROTECT_MIN_BUILD_CODE { | ||||
|                     // Chips with a certain chip type-specific build code or higher have an | ||||
|                     // improved APPROTECT ("hardware and software controlled access port protection") | ||||
|                     // which needs explicit action by the firmware to keep it unlocked | ||||
|                     // See https://devzone.nordicsemi.com/nordic/nordic-blog/b/blog/posts/working-with-the-nrf52-series-improved-approtect | ||||
|  | ||||
|                     // UICR.APPROTECT = SwDisabled | ||||
|                     let res = uicr_write(consts::UICR_APPROTECT, consts::APPROTECT_DISABLED); | ||||
|   | ||||
							
								
								
									
										22
									
								
								embassy-nrf/src/qspi.rs
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										22
									
								
								embassy-nrf/src/qspi.rs
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -391,8 +391,13 @@ impl<'d, T: Instance> Qspi<'d, T> { | ||||
|     /// | ||||
|     /// The difference with `read` is that this does not do bounds checks | ||||
|     /// against the flash capacity. It is intended for use when QSPI is used as | ||||
|     /// a raw bus, not with flash memory.     | ||||
|     /// a raw bus, not with flash memory. | ||||
|     pub async fn read_raw(&mut self, address: u32, data: &mut [u8]) -> Result<(), Error> { | ||||
|         // Avoid blocking_wait_ready() blocking forever on zero-length buffers. | ||||
|         if data.len() == 0 { | ||||
|             return Ok(()); | ||||
|         } | ||||
|  | ||||
|         let ondrop = OnDrop::new(Self::blocking_wait_ready); | ||||
|  | ||||
|         self.start_read(address, data)?; | ||||
| @@ -409,6 +414,11 @@ impl<'d, T: Instance> Qspi<'d, T> { | ||||
|     /// against the flash capacity. It is intended for use when QSPI is used as | ||||
|     /// a raw bus, not with flash memory. | ||||
|     pub async fn write_raw(&mut self, address: u32, data: &[u8]) -> Result<(), Error> { | ||||
|         // Avoid blocking_wait_ready() blocking forever on zero-length buffers. | ||||
|         if data.len() == 0 { | ||||
|             return Ok(()); | ||||
|         } | ||||
|  | ||||
|         let ondrop = OnDrop::new(Self::blocking_wait_ready); | ||||
|  | ||||
|         self.start_write(address, data)?; | ||||
| @@ -425,6 +435,11 @@ impl<'d, T: Instance> Qspi<'d, T> { | ||||
|     /// against the flash capacity. It is intended for use when QSPI is used as | ||||
|     /// a raw bus, not with flash memory. | ||||
|     pub fn blocking_read_raw(&mut self, address: u32, data: &mut [u8]) -> Result<(), Error> { | ||||
|         // Avoid blocking_wait_ready() blocking forever on zero-length buffers. | ||||
|         if data.len() == 0 { | ||||
|             return Ok(()); | ||||
|         } | ||||
|  | ||||
|         self.start_read(address, data)?; | ||||
|         Self::blocking_wait_ready(); | ||||
|         Ok(()) | ||||
| @@ -436,6 +451,11 @@ impl<'d, T: Instance> Qspi<'d, T> { | ||||
|     /// against the flash capacity. It is intended for use when QSPI is used as | ||||
|     /// a raw bus, not with flash memory. | ||||
|     pub fn blocking_write_raw(&mut self, address: u32, data: &[u8]) -> Result<(), Error> { | ||||
|         // Avoid blocking_wait_ready() blocking forever on zero-length buffers. | ||||
|         if data.len() == 0 { | ||||
|             return Ok(()); | ||||
|         } | ||||
|  | ||||
|         self.start_write(address, data)?; | ||||
|         Self::blocking_wait_ready(); | ||||
|         Ok(()) | ||||
|   | ||||
| @@ -52,8 +52,8 @@ qspi-as-gpio = [] | ||||
| run-from-ram = [] | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync" } | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time", features = [ "tick-hz-1_000_000" ] } | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync" } | ||||
| embassy-time = { version = "0.2", path = "../embassy-time", features = [ "tick-hz-1_000_000" ] } | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | ||||
| embassy-hal-internal = {version = "0.1.0", path = "../embassy-hal-internal", features = ["cortex-m", "prio-bits-2"] } | ||||
| embassy-embedded-hal = {version = "0.1.0", path = "../embassy-embedded-hal" } | ||||
| @@ -71,7 +71,7 @@ chrono = { version = "0.4", default-features = false, optional = true } | ||||
| embedded-io = { version = "0.6.0" } | ||||
| embedded-io-async = { version = "0.6.1" } | ||||
| embedded-storage = { version = "0.3" } | ||||
| embedded-storage-async = { version = "0.4.0" } | ||||
| embedded-storage-async = { version = "0.4.1" } | ||||
| rand_core = "0.6.4" | ||||
| fixed = "1.23.1" | ||||
|  | ||||
|   | ||||
| @@ -12,8 +12,8 @@ features = ["stm32wb55rg"] | ||||
|  | ||||
| [dependencies] | ||||
| embassy-stm32 = { version = "0.1.0", path = "../embassy-stm32" } | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync" } | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time", optional = true } | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync" } | ||||
| embassy-time = { version = "0.2", path = "../embassy-time", optional = true } | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | ||||
| embassy-hal-internal = { version = "0.1.0", path = "../embassy-hal-internal" } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../embassy-embedded-hal" } | ||||
|   | ||||
| @@ -32,8 +32,8 @@ flavors = [ | ||||
| ] | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync" } | ||||
| embassy-time = { version = "0.1.5", path = "../embassy-time", optional = true } | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync" } | ||||
| embassy-time = { version = "0.2", path = "../embassy-time", optional = true } | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | ||||
| embassy-hal-internal = {version = "0.1.0", path = "../embassy-hal-internal", features = ["cortex-m", "prio-bits-4"] } | ||||
| embassy-embedded-hal = {version = "0.1.0", path = "../embassy-embedded-hal" } | ||||
| @@ -46,8 +46,8 @@ embedded-hal-1 = { package = "embedded-hal", version = "=1.0.0-rc.2" } | ||||
| embedded-hal-async = { version = "=1.0.0-rc.2" } | ||||
| embedded-hal-nb = { version = "=1.0.0-rc.2" } | ||||
|  | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage-async = { version = "0.4.0" } | ||||
| embedded-storage = "0.3.1" | ||||
| embedded-storage-async = { version = "0.4.1" } | ||||
|  | ||||
| defmt = { version = "0.3", optional = true } | ||||
| log = { version = "0.4.14", optional = true } | ||||
|   | ||||
| @@ -63,6 +63,8 @@ pub mod sai; | ||||
| pub mod sdmmc; | ||||
| #[cfg(spi)] | ||||
| pub mod spi; | ||||
| #[cfg(uid)] | ||||
| pub mod uid; | ||||
| #[cfg(usart)] | ||||
| pub mod usart; | ||||
| #[cfg(usb)] | ||||
|   | ||||
| @@ -10,10 +10,18 @@ use crate::time::Hertz; | ||||
| /// HSI speed | ||||
| pub const HSI_FREQ: Hertz = Hertz(16_000_000); | ||||
|  | ||||
| #[derive(Clone, Copy, Eq, PartialEq)] | ||||
| pub enum HseMode { | ||||
|     /// crystal/ceramic oscillator (HSEBYP=0) | ||||
|     Oscillator, | ||||
|     /// external analog clock (low swing) (HSEBYP=1) | ||||
|     Bypass, | ||||
| } | ||||
|  | ||||
| /// System clock mux source | ||||
| #[derive(Clone, Copy)] | ||||
| pub enum ClockSrc { | ||||
|     HSE(Hertz), | ||||
|     HSE(Hertz, HseMode), | ||||
|     HSI(HSIPrescaler), | ||||
|     PLL(PllConfig), | ||||
|     LSI, | ||||
| @@ -61,7 +69,7 @@ impl Default for PllConfig { | ||||
| #[derive(Clone, Copy, Eq, PartialEq)] | ||||
| pub enum PllSource { | ||||
|     HSI, | ||||
|     HSE(Hertz), | ||||
|     HSE(Hertz, HseMode), | ||||
| } | ||||
|  | ||||
| /// Clocks configutation | ||||
| @@ -90,7 +98,7 @@ impl PllConfig { | ||||
|     pub(crate) fn init(self) -> Hertz { | ||||
|         let (src, input_freq) = match self.source { | ||||
|             PllSource::HSI => (vals::Pllsrc::HSI, HSI_FREQ), | ||||
|             PllSource::HSE(freq) => (vals::Pllsrc::HSE, freq), | ||||
|             PllSource::HSE(freq, _) => (vals::Pllsrc::HSE, freq), | ||||
|         }; | ||||
|  | ||||
|         let m_freq = input_freq / self.m; | ||||
| @@ -125,8 +133,11 @@ impl PllConfig { | ||||
|                 RCC.cr().write(|w| w.set_hsion(true)); | ||||
|                 while !RCC.cr().read().hsirdy() {} | ||||
|             } | ||||
|             PllSource::HSE(_) => { | ||||
|                 RCC.cr().write(|w| w.set_hseon(true)); | ||||
|             PllSource::HSE(_, mode) => { | ||||
|                 RCC.cr().write(|w| { | ||||
|                     w.set_hsebyp(mode != HseMode::Oscillator); | ||||
|                     w.set_hseon(true); | ||||
|                 }); | ||||
|                 while !RCC.cr().read().hserdy() {} | ||||
|             } | ||||
|         } | ||||
| @@ -177,9 +188,12 @@ pub(crate) unsafe fn init(config: Config) { | ||||
|  | ||||
|             (HSI_FREQ / div, Sw::HSI) | ||||
|         } | ||||
|         ClockSrc::HSE(freq) => { | ||||
|         ClockSrc::HSE(freq, mode) => { | ||||
|             // Enable HSE | ||||
|             RCC.cr().write(|w| w.set_hseon(true)); | ||||
|             RCC.cr().write(|w| { | ||||
|                 w.set_hseon(true); | ||||
|                 w.set_hsebyp(mode != HseMode::Oscillator); | ||||
|             }); | ||||
|             while !RCC.cr().read().hserdy() {} | ||||
|  | ||||
|             (freq, Sw::HSE) | ||||
|   | ||||
| @@ -117,6 +117,75 @@ impl From<TimerPrescaler> for Timpre { | ||||
|     } | ||||
| } | ||||
|  | ||||
| /// Power supply configuration | ||||
| /// See RM0433 Rev 4 7.4 | ||||
| #[cfg(any(pwr_h7rm0399, pwr_h7rm0455, pwr_h7rm0468))] | ||||
| #[derive(PartialEq)] | ||||
| pub enum SupplyConfig { | ||||
|     /// Default power supply configuration. | ||||
|     /// V CORE Power Domains are supplied from the LDO according to VOS. | ||||
|     /// SMPS step-down converter enabled at 1.2V, may be used to supply the LDO. | ||||
|     Default, | ||||
|  | ||||
|     /// Power supply configuration using the LDO. | ||||
|     /// V CORE Power Domains are supplied from the LDO according to VOS. | ||||
|     /// LDO power mode (Main, LP, Off) will follow system low-power modes. | ||||
|     /// SMPS step-down converter disabled. | ||||
|     LDO, | ||||
|  | ||||
|     /// Power supply configuration directly from the SMPS step-down converter. | ||||
|     /// V CORE Power Domains are supplied from SMPS step-down converter according to VOS. | ||||
|     /// LDO bypassed. | ||||
|     /// SMPS step-down converter power mode (MR, LP, Off) will follow system low-power modes. | ||||
|     DirectSMPS, | ||||
|  | ||||
|     /// Power supply configuration from the SMPS step-down converter, that supplies the LDO. | ||||
|     /// V CORE Power Domains are supplied from the LDO according to VOS | ||||
|     /// LDO power mode (Main, LP, Off) will follow system low-power modes. | ||||
|     /// SMPS step-down converter enabled according to SDLEVEL, and supplies the LDO. | ||||
|     /// SMPS step-down converter power mode (MR, LP, Off) will follow system low-power modes. | ||||
|     SMPSLDO(SMPSSupplyVoltage), | ||||
|  | ||||
|     /// Power supply configuration from SMPS supplying external circuits and potentially the LDO. | ||||
|     /// V CORE Power Domains are supplied from voltage regulator according to VOS | ||||
|     /// LDO power mode (Main, LP, Off) will follow system low-power modes. | ||||
|     /// SMPS step-down converter enabled according to SDLEVEL used to supply external circuits and may supply the LDO. | ||||
|     /// SMPS step-down converter forced ON in MR mode. | ||||
|     SMPSExternalLDO(SMPSSupplyVoltage), | ||||
|  | ||||
|     /// Power supply configuration from SMPS supplying external circuits and bypassing the LDO. | ||||
|     /// V CORE supplied from external source | ||||
|     /// SMPS step-down converter enabled according to SDLEVEL used to supply external circuits and may supply the external source for V CORE . | ||||
|     /// SMPS step-down converter forced ON in MR mode. | ||||
|     SMPSExternalLDOBypass(SMPSSupplyVoltage), | ||||
|  | ||||
|     /// Power supply configuration from an external source, SMPS disabled and the LDO bypassed. | ||||
|     /// V CORE supplied from external source | ||||
|     /// SMPS step-down converter disabled and LDO bypassed, voltage monitoring still active. | ||||
|     SMPSDisabledLDOBypass, | ||||
| } | ||||
|  | ||||
| /// SMPS step-down converter voltage output level. | ||||
| /// This is only used in certain power supply configurations: | ||||
| /// SMPSLDO, SMPSExternalLDO, SMPSExternalLDOBypass. | ||||
| #[cfg(any(pwr_h7rm0399, pwr_h7rm0455, pwr_h7rm0468))] | ||||
| #[derive(PartialEq)] | ||||
| pub enum SMPSSupplyVoltage { | ||||
|     V1_8, | ||||
|     V2_5, | ||||
| } | ||||
|  | ||||
| #[cfg(any(pwr_h7rm0399, pwr_h7rm0455, pwr_h7rm0468))] | ||||
| impl SMPSSupplyVoltage { | ||||
|     /// Convert SMPSSupplyVoltage to u8 representation. | ||||
|     fn to_u8(&self) -> u8 { | ||||
|         match self { | ||||
|             SMPSSupplyVoltage::V1_8 => 0b01, | ||||
|             SMPSSupplyVoltage::V2_5 => 0b10, | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| /// Configuration of the core clocks | ||||
| #[non_exhaustive] | ||||
| pub struct Config { | ||||
| @@ -144,6 +213,9 @@ pub struct Config { | ||||
|     pub timer_prescaler: TimerPrescaler, | ||||
|     pub voltage_scale: VoltageScale, | ||||
|     pub ls: super::LsConfig, | ||||
|  | ||||
|     #[cfg(any(pwr_h7rm0399, pwr_h7rm0455, pwr_h7rm0468))] | ||||
|     pub supply_config: SupplyConfig, | ||||
| } | ||||
|  | ||||
| impl Default for Config { | ||||
| @@ -177,6 +249,9 @@ impl Default for Config { | ||||
|             timer_prescaler: TimerPrescaler::DefaultX2, | ||||
|             voltage_scale: VoltageScale::Scale0, | ||||
|             ls: Default::default(), | ||||
|  | ||||
|             #[cfg(any(pwr_h7rm0399, pwr_h7rm0455, pwr_h7rm0468))] | ||||
|             supply_config: SupplyConfig::Default, | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -195,12 +270,58 @@ pub(crate) unsafe fn init(config: Config) { | ||||
|     }); | ||||
|  | ||||
|     #[cfg(any(pwr_h7rm0399, pwr_h7rm0455, pwr_h7rm0468))] | ||||
|     PWR.cr3().modify(|w| { | ||||
|         // hardcode "Direct SPMS" for now, this is what works on nucleos with the | ||||
|         // default solderbridge configuration. | ||||
|         w.set_sden(true); | ||||
|         w.set_ldoen(false); | ||||
|     }); | ||||
|     { | ||||
|         match config.supply_config { | ||||
|             SupplyConfig::Default => { | ||||
|                 PWR.cr3().modify(|w| { | ||||
|                     w.set_sdlevel(0b00); | ||||
|                     w.set_sdexthp(false); | ||||
|                     w.set_sden(true); | ||||
|                     w.set_ldoen(true); | ||||
|                     w.set_bypass(false); | ||||
|                 }); | ||||
|             } | ||||
|             SupplyConfig::LDO => { | ||||
|                 PWR.cr3().modify(|w| { | ||||
|                     w.set_sden(false); | ||||
|                     w.set_ldoen(true); | ||||
|                     w.set_bypass(false); | ||||
|                 }); | ||||
|             } | ||||
|             SupplyConfig::DirectSMPS => { | ||||
|                 PWR.cr3().modify(|w| { | ||||
|                     w.set_sdexthp(false); | ||||
|                     w.set_sden(true); | ||||
|                     w.set_ldoen(false); | ||||
|                     w.set_bypass(false); | ||||
|                 }); | ||||
|             } | ||||
|             SupplyConfig::SMPSLDO(ref smps_supply_voltage) | ||||
|             | SupplyConfig::SMPSExternalLDO(ref smps_supply_voltage) | ||||
|             | SupplyConfig::SMPSExternalLDOBypass(ref smps_supply_voltage) => { | ||||
|                 PWR.cr3().modify(|w| { | ||||
|                     w.set_sdlevel(smps_supply_voltage.to_u8()); | ||||
|                     w.set_sdexthp(matches!( | ||||
|                         config.supply_config, | ||||
|                         SupplyConfig::SMPSExternalLDO(_) | SupplyConfig::SMPSExternalLDOBypass(_) | ||||
|                     )); | ||||
|                     w.set_sden(true); | ||||
|                     w.set_ldoen(matches!( | ||||
|                         config.supply_config, | ||||
|                         SupplyConfig::SMPSLDO(_) | SupplyConfig::SMPSExternalLDO(_) | ||||
|                     )); | ||||
|                     w.set_bypass(matches!(config.supply_config, SupplyConfig::SMPSExternalLDOBypass(_))); | ||||
|                 }); | ||||
|             } | ||||
|             SupplyConfig::SMPSDisabledLDOBypass => { | ||||
|                 PWR.cr3().modify(|w| { | ||||
|                     w.set_sden(false); | ||||
|                     w.set_ldoen(false); | ||||
|                     w.set_bypass(true); | ||||
|                 }); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     // Validate the supply configuration. If you are stuck here, it is | ||||
|     // because the voltages on your board do not match those specified | ||||
|   | ||||
| @@ -211,7 +211,7 @@ pub enum DayOfWeek { | ||||
| #[cfg(feature = "chrono")] | ||||
| impl From<chrono::Weekday> for DayOfWeek { | ||||
|     fn from(weekday: Weekday) -> Self { | ||||
|         day_of_week_from_u8(weekday.num_days_from_monday() as u8).unwrap() | ||||
|         day_of_week_from_u8(weekday.number_from_monday() as u8).unwrap() | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -18,6 +18,17 @@ use crate::rtc::Rtc; | ||||
| use crate::timer::sealed::{Basic16bitInstance as BasicInstance, GeneralPurpose16bitInstance as Instance}; | ||||
| use crate::{interrupt, peripherals}; | ||||
|  | ||||
| // NOTE regarding ALARM_COUNT: | ||||
| // | ||||
| // As of 2023-12-04, this driver is implemented using CC1 as the halfway rollover interrupt, and any | ||||
| // additional CC capabilities to provide timer alarms to embassy-time. embassy-time requires AT LEAST | ||||
| // one alarm to be allocatable, which means timers that only have CC1, such as TIM16/TIM17, are not | ||||
| // candidates for use as an embassy-time driver provider. | ||||
| // | ||||
| // The values of ALARM_COUNT below are not the TOTAL CC registers available, but rather the number | ||||
| // available after reserving CC1 for regular time keeping. For example, TIM2 has four CC registers: | ||||
| // CC1, CC2, CC3, and CC4, so it can provide ALARM_COUNT = 3. | ||||
|  | ||||
| #[cfg(not(any(time_driver_tim12, time_driver_tim15)))] | ||||
| const ALARM_COUNT: usize = 3; | ||||
|  | ||||
|   | ||||
| @@ -46,7 +46,10 @@ pub(crate) mod sealed { | ||||
|             assert!(f > 0); | ||||
|             let pclk_ticks_per_timer_period = timer_f / f; | ||||
|             let psc: u16 = unwrap!(((pclk_ticks_per_timer_period - 1) / (1 << 16)).try_into()); | ||||
|             let arr: u16 = unwrap!((pclk_ticks_per_timer_period / (u32::from(psc) + 1)).try_into()); | ||||
|             let divide_by = pclk_ticks_per_timer_period / (u32::from(psc) + 1); | ||||
|  | ||||
|             // the timer counts `0..=arr`, we want it to count `0..divide_by` | ||||
|             let arr = unwrap!(u16::try_from(divide_by - 1)); | ||||
|  | ||||
|             let regs = Self::regs(); | ||||
|             regs.psc().write(|r| r.set_psc(psc)); | ||||
|   | ||||
							
								
								
									
										29
									
								
								embassy-stm32/src/uid.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								embassy-stm32/src/uid.rs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| /// Get this device's unique 96-bit ID. | ||||
| pub fn uid() -> &'static [u8; 12] { | ||||
|     unsafe { &*crate::pac::UID.uid(0).as_ptr().cast::<[u8; 12]>() } | ||||
| } | ||||
|  | ||||
| /// Get this device's unique 96-bit ID, encoded into a string of 24 hexadecimal ASCII digits. | ||||
| pub fn uid_hex() -> &'static str { | ||||
|     unsafe { core::str::from_utf8_unchecked(uid_hex_bytes()) } | ||||
| } | ||||
|  | ||||
| /// Get this device's unique 96-bit ID, encoded into 24 hexadecimal ASCII bytes. | ||||
| pub fn uid_hex_bytes() -> &'static [u8; 24] { | ||||
|     const HEX: &[u8; 16] = b"0123456789ABCDEF"; | ||||
|     static mut UID_HEX: [u8; 24] = [0; 24]; | ||||
|     static mut LOADED: bool = false; | ||||
|     critical_section::with(|_| unsafe { | ||||
|         if !LOADED { | ||||
|             let uid = uid(); | ||||
|             for (idx, v) in uid.iter().enumerate() { | ||||
|                 let lo = v & 0x0f; | ||||
|                 let hi = (v & 0xf0) >> 4; | ||||
|                 UID_HEX[idx * 2] = HEX[hi as usize]; | ||||
|                 UID_HEX[idx * 2 + 1] = HEX[lo as usize]; | ||||
|             } | ||||
|             LOADED = true; | ||||
|         } | ||||
|     }); | ||||
|     unsafe { &UID_HEX } | ||||
| } | ||||
| @@ -5,6 +5,13 @@ All notable changes to this project will be documented in this file. | ||||
| The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), | ||||
| and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). | ||||
|  | ||||
| ## 0.5.0 - 2023-12-04 | ||||
|  | ||||
| - Add a PriorityChannel. | ||||
| - Remove nightly and unstable-traits features in preparation for 1.75. | ||||
| - Upgrade heapless to 0.8. | ||||
| - Upgrade static-cell to 2.0. | ||||
|  | ||||
| ## 0.4.0 - 2023-10-31 | ||||
|  | ||||
| - Re-add impl_trait_projections | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| [package] | ||||
| name = "embassy-sync" | ||||
| version = "0.4.0" | ||||
| version = "0.5.0" | ||||
| edition = "2021" | ||||
| description = "no-std, no-alloc synchronization primitives with async support" | ||||
| repository = "https://github.com/embassy-rs/embassy" | ||||
|   | ||||
| @@ -5,9 +5,11 @@ All notable changes to this project will be documented in this file. | ||||
| The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), | ||||
| and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). | ||||
|  | ||||
| ## 0.1.6 - ??? | ||||
| ## 0.2.0 - 2023-12-04 | ||||
|  | ||||
| - Added tick rates in multiples of 10 kHz | ||||
| - Remove nightly and unstable-traits features in preparation for 1.75. | ||||
| - Update heapless to 0.8. | ||||
|  | ||||
| ## 0.1.5 - 2023-10-16 | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| [package] | ||||
| name = "embassy-time" | ||||
| version = "0.1.5" | ||||
| version = "0.2.0" | ||||
| edition = "2021" | ||||
| description = "Instant and Duration for embedded no-std systems, with async timer support" | ||||
| repository = "https://github.com/embassy-rs/embassy" | ||||
|   | ||||
| @@ -10,7 +10,7 @@ target = "thumbv7em-none-eabi" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-usb = { version = "0.1.0", path = "../embassy-usb" } | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync" } | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | ||||
| futures = { version = "0.3", default-features = false } | ||||
| static_cell = { version = "2" } | ||||
|   | ||||
| @@ -40,7 +40,7 @@ max-handler-count-8 = [] | ||||
| [dependencies] | ||||
| embassy-futures = { version = "0.1.0", path = "../embassy-futures" } | ||||
| embassy-usb-driver = { version = "0.1.0", path = "../embassy-usb-driver" } | ||||
| embassy-sync = { version = "0.4.0", path = "../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../embassy-sync" } | ||||
| embassy-net-driver-channel = { version = "0.2.0", path = "../embassy-net-driver-channel" } | ||||
|  | ||||
| defmt = { version = "0.3", optional = true } | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| embassy-executor = { version = "0.3.3", path = "../../../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "nightly", "integrated-timers", "arch-cortex-m", "executor-thread"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../../../embassy-time", features = [] } | ||||
| embassy-time = { version = "0.2", path = "../../../../embassy-time", features = [] } | ||||
| embassy-nrf = { version = "0.1.0", path = "../../../../embassy-nrf", features = ["time-driver-rtc1", "gpiote", ] } | ||||
| embassy-boot = { version = "0.1.0", path = "../../../../embassy-boot/boot", features = [] } | ||||
| embassy-boot-nrf = { version = "0.1.0", path = "../../../../embassy-boot/nrf", features = [] } | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| embassy-executor = { version = "0.3.3", path = "../../../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "nightly", "integrated-timers", "arch-cortex-m", "executor-thread"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../../../embassy-time", features = [] } | ||||
| embassy-time = { version = "0.2", path = "../../../../embassy-time", features = [] } | ||||
| embassy-rp = { version = "0.1.0", path = "../../../../embassy-rp", features = ["time-driver", ] } | ||||
| embassy-boot-rp = { version = "0.1.0", path = "../../../../embassy-boot/rp", features = [] } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../../../embassy-embedded-hal" } | ||||
| @@ -20,7 +20,7 @@ embedded-hal = { version = "0.2.6" } | ||||
|  | ||||
| cortex-m = { version = "0.7.6", features = ["inline-asm", "critical-section-single-core"] } | ||||
| cortex-m-rt = "0.7.0" | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
|  | ||||
| [features] | ||||
| default = ["panic-reset"] | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| embassy-executor = { version = "0.3.3", path = "../../../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "nightly", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../../../embassy-stm32", features = ["stm32f303re", "time-driver-any", "exti"]  } | ||||
| embassy-boot-stm32 = { version = "0.1.0", path = "../../../../embassy-boot/stm32" } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../../../embassy-embedded-hal" } | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| embassy-executor = { version = "0.3.3", path = "../../../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "nightly", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../../../embassy-stm32", features = ["stm32f767zi", "time-driver-any", "exti"]  } | ||||
| embassy-boot-stm32 = { version = "0.1.0", path = "../../../../embassy-boot/stm32", features = [] } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../../../embassy-embedded-hal" } | ||||
| @@ -16,7 +16,7 @@ defmt = { version = "0.3", optional = true } | ||||
| defmt-rtt = { version = "0.4", optional = true } | ||||
| panic-reset = { version = "0.1.1" } | ||||
| embedded-hal = { version = "0.2.6" } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
|  | ||||
| cortex-m = { version = "0.7.6", features = ["inline-asm", "critical-section-single-core"] } | ||||
| cortex-m-rt = "0.7.0" | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| embassy-executor = { version = "0.3.3", path = "../../../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "nightly", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../../../embassy-stm32", features = ["stm32h743zi", "time-driver-any", "exti"]  } | ||||
| embassy-boot-stm32 = { version = "0.1.0", path = "../../../../embassy-boot/stm32", features = [] } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../../../embassy-embedded-hal" } | ||||
| @@ -16,7 +16,7 @@ defmt = { version = "0.3", optional = true } | ||||
| defmt-rtt = { version = "0.4", optional = true } | ||||
| panic-reset = { version = "0.1.1" } | ||||
| embedded-hal = { version = "0.2.6" } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
|  | ||||
| cortex-m = { version = "0.7.6", features = ["inline-asm", "critical-section-single-core"] } | ||||
| cortex-m-rt = "0.7.0" | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| embassy-executor = { version = "0.3.3", path = "../../../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "nightly", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../../../embassy-stm32", features = ["stm32l072cz", "time-driver-any", "exti", "memory-x"]  } | ||||
| embassy-boot-stm32 = { version = "0.1.0", path = "../../../../embassy-boot/stm32", features = [] } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../../../embassy-embedded-hal" } | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| embassy-executor = { version = "0.3.3", path = "../../../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "nightly", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../../../embassy-stm32", features = ["stm32l151cb-a", "time-driver-any", "exti"]  } | ||||
| embassy-boot-stm32 = { version = "0.1.0", path = "../../../../embassy-boot/stm32", features = [] } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../../../embassy-embedded-hal" } | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| embassy-executor = { version = "0.3.3", path = "../../../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "nightly", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../../../embassy-stm32", features = ["stm32l475vg", "time-driver-any", "exti"]  } | ||||
| embassy-boot-stm32 = { version = "0.1.0", path = "../../../../embassy-boot/stm32", features = [] } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../../../embassy-embedded-hal" } | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| embassy-executor = { version = "0.3.3", path = "../../../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "nightly", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../../../embassy-time", features = [ "tick-hz-32_768"] } | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../../../embassy-stm32", features = ["stm32wl55jc-cm4", "time-driver-any", "exti"]  } | ||||
| embassy-boot-stm32 = { version = "0.1.0", path = "../../../../embassy-boot/stm32", features = [] } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../../../embassy-embedded-hal" } | ||||
|   | ||||
| @@ -12,7 +12,7 @@ defmt-rtt = { version = "0.4", optional = true } | ||||
| embassy-nrf = { path = "../../../../embassy-nrf", features = [] } | ||||
| embassy-boot-nrf = { path = "../../../../embassy-boot/nrf" } | ||||
| cortex-m = { version = "0.7.6", features = ["inline-asm", "critical-section-single-core"] } | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| cortex-m-rt = { version = "0.7" } | ||||
| cfg-if = "1.0.0" | ||||
|  | ||||
|   | ||||
| @@ -11,12 +11,12 @@ defmt-rtt = { version = "0.4", optional = true } | ||||
|  | ||||
| embassy-rp = { path = "../../../../embassy-rp", features = [] } | ||||
| embassy-boot-rp = { path = "../../../../embassy-boot/rp" } | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| embassy-time = { path = "../../../../embassy-time", features = [] } | ||||
|  | ||||
| cortex-m = { version = "0.7.6", features = ["inline-asm", "critical-section-single-core"] } | ||||
| cortex-m-rt = { version = "0.7" } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| embedded-storage-async = "0.4.0" | ||||
| cfg-if = "1.0.0" | ||||
|  | ||||
|   | ||||
| @@ -12,9 +12,9 @@ defmt-rtt = { version = "0.4", optional = true } | ||||
| embassy-stm32 = { path = "../../../../embassy-stm32", features = [] } | ||||
| embassy-boot-stm32 = { path = "../../../../embassy-boot/stm32" } | ||||
| cortex-m = { version = "0.7.6", features = ["inline-asm", "critical-section-single-core"] } | ||||
| embassy-sync = { version = "0.4.0", path = "../../../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../../../embassy-sync" } | ||||
| cortex-m-rt = { version = "0.7" } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| embedded-storage-async = "0.4.0" | ||||
| cfg-if = "1.0.0" | ||||
|  | ||||
|   | ||||
| @@ -15,9 +15,9 @@ log = [ | ||||
| ] | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync" } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "rtos-trace", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time" } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time" } | ||||
| embassy-nrf = { version = "0.1.0", path = "../../embassy-nrf", features = ["nrf52840", "time-driver-rtc1", "gpiote", "unstable-pac"] } | ||||
|  | ||||
| cortex-m = { version = "0.7.6", features = ["inline-asm", "critical-section-single-core"] } | ||||
|   | ||||
| @@ -8,8 +8,8 @@ license = "MIT OR Apache-2.0" | ||||
| rtic = { version = "2", features = ["thumbv7-backend"] } | ||||
|  | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = [ "defmt", "defmt-timestamp-uptime", "generic-queue"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = [ "defmt", "defmt-timestamp-uptime", "generic-queue"] } | ||||
| embassy-nrf = { version = "0.1.0", path = "../../embassy-nrf", features = [ "defmt", "nrf52840", "time-driver-rtc1", "gpiote", "unstable-pac", "time"] } | ||||
|  | ||||
| defmt = "0.3" | ||||
|   | ||||
| @@ -12,9 +12,9 @@ nightly = [ | ||||
|  | ||||
| [dependencies] | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "executor-interrupt", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime"] } | ||||
| embassy-nrf = { version = "0.1.0", path = "../../embassy-nrf", features = ["defmt", "nrf52840", "time-driver-rtc1", "gpiote", "unstable-pac", "time"] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4", "medium-ethernet"] } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
| @@ -33,7 +33,7 @@ cortex-m-rt = "0.7.0" | ||||
| panic-probe = { version = "0.3", features = ["print-defmt"] } | ||||
| futures = { version = "0.3.17", default-features = false, features = ["async-await"] } | ||||
| rand = { version = "0.8.4", default-features = false } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| usbd-hid = "0.6.0" | ||||
| serde = { version = "1.0.136", default-features = false } | ||||
| embedded-hal = { version = "1.0.0-rc.2" } | ||||
|   | ||||
| @@ -6,9 +6,9 @@ license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "nightly", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime"] } | ||||
| embassy-nrf = { version = "0.1.0", path = "../../embassy-nrf", features = ["defmt", "nrf5340-app-s", "time-driver-rtc1", "gpiote", "unstable-pac"] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4", "medium-ethernet"] } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
| @@ -23,7 +23,7 @@ cortex-m-rt = "0.7.0" | ||||
| panic-probe = { version = "0.3", features = ["print-defmt"] } | ||||
| futures = { version = "0.3.17", default-features = false, features = ["async-await"] } | ||||
| rand = { version = "0.8.4", default-features = false } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| usbd-hid = "0.6.0" | ||||
| serde = { version = "1.0.136", default-features = false } | ||||
|  | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../embassy-embedded-hal", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "executor-interrupt", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime"] } | ||||
| embassy-rp = { version = "0.1.0", path = "../../embassy-rp", features = ["defmt", "unstable-pac", "time-driver", "critical-section-impl"] } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt", "tcp", "udp", "dhcpv4", "medium-ethernet"] } | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["log"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["log"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["arch-std", "executor-thread", "log", "nightly", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["log", "std", ] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["log", "std", ] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features=[ "std",  "log", "medium-ethernet", "medium-ip", "tcp", "udp", "dns", "dhcpv4", "proto-ipv6"] } | ||||
| embassy-net-tuntap = { version = "0.1.0", path = "../../embassy-net-tuntap" } | ||||
| embassy-net-ppp = { version = "0.1.0", path = "../../embassy-net-ppp", features = ["log"]} | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32c031c6 to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "time-driver-any", "stm32c031c6", "memory-x", "unstable-pac", "exti"]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
|  | ||||
| defmt = "0.3" | ||||
| defmt-rtt = "0.4" | ||||
|   | ||||
| @@ -14,9 +14,9 @@ cortex-m-rt = "0.7.0" | ||||
| defmt = "0.3" | ||||
| defmt-rtt = "0.4" | ||||
| panic-probe = "0.3" | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "executor-interrupt", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| static_cell = { version = "2", features = ["nightly"]} | ||||
| portable-atomic = { version = "1.5", features = ["unsafe-assume-single-core"] } | ||||
|  | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32f103c8 to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "stm32f103c8", "unstable-pac", "memory-x", "time-driver-any" ]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
|  | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32f207zg to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "stm32f207zg", "unstable-pac", "memory-x", "time-driver-any", "exti"]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
|  | ||||
| defmt = "0.3" | ||||
| defmt-rtt = "0.4" | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32f303ze to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "stm32f303ze", "unstable-pac", "memory-x", "time-driver-any", "exti"]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "executor-interrupt", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
|  | ||||
| @@ -23,7 +23,7 @@ panic-probe = { version = "0.3", features = ["print-defmt"] } | ||||
| futures = { version = "0.3.17", default-features = false, features = ["async-await"] } | ||||
| heapless = { version = "0.8", default-features = false } | ||||
| nb = "1.0.0" | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| static_cell = { version = "2", features = ["nightly"]} | ||||
|  | ||||
| [profile.release] | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "executor-interrupt", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.0", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2.0", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "stm32f334r8", "unstable-pac", "memory-x", "time-driver-any", "exti"]  } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
| @@ -22,5 +22,5 @@ panic-probe = { version = "0.3", features = ["print-defmt"] } | ||||
| futures = { version = "0.3.17", default-features = false, features = ["async-await"] } | ||||
| heapless = { version = "0.8", default-features = false } | ||||
| nb = "1.0.0" | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| static_cell = { version = "2", features = ["nightly"]} | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32f429zi to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "stm32f429zi", "unstable-pac", "memory-x", "time-driver-any", "exti", "embedded-sdmmc", "chrono"]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "executor-interrupt", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt" ] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4", "medium-ethernet", ] } | ||||
|  | ||||
| @@ -25,7 +25,7 @@ panic-probe = { version = "0.3", features = ["print-defmt"] } | ||||
| futures = { version = "0.3.17", default-features = false, features = ["async-await"] } | ||||
| heapless = { version = "0.8", default-features = false } | ||||
| nb = "1.0.0" | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| micromath = "2.0.0" | ||||
| static_cell = { version = "2", features = ["nightly"]} | ||||
| chrono = { version = "^0.4", default-features = false} | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32f767zi to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["defmt", "stm32f767zi", "memory-x", "unstable-pac", "time-driver-any", "exti"]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4", "medium-ethernet"] } | ||||
| embedded-io-async = { version = "0.6.1" } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
| @@ -26,7 +26,7 @@ heapless = { version = "0.8", default-features = false } | ||||
| nb = "1.0.0" | ||||
| rand_core = "0.6.3" | ||||
| critical-section = "1.1" | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| static_cell = { version = "2", features = ["nightly"]} | ||||
|  | ||||
| [profile.release] | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32g071rb to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "time-driver-any", "stm32g071rb", "memory-x", "unstable-pac", "exti"]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
|  | ||||
| defmt = "0.3" | ||||
| defmt-rtt = "0.4" | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32g491re to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "time-driver-any", "stm32g491re", "memory-x", "unstable-pac", "exti"]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
| usbd-hid = "0.6.0" | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32h563zi to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "stm32h563zi", "memory-x", "time-driver-any", "exti", "unstable-pac"] } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4", "medium-ethernet", "proto-ipv6"] } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
|  | ||||
| @@ -30,7 +30,7 @@ rand_core = "0.6.3" | ||||
| critical-section = "1.1" | ||||
| micromath = "2.0.0" | ||||
| stm32-fmc = "0.3.0" | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| static_cell = { version = "2", features = ["nightly"]} | ||||
|  | ||||
| # cargo build/run | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32h743bi to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["defmt", "stm32h743bi", "time-driver-any", "exti", "memory-x", "unstable-pac", "chrono"] } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4", "medium-ethernet", "proto-ipv6", "dns"] } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
|  | ||||
| @@ -30,7 +30,7 @@ rand_core = "0.6.3" | ||||
| critical-section = "1.1" | ||||
| micromath = "2.0.0" | ||||
| stm32-fmc = "0.3.0" | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| static_cell = { version = "2", features = ["nightly"]} | ||||
| chrono = { version = "^0.4", default-features = false } | ||||
|  | ||||
|   | ||||
| @@ -11,14 +11,14 @@ nightly = ["embassy-executor/nightly"] | ||||
| [dependencies] | ||||
| # Change stm32l072cz to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["defmt", "stm32l072cz", "time-driver-any", "exti", "memory-x"]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
|  | ||||
| defmt = "0.3" | ||||
| defmt-rtt = "0.4" | ||||
|  | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| embedded-io = { version = "0.6.0" } | ||||
| embedded-io-async = { version = "0.6.1" } | ||||
|  | ||||
|   | ||||
| @@ -5,9 +5,9 @@ version = "0.1.0" | ||||
| license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "stm32l151cb-a", "time-driver-any", "memory-x"]  } | ||||
|  | ||||
| defmt = "0.3" | ||||
| @@ -19,7 +19,7 @@ embedded-hal = "0.2.6" | ||||
| panic-probe = { version = "0.3", features = ["print-defmt"] } | ||||
| futures = { version = "0.3.17", default-features = false, features = ["async-await"] } | ||||
| heapless = { version = "0.8", default-features = false } | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
|  | ||||
| [profile.release] | ||||
| debug = 2 | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32l4s5vi to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "unstable-pac", "stm32l4s5qi", "memory-x", "time-driver-any", "exti", "chrono"]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768", ] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768", ] } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../embassy-embedded-hal" } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
| embassy-net-adin1110 = { version = "0.2.0", path = "../../embassy-net-adin1110" } | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32l552ze to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "unstable-pac", "stm32l552ze", "time-driver-any", "exti", "memory-x"]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt",  "tcp", "dhcpv4", "medium-ethernet"] } | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32u585ai to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "unstable-pac", "stm32u585ai", "time-driver-any", "memory-x" ]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||
|  | ||||
| defmt = "0.3" | ||||
|   | ||||
| @@ -8,9 +8,9 @@ license = "MIT OR Apache-2.0" | ||||
| # Change stm32wb55rg to your chip name in both dependencies, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "stm32wb55rg", "time-driver-any", "memory-x", "exti"]  } | ||||
| embassy-stm32-wpan = { version = "0.1.0", path = "../../embassy-stm32-wpan", features = ["defmt", "stm32wb55rg"] } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt", "udp", "proto-ipv6", "medium-ieee802154", ], optional=true } | ||||
|  | ||||
| defmt = "0.3" | ||||
|   | ||||
| @@ -6,9 +6,9 @@ license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "stm32wba52cg", "time-driver-any", "memory-x", "exti"]  } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt", "udp", "proto-ipv6", "medium-ieee802154", ], optional=true } | ||||
|  | ||||
| defmt = "0.3" | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| # Change stm32wl55jc-cm4 to your chip name, if necessary. | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["defmt", "stm32wl55jc-cm4", "time-driver-any", "memory-x", "unstable-pac", "exti", "chrono"] } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["nightly", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-hz-32_768"] } | ||||
| embassy-embedded-hal = { version = "0.1.0", path = "../../embassy-embedded-hal" } | ||||
|  | ||||
| defmt = "0.3" | ||||
| @@ -18,7 +18,7 @@ defmt-rtt = "0.4" | ||||
| cortex-m = { version = "0.7.6", features = ["inline-asm", "critical-section-single-core"] } | ||||
| cortex-m-rt = "0.7.0" | ||||
| embedded-hal = "0.2.6" | ||||
| embedded-storage = "0.3.0" | ||||
| embedded-storage = "0.3.1" | ||||
| panic-probe = { version = "0.3", features = ["print-defmt"] } | ||||
| futures = { version = "0.3.17", default-features = false, features = ["async-await"] } | ||||
| heapless = { version = "0.8", default-features = false } | ||||
|   | ||||
| @@ -8,9 +8,9 @@ license = "MIT OR Apache-2.0" | ||||
| crate-type = ["cdylib"] | ||||
|  | ||||
| [dependencies] | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["log"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["log"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["arch-wasm", "executor-thread", "log", "nightly", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["log", "wasm", ] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["log", "wasm", ] } | ||||
|  | ||||
| wasm-logger = "0.2.0" | ||||
| wasm-bindgen = "0.2" | ||||
|   | ||||
| @@ -8,9 +8,9 @@ license = "MIT OR Apache-2.0" | ||||
| teleprobe-meta = "1" | ||||
|  | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt", ] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt", ] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "defmt", "task-arena-size-16384", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt",  "defmt-timestamp-uptime"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt",  "defmt-timestamp-uptime"] } | ||||
| embassy-nrf = { version = "0.1.0", path = "../../embassy-nrf", features = ["defmt",  "nrf52840", "time-driver-rtc1", "gpiote", "unstable-pac"] } | ||||
| embedded-io-async = { version = "0.6.1", features = ["defmt-03"] } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4", "medium-ethernet", ] } | ||||
|   | ||||
| @@ -7,6 +7,6 @@ edition = "2021" | ||||
|  | ||||
| [dependencies] | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", ] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", ] } | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
| defmt = "0.3.0" | ||||
|   | ||||
| @@ -6,9 +6,9 @@ license = "MIT OR Apache-2.0" | ||||
|  | ||||
| [dependencies] | ||||
| critical-section = { version = "1.1.1", features = ["restore-state-bool"] } | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync" } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync" } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["arch-riscv32", "executor-thread"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time" } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time" } | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
|  | ||||
| riscv-rt = "0.11" | ||||
|   | ||||
| @@ -7,9 +7,9 @@ license = "MIT OR Apache-2.0" | ||||
| [dependencies] | ||||
| teleprobe-meta = "1.1" | ||||
|  | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["task-arena-size-32768", "arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", ] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", ] } | ||||
| embassy-rp = { version = "0.1.0", path = "../../embassy-rp", features = [ "defmt", "unstable-pac", "time-driver", "critical-section-impl", "intrinsics", "rom-v2-intrinsics", "run-from-ram"]  } | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
| embassy-net = { version = "0.2.0", path = "../../embassy-net", features = ["defmt",  "tcp", "udp", "dhcpv4", "medium-ethernet"] } | ||||
|   | ||||
| @@ -48,9 +48,9 @@ cm0 = ["portable-atomic/unsafe-assume-single-core"] | ||||
| [dependencies] | ||||
| teleprobe-meta = "1" | ||||
|  | ||||
| embassy-sync = { version = "0.4.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-sync = { version = "0.5.0", path = "../../embassy-sync", features = ["defmt"] } | ||||
| embassy-executor = { version = "0.3.3", path = "../../embassy-executor", features = ["arch-cortex-m", "executor-thread", "defmt", "integrated-timers"] } | ||||
| embassy-time = { version = "0.1.5", path = "../../embassy-time", features = ["defmt", "tick-hz-131_072", "defmt-timestamp-uptime"] } | ||||
| embassy-time = { version = "0.2", path = "../../embassy-time", features = ["defmt", "tick-hz-131_072", "defmt-timestamp-uptime"] } | ||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = [ "defmt", "unstable-pac", "memory-x", "time-driver-any"]  } | ||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||
| embassy-stm32-wpan = { version = "0.1.0", path = "../../embassy-stm32-wpan", optional = true, features = ["defmt", "stm32wb55rg", "ble"] } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user