net: feature-gate nightly-only async traits to allow building on stable.
This commit is contained in:
		
							parent
							
								
									92ed95780d
								
							
						
					
					
						commit
						464ae67108
					
				
							
								
								
									
										5
									
								
								ci.sh
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								ci.sh
									
									
									
									
									
								
							| @ -36,6 +36,10 @@ cargo batch  \ | |||||||
|     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv7em-none-eabi --features nightly,log \ |     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv7em-none-eabi --features nightly,log \ | ||||||
|     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv7em-none-eabi --features nightly,defmt \ |     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv7em-none-eabi --features nightly,defmt \ | ||||||
|     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv6m-none-eabi --features nightly,defmt \ |     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv6m-none-eabi --features nightly,defmt \ | ||||||
|  |     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,dhcpv4,medium-ethernet,pool-16,embassy-time/tick-1mhz \ | ||||||
|  |     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,dhcpv4,medium-ethernet,pool-16,embassy-time/tick-1mhz,unstable-traits \ | ||||||
|  |     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,dhcpv4,medium-ethernet,pool-16,embassy-time/tick-1mhz,nightly \ | ||||||
|  |     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,dhcpv4,medium-ethernet,pool-16,embassy-time/tick-1mhz,unstable-traits,nightly \ | ||||||
|     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nightly,nrf52805,gpiote,time-driver-rtc1 \ |     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nightly,nrf52805,gpiote,time-driver-rtc1 \ | ||||||
|     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nightly,nrf52810,gpiote,time-driver-rtc1 \ |     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nightly,nrf52810,gpiote,time-driver-rtc1 \ | ||||||
|     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nightly,nrf52811,gpiote,time-driver-rtc1 \ |     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nightly,nrf52811,gpiote,time-driver-rtc1 \ | ||||||
| @ -94,6 +98,7 @@ cargo batch  \ | |||||||
|     --- build --release --manifest-path examples/stm32l0/Cargo.toml --target thumbv6m-none-eabi --out-dir out/examples/stm32l0 \ |     --- build --release --manifest-path examples/stm32l0/Cargo.toml --target thumbv6m-none-eabi --out-dir out/examples/stm32l0 \ | ||||||
|     --- build --release --manifest-path examples/stm32l1/Cargo.toml --target thumbv7m-none-eabi --out-dir out/examples/stm32l1 \ |     --- build --release --manifest-path examples/stm32l1/Cargo.toml --target thumbv7m-none-eabi --out-dir out/examples/stm32l1 \ | ||||||
|     --- build --release --manifest-path examples/stm32l4/Cargo.toml --target thumbv7em-none-eabi --out-dir out/examples/stm32l4 \ |     --- build --release --manifest-path examples/stm32l4/Cargo.toml --target thumbv7em-none-eabi --out-dir out/examples/stm32l4 \ | ||||||
|  |     --- build --release --manifest-path examples/stm32l5/Cargo.toml --target thumbv8m.main-none-eabihf --out-dir out/examples/stm32l5 \ | ||||||
|     --- build --release --manifest-path examples/stm32u5/Cargo.toml --target thumbv8m.main-none-eabihf --out-dir out/examples/stm32u5 \ |     --- build --release --manifest-path examples/stm32u5/Cargo.toml --target thumbv8m.main-none-eabihf --out-dir out/examples/stm32u5 \ | ||||||
|     --- build --release --manifest-path examples/stm32wb/Cargo.toml --target thumbv7em-none-eabihf --out-dir out/examples/stm32wb \ |     --- build --release --manifest-path examples/stm32wb/Cargo.toml --target thumbv7em-none-eabihf --out-dir out/examples/stm32wb \ | ||||||
|     --- build --release --manifest-path examples/stm32wl/Cargo.toml --target thumbv7em-none-eabihf --out-dir out/examples/stm32wl \ |     --- build --release --manifest-path examples/stm32wl/Cargo.toml --target thumbv7em-none-eabihf --out-dir out/examples/stm32wl \ | ||||||
|  | |||||||
| @ -13,6 +13,8 @@ cargo batch  \ | |||||||
|     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv7em-none-eabi --features log \ |     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv7em-none-eabi --features log \ | ||||||
|     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv7em-none-eabi --features defmt \ |     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv7em-none-eabi --features defmt \ | ||||||
|     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv6m-none-eabi --features defmt \ |     --- build --release --manifest-path embassy-executor/Cargo.toml --target thumbv6m-none-eabi --features defmt \ | ||||||
|  |     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,dhcpv4,medium-ethernet,pool-16,embassy-time/tick-1mhz \ | ||||||
|  |     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,dhcpv4,medium-ethernet,pool-16,embassy-time/tick-1mhz,unstable-traits \ | ||||||
|     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nrf52805,gpiote,time-driver-rtc1 \ |     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nrf52805,gpiote,time-driver-rtc1 \ | ||||||
|     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nrf52810,gpiote,time-driver-rtc1 \ |     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nrf52810,gpiote,time-driver-rtc1 \ | ||||||
|     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nrf52811,gpiote,time-driver-rtc1 \ |     --- build --release --manifest-path embassy-nrf/Cargo.toml --target thumbv7em-none-eabi --features nrf52811,gpiote,time-driver-rtc1 \ | ||||||
|  | |||||||
| @ -16,6 +16,9 @@ std = [] | |||||||
| 
 | 
 | ||||||
