Lines Matching defs:vcpu

388 static void vmx_update_fb_clear_dis(struct kvm_vcpu *vcpu, struct vcpu_vmx *vmx)  in vmx_update_fb_clear_dis()
523 static int hv_enable_l2_tlb_flush(struct kvm_vcpu *vcpu) in hv_enable_l2_tlb_flush()
663 static inline bool cpu_need_virtualize_apic_accesses(struct kvm_vcpu *vcpu) in cpu_need_virtualize_apic_accesses()
872 void vmx_update_exception_bitmap(struct kvm_vcpu *vcpu) in vmx_update_exception_bitmap()
1184 static inline bool pt_output_base_valid(struct kvm_vcpu *vcpu, u64 base) in pt_output_base_valid()
1280 void vmx_prepare_switch_to_guest(struct kvm_vcpu *vcpu) in vmx_prepare_switch_to_guest()
1413 void vmx_vcpu_load_vmcs(struct kvm_vcpu *vcpu, int cpu, in vmx_vcpu_load_vmcs()
1484 static void vmx_vcpu_load(struct kvm_vcpu *vcpu, int cpu) in vmx_vcpu_load()
1495 static void vmx_vcpu_put(struct kvm_vcpu *vcpu) in vmx_vcpu_put()
1502 bool vmx_emulation_required(struct kvm_vcpu *vcpu) in vmx_emulation_required()
1507 unsigned long vmx_get_rflags(struct kvm_vcpu *vcpu) in vmx_get_rflags()
1525 void vmx_set_rflags(struct kvm_vcpu *vcpu, unsigned long rflags) in vmx_set_rflags()
1554 static bool vmx_get_if_flag(struct kvm_vcpu *vcpu) in vmx_get_if_flag()
1559 u32 vmx_get_interrupt_shadow(struct kvm_vcpu *vcpu) in vmx_get_interrupt_shadow()
1572 void vmx_set_interrupt_shadow(struct kvm_vcpu *vcpu, int mask) in vmx_set_interrupt_shadow()
1588 static int vmx_rtit_ctl_check(struct kvm_vcpu *vcpu, u64 data) in vmx_rtit_ctl_check()
1660 static bool vmx_can_emulate_instruction(struct kvm_vcpu *vcpu, int emul_type, in vmx_can_emulate_instruction()
1677 static int skip_emulated_instruction(struct kvm_vcpu *vcpu) in skip_emulated_instruction()
1745 static void vmx_update_emulated_instruction(struct kvm_vcpu *vcpu) in vmx_update_emulated_instruction()
1776 static int vmx_skip_emulated_instruction(struct kvm_vcpu *vcpu) in vmx_skip_emulated_instruction()
1782 static void vmx_clear_hlt(struct kvm_vcpu *vcpu) in vmx_clear_hlt()
1795 static void vmx_inject_exception(struct kvm_vcpu *vcpu) in vmx_inject_exception()
1895 u64 vmx_get_l2_tsc_offset(struct kvm_vcpu *vcpu) in vmx_get_l2_tsc_offset()
1905 u64 vmx_get_l2_tsc_multiplier(struct kvm_vcpu *vcpu) in vmx_get_l2_tsc_multiplier()
1916 static void vmx_write_tsc_offset(struct kvm_vcpu *vcpu) in vmx_write_tsc_offset()
1921 static void vmx_write_tsc_multiplier(struct kvm_vcpu *vcpu) in vmx_write_tsc_multiplier()
1981 static int vmx_get_msr(struct kvm_vcpu *vcpu, struct msr_data *msr_info) in vmx_get_msr()
2130 static u64 nested_vmx_truncate_sysenter_addr(struct kvm_vcpu *vcpu, in nested_vmx_truncate_sysenter_addr()
2140 static u64 vmx_get_supported_debugctl(struct kvm_vcpu *vcpu, bool host_initiated) in vmx_get_supported_debugctl()
2160 static int vmx_set_msr(struct kvm_vcpu *vcpu, struct msr_data *msr_info) in vmx_set_msr()
2463 static void vmx_cache_reg(struct kvm_vcpu *vcpu, enum kvm_reg reg) in vmx_cache_reg()
2974 static void fix_pmode_seg(struct kvm_vcpu *vcpu, int seg, in fix_pmode_seg()
2993 static void enter_pmode(struct kvm_vcpu *vcpu) in enter_pmode()
3063 static void enter_rmode(struct kvm_vcpu *vcpu) in enter_rmode()
3111 int vmx_set_efer(struct kvm_vcpu *vcpu, u64 efer) in vmx_set_efer()
3136 static void enter_lmode(struct kvm_vcpu *vcpu) in enter_lmode()
3153 static void exit_lmode(struct kvm_vcpu *vcpu) in exit_lmode()
3160 static void vmx_flush_tlb_all(struct kvm_vcpu *vcpu) in vmx_flush_tlb_all()
3183 static inline int vmx_get_current_vpid(struct kvm_vcpu *vcpu) in vmx_get_current_vpid()
3190 static void vmx_flush_tlb_current(struct kvm_vcpu *vcpu) in vmx_flush_tlb_current()
3206 static void vmx_flush_tlb_gva(struct kvm_vcpu *vcpu, gva_t addr) in vmx_flush_tlb_gva()
3215 static void vmx_flush_tlb_guest(struct kvm_vcpu *vcpu) in vmx_flush_tlb_guest()
3227 void vmx_ept_load_pdptrs(struct kvm_vcpu *vcpu) in vmx_ept_load_pdptrs()
3242 void ept_save_pdptrs(struct kvm_vcpu *vcpu) in ept_save_pdptrs()
3260 static bool vmx_is_valid_cr0(struct kvm_vcpu *vcpu, unsigned long cr0) in vmx_is_valid_cr0()
3271 void vmx_set_cr0(struct kvm_vcpu *vcpu, unsigned long cr0) in vmx_set_cr0()
3367 u64 construct_eptp(struct kvm_vcpu *vcpu, hpa_t root_hpa, int root_level) in construct_eptp()
3381 static void vmx_load_mmu_pgd(struct kvm_vcpu *vcpu, hpa_t root_hpa, in vmx_load_mmu_pgd()
3411 static bool vmx_is_valid_cr4(struct kvm_vcpu *vcpu, unsigned long cr4) in vmx_is_valid_cr4()
3427 void vmx_set_cr4(struct kvm_vcpu *vcpu, unsigned long cr4) in vmx_set_cr4()
3491 void vmx_get_segment(struct kvm_vcpu *vcpu, struct kvm_segment *var, int seg) in vmx_get_segment()
3527 static u64 vmx_get_segment_base(struct kvm_vcpu *vcpu, int seg) in vmx_get_segment_base()
3538 int vmx_get_cpl(struct kvm_vcpu *vcpu) in vmx_get_cpl()
3567 void __vmx_set_segment(struct kvm_vcpu *vcpu, struct kvm_segment *var, int seg) in __vmx_set_segment()
3604 static void vmx_set_segment(struct kvm_vcpu *vcpu, struct kvm_segment *var, int seg) in vmx_set_segment()
3611 static void vmx_get_cs_db_l_bits(struct kvm_vcpu *vcpu, int *db, int *l) in vmx_get_cs_db_l_bits()
3619 static void vmx_get_idt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_get_idt()
3625 static void vmx_set_idt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_set_idt()
3631 static void vmx_get_gdt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_get_gdt()
3637 static void vmx_set_gdt(struct kvm_vcpu *vcpu, struct desc_ptr *dt) in vmx_set_gdt()
3643 static bool rmode_segment_valid(struct kvm_vcpu *vcpu, int seg) in rmode_segment_valid()
3664 static bool code_segment_valid(struct kvm_vcpu *vcpu) in code_segment_valid()
3692 static bool stack_segment_valid(struct kvm_vcpu *vcpu) in stack_segment_valid()
3714 static bool data_segment_valid(struct kvm_vcpu *vcpu, int seg) in data_segment_valid()
3739 static bool tr_valid(struct kvm_vcpu *vcpu) in tr_valid()
3757 static bool ldtr_valid(struct kvm_vcpu *vcpu) in ldtr_valid()
3775 static bool cs_ss_rpl_check(struct kvm_vcpu *vcpu) in cs_ss_rpl_check()
3791 bool __vmx_guest_state_valid(struct kvm_vcpu *vcpu) in __vmx_guest_state_valid()
3957 void vmx_disable_intercept_for_msr(struct kvm_vcpu *vcpu, u32 msr, int type) in vmx_disable_intercept_for_msr()
4001 void vmx_enable_intercept_for_msr(struct kvm_vcpu *vcpu, u32 msr, int type) in vmx_enable_intercept_for_msr()
4033 static void vmx_update_msr_bitmap_x2apic(struct kvm_vcpu *vcpu) in vmx_update_msr_bitmap_x2apic()
4093 void pt_update_intercept_for_msr(struct kvm_vcpu *vcpu) in pt_update_intercept_for_msr()
4109 static bool vmx_guest_apic_has_interrupt(struct kvm_vcpu *vcpu) in vmx_guest_apic_has_interrupt()
4129 static void vmx_msr_filter_changed(struct kvm_vcpu *vcpu) in vmx_msr_filter_changed()
4157 static inline void kvm_vcpu_trigger_posted_interrupt(struct kvm_vcpu *vcpu, in kvm_vcpu_trigger_posted_interrupt()
4201 static int vmx_deliver_nested_posted_interrupt(struct kvm_vcpu *vcpu, in vmx_deliver_nested_posted_interrupt()
4240 static int vmx_deliver_posted_interrupt(struct kvm_vcpu *vcpu, int vector) in vmx_deliver_posted_interrupt()
4273 struct kvm_vcpu *vcpu = apic->vcpu; in vmx_deliver_interrupt() local
4360 struct kvm_vcpu *vcpu = &vmx->vcpu; in set_cr4_guest_host_mask() local
4433 static void vmx_refresh_apicv_exec_ctrl(struct kvm_vcpu *vcpu) in vmx_refresh_apicv_exec_ctrl()
4587 struct kvm_vcpu *vcpu = &vmx->vcpu; in vmx_secondary_exec_control() local
4822 static void __vmx_vcpu_reset(struct kvm_vcpu *vcpu) in __vmx_vcpu_reset()
4849 static void vmx_vcpu_reset(struct kvm_vcpu *vcpu, bool init_event) in vmx_vcpu_reset()
4908 static void vmx_enable_irq_window(struct kvm_vcpu *vcpu) in vmx_enable_irq_window()
4913 static void vmx_enable_nmi_window(struct kvm_vcpu *vcpu) in vmx_enable_nmi_window()
4924 static void vmx_inject_irq(struct kvm_vcpu *vcpu, bool reinjected) in vmx_inject_irq()
4952 static void vmx_inject_nmi(struct kvm_vcpu *vcpu) in vmx_inject_nmi()
4983 bool vmx_get_nmi_mask(struct kvm_vcpu *vcpu) in vmx_get_nmi_mask()
4997 void vmx_set_nmi_mask(struct kvm_vcpu *vcpu, bool masked) in vmx_set_nmi_mask()
5017 bool vmx_nmi_blocked(struct kvm_vcpu *vcpu) in vmx_nmi_blocked()
5030 static int vmx_nmi_allowed(struct kvm_vcpu *vcpu, bool for_injection) in vmx_nmi_allowed()
5042 bool vmx_interrupt_blocked(struct kvm_vcpu *vcpu) in vmx_interrupt_blocked()
5052 static int vmx_interrupt_allowed(struct kvm_vcpu *vcpu, bool for_injection) in vmx_interrupt_allowed()
5093 static bool rmode_exception(struct kvm_vcpu *vcpu, int vec) in rmode_exception()
5122 static int handle_rmode_exception(struct kvm_vcpu *vcpu, in handle_rmode_exception()
5149 static int handle_machine_check(struct kvm_vcpu *vcpu) in handle_machine_check()
5166 bool vmx_guest_inject_ac(struct kvm_vcpu *vcpu) in vmx_guest_inject_ac()
5175 static int handle_exception_nmi(struct kvm_vcpu *vcpu) in handle_exception_nmi()
5339 static __always_inline int handle_external_interrupt(struct kvm_vcpu *vcpu) in handle_external_interrupt()
5345 static int handle_triple_fault(struct kvm_vcpu *vcpu) in handle_triple_fault()
5352 static int handle_io(struct kvm_vcpu *vcpu) in handle_io()
5374 vmx_patch_hypercall(struct kvm_vcpu *vcpu, unsigned char *hypercall) in vmx_patch_hypercall()
5385 static int handle_set_cr0(struct kvm_vcpu *vcpu, unsigned long val) in handle_set_cr0()
5411 static int handle_set_cr4(struct kvm_vcpu *vcpu, unsigned long val) in handle_set_cr4()
5428 static int handle_desc(struct kvm_vcpu *vcpu) in handle_desc()
5440 static int handle_cr(struct kvm_vcpu *vcpu) in handle_cr()
5520 static int handle_dr(struct kvm_vcpu *vcpu) in handle_dr()
5583 static void vmx_sync_dirty_debug_regs(struct kvm_vcpu *vcpu) in vmx_sync_dirty_debug_regs()
5602 static void vmx_set_dr7(struct kvm_vcpu *vcpu, unsigned long val) in vmx_set_dr7()
5607 static int handle_tpr_below_threshold(struct kvm_vcpu *vcpu) in handle_tpr_below_threshold()
5613 static int handle_interrupt_window(struct kvm_vcpu *vcpu) in handle_interrupt_window()
5623 static int handle_invlpg(struct kvm_vcpu *vcpu) in handle_invlpg()
5631 static int handle_apic_access(struct kvm_vcpu *vcpu) in handle_apic_access()
5653 static int handle_apic_eoi_induced(struct kvm_vcpu *vcpu) in handle_apic_eoi_induced()
5663 static int handle_apic_write(struct kvm_vcpu *vcpu) in handle_apic_write()
5680 static int handle_task_switch(struct kvm_vcpu *vcpu) in handle_task_switch()
5737 static int handle_ept_violation(struct kvm_vcpu *vcpu) in handle_ept_violation()
5791 static int handle_ept_misconfig(struct kvm_vcpu *vcpu) in handle_ept_misconfig()
5812 static int handle_nmi_window(struct kvm_vcpu *vcpu) in handle_nmi_window()
5824 static bool vmx_emulation_required_with_pending_exception(struct kvm_vcpu *vcpu) in vmx_emulation_required_with_pending_exception()
5832 static int handle_invalid_guest_state(struct kvm_vcpu *vcpu) in handle_invalid_guest_state()
5873 static int vmx_vcpu_pre_run(struct kvm_vcpu *vcpu) in vmx_vcpu_pre_run()
5883 static void grow_ple_window(struct kvm_vcpu *vcpu) in grow_ple_window()
5899 static void shrink_ple_window(struct kvm_vcpu *vcpu) in shrink_ple_window()
5919 static int handle_pause(struct kvm_vcpu *vcpu) in handle_pause()
5934 static int handle_monitor_trap(struct kvm_vcpu *vcpu) in handle_monitor_trap()
5939 static int handle_invpcid(struct kvm_vcpu *vcpu) in handle_invpcid()
5970 static int handle_pml_full(struct kvm_vcpu *vcpu) in handle_pml_full()
5995 static fastpath_t handle_fastpath_preemption_timer(struct kvm_vcpu *vcpu) in handle_fastpath_preemption_timer()
6008 static int handle_preemption_timer(struct kvm_vcpu *vcpu) in handle_preemption_timer()
6018 static int handle_vmx_instruction(struct kvm_vcpu *vcpu) in handle_vmx_instruction()
6025 static int handle_encls(struct kvm_vcpu *vcpu) in handle_encls()
6037 static int handle_bus_lock_vmexit(struct kvm_vcpu *vcpu) in handle_bus_lock_vmexit()
6048 static int handle_notify(struct kvm_vcpu *vcpu) in handle_notify()
6137 static void vmx_get_exit_info(struct kvm_vcpu *vcpu, u32 *reason, in vmx_get_exit_info()
6167 static void vmx_flush_pml_buffer(struct kvm_vcpu *vcpu) in vmx_flush_pml_buffer()
6224 void dump_vmcs(struct kvm_vcpu *vcpu) in dump_vmcs()
6403 static int __vmx_handle_exit(struct kvm_vcpu *vcpu, fastpath_t exit_fastpath) in __vmx_handle_exit()
6582 static int vmx_handle_exit(struct kvm_vcpu *vcpu, fastpath_t exit_fastpath) in vmx_handle_exit()
6610 static noinstr void vmx_l1d_flush(struct kvm_vcpu *vcpu) in vmx_l1d_flush()
6670 static void vmx_update_cr8_intercept(struct kvm_vcpu *vcpu, int tpr, int irr) in vmx_update_cr8_intercept()
6686 void vmx_set_virtual_apic_mode(struct kvm_vcpu *vcpu) in vmx_set_virtual_apic_mode()
6740 static void vmx_set_apic_access_page_addr(struct kvm_vcpu *vcpu) in vmx_set_apic_access_page_addr()
6844 static void vmx_hwapic_irr_update(struct kvm_vcpu *vcpu, int max_irr) in vmx_hwapic_irr_update()
6858 static int vmx_sync_pir_to_irr(struct kvm_vcpu *vcpu) in vmx_sync_pir_to_irr()
6904 static void vmx_load_eoi_exitmap(struct kvm_vcpu *vcpu, u64 *eoi_exit_bitmap) in vmx_load_eoi_exitmap()
6915 static void vmx_apicv_post_state_restore(struct kvm_vcpu *vcpu) in vmx_apicv_post_state_restore()
6926 static void handle_nm_fault_irqoff(struct kvm_vcpu *vcpu) in handle_nm_fault_irqoff()
6961 static void handle_external_interrupt_irqoff(struct kvm_vcpu *vcpu) in handle_external_interrupt_irqoff()
6978 static void vmx_handle_exit_irqoff(struct kvm_vcpu *vcpu) in vmx_handle_exit_irqoff()
7057 static void __vmx_complete_interrupts(struct kvm_vcpu *vcpu, in __vmx_complete_interrupts()
7118 static void vmx_cancel_injection(struct kvm_vcpu *vcpu) in vmx_cancel_injection()
7151 static void vmx_update_hv_timer(struct kvm_vcpu *vcpu) in vmx_update_hv_timer()
7210 static fastpath_t vmx_exit_handlers_fastpath(struct kvm_vcpu *vcpu) in vmx_exit_handlers_fastpath()
7222 static noinstr void vmx_vcpu_enter_exit(struct kvm_vcpu *vcpu, in vmx_vcpu_enter_exit()
7273 static fastpath_t vmx_vcpu_run(struct kvm_vcpu *vcpu) in vmx_vcpu_run()
7429 static void vmx_vcpu_free(struct kvm_vcpu *vcpu) in vmx_vcpu_free()
7440 static int vmx_vcpu_create(struct kvm_vcpu *vcpu) in vmx_vcpu_create()
7580 static u8 vmx_get_mt_mask(struct kvm_vcpu *vcpu, gfn_t gfn, bool is_mmio) in vmx_get_mt_mask()
7643 static void nested_vmx_cr_fixed1_bits_update(struct kvm_vcpu *vcpu) in nested_vmx_cr_fixed1_bits_update()
7683 static void update_intel_pt_cfg(struct kvm_vcpu *vcpu) in update_intel_pt_cfg()
7752 static void vmx_vcpu_after_set_cpuid(struct kvm_vcpu *vcpu) in vmx_vcpu_after_set_cpuid()
7905 static void vmx_request_immediate_exit(struct kvm_vcpu *vcpu) in vmx_request_immediate_exit()
7910 static int vmx_check_intercept_io(struct kvm_vcpu *vcpu, in vmx_check_intercept_io()
7944 static int vmx_check_intercept(struct kvm_vcpu *vcpu, in vmx_check_intercept()
8027 static int vmx_set_hv_timer(struct kvm_vcpu *vcpu, u64 guest_deadline_tsc, in vmx_set_hv_timer()
8067 static void vmx_cancel_hv_timer(struct kvm_vcpu *vcpu) in vmx_cancel_hv_timer()
8073 static void vmx_sched_in(struct kvm_vcpu *vcpu, int cpu) in vmx_sched_in()
8079 void vmx_update_cpu_dirty_logging(struct kvm_vcpu *vcpu) in vmx_update_cpu_dirty_logging()
8102 static void vmx_setup_mce(struct kvm_vcpu *vcpu) in vmx_setup_mce()
8113 static int vmx_smi_allowed(struct kvm_vcpu *vcpu, bool for_injection) in vmx_smi_allowed()
8121 static int vmx_enter_smm(struct kvm_vcpu *vcpu, union kvm_smram *smram) in vmx_enter_smm()
8142 static int vmx_leave_smm(struct kvm_vcpu *vcpu, const union kvm_smram *smram) in vmx_leave_smm()
8163 static void vmx_enable_smi_window(struct kvm_vcpu *vcpu) in vmx_enable_smi_window()
8169 static bool vmx_apic_init_signal_blocked(struct kvm_vcpu *vcpu) in vmx_apic_init_signal_blocked()
8174 static void vmx_migrate_timers(struct kvm_vcpu *vcpu) in vmx_migrate_timers()
8356 struct kvm_vcpu *vcpu = kvm_get_running_vcpu(); in vmx_handle_intel_pt_intr() local