19af5471bSJason Baron /* SPDX-License-Identifier: GPL-2.0 */ 29af5471bSJason Baron #if !defined(KVM_X86_OP) || !defined(KVM_X86_OP_NULL) 39af5471bSJason Baron BUILD_BUG_ON(1) 49af5471bSJason Baron #endif 59af5471bSJason Baron 69af5471bSJason Baron /* 79af5471bSJason Baron * KVM_X86_OP() and KVM_X86_OP_NULL() are used to help generate 89af5471bSJason Baron * "static_call()"s. They are also intended for use when defining 99af5471bSJason Baron * the vmx/svm kvm_x86_ops. KVM_X86_OP() can be used for those 109af5471bSJason Baron * functions that follow the [svm|vmx]_func_name convention. 119af5471bSJason Baron * KVM_X86_OP_NULL() can leave a NULL definition for the 129af5471bSJason Baron * case where there is no definition or a function name that 139af5471bSJason Baron * doesn't match the typical naming convention is supplied. 149af5471bSJason Baron */ 159af5471bSJason Baron KVM_X86_OP_NULL(hardware_enable) 169af5471bSJason Baron KVM_X86_OP_NULL(hardware_disable) 179af5471bSJason Baron KVM_X86_OP_NULL(hardware_unsetup) 189af5471bSJason Baron KVM_X86_OP_NULL(cpu_has_accelerated_tpr) 199af5471bSJason Baron KVM_X86_OP(has_emulated_msr) 209af5471bSJason Baron KVM_X86_OP(vcpu_after_set_cpuid) 219af5471bSJason Baron KVM_X86_OP(vm_init) 229af5471bSJason Baron KVM_X86_OP_NULL(vm_destroy) 239af5471bSJason Baron KVM_X86_OP(vcpu_create) 249af5471bSJason Baron KVM_X86_OP(vcpu_free) 259af5471bSJason Baron KVM_X86_OP(vcpu_reset) 269af5471bSJason Baron KVM_X86_OP(prepare_guest_switch) 279af5471bSJason Baron KVM_X86_OP(vcpu_load) 289af5471bSJason Baron KVM_X86_OP(vcpu_put) 299af5471bSJason Baron KVM_X86_OP(update_exception_bitmap) 309af5471bSJason Baron KVM_X86_OP(get_msr) 319af5471bSJason Baron KVM_X86_OP(set_msr) 329af5471bSJason Baron KVM_X86_OP(get_segment_base) 339af5471bSJason Baron KVM_X86_OP(get_segment) 349af5471bSJason Baron KVM_X86_OP(get_cpl) 359af5471bSJason Baron KVM_X86_OP(set_segment) 369af5471bSJason Baron KVM_X86_OP_NULL(get_cs_db_l_bits) 379af5471bSJason Baron KVM_X86_OP(set_cr0) 389af5471bSJason Baron KVM_X86_OP(is_valid_cr4) 399af5471bSJason Baron KVM_X86_OP(set_cr4) 409af5471bSJason Baron KVM_X86_OP(set_efer) 419af5471bSJason Baron KVM_X86_OP(get_idt) 429af5471bSJason Baron KVM_X86_OP(set_idt) 439af5471bSJason Baron KVM_X86_OP(get_gdt) 449af5471bSJason Baron KVM_X86_OP(set_gdt) 459af5471bSJason Baron KVM_X86_OP(sync_dirty_debug_regs) 469af5471bSJason Baron KVM_X86_OP(set_dr7) 479af5471bSJason Baron KVM_X86_OP(cache_reg) 489af5471bSJason Baron KVM_X86_OP(get_rflags) 499af5471bSJason Baron KVM_X86_OP(set_rflags) 509af5471bSJason Baron KVM_X86_OP(tlb_flush_all) 519af5471bSJason Baron KVM_X86_OP(tlb_flush_current) 529af5471bSJason Baron KVM_X86_OP_NULL(tlb_remote_flush) 539af5471bSJason Baron KVM_X86_OP_NULL(tlb_remote_flush_with_range) 549af5471bSJason Baron KVM_X86_OP(tlb_flush_gva) 559af5471bSJason Baron KVM_X86_OP(tlb_flush_guest) 569af5471bSJason Baron KVM_X86_OP(run) 579af5471bSJason Baron KVM_X86_OP_NULL(handle_exit) 589af5471bSJason Baron KVM_X86_OP_NULL(skip_emulated_instruction) 599af5471bSJason Baron KVM_X86_OP_NULL(update_emulated_instruction) 609af5471bSJason Baron KVM_X86_OP(set_interrupt_shadow) 619af5471bSJason Baron KVM_X86_OP(get_interrupt_shadow) 629af5471bSJason Baron KVM_X86_OP(patch_hypercall) 639af5471bSJason Baron KVM_X86_OP(set_irq) 649af5471bSJason Baron KVM_X86_OP(set_nmi) 659af5471bSJason Baron KVM_X86_OP(queue_exception) 669af5471bSJason Baron KVM_X86_OP(cancel_injection) 679af5471bSJason Baron KVM_X86_OP(interrupt_allowed) 689af5471bSJason Baron KVM_X86_OP(nmi_allowed) 699af5471bSJason Baron KVM_X86_OP(get_nmi_mask) 709af5471bSJason Baron KVM_X86_OP(set_nmi_mask) 719af5471bSJason Baron KVM_X86_OP(enable_nmi_window) 729af5471bSJason Baron KVM_X86_OP(enable_irq_window) 739af5471bSJason Baron KVM_X86_OP(update_cr8_intercept) 749af5471bSJason Baron KVM_X86_OP(check_apicv_inhibit_reasons) 759af5471bSJason Baron KVM_X86_OP_NULL(pre_update_apicv_exec_ctrl) 769af5471bSJason Baron KVM_X86_OP(refresh_apicv_exec_ctrl) 779af5471bSJason Baron KVM_X86_OP(hwapic_irr_update) 789af5471bSJason Baron KVM_X86_OP(hwapic_isr_update) 799af5471bSJason Baron KVM_X86_OP_NULL(guest_apic_has_interrupt) 809af5471bSJason Baron KVM_X86_OP(load_eoi_exitmap) 819af5471bSJason Baron KVM_X86_OP(set_virtual_apic_mode) 829af5471bSJason Baron KVM_X86_OP_NULL(set_apic_access_page_addr) 839af5471bSJason Baron KVM_X86_OP(deliver_posted_interrupt) 849af5471bSJason Baron KVM_X86_OP_NULL(sync_pir_to_irr) 859af5471bSJason Baron KVM_X86_OP(set_tss_addr) 869af5471bSJason Baron KVM_X86_OP(set_identity_map_addr) 879af5471bSJason Baron KVM_X86_OP(get_mt_mask) 889af5471bSJason Baron KVM_X86_OP(load_mmu_pgd) 899af5471bSJason Baron KVM_X86_OP_NULL(has_wbinvd_exit) 909af5471bSJason Baron KVM_X86_OP(write_l1_tsc_offset) 919af5471bSJason Baron KVM_X86_OP(get_exit_info) 929af5471bSJason Baron KVM_X86_OP(check_intercept) 939af5471bSJason Baron KVM_X86_OP(handle_exit_irqoff) 949af5471bSJason Baron KVM_X86_OP_NULL(request_immediate_exit) 959af5471bSJason Baron KVM_X86_OP(sched_in) 96*a85863c2SMakarand Sonare KVM_X86_OP_NULL(update_cpu_dirty_logging) 979af5471bSJason Baron KVM_X86_OP_NULL(pre_block) 989af5471bSJason Baron KVM_X86_OP_NULL(post_block) 999af5471bSJason Baron KVM_X86_OP_NULL(vcpu_blocking) 1009af5471bSJason Baron KVM_X86_OP_NULL(vcpu_unblocking) 1019af5471bSJason Baron KVM_X86_OP_NULL(update_pi_irte) 1029af5471bSJason Baron KVM_X86_OP_NULL(apicv_post_state_restore) 1039af5471bSJason Baron KVM_X86_OP_NULL(dy_apicv_has_pending_interrupt) 1049af5471bSJason Baron KVM_X86_OP_NULL(set_hv_timer) 1059af5471bSJason Baron KVM_X86_OP_NULL(cancel_hv_timer) 1069af5471bSJason Baron KVM_X86_OP(setup_mce) 1079af5471bSJason Baron KVM_X86_OP(smi_allowed) 1089af5471bSJason Baron KVM_X86_OP(pre_enter_smm) 1099af5471bSJason Baron KVM_X86_OP(pre_leave_smm) 1109af5471bSJason Baron KVM_X86_OP(enable_smi_window) 1119af5471bSJason Baron KVM_X86_OP_NULL(mem_enc_op) 1129af5471bSJason Baron KVM_X86_OP_NULL(mem_enc_reg_region) 1139af5471bSJason Baron KVM_X86_OP_NULL(mem_enc_unreg_region) 1149af5471bSJason Baron KVM_X86_OP(get_msr_feature) 1159af5471bSJason Baron KVM_X86_OP(can_emulate_instruction) 1169af5471bSJason Baron KVM_X86_OP(apic_init_signal_blocked) 1179af5471bSJason Baron KVM_X86_OP_NULL(enable_direct_tlbflush) 1189af5471bSJason Baron KVM_X86_OP_NULL(migrate_timers) 1199af5471bSJason Baron KVM_X86_OP(msr_filter_changed) 1209af5471bSJason Baron KVM_X86_OP_NULL(complete_emulated_msr) 1219af5471bSJason Baron 1229af5471bSJason Baron #undef KVM_X86_OP 1239af5471bSJason Baron #undef KVM_X86_OP_NULL 124