Lines Matching defs:vcpu
409 static void vmx_update_fb_clear_dis(struct kvm_vcpu *vcpu, struct vcpu_vmx *vmx) in vmx_update_fb_clear_dis()
532 static int hv_enable_l2_tlb_flush(struct kvm_vcpu *vcpu) in hv_enable_l2_tlb_flush()
672 static inline bool cpu_need_virtualize_apic_accesses(struct kvm_vcpu *vcpu) in cpu_need_virtualize_apic_accesses()
847 void vmx_update_exception_bitmap(struct kvm_vcpu *vcpu) in vmx_update_exception_bitmap()
1159 static inline bool pt_output_base_valid(struct kvm_vcpu *vcpu, u64 base) in pt_output_base_valid()
1255 void vmx_prepare_switch_to_guest(struct kvm_vcpu *vcpu) in vmx_prepare_switch_to_guest()
1388 void vmx_vcpu_load_vmcs(struct kvm_vcpu *vcpu, int cpu, in vmx_vcpu_load_vmcs()
1459 static void vmx_vcpu_load(struct kvm_vcpu *vcpu, int cpu) in vmx_vcpu_load()
1470 static void vmx_vcpu_put(struct kvm_vcpu *vcpu) in vmx_vcpu_put()
1477 bool vmx_emulation_required(struct kvm_vcpu *vcpu) in vmx_emulation_required()
1482 unsigned long vmx_get_rflags(struct kvm_vcpu *vcpu) in vmx_get_rflags()
1500 void vmx_set_rflags(struct kvm_vcpu *vcpu, unsigned long rflags) in vmx_set_rflags()
1524 static bool vmx_get_if_flag(struct kvm_vcpu *vcpu) in vmx_get_if_flag()
1529 u32 vmx_get_interrupt_shadow(struct kvm_vcpu *vcpu) in vmx_get_interrupt_shadow()
1542 void vmx_set_interrupt_shadow(struct kvm_vcpu *vcpu, int mask) in vmx_set_interrupt_shadow()
1558 static int vmx_rtit_ctl_check(struct kvm_vcpu *vcpu, u64 data) in vmx_rtit_ctl_check()
1630 static bool vmx_can_emulate_instruction(struct kvm_vcpu *vcpu, int emul_type, in vmx_can_emulate_instruction()
1647 static int skip_emulated_instruction(struct kvm_vcpu *vcpu) in skip_emulated_instruction()
1715 static void vmx_update_emulated_instruction(struct kvm_vcpu *vcpu) in vmx_update_emulated_instruction()
1746 static int vmx_skip_emulated_instruction(struct kvm_vcpu *vcpu) in vmx_skip_emulated_instruction()
1752 static void vmx_clear_hlt(struct kvm_vcpu *vcpu) in vmx_clear_hlt()
1765 static void vmx_inject_exception(struct kvm_vcpu *vcpu) in vmx_inject_exception()
1865 u64 vmx_get_l2_tsc_offset(struct kvm_vcpu *vcpu) in vmx_get_l2_tsc_offset()
1875 u64 vmx_get_l2_tsc_multiplier(struct kvm_vcpu *vcpu) in vmx_get_l2_tsc_multiplier()
1886 static void vmx_write_tsc_offset(struct kvm_vcpu *vcpu, u64 offset) in vmx_write_tsc_offset()
1891 static void vmx_write_tsc_multiplier(struct kvm_vcpu *vcpu, u64 multiplier) in vmx_write_tsc_multiplier()
1902 bool nested_vmx_allowed(struct kvm_vcpu *vcpu) in nested_vmx_allowed()
1962 static int vmx_get_msr(struct kvm_vcpu *vcpu, struct msr_data *msr_info) in vmx_get_msr()
2111 static u64 nested_vmx_truncate_sysenter_addr(struct kvm_vcpu *vcpu, in nested_vmx_truncate_sysenter_addr()
2121 static u64 vmx_get_supported_debugctl(struct kvm_vcpu *vcpu, bool host_initiated) in vmx_get_supported_debugctl()
2141 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()
2975 static void fix_pmode_seg(struct kvm_vcpu *vcpu, int seg, in fix_pmode_seg()
2994 static void enter_pmode(struct kvm_vcpu *vcpu) in enter_pmode()
3064 static void enter_rmode(struct kvm_vcpu *vcpu) in enter_rmode()
3110 int vmx_set_efer(struct kvm_vcpu *vcpu, u64 efer) in vmx_set_efer()
3135 static void enter_lmode(struct kvm_vcpu *vcpu) in enter_lmode()
3152 static void exit_lmode(struct kvm_vcpu *vcpu) in exit_lmode()
3159 static void vmx_flush_tlb_all(struct kvm_vcpu *vcpu) in vmx_flush_tlb_all()
3182 static inline int vmx_get_current_vpid(struct kvm_vcpu *vcpu) in vmx_get_current_vpid()
3189 static void vmx_flush_tlb_current(struct kvm_vcpu *vcpu) in vmx_flush_tlb_current()
3205 static void vmx_flush_tlb_gva(struct kvm_vcpu *vcpu, gva_t addr) in vmx_flush_tlb_gva()
3214 static void vmx_flush_tlb_guest(struct kvm_vcpu *vcpu) in vmx_flush_tlb_guest()
3226 void vmx_ept_load_pdptrs(struct kvm_vcpu *vcpu) in vmx_ept_load_pdptrs()
3241 void ept_save_pdptrs(struct kvm_vcpu *vcpu) in ept_save_pdptrs()
3259 void vmx_set_cr0(struct kvm_vcpu *vcpu, unsigned long cr0) in vmx_set_cr0()
3355 u64 construct_eptp(struct kvm_vcpu *vcpu, hpa_t root_hpa, int root_level) in construct_eptp()
3369 static void vmx_load_mmu_pgd(struct kvm_vcpu *vcpu, hpa_t root_hpa, in vmx_load_mmu_pgd()
3399 static bool vmx_is_valid_cr4(struct kvm_vcpu *vcpu, unsigned long cr4) in vmx_is_valid_cr4()
3415 void vmx_set_cr4(struct kvm_vcpu *vcpu, unsigned long cr4) in vmx_set_cr4()
3479 void vmx_get_segment(struct kvm_vcpu *vcpu, struct kvm_segment *var, int seg) in vmx_get_segment()
3515 static u64 vmx_get_segment_base(struct kvm_vcpu *vcpu, int seg) in vmx_get_segment_base()
3526 int vmx_get_cpl(struct kvm_vcpu *vcpu) in vmx_get_cpl()
3555 void __vmx_set_segment(struct kvm_vcpu *vcpu, struct kvm_segment *var, int seg) in __vmx_set_segment()
3592 static void vmx_set_segment(struct kvm_vcpu *vcpu, struct kvm_segment *var, int seg) in vmx_set_segment()
3599 static void vmx_get_cs_db_l_bits(struct kvm_vcpu *vcpu, int *db, int *l) in vmx_get_cs_db_l_bits()
3607 static void vmx_get_idt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_get_idt()
3613 static void vmx_set_idt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_set_idt()
3619 static void vmx_get_gdt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_get_gdt()
3625 static void vmx_set_gdt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_set_gdt()
3631 static bool rmode_segment_valid(struct kvm_vcpu *vcpu, int seg) in rmode_segment_valid()
3652 static bool code_segment_valid(struct kvm_vcpu *vcpu) in code_segment_valid()
3680 static bool stack_segment_valid(struct kvm_vcpu *vcpu) in stack_segment_valid()
3702 static bool data_segment_valid(struct kvm_vcpu *vcpu, int seg) in data_segment_valid()
3727 static bool tr_valid(struct kvm_vcpu *vcpu) in tr_valid()
3745 static bool ldtr_valid(struct kvm_vcpu *vcpu) in ldtr_valid()
3763 static bool cs_ss_rpl_check(struct kvm_vcpu *vcpu) in cs_ss_rpl_check()
3779 bool __vmx_guest_state_valid(struct kvm_vcpu *vcpu) in __vmx_guest_state_valid()
3945 void vmx_disable_intercept_for_msr(struct kvm_vcpu *vcpu, u32 msr, int type) in vmx_disable_intercept_for_msr()
3989 void vmx_enable_intercept_for_msr(struct kvm_vcpu *vcpu, u32 msr, int type) in vmx_enable_intercept_for_msr()
4021 static void vmx_update_msr_bitmap_x2apic(struct kvm_vcpu *vcpu) in vmx_update_msr_bitmap_x2apic()
4081 void pt_update_intercept_for_msr(struct kvm_vcpu *vcpu) in pt_update_intercept_for_msr()
4097 static bool vmx_guest_apic_has_interrupt(struct kvm_vcpu *vcpu) in vmx_guest_apic_has_interrupt()
4117 static void vmx_msr_filter_changed(struct kvm_vcpu *vcpu) in vmx_msr_filter_changed()
4145 static inline void kvm_vcpu_trigger_posted_interrupt(struct kvm_vcpu *vcpu, in kvm_vcpu_trigger_posted_interrupt()
4189 static int vmx_deliver_nested_posted_interrupt(struct kvm_vcpu *vcpu, in vmx_deliver_nested_posted_interrupt()
4228 static int vmx_deliver_posted_interrupt(struct kvm_vcpu *vcpu, int vector) in vmx_deliver_posted_interrupt()
4261 struct kvm_vcpu *vcpu = apic->vcpu; in vmx_deliver_interrupt() local
4348 struct kvm_vcpu *vcpu = &vmx->vcpu; in set_cr4_guest_host_mask() local
4421 static void vmx_refresh_apicv_exec_ctrl(struct kvm_vcpu *vcpu) in vmx_refresh_apicv_exec_ctrl()
4572 struct kvm_vcpu *vcpu = &vmx->vcpu; in vmx_secondary_exec_control() local
4817 static void __vmx_vcpu_reset(struct kvm_vcpu *vcpu) in __vmx_vcpu_reset()
4844 static void vmx_vcpu_reset(struct kvm_vcpu *vcpu, bool init_event) in vmx_vcpu_reset()
4903 static void vmx_enable_irq_window(struct kvm_vcpu *vcpu) in vmx_enable_irq_window()
4908 static void vmx_enable_nmi_window(struct kvm_vcpu *vcpu) in vmx_enable_nmi_window()
4919 static void vmx_inject_irq(struct kvm_vcpu *vcpu, bool reinjected) in vmx_inject_irq()
4947 static void vmx_inject_nmi(struct kvm_vcpu *vcpu) in vmx_inject_nmi()
4978 bool vmx_get_nmi_mask(struct kvm_vcpu *vcpu) in vmx_get_nmi_mask()
4992 void vmx_set_nmi_mask(struct kvm_vcpu *vcpu, bool masked) in vmx_set_nmi_mask()
5012 bool vmx_nmi_blocked(struct kvm_vcpu *vcpu) in vmx_nmi_blocked()
5025 static int vmx_nmi_allowed(struct kvm_vcpu *vcpu, bool for_injection) in vmx_nmi_allowed()
5037 bool vmx_interrupt_blocked(struct kvm_vcpu *vcpu) in vmx_interrupt_blocked()
5047 static int vmx_interrupt_allowed(struct kvm_vcpu *vcpu, bool for_injection) in vmx_interrupt_allowed()
5088 static bool rmode_exception(struct kvm_vcpu *vcpu, int vec) in rmode_exception()
5117 static int handle_rmode_exception(struct kvm_vcpu *vcpu, in handle_rmode_exception()
5144 static int handle_machine_check(struct kvm_vcpu *vcpu) in handle_machine_check()
5161 bool vmx_guest_inject_ac(struct kvm_vcpu *vcpu) in vmx_guest_inject_ac()
5170 static int handle_exception_nmi(struct kvm_vcpu *vcpu) in handle_exception_nmi()
5334 static __always_inline int handle_external_interrupt(struct kvm_vcpu *vcpu) in handle_external_interrupt()
5340 static int handle_triple_fault(struct kvm_vcpu *vcpu) in handle_triple_fault()
5347 static int handle_io(struct kvm_vcpu *vcpu) in handle_io()
5369 vmx_patch_hypercall(struct kvm_vcpu *vcpu, unsigned char *hypercall) in vmx_patch_hypercall()
5380 static int handle_set_cr0(struct kvm_vcpu *vcpu, unsigned long val) in handle_set_cr0()
5413 static int handle_set_cr4(struct kvm_vcpu *vcpu, unsigned long val) in handle_set_cr4()
5430 static int handle_desc(struct kvm_vcpu *vcpu) in handle_desc()
5436 static int handle_cr(struct kvm_vcpu *vcpu) in handle_cr()
5516 static int handle_dr(struct kvm_vcpu *vcpu) in handle_dr()
5579 static void vmx_sync_dirty_debug_regs(struct kvm_vcpu *vcpu) in vmx_sync_dirty_debug_regs()
5598 static void vmx_set_dr7(struct kvm_vcpu *vcpu, unsigned long val) in vmx_set_dr7()
5603 static int handle_tpr_below_threshold(struct kvm_vcpu *vcpu) in handle_tpr_below_threshold()
5609 static int handle_interrupt_window(struct kvm_vcpu *vcpu) in handle_interrupt_window()
5619 static int handle_invlpg(struct kvm_vcpu *vcpu) in handle_invlpg()
5627 static int handle_apic_access(struct kvm_vcpu *vcpu) in handle_apic_access()
5649 static int handle_apic_eoi_induced(struct kvm_vcpu *vcpu) in handle_apic_eoi_induced()
5659 static int handle_apic_write(struct kvm_vcpu *vcpu) in handle_apic_write()
5676 static int handle_task_switch(struct kvm_vcpu *vcpu) in handle_task_switch()
5733 static int handle_ept_violation(struct kvm_vcpu *vcpu) in handle_ept_violation()
5787 static int handle_ept_misconfig(struct kvm_vcpu *vcpu) in handle_ept_misconfig()
5808 static int handle_nmi_window(struct kvm_vcpu *vcpu) in handle_nmi_window()
5820 static bool vmx_emulation_required_with_pending_exception(struct kvm_vcpu *vcpu) in vmx_emulation_required_with_pending_exception()
5828 static int handle_invalid_guest_state(struct kvm_vcpu *vcpu) in handle_invalid_guest_state()
5869 static int vmx_vcpu_pre_run(struct kvm_vcpu *vcpu) in vmx_vcpu_pre_run()
5879 static void grow_ple_window(struct kvm_vcpu *vcpu) in grow_ple_window()
5895 static void shrink_ple_window(struct kvm_vcpu *vcpu) in shrink_ple_window()
5915 static int handle_pause(struct kvm_vcpu *vcpu) in handle_pause()
5930 static int handle_monitor_trap(struct kvm_vcpu *vcpu) in handle_monitor_trap()
5935 static int handle_invpcid(struct kvm_vcpu *vcpu) in handle_invpcid()
5966 static int handle_pml_full(struct kvm_vcpu *vcpu) in handle_pml_full()
5991 static fastpath_t handle_fastpath_preemption_timer(struct kvm_vcpu *vcpu) in handle_fastpath_preemption_timer()
6004 static int handle_preemption_timer(struct kvm_vcpu *vcpu) in handle_preemption_timer()
6014 static int handle_vmx_instruction(struct kvm_vcpu *vcpu) in handle_vmx_instruction()
6021 static int handle_encls(struct kvm_vcpu *vcpu) in handle_encls()
6033 static int handle_bus_lock_vmexit(struct kvm_vcpu *vcpu) in handle_bus_lock_vmexit()
6044 static int handle_notify(struct kvm_vcpu *vcpu) in handle_notify()
6133 static void vmx_get_exit_info(struct kvm_vcpu *vcpu, u32 *reason, in vmx_get_exit_info()
6163 static void vmx_flush_pml_buffer(struct kvm_vcpu *vcpu) in vmx_flush_pml_buffer()
6220 void dump_vmcs(struct kvm_vcpu *vcpu) in dump_vmcs()
6399 static int __vmx_handle_exit(struct kvm_vcpu *vcpu, fastpath_t exit_fastpath) in __vmx_handle_exit()
6578 static int vmx_handle_exit(struct kvm_vcpu *vcpu, fastpath_t exit_fastpath) in vmx_handle_exit()
6606 static noinstr void vmx_l1d_flush(struct kvm_vcpu *vcpu) in vmx_l1d_flush()
6666 static void vmx_update_cr8_intercept(struct kvm_vcpu *vcpu, int tpr, int irr) in vmx_update_cr8_intercept()
6682 void vmx_set_virtual_apic_mode(struct kvm_vcpu *vcpu) in vmx_set_virtual_apic_mode()
6736 static void vmx_set_apic_access_page_addr(struct kvm_vcpu *vcpu) in vmx_set_apic_access_page_addr()
6798 static void vmx_hwapic_irr_update(struct kvm_vcpu *vcpu, int max_irr) in vmx_hwapic_irr_update()
6812 static int vmx_sync_pir_to_irr(struct kvm_vcpu *vcpu) in vmx_sync_pir_to_irr()
6858 static void vmx_load_eoi_exitmap(struct kvm_vcpu *vcpu, u64 *eoi_exit_bitmap) in vmx_load_eoi_exitmap()
6869 static void vmx_apicv_post_state_restore(struct kvm_vcpu *vcpu) in vmx_apicv_post_state_restore()
6880 static void handle_nm_fault_irqoff(struct kvm_vcpu *vcpu) in handle_nm_fault_irqoff()
6915 static void handle_external_interrupt_irqoff(struct kvm_vcpu *vcpu) in handle_external_interrupt_irqoff()
6932 static void vmx_handle_exit_irqoff(struct kvm_vcpu *vcpu) in vmx_handle_exit_irqoff()
7011 static void __vmx_complete_interrupts(struct kvm_vcpu *vcpu, in __vmx_complete_interrupts()
7072 static void vmx_cancel_injection(struct kvm_vcpu *vcpu) in vmx_cancel_injection()
7105 static void vmx_update_hv_timer(struct kvm_vcpu *vcpu) in vmx_update_hv_timer()
7164 static fastpath_t vmx_exit_handlers_fastpath(struct kvm_vcpu *vcpu) in vmx_exit_handlers_fastpath()
7176 static noinstr void vmx_vcpu_enter_exit(struct kvm_vcpu *vcpu, in vmx_vcpu_enter_exit()
7219 static fastpath_t vmx_vcpu_run(struct kvm_vcpu *vcpu) in vmx_vcpu_run()
7382 static void vmx_vcpu_free(struct kvm_vcpu *vcpu) in vmx_vcpu_free()
7393 static int vmx_vcpu_create(struct kvm_vcpu *vcpu) in vmx_vcpu_create()
7533 static u8 vmx_get_mt_mask(struct kvm_vcpu *vcpu, gfn_t gfn, bool is_mmio) in vmx_get_mt_mask()
7596 static void nested_vmx_cr_fixed1_bits_update(struct kvm_vcpu *vcpu) in nested_vmx_cr_fixed1_bits_update()
7636 static void update_intel_pt_cfg(struct kvm_vcpu *vcpu) in update_intel_pt_cfg()
7705 static void vmx_vcpu_after_set_cpuid(struct kvm_vcpu *vcpu) in vmx_vcpu_after_set_cpuid()
7841 static void vmx_request_immediate_exit(struct kvm_vcpu *vcpu) in vmx_request_immediate_exit()
7846 static int vmx_check_intercept_io(struct kvm_vcpu *vcpu, in vmx_check_intercept_io()
7880 static int vmx_check_intercept(struct kvm_vcpu *vcpu, in vmx_check_intercept()
7948 static int vmx_set_hv_timer(struct kvm_vcpu *vcpu, u64 guest_deadline_tsc, in vmx_set_hv_timer()
7988 static void vmx_cancel_hv_timer(struct kvm_vcpu *vcpu) in vmx_cancel_hv_timer()
7994 static void vmx_sched_in(struct kvm_vcpu *vcpu, int cpu) in vmx_sched_in()
8000 void vmx_update_cpu_dirty_logging(struct kvm_vcpu *vcpu) in vmx_update_cpu_dirty_logging()
8023 static void vmx_setup_mce(struct kvm_vcpu *vcpu) in vmx_setup_mce()
8034 static int vmx_smi_allowed(struct kvm_vcpu *vcpu, bool for_injection) in vmx_smi_allowed()
8042 static int vmx_enter_smm(struct kvm_vcpu *vcpu, union kvm_smram *smram) in vmx_enter_smm()
8063 static int vmx_leave_smm(struct kvm_vcpu *vcpu, const union kvm_smram *smram) in vmx_leave_smm()
8084 static void vmx_enable_smi_window(struct kvm_vcpu *vcpu) in vmx_enable_smi_window()
8090 static bool vmx_apic_init_signal_blocked(struct kvm_vcpu *vcpu) in vmx_apic_init_signal_blocked()
8095 static void vmx_migrate_timers(struct kvm_vcpu *vcpu) in vmx_migrate_timers()
8276 struct kvm_vcpu *vcpu = kvm_get_running_vcpu(); in vmx_handle_intel_pt_intr() local