# ch32v1
This crate provides an autogenerated API for access to CH32V1 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/ch32v1/latest/ch32v1/
## 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.ch32v1]
version = "0.1.6"
features = ["ch32v103"]
```
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 ch32v1::ch32v103;
let mut peripherals = ch32v103::Peripherals::take().unwrap();
let gpioa = &peripherals.GPIOA;