diff options
author | 2017-06-30 17:25:51 -0500 | |
---|---|---|
committer | 2017-06-30 17:25:51 -0500 | |
commit | 39875a3f538f64134bfe3b1619316bee4b3f39f3 (patch) | |
tree | 3848e53d431402cdd42c3224f1d1eba958bcda5a | |
parent | c9604220201f7c85f6b6fa07a3698552d2e3a281 (diff) | |
download | cortex-m-39875a3f538f64134bfe3b1619316bee4b3f39f3.tar.gz cortex-m-39875a3f538f64134bfe3b1619316bee4b3f39f3.tar.zst cortex-m-39875a3f538f64134bfe3b1619316bee4b3f39f3.zip |
expose an opaque FPU register block on targets without an FPU
this is mainly to avoid adding custom cfg logic to svd2rust generated crates
where all the core peripherals are re-exported. (I'd rather not have to teach
svd2rust how to generate a build script)
-rw-r--r-- | src/peripheral/mod.rs | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/src/peripheral/mod.rs b/src/peripheral/mod.rs index b9a3e0a..f297ab8 100644 --- a/src/peripheral/mod.rs +++ b/src/peripheral/mod.rs @@ -28,7 +28,6 @@ pub const DWT: Peripheral<DWT> = unsafe { Peripheral::new(0xE000_1000) }; pub const FPB: Peripheral<FPB> = unsafe { Peripheral::new(0xE000_2000) }; /// Floating Point Unit -#[cfg(any(has_fpu, test))] pub const FPU: Peripheral<FPU> = unsafe { Peripheral::new(0xE000_EF30) }; /// Instrumentation Trace Macrocell @@ -239,17 +238,20 @@ pub struct FPB { } /// FPU register block -#[cfg(any(has_fpu, test))] #[repr(C)] pub struct FPU { reserved: u32, /// Floating Point Context Control + #[cfg(any(has_fpu, test))] pub fpccr: RW<u32>, /// Floating Point Context Address + #[cfg(any(has_fpu, test))] pub fpcar: RW<u32>, /// Floating Point Default Status Control + #[cfg(any(has_fpu, test))] pub fpdscr: RW<u32>, /// Media and FP Feature + #[cfg(any(has_fpu, test))] pub mvfr: [RO<u32>; 3], } |