pub struct DynamicMutex<T: ?Sized> {
    data: UnsafeCell<RefCell<T>>,
}
Expand description

DynamicMutex implements a guard that is safe for “concurrent” data access on single-core devices that can only experience non-atomic data access via interrupts. It restricts data access to within a CriticalSection, which can only be obtained within a closure given to without_interrupts.

The data is wrapped in a core::cell::RefCell for mutability, which is dynamically checked for consistency and can lead to a panic. Whenever possible, it is recommended to use a Mutex instead, which is based on a Cell.

Fields§

§data: UnsafeCell<RefCell<T>>

Implementations§

source§

impl<T: Sized> DynamicMutex<T>

source

pub const fn new(data: T) -> Self

Create a new DynamicMutex wrapping data of type T.

source§

impl<T: ?Sized> DynamicMutex<T>

source

pub fn lock<'access_time>(
&'access_time self,
_cs: &'access_time CriticalSection
) -> &'access_time RefCell<T>

Get uninterrupted access to the encapsulated data. Can only be called inside a CriticalSection, ensured by requiring a reference to one.

Trait Implementations§

source§

impl<T> Sync for DynamicMutex<T>where
T: Send,

Auto Trait Implementations§

§

impl<T> !RefUnwindSafe for DynamicMutex<T>

§

impl<T: ?Sized> Send for DynamicMutex<T>where
T: Send,

§

impl<T: ?Sized> Unpin for DynamicMutex<T>where
T: Unpin,

§

impl<T: ?Sized> UnwindSafe for DynamicMutex<T>where
T: UnwindSafe,

Blanket Implementations§

§

impl<T> Any for Twhere
T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for Twhere
T: ?Sized,

const: unstable§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for Twhere
T: ?Sized,

const: unstable§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

const: unstable§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for Twhere
U: From<T>,

const: unstable§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of [From]<T> for U chooses to do.

§

impl<T, U> TryFrom<U> for Twhere
U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for Twhere
U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
const: unstable§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.