xref: /kvm-unit-tests/scripts/runtime.bash (revision 9c51d8c9715dcde00525266f094e3fb0fe6a7950)
1103832e8SRadim Krčmář: "${RUNTIME_arch_run?}"
2fd149358SAndrew Jones: ${MAX_SMP:=$(getconf _NPROCESSORS_CONF)}
3fd149358SAndrew Jones: ${TIMEOUT:=90s}
46a53fc26SRadim Krčmář
5*9c51d8c9SRadim KrčmářPASS() { echo -ne "\e[32mPASS\e[0m"; }
6*9c51d8c9SRadim KrčmářSKIP() { echo -ne "\e[33mSKIP\e[0m"; }
7*9c51d8c9SRadim KrčmářFAIL() { echo -ne "\e[31mFAIL\e[0m"; }
8*9c51d8c9SRadim Krčmář
96a53fc26SRadim Krčmářfunction run()
106a53fc26SRadim Krčmář{
116a53fc26SRadim Krčmář    local testname="$1"
126a53fc26SRadim Krčmář    local groups="$2"
136a53fc26SRadim Krčmář    local smp="$3"
146a53fc26SRadim Krčmář    local kernel="$4"
156a53fc26SRadim Krčmář    local opts="$5"
166a53fc26SRadim Krčmář    local arch="$6"
17e9bdb8b5SAndrew Jones    local check="${CHECK:-$7}"
18e9bdb8b5SAndrew Jones    local accel="${ACCEL:-$8}"
19fd149358SAndrew Jones    local timeout="${9:-$TIMEOUT}" # unittests.cfg overrides the default
206a53fc26SRadim Krčmář
216a53fc26SRadim Krčmář    if [ -z "$testname" ]; then
226a53fc26SRadim Krčmář        return
236a53fc26SRadim Krčmář    fi
246a53fc26SRadim Krčmář
256a53fc26SRadim Krčmář    if [ -n "$only_group" ] && ! grep -q "$only_group" <<<$groups; then
266a53fc26SRadim Krčmář        return
276a53fc26SRadim Krčmář    fi
286a53fc26SRadim Krčmář
296a53fc26SRadim Krčmář    if [ -n "$arch" ] && [ "$arch" != "$ARCH" ]; then
30*9c51d8c9SRadim Krčmář        echo "`SKIP` $1 ($arch only)"
31a3831260SAndrew Jones        return 2
326a53fc26SRadim Krčmář    fi
336a53fc26SRadim Krčmář
346a53fc26SRadim Krčmář    # check a file for a particular value before running a test
356a53fc26SRadim Krčmář    # the check line can contain multiple files to check separated by a space
366a53fc26SRadim Krčmář    # but each check parameter needs to be of the form <path>=<value>
376a53fc26SRadim Krčmář    for check_param in ${check[@]}; do
386a53fc26SRadim Krčmář        path=${check_param%%=*}
396a53fc26SRadim Krčmář        value=${check_param#*=}
406a53fc26SRadim Krčmář        if [ "$path" ] && [ "$(cat $path)" != "$value" ]; then
41*9c51d8c9SRadim Krčmář            echo "`SKIP` $1 ($path not equal to $value)"
42a3831260SAndrew Jones            return 2
436a53fc26SRadim Krčmář        fi
446a53fc26SRadim Krčmář    done
456a53fc26SRadim Krčmář
46fd149358SAndrew Jones    cmdline="TESTNAME=$testname TIMEOUT=$timeout ACCEL=$accel $RUNTIME_arch_run $kernel -smp $smp $opts"
475b842da9SAndrew Jones    if [ "$verbose" = "yes" ]; then
486a53fc26SRadim Krčmář        echo $cmdline
496a53fc26SRadim Krčmář    fi
506a53fc26SRadim Krčmář
516a53fc26SRadim Krčmář    # extra_params in the config file may contain backticks that need to be
526a53fc26SRadim Krčmář    # expanded, so use eval to start qemu
53103832e8SRadim Krčmář    eval $cmdline
545af378ddSRadim Krčmář    ret=$?
556a53fc26SRadim Krčmář
56b2a2aa5dSAndrew Jones    if [ $ret -eq 0 ]; then
57*9c51d8c9SRadim Krčmář        echo "`PASS` $1"
58a0833bfcSRadim Krčmář    elif [ $ret -eq 77 ]; then
59*9c51d8c9SRadim Krčmář        echo "`SKIP` $1"
60fd149358SAndrew Jones    elif [ $ret -eq 124 ]; then
61*9c51d8c9SRadim Krčmář        echo "`FAIL` $1 (timeout; duration=$timeout)"
626a53fc26SRadim Krčmář    else
63*9c51d8c9SRadim Krčmář        echo "`FAIL` $1"
646a53fc26SRadim Krčmář    fi
655af378ddSRadim Krčmář
665af378ddSRadim Krčmář    return $ret
676a53fc26SRadim Krčmář}
686a53fc26SRadim Krčmář
69bc52c0c8SAndrew Jones#
70bc52c0c8SAndrew Jones# Probe for MAX_SMP, in case it's less than the number of host cpus.
71bc52c0c8SAndrew Jones#
72bc52c0c8SAndrew Jones# This probing currently only works for ARM, as x86 bails on another
73bc52c0c8SAndrew Jones# error first. Also, this probing isn't necessary for any ARM hosts
74bc52c0c8SAndrew Jones# running kernels later than v4.3, i.e. those including ef748917b52
75bc52c0c8SAndrew Jones# "arm/arm64: KVM: Remove 'config KVM_ARM_MAX_VCPUS'". So, at some
76bc52c0c8SAndrew Jones# point when maintaining the while loop gets too tiresome, we can
77bc52c0c8SAndrew Jones# just remove it...
78bc52c0c8SAndrew Joneswhile $RUNTIME_arch_run _NO_FILE_4Uhere_ -smp $MAX_SMP \
79bc52c0c8SAndrew Jones		|& grep -qi 'exceeds max CPUs'; do
806a53fc26SRadim Krčmář	((--MAX_SMP))
816a53fc26SRadim Krčmářdone
82