Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit ab0e9c4b authored by Shuah Khan (Samsung OSG)'s avatar Shuah Khan (Samsung OSG)
Browse files

selftests: kvm: return Kselftest Skip code for skipped tests



When kvm test is skipped because of unmet dependencies and/or unsupported
configuration, it exits with error which is treated as a fail by the
Kselftest framework. This leads to false negative result even when the test
could not be run.

Change it to return kselftest skip code when a test gets skipped to clearly
report that the test could not be run.

Change it to use ksft_exit_skip() when the test is skipped. In addition,
refine test_assert() message to include strerror() string and add explicit
check for EACCES to cleary identify when test doesn't run when access is
denied to resources required e.g: open /dev/kvm failed, rc: -1 errno: 13

Signed-off-by: default avatarShuah Khan (Samsung OSG) <shuah@kernel.org>
Acked-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
Signed-off-by: default avatarShuah Khan (Samsung OSG) <shuah@kernel.org>
parent 82337406
Loading
Loading
Loading
Loading
+7 −2
Original line number Original line Diff line number Diff line
@@ -13,6 +13,8 @@
#include <execinfo.h>
#include <execinfo.h>
#include <sys/syscall.h>
#include <sys/syscall.h>


#include "../../kselftest.h"

/* Dumps the current stack trace to stderr. */
/* Dumps the current stack trace to stderr. */
static void __attribute__((noinline)) test_dump_stack(void);
static void __attribute__((noinline)) test_dump_stack(void);
static void test_dump_stack(void)
static void test_dump_stack(void)
@@ -70,8 +72,9 @@ test_assert(bool exp, const char *exp_str,


		fprintf(stderr, "==== Test Assertion Failure ====\n"
		fprintf(stderr, "==== Test Assertion Failure ====\n"
			"  %s:%u: %s\n"
			"  %s:%u: %s\n"
			"  pid=%d tid=%d\n",
			"  pid=%d tid=%d - %s\n",
			file, line, exp_str, getpid(), gettid());
			file, line, exp_str, getpid(), gettid(),
			strerror(errno));
		test_dump_stack();
		test_dump_stack();
		if (fmt) {
		if (fmt) {
			fputs("  ", stderr);
			fputs("  ", stderr);
@@ -80,6 +83,8 @@ test_assert(bool exp, const char *exp_str,
		}
		}
		va_end(ap);
		va_end(ap);


		if (errno == EACCES)
			ksft_exit_skip("Access denied - Exiting.\n");
		exit(254);
		exit(254);
	}
	}


+2 −0
Original line number Original line Diff line number Diff line
@@ -28,6 +28,8 @@
#include <string.h>
#include <string.h>
#include <sys/ioctl.h>
#include <sys/ioctl.h>


#include "../kselftest.h"

#ifndef MSR_IA32_TSC_ADJUST
#ifndef MSR_IA32_TSC_ADJUST
#define MSR_IA32_TSC_ADJUST 0x3b
#define MSR_IA32_TSC_ADJUST 0x3b
#endif
#endif