2021-10-22 02:09:55 +02:00
|
|
|
#![no_std]
|
|
|
|
#![no_main]
|
|
|
|
#![feature(type_alias_impl_trait)]
|
|
|
|
|
2022-04-02 04:35:06 +02:00
|
|
|
use defmt::{info, unwrap};
|
2022-08-17 23:40:16 +02:00
|
|
|
use embassy_executor::Spawner;
|
2021-10-22 02:09:55 +02:00
|
|
|
use embassy_nrf::nvmc::Nvmc;
|
2023-10-15 01:57:25 +02:00
|
|
|
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
|
|
|
|
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_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.
|
2023-10-15 01:57:25 +02:00
|
|
|
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);
|
|
|
|
}
|