#memory-map #firmware #boot #efi #service #api-bindings #abstraction

no-std uefi

This crate makes it easy to develop Rust software that leverages safe, convenient, and performant abstractions for UEFI functionality

44 releases (breaking)

0.33.0 Oct 24, 2024
0.31.0 Aug 21, 2024
0.29.0 Jul 3, 2024
0.27.0 Mar 17, 2024
0.1.2 Feb 15, 2016

#46 in Embedded development

Download history 10537/week @ 2024-09-20 8883/week @ 2024-09-27 10829/week @ 2024-10-04 9467/week @ 2024-10-11 11593/week @ 2024-10-18 11780/week @ 2024-10-25 11931/week @ 2024-11-01 10409/week @ 2024-11-08 8775/week @ 2024-11-15 8193/week @ 2024-11-22 8756/week @ 2024-11-29 12201/week @ 2024-12-06 12837/week @ 2024-12-13 7452/week @ 2024-12-20 9073/week @ 2024-12-27 10882/week @ 2025-01-03

42,480 downloads per month
Used in 8 crates

MPL-2.0 license

1MB
20K SLoC

uefi

Rusty wrapper for the Unified Extensible Firmware Interface.

This crate makes it easy to develop Rust software that leverages safe, convenient, and performant abstractions for UEFI functionality.

Crates.io Docs.rs License Build status Stars

Value-add and Use Cases

uefi supports writing code for both pre- and post-exit boot services epochs, but its true strength shines when you create UEFI images that heavily interact with UEFI boot services. Still, you have the flexibility to just integrate selected types and abstractions into your project, for example to parse the UEFI memory map.

Note that for producing UEFI images, you also need to use a corresponding uefi compiler target of Rust, such as x86_64-unknown-uefi.

API and User Documentation

Please refer to docs.rs for comprehensive documentation of the latest stable release. The latest not necessarily yet published documentation can be found in src/lib.rs, which can also be locally viewed by running $ cargo xtask doc --open.

For an introduction to the uefi-rs project and this repository, please refer to our main README.

Dependencies

~2MB
~43K SLoC