#[repr(C)]pub struct EFIMemoryMapTag { /* private fields */ }
Expand description
EFI memory map tag. The embedded EFIMemoryDesc
s follows the EFI
specification.
Implementations§
Source§impl EFIMemoryMapTag
impl EFIMemoryMapTag
Sourcepub fn new_from_descs(descs: &[EFIMemoryDesc]) -> Box<Self>
pub fn new_from_descs(descs: &[EFIMemoryDesc]) -> Box<Self>
Create a new EFI memory map tag with the given memory descriptors.
Sourcepub fn new_from_map(
desc_size: u32,
desc_version: u32,
efi_mmap: &[u8],
) -> Box<Self>
pub fn new_from_map( desc_size: u32, desc_version: u32, efi_mmap: &[u8], ) -> Box<Self>
Create a new EFI memory map tag from the given EFI memory map.
Sourcepub fn memory_areas(&self) -> EFIMemoryAreaIter<'_>
pub fn memory_areas(&self) -> EFIMemoryAreaIter<'_>
Returns an iterator over the provided memory areas.
Usually, this should already reflect the memory consumed by the code running this.
Trait Implementations§
Source§impl Debug for EFIMemoryMapTag
impl Debug for EFIMemoryMapTag
Source§impl Hash for EFIMemoryMapTag
impl Hash for EFIMemoryMapTag
Source§impl MaybeDynSized for EFIMemoryMapTag
impl MaybeDynSized for EFIMemoryMapTag
Source§const BASE_SIZE: usize = 16usize
const BASE_SIZE: usize = 16usize
The true base size of the struct without any implicit or additional
padding. Note that
size_of::<T>()
isn’t sufficient, as for example
the type could have three u32
fields, which would add an implicit
u32
padding. However, this constant must always fulfill
BASE_SIZE >= size_of::<Self::Header>()
. Read moreSource§fn dst_len(header: &TagHeader) -> usize
fn dst_len(header: &TagHeader) -> usize
Returns the amount of items in the dynamically sized portion of the
DST. Note that this is not the amount of bytes. So if the dynamically
sized portion is 16 bytes in size and each element is 4 bytes big, then
this function must return 4. Read more
Source§fn payload(&self) -> &[u8]
fn payload(&self) -> &[u8]
Returns the payload, i.e., all memory that is not occupied by the
Header
of the type.