Skip to content

Commit

Permalink
Merge pull request #3377 from Totto8492/enable-fpu
Browse files Browse the repository at this point in the history
Enable FPU for RP235X Core1
  • Loading branch information
Dirbaio authored Oct 13, 2024
2 parents 0222faa + a4636d8 commit 4eb820a
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 1 deletion.
22 changes: 21 additions & 1 deletion embassy-rp/build.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
use std::env;
use std::ffi::OsStr;
use std::fs::File;
use std::io::Write;
use std::path::PathBuf;
use std::path::{Path, PathBuf};

fn main() {
if env::var("CARGO_FEATURE_RP2040").is_ok() {
Expand All @@ -16,4 +17,23 @@ fn main() {
println!("cargo:rerun-if-changed=build.rs");
println!("cargo:rerun-if-changed=link-rp.x.in");
}

// code below taken from https://github.com/rust-embedded/cortex-m/blob/master/cortex-m-rt/build.rs

let mut target = env::var("TARGET").unwrap();

// When using a custom target JSON, `$TARGET` contains the path to that JSON file. By
// convention, these files are named after the actual target triple, eg.
// `thumbv7m-customos-elf.json`, so we extract the file stem here to allow custom target specs.
let path = Path::new(&target);
if path.extension() == Some(OsStr::new("json")) {
target = path
.file_stem()
.map_or(target.clone(), |stem| stem.to_str().unwrap().to_string());
}

println!("cargo::rustc-check-cfg=cfg(has_fpu)");
if target.ends_with("-eabihf") {
println!("cargo:rustc-cfg=has_fpu");
}
}
7 changes: 7 additions & 0 deletions embassy-rp/src/multicore.rs
Original file line number Diff line number Diff line change
Expand Up @@ -169,6 +169,13 @@ where
interrupt::SIO_IRQ_FIFO.enable()
};

// Enable FPU
#[cfg(all(feature = "_rp235x", has_fpu))]
unsafe {
let p = cortex_m::Peripherals::steal();
p.SCB.cpacr.modify(|cpacr| cpacr | (3 << 20) | (3 << 22));
}

entry()
}

Expand Down

0 comments on commit 4eb820a

Please sign in to comment.