1a9dc68d9SClaudio Fontana /* 2a9dc68d9SClaudio Fontana * QEMU KVM support -- x86 specific functions. 3a9dc68d9SClaudio Fontana * 4a9dc68d9SClaudio Fontana * Copyright (c) 2012 Linaro Limited 5a9dc68d9SClaudio Fontana * 6a9dc68d9SClaudio Fontana * This work is licensed under the terms of the GNU GPL, version 2 or later. 7a9dc68d9SClaudio Fontana * See the COPYING file in the top-level directory. 8a9dc68d9SClaudio Fontana * 9a9dc68d9SClaudio Fontana */ 10a9dc68d9SClaudio Fontana 11a9dc68d9SClaudio Fontana #ifndef QEMU_KVM_I386_H 12a9dc68d9SClaudio Fontana #define QEMU_KVM_I386_H 13a9dc68d9SClaudio Fontana 14a9dc68d9SClaudio Fontana #include "sysemu/kvm.h" 15a9dc68d9SClaudio Fontana 16a9dc68d9SClaudio Fontana #ifdef CONFIG_KVM 17a9dc68d9SClaudio Fontana 18a9dc68d9SClaudio Fontana #define kvm_pit_in_kernel() \ 19a9dc68d9SClaudio Fontana (kvm_irqchip_in_kernel() && !kvm_irqchip_is_split()) 20a9dc68d9SClaudio Fontana #define kvm_pic_in_kernel() \ 21a9dc68d9SClaudio Fontana (kvm_irqchip_in_kernel() && !kvm_irqchip_is_split()) 22a9dc68d9SClaudio Fontana #define kvm_ioapic_in_kernel() \ 23a9dc68d9SClaudio Fontana (kvm_irqchip_in_kernel() && !kvm_irqchip_is_split()) 24a9dc68d9SClaudio Fontana 25a9dc68d9SClaudio Fontana #else 26a9dc68d9SClaudio Fontana 27a9dc68d9SClaudio Fontana #define kvm_pit_in_kernel() 0 28a9dc68d9SClaudio Fontana #define kvm_pic_in_kernel() 0 29a9dc68d9SClaudio Fontana #define kvm_ioapic_in_kernel() 0 30a9dc68d9SClaudio Fontana 31a9dc68d9SClaudio Fontana #endif /* CONFIG_KVM */ 32a9dc68d9SClaudio Fontana 33a9dc68d9SClaudio Fontana bool kvm_has_smm(void); 3433bc5f1dSPhilippe Mathieu-Daudé bool kvm_enable_x2apic(void); 3533bc5f1dSPhilippe Mathieu-Daudé bool kvm_hv_vpindex_settable(void); 36*47e76d03SMichael Roth bool kvm_enable_hypercall(uint64_t enable_mask); 3733bc5f1dSPhilippe Mathieu-Daudé 3833bc5f1dSPhilippe Mathieu-Daudé bool kvm_enable_sgx_provisioning(KVMState *s); 3933bc5f1dSPhilippe Mathieu-Daudé bool kvm_hyperv_expand_features(X86CPU *cpu, Error **errp); 4033bc5f1dSPhilippe Mathieu-Daudé 41ee88612dSPaolo Bonzini int kvm_get_vm_type(MachineState *ms); 42a9dc68d9SClaudio Fontana void kvm_arch_reset_vcpu(X86CPU *cs); 43ec19444aSMaciej S. Szmigiero void kvm_arch_after_reset_vcpu(X86CPU *cpu); 44a9dc68d9SClaudio Fontana void kvm_arch_do_init_vcpu(X86CPU *cs); 45f3f99d2aSPhilippe Mathieu-Daudé uint32_t kvm_arch_get_supported_cpuid(KVMState *env, uint32_t function, 46f3f99d2aSPhilippe Mathieu-Daudé uint32_t index, int reg); 47f3f99d2aSPhilippe Mathieu-Daudé uint64_t kvm_arch_get_supported_msr_feature(KVMState *s, uint32_t index); 48a9dc68d9SClaudio Fontana 4933bc5f1dSPhilippe Mathieu-Daudé void kvm_set_max_apic_id(uint32_t max_apic_id); 5033bc5f1dSPhilippe Mathieu-Daudé void kvm_request_xsave_components(X86CPU *cpu, uint64_t mask); 5133bc5f1dSPhilippe Mathieu-Daudé 5233bc5f1dSPhilippe Mathieu-Daudé #ifdef CONFIG_KVM 5333bc5f1dSPhilippe Mathieu-Daudé 54ee88612dSPaolo Bonzini bool kvm_is_vm_type_supported(int type); 5533bc5f1dSPhilippe Mathieu-Daudé bool kvm_has_adjust_clock_stable(void); 5633bc5f1dSPhilippe Mathieu-Daudé bool kvm_has_exception_payload(void); 5733bc5f1dSPhilippe Mathieu-Daudé void kvm_synchronize_all_tsc(void); 5833bc5f1dSPhilippe Mathieu-Daudé 591f49d476SPhilippe Mathieu-Daudé void kvm_get_apic_state(DeviceState *d, struct kvm_lapic_state *kapic); 60a9dc68d9SClaudio Fontana void kvm_put_apicbase(X86CPU *cpu, uint64_t value); 61a9dc68d9SClaudio Fontana 62a9dc68d9SClaudio Fontana bool kvm_has_x2apic_api(void); 63a9dc68d9SClaudio Fontana bool kvm_has_waitpkg(void); 64a9dc68d9SClaudio Fontana 65a9dc68d9SClaudio Fontana uint64_t kvm_swizzle_msi_ext_dest_id(uint64_t address); 666096cf78SDavid Woodhouse void kvm_update_msi_routes_all(void *private, bool global, 676096cf78SDavid Woodhouse uint32_t index, uint32_t mask); 68a9dc68d9SClaudio Fontana 6933bc5f1dSPhilippe Mathieu-Daudé #endif /* CONFIG_KVM */ 7019e2a9fbSZeng Guang 71bb781b94SPhilippe Mathieu-Daudé void kvm_pc_setup_irq_routing(bool pci_enabled); 72bb781b94SPhilippe Mathieu-Daudé 73a9dc68d9SClaudio Fontana #endif 74