kernel::sync

Struct Arc

Source
pub struct Arc<T: ?Sized> { /* private fields */ }
Expand description

A reference-counted pointer to an instance of T.

The reference count is incremented when new instances of Arc are created, and decremented when they are dropped. When the count reaches zero, the underlying T is also dropped.

§Invariants

The reference count on an instance of Arc is always non-zero. The object pointed to by Arc is always pinned.

§Examples

use kernel::sync::Arc;

struct Example {
    a: u32,
    b: u32,
}

// Create a refcounted instance of `Example`.
let obj = Arc::new(Example { a: 10, b: 20 }, GFP_KERNEL)?;

// Get a new pointer to `obj` and increment the refcount.
let cloned = obj.clone();

// Assert that both `obj` and `cloned` point to the same underlying object.
assert!(core::ptr::eq(&*obj, &*cloned));

// Destroy `obj` and decrement its refcount.
drop(obj);

// Check that the values are still accessible through `cloned`.
assert_eq!(cloned.a, 10);
assert_eq!(cloned.b, 20);

// The refcount drops to zero when `cloned` goes out of scope, and the memory is freed.

Using Arc<T> as the type of self:

use kernel::sync::Arc;

struct Example {
    a: u32,
    b: u32,
}

impl Example {
    fn take_over(self: Arc<Self>) {
        // ...
    }

    fn use_reference(self: &Arc<Self>) {
        // ...
    }
}

let obj = Arc::new(Example { a: 10, b: 20 }, GFP_KERNEL)?;
obj.use_reference();
obj.take_over();

Coercion from Arc<Example> to Arc<dyn MyTrait>:

use kernel::sync::{Arc, ArcBorrow};

trait MyTrait {
    // Trait has a function whose `self` type is `Arc<Self>`.
    fn example1(self: Arc<Self>) {}

