hc
2024-05-14 bedbef8ad3e75a304af6361af235302bcc61d06b
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
#!/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=/tmp/kvm-recheck.sh.$$
trap 'rm -f $T' 0 2
 
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`"
       configfile=`echo $i | sed -e 's,^.*/,,'`
       rm -f $i/console.log.*.diags
       kvm-recheck-${TORTURE_SUITE}.sh $i
       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 > $T 2>&1
           cat $T
           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
               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 grep -q CONFIG_KCSAN=y $T
       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
EDITOR=echo kvm-find-errors.sh "${@: -1}" > $T 2>&1
ret=$?
builderrors="`tr ' ' '\012' < $T | grep -c '/Make.out.diags'`"
if test "$builderrors" -gt 0
then
   echo $builderrors runs with build errors.
fi
runerrors="`tr ' ' '\012' < $T | grep -c '/console.log.diags'`"
if test "$runerrors" -gt 0
then
   echo $runerrors runs with runtime errors.
fi
exit $ret