Skip to content

Commit 8df98ae

Browse files
Sean Christophersonbonzini
authored andcommitted
KVM: selftests: assert on exit reason in CR4/cpuid sync test
...so that the test doesn't end up in an infinite loop if it fails for whatever reason, e.g. SHUTDOWN due to gcc inserting stack canary code into ucall() and attempting to derefence a null segment. Fixes: ca35906 ("kvm: selftests: add cr4_cpuid_sync_test") Cc: Wei Huang <wei@redhat.com> Signed-off-by: Sean Christopherson <sean.j.christopherson@intel.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
1 parent 45def77 commit 8df98ae

File tree

1 file changed

+19
-16
lines changed

1 file changed

+19
-16
lines changed

tools/testing/selftests/kvm/x86_64/cr4_cpuid_sync_test.c

Lines changed: 19 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -87,22 +87,25 @@ int main(int argc, char *argv[])
8787
while (1) {
8888
rc = _vcpu_run(vm, VCPU_ID);
8989

90-
if (run->exit_reason == KVM_EXIT_IO) {
91-
switch (get_ucall(vm, VCPU_ID, &uc)) {
92-
case UCALL_SYNC:
93-
/* emulate hypervisor clearing CR4.OSXSAVE */
94-
vcpu_sregs_get(vm, VCPU_ID, &sregs);
95-
sregs.cr4 &= ~X86_CR4_OSXSAVE;
96-
vcpu_sregs_set(vm, VCPU_ID, &sregs);
97-
break;
98-
case UCALL_ABORT:
99-
TEST_ASSERT(false, "Guest CR4 bit (OSXSAVE) unsynchronized with CPUID bit.");
100-
break;
101-
case UCALL_DONE:
102-
goto done;
103-
default:
104-
TEST_ASSERT(false, "Unknown ucall 0x%x.", uc.cmd);
105-
}
90+
TEST_ASSERT(run->exit_reason == KVM_EXIT_IO,
91+
"Unexpected exit reason: %u (%s),\n",
92+
run->exit_reason,
93+
exit_reason_str(run->exit_reason));
94+
95+
switch (get_ucall(vm, VCPU_ID, &uc)) {
96+
case UCALL_SYNC:
97+
/* emulate hypervisor clearing CR4.OSXSAVE */
98+
vcpu_sregs_get(vm, VCPU_ID, &sregs);
99+
sregs.cr4 &= ~X86_CR4_OSXSAVE;
100+
vcpu_sregs_set(vm, VCPU_ID, &sregs);
101+
break;
102+
case UCALL_ABORT:
103+
TEST_ASSERT(false, "Guest CR4 bit (OSXSAVE) unsynchronized with CPUID bit.");
104+
break;
105+
case UCALL_DONE:
106+
goto done;
107+
default:
108+
TEST_ASSERT(false, "Unknown ucall 0x%x.", uc.cmd);
106109
}
107110
}
108111

0 commit comments

Comments
 (0)