pub struct CriticalSection<'cs> {
pub(crate) _0: PhantomData<&'cs ()>,
}
Expand description
Proof of running inside a critical section. Reexported from the bare_metal crate. Critical section token.
An instance of this type indicates that the current core is executing code within a critical section. This means that no interrupts must be enabled that could preempt the currently running code.
Fields§
§_0: PhantomData<&'cs ()>
Implementations§
Source§impl<'cs> CriticalSection<'cs>
impl<'cs> CriticalSection<'cs>
Sourcepub unsafe fn new() -> CriticalSection<'cs>
pub unsafe fn new() -> CriticalSection<'cs>
Creates a critical section token.
This method is meant to be used to create safe abstractions rather than being directly used in applications.
§Safety
This must only be called when the current core is in a critical section. The caller must ensure that the returned instance will not live beyond the end of the critical section. Moreover, the caller must use adequate fences to prevent the compiler from moving the instructions inside the critical section to the outside of it. Sequentially consistent fences are suggested immediately after entry and immediately before exit from the critical section.
Note that the lifetime 'cs
of the returned instance is unconstrained. User code must not
be able to influence the lifetime picked for this type, since that might cause it to be
inferred to 'static
.
Trait Implementations§
Source§impl<'cs> Clone for CriticalSection<'cs>
impl<'cs> Clone for CriticalSection<'cs>
Source§fn clone(&self) -> CriticalSection<'cs>
fn clone(&self) -> CriticalSection<'cs>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl<'cs> Debug for CriticalSection<'cs>
impl<'cs> Debug for CriticalSection<'cs>
impl<'cs> Copy for CriticalSection<'cs>
Auto Trait Implementations§
impl<'cs> Freeze for CriticalSection<'cs>
impl<'cs> RefUnwindSafe for CriticalSection<'cs>
impl<'cs> Send for CriticalSection<'cs>
impl<'cs> Sync for CriticalSection<'cs>
impl<'cs> Unpin for CriticalSection<'cs>
impl<'cs> UnwindSafe for CriticalSection<'cs>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoSwitch for T
impl<T> IntoSwitch for T
Source§fn into_switch<ActiveLevel>(self) -> Switch<T, ActiveLevel>
fn into_switch<ActiveLevel>(self) -> Switch<T, ActiveLevel>
Source§fn into_active_high_switch(self) -> Switch<Self, ActiveHigh>where
Self: Sized,
fn into_active_high_switch(self) -> Switch<Self, ActiveHigh>where
Self: Sized,
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 0 bytes