diff options
Diffstat (limited to 'rust/kernel/sync/arc.rs')
| -rw-r--r-- | rust/kernel/sync/arc.rs | 25 | 
1 files changed, 14 insertions, 11 deletions
| diff --git a/rust/kernel/sync/arc.rs b/rust/kernel/sync/arc.rs index 8484c814609a..c7af0aa48a0a 100644 --- a/rust/kernel/sync/arc.rs +++ b/rust/kernel/sync/arc.rs @@ -135,14 +135,15 @@ pub struct Arc<T: ?Sized> {      // meaningful with respect to dropck - but this may change in the future so this is left here      // out of an abundance of caution.      // -    // See https://doc.rust-lang.org/nomicon/phantom-data.html#generic-parameters-and-drop-checking +    // See <https://doc.rust-lang.org/nomicon/phantom-data.html#generic-parameters-and-drop-checking>      // for more detail on the semantics of dropck in the presence of `PhantomData`.      _p: PhantomData<ArcInner<T>>,  } +#[doc(hidden)]  #[pin_data]  #[repr(C)] -struct ArcInner<T: ?Sized> { +pub struct ArcInner<T: ?Sized> {      refcount: Opaque<bindings::refcount_t>,      data: T,  } @@ -371,18 +372,20 @@ impl<T: ?Sized> Arc<T> {      }  } -impl<T: 'static> ForeignOwnable for Arc<T> { +// SAFETY: The `into_foreign` function returns a pointer that is well-aligned. +unsafe impl<T: 'static> ForeignOwnable for Arc<T> { +    type PointedTo = ArcInner<T>;      type Borrowed<'a> = ArcBorrow<'a, T>;      type BorrowedMut<'a> = Self::Borrowed<'a>; -    fn into_foreign(self) -> *mut crate::ffi::c_void { -        ManuallyDrop::new(self).ptr.as_ptr().cast() +    fn into_foreign(self) -> *mut Self::PointedTo { +        ManuallyDrop::new(self).ptr.as_ptr()      } -    unsafe fn from_foreign(ptr: *mut crate::ffi::c_void) -> Self { +    unsafe fn from_foreign(ptr: *mut Self::PointedTo) -> Self {          // SAFETY: The safety requirements of this function ensure that `ptr` comes from a previous          // call to `Self::into_foreign`. -        let inner = unsafe { NonNull::new_unchecked(ptr.cast::<ArcInner<T>>()) }; +        let inner = unsafe { NonNull::new_unchecked(ptr) };          // SAFETY: By the safety requirement of this function, we know that `ptr` came from          // a previous call to `Arc::into_foreign`, which guarantees that `ptr` is valid and @@ -390,17 +393,17 @@ impl<T: 'static> ForeignOwnable for Arc<T> {          unsafe { Self::from_inner(inner) }      } -    unsafe fn borrow<'a>(ptr: *mut crate::ffi::c_void) -> ArcBorrow<'a, T> { +    unsafe fn borrow<'a>(ptr: *mut Self::PointedTo) -> ArcBorrow<'a, T> {          // SAFETY: The safety requirements of this function ensure that `ptr` comes from a previous          // call to `Self::into_foreign`. -        let inner = unsafe { NonNull::new_unchecked(ptr.cast::<ArcInner<T>>()) }; +        let inner = unsafe { NonNull::new_unchecked(ptr) };          // SAFETY: The safety requirements of `from_foreign` ensure that the object remains alive          // for the lifetime of the returned value.          unsafe { ArcBorrow::new(inner) }      } -    unsafe fn borrow_mut<'a>(ptr: *mut crate::ffi::c_void) -> ArcBorrow<'a, T> { +    unsafe fn borrow_mut<'a>(ptr: *mut Self::PointedTo) -> ArcBorrow<'a, T> {          // SAFETY: The safety requirements for `borrow_mut` are a superset of the safety          // requirements for `borrow`.          unsafe { Self::borrow(ptr) } @@ -489,7 +492,7 @@ impl<T: ?Sized> From<Pin<UniqueArc<T>>> for Arc<T> {  /// There are no mutable references to the underlying [`Arc`], and it remains valid for the  /// lifetime of the [`ArcBorrow`] instance.  /// -/// # Example +/// # Examples  ///  /// ```  /// use kernel::sync::{Arc, ArcBorrow}; | 
