Struct BootloaderConfig

Source
#[non_exhaustive]
pub struct BootloaderConfig { pub version: ApiVersion, pub mappings: Mappings, pub kernel_stack_size: u64, pub frame_buffer: FrameBuffer, }
Expand description

Allows configuring the bootloader behavior.

TODO: describe use together with entry_point macro TODO: example

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§version: ApiVersion

The version of the bootloader API.

Automatically generated from the crate version. Checked on deserialization to ensure that the kernel and bootloader use the same API version, i.e. the same config and boot info format.

§mappings: Mappings

Configuration for (optional) page table mappings created by the bootloader.

§kernel_stack_size: u64

The size of the stack that the bootloader should allocate for the kernel (in bytes).

The bootloader starts the kernel with a valid stack pointer. This setting defines the stack size that the bootloader should allocate and map.

The stack is created with a additional guard page, so a stack overflow will lead to a page fault.

§frame_buffer: FrameBuffer
👎Deprecated since 0.11.1: The frame buffer is now configured through the BootConfig struct when creating the bootable disk image

Configuration for the frame buffer that can be used by the kernel to display pixels on the screen.

Implementations§

Source§

impl BootloaderConfig

Source

pub const fn new_default() -> Self

Creates a new default configuration with the following values:

Source

pub const fn serialize(&self) -> [u8; 124]

Serializes the configuration to a byte array.

This is used by the [crate::entry_point] macro to store the configuration in a dedicated section in the resulting ELF file.

Source

pub fn deserialize(serialized: &[u8]) -> Result<Self, &'static str>

Tries to deserialize a config byte array that was created using Self::serialize.

This is used by the bootloader to deserialize the configuration given in the kernel’s ELF file.

TODO: return error enum

Trait Implementations§

Source§

impl Clone for BootloaderConfig

Source§

fn clone(&self) -> BootloaderConfig

Returns a copy of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for BootloaderConfig

Source§

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

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

impl Default for BootloaderConfig

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl PartialEq for BootloaderConfig

Source§

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

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

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 Copy for BootloaderConfig

Source§

impl Eq for BootloaderConfig

Source§

impl StructuralPartialEq for BootloaderConfig

Auto Trait Implementations§

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

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

Source§

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

Mutably borrows from an owned value. Read more
Source§

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

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

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

Source§

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, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

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

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

Performs the conversion.
Source§

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

Source§

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

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

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

Performs the conversion.