| #!/bin/bash |
| |
| # Copyright 2021 The IREE Authors |
| # |
| # Licensed under the Apache License v2.0 with LLVM Exceptions. |
| # See https://llvm.org/LICENSE.txt for license information. |
| # SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| |
| # Cross-compile the runtime using CMake targeting RISC-V |
| # |
| # The required IREE_HOST_BIN_DIR environment variable indicates the location |
| # of the precompiled IREE binaries. |
| # |
| # The desired build directory can be passed as the first argument. Otherwise, it |
| # uses the environment variable IREE_TARGET_BUILD_DIR, defaulting to |
| # "build-riscv". Designed for CI, but can be run manually. It reuses the build |
| # directory if it already exists. Expects to be run from the root of the IREE |
| # repository. |
| |
| set -xeuo pipefail |
| |
| BUILD_DIR="${1:-${IREE_TARGET_BUILD_DIR:-build-riscv}}" |
| BUILD_TYPE="${IREE_BUILD_TYPE:-RelWithDebInfo}" |
| RISCV_PLATFORM="${IREE_TARGET_PLATFORM:-linux}" |
| RISCV_ARCH="${IREE_TARGET_ARCH:-riscv_64}" |
| RISCV_COMPILER_FLAGS="${RISCV_COMPILER_FLAGS:--O3}" |
| IREE_HOST_BIN_DIR="$(realpath ${IREE_HOST_BIN_DIR})" |
| |
| source build_tools/cmake/setup_build.sh |
| source build_tools/cmake/setup_ccache.sh |
| |
| RISCV_PLATFORM_ARCH="${RISCV_PLATFORM}-${RISCV_ARCH}" |
| echo "Build riscv target with the config of ${RISCV_PLATFORM_ARCH}" |
| TOOLCHAIN_FILE="$(realpath build_tools/cmake/riscv.toolchain.cmake)" |
| declare -a args |
| args=( |
| "-G" "Ninja" |
| "-B" "${BUILD_DIR}" |
| "-DCMAKE_BUILD_TYPE=${BUILD_TYPE}" |
| "-DPython3_EXECUTABLE=${IREE_PYTHON3_EXECUTABLE}" |
| "-DPYTHON_EXECUTABLE=${IREE_PYTHON3_EXECUTABLE}" |
| "-DCMAKE_TOOLCHAIN_FILE=${TOOLCHAIN_FILE}" |
| "-DIREE_HOST_BIN_DIR=${IREE_HOST_BIN_DIR}" |
| "-DRISCV_CPU=${RISCV_PLATFORM_ARCH}" |
| "-DRISCV_COMPILER_FLAGS=${RISCV_COMPILER_FLAGS}" |
| "-DIREE_ENABLE_ASSERTIONS=ON" |
| "-DIREE_BUILD_SAMPLES=ON" |
| "-DIREE_BUILD_COMPILER=OFF" |
| "-DIREE_BUILD_ALL_CHECK_TEST_MODULES=OFF" |
| # CPU info doesn't work on RISCV |
| "-DIREE_ENABLE_CPUINFO=OFF" |
| ) |
| |
| if [[ "${RISCV_PLATFORM}" == "linux" ]]; then |
| args+=( |
| -DRISCV_TOOLCHAIN_ROOT="${RISCV_RV64_LINUX_TOOLCHAIN_ROOT}" |
| -DRISCV_TOOLCHAIN_PREFIX="riscv64-unknown-linux-gnu-" |
| ) |
| elif [[ "${RISCV_PLATFORM_ARCH}" == "generic-riscv_32" ]]; then |
| args+=( |
| # TODO(#6353): Off until tools/ are refactored to support threadless config. |
| -DIREE_BUILD_TESTS=OFF |
| -DRISCV_TOOLCHAIN_ROOT="${RISCV_RV32_NEWLIB_TOOLCHAIN_ROOT}" |
| -DRISCV_TOOLCHAIN_PREFIX="riscv32-unknown-elf" |
| ) |
| else |
| echo "riscv config for ${RISCV_PLATFORM_ARCH} not supported yet" |
| return -1 |
| fi |
| |
| "${CMAKE_BIN}" "${args[@]}" |
| |
| "${CMAKE_BIN}" --build "${BUILD_DIR}" -- -k 0 |
| if [[ "${RISCV_PLATFORM}" == "linux" ]]; then |
| echo "Building test deps for RISC-V" |
| echo "-----------------------------" |
| "${CMAKE_BIN}" --build "${BUILD_DIR}" --target iree-test-deps -- -k 0 |
| fi |