Crates.io | rsdp |
lib.rs | rsdp |
version | 2.0.1 |
source | src |
created_at | 2020-09-24 22:35:13.734871 |
updated_at | 2023-09-13 01:01:39.314685 |
description | Zero-allocation library for locating and parsing the RSDP, the first ACPI table |
homepage | |
repository | https://github.com/rust-osdev/acpi |
max_upload_size | |
id | 292689 |
size | 18,632 |
⚠️WARNING: The rsdp
crate was previously a component of the acpi
ecosystem, but has been deprecated. Its
functionality is now entirely supported by the acpi
crate, including a subset of functionality that will work in
an environment that does not have an allocator. This crate will likely not receive further updates⚠️
rsdp
)acpi
)aml
)A library to parse ACPI tables and AML, written in pure Rust. Designed to be easy to use from Rust bootloaders and kernels. The library is split into three crates:
rsdp
parses the RSDP and can locate it on BIOS platforms. It does not depend on alloc
, so is suitable to use from bootloaders without heap alloctors. All of its
functionality is reexported by acpi
.acpi
parses the static tables (useful but not feature-complete). It can be used from environments that have allocators, and ones that don't (but with reduced functionality).aml
parses the AML tables (can be useful, far from feature-complete).There is also the acpi-dumper
utility to easily dump a platform's ACPI tables (this currently only works on Linux).
Contributions are more than welcome! You can:
Useful resources for contributing are:
You can run the AML test suite with cargo run --bin aml_tester -- -p tests
.
You can run fuzz the AML parser with cd aml && cargo fuzz run fuzz_target_1
(you may need to cargo install cargo-fuzz
).
This project is dual-licenced under:
Unless you explicitly state otherwise, any contribution submitted for inclusion in this work by you, as defined in the Apache-2.0 licence, shall be dual licenced as above, without additional terms or conditions.