Skip to main content

CoreDSL2 Parser with backend to generate simulation code for the ETISS instruction set simulator

Project description

M2-ISA-R v2

This tool serves as a general-purpose instruction set architecture metamodel. A parser for CoreDSL and an architecture generator for the instruction set simulator ETISS are currently also provided.

Please note: M2-ISA-R is in heavy development, things might change and break without notice. Please report issues on GitHub for any problems you encounter.

Prerequisites

  • Python 3.7+ with at least pip and venv

Installation (Usage with CoreDSL 2 and ETISS)

  • Make a Python venv somewhere: python -m venv <path-to-venv>
  • Activate said venv: source <path-to-venv>/bin/activate
  • Install M2-ISA-R: pip install git+https://github.com/tum-ei-eda/M2-ISA-R@coredsl2

Development Setup

  • Clone the repository, change into the cloned directory
  • Make a Python venv: python -m venv venv
  • Activate said venv: source venv/bin/activate
  • Install M2-ISA-R for development: pip install -e .
  • Install PyPI release: pip install m2isar

Architecture

M2-ISA-R consists of 3 components, two of which are exchangeable for different needs:

Frontend -> Metamodel -> Backend

The frontend transforms a model specification into M2-ISA-R's internal architecture model. This model can then be transformed again to an output format, e.g. models for an ISS. This repo provides a CoreDSL frontend and an ETISS backend.

Usage

M2-ISA-R v2 currently ships three usable tools: Two parsers (for transforming CoreDSL 1.5 / 2 to a M2-ISA-R metamodel) and a writer (for generating ETISS architecture plugins). These are described seperately in their respective directories, TL;DR version:

  • To parse a CoreDSL 2 description: coredsl2_parser path/to/input/<top_level>.core_desc
  • To generate ETISS Architecture: etiss_writer -s path/to/input/gen_model/<top_level>.m2isarmodel

For parsers, see m2isar/frontends/coredsl or m2isar/frontends/coredsl2. For the ETISS architecture writer, see m2isar/backends/etiss.

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

m2isar-0.0.8.tar.gz (149.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

m2isar-0.0.8-py3-none-any.whl (183.3 kB view details)

Uploaded Python 3

File details

Details for the file m2isar-0.0.8.tar.gz.

File metadata

  • Download URL: m2isar-0.0.8.tar.gz
  • Upload date:
  • Size: 149.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for m2isar-0.0.8.tar.gz
Algorithm Hash digest
SHA256 2b7a3636a10c69d2ee084285a942ab5b22648d6febeb400926b68b9fc19d7ee0
MD5 aeecc63303c8d7bb9beeac3df617b8e3
BLAKE2b-256 3f858f573ee7a18b6645e96656a6d2672aa3cc138f5b5591f47909f74c406a7f

See more details on using hashes here.

File details

Details for the file m2isar-0.0.8-py3-none-any.whl.

File metadata

  • Download URL: m2isar-0.0.8-py3-none-any.whl
  • Upload date:
  • Size: 183.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for m2isar-0.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 dcafcca9390d108713c37fcf5215842c74079acd2aa5fd42c8c4430765a8d666
MD5 b1d3cd8b653297e6ace59d0f2419ef31
BLAKE2b-256 fc5b3a9693cb4486658e9338fa10d77bb10f90dc4fa7fc8d404097f8a74be346

See more details on using hashes here.

Supported by

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