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

138 lines
3.9 KiB
Rust
Raw Normal View History

2023-04-06 18:53:51 +02:00
#![no_std]
#![no_main]
#![feature(type_alias_impl_trait)]
use defmt::*;
use embassy_executor::Spawner;
use embassy_net::tcp::TcpSocket;
use embassy_net::{Ipv4Address, Stack, StackResources};
use embassy_stm32::eth::generic_smi::GenericSMI;
use embassy_stm32::eth::{Ethernet, PacketQueue};
use embassy_stm32::peripherals::ETH;
2023-10-09 02:48:22 +02:00
use embassy_stm32::rcc::{
AHBPrescaler, APBPrescaler, Hse, HseMode, Pll, PllDiv, PllMul, PllPreDiv, PllSource, Sysclk, VoltageScale,
};
2023-04-06 18:53:51 +02:00
use embassy_stm32::rng::Rng;
use embassy_stm32::time::Hertz;
2023-07-31 01:41:12 +02:00
use embassy_stm32::{bind_interrupts, eth, peripherals, rng, Config};
use embassy_time::Timer;
2023-08-07 13:43:09 +02:00
use embedded_io_async::Write;
2023-04-06 18:53:51 +02:00
use rand_core::RngCore;
2023-06-01 01:32:11 +02:00
use static_cell::make_static;
2023-04-06 18:53:51 +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>;
});
2023-04-06 18:53:51 +02:00
type Device = Ethernet<'static, ETH, GenericSMI>;
#[embassy_executor::task]
async fn net_task(stack: &'static Stack<Device>) -> ! {
stack.run().await
}
#[embassy_executor::main]
async fn main(spawner: Spawner) -> ! {
let mut config = Config::default();
config.rcc.hsi = None;
config.rcc.hsi48 = true; // needed for rng
config.rcc.hse = Some(Hse {
freq: Hertz(8_000_000),
mode: HseMode::BypassDigital,
});
config.rcc.pll1 = Some(Pll {
2023-10-23 01:48:09 +02:00
source: PllSource::HSE,
2023-10-09 02:48:22 +02:00
prediv: PllPreDiv::DIV2,
mul: PllMul::MUL125,
divp: Some(PllDiv::DIV2),
divq: Some(PllDiv::DIV2),
2023-04-06 18:53:51 +02:00
divr: None,
});
config.rcc.ahb_pre = AHBPrescaler::DIV1;
config.rcc.apb1_pre = APBPrescaler::DIV1;
config.rcc.apb2_pre = APBPrescaler::DIV1;
config.rcc.apb3_pre = APBPrescaler::DIV1;
2023-10-23 01:48:09 +02:00
config.rcc.sys = Sysclk::PLL1_P;
2023-09-19 04:22:57 +02:00
config.rcc.voltage_scale = VoltageScale::Scale0;
2023-04-06 18:53:51 +02:00
let p = embassy_stm32::init(config);
info!("Hello World!");
// Generate random seed.
2023-07-31 01:41:12 +02:00
let mut rng = Rng::new(p.RNG, Irqs);
2023-04-06 18:53:51 +02:00
let mut seed = [0; 8];
rng.fill_bytes(&mut seed);
let seed = u64::from_le_bytes(seed);
let mac_addr = [0x00, 0x00, 0xDE, 0xAD, 0xBE, 0xEF];
let device = Ethernet::new(
2023-06-01 01:32:11 +02:00
make_static!(PacketQueue::<4, 4>::new()),
2023-04-06 18:53:51 +02:00
p.ETH,
Irqs,
2023-04-06 18:53:51 +02:00
p.PA1,
p.PA2,
p.PC1,
p.PA7,
p.PC4,
p.PC5,
p.PG13,
p.PB15,
p.PG11,
2023-10-09 12:00:23 +02:00
GenericSMI::new(0),
2023-04-06 18:53:51 +02:00
mac_addr,
);
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 {
2023-04-06 18:53:51 +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
));
2023-04-06 18:53:51 +02:00
// Launch network task
unwrap!(spawner.spawn(net_task(&stack)));
2023-09-08 17:40:20 +02:00
// Ensure DHCP configuration is up before trying connect
stack.wait_config_up().await;
2023-04-06 18:53:51 +02:00
info!("Network task initialized");
// 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)));
2023-04-06 18:53:51 +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);
Timer::after_secs(3).await;
2023-04-06 18:53:51 +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;
2023-04-06 18:53:51 +02:00
}
Timer::after_secs(1).await;
2023-04-06 18:53:51 +02:00
}
}
}