Refactor firmware updater
* Allow manipulating state without accessing DFU partition. * Provide aligned buffer when creating updater to reduce potential wrong parameters passed.
This commit is contained in:
@ -52,20 +52,20 @@ async fn main(_spawner: Spawner) {
|
||||
let nvmc = Mutex::new(BlockingAsync::new(nvmc));
|
||||
|
||||
let config = FirmwareUpdaterConfig::from_linkerfile(&nvmc);
|
||||
let mut updater = FirmwareUpdater::new(config);
|
||||
let mut magic = [0; 4];
|
||||
let mut updater = FirmwareUpdater::new(config, &mut magic);
|
||||
loop {
|
||||
led.set_low();
|
||||
button.wait_for_any_edge().await;
|
||||
if button.is_low() {
|
||||
let mut offset = 0;
|
||||
let mut magic = [0; 4];
|
||||
for chunk in APP_B.chunks(4096) {
|
||||
let mut buf: [u8; 4096] = [0; 4096];
|
||||
buf[..chunk.len()].copy_from_slice(chunk);
|
||||
updater.write_firmware(&mut magic, offset, &buf).await.unwrap();
|
||||
updater.write_firmware(offset, &buf).await.unwrap();
|
||||
offset += chunk.len();
|
||||
}
|
||||
updater.mark_updated(&mut magic).await.unwrap();
|
||||
updater.mark_updated().await.unwrap();
|
||||
led.set_high();
|
||||
cortex_m::peripheral::SCB::sys_reset();
|
||||
}
|
||||
|
@ -38,7 +38,8 @@ async fn main(_s: Spawner) {
|
||||
let flash = Mutex::new(RefCell::new(flash));
|
||||
|
||||
let config = FirmwareUpdaterConfig::from_linkerfile_blocking(&flash);
|
||||
let mut updater = BlockingFirmwareUpdater::new(config);
|
||||
let mut aligned = AlignedBuffer([0; 4]);
|
||||
let mut updater = BlockingFirmwareUpdater::new(config, &mut aligned.0);
|
||||
|
||||
Timer::after(Duration::from_secs(5)).await;
|
||||
watchdog.feed();
|
||||
@ -47,7 +48,7 @@ async fn main(_s: Spawner) {
|
||||
let mut buf: AlignedBuffer<4096> = AlignedBuffer([0; 4096]);
|
||||
defmt::info!("preparing update");
|
||||
let writer = updater
|
||||
.prepare_update(&mut buf.0[..1])
|
||||
.prepare_update()
|
||||
.map_err(|e| defmt::warn!("E: {:?}", defmt::Debug2Format(&e)))
|
||||
.unwrap();
|
||||
defmt::info!("writer created, starting write");
|
||||
@ -59,7 +60,7 @@ async fn main(_s: Spawner) {
|
||||
}
|
||||
watchdog.feed();
|
||||
defmt::info!("firmware written, marking update");
|
||||
updater.mark_updated(&mut buf.0[..1]).unwrap();
|
||||
updater.mark_updated().unwrap();
|
||||
Timer::after(Duration::from_secs(2)).await;
|
||||
led.set_low();
|
||||
defmt::info!("update marked, resetting");
|
||||
|
@ -31,17 +31,17 @@ async fn main(_spawner: Spawner) {
|
||||
led.set_high();
|
||||
|
||||
let config = FirmwareUpdaterConfig::from_linkerfile(&flash);
|
||||
let mut updater = FirmwareUpdater::new(config);
|
||||
let mut magic = AlignedBuffer([0; WRITE_SIZE]);
|
||||
let mut updater = FirmwareUpdater::new(config, &mut magic.0);
|
||||
button.wait_for_falling_edge().await;
|
||||
let mut offset = 0;
|
||||
let mut magic = AlignedBuffer([0; WRITE_SIZE]);
|
||||
for chunk in APP_B.chunks(2048) {
|
||||
let mut buf: [u8; 2048] = [0; 2048];
|
||||
buf[..chunk.len()].copy_from_slice(chunk);
|
||||
updater.write_firmware(magic.as_mut(), offset, &buf).await.unwrap();
|
||||
updater.write_firmware(offset, &buf).await.unwrap();
|
||||
offset += chunk.len();
|
||||
}
|
||||
updater.mark_updated(magic.as_mut()).await.unwrap();
|
||||
updater.mark_updated().await.unwrap();
|
||||
led.set_low();
|
||||
cortex_m::peripheral::SCB::sys_reset();
|
||||
}
|
||||
|
@ -33,9 +33,9 @@ async fn main(_spawner: Spawner) {
|
||||
led.set_high();
|
||||
|
||||
let config = FirmwareUpdaterConfig::from_linkerfile_blocking(&flash);
|
||||
let mut updater = BlockingFirmwareUpdater::new(config);
|
||||
let mut magic = AlignedBuffer([0; WRITE_SIZE]);
|
||||
let writer = updater.prepare_update(magic.as_mut()).unwrap();
|
||||
let mut updater = BlockingFirmwareUpdater::new(config, &mut magic.0);
|
||||
let writer = updater.prepare_update().unwrap();
|
||||
button.wait_for_rising_edge().await;
|
||||
let mut offset = 0;
|
||||
let mut buf = AlignedBuffer([0; 4096]);
|
||||
@ -44,7 +44,7 @@ async fn main(_spawner: Spawner) {
|
||||
writer.write(offset, buf.as_ref()).unwrap();
|
||||
offset += chunk.len() as u32;
|
||||
}
|
||||
updater.mark_updated(magic.as_mut()).unwrap();
|
||||
updater.mark_updated().unwrap();
|
||||
led.set_low();
|
||||
cortex_m::peripheral::SCB::sys_reset();
|
||||
}
|
||||
|
@ -34,8 +34,8 @@ async fn main(_spawner: Spawner) {
|
||||
|
||||
let config = FirmwareUpdaterConfig::from_linkerfile_blocking(&flash);
|
||||
let mut magic = AlignedBuffer([0; WRITE_SIZE]);
|
||||
let mut updater = BlockingFirmwareUpdater::new(config);
|
||||
let writer = updater.prepare_update(magic.as_mut()).unwrap();
|
||||
let mut updater = BlockingFirmwareUpdater::new(config, &mut magic.0);
|
||||
let writer = updater.prepare_update().unwrap();
|
||||
button.wait_for_rising_edge().await;
|
||||
let mut offset = 0;
|
||||
let mut buf = AlignedBuffer([0; 4096]);
|
||||
@ -44,7 +44,7 @@ async fn main(_spawner: Spawner) {
|
||||
writer.write(offset, buf.as_ref()).unwrap();
|
||||
offset += chunk.len() as u32;
|
||||
}
|
||||
updater.mark_updated(magic.as_mut()).unwrap();
|
||||
updater.mark_updated().unwrap();
|
||||
led.set_low();
|
||||
cortex_m::peripheral::SCB::sys_reset();
|
||||
}
|
||||
|
@ -33,18 +33,18 @@ async fn main(_spawner: Spawner) {
|
||||
led.set_high();
|
||||
|
||||
let config = FirmwareUpdaterConfig::from_linkerfile(&flash);
|
||||
let mut updater = FirmwareUpdater::new(config);
|
||||
let mut magic = AlignedBuffer([0; WRITE_SIZE]);
|
||||
let mut updater = FirmwareUpdater::new(config, &mut magic.0);
|
||||
button.wait_for_falling_edge().await;
|
||||
let mut offset = 0;
|
||||
let mut magic = AlignedBuffer([0; WRITE_SIZE]);
|
||||
for chunk in APP_B.chunks(128) {
|
||||
let mut buf: [u8; 128] = [0; 128];
|
||||
buf[..chunk.len()].copy_from_slice(chunk);
|
||||
updater.write_firmware(magic.as_mut(), offset, &buf).await.unwrap();
|
||||
updater.write_firmware(offset, &buf).await.unwrap();
|
||||
offset += chunk.len();
|
||||
}
|
||||
|
||||
updater.mark_updated(magic.as_mut()).await.unwrap();
|
||||
updater.mark_updated().await.unwrap();
|
||||
led.set_low();
|
||||
Timer::after(Duration::from_secs(1)).await;
|
||||
cortex_m::peripheral::SCB::sys_reset();
|
||||
|
@ -33,18 +33,18 @@ async fn main(_spawner: Spawner) {
|
||||
led.set_high();
|
||||
|
||||
let config = FirmwareUpdaterConfig::from_linkerfile(&flash);
|
||||
let mut updater = FirmwareUpdater::new(config);
|
||||
button.wait_for_falling_edge().await;
|
||||
let mut magic = AlignedBuffer([0; WRITE_SIZE]);
|
||||
let mut updater = FirmwareUpdater::new(config, &mut magic.0);
|
||||
button.wait_for_falling_edge().await;
|
||||
let mut offset = 0;
|
||||
for chunk in APP_B.chunks(128) {
|
||||
let mut buf: [u8; 128] = [0; 128];
|
||||
buf[..chunk.len()].copy_from_slice(chunk);
|
||||
updater.write_firmware(magic.as_mut(), offset, &buf).await.unwrap();
|
||||
updater.write_firmware(offset, &buf).await.unwrap();
|
||||
offset += chunk.len();
|
||||
}
|
||||
|
||||
updater.mark_updated(magic.as_mut()).await.unwrap();
|
||||
updater.mark_updated().await.unwrap();
|
||||
led.set_low();
|
||||
Timer::after(Duration::from_secs(1)).await;
|
||||
cortex_m::peripheral::SCB::sys_reset();
|
||||
|
@ -31,17 +31,17 @@ async fn main(_spawner: Spawner) {
|
||||
led.set_high();
|
||||
|
||||
let config = FirmwareUpdaterConfig::from_linkerfile(&flash);
|
||||
let mut updater = FirmwareUpdater::new(config);
|
||||
button.wait_for_falling_edge().await;
|
||||
let mut magic = AlignedBuffer([0; WRITE_SIZE]);
|
||||
let mut updater = FirmwareUpdater::new(config, &mut magic.0);
|
||||
button.wait_for_falling_edge().await;
|
||||
let mut offset = 0;
|
||||
for chunk in APP_B.chunks(2048) {
|
||||
let mut buf: [u8; 2048] = [0; 2048];
|
||||
buf[..chunk.len()].copy_from_slice(chunk);
|
||||
updater.write_firmware(magic.as_mut(), offset, &buf).await.unwrap();
|
||||
updater.write_firmware(offset, &buf).await.unwrap();
|
||||
offset += chunk.len();
|
||||
}
|
||||
updater.mark_updated(magic.as_mut()).await.unwrap();
|
||||
updater.mark_updated().await.unwrap();
|
||||
led.set_low();
|
||||
cortex_m::peripheral::SCB::sys_reset();
|
||||
}
|
||||
|
@ -31,19 +31,19 @@ async fn main(_spawner: Spawner) {
|
||||
led.set_high();
|
||||
|
||||
let config = FirmwareUpdaterConfig::from_linkerfile(&flash);
|
||||
let mut updater = FirmwareUpdater::new(config);
|
||||
let mut magic = AlignedBuffer([0; WRITE_SIZE]);
|
||||
let mut updater = FirmwareUpdater::new(config, &mut magic.0);
|
||||
button.wait_for_falling_edge().await;
|
||||
//defmt::info!("Starting update");
|
||||
let mut magic = AlignedBuffer([0; WRITE_SIZE]);
|
||||
let mut offset = 0;
|
||||
for chunk in APP_B.chunks(2048) {
|
||||
let mut buf: [u8; 2048] = [0; 2048];
|
||||
buf[..chunk.len()].copy_from_slice(chunk);
|
||||
// defmt::info!("Writing chunk at 0x{:x}", offset);
|
||||
updater.write_firmware(magic.as_mut(), offset, &buf).await.unwrap();
|
||||
updater.write_firmware(offset, &buf).await.unwrap();
|
||||
offset += chunk.len();
|
||||
}
|
||||
updater.mark_updated(magic.as_mut()).await.unwrap();
|
||||
updater.mark_updated().await.unwrap();
|
||||
//defmt::info!("Marked as updated");
|
||||
led.set_low();
|
||||
cortex_m::peripheral::SCB::sys_reset();
|
||||
|
Reference in New Issue
Block a user