diff options
Diffstat (limited to 'tools/testing/selftests/kvm/x86_64/tsc_msrs_test.c')
| -rw-r--r-- | tools/testing/selftests/kvm/x86_64/tsc_msrs_test.c | 158 |
1 files changed, 0 insertions, 158 deletions
diff --git a/tools/testing/selftests/kvm/x86_64/tsc_msrs_test.c b/tools/testing/selftests/kvm/x86_64/tsc_msrs_test.c deleted file mode 100644 index a426078b16a3..000000000000 --- a/tools/testing/selftests/kvm/x86_64/tsc_msrs_test.c +++ /dev/null @@ -1,158 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 -/* - * Tests for MSR_IA32_TSC and MSR_IA32_TSC_ADJUST. - * - * Copyright (C) 2020, Red Hat, Inc. - */ -#include <stdio.h> -#include <string.h> -#include "kvm_util.h" -#include "processor.h" - -#define VCPU_ID 0 - -#define UNITY (1ull << 30) -#define HOST_ADJUST (UNITY * 64) -#define GUEST_STEP (UNITY * 4) -#define ROUND(x) ((x + UNITY / 2) & -UNITY) -#define rounded_rdmsr(x) ROUND(rdmsr(x)) -#define rounded_host_rdmsr(x) ROUND(vcpu_get_msr(vm, 0, x)) - -static void guest_code(void) -{ - u64 val = 0; - - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC), val); - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC_ADJUST), val); - - /* Guest: writes to MSR_IA32_TSC affect both MSRs. */ - val = 1ull * GUEST_STEP; - wrmsr(MSR_IA32_TSC, val); - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC), val); - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC_ADJUST), val); - - /* Guest: writes to MSR_IA32_TSC_ADJUST affect both MSRs. */ - GUEST_SYNC(2); - val = 2ull * GUEST_STEP; - wrmsr(MSR_IA32_TSC_ADJUST, val); - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC), val); - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC_ADJUST), val); - - /* Host: setting the TSC offset. */ - GUEST_SYNC(3); - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC), HOST_ADJUST + val); - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC_ADJUST), val); - - /* - * Guest: writes to MSR_IA32_TSC_ADJUST do not destroy the - * host-side offset and affect both MSRs. - */ - GUEST_SYNC(4); - val = 3ull * GUEST_STEP; - wrmsr(MSR_IA32_TSC_ADJUST, val); - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC), HOST_ADJUST + val); - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC_ADJUST), val); - - /* - * Guest: writes to MSR_IA32_TSC affect both MSRs, so the host-side - * offset is now visible in MSR_IA32_TSC_ADJUST. - */ - GUEST_SYNC(5); - val = 4ull * GUEST_STEP; - wrmsr(MSR_IA32_TSC, val); - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC), val); - GUEST_ASSERT_EQ(rounded_rdmsr(MSR_IA32_TSC_ADJUST), val - HOST_ADJUST); - - GUEST_DONE(); -} - -static void run_vcpu(struct kvm_vm *vm, uint32_t vcpuid, int stage) -{ - struct ucall uc; - - vcpu_args_set(vm, vcpuid, 1, vcpuid); - - vcpu_ioctl(vm, vcpuid, KVM_RUN, NULL); - - switch (get_ucall(vm, vcpuid, &uc)) { - case UCALL_SYNC: - TEST_ASSERT(!strcmp((const char *)uc.args[0], "hello") && - uc.args[1] == stage + 1, "Stage %d: Unexpected register values vmexit, got %lx", - stage + 1, (ulong)uc.args[1]); - return; - case UCALL_DONE: - return; - case UCALL_ABORT: - TEST_ASSERT(false, "%s at %s:%ld\n" \ - "\tvalues: %#lx, %#lx", (const char *)uc.args[0], - __FILE__, uc.args[1], uc.args[2], uc.args[3]); - default: - TEST_ASSERT(false, "Unexpected exit: %s", - exit_reason_str(vcpu_state(vm, vcpuid)->exit_reason)); - } -} - -int main(void) -{ - struct kvm_vm *vm; - uint64_t val; - - vm = vm_create_default(VCPU_ID, 0, guest_code); - - val = 0; - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC), val); - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC_ADJUST), val); - - /* Guest: writes to MSR_IA32_TSC affect both MSRs. */ - run_vcpu(vm, VCPU_ID, 1); - val = 1ull * GUEST_STEP; - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC), val); - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC_ADJUST), val); - - /* Guest: writes to MSR_IA32_TSC_ADJUST affect both MSRs. */ - run_vcpu(vm, VCPU_ID, 2); - val = 2ull * GUEST_STEP; - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC), val); - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC_ADJUST), val); - - /* - * Host: writes to MSR_IA32_TSC set the host-side offset - * and therefore do not change MSR_IA32_TSC_ADJUST. - */ - vcpu_set_msr(vm, 0, MSR_IA32_TSC, HOST_ADJUST + val); - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC), HOST_ADJUST + val); - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC_ADJUST), val); - run_vcpu(vm, VCPU_ID, 3); - - /* Host: writes to MSR_IA32_TSC_ADJUST do not modify the TSC. */ - vcpu_set_msr(vm, 0, MSR_IA32_TSC_ADJUST, UNITY * 123456); - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC), HOST_ADJUST + val); - ASSERT_EQ(vcpu_get_msr(vm, 0, MSR_IA32_TSC_ADJUST), UNITY * 123456); - - /* Restore previous value. */ - vcpu_set_msr(vm, 0, MSR_IA32_TSC_ADJUST, val); - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC), HOST_ADJUST + val); - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC_ADJUST), val); - - /* - * Guest: writes to MSR_IA32_TSC_ADJUST do not destroy the - * host-side offset and affect both MSRs. - */ - run_vcpu(vm, VCPU_ID, 4); - val = 3ull * GUEST_STEP; - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC), HOST_ADJUST + val); - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC_ADJUST), val); - - /* - * Guest: writes to MSR_IA32_TSC affect both MSRs, so the host-side - * offset is now visible in MSR_IA32_TSC_ADJUST. - */ - run_vcpu(vm, VCPU_ID, 5); - val = 4ull * GUEST_STEP; - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC), val); - ASSERT_EQ(rounded_host_rdmsr(MSR_IA32_TSC_ADJUST), val - HOST_ADJUST); - - kvm_vm_free(vm); - - return 0; -} |
