Skip to main content

Tooling package for the computer architecture course at Graz University of Technology.

Project description

Tooling package for the computer architecture course (aka Rechnerorganisation) at Graz University of Technology.

This package provides utilities and tooling for working with textual and binary assembly variants. In more detail, we provide comparable simple implementations of standard tools (e.g., assemblers, instruction set simulators) that are required for experimenting with self-written processors. Given that the tools are used for teaching, the focus of the package is correctness and extensibility. As instruction set architecture, Princeton’s TOY, incl. various extensions, and a subset of the RISC-V RV32I are currently supported.

Quick and Dirty Usage of the Tools

For fast experimentation, executable entry points for the most important tools like toyasm-ng.py and toysim-ng.py are provided next to this README. Subsequently, it is possible to directly use these applications like in one of the following examples:

$ python3 ./relative/pkg_path/toyasm-ng.py some_input_file.asm
$ python3 /absolute/pkg_path/toyasm-ng.py some_input_file.asm

Given that the entry points are marked as executable (i.e., chmod +x ...) and have a proper shebang, on unix-like systems, also direct execution is possible:

$ ./relative/pkg_path/toyasm-ng.py some_input_file.asm
$ /absolute/pkg_path/toyasm-ng.py some_input_file.asm

Finally, when the root directory of this package is part of the PATH (e.g., export PATH=/absolute/pkg_path:$PATH) environment variable, execution of the tools simply by name is working too.

$ toyasm-ng.py some_input_file.asm

Proper Installation and Usage of the Package

asmlib is a proper python package and can also be installed via the standard package manager (e.g., pip3 install --user /absolute/pkg_path). Note that, when development on to the package is planned, installing the package as editable by adding the -e command line flag is recommended. Additionally, virtual environments (e.g., python3 -m venv _venv && source_venv/bin/activate) can be used too.

Either way, this automatically installs the entry points into the correct directories and the tools can directly be used on the command line (i.e., toyasm-ng.py some_input_file.asm).

Building the Sphinx Documentation

When Sphinx is installed (i.e., pip3 install sphinx sphinx-autodoc-typehints), the HTML API documentation for this package can be built via the following sphinx-build invocation:

$ sphinx-build doc doc/_build/html

Alternatively, the sphinx command on the setup.py file can be used.

$ python3 ./setup.py sphinx

Either way, the API documentation gets automatically generated by executing sphinx-apidoc first. The resulting HTML output can be found in the doc/_build/html directory.

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

asmlib-2.2.0.tar.gz (40.6 kB view details)

Uploaded Source

Built Distribution

asmlib-2.2.0-py3-none-any.whl (62.7 kB view details)

Uploaded Python 3

File details

Details for the file asmlib-2.2.0.tar.gz.

File metadata

  • Download URL: asmlib-2.2.0.tar.gz
  • Upload date:
  • Size: 40.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.0.0 pkginfo/1.8.3 requests/2.27.1 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.64.1 CPython/3.6.8

File hashes

Hashes for asmlib-2.2.0.tar.gz
Algorithm Hash digest
SHA256 c5b8d57343cded4aab723329bebd02fe614e1d8ce232c026f0ccab8d02b34e0e
MD5 9ffcc02d6805a52187f8de256e7f7579
BLAKE2b-256 9f5d44faf65112f97172aad8db0f423f2b2dcbad6b0ffa06f66b5f4e05f674dc

See more details on using hashes here.

File details

Details for the file asmlib-2.2.0-py3-none-any.whl.

File metadata

  • Download URL: asmlib-2.2.0-py3-none-any.whl
  • Upload date:
  • Size: 62.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.0.0 pkginfo/1.8.3 requests/2.27.1 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.64.1 CPython/3.6.8

File hashes

Hashes for asmlib-2.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e17fcec059937ec3f07981ec92c621dff57f2934d79efc9655ab561e6c8331b3
MD5 68c9a4fbe5f7e8ed7f7bde66a25cca1e
BLAKE2b-256 756c45ac68ce7a785f62e86bdb9eb30b6e78e89610892a96a8aa263fba8b5a86

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