Received: by 2002:a05:6a10:413:0:0:0:0 with SMTP id 19csp763724pxp; Fri, 11 Mar 2022 14:29:41 -0800 (PST) X-Google-Smtp-Source: ABdhPJy1/VF0FloTRF9OnDSRBT9MON4ZpYYF9P3R/dLpb12Z/9moPNvp7rKqywv9XR0WFJIchOuM X-Received: by 2002:a17:903:2411:b0:151:8304:6936 with SMTP id e17-20020a170903241100b0015183046936mr12252235plo.134.1647037781187; Fri, 11 Mar 2022 14:29:41 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1647037781; cv=none; d=google.com; s=arc-20160816; b=X2CgMbTE0/NEjRgrJUu9YD1YGYdQbynZx92QlMcE/P9PiBeu+0agItijlK6ivdfXga fpSKu7W6mszxyiCISols/vE2501rzVOkX0IZAHXx7wYTaj+nECAhN6YQ2ZBebTV1NlWK mNQXyIVu3AS2z4kWx7qjVPgbN6zq9cDGHiIjZvHu6QmaI933VuOby5XqsYsnPRmB1RkR uaQbq4VlCgA0OMRbt/bek+8jOBa0FFFQbw7aeQFvQ/je0L6cgX3LCX89exrzQGw0K5Ux HUVaRtrjWUl+aLSoBzK+zl+pmzzOBC0hvAWYJgBqXtc25CvYAVX0VUPKVuTyBYNfnq3l ukkQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:dkim-signature; bh=gDqiN5pf4YDkXe9dP0rfveBOw3P+FW2+px95EQefoNY=; b=xauHfLdZ1IqmulAqTcVZ8w79kNd2VU+fC34OpyqXBBmJDGYCG2woyDkiQB+t5J1Y1s pB2lks6b9u7UIbngtLc46rIM4A7OV+W4hjIKYFBG+3QeD2gAS8Kdr7jOz+vfSZ8hLt5o GIstF3J1/UHtq0VqGPsD19c8r7S4tzGkuGzyXEUaAGr/tPfMKuIjjMOA+4VYezHm6s0d CuayfvTViGXN9rFzGVqcZLdvHCaD6GGuZpqoNREadbbW3J2oVkAz+m7Xa7x6qphk1e50 gibyBvrmhTnmT343dj75V7KChm2ckzwerS0TAP3zg78BXvobujtdv3XD0fYsr9HZcUB6 8qcw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=AZEZcXX6; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id g3-20020a633743000000b00372f2b931b7si8739076pgn.475.2022.03.11.14.29.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 11 Mar 2022 14:29:41 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=AZEZcXX6; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 1EB972EE047; Fri, 11 Mar 2022 13:38:51 -0800 (PST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236085AbiCKIbN (ORCPT + 99 others); Fri, 11 Mar 2022 03:31:13 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46882 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229558AbiCKIbK (ORCPT ); Fri, 11 Mar 2022 03:31:10 -0500 Received: from mail-pl1-x630.google.com (mail-pl1-x630.google.com [IPv6:2607:f8b0:4864:20::630]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BEF7D1B45FD; Fri, 11 Mar 2022 00:30:07 -0800 (PST) Received: by mail-pl1-x630.google.com with SMTP id 9so7116795pll.6; Fri, 11 Mar 2022 00:30:07 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=gDqiN5pf4YDkXe9dP0rfveBOw3P+FW2+px95EQefoNY=; b=AZEZcXX6nMsaAwas+IdJHLE7pZOp4Ov+sL7IwkhOxtxDJQfEFh0cgmGklog0Sm7tRP E3yk44onMe7eFe037XDU2MyVeqiV/ide7lkKskpnZ0k51oBxaCVZ6A0oVGBZ6z89F0dt aa8g5wl5qsI+hQcDSS1PDktAOOlpMxPBunZUaOTbYab468G1CrUwy5Ab2d1LhgT3Jeom d6Hx6DPWZvYHqcx8n4mncACAZKZvzDAzsgioKeah6ZWYEZPdubWNNpLm/ENzF+t4kM1a Ne5yFHm/FxO3kC1S6+6mc5njSf74/nsmqzkKTRSVsQipQbWugRkIjPbpMKEoTnsyem1K 2N1w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=gDqiN5pf4YDkXe9dP0rfveBOw3P+FW2+px95EQefoNY=; b=pq19kadIZVMjGIMhXmM4nzp3yebaKcRN+sXogkEL4WglDvvr2PqlWrdGjiEBx0td6a SLe0ilubbrMzluh3rLW+iKD2qY9JYtCu+6lrJiYAUBiNk5Kk+Wj57E2+WHn39TiQQMmh BmosAl5/ryRKfkGlVgUDU4B5XnOCr5KdGtxsZKXjXE+FlxcVWTNOIrXQhH7UvJbyTZf3 dQIG2dyvN2btDxOrQX4TmLra6lWe8YwA97+Qp0Wm6LYUSFE9P0q/kqa+BfKVvCQvHdzP CpzalnoUuoMY3RHYfwZrH+Pz4ZzihjBzOcmTNnXiektto5vi72AJ91Gvw8jsvSyODfRv abXQ== X-Gm-Message-State: AOAM533Reha0H0uA3wwkNCMTh8uf9bwO3/pPer8Ml2SyHnhoEtY6kudL Ddj2zlI/mNLxX4uSLECoENXeYWNkklA= X-Received: by 2002:a17:90b:4595:b0:1be:db22:8327 with SMTP id hd21-20020a17090b459500b001bedb228327mr20604506pjb.99.1646987406951; Fri, 11 Mar 2022 00:30:06 -0800 (PST) Received: from localhost.localdomain ([203.205.141.111]) by smtp.googlemail.com with ESMTPSA id l1-20020a17090aec0100b001bfa1bafeadsm9090576pjy.53.2022.03.11.00.30.04 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Fri, 11 Mar 2022 00:30:06 -0800 (PST) From: Wanpeng Li X-Google-Original-From: Wanpeng Li To: linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: Paolo Bonzini , Sean Christopherson , Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel Subject: [PATCH 1/5] KVM: X86: Add MSR_KVM_PREEMPT_COUNT support Date: Fri, 11 Mar 2022 00:29:10 -0800 Message-Id: <1646987354-28644-2-git-send-email-wanpengli@tencent.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1646987354-28644-1-git-send-email-wanpengli@tencent.com> References: <1646987354-28644-1-git-send-email-wanpengli@tencent.com> X-Spam-Status: No, score=-1.7 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RDNS_NONE, SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Wanpeng Li x86 preempt_count is per-cpu, any non-zero value for preempt_count indicates that either preemption has been disabled explicitly or the CPU is currently servicing some sort of interrupt. The guest will pass this value to the hypervisor, so the hypervisor knows whether the guest is running in the critical section. Signed-off-by: Wanpeng Li --- arch/x86/include/asm/kvm_host.h | 6 +++++ arch/x86/include/uapi/asm/kvm_para.h | 2 ++ arch/x86/kvm/x86.c | 35 ++++++++++++++++++++++++++++ 3 files changed, 43 insertions(+) diff --git a/arch/x86/include/asm/kvm_host.h b/arch/x86/include/asm/kvm_host.h index f72e80178ffc..50f011a7445a 100644 --- a/arch/x86/include/asm/kvm_host.h +++ b/arch/x86/include/asm/kvm_host.h @@ -856,6 +856,12 @@ struct kvm_vcpu_arch { u64 msr_kvm_poll_control; + struct { + u64 msr_val; + bool preempt_count_enabled; + struct gfn_to_hva_cache preempt_count_cache; + } pv_pc; + /* * Indicates the guest is trying to write a gfn that contains one or * more of the PTEs used to translate the write itself, i.e. the access diff --git a/arch/x86/include/uapi/asm/kvm_para.h b/arch/x86/include/uapi/asm/kvm_para.h index 6e64b27b2c1e..f99fa4407604 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_PREEMPT_COUNT 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_PREEMPT_COUNT 0x4b564d09 struct kvm_steal_time { __u64 steal; diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 51106d32f04e..af75e273cb32 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -1456,6 +1456,7 @@ static const u32 emulated_msrs_all[] = { MSR_KVM_ASYNC_PF_EN, MSR_KVM_STEAL_TIME, MSR_KVM_PV_EOI_EN, MSR_KVM_ASYNC_PF_INT, MSR_KVM_ASYNC_PF_ACK, + MSR_KVM_PREEMPT_COUNT, MSR_IA32_TSC_ADJUST, MSR_IA32_TSC_DEADLINE, @@ -3433,6 +3434,25 @@ static void record_steal_time(struct kvm_vcpu *vcpu) mark_page_dirty_in_slot(vcpu->kvm, ghc->memslot, gpa_to_gfn(ghc->gpa)); } +static int kvm_pv_enable_preempt_count(struct kvm_vcpu *vcpu, u64 data) +{ + u64 addr = data & ~KVM_MSR_ENABLED; + struct gfn_to_hva_cache *ghc = &vcpu->arch.pv_pc.preempt_count_cache; + + vcpu->arch.pv_pc.preempt_count_enabled = false; + vcpu->arch.pv_pc.msr_val = data; + + if (!(data & KVM_MSR_ENABLED)) + return 0; + + if (kvm_gfn_to_hva_cache_init(vcpu->kvm, ghc, addr, sizeof(int))) + return 1; + + vcpu->arch.pv_pc.preempt_count_enabled = true; + + return 0; +} + int kvm_set_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info) { bool pr = false; @@ -3652,6 +3672,14 @@ int kvm_set_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info) vcpu->arch.msr_kvm_poll_control = data; break; + case MSR_KVM_PREEMPT_COUNT: + if (!guest_pv_has(vcpu, KVM_FEATURE_PREEMPT_COUNT)) + return 1; + + if (kvm_pv_enable_preempt_count(vcpu, data)) + return 1; + break; + case MSR_IA32_MCG_CTL: case MSR_IA32_MCG_STATUS: case MSR_IA32_MC0_CTL ... MSR_IA32_MCx_CTL(KVM_MAX_MCE_BANKS) - 1: @@ -3992,6 +4020,12 @@ int kvm_get_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info) msr_info->data = vcpu->arch.msr_kvm_poll_control; break; + case MSR_KVM_PREEMPT_COUNT: + if (!guest_pv_has(vcpu, KVM_FEATURE_PREEMPT_COUNT)) + return 1; + + msr_info->data = vcpu->arch.pv_pc.msr_val; + break; case MSR_IA32_P5_MC_ADDR: case MSR_IA32_P5_MC_TYPE: case MSR_IA32_MCG_CAP: @@ -11190,6 +11224,7 @@ int kvm_arch_vcpu_create(struct kvm_vcpu *vcpu) vcpu->arch.pending_external_vector = -1; vcpu->arch.preempted_in_kernel = false; + vcpu->arch.pv_pc.preempt_count_enabled = false; #if IS_ENABLED(CONFIG_HYPERV) vcpu->arch.hv_root_tdp = INVALID_PAGE; -- 2.25.1