@@ -567,6 +567,10 @@ struct vmx_pages {
uint64_t enlightened_vmcs_gpa;
void *enlightened_vmcs;
+ void *partition_assist_hva;
+ uint64_t partition_assist_gpa;
+ void *partition_assist;
+
void *eptp_hva;
uint64_t eptp_gpa;
void *eptp;
@@ -124,6 +124,13 @@ vcpu_alloc_vmx(struct kvm_vm *vm, vm_vaddr_t *p_vmx_gva)
vmx->enlightened_vmcs_gpa =
addr_gva2gpa(vm, (uintptr_t)vmx->enlightened_vmcs);
+ /* Setup of a region of guest memory for the partition assist page. */
+ vmx->partition_assist = (void *)vm_vaddr_alloc_page(vm);
+ vmx->partition_assist_hva =
+ addr_gva2hva(vm, (uintptr_t)vmx->partition_assist);
+ vmx->partition_assist_gpa =
+ addr_gva2gpa(vm, (uintptr_t)vmx->partition_assist);
+
*p_vmx_gva = vmx_gva;
return vmx;
}
In preparation to testing Hyper-V Direct TLB flush hypercalls, allocate so-called Partition assist page and link it to 'struct vmx_pages'. Signed-off-by: Vitaly Kuznetsov <vkuznets@redhat.com> --- tools/testing/selftests/kvm/include/x86_64/vmx.h | 4 ++++ tools/testing/selftests/kvm/lib/x86_64/vmx.c | 7 +++++++ 2 files changed, 11 insertions(+)