2022-10-24 11:33:17 +02:00
|
|
|
#![no_std]
|
|
|
|
#![no_main]
|
|
|
|
#![feature(type_alias_impl_trait)]
|
|
|
|
|
|
|
|
use defmt::*;
|
|
|
|
use embassy_executor::Spawner;
|
2023-10-10 18:10:53 +02:00
|
|
|
use embassy_stm32::i2c::{Error, I2c};
|
2022-10-24 11:33:17 +02:00
|
|
|
use embassy_stm32::time::Hertz;
|
2023-05-25 00:29:56 +02:00
|
|
|
use embassy_stm32::{bind_interrupts, i2c, peripherals};
|
2022-10-24 11:33:17 +02:00
|
|
|
use {defmt_rtt as _, panic_probe as _};
|
|
|
|
|
|
|
|
const ADDRESS: u8 = 0x5F;
|
|
|
|
const WHOAMI: u8 = 0x0F;
|
|
|
|
|
2023-05-25 00:29:56 +02:00
|
|
|
bind_interrupts!(struct Irqs {
|
|
|
|
I2C2_EV => i2c::InterruptHandler<peripherals::I2C2>;
|
|
|
|
});
|
|
|
|
|
2022-10-24 11:33:17 +02:00
|
|
|
#[embassy_executor::main]
|
2023-03-08 03:08:59 +01:00
|
|
|
async fn main(_spawner: Spawner) {
|
2022-10-24 11:33:17 +02:00
|
|
|
info!("Hello world!");
|
|
|
|
let p = embassy_stm32::init(Default::default());
|
|
|
|
|
|
|
|
let mut i2c = I2c::new(
|
|
|
|
p.I2C2,
|
|
|
|
p.PB10,
|
|
|
|
p.PB11,
|
2023-05-25 00:29:56 +02:00
|
|
|
Irqs,
|
2022-10-24 11:33:17 +02:00
|
|
|
p.DMA1_CH4,
|
|
|
|
p.DMA1_CH5,
|
|
|
|
Hertz(100_000),
|
|
|
|
Default::default(),
|
|
|
|
);
|
2022-10-24 21:48:40 +02:00
|
|
|
|
2022-10-24 11:33:17 +02:00
|
|
|
let mut data = [0u8; 1];
|
|
|
|
|
2023-10-10 18:10:53 +02:00
|
|
|
match i2c.blocking_write_read(ADDRESS, &[WHOAMI], &mut data) {
|
2022-10-24 11:33:17 +02:00
|
|
|
Ok(()) => info!("Whoami: {}", data[0]),
|
|
|
|
Err(Error::Timeout) => error!("Operation timed out"),
|
|
|
|
Err(e) => error!("I2c Error: {:?}", e),
|
|
|
|
}
|
|
|
|
}
|