mirror of
https://github.com/italicsjenga/rp-hal-boards.git
synced 2025-01-10 12:31:31 +11:00
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:
parent
0ecf27450a
commit
c1988432c8
|
@ -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()
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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.
|
||||||
|
|
Loading…
Reference in a new issue