Skip to content

Latest commit

 

History

History
90 lines (73 loc) · 3.64 KB

README.md

File metadata and controls

90 lines (73 loc) · 3.64 KB

MLIR-based AIEngine toolchain

GitHub Workflow Status

This repository contains an MLIR-based toolchain for Xilinx Versal AIEngine-based devices. This can be used to generate low-level configuration for the AIEngine portion of the device, including processors, stream switches, TileDMA and ShimDMA blocks. Backend code generation is included, targetting the LibXAIE library. This project is primarily intended to support tool builders with convenient low-level access to devices and enable the development of a wide variety of programming models from higher level abstractions. As such, although it contains some examples, this project is not intended to represent end-to-end compilation flows or to be particularly easy to use for system design.

Full Documentation

Building the code

Prerequisites

cmake 3.17.5
ninja 1.8.2
Xilinx Vitis 2020.1
sudo pip3 install joblib psutil
clang/llvm 13+ from source https://github.com/llvm/llvm-project
Xilinx cmakeModules from https://github.com/Xilinx/cmakeModules

Currently, the only supported target is the Xilinx VCK190 board, running Ubuntu-based Linux, however the tools are largely board and device indepdendent and can be adapted to other environments.

Building on X86

First compile LLVM, with the ability to target AArch64 as a cross-compiler, and with MLIR enabled: In addition, we make some common build optimizations to use a linker other than 'ld' (which tends to be quite slow on large link jobs) and to link against libLLVM.so and libClang.so. You may find that other options are also useful. Note that due to changing MLIR APIs, only a particular revision is expected to work.

git clone https://github.com/llvm/llvm-project
cd llvm-project
git checkout ebe408ad8003
mkdir ${LLVMBUILD}; cd ${LLVMBUILD}
cmake -GNinja \
    -DLLVM_LINK_LLVM_DYLIB=ON 
    -DCLANG_LINK_CLANG_DYLIB=ON
    -DLLVM_BUILD_UTILS=ON
    -DLLVM_INSTALL_UTILS=ON
    -DLLVM_USE_LINKER=lld  (or gold)
    -DCMAKE_INSTALL_PREFIX=${ACDCInstallDir}
    -DLLVM_ENABLE_PROJECTS="clang;lld;mlir"
    -DLLVM_TARGETS_TO_BUILD:STRING="X86;ARM;AArch64;"
    ..
ninja; ninja check-llvm; ninja install

Then you can build the AIE tools:

git clone https://github.com/Xilinx/cmakeModules
git clone https://github.com/Xilinx/mlir-aie
mkdir build; cd build
cmake -GNinja \
    -DLLVM_DIR=${absolute path to LLVMBUILD}/lib/cmake/llvm \
    -DMLIR_DIR=${absolute path to LLVMBUILD}/lib/cmake/mlir \
    -DCMAKE_MODULE_PATH=/absolute/path/to/cmakeModules/ \
    -DVitisSysroot=${SYSROOT} \
    -DCMAKE_BUILD_TYPE=Debug \
    ..
ninja; ninja check-aie; ninja mlir-doc; ninja install

The MLIR AIE tools will be able to generate binaries targetting a combination of AIEngine and ARM processors.

Sysroot

Since the AIE tools are cross-compiling, in order to actually compile code, we need a 'sysroot' directory, containing an ARM rootfs. This rootfs must match what will be available in the runtime environment. Note that copying the rootfs is often insufficient, since many root file systems include absolute links. Absolute symbolic links can be converted to relative symbolic links using symlinks.

cd /
sudo symlinks -rc .

Environment setup

In order to run all the tools, it may be necessary to add some paths into your environment:

setenv MLIRAIE /path/to/build/install
setenv PATH ${MLIRAIE}/bin:${PATH}
setenv PYTHONPATH ${MLIRAIE}/python:${PYTHONPATH}
setenv LD_LIBRARY_PATH ${MLIRAIE}/lib:${LD_LIBRARY_PATH}

(c) Copyright 2019-2021 Xilinx Inc.