Skip to main content

short package description

Project description

xDSL

Prerequisites

To install XDSL you can either clone the Github repository and install the requirements by following:

Clone and install

git clone https://github.com/xdslproject/xdsl.git
pip install -e .
# or for the optional requirements
# pip install -e .[extras]

pip installation

pip install xdsl

Testing

This project includes pytest unit test and llvm-style filecheck tests. They can be executed using to following commands from within the root directory of the project:

# Executes pytests which are located in tests/
pytest

# Executes filecheck tests
lit tests/filecheck

Generating executables through MLIR

xDSL can generate executables using MLIR as its backend. To benefit from this functionality, we first need to clone and build MLIR. Please follow: https://mlir.llvm.org/getting_started/

Next, we need to have mlir-opt, mlir-translate and clang in the path:

# For XDSL-MLIR
export PATH=<insert-your-path>/llvm-project/build/bin:$PATH

Given an input file input.xdsl, that contains IR with only the mirrored dialects found in src/xdsl/dialects (arith, builtin, cf, func, llvm, memref, and scf), run:

### Prints MLIR generic from to tmp.mlir
# e.g.  ./src/tools/xdsl_opt -t mlir -o tmp.mlir `input.xdsl`
/src/tools/xdsl-opt -t mlir -o tmp.mlir tests/filecheck/scf_ops.xdsl

mlir-opt --convert-scf-to-cf --convert-cf-to-llvm --convert-func-to-llvm --convert-arith-to-llvm --convert-memref-to-llvm --reconcile-unrealized-casts tmp.mlir | mlir-translate --mlir-to-llvmir > tmp.ll

The generated tmp.ll file contains LLVMIR, so it can be directly passed to a compiler like clang. Notice that a main function is required for clang to build. Refer to tests/filecheck/arith_ops.test for an example. The functionality is tested with MLIR git commit hash: 74992f4a5bb79e2084abdef406ef2e5aa2024368

Formatting

All python code used in xDSL uses yapf to format the code in a uniform manner.

To automate the formatting within vim, one can use https://github.com/vim-autoformat/vim-autoformat and trigger a :Autoformat on save.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

xdsl-0.7.1-py3-none-any.whl (22.7 kB view details)

Uploaded Python 3

File details

Details for the file xdsl-0.7.1-py3-none-any.whl.

File metadata

  • Download URL: xdsl-0.7.1-py3-none-any.whl
  • Upload date:
  • Size: 22.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.6

File hashes

Hashes for xdsl-0.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 fc77836052dfd14c12ffd1a6a88884b387c6d4735080ecae8560dcaa558bff5b
MD5 71c39ace43500be608736eba70c4381b
BLAKE2b-256 3c2e311e3964c271ba86574af078a51db3e70b7179ab2292606f3ec7ab08fb09

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