- Notifications
You must be signed in to change notification settings - Fork108
MLIR For Beginners tutorial
j2kun/mlir-tutorial
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
This is the code repository for a series of articles on theMLIR framework for building compilers.
- Build System (Getting Started)
- Running and Testing a Lowering
- Writing Our First Pass
- Using Tablegen for Passes
- Defining a New Dialect
- Using Traits
- Folders and Constant Propagation
- Verifiers
- Canonicalizers and Declarative Rewrite Patterns
- Dialect Conversion
- Lowering through LLVM
- A Global Optimization and Dataflow Analysis
- Defining Patterns with PDLL
Bazel is one of two supported build systems for this tutorial. The other isCMake. If you're unfamiliar with Bazel, you can read the tutorials athttps://bazel.build/start. Familiarity with Bazelis not required to build or test, but it is required to follow the articles inthe tutorial series and explained in the first article,Build System (Getting Started).The CMake build is maintained, but was added at article 10 (Dialect Conversion)and will not be explained in the articles.
Note: This project has been upgraded to Bazel 8.3.1 and migrated to useBzlmod for dependency management, replacing the traditional WORKSPACE fileapproach. Dependencies are now managed throughMODULE.bazel using theBazel Central Registry (BCR) where possible.
Install Bazelisk via instructions athttps://github.com/bazelbuild/bazelisk#installation.This should create thebazel command on your system.
You should also have a modern C++ compiler on your system, eithergcc orclang, which Bazel will detect.
Bazel Version: This project requires Bazel 8.3.1 or newer. The specificversion is pinned in.bazelversion.
Run
bazel build ...:allbazeltest ...:allThe project uses Bzlmod (MODULE.bazel) for dependency management:
- Core dependencies: Managed through Bazel Central Registry (BCR)
- rules_python, rules_java, protobuf, abseil-cpp, or-tools, etc.
- LLVM dependencies: Managed through custom module extension
- LLVM/MLIR source code via git repository
- Development tools: hedron_compile_commands via git_override
This approach provides better dependency resolution, versioning, andcompatibility compared to the legacy WORKSPACE approach.
CMake is one of two supported build systems for this tutorial. The other isBazel. If you're unfamiliar with CMake, you can read the tutorials athttps://cmake.org/getting-started/. TheCMake build is maintained, but was added at article 10 (Dialect Conversion) andwill not be explained in the articles.
- Make sure you have installed everything needed to build LLVMhttps://llvm.org/docs/GettingStarted.html#software
- For this recipe Ninja is used so be sure to have it as well installedhttps://github.com/ninja-build/ninja/wiki/Pre-built-Ninja-packages
Checkout the tutorial including the LLVM dependency (submodules):
git clone --recurse-submodules https://github.com/j2kun/mlir-tutorial.gitcd mlir-tutorialNote: The following steps are suitable for macOs and use ninja as buildingsystem, they should not be hard to adapt for your environment.
Build LLVM/MLIR
#!/bin/shBUILD_SYSTEM=NinjaBUILD_TAG=ninjaTHIRDPARTY_LLVM_DIR=$PWD/externals/llvm-projectBUILD_DIR=$THIRDPARTY_LLVM_DIR/buildINSTALL_DIR=$THIRDPARTY_LLVM_DIR/installmkdir -p$BUILD_DIRmkdir -p$INSTALL_DIRpushd$BUILD_DIRcmake ../llvm -G$BUILD_SYSTEM \ -DCMAKE_CXX_COMPILER="$(xcrun --find clang++)" \ -DCMAKE_C_COMPILER="$(xcrun --find clang)" \ -DCMAKE_INSTALL_PREFIX=$INSTALL_DIR \ -DLLVM_LOCAL_RPATH=$INSTALL_DIR/lib \ -DLLVM_PARALLEL_COMPILE_JOBS=7 \ -DLLVM_PARALLEL_LINK_JOBS=1 \ -DLLVM_BUILD_EXAMPLES=OFF \ -DLLVM_INSTALL_UTILS=ON \ -DCMAKE_OSX_ARCHITECTURES="$(uname -m)" \ -DCMAKE_BUILD_TYPE=Release \ -DLLVM_ENABLE_ASSERTIONS=ON \ -DLLVM_CCACHE_BUILD=ON \ -DCMAKE_EXPORT_COMPILE_COMMANDS=ON \ -DLLVM_ENABLE_PROJECTS='mlir' \ -DDEFAULT_SYSROOT="$(xcrun --show-sdk-path)" \ -DCMAKE_OSX_SYSROOT="$(xcrun --show-sdk-path)"cmake --build. --target check-mlirpopd
#!/bin/shBUILD_SYSTEM="Ninja"BUILD_DIR=./build-`echo${BUILD_SYSTEM}| tr'[:upper:]''[:lower:]'`rm -rf$BUILD_DIRmkdir$BUILD_DIRpushd$BUILD_DIRLLVM_BUILD_DIR=externals/llvm-project/buildcmake -G$BUILD_SYSTEM .. \ -DLLVM_DIR="$LLVM_BUILD_DIR/lib/cmake/llvm" \ -DMLIR_DIR="$LLVM_BUILD_DIR/lib/cmake/mlir" \ -DBUILD_DEPS="ON" \ -DBUILD_SHARED_LIBS="OFF" \ -DCMAKE_BUILD_TYPE=Debugpopdcmake --build$BUILD_DIR --target MLIRAffineFullUnrollPassescmake --build$BUILD_DIR --target MLIRMulToAddPassescmake --build$BUILD_DIR --target MLIRNoisyPassescmake --build$BUILD_DIR --target mlir-headerscmake --build$BUILD_DIR --target mlir-doccmake --build$BUILD_DIR --target tutorial-optcmake --build$BUILD_DIR --target check-mlir-tutorial
About
MLIR For Beginners tutorial
Topics
Resources
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Releases
Packages0
Uh oh!
There was an error while loading.Please reload this page.