Skip to main content

Chriesibaum's BSDL file parser

Project description

Chriesibaum's BSDL File Parser

pypi python
Tests Status Coverage Status

When I was tinkering around with JTAG and BSDL files, I realized that there was no truly functional BSDL file parser for Python. Perhaps I simply didn't search hard enough. In any case, many packages are no longer up to date or have broken dependencies. Let's get our hands dirty - a few moments later and here is what I needed. If you can use it too, I'm happy to receive any inputs.

Basic usage:

Download and install the package from pypi.org. It's recommended to install the package into a virtual Python environment.

pip install cb_bsdl_parser

There are two tools available to examine BSDL files:

  • cb_bsdl_check: To check a BSDL file
  • cb_bsdl_info: To get basic data and info from a BSDL file
cb_bsdl_check <bsdl_file> [options]
cb_bsdl_info <bsdl_file> [--cell CELL] [--print-bsr-table]

To use it in your Python project, create a BSDL object and extract the needed data:

bsdl = CBBsdl('bsdl_file.bsdl')

bsdl.get_entity_name()

# get the pin mapping as a dict:
pin_map = bsdl.get_pin_map()

# or just print the boundary scan table:
bsdl.print_bsr_table()

There is a handful of more methods available to extract other data from the BSDL file.

Development

Dev tool installation

The development is mainly being done on an Ubuntu 24.04 box. To set up a dev environment, use Python 3 and install the following packages:

pip install -r requirements.txt
pip install -r requirements_dev.txt

To use antlr4, install it from the deb package sources/store:

sudo apt install antlr4

About Café - The source of coding! ;-)

Do you like this project and would like to support it? I am delighted about every single Café- It keeps me running! Or would you sponsor the project on github sponsors? Thanks for your support!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cb_bsdl_parser-0.7.0.tar.gz (148.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cb_bsdl_parser-0.7.0-py3-none-any.whl (63.6 kB view details)

Uploaded Python 3

File details

Details for the file cb_bsdl_parser-0.7.0.tar.gz.

File metadata

  • Download URL: cb_bsdl_parser-0.7.0.tar.gz
  • Upload date:
  • Size: 148.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cb_bsdl_parser-0.7.0.tar.gz
Algorithm Hash digest
SHA256 44e57ccaccb978be8250dc6eb1d176168a7a17f55364ff1780bf8a162cf216ea
MD5 11ee98d1ae45dd225ce0c7154927d5a1
BLAKE2b-256 b3bb5d4be7d2eb78c9793682982fef8806ce5a67c27ce1c45ae922e804d7e2bc

See more details on using hashes here.

Provenance

The following attestation bundles were made for cb_bsdl_parser-0.7.0.tar.gz:

Publisher: publish_to_pypi.yml on chriesibaum/cb_bsdl_parser

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cb_bsdl_parser-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: cb_bsdl_parser-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 63.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cb_bsdl_parser-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d3d6d61cf5539a44041953c527cead7c9b17973ff740b04c098318eb47476f4d
MD5 4365940d5339932758502ba532b9d5b0
BLAKE2b-256 b0b343c2a5f32b04b5c58756e048d140bdd158b837366f431e61cb7bf69346a2

See more details on using hashes here.

Provenance

The following attestation bundles were made for cb_bsdl_parser-0.7.0-py3-none-any.whl:

Publisher: publish_to_pypi.yml on chriesibaum/cb_bsdl_parser

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page