131d94d8fSWedson Almeida Filho // SPDX-License-Identifier: GPL-2.0 231d94d8fSWedson Almeida Filho 331d94d8fSWedson Almeida Filho //! Extensions to the [`alloc`] crate. 431d94d8fSWedson Almeida Filho 531d94d8fSWedson Almeida Filho #[cfg(not(test))] 631d94d8fSWedson Almeida Filho #[cfg(not(testlib))] 731d94d8fSWedson Almeida Filho mod allocator; 808d3f549SWedson Almeida Filho pub mod box_ext; 903989773SWedson Almeida Filho pub mod vec_ext; 10b6a006e2SWedson Almeida Filho 112c109285SWedson Almeida Filho /// Indicates an allocation error. 122c109285SWedson Almeida Filho #[derive(Copy, Clone, PartialEq, Eq, Debug)] 132c109285SWedson Almeida Filho pub struct AllocError; 142c109285SWedson Almeida Filho 15b6a006e2SWedson Almeida Filho /// Flags to be used when allocating memory. 16b6a006e2SWedson Almeida Filho /// 17b6a006e2SWedson Almeida Filho /// They can be combined with the operators `|`, `&`, and `!`. 18b6a006e2SWedson Almeida Filho /// 19b6a006e2SWedson Almeida Filho /// Values can be used from the [`flags`] module. 20b6a006e2SWedson Almeida Filho #[derive(Clone, Copy)] 21b6a006e2SWedson Almeida Filho pub struct Flags(u32); 22b6a006e2SWedson Almeida Filho 23b6a006e2SWedson Almeida Filho impl core::ops::BitOr for Flags { 24b6a006e2SWedson Almeida Filho type Output = Self; 25b6a006e2SWedson Almeida Filho fn bitor(self, rhs: Self) -> Self::Output { 26b6a006e2SWedson Almeida Filho Self(self.0 | rhs.0) 27b6a006e2SWedson Almeida Filho } 28b6a006e2SWedson Almeida Filho } 29b6a006e2SWedson Almeida Filho 30b6a006e2SWedson Almeida Filho impl core::ops::BitAnd for Flags { 31b6a006e2SWedson Almeida Filho type Output = Self; 32b6a006e2SWedson Almeida Filho fn bitand(self, rhs: Self) -> Self::Output { 33b6a006e2SWedson Almeida Filho Self(self.0 & rhs.0) 34b6a006e2SWedson Almeida Filho } 35b6a006e2SWedson Almeida Filho } 36b6a006e2SWedson Almeida Filho 37b6a006e2SWedson Almeida Filho impl core::ops::Not for Flags { 38b6a006e2SWedson Almeida Filho type Output = Self; 39b6a006e2SWedson Almeida Filho fn not(self) -> Self::Output { 40b6a006e2SWedson Almeida Filho Self(!self.0) 41b6a006e2SWedson Almeida Filho } 42b6a006e2SWedson Almeida Filho } 43b6a006e2SWedson Almeida Filho 44b6a006e2SWedson Almeida Filho /// Allocation flags. 45b6a006e2SWedson Almeida Filho /// 46b6a006e2SWedson Almeida Filho /// These are meant to be used in functions that can allocate memory. 47b6a006e2SWedson Almeida Filho pub mod flags { 48b6a006e2SWedson Almeida Filho use super::Flags; 49b6a006e2SWedson Almeida Filho 50b6a006e2SWedson Almeida Filho /// Zeroes out the allocated memory. 51b6a006e2SWedson Almeida Filho /// 52b6a006e2SWedson Almeida Filho /// This is normally or'd with other flags. 53b6a006e2SWedson Almeida Filho pub const __GFP_ZERO: Flags = Flags(bindings::__GFP_ZERO); 54b6a006e2SWedson Almeida Filho 55b6a006e2SWedson Almeida Filho /// Users can not sleep and need the allocation to succeed. 56b6a006e2SWedson Almeida Filho /// 57b6a006e2SWedson Almeida Filho /// A lower watermark is applied to allow access to "atomic reserves". The current 58b6a006e2SWedson Almeida Filho /// implementation doesn't support NMI and few other strict non-preemptive contexts (e.g. 59b6a006e2SWedson Almeida Filho /// raw_spin_lock). The same applies to [`GFP_NOWAIT`]. 60b6a006e2SWedson Almeida Filho pub const GFP_ATOMIC: Flags = Flags(bindings::GFP_ATOMIC); 61b6a006e2SWedson Almeida Filho 62b6a006e2SWedson Almeida Filho /// Typical for kernel-internal allocations. The caller requires ZONE_NORMAL or a lower zone 63b6a006e2SWedson Almeida Filho /// for direct access but can direct reclaim. 64b6a006e2SWedson Almeida Filho pub const GFP_KERNEL: Flags = Flags(bindings::GFP_KERNEL); 65b6a006e2SWedson Almeida Filho 66b6a006e2SWedson Almeida Filho /// The same as [`GFP_KERNEL`], except the allocation is accounted to kmemcg. 67b6a006e2SWedson Almeida Filho pub const GFP_KERNEL_ACCOUNT: Flags = Flags(bindings::GFP_KERNEL_ACCOUNT); 68b6a006e2SWedson Almeida Filho 69*d3ee24ccSAlice Ryhl /// For kernel allocations that should not stall for direct reclaim, start physical IO or 70b6a006e2SWedson Almeida Filho /// use any filesystem callback. It is very likely to fail to allocate memory, even for very 71b6a006e2SWedson Almeida Filho /// small allocations. 72b6a006e2SWedson Almeida Filho pub const GFP_NOWAIT: Flags = Flags(bindings::GFP_NOWAIT); 73b6a006e2SWedson Almeida Filho } 74