Skip to main content

Tool for decoding Silvair UART protocol.

Project description

Silvair UART Decoder

About The Repository

Silvair 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. Make sure, you have Python with at least 3.6 version and installed pip.

Installation:

Using Command line:

  1. Install UART-Decoder using pip: pip install silvair-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.
  2. 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 directory should be generated in passed path.

Using 'install' file

  1. Download Repository
  2. Run script according to system are you using:
    • Windows: install_windows.bat
    • Linux: install_linux.bat
  3. SilvairUARTDecoder directory should be generated in repository path.

Running Extension in Logic 2

  1. Open Logic 2, click "Extensions" icon on right side.
  2. In upper-right corner should be three dots with "Load existing extensions" option. Click it.
  3. Load extension.json located in previously generated SilvairUARTDecoder directory.
  4. Click "Analyzers" icon on right side.
  5. Load Async Serial analyzer for appropriate channel, and then load Silvair UART Decoder.
  6. 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 silvair-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:
silvair-uart-decoder

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:

silvair-uart-decoder -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.4.tar.gz (19.6 kB view details)

Uploaded Source

File details

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

File metadata

  • Download URL: silvair-uart-decoder-0.1.4.tar.gz
  • Upload date:
  • Size: 19.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for silvair-uart-decoder-0.1.4.tar.gz
Algorithm Hash digest
SHA256 b597a92c05fa9f5cc25024ce77eb08e6ba3645227958aaf1dfc2c81a9dbf4408
MD5 a09f3e46b86deb4867f2102460a25f2c
BLAKE2b-256 9080cf23ee8eed187474d013fcaa7c086c69cf7bde924469c0eac2ac66a2b874

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