Lines Matching defs:vcpu

390 static void vmx_update_fb_clear_dis(struct kvm_vcpu *vcpu, struct vcpu_vmx *vmx)  in vmx_update_fb_clear_dis()
534 static int hv_enable_l2_tlb_flush(struct kvm_vcpu *vcpu) in hv_enable_l2_tlb_flush()
674 static inline bool cpu_need_virtualize_apic_accesses(struct kvm_vcpu *vcpu) in cpu_need_virtualize_apic_accesses()
883 void vmx_update_exception_bitmap(struct kvm_vcpu *vcpu) in vmx_update_exception_bitmap()
1195 static inline bool pt_output_base_valid(struct kvm_vcpu *vcpu, u64 base) in pt_output_base_valid()
1291 void vmx_prepare_switch_to_guest(struct kvm_vcpu *vcpu) in vmx_prepare_switch_to_guest()
1424 void vmx_vcpu_load_vmcs(struct kvm_vcpu *vcpu, int cpu, in vmx_vcpu_load_vmcs()
1495 static void vmx_vcpu_load(struct kvm_vcpu *vcpu, int cpu) in vmx_vcpu_load()
1506 static void vmx_vcpu_put(struct kvm_vcpu *vcpu) in vmx_vcpu_put()
1513 bool vmx_emulation_required(struct kvm_vcpu *vcpu) in vmx_emulation_required()
1518 unsigned long vmx_get_rflags(struct kvm_vcpu *vcpu) in vmx_get_rflags()
1536 void vmx_set_rflags(struct kvm_vcpu *vcpu, unsigned long rflags) in vmx_set_rflags()
1565 static bool vmx_get_if_flag(struct kvm_vcpu *vcpu) in vmx_get_if_flag()
1570 u32 vmx_get_interrupt_shadow(struct kvm_vcpu *vcpu) in vmx_get_interrupt_shadow()
1583 void vmx_set_interrupt_shadow(struct kvm_vcpu *vcpu, int mask) in vmx_set_interrupt_shadow()
1599 static int vmx_rtit_ctl_check(struct kvm_vcpu *vcpu, u64 data) in vmx_rtit_ctl_check()
1671 static bool vmx_can_emulate_instruction(struct kvm_vcpu *vcpu, int emul_type, in vmx_can_emulate_instruction()
1688 static int skip_emulated_instruction(struct kvm_vcpu *vcpu) in skip_emulated_instruction()
1756 static void vmx_update_emulated_instruction(struct kvm_vcpu *vcpu) in vmx_update_emulated_instruction()
1787 static int vmx_skip_emulated_instruction(struct kvm_vcpu *vcpu) in vmx_skip_emulated_instruction()
1793 static void vmx_clear_hlt(struct kvm_vcpu *vcpu) in vmx_clear_hlt()
1806 static void vmx_inject_exception(struct kvm_vcpu *vcpu) in vmx_inject_exception()
1906 u64 vmx_get_l2_tsc_offset(struct kvm_vcpu *vcpu) in vmx_get_l2_tsc_offset()
1916 u64 vmx_get_l2_tsc_multiplier(struct kvm_vcpu *vcpu) in vmx_get_l2_tsc_multiplier()
1927 static void vmx_write_tsc_offset(struct kvm_vcpu *vcpu) in vmx_write_tsc_offset()
1932 static void vmx_write_tsc_multiplier(struct kvm_vcpu *vcpu) in vmx_write_tsc_multiplier()
1992 static int vmx_get_msr(struct kvm_vcpu *vcpu, struct msr_data *msr_info) in vmx_get_msr()
2141 static u64 nested_vmx_truncate_sysenter_addr(struct kvm_vcpu *vcpu, in nested_vmx_truncate_sysenter_addr()
2151 static u64 vmx_get_supported_debugctl(struct kvm_vcpu *vcpu, bool host_initiated) in vmx_get_supported_debugctl()
2171 static int vmx_set_msr(struct kvm_vcpu *vcpu, struct msr_data *msr_info) in vmx_set_msr()
2474 static void vmx_cache_reg(struct kvm_vcpu *vcpu, enum kvm_reg reg) in vmx_cache_reg()
2985 static void fix_pmode_seg(struct kvm_vcpu *vcpu, int seg, in fix_pmode_seg()
3004 static void enter_pmode(struct kvm_vcpu *vcpu) in enter_pmode()
3074 static void enter_rmode(struct kvm_vcpu *vcpu) in enter_rmode()
3122 int vmx_set_efer(struct kvm_vcpu *vcpu, u64 efer) in vmx_set_efer()
3147 static void enter_lmode(struct kvm_vcpu *vcpu) in enter_lmode()
3164 static void exit_lmode(struct kvm_vcpu *vcpu) in exit_lmode()
3171 static void vmx_flush_tlb_all(struct kvm_vcpu *vcpu) in vmx_flush_tlb_all()
3194 static inline int vmx_get_current_vpid(struct kvm_vcpu *vcpu) in vmx_get_current_vpid()
3201 static void vmx_flush_tlb_current(struct kvm_vcpu *vcpu) in vmx_flush_tlb_current()
3217 static void vmx_flush_tlb_gva(struct kvm_vcpu *vcpu, gva_t addr) in vmx_flush_tlb_gva()
3226 static void vmx_flush_tlb_guest(struct kvm_vcpu *vcpu) in vmx_flush_tlb_guest()
3238 void vmx_ept_load_pdptrs(struct kvm_vcpu *vcpu) in vmx_ept_load_pdptrs()
3253 void ept_save_pdptrs(struct kvm_vcpu *vcpu) in ept_save_pdptrs()
3271 static bool vmx_is_valid_cr0(struct kvm_vcpu *vcpu, unsigned long cr0) in vmx_is_valid_cr0()
3282 void vmx_set_cr0(struct kvm_vcpu *vcpu, unsigned long cr0) in vmx_set_cr0()
3378 u64 construct_eptp(struct kvm_vcpu *vcpu, hpa_t root_hpa, int root_level) in construct_eptp()
3392 static void vmx_load_mmu_pgd(struct kvm_vcpu *vcpu, hpa_t root_hpa, in vmx_load_mmu_pgd()
3422 static bool vmx_is_valid_cr4(struct kvm_vcpu *vcpu, unsigned long cr4) in vmx_is_valid_cr4()
3438 void vmx_set_cr4(struct kvm_vcpu *vcpu, unsigned long cr4) in vmx_set_cr4()
3502 void vmx_get_segment(struct kvm_vcpu *vcpu, struct kvm_segment *var, int seg) in vmx_get_segment()
3538 static u64 vmx_get_segment_base(struct kvm_vcpu *vcpu, int seg) in vmx_get_segment_base()
3549 int vmx_get_cpl(struct kvm_vcpu *vcpu) in vmx_get_cpl()
3578 void __vmx_set_segment(struct kvm_vcpu *vcpu, struct kvm_segment *var, int seg) in __vmx_set_segment()
3615 static void vmx_set_segment(struct kvm_vcpu *vcpu, struct kvm_segment *var, int seg) in vmx_set_segment()
3622 static void vmx_get_cs_db_l_bits(struct kvm_vcpu *vcpu, int *db, int *l) in vmx_get_cs_db_l_bits()
3630 static void vmx_get_idt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_get_idt()
3636 static void vmx_set_idt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_set_idt()
3642 static void vmx_get_gdt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_get_gdt()
3648 static void vmx_set_gdt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_set_gdt()
3654 static bool rmode_segment_valid(struct kvm_vcpu *vcpu, int seg) in rmode_segment_valid()
3675 static bool code_segment_valid(struct kvm_vcpu *vcpu) in code_segment_valid()
3703 static bool stack_segment_valid(struct kvm_vcpu *vcpu) in stack_segment_valid()
3725 static bool data_segment_valid(struct kvm_vcpu *vcpu, int seg) in data_segment_valid()
3750 static bool tr_valid(struct kvm_vcpu *vcpu) in tr_valid()
3768 static bool ldtr_valid(struct kvm_vcpu *vcpu) in ldtr_valid()
3786 static bool cs_ss_rpl_check(struct kvm_vcpu *vcpu) in cs_ss_rpl_check()
3802 bool __vmx_guest_state_valid(struct kvm_vcpu *vcpu) in __vmx_guest_state_valid()
3968 void vmx_disable_intercept_for_msr(struct kvm_vcpu *vcpu, u32 msr, int type) in vmx_disable_intercept_for_msr()
4012 void vmx_enable_intercept_for_msr(struct kvm_vcpu *vcpu, u32 msr, int type) in vmx_enable_intercept_for_msr()
4044 static void vmx_update_msr_bitmap_x2apic(struct kvm_vcpu *vcpu) in vmx_update_msr_bitmap_x2apic()
4104 void pt_update_intercept_for_msr(struct kvm_vcpu *vcpu) in pt_update_intercept_for_msr()
4120 static bool vmx_guest_apic_has_interrupt(struct kvm_vcpu *vcpu) in vmx_guest_apic_has_interrupt()
4140 static void vmx_msr_filter_changed(struct kvm_vcpu *vcpu) in vmx_msr_filter_changed()
4168 static inline void kvm_vcpu_trigger_posted_interrupt(struct kvm_vcpu *vcpu, in kvm_vcpu_trigger_posted_interrupt()
4212 static int vmx_deliver_nested_posted_interrupt(struct kvm_vcpu *vcpu, in vmx_deliver_nested_posted_interrupt()
4251 static int vmx_deliver_posted_interrupt(struct kvm_vcpu *vcpu, int vector) in vmx_deliver_posted_interrupt()
4284 struct kvm_vcpu *vcpu = apic->vcpu; in vmx_deliver_interrupt() local
4371 struct kvm_vcpu *vcpu = &vmx->vcpu; in set_cr4_guest_host_mask() local
4444 static void vmx_refresh_apicv_exec_ctrl(struct kvm_vcpu *vcpu) in vmx_refresh_apicv_exec_ctrl()
4598 struct kvm_vcpu *vcpu = &vmx->vcpu; in vmx_secondary_exec_control() local
4833 static void __vmx_vcpu_reset(struct kvm_vcpu *vcpu) in __vmx_vcpu_reset()
4860 static void vmx_vcpu_reset(struct kvm_vcpu *vcpu, bool init_event) in vmx_vcpu_reset()
4919 static void vmx_enable_irq_window(struct kvm_vcpu *vcpu) in vmx_enable_irq_window()
4924 static void vmx_enable_nmi_window(struct kvm_vcpu *vcpu) in vmx_enable_nmi_window()
4935 static void vmx_inject_irq(struct kvm_vcpu *vcpu, bool reinjected) in vmx_inject_irq()
4963 static void vmx_inject_nmi(struct kvm_vcpu *vcpu) in vmx_inject_nmi()
4994 bool vmx_get_nmi_mask(struct kvm_vcpu *vcpu) in vmx_get_nmi_mask()
5008 void vmx_set_nmi_mask(struct kvm_vcpu *vcpu, bool masked) in vmx_set_nmi_mask()
5028 bool vmx_nmi_blocked(struct kvm_vcpu *vcpu) in vmx_nmi_blocked()
5041 static int vmx_nmi_allowed(struct kvm_vcpu *vcpu, bool for_injection) in vmx_nmi_allowed()
5053 bool __vmx_interrupt_blocked(struct kvm_vcpu *vcpu) in __vmx_interrupt_blocked()
5060 bool vmx_interrupt_blocked(struct kvm_vcpu *vcpu) in vmx_interrupt_blocked()
5068 static int vmx_interrupt_allowed(struct kvm_vcpu *vcpu, bool for_injection) in vmx_interrupt_allowed()
5109 static bool rmode_exception(struct kvm_vcpu *vcpu, int vec) in rmode_exception()
5138 static int handle_rmode_exception(struct kvm_vcpu *vcpu, in handle_rmode_exception()
5165 static int handle_machine_check(struct kvm_vcpu *vcpu) in handle_machine_check()
5182 bool vmx_guest_inject_ac(struct kvm_vcpu *vcpu) in vmx_guest_inject_ac()
5191 static int handle_exception_nmi(struct kvm_vcpu *vcpu) in handle_exception_nmi()
5355 static __always_inline int handle_external_interrupt(struct kvm_vcpu *vcpu) in handle_external_interrupt()
5361 static int handle_triple_fault(struct kvm_vcpu *vcpu) in handle_triple_fault()
5368 static int handle_io(struct kvm_vcpu *vcpu) in handle_io()
5390 vmx_patch_hypercall(struct kvm_vcpu *vcpu, unsigned char *hypercall) in vmx_patch_hypercall()
5401 static int handle_set_cr0(struct kvm_vcpu *vcpu, unsigned long val) in handle_set_cr0()
5427 static int handle_set_cr4(struct kvm_vcpu *vcpu, unsigned long val) in handle_set_cr4()
5444 static int handle_desc(struct kvm_vcpu *vcpu) in handle_desc()
5456 static int handle_cr(struct kvm_vcpu *vcpu) in handle_cr()
5536 static int handle_dr(struct kvm_vcpu *vcpu) in handle_dr()
5599 static void vmx_sync_dirty_debug_regs(struct kvm_vcpu *vcpu) in vmx_sync_dirty_debug_regs()
5618 static void vmx_set_dr7(struct kvm_vcpu *vcpu, unsigned long val) in vmx_set_dr7()
5623 static int handle_tpr_below_threshold(struct kvm_vcpu *vcpu) in handle_tpr_below_threshold()
5629 static int handle_interrupt_window(struct kvm_vcpu *vcpu) in handle_interrupt_window()
5639 static int handle_invlpg(struct kvm_vcpu *vcpu) in handle_invlpg()
5647 static int handle_apic_access(struct kvm_vcpu *vcpu) in handle_apic_access()
5669 static int handle_apic_eoi_induced(struct kvm_vcpu *vcpu) in handle_apic_eoi_induced()
5679 static int handle_apic_write(struct kvm_vcpu *vcpu) in handle_apic_write()
5696 static int handle_task_switch(struct kvm_vcpu *vcpu) in handle_task_switch()
5753 static int handle_ept_violation(struct kvm_vcpu *vcpu) in handle_ept_violation()
5807 static int handle_ept_misconfig(struct kvm_vcpu *vcpu) in handle_ept_misconfig()
5828 static int handle_nmi_window(struct kvm_vcpu *vcpu) in handle_nmi_window()
5840 static bool vmx_emulation_required_with_pending_exception(struct kvm_vcpu *vcpu) in vmx_emulation_required_with_pending_exception()
5848 static int handle_invalid_guest_state(struct kvm_vcpu *vcpu) in handle_invalid_guest_state()
5889 static int vmx_vcpu_pre_run(struct kvm_vcpu *vcpu) in vmx_vcpu_pre_run()
5899 static void grow_ple_window(struct kvm_vcpu *vcpu) in grow_ple_window()
5915 static void shrink_ple_window(struct kvm_vcpu *vcpu) in shrink_ple_window()
5935 static int handle_pause(struct kvm_vcpu *vcpu) in handle_pause()
5950 static int handle_monitor_trap(struct kvm_vcpu *vcpu) in handle_monitor_trap()
5955 static int handle_invpcid(struct kvm_vcpu *vcpu) in handle_invpcid()
5986 static int handle_pml_full(struct kvm_vcpu *vcpu) in handle_pml_full()
6011 static fastpath_t handle_fastpath_preemption_timer(struct kvm_vcpu *vcpu) in handle_fastpath_preemption_timer()
6024 static int handle_preemption_timer(struct kvm_vcpu *vcpu) in handle_preemption_timer()
6034 static int handle_vmx_instruction(struct kvm_vcpu *vcpu) in handle_vmx_instruction()
6041 static int handle_encls(struct kvm_vcpu *vcpu) in handle_encls()
6053 static int handle_bus_lock_vmexit(struct kvm_vcpu *vcpu) in handle_bus_lock_vmexit()
6064 static int handle_notify(struct kvm_vcpu *vcpu) in handle_notify()
6153 static void vmx_get_exit_info(struct kvm_vcpu *vcpu, u32 *reason, in vmx_get_exit_info()
6183 static void vmx_flush_pml_buffer(struct kvm_vcpu *vcpu) in vmx_flush_pml_buffer()
6240 void dump_vmcs(struct kvm_vcpu *vcpu) in dump_vmcs()
6419 static int __vmx_handle_exit(struct kvm_vcpu *vcpu, fastpath_t exit_fastpath) in __vmx_handle_exit()
6598 static int vmx_handle_exit(struct kvm_vcpu *vcpu, fastpath_t exit_fastpath) in vmx_handle_exit()
6626 static noinstr void vmx_l1d_flush(struct kvm_vcpu *vcpu) in vmx_l1d_flush()
6686 static void vmx_update_cr8_intercept(struct kvm_vcpu *vcpu, int tpr, int irr) in vmx_update_cr8_intercept()
6702 void vmx_set_virtual_apic_mode(struct kvm_vcpu *vcpu) in vmx_set_virtual_apic_mode()
6756 static void vmx_set_apic_access_page_addr(struct kvm_vcpu *vcpu) in vmx_set_apic_access_page_addr()
6860 static void vmx_hwapic_irr_update(struct kvm_vcpu *vcpu, int max_irr) in vmx_hwapic_irr_update()
6874 static int vmx_sync_pir_to_irr(struct kvm_vcpu *vcpu) in vmx_sync_pir_to_irr()
6920 static void vmx_load_eoi_exitmap(struct kvm_vcpu *vcpu, u64 *eoi_exit_bitmap) in vmx_load_eoi_exitmap()
6931 static void vmx_apicv_pre_state_restore(struct kvm_vcpu *vcpu) in vmx_apicv_pre_state_restore()
6942 static void handle_nm_fault_irqoff(struct kvm_vcpu *vcpu) in handle_nm_fault_irqoff()
6977 static void handle_external_interrupt_irqoff(struct kvm_vcpu *vcpu) in handle_external_interrupt_irqoff()
6994 static void vmx_handle_exit_irqoff(struct kvm_vcpu *vcpu) in vmx_handle_exit_irqoff()
7073 static void __vmx_complete_interrupts(struct kvm_vcpu *vcpu, in __vmx_complete_interrupts()
7134 static void vmx_cancel_injection(struct kvm_vcpu *vcpu) in vmx_cancel_injection()
7167 static void vmx_update_hv_timer(struct kvm_vcpu *vcpu) in vmx_update_hv_timer()
7226 static fastpath_t vmx_exit_handlers_fastpath(struct kvm_vcpu *vcpu) in vmx_exit_handlers_fastpath()
7238 static noinstr void vmx_vcpu_enter_exit(struct kvm_vcpu *vcpu, in vmx_vcpu_enter_exit()
7292 static fastpath_t vmx_vcpu_run(struct kvm_vcpu *vcpu) in vmx_vcpu_run()
7448 static void vmx_vcpu_free(struct kvm_vcpu *vcpu) in vmx_vcpu_free()
7459 static int vmx_vcpu_create(struct kvm_vcpu *vcpu) in vmx_vcpu_create()
7599 static u8 vmx_get_mt_mask(struct kvm_vcpu *vcpu, gfn_t gfn, bool is_mmio) in vmx_get_mt_mask()
7662 static void nested_vmx_cr_fixed1_bits_update(struct kvm_vcpu *vcpu) in nested_vmx_cr_fixed1_bits_update()
7702 static void update_intel_pt_cfg(struct kvm_vcpu *vcpu) in update_intel_pt_cfg()
7771 static void vmx_vcpu_after_set_cpuid(struct kvm_vcpu *vcpu) in vmx_vcpu_after_set_cpuid()
7944 static void vmx_request_immediate_exit(struct kvm_vcpu *vcpu) in vmx_request_immediate_exit()
7949 static int vmx_check_intercept_io(struct kvm_vcpu *vcpu, in vmx_check_intercept_io()
7983 static int vmx_check_intercept(struct kvm_vcpu *vcpu, in vmx_check_intercept()
8066 static int vmx_set_hv_timer(struct kvm_vcpu *vcpu, u64 guest_deadline_tsc, in vmx_set_hv_timer()
8106 static void vmx_cancel_hv_timer(struct kvm_vcpu *vcpu) in vmx_cancel_hv_timer()
8112 static void vmx_sched_in(struct kvm_vcpu *vcpu, int cpu) in vmx_sched_in()
8118 void vmx_update_cpu_dirty_logging(struct kvm_vcpu *vcpu) in vmx_update_cpu_dirty_logging()
8141 static void vmx_setup_mce(struct kvm_vcpu *vcpu) in vmx_setup_mce()
8152 static int vmx_smi_allowed(struct kvm_vcpu *vcpu, bool for_injection) in vmx_smi_allowed()
8160 static int vmx_enter_smm(struct kvm_vcpu *vcpu, union kvm_smram *smram) in vmx_enter_smm()
8181 static int vmx_leave_smm(struct kvm_vcpu *vcpu, const union kvm_smram *smram) in vmx_leave_smm()
8202 static void vmx_enable_smi_window(struct kvm_vcpu *vcpu) in vmx_enable_smi_window()
8208 static bool vmx_apic_init_signal_blocked(struct kvm_vcpu *vcpu) in vmx_apic_init_signal_blocked()
8213 static void vmx_migrate_timers(struct kvm_vcpu *vcpu) in vmx_migrate_timers()
8395 struct kvm_vcpu *vcpu = kvm_get_running_vcpu(); in vmx_handle_intel_pt_intr() local