diff options
| author | Dario Nieuwenhuis <[email protected]> | 2023-06-22 19:18:01 +0000 |
|---|---|---|
| committer | GitHub <[email protected]> | 2023-06-22 19:18:01 +0000 |
| commit | 70907d84f197d1c5d5d112ae1172e9070d41b730 (patch) | |
| tree | 8d6e3085efad9758fc44b19194b5ea574aa38041 /examples | |
| parent | 1f2be2dac5eeed739d2866b9b63ca06fdd84c276 (diff) | |
| parent | 8bbfa6827cd68f67a50a89b13947542e632d5411 (diff) | |
Merge pull request #1546 from embassy-rs/esp-hosted
esp-hosted embassy-net driver.
Diffstat (limited to 'examples')
| -rw-r--r-- | examples/nrf52840/Cargo.toml | 22 | ||||
| -rw-r--r-- | examples/nrf52840/src/bin/wifi_esp_hosted.rs | 139 |
2 files changed, 159 insertions, 2 deletions
diff --git a/examples/nrf52840/Cargo.toml b/examples/nrf52840/Cargo.toml index 6627b7861..8c4175966 100644 --- a/examples/nrf52840/Cargo.toml +++ b/examples/nrf52840/Cargo.toml | |||
| @@ -6,8 +6,24 @@ license = "MIT OR Apache-2.0" | |||
| 6 | 6 | ||
| 7 | [features] | 7 | [features] |
| 8 | default = ["nightly"] | 8 | default = ["nightly"] |
| 9 | nightly = ["embassy-executor/nightly", "embassy-nrf/nightly", "embassy-net/nightly", "embassy-nrf/unstable-traits", "embassy-time/nightly", "embassy-time/unstable-traits", "static_cell/nightly", | 9 | nightly = [ |
| 10 | "embassy-usb", "embedded-io/async", "embassy-net", "embassy-lora", "lora-phy", "lorawan-device", "lorawan"] | 10 | "embedded-hal-async", |
| 11 | "embassy-executor/nightly", | ||
| 12 | "embassy-nrf/nightly", | ||
| 13 | "embassy-net/nightly", | ||
| 14 | "embassy-net-esp-hosted", | ||
| 15 | "embassy-nrf/unstable-traits", | ||
| 16 | "embassy-time/nightly", | ||
| 17 | "embassy-time/unstable-traits", | ||
| 18 | "static_cell/nightly", | ||
| 19 | "embassy-usb", | ||
| 20 | "embedded-io/async", | ||
| 21 | "embassy-net", | ||
| 22 | "embassy-lora", | ||
| 23 | "lora-phy", | ||
| 24 | "lorawan-device", | ||
| 25 | "lorawan", | ||
| 26 | ] | ||
| 11 | 27 | ||
| 12 | [dependencies] | 28 | [dependencies] |
| 13 | embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } | 29 | embassy-futures = { version = "0.1.0", path = "../../embassy-futures" } |
| @@ -22,6 +38,7 @@ embassy-lora = { version = "0.1.0", path = "../../embassy-lora", features = ["ti | |||
| 22 | lora-phy = { version = "1", optional = true } | 38 | lora-phy = { version = "1", optional = true } |
| 23 | lorawan-device = { version = "0.10.0", default-features = false, features = ["async", "external-lora-phy"], optional = true } | 39 | lorawan-device = { version = "0.10.0", default-features = false, features = ["async", "external-lora-phy"], optional = true } |
| 24 | lorawan = { version = "0.7.3", default-features = false, features = ["default-crypto"], optional = true } | 40 | lorawan = { version = "0.7.3", default-features = false, features = ["default-crypto"], optional = true } |
| 41 | embassy-net-esp-hosted = { version = "0.1.0", path = "../../embassy-net-esp-hosted", features = ["defmt"], optional = true } | ||
| 25 | 42 | ||
| 26 | defmt = "0.3" | 43 | defmt = "0.3" |
| 27 | defmt-rtt = "0.4" | 44 | defmt-rtt = "0.4" |
| @@ -35,3 +52,4 @@ rand = { version = "0.8.4", default-features = false } | |||
| 35 | embedded-storage = "0.3.0" | 52 | embedded-storage = "0.3.0" |
| 36 | usbd-hid = "0.6.0" | 53 | usbd-hid = "0.6.0" |
| 37 | serde = { version = "1.0.136", default-features = false } | 54 | serde = { version = "1.0.136", default-features = false } |
| 55 | embedded-hal-async = { version = "0.2.0-alpha.1", optional = true } | ||
diff --git a/examples/nrf52840/src/bin/wifi_esp_hosted.rs b/examples/nrf52840/src/bin/wifi_esp_hosted.rs new file mode 100644 index 000000000..4eb31b105 --- /dev/null +++ b/examples/nrf52840/src/bin/wifi_esp_hosted.rs | |||
| @@ -0,0 +1,139 @@ | |||
| 1 | #![no_std] | ||
| 2 | #![no_main] | ||
| 3 | #![feature(type_alias_impl_trait)] | ||
| 4 | |||
| 5 | use defmt::{info, unwrap, warn}; | ||
| 6 | use embassy_executor::Spawner; | ||
| 7 | use embassy_net::tcp::TcpSocket; | ||
| 8 | use embassy_net::{Stack, StackResources}; | ||
| 9 | use embassy_nrf::gpio::{AnyPin, Input, Level, Output, OutputDrive, Pin, Pull}; | ||
| 10 | use embassy_nrf::rng::Rng; | ||
| 11 | use embassy_nrf::spim::{self, Spim}; | ||
| 12 | use embassy_nrf::{bind_interrupts, peripherals}; | ||
| 13 | use embedded_hal_async::spi::ExclusiveDevice; | ||
| 14 | use embedded_io::asynch::Write; | ||
| 15 | use static_cell::make_static; | ||
| 16 | use {defmt_rtt as _, embassy_net_esp_hosted as hosted, panic_probe as _}; | ||
| 17 | |||
| 18 | bind_interrupts!(struct Irqs { | ||
| 19 | SPIM3 => spim::InterruptHandler<peripherals::SPI3>; | ||
| 20 | RNG => embassy_nrf::rng::InterruptHandler<peripherals::RNG>; | ||
| 21 | }); | ||
| 22 | |||
| 23 | #[embassy_executor::task] | ||
| 24 | async fn wifi_task( | ||
| 25 | runner: hosted::Runner< | ||
| 26 | 'static, | ||
| 27 | ExclusiveDevice<Spim<'static, peripherals::SPI3>, Output<'static, peripherals::P0_31>>, | ||
| 28 | Input<'static, AnyPin>, | ||
| 29 | Output<'static, peripherals::P1_05>, | ||
| 30 | >, | ||
| 31 | ) -> ! { | ||
| 32 | runner.run().await | ||
| 33 | } | ||
| 34 | |||
| 35 | #[embassy_executor::task] | ||
| 36 | async fn net_task(stack: &'static Stack<hosted::NetDriver<'static>>) -> ! { | ||
| 37 | stack.run().await | ||
| 38 | } | ||
| 39 | |||
| 40 | #[embassy_executor::main] | ||
| 41 | async fn main(spawner: Spawner) { | ||
| 42 | info!("Hello World!"); | ||
| 43 | |||
| 44 | let p = embassy_nrf::init(Default::default()); | ||
| 45 | |||
| 46 | let miso = p.P0_28; | ||
| 47 | let sck = p.P0_29; | ||
| 48 | let mosi = p.P0_30; | ||
| 49 | let cs = Output::new(p.P0_31, Level::High, OutputDrive::HighDrive); | ||
| 50 | let handshake = Input::new(p.P1_01.degrade(), Pull::Up); | ||
| 51 | let ready = Input::new(p.P1_04.degrade(), Pull::None); | ||
| 52 | let reset = Output::new(p.P1_05, Level::Low, OutputDrive::Standard); | ||
| 53 | |||
| 54 | let mut config = spim::Config::default(); | ||
| 55 | config.frequency = spim::Frequency::M32; | ||
| 56 | config.mode = spim::MODE_2; // !!! | ||
| 57 | let spi = spim::Spim::new(p.SPI3, Irqs, sck, miso, mosi, config); | ||
| 58 | let spi = ExclusiveDevice::new(spi, cs); | ||
| 59 | |||
| 60 | let (device, mut control, runner) = embassy_net_esp_hosted::new( | ||
| 61 | make_static!(embassy_net_esp_hosted::State::new()), | ||
| 62 | spi, | ||
| 63 | handshake, | ||
| 64 | ready, | ||
| 65 | reset, | ||
| 66 | ) | ||
| 67 | .await; | ||
| 68 | |||
| 69 | unwrap!(spawner.spawn(wifi_task(runner))); | ||
| 70 | |||
| 71 | control.init().await; | ||
| 72 | control.join(env!("WIFI_NETWORK"), env!("WIFI_PASSWORD")).await; | ||
| 73 | |||
| 74 | let config = embassy_net::Config::dhcpv4(Default::default()); | ||
| 75 | // let config = embassy_net::Config::ipv4_static(embassy_net::StaticConfigV4 { | ||
| 76 | // address: Ipv4Cidr::new(Ipv4Address::new(10, 42, 0, 61), 24), | ||
| 77 | // dns_servers: Vec::new(), | ||
| 78 | // gateway: Some(Ipv4Address::new(10, 42, 0, 1)), | ||
| 79 | // }); | ||
| 80 | |||
| 81 | // Generate random seed | ||
| 82 | let mut rng = Rng::new(p.RNG, Irqs); | ||
| 83 | let mut seed = [0; 8]; | ||
| 84 | rng.blocking_fill_bytes(&mut seed); | ||
| 85 | let seed = u64::from_le_bytes(seed); | ||
| 86 | |||
| 87 | // Init network stack | ||
| 88 | let stack = &*make_static!(Stack::new( | ||
| 89 | device, | ||
| 90 | config, | ||
| 91 | make_static!(StackResources::<2>::new()), | ||
| 92 | seed | ||
| 93 | )); | ||
| 94 | |||
| 95 | unwrap!(spawner.spawn(net_task(stack))); | ||
| 96 | |||
| 97 | // And now we can use it! | ||
| 98 | |||
| 99 | let mut rx_buffer = [0; 4096]; | ||
| 100 | let mut tx_buffer = [0; 4096]; | ||
| 101 | let mut buf = [0; 4096]; | ||
| 102 | |||
| 103 | loop { | ||
| 104 | let mut socket = TcpSocket::new(stack, &mut rx_buffer, &mut tx_buffer); | ||
| 105 | socket.set_timeout(Some(embassy_time::Duration::from_secs(10))); | ||
| 106 | |||
| 107 | info!("Listening on TCP:1234..."); | ||
| 108 | if let Err(e) = socket.accept(1234).await { | ||
| 109 | warn!("accept error: {:?}", e); | ||
| 110 | continue; | ||
| 111 | } | ||
| 112 | |||
| 113 | info!("Received connection from {:?}", socket.remote_endpoint()); | ||
| 114 | |||
| 115 | loop { | ||
| 116 | let n = match socket.read(&mut buf).await { | ||
| 117 | Ok(0) => { | ||
| 118 | warn!("read EOF"); | ||
| 119 | break; | ||
| 120 | } | ||
| 121 | Ok(n) => n, | ||
| 122 | Err(e) => { | ||
| 123 | warn!("read error: {:?}", e); | ||
| 124 | break; | ||
| 125 | } | ||
| 126 | }; | ||
| 127 | |||
| 128 | info!("rxd {:02x}", &buf[..n]); | ||
| 129 | |||
| 130 | match socket.write_all(&buf[..n]).await { | ||
| 131 | Ok(()) => {} | ||
| 132 | Err(e) => { | ||
| 133 | warn!("write error: {:?}", e); | ||
| 134 | break; | ||
| 135 | } | ||
| 136 | }; | ||
| 137 | } | ||
| 138 | } | ||
| 139 | } | ||
