Skip to main content

Tool for decoding Silvair UART protocol.

Project description

UART Decoder

About The Repository

UART Decoder is a python library for parsing Silvair UART protocol messages. It also includes two applications that could be used for message parsing:

  • HLA Extension for Saleae Logic 2.
  • Python script for parsing .csv file with serial values for Saleae Logic 1.

Recommended way is to use Logic 2 and HLA extension. Python script could be unstable in future versions.

Built With

UART Decoder is using construct python library to parse all UART messages. Also, it validates CRC value using Crcmod package. All used packages can be obtained from setup.py file.

Getting Started

How to start with HLA Extension?

Tested on Ubuntu 20.04 with Python 3.8 and Windows 11 with Python 3.10

  1. Make sure, you have Python with at least 3.6 version and installed pip.
  2. Install UART-Decoder using pip: pip install UART-decoder. WARNING: If The script is installed in directory, which is not PATH will appear during installation, add this directory to PATH environment variable.
  3. In terminal, call generate_uart_decoder_extension <PATH> executable, where PATH is directory when you want to install HLA Extension. Example: generate_uart_decoder_extension . to install in current directory. SilvairUARTDecoder folder should be generated under passed path.
  4. Open Logic 2, click "Extensions" icon on right side.
  5. In upper-right corner should be three dots with "Load existing extensions" option. Click it.
  6. Load extension.json located in previously generated SilvairUARTDecoder directory.
  7. Click "Analyzers" icon on right side.
  8. Load Async Serial analyzer for appropriate channel, and then load Silvair UART Decoder.
  9. Hooray, Silvair UART messages should be described above waveforms! :)

Screenshots

How to start with Python script?

  1. Make sure, you have Python with at least 3.6 version and installed pip.
  2. Install UART-Decoder using pip: pip install UART-decoder. WARNING: If The script is installed in directory, which is not PATH will appear during installation, add this directory to PATH environment variable.
  3. Run application using command:
python -m silvair_uart_decoder.main 

Pass -h parameter to show help with instruction how to use script.

Parameters:

  • -f or --format-converter: input format converter (optional)
  • -O or --output-file: output file path (result will be saved in this file) (optional)
  • input csv file (required)

Supported input format converters

Currently two input format decoders are available:

  • default - data must be in format: <timestamp>,<label>,<uart_command_frame>
  • saleae - data must be in format: <timestamp>,<label>,<byte> (default Saleae export format).

Example

Parse logs stored in example.csv from Logic 1, and save it to example.txt. example.csv is in saleae Logic 1 format:

python -m silvair_uart_decoder.main -f saleae -O example.txt example.csv 

How to export data from Logic 1?

  1. Open Logic 1 with measurements
  2. Add Async Serial analyzers for appropriate channels
  3. Click on gear circle near Decoded Protocols
  4. Click Export search results

Screenshots

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

silvair-uart-decoder-0.1.2.tar.gz (18.7 kB view details)

Uploaded Source

File details

Details for the file silvair-uart-decoder-0.1.2.tar.gz.

File metadata

  • Download URL: silvair-uart-decoder-0.1.2.tar.gz
  • Upload date:
  • Size: 18.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.8.10

File hashes

Hashes for silvair-uart-decoder-0.1.2.tar.gz
Algorithm Hash digest
SHA256 a64abcf2f85ede55d6bf8180a78aba5395860feee426fd7447486c90ea9f7b33
MD5 0e512ccdac863483d660a7f3718bde25
BLAKE2b-256 52edacd60c6547425511428b3cb6a8006ac41e923141df407931a1c12cb849f8

See more details on using hashes here.

Supported by

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