| defmt = ["dep:defmt", "smoltcp/defmt"] | defmt = ["dep:defmt", "smoltcp/defmt"] | ||||||
| 
 | 
 | ||||||
|  | nightly = ["dep:embedded-io", "embedded-io?/async", "dep:embedded-nal-async"] | ||||||
|  | unstable-traits = [] | ||||||
|  | 
 | ||||||
| udp = ["smoltcp/socket-udp"] | udp = ["smoltcp/socket-udp"] | ||||||
| tcp = ["smoltcp/socket-tcp"] | tcp = ["smoltcp/socket-tcp"] | ||||||
| dns = ["smoltcp/socket-dns"] | dns = ["smoltcp/socket-dns"] | ||||||
| @ -30,7 +33,6 @@ pool-16 = [] | |||||||
| pool-32 = [] | pool-32 = [] | ||||||
| pool-64 = [] | pool-64 = [] | ||||||
| pool-128 = [] | pool-128 = [] | ||||||
| unstable-traits = [] |  | ||||||
| 
 | 
 | ||||||
| [dependencies] | [dependencies] | ||||||
| 
 | 
 | ||||||
| @ -39,7 +41,7 @@ log = { version = "0.4.14", optional = true } | |||||||
| 
 | 
 | ||||||
| embassy-time = { version = "0.1.0", path = "../embassy-time" } | embassy-time = { version = "0.1.0", path = "../embassy-time" } | ||||||
| embassy-sync = { version = "0.1.0", path = "../embassy-sync" } | embassy-sync = { version = "0.1.0", path = "../embassy-sync" } | ||||||
| embedded-io = { version = "0.3.0", features = [ "async" ] } | embedded-io = { version = "0.3.0", optional = true } | ||||||
| 
 | 
 | ||||||
| managed = { version = "0.8.0", default-features = false, features = [ "map" ] } | managed = { version = "0.8.0", default-features = false, features = [ "map" ] } | ||||||
| heapless = { version = "0.7.5", default-features = false } | heapless = { version = "0.7.5", default-features = false } | ||||||
| @ -49,7 +51,7 @@ stable_deref_trait = { version = "1.2.0", default-features = false } | |||||||
| futures = { version = "0.3.17", default-features = false, features = [ "async-await" ] } | futures = { version = "0.3.17", default-features = false, features = [ "async-await" ] } | ||||||
| atomic-pool = "1.0" | atomic-pool = "1.0" | ||||||
| atomic-polyfill = "1.0.1" | atomic-polyfill = "1.0.1" | ||||||
| embedded-nal-async = "0.2.0" | embedded-nal-async = { version = "0.2.0", optional = true } | ||||||
| 
 | 
 | ||||||
