Re: [PATCH v8 33/39] KVM: selftests: nVMX: Allocate Hyper-V partition assist page

From: Sean Christopherson
Date: Thu Jul 21 2022 - 17:34:55 EST


On Thu, Jul 14, 2022, Vitaly Kuznetsov wrote:
> In preparation to testing Hyper-V L2 TLB flush hypercalls, allocate
> so-called Partition assist page and link it to 'struct vmx_pages'.
>
> Reviewed-by: Maxim Levitsky <mlevitsk@xxxxxxxxxx>
> Signed-off-by: Vitaly Kuznetsov <vkuznets@xxxxxxxxxx>
> ---
> 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(+)
>
> diff --git a/tools/testing/selftests/kvm/include/x86_64/vmx.h b/tools/testing/selftests/kvm/include/x86_64/vmx.h
> index cc3604f8f1d3..f7c8184c1de8 100644
> --- a/tools/testing/selftests/kvm/include/x86_64/vmx.h
> +++ b/tools/testing/selftests/kvm/include/x86_64/vmx.h
> @@ -570,6 +570,10 @@ struct vmx_pages {
> uint64_t enlightened_vmcs_gpa;
> void *enlightened_vmcs;
>
> + void *partition_assist_hva;
> + uint64_t partition_assist_gpa;
> + void *partition_assist;

Rather than duplicate this and other Hyper-V stuff, can you first add a struct
to hold the Hyper-V pages, along with a helper to populate them? I'd even throw
in the eVMCS stuff, it's trivial for the helper to have a flag saying "don't bother
allocating eVMCS". That will give us an easier path to allocating these pages
if and only if the test actually wants to enable Hyper-V stuff.