Skip to content

Repo for AI Compiler team. The intended purpose of this repo is for implementation of a PJRT device.

License

Notifications You must be signed in to change notification settings

tenstorrent/tt-xla

Repository files navigation

tt-xla

tt-xla leverages PJRT to integrate JAX (and in the future other frameworks), tt-mlir and Tenstorrent hardware. Please see this blog post for more information about PJRT project. This project is a fork of iree-pjrt.

Note: Currently only Tenstorrent nebula boards are supported and galaxy boards are not yet supported.

Build Process

tt-xla integration with tt-mlir compiler is still under progress and currently it depends on tt-mlir toolchain for build. This build flow provides an easy way to experiment with tt-xla, StableHLO and tt-mlir infrastructure. Build process will be updated in the future to enhance the user experience.

tt-mlir toolchain

Before compiling tt-xla, tt-mlir toolchain needs to be built:

tt-xla

Before running these commands to build tt-xla, please ensure that the environtment variable TTMLIR_TOOLCHAIN_DIR is set to point to the tt-mlir toolchain directory created above as part of tt-mlir environment setup (for example export TTMLIR_TOOLCHAIN_DIR=/opt/ttmlir-toolchain/). You can also set export LOGGER_LEVEL=DEBUG in order to enable debug logs.

git clone git@github.com:tenstorrent/tt-xla.git
cd tt-xla
source venv/activate
cmake -G Ninja -B build # -DCMAKE_BUILD_TYPE=Debug in case you want debug build
cmake --build build

Testing

tt-xla repo contains various tests in tests directory. To run them all, please run pytest -v tests from project root directory. To run individual test, pytest -svv is recommended in order to capture all potential error messages down the line.

Common Build Errors

  • Building tt-xla requires clang-17. Please make sure that clang-17 is installed on the system and clang/clang++ link to correct version of respective tools.
  • tt-xla also builds tt-metal and it may cause sfpi-trisc-ncrisc-build-failure. Please use this fix.
  • Please see tt-mlir docs for common build errors.

Pre-Commit

Pre-Commit applies a git hook to the local repository such that linting is checked and applied on every git commit action. Install from the root of the repository using:

source venv/activate
pre-commit install

If you have already committed something locally before installing the pre-commit hooks, you can run this command to "catch up" on all files:

pre-commit run --all-files

For more information please visit pre-commit.

About

Repo for AI Compiler team. The intended purpose of this repo is for implementation of a PJRT device.

Resources

License

Stars

Watchers

Forks

Packages