| #!/bin/bash |
| # Copyright 2022 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 |
| |
| # Builds the sample, running host tools, Emscripten, and CMake as needed. |
| # |
| # Prerequisites: |
| # * Environment must be configured for Emscripten |
| # * Host tools must be built (default at IREE_SOURCE_DIR/build-host/install). |
| # The build_tools/cmake/build_host_tools.sh script can do this for you. |
| # |
| # Usage: |
| # build_sample.sh (optional install path) && serve_sample.sh |
| # |
| # The desired host install directory can be passed as the first argument. |
| # Otherwise, it looks for an install directory under path set in the environment |
| # variable IREE_HOST_BUILD_DIR (default build-host). The build directory for the |
| # emscripten build is taken from the environment variable |
| # IREE_EMPSCRIPTEN_BUILD_DIR, defaulting to "build-emscripten". Designed for |
| # CI, but can be run manually. It reuses the build directory if it already |
| # exists. |
| # |
| # NOTE: This is different from most of build scripts we use for CI because it is |
| # intended to also be runnable by humans with minimal configuration. |
| |
| set -euo pipefail |
| |
| ROOT_DIR=$(git rev-parse --show-toplevel) |
| |
| HOST_BUILD_DIR="${IREE_HOST_BUILD_DIR:-${ROOT_DIR}/build-host}" |
| BUILD_DIR="${IREE_EMPSCRIPTEN_BUILD_DIR:-build-emscripten}" |
| INSTALL_ROOT="$(realpath ${1:-${HOST_BUILD_DIR}/install})" |
| SOURCE_DIR=${ROOT_DIR}/experimental/web/sample_dynamic |
| BINARY_DIR=${BUILD_DIR}/experimental/web/sample_dynamic |
| IREE_PYTHON3_EXECUTABLE="${IREE_PYTHON3_EXECUTABLE:-$(which python3)}" |
| |
| |
| ############################################################################### |
| # Setup and checking for dependencies # |
| ############################################################################### |
| |
| if ! command -v emcmake &> /dev/null |
| then |
| echo "'emcmake' not found, setup environment according to https://emscripten.org/docs/getting_started/downloads.html" |
| exit 1 |
| fi |
| |
| source "${ROOT_DIR}/build_tools/cmake/setup_build.sh" |
| |
| mkdir -p ${BINARY_DIR} |
| |
| ############################################################################### |
| # Compile from .mlir input to portable .vmfb file using host tools # |
| ############################################################################### |
| |
| COMPILE_TOOL="${INSTALL_ROOT}/bin/iree-compile" |
| |
| compile_sample() { |
| echo " Compiling '$1' sample..." |
| "${COMPILE_TOOL}" "$2" \ |
| --iree-input-type=mhlo \ |
| --iree-hal-target-backends=llvm-cpu \ |
| --iree-llvm-target-triple=wasm32-unknown-emscripten \ |
| --iree-llvm-target-cpu-features=+atomics,+bulk-memory,+simd128 \ |
| --o "${BINARY_DIR}/$1.vmfb" |
| } |
| |
| echo "=== Compiling sample MLIR files to VM FlatBuffer outputs (.vmfb) ===" |
| compile_sample "simple_abs" "${ROOT_DIR}/samples/models/simple_abs.mlir" |
| compile_sample "fullyconnected" "${ROOT_DIR}/tests/e2e/models/fullyconnected.mlir" |
| compile_sample "collatz" "${ROOT_DIR}/tests/e2e/models/collatz.mlir" |
| |
| ############################################################################### |
| # Build the web artifacts using Emscripten # |
| ############################################################################### |
| |
| echo "=== Building web artifacts using Emscripten ===" |
| |
| # Configure using Emscripten's CMake wrapper, then build. |
| # Note: The sample creates a device directly, so no drivers are required. |
| emcmake "${CMAKE_BIN}" \ |
| -B "${BUILD_DIR}" \ |
| -G Ninja \ |
| -DPython3_EXECUTABLE="${IREE_PYTHON3_EXECUTABLE}" \ |
| -DPYTHON_EXECUTABLE="${IREE_PYTHON3_EXECUTABLE}" \ |
| -DCMAKE_BUILD_TYPE=RelWithDebInfo \ |
| -DIREE_HOST_BINARY_ROOT="${INSTALL_ROOT}" \ |
| -DIREE_BUILD_EXPERIMENTAL_WEB_SAMPLES=ON \ |
| -DIREE_HAL_DRIVER_DEFAULTS=OFF \ |
| -DIREE_HAL_DRIVER_LOCAL_SYNC=ON \ |
| -DIREE_BUILD_COMPILER=OFF \ |
| -DIREE_BUILD_TESTS=OFF \ |
| . |
| |
| "${CMAKE_BIN}" --build "${BUILD_DIR}" --target \ |
| iree_experimental_web_sample_dynamic_sync |
| |
| echo "=== Copying static files (.html, .js) to the build directory ===" |
| |
| cp "${SOURCE_DIR}/index.html" "${BINARY_DIR}" |
| cp "${SOURCE_DIR}/benchmarks.html" "${BINARY_DIR}" |
| cp "${ROOT_DIR}/docs/website/overrides/ghost.svg" "${BINARY_DIR}" |
| cp "${SOURCE_DIR}/iree_api.js" "${BINARY_DIR}" |
| cp "${SOURCE_DIR}/iree_worker.js" "${BINARY_DIR}" |