pub struct UniqueArc<T: ?Sized> { /* private fields */ }
Expand description
A refcounted object that is known to have a refcount of 1.
It is mutable and can be converted to an Arc
so that it can be shared.
§Invariants
inner
always has a reference count of 1.
§Examples
In the following example, we make changes to the inner object before turning it into an
Arc<Test>
object (after which point, it cannot be mutated directly). Note that x.into()
cannot fail.
use kernel::sync::{Arc, UniqueArc};
struct Example {
a: u32,
b: u32,
}
fn test() -> Result<Arc<Example>> {
let mut x = UniqueArc::new(Example { a: 10, b: 20 }, GFP_KERNEL)?;
x.a += 1;
x.b += 1;
Ok(x.into())
}
In the following example we first allocate memory for a refcounted Example
but we don’t
initialise it on allocation. We do initialise it later with a call to UniqueArc::write
,
followed by a conversion to Arc<Example>
. This is particularly useful when allocation happens
in one context (e.g., sleepable) and initialisation in another (e.g., atomic):
use kernel::sync::{Arc, UniqueArc};
struct Example {
a: u32,
b: u32,
}
fn test() -> Result<Arc<Example>> {
let x = UniqueArc::new_uninit(GFP_KERNEL)?;
Ok(x.write(Example { a: 10, b: 20 }).into())
}
In the last example below, the caller gets a pinned instance of Example
while converting to
Arc<Example>
; this is useful in scenarios where one needs a pinned reference during
initialisation, for example, when initialising fields that are wrapped in locks.
use kernel::sync::{Arc, UniqueArc};
struct Example {
a: u32,
b: u32,
}
fn test() -> Result<Arc<Example>> {
let mut pinned = Pin::from(UniqueArc::new(Example { a: 10, b: 20 }, GFP_KERNEL)?);
// We can modify `pinned` because it is `Unpin`.
pinned.as_mut().a += 1;
Ok(pinned.into())
}
Implementations§
Source§impl<T> UniqueArc<T>
impl<T> UniqueArc<T>
Sourcepub fn new(value: T, flags: Flags) -> Result<Self, AllocError>
pub fn new(value: T, flags: Flags) -> Result<Self, AllocError>
Tries to allocate a new UniqueArc
instance.
Sourcepub fn new_uninit(flags: Flags) -> Result<UniqueArc<MaybeUninit<T>>, AllocError>
pub fn new_uninit(flags: Flags) -> Result<UniqueArc<MaybeUninit<T>>, AllocError>
Tries to allocate a new UniqueArc
instance whose contents are not initialised yet.
Source§impl<T> UniqueArc<MaybeUninit<T>>
impl<T> UniqueArc<MaybeUninit<T>>
Sourcepub fn write(self, value: T) -> UniqueArc<T>
pub fn write(self, value: T) -> UniqueArc<T>
Converts a UniqueArc<MaybeUninit<T>>
into a UniqueArc<T>
by writing a value into it.
Sourcepub unsafe fn assume_init(self) -> UniqueArc<T>
pub unsafe fn assume_init(self) -> UniqueArc<T>
Unsafely assume that self
is initialized.
§Safety
The caller guarantees that the value behind this pointer has been initialized. It is immediate UB to call this when the value is not initialized.
Trait Implementations§
Source§impl<T, const ID: u64> From<UniqueArc<T>> for ListArc<T, ID>where
T: ListArcSafe<ID> + ?Sized,
impl<T, const ID: u64> From<UniqueArc<T>> for ListArc<T, ID>where
T: ListArcSafe<ID> + ?Sized,
Source§impl<T> InPlaceInit<T> for UniqueArc<T>
impl<T> InPlaceInit<T> for UniqueArc<T>
Source§fn try_pin_init<E>(
init: impl PinInit<T, E>,
flags: Flags,
) -> Result<Self::PinnedSelf, E>where
E: From<AllocError>,
fn try_pin_init<E>(
init: impl PinInit<T, E>,
flags: Flags,
) -> Result<Self::PinnedSelf, E>where
E: From<AllocError>,
T
inside of a new smart pointer of this
type. Read moreSource§fn try_init<E>(init: impl Init<T, E>, flags: Flags) -> Result<Self, E>where
E: From<AllocError>,
fn try_init<E>(init: impl Init<T, E>, flags: Flags) -> Result<Self, E>where
E: From<AllocError>,
T
.Source§impl<T> InPlaceWrite<T> for UniqueArc<MaybeUninit<T>>
impl<T> InPlaceWrite<T> for UniqueArc<MaybeUninit<T>>
Source§type Initialized = UniqueArc<T>
type Initialized = UniqueArc<T>
Self
turns into when the contents are initialized.Source§fn write_init<E>(self, init: impl Init<T, E>) -> Result<Self::Initialized, E>
fn write_init<E>(self, init: impl Init<T, E>) -> Result<Self::Initialized, E>
self
. Read moreSource§fn write_pin_init<E>(
self,
init: impl PinInit<T, E>,
) -> Result<Pin<Self::Initialized>, E>
fn write_pin_init<E>( self, init: impl PinInit<T, E>, ) -> Result<Pin<Self::Initialized>, E>
self
. Read more