Lazy tscdeadline is a new paravirtulization feature which target is to reduce vm-exit caused by msr-write to MSR_IA32_TSC_DEADLINE. This patch adds things below: - a new msr register to communicate between guest and host - a new feature flag to tell guest open this feature - a new data structure to exchange data between guest and host There is no functional changes in this patch. Signed-off-by: Li Shujin <arkinjob@xxxxxxxxxxx> Signed-off-by: Wang Jianchao <jianchwa@xxxxxxxxxxx> --- arch/x86/include/uapi/asm/kvm_para.h | 9 +++++++++ arch/x86/kvm/cpuid.c | 1 + 2 files changed, 10 insertions(+) diff --git a/arch/x86/include/uapi/asm/kvm_para.h b/arch/x86/include/uapi/asm/kvm_para.h index 6e64b27b..86ba601 100644 --- a/arch/x86/include/uapi/asm/kvm_para.h +++ b/arch/x86/include/uapi/asm/kvm_para.h @@ -36,6 +36,7 @@ #define KVM_FEATURE_MSI_EXT_DEST_ID 15 #define KVM_FEATURE_HC_MAP_GPA_RANGE 16 #define KVM_FEATURE_MIGRATION_CONTROL 17 +#define KVM_FEATURE_LAZY_TSCDEADLINE 18 #define KVM_HINTS_REALTIME 0 @@ -58,6 +59,7 @@ #define MSR_KVM_ASYNC_PF_INT 0x4b564d06 #define MSR_KVM_ASYNC_PF_ACK 0x4b564d07 #define MSR_KVM_MIGRATION_CONTROL 0x4b564d08 +#define MSR_KVM_LAZY_TSCDEADLINE 0x4b564d09 struct kvm_steal_time { __u64 steal; @@ -84,6 +86,13 @@ struct kvm_clock_pairing { #define KVM_STEAL_VALID_BITS ((-1ULL << (KVM_STEAL_ALIGNMENT_BITS + 1))) #define KVM_STEAL_RESERVED_MASK (((1 << KVM_STEAL_ALIGNMENT_BITS) - 1 ) << 1) +struct kvm_lazy_tscdeadline { + __u64 armed; + __u64 pending; + __u32 flags; + __u32 pad[11]; +}; + #define KVM_MAX_MMU_OP_BATCH 32 #define KVM_ASYNC_PF_ENABLED (1 << 0) diff --git a/arch/x86/kvm/cpuid.c b/arch/x86/kvm/cpuid.c index 7f4d133..bbebf81 100644 --- a/arch/x86/kvm/cpuid.c +++ b/arch/x86/kvm/cpuid.c @@ -1117,6 +1117,7 @@ static inline int __do_cpuid_func(struct kvm_cpuid_array *array, u32 function) (1 << KVM_FEATURE_PV_SEND_IPI) | (1 << KVM_FEATURE_POLL_CONTROL) | (1 << KVM_FEATURE_PV_SCHED_YIELD) | + (1 << KVM_FEATURE_LAZY_TSCDEADLINE) | (1 << KVM_FEATURE_ASYNC_PF_INT); if (sched_info_on()) -- 2.7.4