https://github.com/rahix/atdf2svd
  
  
    Converter from Atmel's atdf format to CMSIS SVD 
    https://github.com/rahix/atdf2svd
  
atdf avr avr-rust cmsis-svd microcontroller rust
        Last synced: 7 months ago 
        JSON representation
    
Converter from Atmel's atdf format to CMSIS SVD
- Host: GitHub
- URL: https://github.com/rahix/atdf2svd
- Owner: Rahix
- License: gpl-3.0
- Created: 2019-05-07T18:37:26.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2025-03-01T04:32:05.000Z (8 months ago)
- Last Synced: 2025-03-31T12:06:56.976Z (7 months ago)
- Topics: atdf, avr, avr-rust, cmsis-svd, microcontroller, rust
- Language: Rust
- Size: 440 KB
- Stars: 19
- Watchers: 4
- Forks: 11
- Open Issues: 6
- 
            Metadata Files:
            - Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
 
Awesome Lists containing this project
README
          atdf2svd [](https://crates.io/crates/atdf2svd) [](https://github.com/Rahix/atdf2svd/actions/workflows/ci.yml)
========
A converter tool that converts Atmel's *atdf* files into *svd*.  The primary usecase for this is to then use the *svd* files with `svd2rust` to create safe abstractions for register access.
## Usage
```
USAGE:
    atdf2svd  [svd_path]
```
## Installation
Install *atdf2svd* using
```shell-session
$ cargo install -f atdf2svd
```
## Notes
### Automatic Changes
There are two "post-processors" running after the conversion ([`patch.rs`](src/atdf/patch.rs)):
- `signals_to_port_fields`: Patches the registers for all `PORTx` peripherals to contain fields for each existing pin.  Pin IDs are taken from the `` tag of the port instance.
- `remove_unsafe_cpu_regs`: Removes the `SREG`(Status Register) and `SP`(Stack Pointer) registers as they should not be safely accessible.
### Manual Changes
Unfortunately, the provided *atdf* files are often not completely correct or contain undescriptive names.  One big issue is that enumerated values are often just named `VAL_0xXX`.  I recommend patching the generated *svd* files using the patch tool written by the [stm32-rs](https://github.com/stm32-rs/stm32-rs#device-and-peripheral-yaml-format) project.
## License
`atdf2svd` is licensed under the `GPL v3` license.  See [LICENSE](LICENSE) or  for more info.