Square and HeteroSync's pre-built binaries were downloaded into the tests folder in the nightly regression script, but the docker command running them assumed we were in GEM5_ROOT. This commit fixes this problem by specificying the benchmark root for the applications. Change-Id: I905c8bde7231bc708db01bff196fd85d99c7ceac Reviewed-on: https://gem5-review.googlesource.com/c/public/gem5/+/51247 Tested-by: kokoro <noreply+kokoro@google.com> Reviewed-by: Jason Lowe-Power <power.jg@gmail.com> Maintainer: Bobby R. Bruce <bbruce@ucdavis.edu>
127 lines
5.3 KiB
Bash
Executable File
127 lines
5.3 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
# Copyright (c) 2021 The Regents of the University of California
|
|
# All Rights Reserved.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are
|
|
# met: redistributions of source code must retain the above copyright
|
|
# notice, this list of conditions and the following disclaimer;
|
|
# redistributions in binary form must reproduce the above copyright
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
# documentation and/or other materials provided with the distribution;
|
|
# neither the name of the copyright holders nor the names of its
|
|
# contributors may be used to endorse or promote products derived from
|
|
# this software without specific prior written permission.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
set -e
|
|
set -x
|
|
|
|
dir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )"
|
|
gem5_root="${dir}/.."
|
|
|
|
# We assume the lone argument is the number of threads. If no argument is
|
|
# given we default to one.
|
|
threads=1
|
|
if [[ $# -gt 0 ]]; then
|
|
threads=$1
|
|
fi
|
|
|
|
build_target () {
|
|
isa=$1
|
|
|
|
# Try to build. If not, delete the build directory and try again.
|
|
# SCons is not perfect, and occasionally does not catch a necessary
|
|
# compilation: https://gem5.atlassian.net/browse/GEM5-753
|
|
docker run -u $UID:$GID --volume "${gem5_root}":"${gem5_root}" -w \
|
|
"${gem5_root}" --rm gcr.io/gem5-test/ubuntu-20.04_all-dependencies \
|
|
bash -c "scons build/${isa}/gem5.opt -j${threads} \
|
|
|| (rm -rf build && scons build/${isa}/gem5.opt -j${threads})"
|
|
}
|
|
|
|
unit_test () {
|
|
build=$1
|
|
|
|
docker run -u $UID:$GID --volume "${gem5_root}":"${gem5_root}" -w \
|
|
"${gem5_root}" --rm gcr.io/gem5-test/ubuntu-20.04_all-dependencies \
|
|
scons build/NULL/unittests.${build} -j${threads}
|
|
}
|
|
|
|
# Ensure we have the latest docker images.
|
|
docker pull gcr.io/gem5-test/ubuntu-20.04_all-dependencies
|
|
|
|
# Try to build the ISA targets.
|
|
build_target NULL
|
|
build_target RISCV
|
|
build_target X86
|
|
build_target ARM
|
|
build_target SPARC
|
|
build_target MIPS
|
|
build_target POWER
|
|
|
|
# Run the unit tests.
|
|
unit_test opt
|
|
unit_test debug
|
|
unit_test perf
|
|
unit_test prof
|
|
|
|
# Run the gem5 long tests.
|
|
docker run -u $UID:$GID --volume "${gem5_root}":"${gem5_root}" -w \
|
|
"${gem5_root}"/tests --rm gcr.io/gem5-test/ubuntu-20.04_all-dependencies \
|
|
./main.py run --length long -j${threads} -t${threads}
|
|
|
|
# Run the GPU tests.
|
|
|
|
# For the GPU tests we compile and run GCN3_X86 inside a gcn-gpu container.
|
|
docker pull gcr.io/gem5-test/gcn-gpu:latest
|
|
docker run --rm -u $UID:$GUID --volume "${gem5_root}":"${gem5_root}" -w \
|
|
"${gem5_root}" gcr.io/gem5-test/gcn-gpu:latest bash -c \
|
|
"scons build/GCN3_X86/gem5.opt -j${threads} \
|
|
|| (rm -rf build && scons build/GCN3_X86/gem5.opt -j${threads})"
|
|
|
|
# get square
|
|
wget -qN http://dist.gem5.org/dist/develop/test-progs/square/square
|
|
|
|
mkdir -p tests/testing-results
|
|
|
|
# Square is the simplest, fastest, more heavily tested GPU application
|
|
# Thus, we always want to run this in the nightly regressions to make sure
|
|
# basic GPU functionality is working.
|
|
docker run --rm -u $UID:$GUID --volume "${gem5_root}":"${gem5_root}" -w \
|
|
"${gem5_root}" gcr.io/gem5-test/gcn-gpu:latest build/GCN3_X86/gem5.opt \
|
|
configs/example/apu_se.py -n3 --benchmark-root="${gem5_root}/tests" -c square
|
|
|
|
# get HeteroSync
|
|
wget -qN http://dist.gem5.org/dist/develop/test-progs/heterosync/gcn3/allSyncPrims-1kernel
|
|
|
|
# run HeteroSync sleepMutex -- 16 WGs (4 per CU in default config), each doing
|
|
# 10 Ld/St per thread and 4 iterations of the critical section is a reasonable
|
|
# moderate contention case for the default 4 CU GPU config and help ensure GPU
|
|
# atomics are tested.
|
|
docker run --rm -u $UID:$GUID --volume "${gem5_root}":"${gem5_root}" -w \
|
|
"${gem5_root}" gcr.io/gem5-test/gcn-gpu:latest build/GCN3_X86/gem5.opt \
|
|
configs/example/apu_se.py -n3 --benchmark-root="${gem5_root}/tests" \
|
|
-c allSyncPrims-1kernel --options="sleepMutex 10 16 4"
|
|
|
|
# run HeteroSync LFBarr -- similar setup to sleepMutex above -- 16 WGs
|
|
# accessing unique data and then joining a lock-free barrier, 10 Ld/St per
|
|
# thread, 4 iterations of critical section. Again this is representative of a
|
|
# moderate contention case for the default 4 CU GPU config and help ensure GPU
|
|
# atomics are tested.
|
|
docker run --rm -u $UID:$GUID --volume "${gem5_root}":"${gem5_root}" -w \
|
|
"${gem5_root}" gcr.io/gem5-test/gcn-gpu:latest build/GCN3_X86/gem5.opt \
|
|
configs/example/apu_se.py -n3 --benchmark-root="${gem5_root}/tests" \
|
|
-c allSyncPrims-1kernel --options="lfTreeBarrUniq 10 16 4"
|