aboutsummaryrefslogtreecommitdiff
path: root/examples/boot/bootloader/stm32wb-dfu/src/main.rs
diff options
context:
space:
mode:
authorKaitlyn Kenwell <[email protected]>2023-12-14 09:36:22 -0500
committerKaitlyn Kenwell <[email protected]>2023-12-14 09:36:22 -0500
commite27e00f6280683293f427d0731aa69ca32dbbe60 (patch)
treee238a3ed8fda1b7c89c27864b62d387786e75925 /examples/boot/bootloader/stm32wb-dfu/src/main.rs
parentb60b3f4eb8f22ecda1c30d63213010f1b6b47686 (diff)
Address reviews
Diffstat (limited to 'examples/boot/bootloader/stm32wb-dfu/src/main.rs')
-rw-r--r--examples/boot/bootloader/stm32wb-dfu/src/main.rs94
1 files changed, 94 insertions, 0 deletions
diff --git a/examples/boot/bootloader/stm32wb-dfu/src/main.rs b/examples/boot/bootloader/stm32wb-dfu/src/main.rs
new file mode 100644
index 000000000..a2b884770
--- /dev/null
+++ b/examples/boot/bootloader/stm32wb-dfu/src/main.rs
@@ -0,0 +1,94 @@
1#![no_std]
2#![no_main]
3
4use core::cell::RefCell;
5
6use cortex_m_rt::{entry, exception};
7#[cfg(feature = "defmt")]
8use defmt_rtt as _;
9use embassy_boot_stm32::*;
10use embassy_stm32::flash::{Flash, BANK1_REGION, WRITE_SIZE};
11use embassy_stm32::rcc::WPAN_DEFAULT;
12use embassy_stm32::usb::Driver;
13use embassy_stm32::{bind_interrupts, peripherals, usb};
14use embassy_sync::blocking_mutex::Mutex;
15use embassy_usb::Builder;
16use embassy_usb_dfu::consts::DfuAttributes;
17use embassy_usb_dfu::{usb_dfu, Control};
18
19bind_interrupts!(struct Irqs {
20 USB_LP => usb::InterruptHandler<peripherals::USB>;
21});
22
23#[entry]
24fn main() -> ! {
25 let mut config = embassy_stm32::Config::default();
26 config.rcc = WPAN_DEFAULT;
27 let p = embassy_stm32::init(config);
28
29 // Prevent a hard fault when accessing flash 'too early' after boot.
30 #[cfg(feature = "defmt")]
31 for _ in 0..10000000 {
32 cortex_m::asm::nop();
33 }
34
35
36 let layout = Flash::new_blocking(p.FLASH).into_blocking_regions();
37 let flash = Mutex::new(RefCell::new(layout.bank1_region));
38
39 let config = BootLoaderConfig::from_linkerfile_blocking(&flash);
40 let active_offset = config.active.offset();
41 let bl = BootLoader::prepare::<_, _, _, 2048>(config);
42 if bl.state == State::DfuDetach {
43 let driver = Driver::new(p.USB, Irqs, p.PA12, p.PA11);
44 let mut config = embassy_usb::Config::new(0xc0de, 0xcafe);
45 config.manufacturer = Some("Embassy");
46 config.product = Some("USB-DFU Bootloader example");
47 config.serial_number = Some("1235678");
48
49 let fw_config = FirmwareUpdaterConfig::from_linkerfile_blocking(&flash);
50 let mut buffer = AlignedBuffer([0; WRITE_SIZE]);
51 let updater = BlockingFirmwareUpdater::new(fw_config, &mut buffer.0[..]);
52
53 let mut device_descriptor = [0; 256];
54 let mut config_descriptor = [0; 256];
55 let mut bos_descriptor = [0; 256];
56 let mut control_buf = [0; 4096];
57 let mut state = Control::new(updater, DfuAttributes::CAN_DOWNLOAD);
58 let mut builder = Builder::new(
59 driver,
60 config,
61 &mut device_descriptor,
62 &mut config_descriptor,
63 &mut bos_descriptor,
64 &mut [],
65 &mut control_buf,
66 );
67
68 usb_dfu::<_, _, _, 4096>(&mut builder, &mut state);
69
70 let mut dev = builder.build();
71 embassy_futures::block_on(dev.run());
72 }
73
74 unsafe { bl.load(BANK1_REGION.base + active_offset) }
75}
76
77#[no_mangle]
78#[cfg_attr(target_os = "none", link_section = ".HardFault.user")]
79unsafe extern "C" fn HardFault() {
80 cortex_m::peripheral::SCB::sys_reset();
81}
82
83#[exception]
84unsafe fn DefaultHandler(_: i16) -> ! {
85 const SCB_ICSR: *const u32 = 0xE000_ED04 as *const u32;
86 let irqn = core::ptr::read_volatile(SCB_ICSR) as u8 as i16 - 16;
87
88 panic!("DefaultHandler #{:?}", irqn);
89}
90
91#[panic_handler]
92fn panic(_info: &core::panic::PanicInfo) -> ! {
93 cortex_m::asm::udf();
94}