When Secure AVIC is enabled, call Secure AVIC
function to allow Hyper-V to inject STIMER0 interrupt.

Reviewed-by: Neeraj Upadhyay <[email protected]>
Reviewed-by: Michael Kelley <[email protected]>
Signed-off-by: Tianyu Lan <[email protected]>
---
 arch/x86/hyperv/hv_init.c | 7 +++++++
 1 file changed, 7 insertions(+)

diff --git a/arch/x86/hyperv/hv_init.c b/arch/x86/hyperv/hv_init.c
index afdbda2dd7b7..a38bb96c9f5e 100644
--- a/arch/x86/hyperv/hv_init.c
+++ b/arch/x86/hyperv/hv_init.c
@@ -133,6 +133,10 @@ static int hv_cpu_init(unsigned int cpu)
                wrmsrq(HV_X64_MSR_VP_ASSIST_PAGE, msr.as_uint64);
        }
 
+       /* Allow Hyper-V stimer vector to be injected from Hypervisor. */
+       if (ms_hyperv.misc_features & HV_STIMER_DIRECT_MODE_AVAILABLE)
+               apic_update_vector(cpu, HYPERV_STIMER0_VECTOR, true);
+
        return hyperv_init_ghcb();
 }
 
@@ -240,6 +244,9 @@ static int hv_cpu_die(unsigned int cpu)
                *ghcb_va = NULL;
        }
 
+       if (ms_hyperv.misc_features & HV_STIMER_DIRECT_MODE_AVAILABLE)
+               apic_update_vector(cpu, HYPERV_STIMER0_VECTOR, false);
+
        hv_common_cpu_die(cpu);
 
        if (hv_vp_assist_page && hv_vp_assist_page[cpu]) {
-- 
2.25.1


Reply via email to