Avoid dead_code warning if critical-section-impl is not enabled

Also make Spinlock31 public if it's not used by the critical section impl
This commit is contained in:
Jan Niehusmann 2022-11-12 14:16:56 +00:00
parent 0ecf27450a
commit c1988432c8
3 changed files with 6 additions and 4 deletions

View file

@ -1,9 +1,7 @@
use core::sync::atomic::{AtomicU8, Ordering}; use core::sync::atomic::{AtomicU8, Ordering};
struct RpSpinlockCs; struct RpSpinlockCs;
#[cfg(feature = "critical-section-impl")]
critical_section_0_2::custom_impl!(RpSpinlockCs); critical_section_0_2::custom_impl!(RpSpinlockCs);
#[cfg(feature = "critical-section-impl")]
critical_section::set_impl!(RpSpinlockCs); critical_section::set_impl!(RpSpinlockCs);
/// Marker value to indicate no-one has the lock. /// Marker value to indicate no-one has the lock.
@ -24,7 +22,6 @@ static LOCK_OWNER: AtomicU8 = AtomicU8::new(LOCK_UNOWNED);
/// The value 2 indicates that we aren't the outermost call, and should not release the spinlock or re-enable interrupts in `release` /// The value 2 indicates that we aren't the outermost call, and should not release the spinlock or re-enable interrupts in `release`
const LOCK_ALREADY_OWNED: u8 = 2; const LOCK_ALREADY_OWNED: u8 = 2;
#[cfg(feature = "critical-section-impl")]
unsafe impl critical_section_0_2::Impl for RpSpinlockCs { unsafe impl critical_section_0_2::Impl for RpSpinlockCs {
unsafe fn acquire() -> u8 { unsafe fn acquire() -> u8 {
RpSpinlockCs::acquire() RpSpinlockCs::acquire()
@ -35,7 +32,6 @@ unsafe impl critical_section_0_2::Impl for RpSpinlockCs {
} }
} }
#[cfg(feature = "critical-section-impl")]
unsafe impl critical_section::Impl for RpSpinlockCs { unsafe impl critical_section::Impl for RpSpinlockCs {
unsafe fn acquire() -> u8 { unsafe fn acquire() -> u8 {
RpSpinlockCs::acquire() RpSpinlockCs::acquire()

View file

@ -19,6 +19,7 @@ mod intrinsics;
pub mod adc; pub mod adc;
pub(crate) mod atomic_register_access; pub(crate) mod atomic_register_access;
pub mod clocks; pub mod clocks;
#[cfg(feature = "critical-section-impl")]
mod critical_section_impl; mod critical_section_impl;
pub mod dma; pub mod dma;
mod float; mod float;

View file

@ -638,8 +638,13 @@ pub type Spinlock30 = Spinlock<30>;
impl SpinlockValid for Spinlock<30> {} impl SpinlockValid for Spinlock<30> {}
/// Spinlock number 31 - used by critical section implementation /// Spinlock number 31 - used by critical section implementation
#[cfg(feature = "critical-section-impl")]
pub(crate) type Spinlock31 = Spinlock<31>; pub(crate) type Spinlock31 = Spinlock<31>;
/// Spinlock number 31 - only public if critical-section-impl is not enabled
#[cfg(not(feature = "critical-section-impl"))]
pub type Spinlock31 = Spinlock<31>;
impl SpinlockValid for Spinlock<31> {} impl SpinlockValid for Spinlock<31> {}
/// Returns the current state of the spinlocks. Each index corresponds to the associated spinlock, e.g. if index `5` is set to `true`, it means that [`Spinlock5`] is currently locked. /// Returns the current state of the spinlocks. Each index corresponds to the associated spinlock, e.g. if index `5` is set to `true`, it means that [`Spinlock5`] is currently locked.