embassy/examples/nrf52840/src/bin/nvmc.rs

44 lines
1.1 KiB
Rust
Raw Normal View History

2021-10-22 02:09:55 +02:00
#![no_std]
#![no_main]
#![feature(type_alias_impl_trait)]
use defmt::{info, unwrap};
use embassy_executor::Spawner;
2021-10-22 02:09:55 +02:00
use embassy_nrf::nvmc::Nvmc;
use embassy_time::Timer;
2021-10-22 02:09:55 +02:00
use embedded_storage::nor_flash::{NorFlash, ReadNorFlash};
2022-06-12 22:15:44 +02:00
use {defmt_rtt as _, panic_probe as _};
2021-10-22 02:09:55 +02:00
#[embassy_executor::main]
async fn main(_spawner: Spawner) {
let p = embassy_nrf::init(Default::default());
2021-10-22 02:09:55 +02:00
info!("Hello NVMC!");
2023-06-29 02:39:28 +02:00
// probe-rs run breaks without this, I'm not sure why.
Timer::after_secs(1).await;
2021-10-22 02:09:55 +02:00
let mut f = Nvmc::new(p.NVMC);
const ADDR: u32 = 0x80000;
info!("Reading...");
let mut buf = [0u8; 4];
unwrap!(f.read(ADDR, &mut buf));
info!("Read: {=[u8]:x}", buf);
info!("Erasing...");
unwrap!(f.erase(ADDR, ADDR + 4096));
info!("Reading...");
let mut buf = [0u8; 4];
unwrap!(f.read(ADDR, &mut buf));
info!("Read: {=[u8]:x}", buf);
info!("Writing...");
unwrap!(f.write(ADDR, &[1, 2, 3, 4]));
info!("Reading...");
let mut buf = [0u8; 4];
unwrap!(f.read(ADDR, &mut buf));
info!("Read: {=[u8]:x}", buf);
}