#register

no-std avr-device

Register access crate for AVR microcontrollers

19 releases

0.7.0 Jan 5, 2025
0.6.0 Sep 20, 2024
0.5.4 Jan 28, 2024
0.5.3 Nov 17, 2023
0.1.1 Jul 31, 2020

#47 in Embedded development

Download history 768/week @ 2024-09-27 458/week @ 2024-10-04 693/week @ 2024-10-11 772/week @ 2024-10-18 616/week @ 2024-10-25 726/week @ 2024-11-01 347/week @ 2024-11-08 390/week @ 2024-11-15 962/week @ 2024-11-22 887/week @ 2024-11-29 1681/week @ 2024-12-06 1808/week @ 2024-12-13 891/week @ 2024-12-20 549/week @ 2024-12-27 2304/week @ 2025-01-03 1451/week @ 2025-01-10

5,254 downloads per month
Used in 2 crates

MIT/Apache

44MB
1.5M SLoC

avr-device crates.io page docs.rs Continuous Integration

Auto-generated wrappers around registers for AVR microcontrollers.

Usage

Add the following to Cargo.toml:

[dependencies.avr-device]
version = "0.7.0"
features = ["atmega32u4"]

Via the feature you can select which chip you want the register specifications for. The following list is what is currently supported:

ATmega ATmega USB ATmega 0,1 Series AT90 ATtiny
atmega8 atmega8u2 atmega3208 at90usb1286 attiny13a
atmega48p atmega16u2 atmega3209 attiny167
atmega64 atmega32u2 atmega4808 attiny202
atmega644 atmega32u4 atmega4809 attiny212
atmega88p avr64du32 attiny214
atmega16 avr64du28 attiny402
atmega168 attiny404
atmega324pa attiny412
atmega328p attiny414
atmega328pb attiny416
atmega32a attiny44a
atmega1280 attiny84
atmega1284p attiny85
atmega128a attiny88
atmega128rfa1 attiny816
atmega2560 attiny828
atmega164pa attiny841
attiny84a
attiny861
attiny1614
attiny2313
attiny2313a

Build Instructions

The version on crates.io is pre-built. The following is only necessary when trying to build this crate from source.

You need to have atdf2svd (= 0.5.0), svd2rust (= 0.28), form (>= 0.8), rustfmt(for the nightly toolchain) and svdtools (>= 0.1.9) installed:

cargo install atdf2svd --version 0.5.0 --locked
cargo install svd2rust --version 0.28.0 --locked
cargo install form
rustup component add --toolchain nightly rustfmt
pip3 install --user svdtools

# check svdtools
svd --version
# if a "command not found" error is printed instead of a version,
# either svdtools is installed incorrectly, or its installation path is missing from the PATH variable.
# Temporary solution to PATH variable issue is to manually add the path. Like so:
export PATH=$PATH:~/.local/bin

Next, clone this repo and build the device definitions:

git clone https://github.com/Rahix/avr-device
cd avr-device
make
# You can build for just one specific chip using
# make atmega32u4
# I suggest building documentation as well
cargo +nightly doc --features <chip> --open

Internals

avr-device is generated using atdf2svd and svd2rust. The vendor-provided atdf files can be found in vendor/. The intermediate svd files are patched by svdpatch.py (Adapted from svdpatch.py in stm32-rs) with device-dependent patches in patch/, mainly to improve undescriptive names and missing descriptions.

Adding a new Chip

To add a new chip, download the atdf from http://packs.download.atmel.com/ (or avr-mcu/packs/) and place it in vendor/ note: file name may need to be modified. Be sure to name it like the Rust module that should be generated. Next, you need to integrate it into the base crate and build system. Follow what was done in commit 290613454fbd ("Add basic support for ATmega64"). Please adhere to the alphabetical sorting that is present so far.

Next, you must create a <chipname>.yaml in patch/ which has at least the following content:

_svd: ../svd/<chipname>.svd

If more patches need to be applied (most likely!), they should be added into this file as well. The patching format is documented in the svdtools README. Ideally, try to reuse the exisiting patches in patch/common/ or patch/timer/.

Finally, try building the crate for your MCU with make <chipname>.

License

avr-device is licensed under either of

at your option.

The vendored atdf files are licensed under the Apache License, Version 2.0 (LICENSE-VENDOR).

Dependencies