#[repr(transparent)]
pub struct EFIMemoryAreaType(pub u32);
Expand description

The type of a memory range.

UEFI allows firmwares and operating systems to introduce new memory types in the 0x70000000..0xFFFFFFFF range. Therefore, we don’t know the full set of memory types at compile time, and it is not safe to model this C enum as a Rust enum.

Tuple Fields§

§0: u32

Implementations§

source§

impl MemoryType

source

pub const RESERVED: MemoryType = _

This enum variant is not used.

source

pub const LOADER_CODE: MemoryType = _

The code portions of a loaded UEFI application.

source

pub const LOADER_DATA: MemoryType = _

The data portions of a loaded UEFI applications, as well as any memory allocated by it.

source

pub const BOOT_SERVICES_CODE: MemoryType = _

Code of the boot drivers.

Can be reused after OS is loaded.

source

pub const BOOT_SERVICES_DATA: MemoryType = _

Memory used to store boot drivers’ data.

Can be reused after OS is loaded.

source

pub const RUNTIME_SERVICES_CODE: MemoryType = _

Runtime drivers’ code.

source

pub const RUNTIME_SERVICES_DATA: MemoryType = _

Runtime services’ code.

source

pub const CONVENTIONAL: MemoryType = _

Free usable memory.

source

pub const UNUSABLE: MemoryType = _

Memory in which errors have been detected.

source

pub const ACPI_RECLAIM: MemoryType = _

Memory that holds ACPI tables. Can be reclaimed after they are parsed.

source

pub const ACPI_NON_VOLATILE: MemoryType = _

Firmware-reserved addresses.

source

pub const MMIO: MemoryType = _

A region used for memory-mapped I/O.

source

pub const MMIO_PORT_SPACE: MemoryType = _

Address space used for memory-mapped port I/O.

source

pub const PAL_CODE: MemoryType = _

Address space which is part of the processor.

source

pub const PERSISTENT_MEMORY: MemoryType = _

Memory region which is usable and is also non-volatile.

source§

impl MemoryType

source

pub const fn custom(value: u32) -> MemoryType

Construct a custom MemoryType. Values in the range 0x80000000..=0xffffffff are free for use if you are an OS loader.

Trait Implementations§

source§

impl Clone for MemoryType

source§

fn clone(&self) -> MemoryType

Returns a copy of the value. Read more
1.0.0§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for MemoryType

source§

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

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

impl Hash for MemoryType

source§

fn hash<__H>(&self, state: &mut __H)
where __H: Hasher,

Feeds this value into the given [Hasher]. Read more
1.3.0§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given [Hasher]. Read more
source§

impl Ord for MemoryType

source§

fn cmp(&self, other: &MemoryType) -> Ordering

This method returns an [Ordering] between self and other. Read more
1.21.0§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized + PartialOrd,

Restrict a value to a certain interval. Read more
source§

impl PartialEq for MemoryType

source§

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

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

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl PartialOrd for MemoryType

source§

fn partial_cmp(&self, other: &MemoryType) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0§

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

This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0§

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

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0§

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

This method tests greater than (for self and other) and is used by the > operator. Read more
1.0.0§

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

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
source§

impl Copy for MemoryType

source§

impl Eq for MemoryType

source§

impl StructuralEq for MemoryType

source§

impl StructuralPartialEq for MemoryType

Auto Trait Implementations§

§

impl RefUnwindSafe for MemoryType

§

impl Send for MemoryType

§

impl Sync for MemoryType

§

impl Unpin for MemoryType

§

impl UnwindSafe for MemoryType

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
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of [From]<T> for U chooses to do.

source§

impl<T> Pointee for T

§

type Metadata = ()

The type for metadata in pointers and references to Self.
source§

impl<T> TagTrait for T
where T: Pointee<Metadata = ()>,

source§

fn dst_size(_: &Tag) -> <T as Pointee>::Metadata

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

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
§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.