aboutsummaryrefslogtreecommitdiff
path: root/examples/boot/application
diff options
context:
space:
mode:
authorRasmus Melchior Jacobsen <[email protected]>2023-05-30 14:03:31 +0200
committerRasmus Melchior Jacobsen <[email protected]>2023-05-30 14:03:31 +0200
commit36e00caf4dc70905b735531c0d5634addd026954 (patch)
tree01d3bbb3b7f1ab522f9a1fc651f48197ce355927 /examples/boot/application
parentc2aca45b8d3785007da20ce007d6a6e352fac1a0 (diff)
Align examples
Diffstat (limited to 'examples/boot/application')
-rw-r--r--examples/boot/application/nrf/src/bin/a.rs12
-rw-r--r--examples/boot/application/rp/Cargo.toml1
-rw-r--r--examples/boot/application/rp/src/bin/a.rs19
-rw-r--r--examples/boot/application/stm32f3/src/bin/a.rs12
-rw-r--r--examples/boot/application/stm32f7/src/bin/a.rs14
-rw-r--r--examples/boot/application/stm32h7/src/bin/a.rs15
-rw-r--r--examples/boot/application/stm32l1/src/bin/a.rs11
-rw-r--r--examples/boot/application/stm32l4/src/bin/a.rs9
-rw-r--r--examples/boot/application/stm32wl/src/bin/a.rs9
9 files changed, 59 insertions, 43 deletions
diff --git a/examples/boot/application/nrf/src/bin/a.rs b/examples/boot/application/nrf/src/bin/a.rs
index 090a05b23..06c237781 100644
--- a/examples/boot/application/nrf/src/bin/a.rs
+++ b/examples/boot/application/nrf/src/bin/a.rs
@@ -3,12 +3,13 @@
3#![macro_use] 3#![macro_use]
4#![feature(type_alias_impl_trait)] 4#![feature(type_alias_impl_trait)]
5 5
6use embassy_boot_nrf::FirmwareUpdater; 6use embassy_boot_nrf::{FirmwareUpdater, FirmwareUpdaterConfig};
7use embassy_embedded_hal::adapter::BlockingAsync; 7use embassy_embedded_hal::adapter::BlockingAsync;
8use embassy_executor::Spawner; 8use embassy_executor::Spawner;
9use embassy_nrf::gpio::{Input, Level, Output, OutputDrive, Pull}; 9use embassy_nrf::gpio::{Input, Level, Output, OutputDrive, Pull};
10use embassy_nrf::nvmc::Nvmc; 10use embassy_nrf::nvmc::Nvmc;
11use embassy_nrf::wdt::{self, Watchdog}; 11use embassy_nrf::wdt::{self, Watchdog};
12use embassy_sync::mutex::Mutex;
12use panic_reset as _; 13use panic_reset as _;
13 14
14static APP_B: &[u8] = include_bytes!("../../b.bin"); 15static APP_B: &[u8] = include_bytes!("../../b.bin");
@@ -45,9 +46,10 @@ async fn main(_spawner: Spawner) {
45 }; 46 };
46 47
47 let nvmc = Nvmc::new(p.NVMC); 48 let nvmc = Nvmc::new(p.NVMC);
48 let mut nvmc = BlockingAsync::new(nvmc); 49 let nvmc = Mutex::new(BlockingAsync::new(nvmc));
49 50
50 let mut updater = FirmwareUpdater::default(); 51 let config = FirmwareUpdaterConfig::from_linkerfile(&nvmc);
52 let mut updater = FirmwareUpdater::new(config);
51 loop { 53 loop {
52 led.set_low(); 54 led.set_low();
53 button.wait_for_any_edge().await; 55 button.wait_for_any_edge().await;
@@ -56,11 +58,11 @@ async fn main(_spawner: Spawner) {
56 for chunk in APP_B.chunks(4096) { 58 for chunk in APP_B.chunks(4096) {
57 let mut buf: [u8; 4096] = [0; 4096]; 59 let mut buf: [u8; 4096] = [0; 4096];
58 buf[..chunk.len()].copy_from_slice(chunk); 60 buf[..chunk.len()].copy_from_slice(chunk);
59 updater.write_firmware(offset, &buf, &mut nvmc, 4096).await.unwrap(); 61 updater.write_firmware(offset, &buf).await.unwrap();
60 offset += chunk.len(); 62 offset += chunk.len();
61 } 63 }
62 let mut magic = [0; 4]; 64 let mut magic = [0; 4];
63 updater.mark_updated(&mut nvmc, &mut magic).await.unwrap(); 65 updater.mark_updated(&mut magic).await.unwrap();
64 led.set_high(); 66 led.set_high();
65 cortex_m::peripheral::SCB::sys_reset(); 67 cortex_m::peripheral::SCB::sys_reset();
66 } 68 }
diff --git a/examples/boot/application/rp/Cargo.toml b/examples/boot/application/rp/Cargo.toml
index 64c2b8925..4a2c5dd8f 100644
--- a/examples/boot/application/rp/Cargo.toml
+++ b/examples/boot/application/rp/Cargo.toml
@@ -20,6 +20,7 @@ embedded-hal = { version = "0.2.6" }
20 20
21cortex-m = { version = "0.7.6", features = ["inline-asm", "critical-section-single-core"] } 21cortex-m = { version = "0.7.6", features = ["inline-asm", "critical-section-single-core"] }
22cortex-m-rt = "0.7.0" 22cortex-m-rt = "0.7.0"
23embedded-storage = "0.3.0"
23 24
24[features] 25[features]
25default = ["panic-reset"] 26default = ["panic-reset"]
diff --git a/examples/boot/application/rp/src/bin/a.rs b/examples/boot/application/rp/src/bin/a.rs
index 47f1d16d8..3fa908b63 100644
--- a/examples/boot/application/rp/src/bin/a.rs
+++ b/examples/boot/application/rp/src/bin/a.rs
@@ -9,6 +9,9 @@ use embassy_rp::flash::Flash;
9use embassy_rp::gpio::{Level, Output}; 9use embassy_rp::gpio::{Level, Output};
10use embassy_rp::watchdog::Watchdog; 10use embassy_rp::watchdog::Watchdog;
11use embassy_time::{Duration, Timer}; 11use embassy_time::{Duration, Timer};
12use embassy_sync::blocking_mutex::Mutex;
13use core::cell::RefCell;
14use embedded_storage::nor_flash::NorFlash;
12#[cfg(feature = "panic-probe")] 15#[cfg(feature = "panic-probe")]
13use panic_probe as _; 16use panic_probe as _;
14#[cfg(feature = "panic-reset")] 17#[cfg(feature = "panic-reset")]
@@ -26,9 +29,11 @@ async fn main(_s: Spawner) {
26 let mut watchdog = Watchdog::new(p.WATCHDOG); 29 let mut watchdog = Watchdog::new(p.WATCHDOG);
27 watchdog.start(Duration::from_secs(8)); 30 watchdog.start(Duration::from_secs(8));
28 31
29 let mut flash: Flash<_, FLASH_SIZE> = Flash::new_blocking(p.FLASH); 32 let flash: Flash<_, FLASH_SIZE> = Flash::new(p.FLASH);
33 let flash = Mutex::new(RefCell::new(flash));
30 34
31 let mut updater = FirmwareUpdater::default(); 35 let config = FirmwareUpdaterConfig::from_linkerfile_blocking(&flash);
36 let mut updater = BlockingFirmwareUpdater::new(config);
32 37
33 Timer::after(Duration::from_secs(5)).await; 38 Timer::after(Duration::from_secs(5)).await;
34 watchdog.feed(); 39 watchdog.feed();
@@ -36,8 +41,8 @@ async fn main(_s: Spawner) {
36 let mut offset = 0; 41 let mut offset = 0;
37 let mut buf: AlignedBuffer<4096> = AlignedBuffer([0; 4096]); 42 let mut buf: AlignedBuffer<4096> = AlignedBuffer([0; 4096]);
38 defmt::info!("preparing update"); 43 defmt::info!("preparing update");
39 let mut writer = updater 44 let writer = updater
40 .prepare_update_blocking(&mut flash) 45 .prepare_update()
41 .map_err(|e| defmt::warn!("E: {:?}", defmt::Debug2Format(&e))) 46 .map_err(|e| defmt::warn!("E: {:?}", defmt::Debug2Format(&e)))
42 .unwrap(); 47 .unwrap();
43 defmt::info!("writer created, starting write"); 48 defmt::info!("writer created, starting write");
@@ -45,13 +50,13 @@ async fn main(_s: Spawner) {
45 buf.0[..chunk.len()].copy_from_slice(chunk); 50 buf.0[..chunk.len()].copy_from_slice(chunk);
46 defmt::info!("writing block at offset {}", offset); 51 defmt::info!("writing block at offset {}", offset);
47 writer 52 writer
48 .write_block_blocking(offset, &buf.0[..], &mut flash, 256) 53 .write(offset, &buf.0[..])
49 .unwrap(); 54 .unwrap();
50 offset += chunk.len(); 55 offset += chunk.len() as u32;
51 } 56 }
52 watchdog.feed(); 57 watchdog.feed();
53 defmt::info!("firmware written, marking update"); 58 defmt::info!("firmware written, marking update");
54 updater.mark_updated_blocking(&mut flash, &mut buf.0[..1]).unwrap(); 59 updater.mark_updated(&mut buf.0[..1]).unwrap();
55 Timer::after(Duration::from_secs(2)).await; 60 Timer::after(Duration::from_secs(2)).await;
56 led.set_low(); 61 led.set_low();
57 defmt::info!("update marked, resetting"); 62 defmt::info!("update marked, resetting");
diff --git a/examples/boot/application/stm32f3/src/bin/a.rs b/examples/boot/application/stm32f3/src/bin/a.rs
index 5db1dbb57..6a5c276fd 100644
--- a/examples/boot/application/stm32f3/src/bin/a.rs
+++ b/examples/boot/application/stm32f3/src/bin/a.rs
@@ -4,7 +4,8 @@
4 4
5#[cfg(feature = "defmt-rtt")] 5#[cfg(feature = "defmt-rtt")]
6use defmt_rtt::*; 6use defmt_rtt::*;
7use embassy_boot_stm32::{AlignedBuffer, FirmwareUpdater}; 7use embassy_boot_stm32::{AlignedBuffer, FirmwareUpdater, FirmwareUpdaterConfig};
8use embassy_sync::mutex::Mutex;
8use embassy_embedded_hal::adapter::BlockingAsync; 9use embassy_embedded_hal::adapter::BlockingAsync;
9use embassy_executor::Spawner; 10use embassy_executor::Spawner;
10use embassy_stm32::exti::ExtiInput; 11use embassy_stm32::exti::ExtiInput;
@@ -18,7 +19,7 @@ static APP_B: &[u8] = include_bytes!("../../b.bin");
18async fn main(_spawner: Spawner) { 19async fn main(_spawner: Spawner) {
19 let p = embassy_stm32::init(Default::default()); 20 let p = embassy_stm32::init(Default::default());
20 let flash = Flash::new_blocking(p.FLASH); 21 let flash = Flash::new_blocking(p.FLASH);
21 let mut flash = BlockingAsync::new(flash); 22 let flash = Mutex::new(BlockingAsync::new(flash));
22 23
23 let button = Input::new(p.PC13, Pull::Up); 24 let button = Input::new(p.PC13, Pull::Up);
24 let mut button = ExtiInput::new(button, p.EXTI13); 25 let mut button = ExtiInput::new(button, p.EXTI13);
@@ -26,17 +27,18 @@ async fn main(_spawner: Spawner) {
26 let mut led = Output::new(p.PA5, Level::Low, Speed::Low); 27 let mut led = Output::new(p.PA5, Level::Low, Speed::Low);
27 led.set_high(); 28 led.set_high();
28 29
29 let mut updater = FirmwareUpdater::default(); 30 let config = FirmwareUpdaterConfig::from_linkerfile(&flash);
31 let mut updater = FirmwareUpdater::new(config);
30 button.wait_for_falling_edge().await; 32 button.wait_for_falling_edge().await;
31 let mut offset = 0; 33 let mut offset = 0;
32 for chunk in APP_B.chunks(2048) { 34 for chunk in APP_B.chunks(2048) {
33 let mut buf: [u8; 2048] = [0; 2048]; 35 let mut buf: [u8; 2048] = [0; 2048];
34 buf[..chunk.len()].copy_from_slice(chunk); 36 buf[..chunk.len()].copy_from_slice(chunk);
35 updater.write_firmware(offset, &buf, &mut flash, 2048).await.unwrap(); 37 updater.write_firmware(offset, &buf).await.unwrap();
36 offset += chunk.len(); 38 offset += chunk.len();
37 } 39 }
38 let mut magic = AlignedBuffer([0; WRITE_SIZE]); 40 let mut magic = AlignedBuffer([0; WRITE_SIZE]);
39 updater.mark_updated(&mut flash, magic.as_mut()).await.unwrap(); 41 updater.mark_updated(magic.as_mut()).await.unwrap();
40 led.set_low(); 42 led.set_low();
41 cortex_m::peripheral::SCB::sys_reset(); 43 cortex_m::peripheral::SCB::sys_reset();
42} 44}
diff --git a/examples/boot/application/stm32f7/src/bin/a.rs b/examples/boot/application/stm32f7/src/bin/a.rs
index 5d586445c..530683cac 100644
--- a/examples/boot/application/stm32f7/src/bin/a.rs
+++ b/examples/boot/application/stm32f7/src/bin/a.rs
@@ -4,7 +4,7 @@
4 4
5#[cfg(feature = "defmt-rtt")] 5#[cfg(feature = "defmt-rtt")]
6use defmt_rtt::*; 6use defmt_rtt::*;
7use embassy_boot_stm32::{AlignedBuffer, FirmwareUpdater}; 7use embassy_boot_stm32::{AlignedBuffer, BlockingFirmwareUpdater, FirmwareUpdaterConfig};
8use embassy_executor::Spawner; 8use embassy_executor::Spawner;
9use embassy_stm32::exti::ExtiInput; 9use embassy_stm32::exti::ExtiInput;
10use embassy_stm32::flash::{Flash, WRITE_SIZE}; 10use embassy_stm32::flash::{Flash, WRITE_SIZE};
@@ -16,7 +16,8 @@ static APP_B: &[u8] = include_bytes!("../../b.bin");
16#[embassy_executor::main] 16#[embassy_executor::main]
17async fn main(_spawner: Spawner) { 17async fn main(_spawner: Spawner) {
18 let p = embassy_stm32::init(Default::default()); 18 let p = embassy_stm32::init(Default::default());
19 let mut flash = Flash::new_blocking(p.FLASH); 19 let flash = Flash::new_blocking(p.FLASH);
20 let flash = Mutex::new(RefCell::new(flash));
20 21
21 let button = Input::new(p.PC13, Pull::Down); 22 let button = Input::new(p.PC13, Pull::Down);
22 let mut button = ExtiInput::new(button, p.EXTI13); 23 let mut button = ExtiInput::new(button, p.EXTI13);
@@ -24,20 +25,21 @@ async fn main(_spawner: Spawner) {
24 let mut led = Output::new(p.PB7, Level::Low, Speed::Low); 25 let mut led = Output::new(p.PB7, Level::Low, Speed::Low);
25 led.set_high(); 26 led.set_high();
26 27
27 let mut updater = FirmwareUpdater::default(); 28 let config = FirmwareUpdaterConfig::from_linkerfile_blocking(&flash);
28 let mut writer = updater.prepare_update_blocking(&mut flash).unwrap(); 29 let mut updater = BlockingFirmwareUpdater::new(config);
30 let mut writer = updater.prepare_update().unwrap();
29 button.wait_for_rising_edge().await; 31 button.wait_for_rising_edge().await;
30 let mut offset = 0; 32 let mut offset = 0;
31 let mut buf = AlignedBuffer([0; 4096]); 33 let mut buf = AlignedBuffer([0; 4096]);
32 for chunk in APP_B.chunks(4096) { 34 for chunk in APP_B.chunks(4096) {
33 buf.as_mut()[..chunk.len()].copy_from_slice(chunk); 35 buf.as_mut()[..chunk.len()].copy_from_slice(chunk);
34 writer 36 writer
35 .write_block_blocking(offset, buf.as_ref(), &mut flash, chunk.len()) 37 .write(offset, buf.as_ref())
36 .unwrap(); 38 .unwrap();
37 offset += chunk.len(); 39 offset += chunk.len();
38 } 40 }
39 let mut magic = AlignedBuffer([0; WRITE_SIZE]); 41 let mut magic = AlignedBuffer([0; WRITE_SIZE]);
40 updater.mark_updated_blocking(&mut flash, magic.as_mut()).unwrap(); 42 updater.mark_updated(magic.as_mut()).unwrap();
41 led.set_low(); 43 led.set_low();
42 cortex_m::peripheral::SCB::sys_reset(); 44 cortex_m::peripheral::SCB::sys_reset();
43} 45}
diff --git a/examples/boot/application/stm32h7/src/bin/a.rs b/examples/boot/application/stm32h7/src/bin/a.rs
index 202220223..e5f94310c 100644
--- a/examples/boot/application/stm32h7/src/bin/a.rs
+++ b/examples/boot/application/stm32h7/src/bin/a.rs
@@ -4,7 +4,7 @@
4 4
5#[cfg(feature = "defmt-rtt")] 5#[cfg(feature = "defmt-rtt")]
6use defmt_rtt::*; 6use defmt_rtt::*;
7use embassy_boot_stm32::{AlignedBuffer, FirmwareUpdater}; 7use embassy_boot_stm32::{AlignedBuffer, BlockingFirmwareUpdater, FirmwareUpdaterConfig};
8use embassy_executor::Spawner; 8use embassy_executor::Spawner;
9use embassy_stm32::exti::ExtiInput; 9use embassy_stm32::exti::ExtiInput;
10use embassy_stm32::flash::{Flash, WRITE_SIZE}; 10use embassy_stm32::flash::{Flash, WRITE_SIZE};
@@ -16,7 +16,8 @@ static APP_B: &[u8] = include_bytes!("../../b.bin");
16#[embassy_executor::main] 16#[embassy_executor::main]
17async fn main(_spawner: Spawner) { 17async fn main(_spawner: Spawner) {
18 let p = embassy_stm32::init(Default::default()); 18 let p = embassy_stm32::init(Default::default());
19 let mut flash = Flash::new_blocking(p.FLASH); 19 let flash = Flash::new_blocking(p.FLASH);
20 let flash = Mutex::new(RefCell::new(flash));
20 21
21 let button = Input::new(p.PC13, Pull::Down); 22 let button = Input::new(p.PC13, Pull::Down);
22 let mut button = ExtiInput::new(button, p.EXTI13); 23 let mut button = ExtiInput::new(button, p.EXTI13);
@@ -24,21 +25,21 @@ async fn main(_spawner: Spawner) {
24 let mut led = Output::new(p.PB14, Level::Low, Speed::Low); 25 let mut led = Output::new(p.PB14, Level::Low, Speed::Low);
25 led.set_high(); 26 led.set_high();
26 27
27 let mut updater = FirmwareUpdater::default(); 28 let config = FirmwareUpdaterConfig::from_linkerfile_blocking(&flash);
28 29 let mut updater = BlockingFirmwareUpdater::new(config);
29 let mut writer = updater.prepare_update_blocking(&mut flash).unwrap(); 30 let mut writer = updater.prepare_update().unwrap();
30 button.wait_for_rising_edge().await; 31 button.wait_for_rising_edge().await;
31 let mut offset = 0; 32 let mut offset = 0;
32 let mut buf = AlignedBuffer([0; 4096]); 33 let mut buf = AlignedBuffer([0; 4096]);
33 for chunk in APP_B.chunks(4096) { 34 for chunk in APP_B.chunks(4096) {
34 buf.as_mut()[..chunk.len()].copy_from_slice(chunk); 35 buf.as_mut()[..chunk.len()].copy_from_slice(chunk);
35 writer 36 writer
36 .write_block_blocking(offset, buf.as_ref(), &mut flash, 4096) 37 .write(offset, buf.as_ref())
37 .unwrap(); 38 .unwrap();
38 offset += chunk.len(); 39 offset += chunk.len();
39 } 40 }
40 let mut magic = AlignedBuffer([0; WRITE_SIZE]); 41 let mut magic = AlignedBuffer([0; WRITE_SIZE]);
41 updater.mark_updated_blocking(&mut flash, magic.as_mut()).unwrap(); 42 updater.mark_updated(magic.as_mut()).unwrap();
42 led.set_low(); 43 led.set_low();
43 cortex_m::peripheral::SCB::sys_reset(); 44 cortex_m::peripheral::SCB::sys_reset();
44} 45}
diff --git a/examples/boot/application/stm32l1/src/bin/a.rs b/examples/boot/application/stm32l1/src/bin/a.rs
index 4033ac590..00ddda636 100644
--- a/examples/boot/application/stm32l1/src/bin/a.rs
+++ b/examples/boot/application/stm32l1/src/bin/a.rs
@@ -4,7 +4,7 @@
4 4
5#[cfg(feature = "defmt-rtt")] 5#[cfg(feature = "defmt-rtt")]
6use defmt_rtt::*; 6use defmt_rtt::*;
7use embassy_boot_stm32::{AlignedBuffer, FirmwareUpdater}; 7use embassy_boot_stm32::{AlignedBuffer, FirmwareUpdater, FirmwareUpdaterConfig};
8use embassy_embedded_hal::adapter::BlockingAsync; 8use embassy_embedded_hal::adapter::BlockingAsync;
9use embassy_executor::Spawner; 9use embassy_executor::Spawner;
10use embassy_stm32::exti::ExtiInput; 10use embassy_stm32::exti::ExtiInput;
@@ -19,7 +19,7 @@ static APP_B: &[u8] = include_bytes!("../../b.bin");
19async fn main(_spawner: Spawner) { 19async fn main(_spawner: Spawner) {
20 let p = embassy_stm32::init(Default::default()); 20 let p = embassy_stm32::init(Default::default());
21 let flash = Flash::new_blocking(p.FLASH); 21 let flash = Flash::new_blocking(p.FLASH);
22 let mut flash = BlockingAsync::new(flash); 22 let flash = Mutex::new(BlockingAsync::new(flash));
23 23
24 let button = Input::new(p.PB2, Pull::Up); 24 let button = Input::new(p.PB2, Pull::Up);
25 let mut button = ExtiInput::new(button, p.EXTI2); 25 let mut button = ExtiInput::new(button, p.EXTI2);
@@ -28,18 +28,19 @@ async fn main(_spawner: Spawner) {
28 28
29 led.set_high(); 29 led.set_high();
30 30
31 let mut updater = FirmwareUpdater::default(); 31 let config = FirmwareUpdaterConfig::from_linkerfile(&flash);
32 let mut updater = FirmwareUpdater::new(config);
32 button.wait_for_falling_edge().await; 33 button.wait_for_falling_edge().await;
33 let mut offset = 0; 34 let mut offset = 0;
34 for chunk in APP_B.chunks(128) { 35 for chunk in APP_B.chunks(128) {
35 let mut buf: [u8; 128] = [0; 128]; 36 let mut buf: [u8; 128] = [0; 128];
36 buf[..chunk.len()].copy_from_slice(chunk); 37 buf[..chunk.len()].copy_from_slice(chunk);
37 updater.write_firmware(offset, &buf, &mut flash, 128).await.unwrap(); 38 updater.write_firmware(offset, &buf).await.unwrap();
38 offset += chunk.len(); 39 offset += chunk.len();
39 } 40 }
40 41
41 let mut magic = AlignedBuffer([0; WRITE_SIZE]); 42 let mut magic = AlignedBuffer([0; WRITE_SIZE]);
42 updater.mark_updated(&mut flash, magic.as_mut()).await.unwrap(); 43 updater.mark_updated(magic.as_mut()).await.unwrap();
43 led.set_low(); 44 led.set_low();
44 Timer::after(Duration::from_secs(1)).await; 45 Timer::after(Duration::from_secs(1)).await;
45 cortex_m::peripheral::SCB::sys_reset(); 46 cortex_m::peripheral::SCB::sys_reset();
diff --git a/examples/boot/application/stm32l4/src/bin/a.rs b/examples/boot/application/stm32l4/src/bin/a.rs
index 141d82afd..54579e4ac 100644
--- a/examples/boot/application/stm32l4/src/bin/a.rs
+++ b/examples/boot/application/stm32l4/src/bin/a.rs
@@ -4,7 +4,7 @@
4 4
5#[cfg(feature = "defmt-rtt")] 5#[cfg(feature = "defmt-rtt")]
6use defmt_rtt::*; 6use defmt_rtt::*;
7use embassy_boot_stm32::{AlignedBuffer, FirmwareUpdater}; 7use embassy_boot_stm32::{AlignedBuffer, FirmwareUpdater, FirmwareUpdaterConfig};
8use embassy_embedded_hal::adapter::BlockingAsync; 8use embassy_embedded_hal::adapter::BlockingAsync;
9use embassy_executor::Spawner; 9use embassy_executor::Spawner;
10use embassy_stm32::exti::ExtiInput; 10use embassy_stm32::exti::ExtiInput;
@@ -18,7 +18,7 @@ static APP_B: &[u8] = include_bytes!("../../b.bin");
18async fn main(_spawner: Spawner) { 18async fn main(_spawner: Spawner) {
19 let p = embassy_stm32::init(Default::default()); 19 let p = embassy_stm32::init(Default::default());
20 let flash = Flash::new_blocking(p.FLASH); 20 let flash = Flash::new_blocking(p.FLASH);
21 let mut flash = BlockingAsync::new(flash); 21 let flash = Mutex::new(BlockingAsync::new(flash));
22 22
23 let button = Input::new(p.PC13, Pull::Up); 23 let button = Input::new(p.PC13, Pull::Up);
24 let mut button = ExtiInput::new(button, p.EXTI13); 24 let mut button = ExtiInput::new(button, p.EXTI13);
@@ -26,13 +26,14 @@ async fn main(_spawner: Spawner) {
26 let mut led = Output::new(p.PB14, Level::Low, Speed::Low); 26 let mut led = Output::new(p.PB14, Level::Low, Speed::Low);
27 led.set_high(); 27 led.set_high();
28 28
29 let mut updater = FirmwareUpdater::default(); 29 let config = FirmwareUpdaterConfig::from_linkerfile(&flash);
30 let mut updater = FirmwareUpdater::new(config);
30 button.wait_for_falling_edge().await; 31 button.wait_for_falling_edge().await;
31 let mut offset = 0; 32 let mut offset = 0;
32 for chunk in APP_B.chunks(2048) { 33 for chunk in APP_B.chunks(2048) {
33 let mut buf: [u8; 2048] = [0; 2048]; 34 let mut buf: [u8; 2048] = [0; 2048];
34 buf[..chunk.len()].copy_from_slice(chunk); 35 buf[..chunk.len()].copy_from_slice(chunk);
35 updater.write_firmware(offset, &buf, &mut flash, 2048).await.unwrap(); 36 updater.write_firmware(offset, &buf).await.unwrap();
36 offset += chunk.len(); 37 offset += chunk.len();
37 } 38 }
38 let mut magic = AlignedBuffer([0; WRITE_SIZE]); 39 let mut magic = AlignedBuffer([0; WRITE_SIZE]);
diff --git a/examples/boot/application/stm32wl/src/bin/a.rs b/examples/boot/application/stm32wl/src/bin/a.rs
index 5f48dbe51..0c6fa05f9 100644
--- a/examples/boot/application/stm32wl/src/bin/a.rs
+++ b/examples/boot/application/stm32wl/src/bin/a.rs
@@ -18,7 +18,7 @@ static APP_B: &[u8] = include_bytes!("../../b.bin");
18async fn main(_spawner: Spawner) { 18async fn main(_spawner: Spawner) {
19 let p = embassy_stm32::init(Default::default()); 19 let p = embassy_stm32::init(Default::default());
20 let flash = Flash::new_blocking(p.FLASH); 20 let flash = Flash::new_blocking(p.FLASH);
21 let mut flash = BlockingAsync::new(flash); 21 let mut flash = Mutex::new(BlockingAsync::new(flash));
22 22
23 let button = Input::new(p.PA0, Pull::Up); 23 let button = Input::new(p.PA0, Pull::Up);
24 let mut button = ExtiInput::new(button, p.EXTI0); 24 let mut button = ExtiInput::new(button, p.EXTI0);
@@ -26,7 +26,8 @@ async fn main(_spawner: Spawner) {
26 let mut led = Output::new(p.PB9, Level::Low, Speed::Low); 26 let mut led = Output::new(p.PB9, Level::Low, Speed::Low);
27 led.set_high(); 27 led.set_high();
28 28
29 let mut updater = FirmwareUpdater::default(); 29 let config = FirmwareUpdaterConfig::from_linkerfile(&flash);
30 let mut updater = FirmwareUpdater::new(config);
30 button.wait_for_falling_edge().await; 31 button.wait_for_falling_edge().await;
31 //defmt::info!("Starting update"); 32 //defmt::info!("Starting update");
32 let mut offset = 0; 33 let mut offset = 0;
@@ -34,11 +35,11 @@ async fn main(_spawner: Spawner) {
34 let mut buf: [u8; 2048] = [0; 2048]; 35 let mut buf: [u8; 2048] = [0; 2048];
35 buf[..chunk.len()].copy_from_slice(chunk); 36 buf[..chunk.len()].copy_from_slice(chunk);
36 // defmt::info!("Writing chunk at 0x{:x}", offset); 37 // defmt::info!("Writing chunk at 0x{:x}", offset);
37 updater.write_firmware(offset, &buf, &mut flash, 2048).await.unwrap(); 38 updater.write_firmware(offset, &buf).await.unwrap();
38 offset += chunk.len(); 39 offset += chunk.len();
39 } 40 }
40 let mut magic = AlignedBuffer([0; WRITE_SIZE]); 41 let mut magic = AlignedBuffer([0; WRITE_SIZE]);
41 updater.mark_updated(&mut flash, magic.as_mut()).await.unwrap(); 42 updater.mark_updated(magic.as_mut()).await.unwrap();
42 //defmt::info!("Marked as updated"); 43 //defmt::info!("Marked as updated");
43 led.set_low(); 44 led.set_low();
44 cortex_m::peripheral::SCB::sys_reset(); 45 cortex_m::peripheral::SCB::sys_reset();