2022-04-20 13:49:59 +02:00
|
|
|
#![no_std]
|
|
|
|
#![no_main]
|
|
|
|
#![feature(type_alias_impl_trait)]
|
|
|
|
|
|
|
|
use defmt::{info, unwrap};
|
2022-08-17 23:40:16 +02:00
|
|
|
use embassy_executor::Spawner;
|
2023-05-25 13:42:42 +02:00
|
|
|
use embassy_stm32::flash::Flash;
|
2022-06-12 22:15:44 +02:00
|
|
|
use {defmt_rtt as _, panic_probe as _};
|
2022-04-20 13:49:59 +02:00
|
|
|
|
2022-07-29 21:58:35 +02:00
|
|
|
#[embassy_executor::main]
|
2022-08-17 18:49:55 +02:00
|
|
|
async fn main(_spawner: Spawner) {
|
|
|
|
let p = embassy_stm32::init(Default::default());
|
2022-04-20 13:49:59 +02:00
|
|
|
info!("Hello Flash!");
|
|
|
|
|
2022-04-26 18:33:09 +02:00
|
|
|
const ADDR: u32 = 0x26000;
|
2022-04-20 13:49:59 +02:00
|
|
|
|
2023-05-25 13:42:42 +02:00
|
|
|
let mut f = Flash::new_blocking_only(p.FLASH).into_blocking_regions().bank1_region;
|
2022-04-20 13:49:59 +02:00
|
|
|
|
|
|
|
info!("Reading...");
|
|
|
|
let mut buf = [0u8; 8];
|
2023-05-24 17:31:35 +02:00
|
|
|
unwrap!(f.read_blocking(ADDR, &mut buf));
|
2022-04-20 13:49:59 +02:00
|
|
|
info!("Read: {=[u8]:x}", buf);
|
|
|
|
|
|
|
|
info!("Erasing...");
|
2023-05-24 17:31:35 +02:00
|
|
|
unwrap!(f.erase_blocking(ADDR, ADDR + 128));
|
2022-04-20 13:49:59 +02:00
|
|
|
|
|
|
|
info!("Reading...");
|
|
|
|
let mut buf = [0u8; 8];
|
2023-05-24 17:31:35 +02:00
|
|
|
unwrap!(f.read_blocking(ADDR, &mut buf));
|
2022-04-20 13:49:59 +02:00
|
|
|
info!("Read after erase: {=[u8]:x}", buf);
|
|
|
|
|
|
|
|
info!("Writing...");
|
2023-05-24 17:31:35 +02:00
|
|
|
unwrap!(f.write_blocking(ADDR, &[1, 2, 3, 4, 5, 6, 7, 8]));
|
2022-04-20 13:49:59 +02:00
|
|
|
|
|
|
|
info!("Reading...");
|
|
|
|
let mut buf = [0u8; 8];
|
2023-05-24 17:31:35 +02:00
|
|
|
unwrap!(f.read_blocking(ADDR, &mut buf));
|
2022-04-20 13:49:59 +02:00
|
|
|
info!("Read: {=[u8]:x}", buf);
|
|
|
|
assert_eq!(&buf[..], &[1, 2, 3, 4, 5, 6, 7, 8]);
|
|
|
|
}
|