Struct multiboot2::MemoryMapTag
source · #[repr(C)]pub struct MemoryMapTag { /* private fields */ }
Expand description
This tag provides an initial host memory map (legacy boot, not UEFI).
The map provided is guaranteed to list all standard RAM that should be available for normal use. This type however includes the regions occupied by kernel, mbi, segments and modules. Kernel must take care not to overwrite these regions.
This tag may not be provided by some boot loaders on EFI platforms if EFI boot services are enabled and available for the loaded image (The EFI boot services tag may exist in the Multiboot2 boot information structure).
Implementations§
source§impl MemoryMapTag
impl MemoryMapTag
pub fn new(areas: &[MemoryArea]) -> BoxedDst<Self>
sourcepub fn entry_size(&self) -> u32
pub fn entry_size(&self) -> u32
Returns the entry size.
sourcepub fn entry_version(&self) -> u32
pub fn entry_version(&self) -> u32
Returns the entry version.
sourcepub fn memory_areas(&self) -> &[MemoryArea]
pub fn memory_areas(&self) -> &[MemoryArea]
Return the slice with all memory areas.
Trait Implementations§
source§impl Debug for MemoryMapTag
impl Debug for MemoryMapTag
source§impl PartialEq for MemoryMapTag
impl PartialEq for MemoryMapTag
source§impl Pointee for MemoryMapTagwhere
[MemoryArea]: Pointee,
impl Pointee for MemoryMapTagwhere
[MemoryArea]: Pointee,
§type Metadata = <[MemoryArea] as Pointee>::Metadata
type Metadata = <[MemoryArea] as Pointee>::Metadata
The type for metadata in pointers and references to
Self
.source§impl TagTrait for MemoryMapTag
impl TagTrait for MemoryMapTag
source§fn dst_size(base_tag: &Tag) -> usize
fn dst_size(base_tag: &Tag) -> 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.
source§unsafe fn from_base_tag<'a>(tag: &Tag) -> &'a Self
unsafe fn from_base_tag<'a>(tag: &Tag) -> &'a Self
Creates a reference to a (dynamically sized) tag type in a safe way.
DST tags need to implement a proper
Self::dst_size
implementation. Read more