rust: kernel: remove usage of allocator_api unstable feature

With the adoption of `BoxExt` and `VecExt`, we don't need the functions
provided by this feature (namely the methods prefixed with `try_` and
different allocator per collection instance).

We do need `AllocError`, but we define our own as it is a trivial empty
struct.

Reviewed-by: Benno Lossin <benno.lossin@proton.me>
Signed-off-by: Wedson Almeida Filho <walmeida@microsoft.com>
Link: https://lore.kernel.org/r/20240328013603.206764-11-wedsonaf@gmail.com
Signed-off-by: Miguel Ojeda <ojeda@kernel.org>
This commit is contained in:
Wedson Almeida Filho 2024-03-27 22:36:03 -03:00 committed by Miguel Ojeda
parent c34aa00d1d
commit 2c1092853f
9 changed files with 14 additions and 15 deletions

View File

@ -8,6 +8,10 @@
pub mod box_ext; pub mod box_ext;
pub mod vec_ext; pub mod vec_ext;
/// Indicates an allocation error.
#[derive(Copy, Clone, PartialEq, Eq, Debug)]
pub struct AllocError;
/// Flags to be used when allocating memory. /// Flags to be used when allocating memory.
/// ///
/// They can be combined with the operators `|`, `&`, and `!`. /// They can be combined with the operators `|`, `&`, and `!`.

View File

@ -2,9 +2,8 @@
//! Extensions to [`Box`] for fallible allocations. //! Extensions to [`Box`] for fallible allocations.
use super::Flags; use super::{AllocError, Flags};
use alloc::boxed::Box; use alloc::boxed::Box;
use core::alloc::AllocError;
use core::mem::MaybeUninit; use core::mem::MaybeUninit;
use core::result::Result; use core::result::Result;

View File

@ -2,8 +2,8 @@
//! Extensions to [`Vec`] for fallible allocations. //! Extensions to [`Vec`] for fallible allocations.
use super::Flags; use super::{AllocError, Flags};
use alloc::{alloc::AllocError, vec::Vec}; use alloc::vec::Vec;
use core::result::Result; use core::result::Result;
/// Extensions to [`Vec`]. /// Extensions to [`Vec`].

View File

@ -4,9 +4,9 @@
//! //!
//! C header: [`include/uapi/asm-generic/errno-base.h`](srctree/include/uapi/asm-generic/errno-base.h) //! C header: [`include/uapi/asm-generic/errno-base.h`](srctree/include/uapi/asm-generic/errno-base.h)
use crate::str::CStr; use crate::{alloc::AllocError, str::CStr};
use alloc::alloc::{AllocError, LayoutError}; use alloc::alloc::LayoutError;
use core::convert::From; use core::convert::From;
use core::fmt; use core::fmt;

View File

@ -211,14 +211,13 @@
//! [`pin_init!`]: crate::pin_init! //! [`pin_init!`]: crate::pin_init!
use crate::{ use crate::{
alloc::{box_ext::BoxExt, Flags}, alloc::{box_ext::BoxExt, AllocError, Flags},
error::{self, Error}, error::{self, Error},
sync::UniqueArc, sync::UniqueArc,
types::{Opaque, ScopeGuard}, types::{Opaque, ScopeGuard},
}; };
use alloc::boxed::Box; use alloc::boxed::Box;
use core::{ use core::{
alloc::AllocError,
cell::UnsafeCell, cell::UnsafeCell,
convert::Infallible, convert::Infallible,
marker::PhantomData, marker::PhantomData,

View File

@ -12,7 +12,6 @@
//! do so first instead of bypassing this crate. //! do so first instead of bypassing this crate.
#![no_std] #![no_std]
#![feature(allocator_api)]
#![feature(coerce_unsized)] #![feature(coerce_unsized)]
#![feature(dispatch_from_dyn)] #![feature(dispatch_from_dyn)]
#![feature(new_uninit)] #![feature(new_uninit)]

View File

@ -2,8 +2,7 @@
//! String representations. //! String representations.
use crate::alloc::{flags::*, vec_ext::VecExt}; use crate::alloc::{flags::*, vec_ext::VecExt, AllocError};
use alloc::alloc::AllocError;
use alloc::vec::Vec; use alloc::vec::Vec;
use core::fmt::{self, Write}; use core::fmt::{self, Write};
use core::ops::{self, Deref, DerefMut, Index}; use core::ops::{self, Deref, DerefMut, Index};

View File

@ -16,7 +16,7 @@
//! [`Arc`]: https://doc.rust-lang.org/std/sync/struct.Arc.html //! [`Arc`]: https://doc.rust-lang.org/std/sync/struct.Arc.html
use crate::{ use crate::{
alloc::{box_ext::BoxExt, Flags}, alloc::{box_ext::BoxExt, AllocError, Flags},
bindings, bindings,
error::{self, Error}, error::{self, Error},
init::{self, InPlaceInit, Init, PinInit}, init::{self, InPlaceInit, Init, PinInit},
@ -25,7 +25,7 @@
}; };
use alloc::boxed::Box; use alloc::boxed::Box;
use core::{ use core::{
alloc::{AllocError, Layout}, alloc::Layout,
fmt, fmt,
marker::{PhantomData, Unsize}, marker::{PhantomData, Unsize},
mem::{ManuallyDrop, MaybeUninit}, mem::{ManuallyDrop, MaybeUninit},

View File

@ -132,9 +132,8 @@
//! //!
//! C header: [`include/linux/workqueue.h`](srctree/include/linux/workqueue.h) //! C header: [`include/linux/workqueue.h`](srctree/include/linux/workqueue.h)
use crate::alloc::Flags; use crate::alloc::{AllocError, Flags};
use crate::{bindings, prelude::*, sync::Arc, sync::LockClassKey, types::Opaque}; use crate::{bindings, prelude::*, sync::Arc, sync::LockClassKey, types::Opaque};
use alloc::alloc::AllocError;
use alloc::boxed::Box; use alloc::boxed::Box;
use core::marker::PhantomData; use core::marker::PhantomData;
use core::pin::Pin; use core::pin::Pin;