xref: /aosp_15_r20/external/swiftshader/tests/kokoro/gcp_ubuntu/build.sh (revision 03ce13f70fcc45d86ee91b7ee4cab1936a95046e)
1#!/bin/bash
2
3# Copyright 2022 The SwiftShader Authors. All Rights Reserved.
4#
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9#    http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14# See the License for the specific language governing permissions and
15# limitations under the License.
16
17set -e # Fail on any error.
18
19SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}")" >/dev/null 2>&1 && pwd )"
20ROOT_DIR="$( cd "${SCRIPT_DIR}/../../.." >/dev/null 2>&1 && pwd )"
21
22# Inside the docker VM, we clone the project to a new directory.
23# We do this so that the docker script can be tested in a local development
24# checkout, without having the build litter the local checkout with artifacts.
25# This directory is mapped to the host temporary directory.
26# Kokoro uses a '/tmpfs' root, where as most linux enviroments just have '/tmp'
27if [ -d "/tmpfs" ]; then
28    TMP_DIR=/tmpfs
29else
30    TMP_DIR=/tmp
31fi
32
33# --privileged is required for some sanitizer builds, as they seem to require PTRACE privileges
34docker run --rm -i \
35  --privileged \
36  --volume "${ROOT_DIR}:${ROOT_DIR}" \
37  --volume "${TMP_DIR}:/src" \
38  --volume "${KOKORO_ARTIFACTS_DIR}:/mnt/artifacts" \
39  --workdir "${ROOT_DIR}" \
40  --env SRC_DIR="/src/swiftshader" \
41  --env BUILD_TYPE=$BUILD_TYPE \
42  --env REACTOR_BACKEND=$REACTOR_BACKEND \
43  --env LLVM_VERSION=$LLVM_VERSION \
44  --entrypoint "${SCRIPT_DIR}/docker.sh" \
45  "gcr.io/shaderc-build/radial-build:latest"
46