# ch32v2 This crate provides an autogenerated API for access to CH32V2 peripherals. The API is generated using [svd2rust] with patched svd files containing extensive type-safe support. For more information please see the [main repo]. Refer to the [documentation] for full details. [svd2rust]: https://github.com/rust-embedded/svd2rust [main repo]: https://github.com/ch32-rs/ch32-rs [documentation]: https://docs.rs/ch32v2/latest/ch32v2/ ## Usage Each device supported by this crate is behind a feature gate so that you only compile the device(s) you want. To use, in your Cargo.toml: ```toml [dependencies.ch32v2] version = "0.1.6" features = ["ch32v20x"] ``` The `rt` feature is enabled by default and brings in support for `riscv-rt`. To disable, specify `default-features = false` in `Cargo.toml`. In your code: ```rust use ch32v2::ch32v20x; let mut peripherals = ch32v20x::Peripherals::take().unwrap(); let gpioa = &peripherals.GPIOA; gpioa.odr.modify(|_, w| w.odr0().set_bit()); ``` For full details on the autogenerated API, please see: https://docs.rs/svd2rust/0.26.0/svd2rust/#peripheral-api ## Supported Devices | Module | Devices | Links | |:------:|:-------:|:-----:|