multiboot2-common

Crates.iomultiboot2-common
lib.rsmultiboot2-common
version0.2.1
sourcesrc
created_at2024-08-20 15:30:10.553813
updated_at2024-09-19 13:35:35.69282
descriptionCommon helpers for the `multiboot2` and `multiboot2-header` crates.
homepagehttps://github.com/rust-osdev/multiboot2/tree/main/multiboot2-common
repositoryhttps://github.com/rust-osdev/multiboot2
max_upload_size
id1345404
size1,480,971
multiboot2 (github:rust-osdev:multiboot2)

documentation

https://docs.rs/multiboot2-common

README

multiboot2-common

crates.io docs

Common helpers for the multiboot2 and multiboot2-header crates.

Architecture Diagrams

The following figures, not displayable in lib.rs / on docs.rs unfortunately, outline the design of this crate. In the following figure, you can see the four classes of Multiboot2 structures and their memory properties. The four kinds of Multiboot2 structures are boot information, boot information tags, header, and header tags. All share the same technical foundation: They have a common header and a possible dynamic size, depending on the header.

Overview Multiboot2 structures

In the next figure, you see how the types from multiboot2-common are used to parse a raw byte slice as the corresponding Multiboot2 structure a safe manner. The BytesRef wrapper ensures basic memory guarantees for the underlying &[u8] slice, while DynSizedStructure can then be used to safely cast to the target type.

Generic parsing flow overview

The next figure is like the previous figure, but shows a more specific parsing flow by using types of the multiboot2 crate. Green shows the raw memory. Purple boxes refers to logic in multiboot2-common. Red components show structs from the multiboot2 crate.

Specific parsing flow overview

The last complex figure shows all traits and structs from multiboot2-common, their internal relation, and how consumers (multiboot2 and multiboot2-header) consume them. As this figure is quite complex, we recommend to first study the inner box (multiboot2-common) and then study how types from multiboot2 (orange) and multiboot2-header (green) interface with multiboot2-common.

Architecture overview

MSRV

The MSRV is 1.75.0 stable.

License & Contribution

See main README file.

Commit count: 678

cargo fmt