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: ?Sized> Borrow<T> for UniqueArc<T>
§Examples
struct Foo<B: Borrow<u32>>(B);
// Owned instance.
let owned = Foo(1);
// Owned instance using `UniqueArc`.
let arc = UniqueArc::new(1, GFP_KERNEL)?;
let shared = Foo(arc);
let i = 1;
// Borrowed from `i`.
let borrowed = Foo(&i);
 
impl<T: ?Sized> Borrow<T> for UniqueArc<T>
§Examples
struct Foo<B: Borrow<u32>>(B);
// Owned instance.
let owned = Foo(1);
// Owned instance using `UniqueArc`.
let arc = UniqueArc::new(1, GFP_KERNEL)?;
let shared = Foo(arc);
let i = 1;
// Borrowed from `i`.
let borrowed = Foo(&i);Source§impl<T: ?Sized> BorrowMut<T> for UniqueArc<T>
§Examples
struct Foo<B: BorrowMut<u32>>(B);
// Owned instance.
let owned = Foo(1);
// Owned instance using `UniqueArc`.
let arc = UniqueArc::new(1, GFP_KERNEL)?;
let shared = Foo(arc);
let mut i = 1;
// Borrowed from `i`.
let borrowed = Foo(&mut i);
 
impl<T: ?Sized> BorrowMut<T> for UniqueArc<T>
§Examples
struct Foo<B: BorrowMut<u32>>(B);
// Owned instance.
let owned = Foo(1);
// Owned instance using `UniqueArc`.
let arc = UniqueArc::new(1, GFP_KERNEL)?;
let shared = Foo(arc);
let mut i = 1;
// Borrowed from `i`.
let borrowed = Foo(&mut i);Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
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 moreAuto Trait Implementations§
impl<T> Freeze for UniqueArc<T>where
    T: ?Sized,
impl<T> !RefUnwindSafe for UniqueArc<T>
impl<T> Send for UniqueArc<T>
impl<T> Sync for UniqueArc<T>
impl<T> Unpin for UniqueArc<T>where
    T: ?Sized,
impl<T> !UnwindSafe for UniqueArc<T>
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> PinInit<T> for T
 
impl<T> PinInit<T> for T
Source§unsafe fn __pinned_init(self, slot: *mut T) -> Result<(), Infallible>
 
unsafe fn __pinned_init(self, slot: *mut T) -> Result<(), Infallible>
slot. Read more