embassy/examples/stm32h7/src/bin/eth.rs

136 lines
3.9 KiB
Rust
Raw Normal View History

2021-06-15 23:52:43 +02:00
#![no_std]
#![no_main]
#![feature(type_alias_impl_trait)]
use defmt::*;
use embassy_executor::Spawner;
2022-05-04 20:48:37 +02:00
use embassy_net::tcp::TcpSocket;
2022-05-23 03:50:43 +02:00
use embassy_net::{Ipv4Address, Stack, StackResources};
use embassy_stm32::eth::generic_smi::GenericSMI;
use embassy_stm32::eth::{Ethernet, PacketQueue};
use embassy_stm32::peripherals::ETH;
use embassy_stm32::rng::Rng;
2023-07-31 01:41:12 +02:00
use embassy_stm32::{bind_interrupts, eth, peripherals, rng, Config};
use embassy_time::{Duration, Timer};
2023-08-07 13:43:09 +02:00
use embedded_io_async::Write;
2022-05-23 03:50:43 +02:00
use rand_core::RngCore;
2023-06-01 01:32:11 +02:00
use static_cell::make_static;
2022-06-12 22:15:44 +02:00
use {defmt_rtt as _, panic_probe as _};
2023-07-31 01:41:12 +02:00
bind_interrupts!(struct Irqs {
ETH => eth::InterruptHandler;
2023-07-31 01:41:12 +02:00
RNG => rng::InterruptHandler<peripherals::RNG>;
});
type Device = Ethernet<'static, ETH, GenericSMI>;
2021-06-15 23:52:43 +02:00
#[embassy_executor::task]
2022-05-23 03:50:43 +02:00
async fn net_task(stack: &'static Stack<Device>) -> ! {
stack.run().await
2021-06-15 23:52:43 +02:00
}
#[embassy_executor::main]
async fn main(spawner: Spawner) -> ! {
let mut config = Config::default();
2023-09-19 04:22:57 +02:00
{
use embassy_stm32::rcc::*;
config.rcc.hsi = Some(Hsi::Mhz64);
config.rcc.csi = true;
config.rcc.hsi48 = true; // needed for RNG
config.rcc.pll_src = PllSource::Hsi;
config.rcc.pll1 = Some(Pll {
2023-10-09 02:48:22 +02:00
prediv: PllPreDiv::DIV4,
mul: PllMul::MUL50,
divp: Some(PllDiv::DIV2),
2023-09-19 04:22:57 +02:00
divq: None,
divr: None,
});
config.rcc.sys = Sysclk::Pll1P; // 400 Mhz
config.rcc.ahb_pre = AHBPrescaler::DIV2; // 200 Mhz
config.rcc.apb1_pre = APBPrescaler::DIV2; // 100 Mhz
config.rcc.apb2_pre = APBPrescaler::DIV2; // 100 Mhz
config.rcc.apb3_pre = APBPrescaler::DIV2; // 100 Mhz
config.rcc.apb4_pre = APBPrescaler::DIV2; // 100 Mhz
config.rcc.voltage_scale = VoltageScale::Scale1;
}
let p = embassy_stm32::init(config);
2021-06-15 23:52:43 +02:00
info!("Hello World!");
2022-05-23 03:50:43 +02:00
// Generate random seed.
2023-07-31 01:41:12 +02:00
let mut rng = Rng::new(p.RNG, Irqs);
2022-05-23 03:50:43 +02:00
let mut seed = [0; 8];
rng.fill_bytes(&mut seed);
let seed = u64::from_le_bytes(seed);
2021-06-15 23:52:43 +02:00
2022-05-23 03:50:43 +02:00
let mac_addr = [0x00, 0x00, 0xDE, 0xAD, 0xBE, 0xEF];
let device = Ethernet::new(
2023-06-01 01:32:11 +02:00
make_static!(PacketQueue::<16, 16>::new()),
p.ETH,
Irqs,
p.PA1,
p.PA2,
p.PC1,
p.PA7,
p.PC4,
p.PC5,
p.PG13,
p.PB13,
p.PG11,
2023-07-15 19:02:08 +02:00
GenericSMI::new(),
mac_addr,
0,
);
2021-06-15 23:52:43 +02:00
2023-06-07 12:04:15 +02:00
let config = embassy_net::Config::dhcpv4(Default::default());
//let config = embassy_net::Config::ipv4_static(embassy_net::StaticConfigV4 {
2022-05-23 03:50:43 +02:00
// address: Ipv4Cidr::new(Ipv4Address::new(10, 42, 0, 61), 24),
// dns_servers: Vec::new(),
// gateway: Some(Ipv4Address::new(10, 42, 0, 1)),
//});
// Init network stack
2023-06-01 01:32:11 +02:00
let stack = &*make_static!(Stack::new(
device,
config,
make_static!(StackResources::<2>::new()),
seed
));
2021-06-15 23:52:43 +02:00
2022-05-23 03:50:43 +02:00
// Launch network task
unwrap!(spawner.spawn(net_task(&stack)));
2021-06-15 23:52:43 +02:00
2023-09-08 17:40:20 +02:00
// Ensure DHCP configuration is up before trying connect
stack.wait_config_up().await;
2022-05-23 03:50:43 +02:00
info!("Network task initialized");
2021-06-15 23:52:43 +02:00
2022-05-23 03:50:43 +02:00
// Then we can use it!
let mut rx_buffer = [0; 1024];
let mut tx_buffer = [0; 1024];
loop {
let mut socket = TcpSocket::new(&stack, &mut rx_buffer, &mut tx_buffer);
socket.set_timeout(Some(embassy_time::Duration::from_secs(10)));
2022-05-23 03:50:43 +02:00
let remote_endpoint = (Ipv4Address::new(10, 42, 0, 1), 8000);
info!("connecting...");
let r = socket.connect(remote_endpoint).await;
if let Err(e) = r {
info!("connect error: {:?}", e);
2023-09-19 04:22:57 +02:00
Timer::after(Duration::from_secs(1)).await;
2022-05-23 03:50:43 +02:00
continue;
}
info!("connected!");
loop {
let r = socket.write_all(b"Hello\n").await;
if let Err(e) = r {
info!("write error: {:?}", e);
2023-09-19 04:22:57 +02:00
break;
2022-05-23 03:50:43 +02:00
}
Timer::after(Duration::from_secs(1)).await;
}
}
2021-06-15 23:52:43 +02:00
}