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/nrf52840/src | |
| parent | 1f2be2dac5eeed739d2866b9b63ca06fdd84c276 (diff) | |
| parent | 8bbfa6827cd68f67a50a89b13947542e632d5411 (diff) | |
Merge pull request #1546 from embassy-rs/esp-hosted
esp-hosted embassy-net driver.
Diffstat (limited to 'examples/nrf52840/src')
| -rw-r--r-- | examples/nrf52840/src/bin/wifi_esp_hosted.rs | 139 |
1 files changed, 139 insertions, 0 deletions
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 | } | ||
