/syzygy-tools

A collection of tools to help developers of SYZYGY carriers and peripherals

Primary LanguageC++MIT LicenseMIT

SYZYGY Tools

Overview

The SYZYGY Tools package provides a suite of applications to assist developers of SYZYGY compatible carriers and peripherals.

These tools include:

  • smartvio/syzygy.(h,c) - A library that can be used to parse SYZYGY DNA data and determine an appropriate VIO voltage for a set of peripherals.

  • smartvio/smartvio-test.cpp - A test suite for the syzygy.(h,c) library.

  • dna-tools - Applications for generating SYZYGY DNA blobs that can be written to peripheral MCUs.

  • szg-dna - Human readable SYZYGY DNA JSON config files for Opal Kelly peripherals.

** Warning **

You should not attempt to flash firmware/DNA onto SYZYGY pods while they are connected to an Opal Kelly carrier that supports device sensors or any other carrier that automatically polls the SDA/SCL lines. The pMCU may share its SDA/SCL lines with the programming interface (this is the case for the ATTINY44a). I2C traffic during programming can interrupt write/read/verify operations and may possibly put the pMCU in an unrecoverable state. Carriers that support device sensors have consistent I2C traffic to poll those sensors. It is highly recommended to disconnect a pod from the SYZYGY port and supply external 3.3V power while programming pMCU firmware/DNA.

SmartVIO Library

The SmartVIO library consists of a C header file (syzygy.h) along with C source code (syzygy.c). The library includes a set of useful definitions and structures for working with DNA data. It also includes functions for parsing DNA data, solving for a VIO voltage from a group of pods, and calculating the CRC-16 used in the DNA.

Note that some modification will be required to integrate the library with a SmartVIO controller, as the set number of ports and VIO groups will change based on the requirements of a particular carrier.

A test application smartvio-test is provided as a test suite for the SmartVIO solver algorithm. This test is based on the Catch library.

DNA Tools Applications

There are Python and C++ based tools provided in the dna-tools folder for generating the binary DNA blobs from a JSON-formatted DNA file. See the readme in that folder for usage information about the tools. Example JSON files for Opal Kelly peripherals are provided in the szg-dna folder.

Building

A Makefile is provided to assist with building this design. Simply run the "make" command on a system with the necessary development tools installed to build all provided applications. Note that the dna-writer and smartvio-test applications require C++ 11 support. The JSON library used by dna-writer requires GCC 4.9 or later.

Individual applications can be built by running make <application>.

Running make runtests will build everything needed to run the smartvio-test application and execute the tests.

This build has been tested on a machine running Ubuntu 16.04 LTS with GCC 5.4.0.