| #!/bin/bash |
| # SPDX-License-Identifier: GPL-2.0+ |
| # |
| # Carry out a kvm-based run for the specified batch of scenarios, which |
| # might have been built by --build-only kvm.sh run. |
| # |
| # Usage: kvm-test-1-run-batch.sh SCENARIO [ SCENARIO ... ] |
| # |
| # Each SCENARIO is the name of a directory in the current directory |
| # containing a ready-to-run qemu-cmd file. |
| # |
| # Copyright (C) 2021 Facebook, Inc. |
| # |
| # Authors: Paul E. McKenney <paulmck@kernel.org> |
| |
| T="`mktemp -d ${TMPDIR-/tmp}/kvm-test-1-run-batch.sh.XXXXXX`" |
| trap 'rm -rf $T' 0 |
| |
| echo ---- Running batch $* |
| # Check arguments |
| runfiles= |
| for i in "$@" |
| do |
| if ! echo $i | grep -q '^[^/.a-z]\+\(\.[0-9]\+\)\?$' |
| then |
| echo Bad scenario name: \"$i\" 1>&2 |
| exit 1 |
| fi |
| if ! test -d "$i" |
| then |
| echo Scenario name not a directory: \"$i\" 1>&2 |
| exit 2 |
| fi |
| if ! test -f "$i/qemu-cmd" |
| then |
| echo Scenario lacks a command file: \"$i/qemu-cmd\" 1>&2 |
| exit 3 |
| fi |
| rm -f $i/build.* |
| touch $i/build.run |
| runfiles="$runfiles $i/build.run" |
| done |
| |
| # Extract settings from the qemu-cmd file. |
| grep '^#' $1/qemu-cmd | sed -e 's/^# //' > $T/qemu-cmd-settings |
| . $T/qemu-cmd-settings |
| |
| # Start up jitter, start each scenario, wait, end jitter. |
| echo ---- System running test: `uname -a` |
| echo ---- Starting kernels. `date` | tee -a log |
| $TORTURE_JITTER_START |
| kvm-assign-cpus.sh /sys/devices/system/node > $T/cpuarray.awk |
| for i in "$@" |
| do |
| echo ---- System running test: `uname -a` > $i/kvm-test-1-run-qemu.sh.out |
| echo > $i/kvm-test-1-run-qemu.sh.out |
| export TORTURE_AFFINITY= |
| kvm-get-cpus-script.sh $T/cpuarray.awk $T/cpubatches.awk $T/cpustate |
| cat << ' ___EOF___' >> $T/cpubatches.awk |
| END { |
| affinitylist = ""; |
| if (!gotcpus()) { |
| print "echo No CPU-affinity information, so no taskset command."; |
| } else if (cpu_count !~ /^[0-9][0-9]*$/) { |
| print "echo " scenario ": Bogus number of CPUs (old qemu-cmd?), so no taskset command."; |
| } else { |
| affinitylist = nextcpus(cpu_count); |
| if (!(affinitylist ~ /^[0-9,-][0-9,-]*$/)) |
| print "echo " scenario ": Bogus CPU-affinity information, so no taskset command."; |
| else if (!dumpcpustate()) |
| print "echo " scenario ": Could not dump state, so no taskset command."; |
| else |
| print "export TORTURE_AFFINITY=" affinitylist; |
| } |
| } |
| ___EOF___ |
| cpu_count="`grep '# TORTURE_CPU_COUNT=' $i/qemu-cmd | sed -e 's/^.*=//'`" |
| affinity_export="`awk -f $T/cpubatches.awk -v cpu_count="$cpu_count" -v scenario=$i < /dev/null`" |
| $affinity_export |
| kvm-test-1-run-qemu.sh $i >> $i/kvm-test-1-run-qemu.sh.out 2>&1 & |
| done |
| for i in $runfiles |
| do |
| while ls $i > /dev/null 2>&1 |
| do |
| : |
| done |
| done |
| echo ---- All kernel runs complete. `date` | tee -a log |
| $TORTURE_JITTER_STOP |