pub struct PhysicalPageFlags(/* private fields */);
Expand description
Represents the fields and flags in a page table entry for a memory page.
Implementations§
Source§impl PhysicalPageFlags
impl PhysicalPageFlags
Sourcepub const LOCKED: PhysicalPageFlags
pub const LOCKED: PhysicalPageFlags
The page is being locked for exclusive access, e.g. by undergoing read/write IO
Sourcepub const ERROR: PhysicalPageFlags
pub const ERROR: PhysicalPageFlags
IO error occurred
Sourcepub const REFERENCED: PhysicalPageFlags
pub const REFERENCED: PhysicalPageFlags
The page has been referenced since last LRU list enqueue/requeue
Sourcepub const UPTODATE: PhysicalPageFlags
pub const UPTODATE: PhysicalPageFlags
The page has up-to-date data. ie. for file backed page: (in-memory data revision >= on-disk one)
Sourcepub const DIRTY: PhysicalPageFlags
pub const DIRTY: PhysicalPageFlags
The page has been written to, hence contains new data. i.e. for file backed page: (in-memory data revision > on-disk one)
Sourcepub const LRU: PhysicalPageFlags
pub const LRU: PhysicalPageFlags
The page is in one of the LRU lists
Sourcepub const ACTIVE: PhysicalPageFlags
pub const ACTIVE: PhysicalPageFlags
The page is in the active LRU list
Sourcepub const SLAB: PhysicalPageFlags
pub const SLAB: PhysicalPageFlags
The page is managed by the SLAB/SLOB/SLUB/SLQB kernel memory allocator. When compound page is used, SLUB/SLQB will only set this flag on the head page; SLOB will not flag it at all
Sourcepub const WRITEBACK: PhysicalPageFlags
pub const WRITEBACK: PhysicalPageFlags
The page is being synced to disk
Sourcepub const RECLAIM: PhysicalPageFlags
pub const RECLAIM: PhysicalPageFlags
The page will be reclaimed soon after its pageout IO completed
Sourcepub const BUDDY: PhysicalPageFlags
pub const BUDDY: PhysicalPageFlags
A free memory block managed by the buddy system allocator. The buddy system organizes free memory in blocks of various orders. An order N block has 2^N physically contiguous pages, with the BUDDY flag set for and only for the first page
Sourcepub const MMAP: PhysicalPageFlags
pub const MMAP: PhysicalPageFlags
A memory mapped page
Sourcepub const ANON: PhysicalPageFlags
pub const ANON: PhysicalPageFlags
A memory mapped page that is not part of a file
Sourcepub const SWAPCACHE: PhysicalPageFlags
pub const SWAPCACHE: PhysicalPageFlags
The page is mapped to swap space, i.e. has an associated swap entry
Sourcepub const SWAPBACKED: PhysicalPageFlags
pub const SWAPBACKED: PhysicalPageFlags
The page is backed by swap/RAM
Sourcepub const COMPOUND_HEAD: PhysicalPageFlags
pub const COMPOUND_HEAD: PhysicalPageFlags
A compound page with order N consists of 2^N physically contiguous pages. A compound page with order 2 takes the form of “HTTT”, where H donates its head page and T donates its tail page(s). The major consumers of compound pages are hugeTLB pages (https://www.kernel.org/doc/html/latest/admin-guide/mm/hugetlbpage.html#hugetlbpage), the SLUB etc. memory allocators and various device drivers. However in this interface, only huge/giga pages are made visible to end users
Sourcepub const COMPOUND_TAIL: PhysicalPageFlags
pub const COMPOUND_TAIL: PhysicalPageFlags
A compound page tail (see description above)
Sourcepub const HUGE: PhysicalPageFlags
pub const HUGE: PhysicalPageFlags
This is an integral part of a HugeTLB page
Sourcepub const UNEVICTABLE: PhysicalPageFlags
pub const UNEVICTABLE: PhysicalPageFlags
The page is in the unevictable (non-)LRU list It is somehow pinned and not a candidate for LRU page reclaims, e.g. ramfs pages, shmctl(SHM_LOCK) and mlock() memory segments
Sourcepub const HWPOISON: PhysicalPageFlags
pub const HWPOISON: PhysicalPageFlags
Hardware detected memory corruption on this page: don’t touch the data!
Sourcepub const NOPAGE: PhysicalPageFlags
pub const NOPAGE: PhysicalPageFlags
No page frame exists at the requested address
Sourcepub const KSM: PhysicalPageFlags
pub const KSM: PhysicalPageFlags
Identical memory pages dynamically shared between one or more processes
Sourcepub const THP: PhysicalPageFlags
pub const THP: PhysicalPageFlags
Contiguous pages which construct transparent hugepages
Sourcepub const OFFLINE: PhysicalPageFlags
pub const OFFLINE: PhysicalPageFlags
The page is logically offline
Sourcepub const ZERO_PAGE: PhysicalPageFlags
pub const ZERO_PAGE: PhysicalPageFlags
Zero page for pfn_zero or huge_zero page
Sourcepub const IDLE: PhysicalPageFlags
pub const IDLE: PhysicalPageFlags
The page has not been accessed since it was marked idle (see https://www.kernel.org/doc/html/latest/admin-guide/mm/idle_page_tracking.html#idle-page-tracking). Note that this flag may be stale in case the page was accessed via a PTE. To make sure the flag is up-to-date one has to read /sys/kernel/mm/page_idle/bitmap first
Sourcepub const PGTABLE: PhysicalPageFlags
pub const PGTABLE: PhysicalPageFlags
The page is in use as a page table
Source§impl PhysicalPageFlags
impl PhysicalPageFlags
Sourcepub const fn empty() -> PhysicalPageFlags
pub const fn empty() -> PhysicalPageFlags
Get a flags value with all bits unset.
Sourcepub const fn all() -> PhysicalPageFlags
pub const fn all() -> PhysicalPageFlags
Get a flags value with all known bits set.
Sourcepub const fn bits(&self) -> u64
pub const fn bits(&self) -> u64
Get the underlying bits value.
The returned value is exactly the bits set in this flags value.
Sourcepub const fn from_bits(bits: u64) -> Option<PhysicalPageFlags>
pub const fn from_bits(bits: u64) -> Option<PhysicalPageFlags>
Convert from a bits value.
This method will return None
if any unknown bits are set.
Sourcepub const fn from_bits_truncate(bits: u64) -> PhysicalPageFlags
pub const fn from_bits_truncate(bits: u64) -> PhysicalPageFlags
Convert from a bits value, unsetting any unknown bits.
Sourcepub const fn from_bits_retain(bits: u64) -> PhysicalPageFlags
pub const fn from_bits_retain(bits: u64) -> PhysicalPageFlags
Convert from a bits value exactly.
Sourcepub fn from_name(name: &str) -> Option<PhysicalPageFlags>
pub fn from_name(name: &str) -> Option<PhysicalPageFlags>
Get a flags value with the bits of a flag with the given name set.
This method will return None
if name
is empty or doesn’t
correspond to any named flag.
Sourcepub const fn intersects(&self, other: PhysicalPageFlags) -> bool
pub const fn intersects(&self, other: PhysicalPageFlags) -> bool
Whether any set bits in a source flags value are also set in a target flags value.
Sourcepub const fn contains(&self, other: PhysicalPageFlags) -> bool
pub const fn contains(&self, other: PhysicalPageFlags) -> bool
Whether all set bits in a source flags value are also set in a target flags value.
Sourcepub fn insert(&mut self, other: PhysicalPageFlags)
pub fn insert(&mut self, other: PhysicalPageFlags)
The bitwise or (|
) of the bits in two flags values.
Sourcepub fn remove(&mut self, other: PhysicalPageFlags)
pub fn remove(&mut self, other: PhysicalPageFlags)
The intersection of a source flags value with the complement of a target flags value (&!
).
This method is not equivalent to self & !other
when other
has unknown bits set.
remove
won’t truncate other
, but the !
operator will.
Sourcepub fn toggle(&mut self, other: PhysicalPageFlags)
pub fn toggle(&mut self, other: PhysicalPageFlags)
The bitwise exclusive-or (^
) of the bits in two flags values.
Sourcepub fn set(&mut self, other: PhysicalPageFlags, value: bool)
pub fn set(&mut self, other: PhysicalPageFlags, value: bool)
Call insert
when value
is true
or remove
when value
is false
.
Sourcepub const fn intersection(self, other: PhysicalPageFlags) -> PhysicalPageFlags
pub const fn intersection(self, other: PhysicalPageFlags) -> PhysicalPageFlags
The bitwise and (&
) of the bits in two flags values.
Sourcepub const fn union(self, other: PhysicalPageFlags) -> PhysicalPageFlags
pub const fn union(self, other: PhysicalPageFlags) -> PhysicalPageFlags
The bitwise or (|
) of the bits in two flags values.
Sourcepub const fn difference(self, other: PhysicalPageFlags) -> PhysicalPageFlags
pub const fn difference(self, other: PhysicalPageFlags) -> PhysicalPageFlags
The intersection of a source flags value with the complement of a target flags value (&!
).
This method is not equivalent to self & !other
when other
has unknown bits set.
difference
won’t truncate other
, but the !
operator will.
Sourcepub const fn symmetric_difference(
self,
other: PhysicalPageFlags,
) -> PhysicalPageFlags
pub const fn symmetric_difference( self, other: PhysicalPageFlags, ) -> PhysicalPageFlags
The bitwise exclusive-or (^
) of the bits in two flags values.
Sourcepub const fn complement(self) -> PhysicalPageFlags
pub const fn complement(self) -> PhysicalPageFlags
The bitwise negation (!
) of the bits in a flags value, truncating the result.
Source§impl PhysicalPageFlags
impl PhysicalPageFlags
Sourcepub const fn iter(&self) -> Iter<PhysicalPageFlags>
pub const fn iter(&self) -> Iter<PhysicalPageFlags>
Yield a set of contained flags values.
Each yielded flags value will correspond to a defined named flag. Any unknown bits will be yielded together as a final flags value.
Sourcepub const fn iter_names(&self) -> IterNames<PhysicalPageFlags>
pub const fn iter_names(&self) -> IterNames<PhysicalPageFlags>
Yield a set of contained named flags values.
This method is like iter
, except only yields bits in contained named flags.
Any unknown bits, or bits not corresponding to a contained flag will not be yielded.
Source§impl PhysicalPageFlags
impl PhysicalPageFlags
pub fn parse_info(info: u64) -> PhysicalPageFlags
Trait Implementations§
Source§impl Binary for PhysicalPageFlags
impl Binary for PhysicalPageFlags
Source§impl BitAnd for PhysicalPageFlags
impl BitAnd for PhysicalPageFlags
Source§fn bitand(self, other: PhysicalPageFlags) -> PhysicalPageFlags
fn bitand(self, other: PhysicalPageFlags) -> PhysicalPageFlags
The bitwise and (&
) of the bits in two flags values.
Source§type Output = PhysicalPageFlags
type Output = PhysicalPageFlags
&
operator.Source§impl BitAndAssign for PhysicalPageFlags
impl BitAndAssign for PhysicalPageFlags
Source§fn bitand_assign(&mut self, other: PhysicalPageFlags)
fn bitand_assign(&mut self, other: PhysicalPageFlags)
The bitwise and (&
) of the bits in two flags values.
Source§impl BitOr for PhysicalPageFlags
impl BitOr for PhysicalPageFlags
Source§fn bitor(self, other: PhysicalPageFlags) -> PhysicalPageFlags
fn bitor(self, other: PhysicalPageFlags) -> PhysicalPageFlags
The bitwise or (|
) of the bits in two flags values.
Source§type Output = PhysicalPageFlags
type Output = PhysicalPageFlags
|
operator.Source§impl BitOrAssign for PhysicalPageFlags
impl BitOrAssign for PhysicalPageFlags
Source§fn bitor_assign(&mut self, other: PhysicalPageFlags)
fn bitor_assign(&mut self, other: PhysicalPageFlags)
The bitwise or (|
) of the bits in two flags values.
Source§impl BitXor for PhysicalPageFlags
impl BitXor for PhysicalPageFlags
Source§fn bitxor(self, other: PhysicalPageFlags) -> PhysicalPageFlags
fn bitxor(self, other: PhysicalPageFlags) -> PhysicalPageFlags
The bitwise exclusive-or (^
) of the bits in two flags values.
Source§type Output = PhysicalPageFlags
type Output = PhysicalPageFlags
^
operator.Source§impl BitXorAssign for PhysicalPageFlags
impl BitXorAssign for PhysicalPageFlags
Source§fn bitxor_assign(&mut self, other: PhysicalPageFlags)
fn bitxor_assign(&mut self, other: PhysicalPageFlags)
The bitwise exclusive-or (^
) of the bits in two flags values.
Source§impl Clone for PhysicalPageFlags
impl Clone for PhysicalPageFlags
Source§fn clone(&self) -> PhysicalPageFlags
fn clone(&self) -> PhysicalPageFlags
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for PhysicalPageFlags
impl Debug for PhysicalPageFlags
Source§impl<'de> Deserialize<'de> for PhysicalPageFlags
impl<'de> Deserialize<'de> for PhysicalPageFlags
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<PhysicalPageFlags, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<PhysicalPageFlags, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Source§impl Extend<PhysicalPageFlags> for PhysicalPageFlags
impl Extend<PhysicalPageFlags> for PhysicalPageFlags
Source§fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = PhysicalPageFlags>,
fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = PhysicalPageFlags>,
The bitwise or (|
) of the bits in each flags value.
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one
)Source§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
extend_one
)Source§impl Flags for PhysicalPageFlags
impl Flags for PhysicalPageFlags
Source§const FLAGS: &'static [Flag<PhysicalPageFlags>]
const FLAGS: &'static [Flag<PhysicalPageFlags>]
Source§fn from_bits_retain(bits: u64) -> PhysicalPageFlags
fn from_bits_retain(bits: u64) -> PhysicalPageFlags
Source§fn from_bits_truncate(bits: Self::Bits) -> Self
fn from_bits_truncate(bits: Self::Bits) -> Self
Source§fn from_name(name: &str) -> Option<Self>
fn from_name(name: &str) -> Option<Self>
Source§fn iter_names(&self) -> IterNames<Self>
fn iter_names(&self) -> IterNames<Self>
Source§fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
Source§fn contains(&self, other: Self) -> boolwhere
Self: Sized,
fn contains(&self, other: Self) -> boolwhere
Self: Sized,
Source§fn insert(&mut self, other: Self)where
Self: Sized,
fn insert(&mut self, other: Self)where
Self: Sized,
|
) of the bits in two flags values.Source§fn remove(&mut self, other: Self)where
Self: Sized,
fn remove(&mut self, other: Self)where
Self: Sized,
&!
). Read moreSource§fn toggle(&mut self, other: Self)where
Self: Sized,
fn toggle(&mut self, other: Self)where
Self: Sized,
^
) of the bits in two flags values.Source§fn intersection(self, other: Self) -> Self
fn intersection(self, other: Self) -> Self
&
) of the bits in two flags values.Source§fn difference(self, other: Self) -> Self
fn difference(self, other: Self) -> Self
&!
). Read moreSource§fn symmetric_difference(self, other: Self) -> Self
fn symmetric_difference(self, other: Self) -> Self
^
) of the bits in two flags values.Source§fn complement(self) -> Self
fn complement(self) -> Self
!
) of the bits in a flags value, truncating the result.Source§impl FromIterator<PhysicalPageFlags> for PhysicalPageFlags
impl FromIterator<PhysicalPageFlags> for PhysicalPageFlags
Source§fn from_iter<T>(iterator: T) -> PhysicalPageFlagswhere
T: IntoIterator<Item = PhysicalPageFlags>,
fn from_iter<T>(iterator: T) -> PhysicalPageFlagswhere
T: IntoIterator<Item = PhysicalPageFlags>,
The bitwise or (|
) of the bits in each flags value.
Source§impl Hash for PhysicalPageFlags
impl Hash for PhysicalPageFlags
Source§impl IntoIterator for PhysicalPageFlags
impl IntoIterator for PhysicalPageFlags
Source§type Item = PhysicalPageFlags
type Item = PhysicalPageFlags
Source§type IntoIter = Iter<PhysicalPageFlags>
type IntoIter = Iter<PhysicalPageFlags>
Source§fn into_iter(self) -> <PhysicalPageFlags as IntoIterator>::IntoIter
fn into_iter(self) -> <PhysicalPageFlags as IntoIterator>::IntoIter
Source§impl LowerHex for PhysicalPageFlags
impl LowerHex for PhysicalPageFlags
Source§impl Not for PhysicalPageFlags
impl Not for PhysicalPageFlags
Source§fn not(self) -> PhysicalPageFlags
fn not(self) -> PhysicalPageFlags
The bitwise negation (!
) of the bits in a flags value, truncating the result.
Source§type Output = PhysicalPageFlags
type Output = PhysicalPageFlags
!
operator.Source§impl Octal for PhysicalPageFlags
impl Octal for PhysicalPageFlags
Source§impl Ord for PhysicalPageFlags
impl Ord for PhysicalPageFlags
Source§fn cmp(&self, other: &PhysicalPageFlags) -> Ordering
fn cmp(&self, other: &PhysicalPageFlags) -> Ordering
1.21.0 · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Source§impl PartialEq for PhysicalPageFlags
impl PartialEq for PhysicalPageFlags
Source§impl PartialOrd for PhysicalPageFlags
impl PartialOrd for PhysicalPageFlags
Source§impl Serialize for PhysicalPageFlags
impl Serialize for PhysicalPageFlags
Source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Source§impl Sub for PhysicalPageFlags
impl Sub for PhysicalPageFlags
Source§fn sub(self, other: PhysicalPageFlags) -> PhysicalPageFlags
fn sub(self, other: PhysicalPageFlags) -> PhysicalPageFlags
The intersection of a source flags value with the complement of a target flags value (&!
).
This method is not equivalent to self & !other
when other
has unknown bits set.
difference
won’t truncate other
, but the !
operator will.
Source§type Output = PhysicalPageFlags
type Output = PhysicalPageFlags
-
operator.Source§impl SubAssign for PhysicalPageFlags
impl SubAssign for PhysicalPageFlags
Source§fn sub_assign(&mut self, other: PhysicalPageFlags)
fn sub_assign(&mut self, other: PhysicalPageFlags)
The intersection of a source flags value with the complement of a target flags value (&!
).
This method is not equivalent to self & !other
when other
has unknown bits set.
difference
won’t truncate other
, but the !
operator will.