| [dependencies.smoltcp] | [dependencies.smoltcp] | ||||||
| version = "0.8.0" | version = "0.8.0" | ||||||
|  | |||||||
| @ -1,6 +1,5 @@ | |||||||
| #![cfg_attr(not(feature = "std"), no_std)] | #![cfg_attr(not(feature = "std"), no_std)] | ||||||
| #![allow(clippy::new_without_default)] | #![cfg_attr(feature = "nightly", feature(generic_associated_types, type_alias_impl_trait))] | ||||||
| #![feature(generic_associated_types, type_alias_impl_trait)] |  | ||||||
| 
 | 
 | ||||||
| // This mod MUST go first, so that the others see its macros.
 | // This mod MUST go first, so that the others see its macros.
 | ||||||
| pub(crate) mod fmt; | pub(crate) mod fmt; | ||||||
|  | |||||||
| @ -1,5 +1,4 @@ | |||||||
| use core::cell::UnsafeCell; | use core::cell::UnsafeCell; | ||||||
| use core::future::Future; |  | ||||||
| use core::mem; | use core::mem; | ||||||
| use core::task::Poll; | use core::task::Poll; | ||||||
| 
 | 
 | ||||||
| @ -55,6 +54,18 @@ pub struct TcpWriter<'a> { | |||||||
|     io: TcpIo<'a>, |     io: TcpIo<'a>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | impl<'a> TcpReader<'a> { | ||||||
|  |     pub async fn read(&mut self, buf: &mut [u8]) -> Result<usize, Error> { | ||||||
|  |         self.io.read(buf).await | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | impl<'a> TcpWriter<'a> { | ||||||
|  |     pub async fn write(&mut self, buf: &[u8]) -> Result<usize, Error> { | ||||||
|  |         self.io.write(buf).await | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| impl<'a> TcpSocket<'a> { | impl<'a> TcpSocket<'a> { | ||||||
|     pub fn new<D: Device>(stack: &'a Stack<D>, rx_buffer: &'a mut [u8], tx_buffer: &'a mut [u8]) -> Self { |     pub fn new<D: Device>(stack: &'a Stack<D>, rx_buffer: &'a mut [u8], tx_buffer: &'a mut [u8]) -> Self { | ||||||
|         // safety: not accessed reentrantly.
 |         // safety: not accessed reentrantly.
 | ||||||
| @ -129,6 +140,14 @@ impl<'a> TcpSocket<'a> { | |||||||
|         .await |         .await | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     pub async fn read(&mut self, buf: &mut [u8]) -> Result<usize, Error> { | ||||||
|  |         self.io.read(buf).await | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     pub async fn write(&mut self, buf: &[u8]) -> Result<usize, Error> { | ||||||
|  |         self.io.write(buf).await | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     pub fn set_timeout(&mut self, duration: Option<Duration>) { |     pub fn set_timeout(&mut self, duration: Option<Duration>) { | ||||||
|         unsafe { self.io.with_mut(|s, _| s.set_timeout(duration)) } |         unsafe { self.io.with_mut(|s, _| s.set_timeout(duration)) } | ||||||
|     } |     } | ||||||
| @ -241,6 +260,7 @@ impl<'d> TcpIo<'d> { | |||||||
|         .await |         .await | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     #[allow(unused)] | ||||||
|     async fn flush(&mut self) -> Result<(), Error> { |     async fn flush(&mut self) -> Result<(), Error> { | ||||||
|         poll_fn(move |_| { |         poll_fn(move |_| { | ||||||
|             Poll::Ready(Ok(())) // TODO: Is there a better implementation for this?
 |             Poll::Ready(Ok(())) // TODO: Is there a better implementation for this?
 | ||||||
| @ -249,88 +269,96 @@ impl<'d> TcpIo<'d> { | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl embedded_io::Error for ConnectError { | #[cfg(feature = "nightly")] | ||||||
|     fn kind(&self) -> embedded_io::ErrorKind { | mod embedded_io_impls { | ||||||
|         embedded_io::ErrorKind::Other |     use core::future::Future; | ||||||
|  | 
 | ||||||
|  |     use super::*; | ||||||
|  | 
 | ||||||
|  |     impl embedded_io::Error for ConnectError { | ||||||
|  |         fn kind(&self) -> embedded_io::ErrorKind { | ||||||
|  |             embedded_io::ErrorKind::Other | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| impl embedded_io::Error for Error { |     impl embedded_io::Error for Error { | ||||||
|     fn kind(&self) -> embedded_io::ErrorKind { |         fn kind(&self) -> embedded_io::ErrorKind { | ||||||
|         embedded_io::ErrorKind::Other |             embedded_io::ErrorKind::Other | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| impl<'d> embedded_io::Io for TcpSocket<'d> { |     impl<'d> embedded_io::Io for TcpSocket<'d> { | ||||||
|     type Error = Error; |         type Error = Error; | ||||||
| } |     } | ||||||
| 
 | 
 | ||||||
| impl<'d> embedded_io::asynch::Read for TcpSocket<'d> { |     impl<'d> embedded_io::asynch::Read for TcpSocket<'d> { | ||||||
|     type ReadFuture<'a> = impl Future<Output = Result<usize, Self::Error>> |         type ReadFuture<'a> = impl Future<Output = Result<usize, Self::Error>> | ||||||
|     where |     where | ||||||
|         Self: 'a; |         Self: 'a; | ||||||
| 
 | 
 | ||||||
|     fn read<'a>(&'a mut self, buf: &'a mut [u8]) -> Self::ReadFuture<'a> { |         fn read<'a>(&'a mut self, buf: &'a mut [u8]) -> Self::ReadFuture<'a> { | ||||||
|         self.io.read(buf) |             self.io.read(buf) | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| impl<'d> embedded_io::asynch::Write for TcpSocket<'d> { |     impl<'d> embedded_io::asynch::Write for TcpSocket<'d> { | ||||||
|     type WriteFuture<'a> = impl Future<Output = Result<usize, Self::Error>> |         type WriteFuture<'a> = impl Future<Output = Result<usize, Self::Error>> | ||||||
|     where |     where | ||||||
|         Self: 'a; |         Self: 'a; | ||||||
| 
 | 
 | ||||||
|     fn write<'a>(&'a mut self, buf: &'a [u8]) -> Self::WriteFuture<'a> { |         fn write<'a>(&'a mut self, buf: &'a [u8]) -> Self::WriteFuture<'a> { | ||||||
|         self.io.write(buf) |             self.io.write(buf) | ||||||
|     } |         } | ||||||
| 
 | 
 | ||||||
|     type FlushFuture<'a> = impl Future<Output = Result<(), Self::Error>> |         type FlushFuture<'a> = impl Future<Output = Result<(), Self::Error>> | ||||||
|     where |     where | ||||||
|         Self: 'a; |         Self: 'a; | ||||||
| 
 | 
 | ||||||
|     fn flush<'a>(&'a mut self) -> Self::FlushFuture<'a> { |         fn flush<'a>(&'a mut self) -> Self::FlushFuture<'a> { | ||||||
|         self.io.flush() |             self.io.flush() | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| impl<'d> embedded_io::Io for TcpReader<'d> { |     impl<'d> embedded_io::Io for TcpReader<'d> { | ||||||
|     type Error = Error; |         type Error = Error; | ||||||
| } |     } | ||||||
| 
 | 
 | ||||||
| impl<'d> embedded_io::asynch::Read for TcpReader<'d> { |     impl<'d> embedded_io::asynch::Read for TcpReader<'d> { | ||||||
|     type ReadFuture<'a> = impl Future<Output = Result<usize, Self::Error>> |         type ReadFuture<'a> = impl Future<Output = Result<usize, Self::Error>> | ||||||
|     where |     where | ||||||
|         Self: 'a; |         Self: 'a; | ||||||
| 
 | 
 | ||||||
|     fn read<'a>(&'a mut self, buf: &'a mut [u8]) -> Self::ReadFuture<'a> { |         fn read<'a>(&'a mut self, buf: &'a mut [u8]) -> Self::ReadFuture<'a> { | ||||||
|         self.io.read(buf) |             self.io.read(buf) | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| impl<'d> embedded_io::Io for TcpWriter<'d> { |     impl<'d> embedded_io::Io for TcpWriter<'d> { | ||||||
|     type Error = Error; |         type Error = Error; | ||||||
| } |     } | ||||||
| 
 | 
 | ||||||
| impl<'d> embedded_io::asynch::Write for TcpWriter<'d> { |     impl<'d> embedded_io::asynch::Write for TcpWriter<'d> { | ||||||
|     type WriteFuture<'a> = impl Future<Output = Result<usize, Self::Error>> |         type WriteFuture<'a> = impl Future<Output = Result<usize, Self::Error>> | ||||||
|     where |     where | ||||||
|         Self: 'a; |         Self: 'a; | ||||||
| 
 | 
 | ||||||
|     fn write<'a>(&'a mut self, buf: &'a [u8]) -> Self::WriteFuture<'a> { |         fn write<'a>(&'a mut self, buf: &'a [u8]) -> Self::WriteFuture<'a> { | ||||||
|         self.io.write(buf) |             self.io.write(buf) | ||||||
|     } |         } | ||||||
| 
 | 
 | ||||||
|     type FlushFuture<'a> = impl Future<Output = Result<(), Self::Error>> |         type FlushFuture<'a> = impl Future<Output = Result<(), Self::Error>> | ||||||
|     where |     where | ||||||
|         Self: 'a; |         Self: 'a; | ||||||
| 
 | 
 | ||||||
|     fn flush<'a>(&'a mut self) -> Self::FlushFuture<'a> { |         fn flush<'a>(&'a mut self) -> Self::FlushFuture<'a> { | ||||||
|         self.io.flush() |             self.io.flush() | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #[cfg(feature = "unstable-traits")] | #[cfg(all(feature = "unstable-traits", feature = "nightly"))] | ||||||
| pub mod client { | pub mod client { | ||||||
|  |     use core::future::Future; | ||||||
|     use core::mem::MaybeUninit; |     use core::mem::MaybeUninit; | ||||||
|     use core::ptr::NonNull; |     use core::ptr::NonNull; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -5,7 +5,7 @@ version = "0.1.0" | |||||||
| 
 | 
 | ||||||
| [features] | [features] | ||||||
| default = ["nightly"] | default = ["nightly"] | ||||||
| nightly = ["embassy-executor/nightly", "embassy-nrf/nightly", "embassy-nrf/unstable-traits", "embassy-usb", "embassy-usb-serial", "embassy-usb-hid", "embassy-usb-ncm", "embedded-io/async", "embassy-net"] | nightly = ["embassy-executor/nightly", "embassy-nrf/nightly", "embassy-net/nightly", "embassy-nrf/unstable-traits", "embassy-usb", "embassy-usb-serial", "embassy-usb-hid", "embassy-usb-ncm", "embedded-io/async", "embassy-net"] | ||||||
| 
 | 
 | ||||||
| [dependencies] | [dependencies] | ||||||
| embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | ||||||
|  | |||||||
| @ -18,7 +18,7 @@ use embassy_sync::blocking_mutex::raw::ThreadModeRawMutex; | |||||||
| use embassy_sync::channel::Channel; | use embassy_sync::channel::Channel; | ||||||
| use embassy_usb::{Builder, Config, UsbDevice}; | use embassy_usb::{Builder, Config, UsbDevice}; | ||||||
| use embassy_usb_ncm::{CdcNcmClass, Receiver, Sender, State}; | use embassy_usb_ncm::{CdcNcmClass, Receiver, Sender, State}; | ||||||
| use embedded_io::asynch::{Read, Write}; | use embedded_io::asynch::Write; | ||||||
| use static_cell::StaticCell; | use static_cell::StaticCell; | ||||||
| use {defmt_rtt as _, panic_probe as _}; | use {defmt_rtt as _, panic_probe as _}; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -11,7 +11,7 @@ embassy-time = { version = "0.1.0", path = "../../embassy-time", features = ["de | |||||||
| embassy-rp = { version = "0.1.0", path = "../../embassy-rp", features = ["defmt", "unstable-traits", "nightly", "unstable-pac"] } | embassy-rp = { version = "0.1.0", path = "../../embassy-rp", features = ["defmt", "unstable-traits", "nightly", "unstable-pac"] } | ||||||
| embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defmt"] } | ||||||
| embassy-usb-serial = { version = "0.1.0", path = "../../embassy-usb-serial", features = ["defmt"] } | embassy-usb-serial = { version = "0.1.0", path = "../../embassy-usb-serial", features = ["defmt"] } | ||||||
| embassy-net = { version = "0.1.0", path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4", "medium-ethernet", "pool-16"] } | embassy-net = { version = "0.1.0", path = "../../embassy-net", features = ["defmt", "nightly", "tcp", "dhcpv4", "medium-ethernet", "pool-16"] } | ||||||
| embassy-usb-ncm = { version = "0.1.0", path = "../../embassy-usb-ncm", features = ["defmt"] } | embassy-usb-ncm = { version = "0.1.0", path = "../../embassy-usb-ncm", features = ["defmt"] } | ||||||
| 
 | 
 | ||||||
| defmt = "0.3" | defmt = "0.3" | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ use embassy_sync::blocking_mutex::raw::ThreadModeRawMutex; | |||||||
| use embassy_sync::channel::Channel; | use embassy_sync::channel::Channel; | ||||||
| use embassy_usb::{Builder, Config, UsbDevice}; | use embassy_usb::{Builder, Config, UsbDevice}; | ||||||
| use embassy_usb_ncm::{CdcNcmClass, Receiver, Sender, State}; | use embassy_usb_ncm::{CdcNcmClass, Receiver, Sender, State}; | ||||||
| use embedded_io::asynch::{Read, Write}; | use embedded_io::asynch::Write; | ||||||
| use static_cell::StaticCell; | use static_cell::StaticCell; | ||||||
| use {defmt_rtt as _, panic_probe as _}; | use {defmt_rtt as _, panic_probe as _}; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -7,7 +7,7 @@ version = "0.1.0" | |||||||
| embassy-sync = { version = "0.1.0", path = "../../embassy-sync", features = ["log"] } | embassy-sync = { version = "0.1.0", path = "../../embassy-sync", features = ["log"] } | ||||||
| embassy-executor = { version = "0.1.0", path = "../../embassy-executor", features = ["log", "std", "nightly", "integrated-timers"] } | embassy-executor = { version = "0.1.0", path = "../../embassy-executor", features = ["log", "std", "nightly", "integrated-timers"] } | ||||||
| embassy-time = { version = "0.1.0", path = "../../embassy-time", features = ["log", "std", "nightly"] } | embassy-time = { version = "0.1.0", path = "../../embassy-time", features = ["log", "std", "nightly"] } | ||||||
| embassy-net = { version = "0.1.0", path = "../../embassy-net", features=[ "std", "log", "medium-ethernet", "tcp", "udp", "dhcpv4", "pool-16"] } | embassy-net = { version = "0.1.0", path = "../../embassy-net", features=[ "std", "nightly", "log", "medium-ethernet", "tcp", "udp", "dhcpv4", "pool-16"] } | ||||||
| embedded-io = { version = "0.3.0", features = ["async", "std", "futures"] } | embedded-io = { version = "0.3.0", features = ["async", "std", "futures"] } | ||||||
| critical-section = { version = "1.1", features = ["std"] } | critical-section = { version = "1.1", features = ["std"] } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -8,7 +8,7 @@ embassy-sync = { version = "0.1.0", path = "../../embassy-sync", features = ["de | |||||||
| embassy-executor = { version = "0.1.0", path = "../../embassy-executor", features = ["defmt", "integrated-timers"] } | embassy-executor = { version = "0.1.0", path = "../../embassy-executor", features = ["defmt", "integrated-timers"] } | ||||||
| embassy-time = { version = "0.1.0", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-32768hz"] } | embassy-time = { version = "0.1.0", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "tick-32768hz"] } | ||||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["nightly", "defmt", "net", "stm32f767zi", "unstable-pac", "time-driver-any", "exti"]  } | embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["nightly", "defmt", "net", "stm32f767zi", "unstable-pac", "time-driver-any", "exti"]  } | ||||||
| embassy-net = { path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4", "medium-ethernet", "pool-16"] } | embassy-net = { path = "../../embassy-net", features = ["defmt", "nightly", "tcp", "dhcpv4", "medium-ethernet", "pool-16"] } | ||||||
| embedded-io = { version = "0.3.0", features = ["async"] } | embedded-io = { version = "0.3.0", features = ["async"] } | ||||||
| 
 | 
 | ||||||
| defmt = "0.3" | defmt = "0.3" | ||||||
|  | |||||||
| @ -8,7 +8,7 @@ embassy-sync = { version = "0.1.0", path = "../../embassy-sync", features = ["de | |||||||
| embassy-executor = { version = "0.1.0", path = "../../embassy-executor", features = ["defmt", "integrated-timers"] } | embassy-executor = { version = "0.1.0", path = "../../embassy-executor", features = ["defmt", "integrated-timers"] } | ||||||
| embassy-time = { version = "0.1.0", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "unstable-traits", "tick-32768hz"] } | embassy-time = { version = "0.1.0", path = "../../embassy-time", features = ["defmt", "defmt-timestamp-uptime", "unstable-traits", "tick-32768hz"] } | ||||||
| embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["nightly", "defmt", "stm32h743bi", "net", "time-driver-any", "exti", "unstable-pac", "unstable-traits"] } | embassy-stm32 = { version = "0.1.0", path = "../../embassy-stm32", features = ["nightly", "defmt", "stm32h743bi", "net", "time-driver-any", "exti", "unstable-pac", "unstable-traits"] } | ||||||
| embassy-net = { path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4", "medium-ethernet", "pool-16", "unstable-traits"] } | embassy-net = { path = "../../embassy-net", features = ["defmt", "nightly", "tcp", "dhcpv4", "medium-ethernet", "pool-16", "unstable-traits"] } | ||||||
| embedded-io = { version = "0.3.0", features = ["async"] } | embedded-io = { version = "0.3.0", features = ["async"] } | ||||||
| 
 | 
 | ||||||
| defmt = "0.3" | defmt = "0.3" | ||||||
|  | |||||||
| @ -14,7 +14,7 @@ embassy-usb = { version = "0.1.0", path = "../../embassy-usb", features = ["defm | |||||||
| embassy-usb-serial = { version = "0.1.0", path = "../../embassy-usb-serial", features = ["defmt"] } | embassy-usb-serial = { version = "0.1.0", path = "../../embassy-usb-serial", features = ["defmt"] } | ||||||
| embassy-usb-hid = { version = "0.1.0", path = "../../embassy-usb-hid", features = ["defmt"] } | embassy-usb-hid = { version = "0.1.0", path = "../../embassy-usb-hid", features = ["defmt"] } | ||||||
| embassy-usb-ncm = { version = "0.1.0", path = "../../embassy-usb-ncm", features = ["defmt"] } | embassy-usb-ncm = { version = "0.1.0", path = "../../embassy-usb-ncm", features = ["defmt"] } | ||||||
| embassy-net = { version = "0.1.0", path = "../../embassy-net", features = ["defmt", "tcp", "dhcpv4", "medium-ethernet", "pool-16"] } | embassy-net = { version = "0.1.0", path = "../../embassy-net", features = ["defmt", "nightly", "tcp", "dhcpv4", "medium-ethernet", "pool-16"] } | ||||||
| usbd-hid = "0.5.2" | usbd-hid = "0.5.2" | ||||||
| 
 | 
 | ||||||
| defmt = "0.3" | defmt = "0.3" | ||||||
|  | |||||||
| @ -12,14 +12,13 @@ use embassy_net::tcp::TcpSocket; | |||||||
| use embassy_net::{PacketBox, PacketBoxExt, PacketBuf, Stack, StackResources}; | use embassy_net::{PacketBox, PacketBoxExt, PacketBuf, Stack, StackResources}; | ||||||
| use embassy_stm32::rcc::*; | use embassy_stm32::rcc::*; | ||||||
| use embassy_stm32::rng::Rng; | use embassy_stm32::rng::Rng; | ||||||
| use embassy_stm32::time::Hertz; |  | ||||||
| use embassy_stm32::usb::Driver; | use embassy_stm32::usb::Driver; | ||||||
| use embassy_stm32::{interrupt, Config}; | use embassy_stm32::{interrupt, Config}; | ||||||
| use embassy_sync::blocking_mutex::raw::ThreadModeRawMutex; | use embassy_sync::blocking_mutex::raw::ThreadModeRawMutex; | ||||||
| use embassy_sync::channel::Channel; | use embassy_sync::channel::Channel; | ||||||
| use embassy_usb::{Builder, UsbDevice}; | use embassy_usb::{Builder, UsbDevice}; | ||||||
| use embassy_usb_ncm::{CdcNcmClass, Receiver, Sender, State}; | use embassy_usb_ncm::{CdcNcmClass, Receiver, Sender, State}; | ||||||
| use embedded_io::asynch::{Read, Write}; | use embedded_io::asynch::Write; | ||||||
| use rand_core::RngCore; | use rand_core::RngCore; | ||||||
| use static_cell::StaticCell; | use static_cell::StaticCell; | ||||||
| use {defmt_rtt as _, panic_probe as _}; | use {defmt_rtt as _, panic_probe as _}; | ||||||
|  | |||||||
| @ -6,9 +6,8 @@ | |||||||
| use defmt::*; | use defmt::*; | ||||||
| use embassy_executor::Spawner; | use embassy_executor::Spawner; | ||||||
| use embassy_stm32::rcc::*; | use embassy_stm32::rcc::*; | ||||||
| use embassy_stm32::time::Hertz; |  | ||||||
| use embassy_stm32::usb::Driver; | use embassy_stm32::usb::Driver; | ||||||
| use embassy_stm32::{interrupt, Config, Peripherals}; | use embassy_stm32::{interrupt, Config}; | ||||||
| use embassy_time::{Duration, Timer}; | use embassy_time::{Duration, Timer}; | ||||||
| use embassy_usb::control::OutResponse; | use embassy_usb::control::OutResponse; | ||||||
| use embassy_usb::Builder; | use embassy_usb::Builder; | ||||||
| @ -111,11 +110,11 @@ impl RequestHandler for MyRequestHandler { | |||||||
|         OutResponse::Accepted |         OutResponse::Accepted | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     fn set_idle(&self, id: Option<ReportId>, dur: Duration) { |     fn set_idle_ms(&self, id: Option<ReportId>, dur: u32) { | ||||||
|         info!("Set idle rate for {:?} to {:?}", id, dur); |         info!("Set idle rate for {:?} to {:?}", id, dur); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     fn get_idle(&self, id: Option<ReportId>) -> Option<Duration> { |     fn get_idle_ms(&self, id: Option<ReportId>) -> Option<u32> { | ||||||
|         info!("Get idle rate for {:?}", id); |         info!("Get idle rate for {:?}", id); | ||||||
|         None |         None | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -5,7 +5,6 @@ | |||||||
| use defmt::{panic, *}; | use defmt::{panic, *}; | ||||||
| use embassy_executor::Spawner; | use embassy_executor::Spawner; | ||||||
| use embassy_stm32::rcc::*; | use embassy_stm32::rcc::*; | ||||||
| use embassy_stm32::time::Hertz; |  | ||||||
| use embassy_stm32::usb::{Driver, Instance}; | use embassy_stm32::usb::{Driver, Instance}; | ||||||
| use embassy_stm32::{interrupt, Config}; | use embassy_stm32::{interrupt, Config}; | ||||||
| use embassy_usb::driver::EndpointError; | use embassy_usb::driver::EndpointError; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user