Fill the per-vCPU args when creating the perf_test VM instead of having the caller do so. This helps ensure that any adjustments to the number of pages (and thus vcpu_memory_bytes) are reflected in the per-VM args. Automatically filling the per-vCPU args will also allow a future patch to do the sync to the guest during creation. Signed-off-by: Sean Christopherson <seanjc@google.com> [Updated access_tracking_perf_test as well.] Signed-off-by: David Matlack <dmatlack@google.com> Reviewed-by: Ben Gardon <bgardon@google.com> Message-Id: <20211111000310.1435032-12-dmatlack@google.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
46 lines
1.1 KiB
C
46 lines
1.1 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* tools/testing/selftests/kvm/include/perf_test_util.h
|
|
*
|
|
* Copyright (C) 2020, Google LLC.
|
|
*/
|
|
|
|
#ifndef SELFTEST_KVM_PERF_TEST_UTIL_H
|
|
#define SELFTEST_KVM_PERF_TEST_UTIL_H
|
|
|
|
#include "kvm_util.h"
|
|
|
|
/* Default guest test virtual memory offset */
|
|
#define DEFAULT_GUEST_TEST_MEM 0xc0000000
|
|
|
|
#define DEFAULT_PER_VCPU_MEM_SIZE (1 << 30) /* 1G */
|
|
|
|
#define PERF_TEST_MEM_SLOT_INDEX 1
|
|
|
|
struct perf_test_vcpu_args {
|
|
uint64_t gpa;
|
|
uint64_t gva;
|
|
uint64_t pages;
|
|
|
|
/* Only used by the host userspace part of the vCPU thread */
|
|
int vcpu_id;
|
|
};
|
|
|
|
struct perf_test_args {
|
|
struct kvm_vm *vm;
|
|
uint64_t gpa;
|
|
uint64_t guest_page_size;
|
|
int wr_fract;
|
|
|
|
struct perf_test_vcpu_args vcpu_args[KVM_MAX_VCPUS];
|
|
};
|
|
|
|
extern struct perf_test_args perf_test_args;
|
|
|
|
struct kvm_vm *perf_test_create_vm(enum vm_guest_mode mode, int vcpus,
|
|
uint64_t vcpu_memory_bytes, int slots,
|
|
enum vm_mem_backing_src_type backing_src,
|
|
bool partition_vcpu_memory_access);
|
|
void perf_test_destroy_vm(struct kvm_vm *vm);
|
|
|
|
#endif /* SELFTEST_KVM_PERF_TEST_UTIL_H */
|