struct vmcs_config;
 
-DECLARE_STATIC_KEY_FALSE(enable_evmcs);
-
 #define current_evmcs ((struct hv_enlightened_vmcs *)this_cpu_read(current_vmcs))
 
 #define KVM_EVMCS_VERSION 1
 
 #if IS_ENABLED(CONFIG_HYPERV)
 
+DECLARE_STATIC_KEY_FALSE(enable_evmcs);
+
+static __always_inline bool kvm_is_using_evmcs(void)
+{
+       return static_branch_unlikely(&enable_evmcs);
+}
+
 static __always_inline int get_evmcs_offset(unsigned long field,
                                            u16 *clean_field)
 {
 
 void evmcs_sanitize_exec_ctrls(struct vmcs_config *vmcs_conf);
 #else /* !IS_ENABLED(CONFIG_HYPERV) */
+static __always_inline bool kvm_is_using_evmcs(void) { return false; }
 static __always_inline void evmcs_write64(unsigned long field, u64 value) {}
 static __always_inline void evmcs_write32(unsigned long field, u32 value) {}
 static __always_inline void evmcs_write16(unsigned long field, u16 value) {}
 
 {
        struct hv_vp_assist_page *vp_ap;
 
-       if (!static_branch_unlikely(&enable_evmcs))
+       if (!kvm_is_using_evmcs())
                return;
 
        /*
         * This can happen if we hot-added a CPU but failed to allocate
         * VP assist page for it.
         */
-       if (static_branch_unlikely(&enable_evmcs) &&
-           !hv_get_vp_assist_page(cpu))
+       if (kvm_is_using_evmcs() && !hv_get_vp_assist_page(cpu))
                return -EFAULT;
 
        intel_pt_handle_vmx(1);
        memset(vmcs, 0, vmcs_config.size);
 
        /* KVM supports Enlightened VMCS v1 only */
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                vmcs->hdr.revision_id = KVM_EVMCS_VERSION;
        else
                vmcs->hdr.revision_id = vmcs_config.revision_id;
                 * still be marked with revision_id reported by
                 * physical CPU.
                 */
-               if (static_branch_unlikely(&enable_evmcs))
+               if (kvm_is_using_evmcs())
                        vmcs->hdr.revision_id = vmcs_config.revision_id;
 
                per_cpu(vmxarea, cpu) = vmcs;
         * 'Enlightened MSR Bitmap' feature L0 needs to know that MSR
         * bitmap has changed.
         */
-       if (IS_ENABLED(CONFIG_HYPERV) && static_branch_unlikely(&enable_evmcs)) {
+       if (kvm_is_using_evmcs()) {
                struct hv_enlightened_vmcs *evmcs = (void *)vmx->vmcs01.vmcs;
 
                if (evmcs->hv_enlightenments_control.msr_bitmap)
        vmx_vcpu_enter_exit(vcpu, __vmx_vcpu_run_flags(vmx));
 
        /* All fields are clean at this point */
-       if (static_branch_unlikely(&enable_evmcs)) {
+       if (kvm_is_using_evmcs()) {
                current_evmcs->hv_clean_fields |=
                        HV_VMX_ENLIGHTENED_CLEAN_FIELD_ALL;
 
         * feature only for vmcs01, KVM currently isn't equipped to realize any
         * performance benefits from enabling it for vmcs02.
         */
-       if (IS_ENABLED(CONFIG_HYPERV) && static_branch_unlikely(&enable_evmcs) &&
+       if (kvm_is_using_evmcs() &&
            (ms_hyperv.nested_features & HV_X64_NESTED_MSR_BITMAP)) {
                struct hv_enlightened_vmcs *evmcs = (void *)vmx->vmcs01.vmcs;
 
 
 static __always_inline u16 vmcs_read16(unsigned long field)
 {
        vmcs_check16(field);
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                return evmcs_read16(field);
        return __vmcs_readl(field);
 }
 static __always_inline u32 vmcs_read32(unsigned long field)
 {
        vmcs_check32(field);
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                return evmcs_read32(field);
        return __vmcs_readl(field);
 }
 static __always_inline u64 vmcs_read64(unsigned long field)
 {
        vmcs_check64(field);
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                return evmcs_read64(field);
 #ifdef CONFIG_X86_64
        return __vmcs_readl(field);
 static __always_inline unsigned long vmcs_readl(unsigned long field)
 {
        vmcs_checkl(field);
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                return evmcs_read64(field);
        return __vmcs_readl(field);
 }
 static __always_inline void vmcs_write16(unsigned long field, u16 value)
 {
        vmcs_check16(field);
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                return evmcs_write16(field, value);
 
        __vmcs_writel(field, value);
 static __always_inline void vmcs_write32(unsigned long field, u32 value)
 {
        vmcs_check32(field);
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                return evmcs_write32(field, value);
 
        __vmcs_writel(field, value);
 static __always_inline void vmcs_write64(unsigned long field, u64 value)
 {
        vmcs_check64(field);
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                return evmcs_write64(field, value);
 
        __vmcs_writel(field, value);
 static __always_inline void vmcs_writel(unsigned long field, unsigned long value)
 {
        vmcs_checkl(field);
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                return evmcs_write64(field, value);
 
        __vmcs_writel(field, value);
 {
        BUILD_BUG_ON_MSG(__builtin_constant_p(field) && ((field) & 0x6000) == 0x2000,
                         "vmcs_clear_bits does not support 64-bit fields");
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                return evmcs_write32(field, evmcs_read32(field) & ~mask);
 
        __vmcs_writel(field, __vmcs_readl(field) & ~mask);
 {
        BUILD_BUG_ON_MSG(__builtin_constant_p(field) && ((field) & 0x6000) == 0x2000,
                         "vmcs_set_bits does not support 64-bit fields");
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                return evmcs_write32(field, evmcs_read32(field) | mask);
 
        __vmcs_writel(field, __vmcs_readl(field) | mask);
 {
        u64 phys_addr = __pa(vmcs);
 
-       if (static_branch_unlikely(&enable_evmcs))
+       if (kvm_is_using_evmcs())
                return evmcs_load(phys_addr);
 
        vmx_asm1(vmptrld, "m"(phys_addr), vmcs, phys_addr);