108 lines
2.8 KiB
Rust
Raw Normal View History

2021-06-02 01:30:07 +02:00
#![feature(type_alias_impl_trait)]
2023-01-18 10:10:33 +01:00
use std::default::Default;
2021-10-18 01:19:01 +02:00
use clap::Parser;
use embassy_executor::{Executor, Spawner};
2022-05-04 20:48:37 +02:00
use embassy_net::tcp::TcpSocket;
2023-01-18 10:10:33 +01:00
use embassy_net::{Config, Ipv4Address, Ipv4Cidr, Stack, StackResources};
use embassy_time::Duration;
2022-05-04 20:48:37 +02:00
use embedded_io::asynch::Write;
2021-06-02 01:30:07 +02:00
use heapless::Vec;
use log::*;
2022-05-23 03:50:43 +02:00
use rand_core::{OsRng, RngCore};
2023-06-01 01:32:11 +02:00
use static_cell::{make_static, StaticCell};
2021-06-02 01:30:07 +02:00
#[path = "../tuntap.rs"]
mod tuntap;
use crate::tuntap::TunTapDevice;
2021-10-18 01:19:01 +02:00
#[derive(Parser)]
2021-06-02 01:30:07 +02:00
#[clap(version = "1.0")]
struct Opts {
/// TAP device name
#[clap(long, default_value = "tap0")]
tap: String,
2021-07-04 12:42:39 +10:00
/// use a static IP instead of DHCP
#[clap(long)]
static_ip: bool,
2021-06-02 01:30:07 +02:00
}
#[embassy_executor::task]
2022-05-23 03:50:43 +02:00
async fn net_task(stack: &'static Stack<TunTapDevice>) -> ! {
stack.run().await
2021-06-02 01:30:07 +02:00
}
#[embassy_executor::task]
2021-06-02 01:30:07 +02:00
async fn main_task(spawner: Spawner) {
let opts: Opts = Opts::parse();
// Init network device
let device = TunTapDevice::new(&opts.tap).unwrap();
2021-07-04 12:42:39 +10:00
// Choose between dhcp or static ip
2022-05-23 03:50:43 +02:00
let config = if opts.static_ip {
2023-01-18 10:10:33 +01:00
Config::Static(embassy_net::StaticConfig {
2021-07-04 12:42:39 +10:00
address: Ipv4Cidr::new(Ipv4Address::new(192, 168, 69, 2), 24),
dns_servers: Vec::new(),
gateway: Some(Ipv4Address::new(192, 168, 69, 1)),
2022-05-23 03:50:43 +02:00
})
2021-07-04 12:42:39 +10:00
} else {
2023-01-18 10:10:33 +01:00
Config::Dhcp(Default::default())
2021-07-04 12:42:39 +10:00
};
2021-06-02 01:30:07 +02:00
2022-05-23 03:50:43 +02:00
// Generate random seed
let mut seed = [0; 8];
OsRng.fill_bytes(&mut seed);
let seed = u64::from_le_bytes(seed);
2021-06-02 01:30:07 +02:00
// Init network stack
2023-06-01 01:32:11 +02:00
let stack = &*make_static!(Stack::new(
device,
config,
make_static!(StackResources::<3>::new()),
seed
));
2021-06-02 01:30:07 +02:00
// Launch network task
2022-05-23 03:50:43 +02:00
spawner.spawn(net_task(stack)).unwrap();
2021-06-02 01:30:07 +02:00
// Then we can use it!
let mut rx_buffer = [0; 4096];
let mut tx_buffer = [0; 4096];
2022-05-23 03:50:43 +02:00
let mut socket = TcpSocket::new(stack, &mut rx_buffer, &mut tx_buffer);
2021-06-02 01:30:07 +02:00
socket.set_timeout(Some(Duration::from_secs(10)));
2021-06-02 01:30:07 +02:00
2021-11-26 04:12:14 +01:00
let remote_endpoint = (Ipv4Address::new(192, 168, 69, 100), 8000);
2021-06-02 01:30:07 +02:00
info!("connecting to {:?}...", remote_endpoint);
let r = socket.connect(remote_endpoint).await;
if let Err(e) = r {
warn!("connect error: {:?}", e);
return;
}
info!("connected!");
loop {
let r = socket.write_all(b"Hello!\n").await;
if let Err(e) = r {
warn!("write error: {:?}", e);
return;
}
}
}
2022-08-22 15:51:44 +02:00
static EXECUTOR: StaticCell<Executor> = StaticCell::new();
2021-06-02 01:30:07 +02:00
fn main() {
env_logger::builder()
.filter_level(log::LevelFilter::Debug)
.filter_module("async_io", log::LevelFilter::Info)
.format_timestamp_nanos()
.init();
2022-08-22 15:51:44 +02:00
let executor = EXECUTOR.init(Executor::new());
2021-06-02 01:30:07 +02:00
executor.run(|spawner| {
spawner.spawn(main_task(spawner)).unwrap();
});
}