Bug: 326112506

Clone this repo:
  1. 2dc48d6 Migrate 5 crates to monorepo. by James Farrell · 3 months ago main
  2. 1d19727 Add patch for license file. by James Farrell · 3 months ago
  3. a5f2e4e Update Android.bp by running cargo_embargo by Inseob Kim · 3 months ago
  4. 45121fe Use FIND_CRATE to locate dependencies for acpi crate by Per Larsen · 4 months ago
  5. 16d1179 Merge "Enable cargo_embargo generation of rules.mk" into main am: 6412deb0d4 by Treehugger Robot · 7 months ago android15-tests-dev

Acpi

Build Status Version Version Version

Documentation (rsdp)

Documentation (acpi)

Documentation (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).

Contributing

Contributions are more than welcome! You can:

  • Write code - the ACPI spec is huge and there are bound to be things we don't support yet!
  • Improve our documentation!
  • Use the crates within your kernel and file bug reports and feature requests!

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).

Licence

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.