104 lines
2.2 KiB
Bash
Executable File
104 lines
2.2 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
set -o errexit
|
|
set -o pipefail
|
|
set -o nounset
|
|
|
|
# Script options.
|
|
while getopts 'j:' opt
|
|
do
|
|
case $opt in
|
|
j) JOBS="${OPTARG}";;
|
|
esac
|
|
done
|
|
|
|
# If ninja is available, use it.
|
|
CMAKE_GENERATOR="Unix Makefiles"
|
|
if which ninja &>/dev/null; then
|
|
CMAKE_GENERATOR="Ninja"
|
|
fi
|
|
|
|
# The absolute path to the directory of this script.
|
|
SCALEHLS_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )"
|
|
|
|
# Make sure polygeist submodule is up-to-date.
|
|
git submodule sync
|
|
git submodule update --init --recursive
|
|
|
|
echo ""
|
|
echo ">>> Unified MLIR, Clang, and ScaleHLS build..."
|
|
echo ""
|
|
|
|
# Got to the build directory.
|
|
cd "${SCALEHLS_DIR}"
|
|
mkdir -p build
|
|
cd build
|
|
|
|
# Configure CMake.
|
|
if [ ! -f "CMakeCache.txt" ]; then
|
|
cmake -G "${CMAKE_GENERATOR}" \
|
|
../polygeist/llvm-project/llvm \
|
|
-DLLVM_ENABLE_PROJECTS="mlir;clang" \
|
|
-DLLVM_EXTERNAL_PROJECTS="scalehls" \
|
|
-DLLVM_EXTERNAL_SCALEHLS_SOURCE_DIR="${SCALEHLS_DIR}" \
|
|
-DLLVM_TARGETS_TO_BUILD="host" \
|
|
-DLLVM_ENABLE_ASSERTIONS=ON \
|
|
-DCMAKE_BUILD_TYPE=DEBUG \
|
|
-DMLIR_ENABLE_BINDINGS_PYTHON=ON \
|
|
-DSCALEHLS_ENABLE_BINDINGS_PYTHON=ON \
|
|
-DLLVM_PARALLEL_LINK_JOBS="${JOBS:=}" \
|
|
-DLLVM_USE_LINKER=lld \
|
|
-DCMAKE_C_COMPILER=clang \
|
|
-DCMAKE_CXX_COMPILER=clang++
|
|
fi
|
|
|
|
# Run building.
|
|
if [ "${CMAKE_GENERATOR}" == "Ninja" ]; then
|
|
ninja
|
|
else
|
|
make -j "$(nproc)"
|
|
fi
|
|
|
|
echo ""
|
|
echo ">>> Polygeist build..."
|
|
echo ""
|
|
|
|
# Got to the build directory.
|
|
cd "${SCALEHLS_DIR}/polygeist"
|
|
mkdir -p build
|
|
cd build
|
|
|
|
# Configure CMake.
|
|
if [ ! -f "CMakeCache.txt" ]; then
|
|
cmake -G "${CMAKE_GENERATOR}" \
|
|
.. \
|
|
-DMLIR_DIR="${SCALEHLS_DIR}/build/lib/cmake/mlir" \
|
|
-DCLANG_DIR="${SCALEHLS_DIR}/build/lib/cmake/clang" \
|
|
-DLLVM_ENABLE_ASSERTIONS=ON \
|
|
-DCMAKE_BUILD_TYPE=DEBUG \
|
|
-DLLVM_USE_LINKER=lld \
|
|
-DCMAKE_C_COMPILER=clang \
|
|
-DCMAKE_CXX_COMPILER=clang++
|
|
fi
|
|
|
|
# Run building.
|
|
if [ "${CMAKE_GENERATOR}" == "Ninja" ]; then
|
|
ninja
|
|
ninja check-mlir-clang
|
|
else
|
|
make -j "$(nproc)"
|
|
make -j "$(nproc)" check-mlir-clang
|
|
fi
|
|
|
|
echo ""
|
|
echo ">>> ScaleHLS check..."
|
|
echo ""
|
|
|
|
cd "${SCALEHLS_DIR}/build"
|
|
|
|
if [ "${CMAKE_GENERATOR}" == "Ninja" ]; then
|
|
ninja check-scalehls
|
|
else
|
|
make -j "$(nproc)" check-scalehls
|
|
fi
|