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