summaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorThadeu Lima de Souza Cascardo <cascardo@canonical.com>2020-07-28 17:50:39 +0200
committerMichael Ellerman <mpe@ellerman.id.au>2020-07-29 15:47:52 +0200
commitf3054ffd71b5afd44832b2207e6e90267e1cd2d1 (patch)
tree30a8fb4ca8444786a7895aaf8582ec711d22fec8 /tools
parentpowerpc/test_emulate_step: Add testcases for divde[.] and divdeu[.] instructions (diff)
downloadlinux-f3054ffd71b5afd44832b2207e6e90267e1cd2d1.tar.xz
linux-f3054ffd71b5afd44832b2207e6e90267e1cd2d1.zip
selftests/powerpc: Return skip code for spectre_v2
When running under older versions of qemu of under newer versions with old machine types, some security features will not be reported to the guest. This will lead the guest OS to consider itself Vulnerable to spectre_v2. So, spectre_v2 test fails in such cases when the host is mitigated and miss predictions cannot be detected as expected by the test. Make it return the skip code instead, for this particular case. We don't want to miss the case when the test fails and the system reports as mitigated or not affected. But it is not a problem to miss failures when the system reports as Vulnerable. Signed-off-by: Thadeu Lima de Souza Cascardo <cascardo@canonical.com> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/20200728155039.401445-1-cascardo@canonical.com
Diffstat (limited to 'tools')
-rw-r--r--tools/testing/selftests/powerpc/security/spectre_v2.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/tools/testing/selftests/powerpc/security/spectre_v2.c b/tools/testing/selftests/powerpc/security/spectre_v2.c
index 8c6b982af2a8..c8d82b784102 100644
--- a/tools/testing/selftests/powerpc/security/spectre_v2.c
+++ b/tools/testing/selftests/powerpc/security/spectre_v2.c
@@ -183,6 +183,16 @@ int spectre_v2_test(void)
if (miss_percent > 15) {
printf("Branch misses > 15%% unexpected in this configuration!\n");
printf("Possible mis-match between reported & actual mitigation\n");
+ /*
+ * Such a mismatch may be caused by a guest system
+ * reporting as vulnerable when the host is mitigated.
+ * Return skip code to avoid detecting this as an error.
+ * We are not vulnerable and reporting otherwise, so
+ * missing such a mismatch is safe.
+ */
+ if (state == VULNERABLE)
+ return 4;
+
return 1;
}
break;