1 /* SPDX-License-Identifier: GPL-2.0 */
2 #if !defined(KVM_X86_OP) || !defined(KVM_X86_OP_OPTIONAL)
7 * KVM_X86_OP() and KVM_X86_OP_OPTIONAL() are used to help generate
8 * both DECLARE/DEFINE_STATIC_CALL() invocations and
9 * "static_call_update()" calls.
11 * KVM_X86_OP_OPTIONAL() can be used for those functions that can have
12 * a NULL definition. KVM_X86_OP_OPTIONAL_RET0() can be used likewise
13 * to make a definition optional, but in this case the default will
14 * be __static_call_return0.
16 KVM_X86_OP(check_processor_compatibility
)
17 KVM_X86_OP(enable_virtualization_cpu
)
18 KVM_X86_OP(disable_virtualization_cpu
)
19 KVM_X86_OP(hardware_unsetup
)
20 KVM_X86_OP(has_emulated_msr
)
21 KVM_X86_OP(vcpu_after_set_cpuid
)
23 KVM_X86_OP_OPTIONAL(vm_destroy
)
24 KVM_X86_OP_OPTIONAL_RET0(vcpu_precreate
)
25 KVM_X86_OP(vcpu_create
)
27 KVM_X86_OP(vcpu_reset
)
28 KVM_X86_OP(prepare_switch_to_guest
)
31 KVM_X86_OP(update_exception_bitmap
)
34 KVM_X86_OP(get_segment_base
)
35 KVM_X86_OP(get_segment
)
37 KVM_X86_OP(get_cpl_no_cache
)
38 KVM_X86_OP(set_segment
)
39 KVM_X86_OP(get_cs_db_l_bits
)
40 KVM_X86_OP(is_valid_cr0
)
42 KVM_X86_OP_OPTIONAL(post_set_cr3
)
43 KVM_X86_OP(is_valid_cr4
)
50 KVM_X86_OP(sync_dirty_debug_regs
)
53 KVM_X86_OP(get_rflags
)
54 KVM_X86_OP(set_rflags
)
55 KVM_X86_OP(get_if_flag
)
56 KVM_X86_OP(flush_tlb_all
)
57 KVM_X86_OP(flush_tlb_current
)
58 #if IS_ENABLED(CONFIG_HYPERV)
59 KVM_X86_OP_OPTIONAL(flush_remote_tlbs
)
60 KVM_X86_OP_OPTIONAL(flush_remote_tlbs_range
)
62 KVM_X86_OP(flush_tlb_gva
)
63 KVM_X86_OP(flush_tlb_guest
)
64 KVM_X86_OP(vcpu_pre_run
)
66 KVM_X86_OP(handle_exit
)
67 KVM_X86_OP(skip_emulated_instruction
)
68 KVM_X86_OP_OPTIONAL(update_emulated_instruction
)
69 KVM_X86_OP(set_interrupt_shadow
)
70 KVM_X86_OP(get_interrupt_shadow
)
71 KVM_X86_OP(patch_hypercall
)
72 KVM_X86_OP(inject_irq
)
73 KVM_X86_OP(inject_nmi
)
74 KVM_X86_OP_OPTIONAL_RET0(is_vnmi_pending
)
75 KVM_X86_OP_OPTIONAL_RET0(set_vnmi_pending
)
76 KVM_X86_OP(inject_exception
)
77 KVM_X86_OP(cancel_injection
)
78 KVM_X86_OP(interrupt_allowed
)
79 KVM_X86_OP(nmi_allowed
)
80 KVM_X86_OP(get_nmi_mask
)
81 KVM_X86_OP(set_nmi_mask
)
82 KVM_X86_OP(enable_nmi_window
)
83 KVM_X86_OP(enable_irq_window
)
84 KVM_X86_OP_OPTIONAL(update_cr8_intercept
)
85 KVM_X86_OP(refresh_apicv_exec_ctrl
)
86 KVM_X86_OP_OPTIONAL(hwapic_irr_update
)
87 KVM_X86_OP_OPTIONAL(hwapic_isr_update
)
88 KVM_X86_OP_OPTIONAL(load_eoi_exitmap
)
89 KVM_X86_OP_OPTIONAL(set_virtual_apic_mode
)
90 KVM_X86_OP_OPTIONAL(set_apic_access_page_addr
)
91 KVM_X86_OP(deliver_interrupt
)
92 KVM_X86_OP_OPTIONAL(sync_pir_to_irr
)
93 KVM_X86_OP_OPTIONAL_RET0(set_tss_addr
)
94 KVM_X86_OP_OPTIONAL_RET0(set_identity_map_addr
)
95 KVM_X86_OP_OPTIONAL_RET0(get_mt_mask
)
96 KVM_X86_OP(load_mmu_pgd
)
97 KVM_X86_OP(has_wbinvd_exit
)
98 KVM_X86_OP(get_l2_tsc_offset
)
99 KVM_X86_OP(get_l2_tsc_multiplier
)
100 KVM_X86_OP(write_tsc_offset
)
101 KVM_X86_OP(write_tsc_multiplier
)
102 KVM_X86_OP(get_exit_info
)
103 KVM_X86_OP(check_intercept
)
104 KVM_X86_OP(handle_exit_irqoff
)
105 KVM_X86_OP_OPTIONAL(update_cpu_dirty_logging
)
106 KVM_X86_OP_OPTIONAL(vcpu_blocking
)
107 KVM_X86_OP_OPTIONAL(vcpu_unblocking
)
108 KVM_X86_OP_OPTIONAL(pi_update_irte
)
109 KVM_X86_OP_OPTIONAL(pi_start_assignment
)
110 KVM_X86_OP_OPTIONAL(apicv_pre_state_restore
)
111 KVM_X86_OP_OPTIONAL(apicv_post_state_restore
)
112 KVM_X86_OP_OPTIONAL_RET0(dy_apicv_has_pending_interrupt
)
113 KVM_X86_OP_OPTIONAL(set_hv_timer
)
114 KVM_X86_OP_OPTIONAL(cancel_hv_timer
)
115 KVM_X86_OP(setup_mce
)
116 #ifdef CONFIG_KVM_SMM
117 KVM_X86_OP(smi_allowed
)
118 KVM_X86_OP(enter_smm
)
119 KVM_X86_OP(leave_smm
)
120 KVM_X86_OP(enable_smi_window
)
122 KVM_X86_OP_OPTIONAL(dev_get_attr
)
123 KVM_X86_OP_OPTIONAL(mem_enc_ioctl
)
124 KVM_X86_OP_OPTIONAL(mem_enc_register_region
)
125 KVM_X86_OP_OPTIONAL(mem_enc_unregister_region
)
126 KVM_X86_OP_OPTIONAL(vm_copy_enc_context_from
)
127 KVM_X86_OP_OPTIONAL(vm_move_enc_context_from
)
128 KVM_X86_OP_OPTIONAL(guest_memory_reclaimed
)
129 KVM_X86_OP(get_feature_msr
)
130 KVM_X86_OP(check_emulate_instruction
)
131 KVM_X86_OP(apic_init_signal_blocked
)
132 KVM_X86_OP_OPTIONAL(enable_l2_tlb_flush
)
133 KVM_X86_OP_OPTIONAL(migrate_timers
)
134 KVM_X86_OP(msr_filter_changed
)
135 KVM_X86_OP(complete_emulated_msr
)
136 KVM_X86_OP(vcpu_deliver_sipi_vector
)
137 KVM_X86_OP_OPTIONAL_RET0(vcpu_get_apicv_inhibit_reasons
);
138 KVM_X86_OP_OPTIONAL(get_untagged_addr
)
139 KVM_X86_OP_OPTIONAL(alloc_apic_backing_page
)
140 KVM_X86_OP_OPTIONAL_RET0(gmem_prepare
)
141 KVM_X86_OP_OPTIONAL_RET0(private_max_mapping_level
)
142 KVM_X86_OP_OPTIONAL(gmem_invalidate
)
145 #undef KVM_X86_OP_OPTIONAL
146 #undef KVM_X86_OP_OPTIONAL_RET0