Skip to content
forked from esp-rs/esp-pacs

Peripheral Access Crates for Espressif SoCs and modules

License

Notifications You must be signed in to change notification settings

ducktec/esp-pacs

 
 

Repository files navigation

esp-pacs

GitHub Workflow Status MIT/Apache-2.0 licensed Matrix

Peripheral Access Crates for Espressif SoCs and modules. For information on how to use these crates, please refer to the svd2rust documentation.

If you discover any errors in an SVD file, please report the issue(s) upstream in the espressif/svd repository.

Please note that in order to build the PACs for Xtensa devices (ESP32, ESP32-S2, ESP32-S3, ESP8266) you will need to first install the Rust compiler fork with Xtensa support. The minimum supported Rust version (MSRV) for these devices is 1.58.0.

Generating the PACs

We use the workflow described by cargo-xtask to automate tasks within this monorepo. Currently there is only a single task, which generates a Peripheral Access Crate (PAC) for the specified chip.

xtask

USAGE:
    xtask [OPTIONS] <CHIP>

ARGS:
    <CHIP>    Chip to target [possible values: esp32, esp32c3, esp32s2, esp32s3, esp8266]

OPTIONS:
        --generate-only    Patch the SVD and generate the PAC, but do not build it
    -h, --help             Print help information
        --patch-only       Only patch the SVD, do not generate or build the PAC

For example, to generate a PAC for the ESP32-C3 without subsequently building the crate, from the root of the repository run:

$ cargo xtask --generate-only esp32c3

License

Licensed under either of:

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

About

Peripheral Access Crates for Espressif SoCs and modules

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 100.0%