diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2024-11-26 14:00:26 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2024-11-26 14:00:26 -0800 | 
| commit | 798bb342e0416d846cf67f4725a3428f39bfb96b (patch) | |
| tree | 66a4eda8cba9d7c6b0f535bb85760ef8bf3d2a49 /rust/kernel/init.rs | |
| parent | e68ce9474a1dac72ea9b1eab25bcd7a5b28adc79 (diff) | |
| parent | b7ed2b6f4e8d7f64649795e76ee9db67300de8eb (diff) | |
Merge tag 'rust-6.13' of https://github.com/Rust-for-Linux/linux
Pull rust updates from Miguel Ojeda:
 "Toolchain and infrastructure:
   - Enable a series of lints, including safety-related ones, e.g. the
     compiler will now warn about missing safety comments, as well as
     unnecessary ones. How safety documentation is organized is a
     frequent source of review comments, thus having the compiler guide
     new developers on where they are expected (and where not) is very
     nice.
   - Start using '#[expect]': an interesting feature in Rust (stabilized
     in 1.81.0) that makes the compiler warn if an expected warning was
     _not_ emitted. This is useful to avoid forgetting cleaning up
     locally ignored diagnostics ('#[allow]'s).
   - Introduce '.clippy.toml' configuration file for Clippy, the Rust
     linter, which will allow us to tweak its behaviour. For instance,
     our first use cases are declaring a disallowed macro and, more
     importantly, enabling the checking of private items.
   - Lints-related fixes and cleanups related to the items above.
   - Migrate from 'receiver_trait' to 'arbitrary_self_types': to get the
     kernel into stable Rust, one of the major pieces of the puzzle is
     the support to write custom types that can be used as 'self', i.e.
     as receivers, since the kernel needs to write types such as 'Arc'
     that common userspace Rust would not. 'arbitrary_self_types' has
     been accepted to become stable, and this is one of the steps
     required to get there.
   - Remove usage of the 'new_uninit' unstable feature.
   - Use custom C FFI types. Includes a new 'ffi' crate to contain our
     custom mapping, instead of using the standard library 'core::ffi'
     one. The actual remapping will be introduced in a later cycle.
   - Map '__kernel_{size_t,ssize_t,ptrdiff_t}' to 'usize'/'isize'
     instead of 32/64-bit integers.
   - Fix 'size_t' in bindgen generated prototypes of C builtins.
   - Warn on bindgen < 0.69.5 and libclang >= 19.1 due to a double issue
     in the projects, which we managed to trigger with the upcoming
     tracepoint support. It includes a build test since some
     distributions backported the fix (e.g. Debian -- thanks!). All
     major distributions we list should be now OK except Ubuntu non-LTS.
  'macros' crate:
   - Adapt the build system to be able run the doctests there too; and
     clean up and enable the corresponding doctests.
  'kernel' crate:
   - Add 'alloc' module with generic kernel allocator support and remove
     the dependency on the Rust standard library 'alloc' and the
     extension traits we used to provide fallible methods with flags.
     Add the 'Allocator' trait and its implementations '{K,V,KV}malloc'.
     Add the 'Box' type (a heap allocation for a single value of type
     'T' that is also generic over an allocator and considers the
     kernel's GFP flags) and its shorthand aliases '{K,V,KV}Box'. Add
     'ArrayLayout' type. Add 'Vec' (a contiguous growable array type)
     and its shorthand aliases '{K,V,KV}Vec', including iterator
     support.
     For instance, now we may write code such as:
         let mut v = KVec::new();
         v.push(1, GFP_KERNEL)?;
         assert_eq!(&v, &[1]);
     Treewide, move as well old users to these new types.
   - 'sync' module: add global lock support, including the
     'GlobalLockBackend' trait; the 'Global{Lock,Guard,LockedBy}' types
     and the 'global_lock!' macro. Add the 'Lock::try_lock' method.
   - 'error' module: optimize 'Error' type to use 'NonZeroI32' and make
     conversion functions public.
   - 'page' module: add 'page_align' function.
   - Add 'transmute' module with the existing 'FromBytes' and 'AsBytes'
     traits.
   - 'block::mq::request' module: improve rendered documentation.
   - 'types' module: extend 'Opaque' type documentation and add simple
     examples for the 'Either' types.
  drm/panic:
   - Clean up a series of Clippy warnings.
  Documentation:
   - Add coding guidelines for lints and the '#[expect]' feature.
   - Add Ubuntu to the list of distributions in the Quick Start guide.
  MAINTAINERS:
   - Add Danilo Krummrich as maintainer of the new 'alloc' module.
  And a few other small cleanups and fixes"
* tag 'rust-6.13' of https://github.com/Rust-for-Linux/linux: (82 commits)
  rust: alloc: Fix `ArrayLayout` allocations
  docs: rust: remove spurious item in `expect` list
  rust: allow `clippy::needless_lifetimes`
  rust: warn on bindgen < 0.69.5 and libclang >= 19.1
  rust: use custom FFI integer types
  rust: map `__kernel_size_t` and friends also to usize/isize
  rust: fix size_t in bindgen prototypes of C builtins
  rust: sync: add global lock support
  rust: macros: enable the rest of the tests
  rust: macros: enable paste! use from macro_rules!
  rust: enable macros::module! tests
  rust: kbuild: expand rusttest target for macros
  rust: types: extend `Opaque` documentation
  rust: block: fix formatting of `kernel::block::mq::request` module
  rust: macros: fix documentation of the paste! macro
  rust: kernel: fix THIS_MODULE header path in ThisModule doc comment
  rust: page: add Rust version of PAGE_ALIGN
  rust: helpers: remove unnecessary header includes
  rust: exports: improve grammar in commentary
  drm/panic: allow verbose version check
  ...
Diffstat (limited to 'rust/kernel/init.rs')
| -rw-r--r-- | rust/kernel/init.rs | 127 | 
1 files changed, 43 insertions, 84 deletions
| diff --git a/rust/kernel/init.rs b/rust/kernel/init.rs index a17ac8762d8f..347049df556b 100644 --- a/rust/kernel/init.rs +++ b/rust/kernel/init.rs @@ -13,7 +13,7 @@  //! To initialize a `struct` with an in-place constructor you will need two things:  //! - an in-place constructor,  //! - a memory location that can hold your `struct` (this can be the [stack], an [`Arc<T>`], -//!   [`UniqueArc<T>`], [`Box<T>`] or any other smart pointer that implements [`InPlaceInit`]). +//!   [`UniqueArc<T>`], [`KBox<T>`] or any other smart pointer that implements [`InPlaceInit`]).  //!  //! To get an in-place constructor there are generally three options:  //! - directly creating an in-place constructor using the [`pin_init!`] macro, @@ -35,7 +35,7 @@  //! that you need to write `<-` instead of `:` for fields that you want to initialize in-place.  //!  //! ```rust -//! # #![allow(clippy::disallowed_names)] +//! # #![expect(clippy::disallowed_names)]  //! use kernel::sync::{new_mutex, Mutex};  //! # use core::pin::Pin;  //! #[pin_data] @@ -55,7 +55,7 @@  //! (or just the stack) to actually initialize a `Foo`:  //!  //! ```rust -//! # #![allow(clippy::disallowed_names)] +//! # #![expect(clippy::disallowed_names)]  //! # use kernel::sync::{new_mutex, Mutex};  //! # use core::pin::Pin;  //! # #[pin_data] @@ -68,7 +68,7 @@  //! #     a <- new_mutex!(42, "Foo::a"),  //! #     b: 24,  //! # }); -//! let foo: Result<Pin<Box<Foo>>> = Box::pin_init(foo, GFP_KERNEL); +//! let foo: Result<Pin<KBox<Foo>>> = KBox::pin_init(foo, GFP_KERNEL);  //! ```  //!  //! For more information see the [`pin_init!`] macro. @@ -87,20 +87,19 @@  //! To declare an init macro/function you just return an [`impl PinInit<T, E>`]:  //!  //! ```rust -//! # #![allow(clippy::disallowed_names)]  //! # use kernel::{sync::Mutex, new_mutex, init::PinInit, try_pin_init};  //! #[pin_data]  //! struct DriverData {  //!     #[pin]  //!     status: Mutex<i32>, -//!     buffer: Box<[u8; 1_000_000]>, +//!     buffer: KBox<[u8; 1_000_000]>,  //! }  //!  //! impl DriverData {  //!     fn new() -> impl PinInit<Self, Error> {  //!         try_pin_init!(Self {  //!             status <- new_mutex!(0, "DriverData::status"), -//!             buffer: Box::init(kernel::init::zeroed(), GFP_KERNEL)?, +//!             buffer: KBox::init(kernel::init::zeroed(), GFP_KERNEL)?,  //!         })  //!     }  //! } @@ -121,11 +120,12 @@  //!   `slot` gets called.  //!  //! ```rust -//! # #![allow(unreachable_pub, clippy::disallowed_names)] +//! # #![expect(unreachable_pub, clippy::disallowed_names)]  //! use kernel::{init, types::Opaque};  //! use core::{ptr::addr_of_mut, marker::PhantomPinned, pin::Pin};  //! # mod bindings { -//! #     #![allow(non_camel_case_types)] +//! #     #![expect(non_camel_case_types)] +//! #     #![expect(clippy::missing_safety_doc)]  //! #     pub struct foo;  //! #     pub unsafe fn init_foo(_ptr: *mut foo) {}  //! #     pub unsafe fn destroy_foo(_ptr: *mut foo) {} @@ -133,7 +133,7 @@  //! # }  //! # // `Error::from_errno` is `pub(crate)` in the `kernel` crate, thus provide a workaround.  //! # trait FromErrno { -//! #     fn from_errno(errno: core::ffi::c_int) -> Error { +//! #     fn from_errno(errno: kernel::ffi::c_int) -> Error {  //! #         // Dummy error that can be constructed outside the `kernel` crate.  //! #         Error::from(core::fmt::Error)  //! #     } @@ -211,13 +211,12 @@  //! [`pin_init!`]: crate::pin_init!  use crate::{ -    alloc::{box_ext::BoxExt, AllocError, Flags}, +    alloc::{AllocError, Flags, KBox},      error::{self, Error},      sync::Arc,      sync::UniqueArc,      types::{Opaque, ScopeGuard},  }; -use alloc::boxed::Box;  use core::{      cell::UnsafeCell,      convert::Infallible, @@ -238,7 +237,7 @@ pub mod macros;  /// # Examples  ///  /// ```rust -/// # #![allow(clippy::disallowed_names)] +/// # #![expect(clippy::disallowed_names)]  /// # use kernel::{init, macros::pin_data, pin_init, stack_pin_init, init::*, sync::Mutex, new_mutex};  /// # use core::pin::Pin;  /// #[pin_data] @@ -290,7 +289,7 @@ macro_rules! stack_pin_init {  /// # Examples  ///  /// ```rust,ignore -/// # #![allow(clippy::disallowed_names)] +/// # #![expect(clippy::disallowed_names)]  /// # use kernel::{init, pin_init, stack_try_pin_init, init::*, sync::Mutex, new_mutex};  /// # use macros::pin_data;  /// # use core::{alloc::AllocError, pin::Pin}; @@ -298,7 +297,7 @@ macro_rules! stack_pin_init {  /// struct Foo {  ///     #[pin]  ///     a: Mutex<usize>, -///     b: Box<Bar>, +///     b: KBox<Bar>,  /// }  ///  /// struct Bar { @@ -307,7 +306,7 @@ macro_rules! stack_pin_init {  ///  /// stack_try_pin_init!(let foo: Result<Pin<&mut Foo>, AllocError> = pin_init!(Foo {  ///     a <- new_mutex!(42), -///     b: Box::new(Bar { +///     b: KBox::new(Bar {  ///         x: 64,  ///     }, GFP_KERNEL)?,  /// })); @@ -316,7 +315,7 @@ macro_rules! stack_pin_init {  /// ```  ///  /// ```rust,ignore -/// # #![allow(clippy::disallowed_names)] +/// # #![expect(clippy::disallowed_names)]  /// # use kernel::{init, pin_init, stack_try_pin_init, init::*, sync::Mutex, new_mutex};  /// # use macros::pin_data;  /// # use core::{alloc::AllocError, pin::Pin}; @@ -324,7 +323,7 @@ macro_rules! stack_pin_init {  /// struct Foo {  ///     #[pin]  ///     a: Mutex<usize>, -///     b: Box<Bar>, +///     b: KBox<Bar>,  /// }  ///  /// struct Bar { @@ -333,7 +332,7 @@ macro_rules! stack_pin_init {  ///  /// stack_try_pin_init!(let foo: Pin<&mut Foo> =? pin_init!(Foo {  ///     a <- new_mutex!(42), -///     b: Box::new(Bar { +///     b: KBox::new(Bar {  ///         x: 64,  ///     }, GFP_KERNEL)?,  /// })); @@ -368,7 +367,6 @@ macro_rules! stack_try_pin_init {  /// The syntax is almost identical to that of a normal `struct` initializer:  ///  /// ```rust -/// # #![allow(clippy::disallowed_names)]  /// # use kernel::{init, pin_init, macros::pin_data, init::*};  /// # use core::pin::Pin;  /// #[pin_data] @@ -392,7 +390,7 @@ macro_rules! stack_try_pin_init {  ///     },  /// });  /// # initializer } -/// # Box::pin_init(demo(), GFP_KERNEL).unwrap(); +/// # KBox::pin_init(demo(), GFP_KERNEL).unwrap();  /// ```  ///  /// Arbitrary Rust expressions can be used to set the value of a variable. @@ -413,7 +411,6 @@ macro_rules! stack_try_pin_init {  /// To create an initializer function, simply declare it like this:  ///  /// ```rust -/// # #![allow(clippy::disallowed_names)]  /// # use kernel::{init, pin_init, init::*};  /// # use core::pin::Pin;  /// # #[pin_data] @@ -440,7 +437,7 @@ macro_rules! stack_try_pin_init {  /// Users of `Foo` can now create it like this:  ///  /// ```rust -/// # #![allow(clippy::disallowed_names)] +/// # #![expect(clippy::disallowed_names)]  /// # use kernel::{init, pin_init, macros::pin_data, init::*};  /// # use core::pin::Pin;  /// # #[pin_data] @@ -462,13 +459,12 @@ macro_rules! stack_try_pin_init {  /// #         })  /// #     }  /// # } -/// let foo = Box::pin_init(Foo::new(), GFP_KERNEL); +/// let foo = KBox::pin_init(Foo::new(), GFP_KERNEL);  /// ```  ///  /// They can also easily embed it into their own `struct`s:  ///  /// ```rust -/// # #![allow(clippy::disallowed_names)]  /// # use kernel::{init, pin_init, macros::pin_data, init::*};  /// # use core::pin::Pin;  /// # #[pin_data] @@ -541,6 +537,7 @@ macro_rules! stack_try_pin_init {  /// }  /// pin_init!(&this in Buf {  ///     buf: [0; 64], +///     // SAFETY: TODO.  ///     ptr: unsafe { addr_of_mut!((*this.as_ptr()).buf).cast() },  ///     pin: PhantomPinned,  /// }); @@ -590,11 +587,10 @@ macro_rules! pin_init {  /// # Examples  ///  /// ```rust -/// # #![feature(new_uninit)]  /// use kernel::{init::{self, PinInit}, error::Error};  /// #[pin_data]  /// struct BigBuf { -///     big: Box<[u8; 1024 * 1024 * 1024]>, +///     big: KBox<[u8; 1024 * 1024 * 1024]>,  ///     small: [u8; 1024 * 1024],  ///     ptr: *mut u8,  /// } @@ -602,7 +598,7 @@ macro_rules! pin_init {  /// impl BigBuf {  ///     fn new() -> impl PinInit<Self, Error> {  ///         try_pin_init!(Self { -///             big: Box::init(init::zeroed(), GFP_KERNEL)?, +///             big: KBox::init(init::zeroed(), GFP_KERNEL)?,  ///             small: [0; 1024 * 1024],  ///             ptr: core::ptr::null_mut(),  ///         }? Error) @@ -694,16 +690,16 @@ macro_rules! init {  /// # Examples  ///  /// ```rust -/// use kernel::{init::{PinInit, zeroed}, error::Error}; +/// use kernel::{alloc::KBox, init::{PinInit, zeroed}, error::Error};  /// struct BigBuf { -///     big: Box<[u8; 1024 * 1024 * 1024]>, +///     big: KBox<[u8; 1024 * 1024 * 1024]>,  ///     small: [u8; 1024 * 1024],  /// }  ///  /// impl BigBuf {  ///     fn new() -> impl Init<Self, Error> {  ///         try_init!(Self { -///             big: Box::init(zeroed(), GFP_KERNEL)?, +///             big: KBox::init(zeroed(), GFP_KERNEL)?,  ///             small: [0; 1024 * 1024],  ///         }? Error)  ///     } @@ -814,8 +810,8 @@ macro_rules! assert_pinned {  /// A pin-initializer for the type `T`.  ///  /// To use this initializer, you will need a suitable memory location that can hold a `T`. This can -/// be [`Box<T>`], [`Arc<T>`], [`UniqueArc<T>`] or even the stack (see [`stack_pin_init!`]). Use the -/// [`InPlaceInit::pin_init`] function of a smart pointer like [`Arc<T>`] on this. +/// be [`KBox<T>`], [`Arc<T>`], [`UniqueArc<T>`] or even the stack (see [`stack_pin_init!`]). Use +/// the [`InPlaceInit::pin_init`] function of a smart pointer like [`Arc<T>`] on this.  ///  /// Also see the [module description](self).  /// @@ -854,7 +850,7 @@ pub unsafe trait PinInit<T: ?Sized, E = Infallible>: Sized {      /// # Examples      ///      /// ```rust -    /// # #![allow(clippy::disallowed_names)] +    /// # #![expect(clippy::disallowed_names)]      /// use kernel::{types::Opaque, init::pin_init_from_closure};      /// #[repr(C)]      /// struct RawFoo([u8; 16]); @@ -875,6 +871,7 @@ pub unsafe trait PinInit<T: ?Sized, E = Infallible>: Sized {      /// }      ///      /// let foo = pin_init!(Foo { +    ///     // SAFETY: TODO.      ///     raw <- unsafe {      ///         Opaque::ffi_init(|s| {      ///             init_foo(s); @@ -894,7 +891,7 @@ pub unsafe trait PinInit<T: ?Sized, E = Infallible>: Sized {  }  /// An initializer returned by [`PinInit::pin_chain`]. -pub struct ChainPinInit<I, F, T: ?Sized, E>(I, F, __internal::Invariant<(E, Box<T>)>); +pub struct ChainPinInit<I, F, T: ?Sized, E>(I, F, __internal::Invariant<(E, KBox<T>)>);  // SAFETY: The `__pinned_init` function is implemented such that it  // - returns `Ok(())` on successful initialization, @@ -920,8 +917,8 @@ where  /// An initializer for `T`.  ///  /// To use this initializer, you will need a suitable memory location that can hold a `T`. This can -/// be [`Box<T>`], [`Arc<T>`], [`UniqueArc<T>`] or even the stack (see [`stack_pin_init!`]). Use the -/// [`InPlaceInit::init`] function of a smart pointer like [`Arc<T>`] on this. Because +/// be [`KBox<T>`], [`Arc<T>`], [`UniqueArc<T>`] or even the stack (see [`stack_pin_init!`]). Use +/// the [`InPlaceInit::init`] function of a smart pointer like [`Arc<T>`] on this. Because  /// [`PinInit<T, E>`] is a super trait, you can use every function that takes it as well.  ///  /// Also see the [module description](self). @@ -965,7 +962,7 @@ pub unsafe trait Init<T: ?Sized, E = Infallible>: PinInit<T, E> {      /// # Examples      ///      /// ```rust -    /// # #![allow(clippy::disallowed_names)] +    /// # #![expect(clippy::disallowed_names)]      /// use kernel::{types::Opaque, init::{self, init_from_closure}};      /// struct Foo {      ///     buf: [u8; 1_000_000], @@ -993,7 +990,7 @@ pub unsafe trait Init<T: ?Sized, E = Infallible>: PinInit<T, E> {  }  /// An initializer returned by [`Init::chain`]. -pub struct ChainInit<I, F, T: ?Sized, E>(I, F, __internal::Invariant<(E, Box<T>)>); +pub struct ChainInit<I, F, T: ?Sized, E>(I, F, __internal::Invariant<(E, KBox<T>)>);  // SAFETY: The `__init` function is implemented such that it  // - returns `Ok(())` on successful initialization, @@ -1077,8 +1074,9 @@ pub fn uninit<T, E>() -> impl Init<MaybeUninit<T>, E> {  /// # Examples  ///  /// ```rust -/// use kernel::{error::Error, init::init_array_from_fn}; -/// let array: Box<[usize; 1_000]> = Box::init::<Error>(init_array_from_fn(|i| i), GFP_KERNEL).unwrap(); +/// use kernel::{alloc::KBox, error::Error, init::init_array_from_fn}; +/// let array: KBox<[usize; 1_000]> = +///     KBox::init::<Error>(init_array_from_fn(|i| i), GFP_KERNEL).unwrap();  /// assert_eq!(array.len(), 1_000);  /// ```  pub fn init_array_from_fn<I, const N: usize, T, E>( @@ -1162,6 +1160,7 @@ where  // SAFETY: Every type can be initialized by-value.  unsafe impl<T, E> Init<T, E> for T {      unsafe fn __init(self, slot: *mut T) -> Result<(), E> { +        // SAFETY: TODO.          unsafe { slot.write(self) };          Ok(())      } @@ -1170,6 +1169,7 @@ unsafe impl<T, E> Init<T, E> for T {  // SAFETY: Every type can be initialized by-value. `__pinned_init` calls `__init`.  unsafe impl<T, E> PinInit<T, E> for T {      unsafe fn __pinned_init(self, slot: *mut T) -> Result<(), E> { +        // SAFETY: TODO.          unsafe { self.__init(slot) }      }  } @@ -1243,26 +1243,6 @@ impl<T> InPlaceInit<T> for Arc<T> {      }  } -impl<T> InPlaceInit<T> for Box<T> { -    type PinnedSelf = Pin<Self>; - -    #[inline] -    fn try_pin_init<E>(init: impl PinInit<T, E>, flags: Flags) -> Result<Self::PinnedSelf, E> -    where -        E: From<AllocError>, -    { -        <Box<_> as BoxExt<_>>::new_uninit(flags)?.write_pin_init(init) -    } - -    #[inline] -    fn try_init<E>(init: impl Init<T, E>, flags: Flags) -> Result<Self, E> -    where -        E: From<AllocError>, -    { -        <Box<_> as BoxExt<_>>::new_uninit(flags)?.write_init(init) -    } -} -  impl<T> InPlaceInit<T> for UniqueArc<T> {      type PinnedSelf = Pin<Self>; @@ -1299,28 +1279,6 @@ pub trait InPlaceWrite<T> {      fn write_pin_init<E>(self, init: impl PinInit<T, E>) -> Result<Pin<Self::Initialized>, E>;  } -impl<T> InPlaceWrite<T> for Box<MaybeUninit<T>> { -    type Initialized = Box<T>; - -    fn write_init<E>(mut self, init: impl Init<T, E>) -> Result<Self::Initialized, E> { -        let slot = self.as_mut_ptr(); -        // SAFETY: When init errors/panics, slot will get deallocated but not dropped, -        // slot is valid. -        unsafe { init.__init(slot)? }; -        // SAFETY: All fields have been initialized. -        Ok(unsafe { self.assume_init() }) -    } - -    fn write_pin_init<E>(mut self, init: impl PinInit<T, E>) -> Result<Pin<Self::Initialized>, E> { -        let slot = self.as_mut_ptr(); -        // SAFETY: When init errors/panics, slot will get deallocated but not dropped, -        // slot is valid and will not be moved, because we pin it later. -        unsafe { init.__pinned_init(slot)? }; -        // SAFETY: All fields have been initialized. -        Ok(unsafe { self.assume_init() }.into()) -    } -} -  impl<T> InPlaceWrite<T> for UniqueArc<MaybeUninit<T>> {      type Initialized = UniqueArc<T>; @@ -1411,6 +1369,7 @@ pub fn zeroed<T: Zeroable>() -> impl Init<T> {  macro_rules! impl_zeroable {      ($($({$($generics:tt)*})? $t:ty, )*) => { +        // SAFETY: Safety comments written in the macro invocation.          $(unsafe impl$($($generics)*)? Zeroable for $t {})*      };  } @@ -1451,7 +1410,7 @@ impl_zeroable! {      //      // In this case we are allowed to use `T: ?Sized`, since all zeros is the `None` variant.      {<T: ?Sized>} Option<NonNull<T>>, -    {<T: ?Sized>} Option<Box<T>>, +    {<T: ?Sized>} Option<KBox<T>>,      // SAFETY: `null` pointer is valid.      // | 
