Add a union to provide hv_enlightenments side-by-side with the sw_reserved
bytes that Hyper-V's enlightenments overlay.  Casting sw_reserved
everywhere is messy, confusing, and unnecessarily unsafe.
No functional change intended.
Signed-off-by: Sean Christopherson <seanjc@google.com>
Signed-off-by: Vitaly Kuznetsov <vkuznets@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Message-Id: <
20221101145426.251680-4-vkuznets@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
 #include <uapi/asm/svm.h>
 #include <uapi/asm/kvm.h>
 
+#include <asm/hyperv-tlfs.h>
+
 /*
  * 32-bit intercept words in the VMCB Control Area, starting
  * at Byte offset 000h.
         * Offset 0x3e0, 32 bytes reserved
         * for use by hypervisor/software.
         */
-       u8 reserved_sw[32];
+       union {
+               struct hv_enlightenments hv_enlightenments;
+               u8 reserved_sw[32];
+       };
 };
 
 
 
  */
 static bool nested_svm_vmrun_msrpm(struct vcpu_svm *svm)
 {
-       struct hv_enlightenments *hve =
-               (struct hv_enlightenments *)svm->nested.ctl.reserved_sw;
+       struct hv_enlightenments *hve = &svm->nested.ctl.hv_enlightenments;
        int i;
 
        /*
        /* Hyper-V extensions (Enlightened VMCB) */
        if (kvm_hv_hypercall_enabled(vcpu)) {
                to->clean = from->clean;
-               memcpy(to->reserved_sw, from->reserved_sw,
-                      sizeof(struct hv_enlightenments));
+               memcpy(&to->hv_enlightenments, &from->hv_enlightenments,
+                      sizeof(to->hv_enlightenments));
        }
 }
 
        dst->virt_ext              = from->virt_ext;
        dst->pause_filter_count   = from->pause_filter_count;
        dst->pause_filter_thresh  = from->pause_filter_thresh;
-       /* 'clean' and 'reserved_sw' are not changed by KVM */
+       /* 'clean' and 'hv_enlightenments' are not changed by KVM */
 }
 
 static int svm_get_nested_state(struct kvm_vcpu *vcpu,
 
        u64 nested_cr3;
        u64 virt_ext;
        u32 clean;
-       u8 reserved_sw[32];
+       union {
+               struct hv_enlightenments hv_enlightenments;
+               u8 reserved_sw[32];
+       };
 };
 
 struct svm_nested_state {
 
        if (!*p_hv_pa_pg)
                return -ENOMEM;
 
-       hve = (struct hv_enlightenments *)to_svm(vcpu)->vmcb->control.reserved_sw;
+       hve = &to_svm(vcpu)->vmcb->control.hv_enlightenments;
 
        hve->partition_assist_page = __pa(*p_hv_pa_pg);
        hve->hv_vm_id = (unsigned long)vcpu->kvm;
 
 
 static inline void svm_hv_init_vmcb(struct vmcb *vmcb)
 {
-       struct hv_enlightenments *hve =
-               (struct hv_enlightenments *)vmcb->control.reserved_sw;
+       struct hv_enlightenments *hve = &vmcb->control.hv_enlightenments;
+
+       BUILD_BUG_ON(sizeof(vmcb->control.hv_enlightenments) !=
+                    sizeof(vmcb->control.reserved_sw));
 
        if (npt_enabled &&
            ms_hyperv.nested_features & HV_X64_NESTED_ENLIGHTENED_TLB)
                struct kvm_vcpu *vcpu)
 {
        struct vmcb *vmcb = to_svm(vcpu)->vmcb;
-       struct hv_enlightenments *hve =
-               (struct hv_enlightenments *)vmcb->control.reserved_sw;
+       struct hv_enlightenments *hve = &vmcb->control.hv_enlightenments;
 
        if (hve->hv_enlightenments_control.msr_bitmap)
                vmcb_mark_dirty(vmcb, HV_VMCB_NESTED_ENLIGHTENMENTS);
 }
 
-static inline void svm_hv_update_vp_id(struct vmcb *vmcb,
-               struct kvm_vcpu *vcpu)
+static inline void svm_hv_update_vp_id(struct vmcb *vmcb, struct kvm_vcpu *vcpu)
 {
-       struct hv_enlightenments *hve =
-               (struct hv_enlightenments *)vmcb->control.reserved_sw;
+       struct hv_enlightenments *hve = &vmcb->control.hv_enlightenments;
        u32 vp_index = kvm_hv_get_vpindex(vcpu);
 
        if (hve->hv_vp_id != vp_index) {
 
         * Offset 0x3e0, 32 bytes reserved
         * for use by hypervisor/software.
         */
-       u8 reserved_sw[32];
+       union {
+               struct hv_enlightenments hv_enlightenments;
+               u8 reserved_sw[32];
+       };
 };
 
 
 
 {
        unsigned long l2_guest_stack[L2_GUEST_STACK_SIZE];
        struct vmcb *vmcb = svm->vmcb;
-       struct hv_enlightenments *hve =
-               (struct hv_enlightenments *)vmcb->control.reserved_sw;
+       struct hv_enlightenments *hve = &vmcb->control.hv_enlightenments;
 
        GUEST_SYNC(1);