aboutsummaryrefslogtreecommitdiff
path: root/embassy-boot
diff options
context:
space:
mode:
authorDario Nieuwenhuis <[email protected]>2022-05-31 23:52:27 +0200
committerDario Nieuwenhuis <[email protected]>2022-05-31 23:52:27 +0200
commitd13d893ff2e7190ac8f9c2187e487a7abe45b43a (patch)
treed850d9ce23508ad81f30ad65083286b402dfeced /embassy-boot
parent962fabe5c9aa98ce073b362cf417e4ef3572861f (diff)
boot/stm32: autodetect thumbv6, remove cargo feature.
Diffstat (limited to 'embassy-boot')
-rw-r--r--embassy-boot/stm32/Cargo.toml1
-rw-r--r--embassy-boot/stm32/build.rs5
-rw-r--r--embassy-boot/stm32/src/lib.rs2
3 files changed, 6 insertions, 2 deletions
diff --git a/embassy-boot/stm32/Cargo.toml b/embassy-boot/stm32/Cargo.toml
index 78339b0a2..a31717ff3 100644
--- a/embassy-boot/stm32/Cargo.toml
+++ b/embassy-boot/stm32/Cargo.toml
@@ -27,7 +27,6 @@ defmt = [
27 "embassy-stm32/defmt", 27 "embassy-stm32/defmt",
28] 28]
29debug = ["defmt-rtt"] 29debug = ["defmt-rtt"]
30thumbv6 = []
31 30
32[profile.dev] 31[profile.dev]
33debug = 2 32debug = 2
diff --git a/embassy-boot/stm32/build.rs b/embassy-boot/stm32/build.rs
index fd605991f..3997702f6 100644
--- a/embassy-boot/stm32/build.rs
+++ b/embassy-boot/stm32/build.rs
@@ -24,4 +24,9 @@ fn main() {
24 if env::var("CARGO_FEATURE_DEFMT").is_ok() { 24 if env::var("CARGO_FEATURE_DEFMT").is_ok() {
25 println!("cargo:rustc-link-arg-bins=-Tdefmt.x"); 25 println!("cargo:rustc-link-arg-bins=-Tdefmt.x");
26 } 26 }
27
28 let target = env::var("TARGET").unwrap();
29 if target.starts_with("thumbv6m-") {
30 println!("cargo:rustc-cfg=armv6m");
31 }
27} 32}
diff --git a/embassy-boot/stm32/src/lib.rs b/embassy-boot/stm32/src/lib.rs
index 48512534b..8c6e65507 100644
--- a/embassy-boot/stm32/src/lib.rs
+++ b/embassy-boot/stm32/src/lib.rs
@@ -76,7 +76,7 @@ impl<const PAGE_SIZE: usize> BootLoader<PAGE_SIZE> {
76 trace!("Loading app at 0x{:x}", start); 76 trace!("Loading app at 0x{:x}", start);
77 #[allow(unused_mut)] 77 #[allow(unused_mut)]
78 let mut p = cortex_m::Peripherals::steal(); 78 let mut p = cortex_m::Peripherals::steal();
79 #[cfg(not(feature = "thumbv6"))] 79 #[cfg(not(armv6m))]
80 p.SCB.invalidate_icache(); 80 p.SCB.invalidate_icache();
81 p.SCB.vtor.write(start as u32); 81 p.SCB.vtor.write(start as u32);
82 82