|
@@ -128,6 +128,43 @@ if check_set_ftrace_filter "$FUNC1" "$FUNC2" ; then
|
|
fail "Expected $FUNC1 and $FUNC2"
|
|
fail "Expected $FUNC1 and $FUNC2"
|
|
fi
|
|
fi
|
|
|
|
|
|
|
|
+test_actual() { # Compares $TMPDIR/expected with set_ftrace_filter
|
|
|
|
+ cat set_ftrace_filter | grep -v '#' | cut -d' ' -f1 | cut -d':' -f1 | sort -u > $TMPDIR/actual
|
|
|
|
+ DIFF=`diff $TMPDIR/actual $TMPDIR/expected`
|
|
|
|
+ test -z "$DIFF"
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+# Set traceoff trigger for all fuctions with "lock" in their name
|
|
|
|
+cat available_filter_functions | cut -d' ' -f1 | grep 'lock' | sort -u > $TMPDIR/expected
|
|
|
|
+echo '*lock*:traceoff' > set_ftrace_filter
|
|
|
|
+test_actual
|
|
|
|
+
|
|
|
|
+# now remove all with 'try' in it, and end with lock
|
|
|
|
+grep -v 'try.*lock$' $TMPDIR/expected > $TMPDIR/expected2
|
|
|
|
+mv $TMPDIR/expected2 $TMPDIR/expected
|
|
|
|
+echo '!*try*lock:traceoff' >> set_ftrace_filter
|
|
|
|
+test_actual
|
|
|
|
+
|
|
|
|
+# remove all that start with "m" and end with "lock"
|
|
|
|
+grep -v '^m.*lock$' $TMPDIR/expected > $TMPDIR/expected2
|
|
|
|
+mv $TMPDIR/expected2 $TMPDIR/expected
|
|
|
|
+echo '!m*lock:traceoff' >> set_ftrace_filter
|
|
|
|
+test_actual
|
|
|
|
+
|
|
|
|
+# remove all that start with "c" and have "unlock"
|
|
|
|
+grep -v '^c.*unlock' $TMPDIR/expected > $TMPDIR/expected2
|
|
|
|
+mv $TMPDIR/expected2 $TMPDIR/expected
|
|
|
|
+echo '!c*unlock*:traceoff' >> set_ftrace_filter
|
|
|
|
+test_actual
|
|
|
|
+
|
|
|
|
+# clear all the rest
|
|
|
|
+> $TMPDIR/expected
|
|
|
|
+echo '!*:traceoff' >> set_ftrace_filter
|
|
|
|
+test_actual
|
|
|
|
+
|
|
|
|
+rm $TMPDIR/expected
|
|
|
|
+rm $TMPDIR/actual
|
|
|
|
+
|
|
do_reset
|
|
do_reset
|
|
|
|
|
|
exit 0
|
|
exit 0
|