Struct MemoryMapTag

Source
#[repr(C, align(8))]
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

Source

pub fn new(areas: &[MemoryArea]) -> Box<Self>

Constructs a new tag.

Source

pub const fn entry_size(&self) -> u32

Returns the entry size.

Source

pub const fn entry_version(&self) -> u32

Returns the entry version.

Source

pub fn memory_areas(&self) -> &[MemoryArea]

Return the slice of the provided MemoryAreas.

Usually, this should already reflect the memory consumed by the code running this.

Trait Implementations§

Source§

impl Debug for MemoryMapTag

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl MaybeDynSized for MemoryMapTag

Source§

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 more
Source§

type Header = TagHeader

The associated Header of this tag.
Source§

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 header(&self) -> &Self::Header

Returns the corresponding Header.
Source§

fn payload(&self) -> &[u8]

Returns the payload, i.e., all memory that is not occupied by the Header of the type.
Source§

fn as_bytes(&self) -> BytesRef<'_, Self::Header>

Returns the whole allocated bytes for this structure encapsulated in BytesRef. This includes padding bytes. To only get the “true” tag data, read the tag size from Self::header and create a sub slice.
Source§

fn as_ptr(&self) -> *const Self::Header

Returns a pointer to this structure.
Source§

impl PartialEq for MemoryMapTag

Source§

fn eq(&self, other: &MemoryMapTag) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Pointee for MemoryMapTag

Source§

type Metadata = <[MemoryArea] as Pointee>::Metadata

The metadata type for pointers and references to this type.
Source§

impl Tag for MemoryMapTag

Source§

const ID: TagType = TagType::Mmap

The ID of this tag. This should be unique across all implementors. Read more
Source§

type IDType = TagType

The ID type that identifies the tag.
Source§

impl Eq for MemoryMapTag

Source§

impl StructuralPartialEq for MemoryMapTag

Auto Trait Implementations§

§

impl Freeze for MemoryMapTag

§

impl RefUnwindSafe for MemoryMapTag

§

impl Send for MemoryMapTag

§

impl !Sized for MemoryMapTag

§

impl Sync for MemoryMapTag

§

impl Unpin for MemoryMapTag

§

impl UnwindSafe for MemoryMapTag

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more