| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- #!/bin/bash
- # SPDX-License-Identifier: GPL-2.0+
- #
- # Given the results directories for previous KVM-based torture runs,
- # check the build and console output for errors. Given a directory
- # containing results directories, this recursively checks them all.
- #
- # Usage: kvm-recheck.sh resdir ...
- #
- # Returns status reflecting the success or not of the last run specified.
- #
- # Copyright (C) IBM Corporation, 2011
- #
- # Authors: Paul E. McKenney <paulmck@linux.ibm.com>
- T="`mktemp ${TMPDIR-/tmp}/kvm-recheck.sh.XXXXXX`"
- trap 'rm -f $T' 0 2
- configerrors=0
- PATH=`pwd`/tools/testing/selftests/rcutorture/bin:$PATH; export PATH
- . functions.sh
- for rd in "$@"
- do
- firsttime=1
- dirs=`find $rd -name Make.defconfig.out -print | sort | sed -e 's,/[^/]*$,,' | sort -u`
- for i in $dirs
- do
- if test -n "$firsttime"
- then
- firsttime=""
- resdir=`echo $i | sed -e 's,/$,,' -e 's,/[^/]*$,,'`
- head -1 $resdir/log
- fi
- TORTURE_SUITE="`cat $i/../torture_suite`" ; export TORTURE_SUITE
- configfile=`echo $i | sed -e 's,^.*/,,'`
- rm -f $i/console.log.*.diags $i/ConfigFragment.diags
- case "${TORTURE_SUITE}" in
- X*)
- ;;
- *)
- kvm-recheck-${TORTURE_SUITE}.sh $i
- esac
- if test -f "$i/qemu-retval" && test "`cat $i/qemu-retval`" -ne 0 && test "`cat $i/qemu-retval`" -ne 137
- then
- echo QEMU error, output:
- cat $i/qemu-output
- elif test -f "$i/console.log"
- then
- if test -f "$i/qemu-retval" && test "`cat $i/qemu-retval`" -eq 137
- then
- echo QEMU killed
- fi
- configcheck.sh $i/.config $i/ConfigFragment > $i/ConfigFragment.diags 2>&1
- if grep -q '^CONFIG_KCSAN=y$' $i/ConfigFragment.input
- then
- # KCSAN forces a number of Kconfig options, so remove
- # complaints about those Kconfig options in KCSAN runs.
- mv $i/ConfigFragment.diags $i/ConfigFragment.diags.kcsan
- grep -v -E 'CONFIG_PROVE_RCU|CONFIG_PREEMPT_COUNT' $i/ConfigFragment.diags.kcsan > $i/ConfigFragment.diags
- fi
- if test -s $i/ConfigFragment.diags
- then
- cat $i/ConfigFragment.diags
- configerrors=$((configerrors+1))
- else
- rm $i/ConfigFragment.diags
- fi
- if test -r $i/Make.oldconfig.err
- then
- cat $i/Make.oldconfig.err
- fi
- parse-build.sh $i/Make.out $configfile
- parse-console.sh $i/console.log $configfile
- if test -r $i/Warnings
- then
- cat $i/Warnings
- fi
- else
- if test -f "$i/buildonly"
- then
- echo Build-only run, no boot/test
- configcheck.sh $i/.config $i/ConfigFragment > $i/ConfigFragment.diags 2>&1
- if test -s $i/ConfigFragment.diags
- then
- cat $i/ConfigFragment.diags
- configerrors=$((configerrors+1))
- else
- rm $i/ConfigFragment.diags
- fi
- parse-build.sh $i/Make.out $configfile
- elif test -f "$i/qemu-cmd"
- then
- print_bug qemu failed
- echo " $i"
- else
- print_bug Build failed
- echo " $i"
- fi
- fi
- done
- if test -f "$rd/kcsan.sum"
- then
- if ! test -f $i/ConfigFragment.diags
- then
- :
- elif grep -q CONFIG_KCSAN=y $i/ConfigFragment.diags
- then
- echo "Compiler or architecture does not support KCSAN!"
- echo Did you forget to switch your compiler with '--kmake-arg CC=<cc-that-supports-kcsan>'?
- elif test -s "$rd/kcsan.sum"
- then
- echo KCSAN summary in $rd/kcsan.sum
- else
- echo Clean KCSAN run in $rd
- fi
- fi
- done
- if test "$configerrors" -gt 0
- then
- echo $configerrors runs with .config errors.
- ret=1
- fi
- EDITOR=echo kvm-find-errors.sh "${@: -1}" > $T 2>&1
- builderrors="`tr ' ' '\012' < $T | grep -c '/Make.out.diags'`"
- if test "$builderrors" -gt 0
- then
- echo $builderrors runs with build errors.
- ret=2
- fi
- runerrors="`tr ' ' '\012' < $T | grep -c '/console.log.diags'`"
- if test "$runerrors" -gt 0
- then
- echo $runerrors runs with runtime errors.
- ret=3
- fi
- exit $ret
|