Skip to content

CMSIS SVD file to JSON converter for code generation

License

Notifications You must be signed in to change notification settings

fvalette-ledger/python-svd2json

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

42 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

REUSE status

PyPI - Version PyPI - License PyPI - Python Version

codecov lint unittest doc quality

Python svd2json package

This package converts a CMSIS SVD (System View Description) file into a more friendly JSon format than raw XML to JSon conversion. The aim of this package is to ease code generation from SVD file. We state that JSon format is the best suitable for this purpose. For instance, it can be used as-is in Jinja2 template processing.

JSon format

The resulting JSon root node is the device node in SVD. XML values are converted to equivalent JSon ones.

NOTE: Some SVD files might be inconsistent in peripherals and/or registers naming convention across devices or in a single SVD file. E.g. only few registers are prefixed by peripheral name but no others, you can optionally trim this prefix in order to keep code generation as simple as possible and reusable among a wide range of devices/mcu. !!ADD REF!!

An Additional interrupts is added in the resulting JSon which collects all interrupts declared across all peripherals. This can ease, for instance, VTOR table generation, one only has to walk through this array.

Script

This package exports the following script:

svd2json

$ svd2json --help
usage: svd2json [-h] -s SVD output

convert svd file to json

positional arguments:
  output             output filename

options:
  -h, --help         show this help message and exit
  -s SVD, --svd SVD  SVD file to convert

How to ...

This package follows PEP517/518/621 for its build system using a single pyproject.toml file and setuptools with dynamic versioning as build-backend. Unit testing, linting etc. are done with tox. The minimal python version is Python 3.10.

Build

One can use any python build front-end. E.g. with PyPA build front-end :

python -m build

Lint

This package is linted by black and flake8. In case of conflict between those two linter, we choose to follow black rules by default as it is closer to PEP8 than flake8.

tox -e lint

Type check

Type checking is done with mypy with a python 3.10+ syntax.

tox -e type

License check

Package license(s) can be checked using reuse.

tox -e licenses

Doc

Documentation is generated using Sphinx and using the numpy style for pythondoc with napoleon extension.

tox -e docs

Unit tests

Package Unit tests are based on pytest with coverage support.

tox -e unittests
tox -e htmlcov

License

Licensed under Apache-2.0

see LICENSE file

About

CMSIS SVD file to JSON converter for code generation

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%