Commit f54e66ae authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'linux-kselftest-5.4-rc3' of...

Merge tag 'linux-kselftest-5.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest

Pull Kselftest fixes from Shuah Khan:
 "Fixes for existing tests and the framework.

  Cristian Marussi's patches add the ability to skip targets (tests) and
  exclude tests that didn't build from run-list. These patches improve
  the Kselftest results. Ability to skip targets helps avoid running
  tests that aren't supported in certain environments. As an example,
  bpf tests from mainline aren't supported on stable kernels and have
  dependency on bleeding edge llvm. Being able to skip bpf on systems
  that can't meet this llvm dependency will be helpful.

  Kselftest can be built and installed from the main Makefile. This
  change help simplify Kselftest use-cases which addresses request from
  users.

  Kees Cook added per test timeout support to limit individual test
  run-time"

* tag 'linux-kselftest-5.4-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest:
  selftests: watchdog: Add command line option to show watchdog_info
  selftests: watchdog: Validate optional file argument
  selftests/kselftest/runner.sh: Add 45 second timeout per test
  kselftest: exclude failed TARGETS from runlist
  kselftest: add capability to skip chosen TARGETS
  selftests: Add kselftest-all and kselftest-install targets
parents eda57a0e ce3a6778
...@@ -89,6 +89,22 @@ To build, save output files in a separate directory with KBUILD_OUTPUT :: ...@@ -89,6 +89,22 @@ To build, save output files in a separate directory with KBUILD_OUTPUT ::
$ export KBUILD_OUTPUT=/tmp/kselftest; make TARGETS="size timers" kselftest $ export KBUILD_OUTPUT=/tmp/kselftest; make TARGETS="size timers" kselftest
Additionally you can use the "SKIP_TARGETS" variable on the make command
line to specify one or more targets to exclude from the TARGETS list.
To run all tests but a single subsystem::
$ make -C tools/testing/selftests SKIP_TARGETS=ptrace run_tests
You can specify multiple tests to skip::
$ make SKIP_TARGETS="size timers" kselftest
You can also specify a restricted list of tests to run together with a
dedicated skiplist::
$ make TARGETS="bpf breakpoints size timers" SKIP_TARGETS=bpf kselftest
See the top-level tools/testing/selftests/Makefile for the list of all See the top-level tools/testing/selftests/Makefile for the list of all
possible targets. possible targets.
......
...@@ -1217,9 +1217,8 @@ PHONY += kselftest ...@@ -1217,9 +1217,8 @@ PHONY += kselftest
kselftest: kselftest:
$(Q)$(MAKE) -C $(srctree)/tools/testing/selftests run_tests $(Q)$(MAKE) -C $(srctree)/tools/testing/selftests run_tests
PHONY += kselftest-clean kselftest-%: FORCE
kselftest-clean: $(Q)$(MAKE) -C $(srctree)/tools/testing/selftests $*
$(Q)$(MAKE) -C $(srctree)/tools/testing/selftests clean
PHONY += kselftest-merge PHONY += kselftest-merge
kselftest-merge: kselftest-merge:
......
...@@ -63,6 +63,13 @@ TARGETS += zram ...@@ -63,6 +63,13 @@ TARGETS += zram
TARGETS_HOTPLUG = cpu-hotplug TARGETS_HOTPLUG = cpu-hotplug
TARGETS_HOTPLUG += memory-hotplug TARGETS_HOTPLUG += memory-hotplug
# User can optionally provide a TARGETS skiplist.
SKIP_TARGETS ?=
ifneq ($(SKIP_TARGETS),)
TMP := $(filter-out $(SKIP_TARGETS), $(TARGETS))
override TARGETS := $(TMP)
endif
# Clear LDFLAGS and MAKEFLAGS if called from main # Clear LDFLAGS and MAKEFLAGS if called from main
# Makefile to avoid test build failures when test # Makefile to avoid test build failures when test
# Makefile doesn't have explicit build rules. # Makefile doesn't have explicit build rules.
...@@ -171,9 +178,12 @@ run_pstore_crash: ...@@ -171,9 +178,12 @@ run_pstore_crash:
# 1. output_dir=kernel_src # 1. output_dir=kernel_src
# 2. a separate output directory is specified using O= KBUILD_OUTPUT # 2. a separate output directory is specified using O= KBUILD_OUTPUT
# 3. a separate output directory is specified using KBUILD_OUTPUT # 3. a separate output directory is specified using KBUILD_OUTPUT
# Avoid conflict with INSTALL_PATH set by the main Makefile
# #
INSTALL_PATH ?= $(BUILD)/install KSFT_INSTALL_PATH ?= $(BUILD)/kselftest_install
INSTALL_PATH := $(abspath $(INSTALL_PATH)) KSFT_INSTALL_PATH := $(abspath $(KSFT_INSTALL_PATH))
# Avoid changing the rest of the logic here and lib.mk.
INSTALL_PATH := $(KSFT_INSTALL_PATH)
ALL_SCRIPT := $(INSTALL_PATH)/run_kselftest.sh ALL_SCRIPT := $(INSTALL_PATH)/run_kselftest.sh
install: all install: all
...@@ -198,11 +208,16 @@ ifdef INSTALL_PATH ...@@ -198,11 +208,16 @@ ifdef INSTALL_PATH
echo " cat /dev/null > \$$logfile" >> $(ALL_SCRIPT) echo " cat /dev/null > \$$logfile" >> $(ALL_SCRIPT)
echo "fi" >> $(ALL_SCRIPT) echo "fi" >> $(ALL_SCRIPT)
@# While building run_kselftest.sh skip also non-existent TARGET dirs:
@# they could be the result of a build failure and should NOT be
@# included in the generated runlist.
for TARGET in $(TARGETS); do \ for TARGET in $(TARGETS); do \
BUILD_TARGET=$$BUILD/$$TARGET; \ BUILD_TARGET=$$BUILD/$$TARGET; \
[ ! -d $$INSTALL_PATH/$$TARGET ] && echo "Skipping non-existent dir: $$TARGET" && continue; \
echo "[ -w /dev/kmsg ] && echo \"kselftest: Running tests in $$TARGET\" >> /dev/kmsg" >> $(ALL_SCRIPT); \ echo "[ -w /dev/kmsg ] && echo \"kselftest: Running tests in $$TARGET\" >> /dev/kmsg" >> $(ALL_SCRIPT); \
echo "cd $$TARGET" >> $(ALL_SCRIPT); \ echo "cd $$TARGET" >> $(ALL_SCRIPT); \
echo -n "run_many" >> $(ALL_SCRIPT); \ echo -n "run_many" >> $(ALL_SCRIPT); \
echo -n "Emit Tests for $$TARGET\n"; \
$(MAKE) -s --no-print-directory OUTPUT=$$BUILD_TARGET -C $$TARGET emit_tests >> $(ALL_SCRIPT); \ $(MAKE) -s --no-print-directory OUTPUT=$$BUILD_TARGET -C $$TARGET emit_tests >> $(ALL_SCRIPT); \
echo "" >> $(ALL_SCRIPT); \ echo "" >> $(ALL_SCRIPT); \
echo "cd \$$ROOT" >> $(ALL_SCRIPT); \ echo "cd \$$ROOT" >> $(ALL_SCRIPT); \
......
...@@ -3,9 +3,14 @@ ...@@ -3,9 +3,14 @@
# #
# Runs a set of tests in a given subdirectory. # Runs a set of tests in a given subdirectory.
export skip_rc=4 export skip_rc=4
export timeout_rc=124
export logfile=/dev/stdout export logfile=/dev/stdout
export per_test_logging= export per_test_logging=
# Defaults for "settings" file fields:
# "timeout" how many seconds to let each test run before failing.
export kselftest_default_timeout=45
# There isn't a shell-agnostic way to find the path of a sourced file, # There isn't a shell-agnostic way to find the path of a sourced file,
# so we must rely on BASE_DIR being set to find other tools. # so we must rely on BASE_DIR being set to find other tools.
if [ -z "$BASE_DIR" ]; then if [ -z "$BASE_DIR" ]; then
...@@ -24,6 +29,16 @@ tap_prefix() ...@@ -24,6 +29,16 @@ tap_prefix()
fi fi
} }
tap_timeout()
{
# Make sure tests will time out if utility is available.
if [ -x /usr/bin/timeout ] ; then
/usr/bin/timeout "$kselftest_timeout" "$1"
else
"$1"
fi
}
run_one() run_one()
{ {
DIR="$1" DIR="$1"
...@@ -32,6 +47,18 @@ run_one() ...@@ -32,6 +47,18 @@ run_one()
BASENAME_TEST=$(basename $TEST) BASENAME_TEST=$(basename $TEST)
# Reset any "settings"-file variables.
export kselftest_timeout="$kselftest_default_timeout"
# Load per-test-directory kselftest "settings" file.
settings="$BASE_DIR/$DIR/settings"
if [ -r "$settings" ] ; then
while read line ; do
field=$(echo "$line" | cut -d= -f1)
value=$(echo "$line" | cut -d= -f2-)
eval "kselftest_$field"="$value"
done < "$settings"
fi
TEST_HDR_MSG="selftests: $DIR: $BASENAME_TEST" TEST_HDR_MSG="selftests: $DIR: $BASENAME_TEST"
echo "# $TEST_HDR_MSG" echo "# $TEST_HDR_MSG"
if [ ! -x "$TEST" ]; then if [ ! -x "$TEST" ]; then
...@@ -44,14 +71,17 @@ run_one() ...@@ -44,14 +71,17 @@ run_one()
echo "not ok $test_num $TEST_HDR_MSG" echo "not ok $test_num $TEST_HDR_MSG"
else else
cd `dirname $TEST` > /dev/null cd `dirname $TEST` > /dev/null
(((((./$BASENAME_TEST 2>&1; echo $? >&3) | ((((( tap_timeout ./$BASENAME_TEST 2>&1; echo $? >&3) |
tap_prefix >&4) 3>&1) | tap_prefix >&4) 3>&1) |
(read xs; exit $xs)) 4>>"$logfile" && (read xs; exit $xs)) 4>>"$logfile" &&
echo "ok $test_num $TEST_HDR_MSG") || echo "ok $test_num $TEST_HDR_MSG") ||
(if [ $? -eq $skip_rc ]; then \ (rc=$?; \
if [ $rc -eq $skip_rc ]; then \
echo "not ok $test_num $TEST_HDR_MSG # SKIP" echo "not ok $test_num $TEST_HDR_MSG # SKIP"
elif [ $rc -eq $timeout_rc ]; then \
echo "not ok $test_num $TEST_HDR_MSG # TIMEOUT"
else else
echo "not ok $test_num $TEST_HDR_MSG" echo "not ok $test_num $TEST_HDR_MSG # exit=$rc"
fi) fi)
cd - >/dev/null cd - >/dev/null
fi fi
......
...@@ -24,12 +24,12 @@ main() ...@@ -24,12 +24,12 @@ main()
echo "$0: Installing in specified location - $install_loc ..." echo "$0: Installing in specified location - $install_loc ..."
fi fi
install_dir=$install_loc/kselftest install_dir=$install_loc/kselftest_install
# Create install directory # Create install directory
mkdir -p $install_dir mkdir -p $install_dir
# Build tests # Build tests
INSTALL_PATH=$install_dir make install KSFT_INSTALL_PATH=$install_dir make install
} }
main "$@" main "$@"
...@@ -19,7 +19,7 @@ ...@@ -19,7 +19,7 @@
int fd; int fd;
const char v = 'V'; const char v = 'V';
static const char sopts[] = "bdehp:t:Tn:NLf:"; static const char sopts[] = "bdehp:t:Tn:NLf:i";
static const struct option lopts[] = { static const struct option lopts[] = {
{"bootstatus", no_argument, NULL, 'b'}, {"bootstatus", no_argument, NULL, 'b'},
{"disable", no_argument, NULL, 'd'}, {"disable", no_argument, NULL, 'd'},
...@@ -32,6 +32,7 @@ static const struct option lopts[] = { ...@@ -32,6 +32,7 @@ static const struct option lopts[] = {
{"getpretimeout", no_argument, NULL, 'N'}, {"getpretimeout", no_argument, NULL, 'N'},
{"gettimeleft", no_argument, NULL, 'L'}, {"gettimeleft", no_argument, NULL, 'L'},
{"file", required_argument, NULL, 'f'}, {"file", required_argument, NULL, 'f'},
{"info", no_argument, NULL, 'i'},
{NULL, no_argument, NULL, 0x0} {NULL, no_argument, NULL, 0x0}
}; };
...@@ -72,6 +73,7 @@ static void usage(char *progname) ...@@ -72,6 +73,7 @@ static void usage(char *progname)
printf("Usage: %s [options]\n", progname); printf("Usage: %s [options]\n", progname);
printf(" -f, --file\t\tOpen watchdog device file\n"); printf(" -f, --file\t\tOpen watchdog device file\n");
printf("\t\t\tDefault is /dev/watchdog\n"); printf("\t\t\tDefault is /dev/watchdog\n");
printf(" -i, --info\t\tShow watchdog_info\n");
printf(" -b, --bootstatus\tGet last boot status (Watchdog/POR)\n"); printf(" -b, --bootstatus\tGet last boot status (Watchdog/POR)\n");
printf(" -d, --disable\t\tTurn off the watchdog timer\n"); printf(" -d, --disable\t\tTurn off the watchdog timer\n");
printf(" -e, --enable\t\tTurn on the watchdog timer\n"); printf(" -e, --enable\t\tTurn on the watchdog timer\n");
...@@ -97,6 +99,7 @@ int main(int argc, char *argv[]) ...@@ -97,6 +99,7 @@ int main(int argc, char *argv[])
int c; int c;
int oneshot = 0; int oneshot = 0;
char *file = "/dev/watchdog"; char *file = "/dev/watchdog";
struct watchdog_info info;
setbuf(stdout, NULL); setbuf(stdout, NULL);
...@@ -118,6 +121,16 @@ int main(int argc, char *argv[]) ...@@ -118,6 +121,16 @@ int main(int argc, char *argv[])
exit(-1); exit(-1);
} }
/*
* Validate that `file` is a watchdog device
*/
ret = ioctl(fd, WDIOC_GETSUPPORT, &info);
if (ret) {
printf("WDIOC_GETSUPPORT error '%s'\n", strerror(errno));
close(fd);
exit(ret);
}
optind = 0; optind = 0;
while ((c = getopt_long(argc, argv, sopts, lopts, NULL)) != -1) { while ((c = getopt_long(argc, argv, sopts, lopts, NULL)) != -1) {
...@@ -205,6 +218,18 @@ int main(int argc, char *argv[]) ...@@ -205,6 +218,18 @@ int main(int argc, char *argv[])
case 'f': case 'f':
/* Handled above */ /* Handled above */
break; break;
case 'i':
/*
* watchdog_info was obtained as part of file open
* validation. So we just show it here.
*/
oneshot = 1;
printf("watchdog_info:\n");
printf(" identity:\t\t%s\n", info.identity);
printf(" firmware_version:\t%u\n",
info.firmware_version);
printf(" options:\t\t%08x\n", info.options);
break;
default: default:
usage(argv[0]); usage(argv[0]);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment