[Intel-gfx] [PATCH v2] drv_module_reload_basic: Add inject-fault-* subtests

Imre Deak imre.deak at intel.com
Sat Mar 12 14:40:17 UTC 2016


Add subtests for loading the module with fault injection enabled.

Requested by Chris.

v2:
- add proper IGT subtests instead of the --inject-fault option

CC: Chris Wilson <chris at chris-wilson.co.uk>
Signed-off-by: Imre Deak <imre.deak at intel.com>
---
 tests/drm_lib.sh              | 47 ++++++++++++++++++++++++++++++++++---------
 tests/drv_module_reload_basic | 37 +++++++++++++++++++++++++++++++++-
 2 files changed, 74 insertions(+), 10 deletions(-)

diff --git a/tests/drm_lib.sh b/tests/drm_lib.sh
index c50664c..0d502df 100755
--- a/tests/drm_lib.sh
+++ b/tests/drm_lib.sh
@@ -1,13 +1,46 @@
 #!/bin/sh
 
 # hacked-up long option parsing
-for arg in $@ ; do
+
+die() {
+	echo "$@"
+	exit 1
+}
+
+arg_idx=1
+
+while [ $arg_idx -le $# ] ; do
+	arg=$(eval echo \$$arg_idx)
 	case $arg in
 		--list-subtests)
-			exit 79
+			if [ -z "IGT_SUBTEST_LIST" ]; then
+				exit 79
+			fi
+
+			for subtest in $IGT_SUBTEST_LIST; do
+				echo $subtest
+			done
+
+			exit 0
 			;;
-		--run-subtest)
-			exit 79
+		--run-subtest | --run-subtest=*)
+			if [ -z "$IGT_SUBTEST_LIST" ]; then
+				exit 79
+			fi
+
+			if [ x"${arg#--run-subtest=}" != x"$arg" ]; then
+				IGT_SUBTEST=${arg#--run-subtest=}
+			elif [ $arg_idx -lt $# ]; then
+				arg_idx=$(expr $arg_idx + 1)
+				IGT_SUBTEST=$(eval echo \$$arg_idx)
+			else
+				die "missing argument to $arg"
+			fi
+
+			if ! echo "$IGT_SUBTEST_LIST" | \
+			     grep -q "\<$IGT_SUBTEST\>"; then
+				die "unknown subtest $IGT_SUBTEST"
+			fi
 			;;
 		--debug)
 			IGT_LOG_LEVEL=debug
@@ -26,13 +59,9 @@ for arg in $@ ; do
 			exit 0
 			;;
 	esac
+	arg_idx=$(expr $arg_idx + 1)
 done
 
-die() {
-	echo "$@"
-	exit 1
-}
-
 do_or_die() {
 	$@ > /dev/null 2>&1 || (echo "FAIL: $@ ($?)" && exit -1)
 }
diff --git a/tests/drv_module_reload_basic b/tests/drv_module_reload_basic
index ec1bae8..37d4bbc 100755
--- a/tests/drv_module_reload_basic
+++ b/tests/drv_module_reload_basic
@@ -5,9 +5,38 @@
 # ... we've broken this way too often :(
 #
 
+IGT_SUBTEST_LIST="
+basic
+basic-fault-init-early
+basic-fault-init-mmio
+basic-fault-init-hw
+"
+
 SOURCE_DIR="$( dirname "${BASH_SOURCE[0]}" )"
 . $SOURCE_DIR/drm_lib.sh
 
+if [ -z "$IGT_SUBTEST" ]; then
+	IGT_SUBTEST="basic"
+fi
+
+inject_fault_mask=
+
+case $IGT_SUBTEST in
+basic)
+	;;
+basic-fault-init-early)
+	inject_fault_mask=0x1
+	;;
+basic-fault-init-mmio)
+	inject_fault_mask=0x2
+	;;
+basic-fault-init-hw)
+	inject_fault_mask=0x4
+	;;
+*)
+	die "unknown subtest $IGT_SUBTEST"
+esac
+
 # no other drm service should be running, so we can just unbind
 
 # we must kick away fbcon (but only fbcon)
@@ -38,7 +67,13 @@ else
 	echo module successfully unloaded
 fi
 
-modprobe i915
+if [ -z "$inject_fault_mask" ]; then
+	modprobe i915
+else
+	modprobe i915 inject_fault=$inject_fault_mask
+	rmmod i915
+	modprobe i915
+fi
 echo 1 > /sys/class/vtconsole/vtcon1/bind
 
 modprobe snd_hda_intel
-- 
2.5.0



More information about the Intel-gfx mailing list