Commit 06b651d2 authored by Sean Christopherson's avatar Sean Christopherson

KVM: selftests: Convert x86's CPUID test to printf style GUEST_ASSERT

Convert x86's CPUID test to use printf-based GUEST_ASSERT_EQ() so that
the test prints out debug information.  Note, the test previously used
REPORT_GUEST_ASSERT_2(), but that was pointless because none of the
guest-side code passed any parameters to the assert.

Link: https://lore.kernel.org/r/20230729003643.1053367-21-seanjc@google.comSigned-off-by: default avatarSean Christopherson <seanjc@google.com>
parent 3d9bd831
...@@ -4,6 +4,8 @@ ...@@ -4,6 +4,8 @@
* *
* Generic tests for KVM CPUID set/get ioctls * Generic tests for KVM CPUID set/get ioctls
*/ */
#define USE_GUEST_ASSERT_PRINTF 1
#include <asm/kvm_para.h> #include <asm/kvm_para.h>
#include <linux/kvm_para.h> #include <linux/kvm_para.h>
#include <stdint.h> #include <stdint.h>
...@@ -35,10 +37,10 @@ static void test_guest_cpuids(struct kvm_cpuid2 *guest_cpuid) ...@@ -35,10 +37,10 @@ static void test_guest_cpuids(struct kvm_cpuid2 *guest_cpuid)
guest_cpuid->entries[i].index, guest_cpuid->entries[i].index,
&eax, &ebx, &ecx, &edx); &eax, &ebx, &ecx, &edx);
GUEST_ASSERT(eax == guest_cpuid->entries[i].eax && GUEST_ASSERT_EQ(eax, guest_cpuid->entries[i].eax);
ebx == guest_cpuid->entries[i].ebx && GUEST_ASSERT_EQ(ebx, guest_cpuid->entries[i].ebx);
ecx == guest_cpuid->entries[i].ecx && GUEST_ASSERT_EQ(ecx, guest_cpuid->entries[i].ecx);
edx == guest_cpuid->entries[i].edx); GUEST_ASSERT_EQ(edx, guest_cpuid->entries[i].edx);
} }
} }
...@@ -51,7 +53,7 @@ static void guest_main(struct kvm_cpuid2 *guest_cpuid) ...@@ -51,7 +53,7 @@ static void guest_main(struct kvm_cpuid2 *guest_cpuid)
GUEST_SYNC(2); GUEST_SYNC(2);
GUEST_ASSERT(this_cpu_property(X86_PROPERTY_MAX_KVM_LEAF) == 0x40000001); GUEST_ASSERT_EQ(this_cpu_property(X86_PROPERTY_MAX_KVM_LEAF), 0x40000001);
GUEST_DONE(); GUEST_DONE();
} }
...@@ -116,7 +118,7 @@ static void run_vcpu(struct kvm_vcpu *vcpu, int stage) ...@@ -116,7 +118,7 @@ static void run_vcpu(struct kvm_vcpu *vcpu, int stage)
case UCALL_DONE: case UCALL_DONE:
return; return;
case UCALL_ABORT: case UCALL_ABORT:
REPORT_GUEST_ASSERT_2(uc, "values: %#lx, %#lx"); REPORT_GUEST_ASSERT(uc);
default: default:
TEST_ASSERT(false, "Unexpected exit: %s", TEST_ASSERT(false, "Unexpected exit: %s",
exit_reason_str(vcpu->run->exit_reason)); exit_reason_str(vcpu->run->exit_reason));
......
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