    // Trait has a function whose `self` type is `ArcBorrow<'_, Self>`.
    fn example2(self: ArcBorrow<'_, Self>) {}
}

struct Example;
impl MyTrait for Example {}

// `obj` has type `Arc<Example>`.
let obj: Arc<Example> = Arc::new(Example, GFP_KERNEL)?;

// `coerced` has type `Arc<dyn MyTrait>`.
let coerced: Arc<dyn MyTrait> = obj;

Implementations§

Source§

impl Arc<dyn Any + Send + Sync>

Source

pub fn downcast<T>(self) -> Result<Arc<T>, Self>
where T: Any + Send + Sync,

Attempt to downcast the Arc<dyn Any + Send + Sync> to a concrete type.

Source§

impl<T> Arc<T>

Source

pub fn new(contents: T, flags: Flags) -> Result<Self, AllocError>

Constructs a new reference counted instance of T.

Source§

impl<T: ?Sized> Arc<T>

Source

pub fn into_raw(self) -> *const T

Convert the Arc into a raw pointer.

The raw pointer has ownership of the refcount that this Arc object owned.

Source

pub unsafe fn from_raw(ptr: *const T) -> Self

Recreates an Arc instance previously deconstructed via Arc::into_raw.

§Safety

ptr must have been returned by a previous call to Arc::into_raw. Additionally, it must not be called more than once for each previous call to Arc::into_raw.

Source

pub fn as_arc_borrow(&self) -> ArcBorrow<'_, T>

Returns an ArcBorrow from the given Arc.

This is useful when the argument of a function call is an ArcBorrow (e.g., in a method receiver), but we have an Arc instead. Getting an ArcBorrow is free when optimised.

Source

pub fn ptr_eq(this: &Self, other: &Self) -> bool

Compare whether two Arc pointers reference the same underlying object.

Source

pub fn into_unique_or_drop(self) -> Option<Pin<UniqueArc<T>>>

Converts this Arc into a UniqueArc, or destroys it if it is not unique.

When this destroys the Arc, it does so while properly avoiding races. This means that this method will never call the destructor of the value.

§Examples
use kernel::sync::{Arc, UniqueArc};

let arc = Arc::new(42, GFP_KERNEL)?;
let unique_arc = arc.into_unique_or_drop();

// The above conversion should succeed since refcount of `arc` is 1.
assert!(unique_arc.is_some());

assert_eq!(*(unique_arc.unwrap()), 42);
use kernel::sync::{Arc, UniqueArc};

let arc = Arc::new(42, GFP_KERNEL)?;
let another = arc.clone();

let unique_arc = arc.into_unique_or_drop();

// The above conversion should fail since refcount of `arc` is >1.
assert!(unique_arc.is_none());

Trait Implementations§

Source§

impl<T, const ID: u64> AsRef<Arc<T>> for ListArc<T, ID>
where T: ListArcSafe<ID> + ?Sized,

Source§

fn as_ref(&self) -> &Arc<T>

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<T: ?Sized> AsRef<T> for Arc<T>

Source§

fn as_ref(&self) -> &T

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<T: ?Sized> Clone for Arc<T>

Source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T: Debug + ?Sized> Debug for Arc<T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<T: ?Sized> Deref for Arc<T>

Source§

type Target = T

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl<T: Display + ?Sized> Display for Arc<T>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<T: ?Sized> Drop for Arc<T>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<T: 'static> ForeignOwnable for Arc<T>

Source§

type Borrowed<'a> = ArcBorrow<'a, T>

Type of values borrowed between calls to ForeignOwnable::into_foreign and ForeignOwnable::from_foreign.
Source§

fn into_foreign(self) -> *const c_void

Converts a Rust-owned object to a foreign-owned one. Read more
Source§

unsafe fn borrow<'a>(ptr: *const c_void) -> ArcBorrow<'a, T>

Borrows a foreign-owned object. Read more
Source§

unsafe fn from_foreign(ptr: *const c_void) -> Self

Converts a foreign-owned object back to a Rust-owned one. Read more
Source§

unsafe fn try_from_foreign(ptr: *const c_void) -> Option<Self>

Tries to convert a foreign-owned object back to a Rust-owned one. Read more
Source§

impl<T: ?Sized> From<ArcBorrow<'_, T>> for Arc<T>

Source§

fn from(b: ArcBorrow<'_, T>) -> Self

Converts to this type from the input type.
Source§

impl<T: ?Sized> From<Pin<UniqueArc<T>>> for Arc<T>

Source§

fn from(item: Pin<UniqueArc<T>>) -> Self

Converts to this type from the input type.
Source§

impl<T: ?Sized> From<UniqueArc<T>> for Arc<T>

Source§

fn from(item: UniqueArc<T>) -> Self

Converts to this type from the input type.
Source§

impl<T> InPlaceInit<T> for Arc<T>

Source§

type PinnedSelf = Arc<T>

Pinned version of Self. Read more
Source§

fn try_pin_init<E>( init: impl PinInit<T, E>, flags: Flags, ) -> Result<Self::PinnedSelf, E>
where E: From<AllocError>,

Use the given pin-initializer to pin-initialize a T inside of a new smart pointer of this type. Read more
Source§

fn try_init<E>(init: impl Init<T, E>, flags: Flags) -> Result<Self, E>
where E: From<AllocError>,

Use the given initializer to in-place initialize a T.
Source§

fn pin_init<E>( init: impl PinInit<T, E>, flags: Flags, ) -> Result<Self::PinnedSelf>
where Error: From<E>,

Use the given pin-initializer to pin-initialize a T inside of a new smart pointer of this type. Read more
Source§

fn init<E>(init: impl Init<T, E>, flags: Flags) -> Result<Self>
where Error: From<E>,

Use the given initializer to in-place initialize a T.
Source§

impl<T, const ID: u64> RawWorkItem<ID> for Arc<T>
where T: WorkItem<ID, Pointer = Self> + HasWork<T, ID>,

Source§

type EnqueueOutput = Result<(), Arc<T>>

The return type of Queue::enqueue.
Source§

unsafe fn __enqueue<F>(self, queue_work_on: F) -> Self::EnqueueOutput
where F: FnOnce(*mut work_struct) -> bool,

Enqueues this work item on a queue using the provided queue_work_on method. Read more
Source§

impl<T, const ID: u64> WorkItemPointer<ID> for Arc<T>
where T: WorkItem<ID, Pointer = Self> + HasWork<T, ID>,

Source§

unsafe extern "C" fn run(ptr: *mut work_struct)

Run this work item. Read more
Source§

impl<T: ?Sized + Unsize<U>, U: ?Sized> CoerceUnsized<Arc<U>> for Arc<T>

Source§

impl<T: ?Sized + Unsize<U>, U: ?Sized> DispatchFromDyn<Arc<U>> for Arc<T>

Source§

impl<T: ?Sized + Sync + Send> Send for Arc<T>

Source§

impl<T: ?Sized + Sync + Send> Sync for Arc<T>

Auto Trait Implementations§

§

impl<T> Freeze for Arc<T>
where T: ?Sized,

§

impl<T> !RefUnwindSafe for Arc<T>

§

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

§

impl<T> !UnwindSafe for Arc<T>

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

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

Source§

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

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, E> Init<T, E> for T

Source§

unsafe fn __init(self, slot: *mut T) -> Result<(), E>

Initializes slot. Read more
Source§

fn chain<F>(self, f: F) -> ChainInit<Self, F, T, E>
where F: FnOnce(&mut T) -> Result<(), E>,

First initializes the value using self then calls the function f with the initialized value. Read more
Source§

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

Source§

fn into(self) -> U

Calls U::from(self).

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

Source§

impl<T, E> PinInit<T, E> for T

Source§

unsafe fn __pinned_init(self, slot: *mut T) -> Result<(), E>

Initializes slot. Read more
Source§

fn pin_chain<F>(self, f: F) -> ChainPinInit<Self, F, T, E>
where F: FnOnce(Pin<&mut T>) -> Result<(), E>,

First initializes the value using self then calls the function f with the initialized value. Read more
Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

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

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.
Source§

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

Source§

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

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.