diff options
| author | xoviat <[email protected]> | 2023-07-22 14:49:31 -0500 |
|---|---|---|
| committer | xoviat <[email protected]> | 2023-07-22 14:49:31 -0500 |
| commit | d42dff45de94522d7a5324773b352266a77f0c2c (patch) | |
| tree | b1d9e5d113405f60a211d046713f992a0f7c825b /examples/stm32f4/src | |
| parent | 0c49e6747c02e03fc6517969105cfdf20239fc64 (diff) | |
| parent | 603ea9f31039f3c25a5314f53c2d8f8bcabe16af (diff) | |
Merge branch 'main' of https://github.com/embassy-rs/embassy into hrtim
Diffstat (limited to 'examples/stm32f4/src')
| -rw-r--r-- | examples/stm32f4/src/bin/can.rs | 18 | ||||
| -rw-r--r-- | examples/stm32f4/src/bin/eth.rs | 111 |
2 files changed, 121 insertions, 8 deletions
diff --git a/examples/stm32f4/src/bin/can.rs b/examples/stm32f4/src/bin/can.rs index da8955053..08bed88db 100644 --- a/examples/stm32f4/src/bin/can.rs +++ b/examples/stm32f4/src/bin/can.rs | |||
| @@ -2,8 +2,8 @@ | |||
| 2 | #![no_main] | 2 | #![no_main] |
| 3 | #![feature(type_alias_impl_trait)] | 3 | #![feature(type_alias_impl_trait)] |
| 4 | 4 | ||
| 5 | use cortex_m_rt::entry; | ||
| 6 | use defmt::*; | 5 | use defmt::*; |
| 6 | use embassy_executor::Spawner; | ||
| 7 | use embassy_stm32::bind_interrupts; | 7 | use embassy_stm32::bind_interrupts; |
| 8 | use embassy_stm32::can::bxcan::filter::Mask32; | 8 | use embassy_stm32::can::bxcan::filter::Mask32; |
| 9 | use embassy_stm32::can::bxcan::{Fifo, Frame, StandardId}; | 9 | use embassy_stm32::can::bxcan::{Fifo, Frame, StandardId}; |
| @@ -19,8 +19,8 @@ bind_interrupts!(struct Irqs { | |||
| 19 | CAN1_TX => TxInterruptHandler<CAN1>; | 19 | CAN1_TX => TxInterruptHandler<CAN1>; |
| 20 | }); | 20 | }); |
| 21 | 21 | ||
| 22 | #[entry] | 22 | #[embassy_executor::main] |
| 23 | fn main() -> ! { | 23 | async fn main(_spawner: Spawner) { |
| 24 | info!("Hello World!"); | 24 | info!("Hello World!"); |
| 25 | 25 | ||
| 26 | let mut p = embassy_stm32::init(Default::default()); | 26 | let mut p = embassy_stm32::init(Default::default()); |
| @@ -34,9 +34,12 @@ fn main() -> ! { | |||
| 34 | 34 | ||
| 35 | let mut can = Can::new(p.CAN1, p.PA11, p.PA12, Irqs); | 35 | let mut can = Can::new(p.CAN1, p.PA11, p.PA12, Irqs); |
| 36 | 36 | ||
| 37 | can.modify_filters().enable_bank(0, Fifo::Fifo0, Mask32::accept_all()); | 37 | can.as_mut() |
| 38 | .modify_filters() | ||
| 39 | .enable_bank(0, Fifo::Fifo0, Mask32::accept_all()); | ||
| 38 | 40 | ||
| 39 | can.modify_config() | 41 | can.as_mut() |
| 42 | .modify_config() | ||
| 40 | .set_bit_timing(0x001c0003) // http://www.bittiming.can-wiki.info/ | 43 | .set_bit_timing(0x001c0003) // http://www.bittiming.can-wiki.info/ |
| 41 | .set_loopback(true) // Receive own frames | 44 | .set_loopback(true) // Receive own frames |
| 42 | .set_silent(true) | 45 | .set_silent(true) |
| @@ -45,9 +48,8 @@ fn main() -> ! { | |||
| 45 | let mut i: u8 = 0; | 48 | let mut i: u8 = 0; |
| 46 | loop { | 49 | loop { |
| 47 | let tx_frame = Frame::new_data(unwrap!(StandardId::new(i as _)), [i]); | 50 | let tx_frame = Frame::new_data(unwrap!(StandardId::new(i as _)), [i]); |
| 48 | unwrap!(nb::block!(can.transmit(&tx_frame))); | 51 | can.write(&tx_frame).await; |
| 49 | while !can.is_transmitter_idle() {} | 52 | let (_, rx_frame) = can.read().await.unwrap(); |
| 50 | let rx_frame = unwrap!(nb::block!(can.receive())); | ||
| 51 | info!("loopback frame {=u8}", unwrap!(rx_frame.data())[0]); | 53 | info!("loopback frame {=u8}", unwrap!(rx_frame.data())[0]); |
| 52 | i += 1; | 54 | i += 1; |
| 53 | } | 55 | } |
diff --git a/examples/stm32f4/src/bin/eth.rs b/examples/stm32f4/src/bin/eth.rs new file mode 100644 index 000000000..d0b164393 --- /dev/null +++ b/examples/stm32f4/src/bin/eth.rs | |||
| @@ -0,0 +1,111 @@ | |||
| 1 | #![no_std] | ||
| 2 | #![no_main] | ||
| 3 | #![feature(type_alias_impl_trait)] | ||
| 4 | |||
| 5 | use defmt::*; | ||
| 6 | use embassy_executor::Spawner; | ||
| 7 | use embassy_net::tcp::TcpSocket; | ||
| 8 | use embassy_net::{Ipv4Address, Stack, StackResources}; | ||
| 9 | use embassy_stm32::eth::generic_smi::GenericSMI; | ||
| 10 | use embassy_stm32::eth::{Ethernet, PacketQueue}; | ||
| 11 | use embassy_stm32::peripherals::ETH; | ||
| 12 | use embassy_stm32::rng::Rng; | ||
| 13 | use embassy_stm32::time::mhz; | ||
| 14 | use embassy_stm32::{bind_interrupts, eth, Config}; | ||
| 15 | use embassy_time::{Duration, Timer}; | ||
| 16 | use embedded_io::asynch::Write; | ||
| 17 | use static_cell::make_static; | ||
| 18 | use {defmt_rtt as _, panic_probe as _}; | ||
| 19 | bind_interrupts!(struct Irqs { | ||
| 20 | ETH => eth::InterruptHandler; | ||
| 21 | }); | ||
| 22 | |||
| 23 | type Device = Ethernet<'static, ETH, GenericSMI>; | ||
| 24 | |||
| 25 | #[embassy_executor::task] | ||
| 26 | async fn net_task(stack: &'static Stack<Device>) -> ! { | ||
| 27 | stack.run().await | ||
| 28 | } | ||
| 29 | |||
| 30 | #[embassy_executor::main] | ||
| 31 | async fn main(spawner: Spawner) -> ! { | ||
| 32 | let mut config = Config::default(); | ||
| 33 | config.rcc.sys_ck = Some(mhz(200)); | ||
| 34 | let p = embassy_stm32::init(config); | ||
| 35 | |||
| 36 | info!("Hello World!"); | ||
| 37 | |||
| 38 | // Generate random seed. | ||
| 39 | let mut rng = Rng::new(p.RNG); | ||
| 40 | let mut seed = [0; 8]; | ||
| 41 | let _ = rng.async_fill_bytes(&mut seed).await; | ||
| 42 | let seed = u64::from_le_bytes(seed); | ||
| 43 | |||
| 44 | let mac_addr = [0x00, 0x00, 0xDE, 0xAD, 0xBE, 0xEF]; | ||
| 45 | |||
| 46 | let device = Ethernet::new( | ||
| 47 | make_static!(PacketQueue::<16, 16>::new()), | ||
| 48 | p.ETH, | ||
| 49 | Irqs, | ||
| 50 | p.PA1, | ||
| 51 | p.PA2, | ||
| 52 | p.PC1, | ||
| 53 | p.PA7, | ||
| 54 | p.PC4, | ||
| 55 | p.PC5, | ||
| 56 | p.PG13, | ||
| 57 | p.PB13, | ||
| 58 | p.PG11, | ||
| 59 | GenericSMI::new(), | ||
| 60 | mac_addr, | ||
| 61 | 0, | ||
| 62 | ); | ||
| 63 | |||
| 64 | let config = embassy_net::Config::dhcpv4(Default::default()); | ||
| 65 | //let config = embassy_net::Config::ipv4_static(embassy_net::StaticConfigV4 { | ||
| 66 | // address: Ipv4Cidr::new(Ipv4Address::new(10, 42, 0, 61), 24), | ||
| 67 | // dns_servers: Vec::new(), | ||
| 68 | // gateway: Some(Ipv4Address::new(10, 42, 0, 1)), | ||
| 69 | //}); | ||
| 70 | |||
| 71 | // Init network stack | ||
| 72 | let stack = &*make_static!(Stack::new( | ||
| 73 | device, | ||
| 74 | config, | ||
| 75 | make_static!(StackResources::<2>::new()), | ||
| 76 | seed | ||
| 77 | )); | ||
| 78 | |||
| 79 | // Launch network task | ||
| 80 | unwrap!(spawner.spawn(net_task(&stack))); | ||
| 81 | |||
| 82 | info!("Network task initialized"); | ||
| 83 | |||
| 84 | // Then we can use it! | ||
| 85 | let mut rx_buffer = [0; 4096]; | ||
| 86 | let mut tx_buffer = [0; 4096]; | ||
| 87 | |||
| 88 | loop { | ||
| 89 | let mut socket = TcpSocket::new(&stack, &mut rx_buffer, &mut tx_buffer); | ||
| 90 | |||
| 91 | socket.set_timeout(Some(embassy_time::Duration::from_secs(10))); | ||
| 92 | |||
| 93 | let remote_endpoint = (Ipv4Address::new(10, 42, 0, 1), 8000); | ||
| 94 | info!("connecting..."); | ||
| 95 | let r = socket.connect(remote_endpoint).await; | ||
| 96 | if let Err(e) = r { | ||
| 97 | info!("connect error: {:?}", e); | ||
| 98 | continue; | ||
| 99 | } | ||
| 100 | info!("connected!"); | ||
| 101 | let buf = [0; 1024]; | ||
| 102 | loop { | ||
| 103 | let r = socket.write_all(&buf).await; | ||
| 104 | if let Err(e) = r { | ||
| 105 | info!("write error: {:?}", e); | ||
| 106 | continue; | ||
| 107 | } | ||
| 108 | Timer::after(Duration::from_secs(1)).await; | ||
| 109 | } | ||
| 110 | } | ||
| 111 | } | ||
