Skip to main content

An assembler and simulation toolchain for the Digirule2 series of hardware.

Project description

dgtools

dgtools is a complete toolkit for developing software for the Digirule series (2A/2U) of hardware by bradsprojects.

Overview

  1. dgasm

    • The assembler, accepts a human readable .asm text file with Digirule ASM and produces:
      1. A .dgb binary file with compiled code ready for simulation by dgsim.py .
      2. A .hex file (in the case of 2U) to be downloaded to the board.
  2. dginspect

    • The binary file "inspector", accepts a .dgb binary file and produces a human readable "dump" of the full 256 byte memory range to stdout. It also allows a user to apply certain modifications to the memory space without re-compiling.
  3. dgsim

    • The Digirule Virtual Machine, accepts a .dgb binary file and produces:
      1. A human readable HTML (themeable) trace of every state change the CPU goes through at each timestep of execution.
      2. An additional .dgb file that contains the final state of the memory space at the end of program execution.

These tools work together to write, debug and simulate code for the Digirule 2 prior to transfering it to the actual hardware.

dgtools also includes some "extras", such as a Sublime text .dsf ASM plugin, a console gui (dgui) that can handle compilation/simulation in one step and a code formatter (dgform).

The most common workflow is to:

  1. Use a text editor to write human readable assembly code.
  2. Call dgasm.py to compile the binary
  3. Call dgsim.py to run and debug the binary
  4. (Alternatively, call dgui to perform both of the above in sequence)
  5. Use dginspect.py to check a binary file, get/set values from the virtual machine or key the code in.

Installation

Pre-requisites

  1. Linux
  2. Python >=3.6
  3. virtualenv

Install from PyPi with pip

  • pip install dgtools

Install latest development version

  1. Checkout the dgtools repository
  2. > virtualenv -p python3.8 pyenv
  3. > source pyenv/bin/activate
  4. To start using dgtools:
    • pip install -e ./ (From within the dgtools/ directory that contains the setup.py file)
    • This will make the dgtools scripts callable from any position in the filesystem, as long as the pyenv virtual environment is activated.
  5. If you are interested in developing dgtools further:
    • pip install -r requirements.txt

Where to from here?

dgtools documentation is up on ReadTheDocs and of course in doc/.

Practical examples of how to use dgtools are available in this introductory walkthrough.

Once you familiarise yourself with the tools and Digirule's ASM, you might want to move to the advanced walkthrough or check out other programming examples in dg_asm_eamples/.

Enjoy!

Athanasios Anastasiou

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

dgtools-1.0.1.tar.gz (33.5 kB view details)

Uploaded Source

Built Distribution

dgtools-1.0.1-py3-none-any.whl (55.9 kB view details)

Uploaded Python 3

File details

Details for the file dgtools-1.0.1.tar.gz.

File metadata

  • Download URL: dgtools-1.0.1.tar.gz
  • Upload date:
  • Size: 33.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.49.0 CPython/3.8.2

File hashes

Hashes for dgtools-1.0.1.tar.gz
Algorithm Hash digest
SHA256 f9e72973b98844a4d5545c485fa06c8fec4f943afbefa380b37018246a818aec
MD5 dda79ba9fc77838c64841ceb20ea8881
BLAKE2b-256 3098d117d711bb086a6f0316b8fe9bca0c8450545b39b514793edecb7c1e1c39

See more details on using hashes here.

File details

Details for the file dgtools-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: dgtools-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 55.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.49.0 CPython/3.8.2

File hashes

Hashes for dgtools-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 be74e14c0403b482161aee61e53068b6da9788c4d5446667e9f64dfd0a53b141
MD5 edca16521add914f2836ab8ad66099f1
BLAKE2b-256 015722102ac936fa3d5dbc5ef2f49157b38c0264a03d848c9664a84ce519d9ea

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