Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp5987300yba; Mon, 13 May 2019 22:56:19 -0700 (PDT) X-Google-Smtp-Source: APXvYqyED5HTqxihjMlo/Ohswksl5NCEG0zTfxqSi8K/MIKVjA6vy8G7tUwRu+QRkOwNfx3swAa3 X-Received: by 2002:a65:4b88:: with SMTP id t8mr36026077pgq.374.1557813379883; Mon, 13 May 2019 22:56:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557813379; cv=none; d=google.com; s=arc-20160816; b=teqxLoq01Sm19F1OrIxKrK0Wa735jPTs6AQp6JELg6xEVarb0fIWAYFsFhh/DG6M7G 7NZ5CX62Xxi2SJfRWUVvKPqdP0LmOpBFbzWWKGl3wJ10PGjFcHezchojIN+IIhuI7y0R Nl2H01xcKH7TDRAGG1JcSO90y+4emIC2YxDsSGfq3FBtDEQHPMLoieYLn7Rd1qDf2GI8 SzM2oBkMVxMJTsQinB7+GNiHilYx6+LoaZTnMXnm9ln+AvbQa44/SKc3ARYK3zKvkjnD JrkW5gHhCFxpXBPFKrMb8XaV0PgtnKhS23dRwvNBhzAg+4NgCQkfr3PVT/BuzzFVcDCF Svlw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=CMDRp8XpQweyoE6w7mWaIS4V4U3Zt6PA6daqDS60vy4=; b=N4JugKOXYdgcm7iTje6KAWNMrCr0LNaAlZK8iEUbnsiLKazjIp7Ax5/eRLT07m3crO iHdOyhiJtK39u/CMh5eoVleCvpb0lM5NuH4H/Ke4PTj3muToqbWGzVq/RetyXmJo1eK9 7k3GNhqzueEVvBvDCA5daiWVSU/5tsimMd+VoVwiiarSbOPUdU4jEWCLxgTegiN+claW Wn6lXYxj6SgWzAeMWKRgIVAC3qVjNZJDuOF3TKl+JJBzK+DWn1gbXI4KrYF0apQQHrba a88rQQ5xoV8Fj9sj6us6SNj3AyD6F+V3M95lI+U/Q/QlQZJqMOUoFjEIEj7hdwlGuwNq c36g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=AGETcZb5; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 127si19154213pgc.349.2019.05.13.22.56.04; Mon, 13 May 2019 22:56:19 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=AGETcZb5; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726872AbfENFzQ (ORCPT + 99 others); Tue, 14 May 2019 01:55:16 -0400 Received: from mail-pf1-f196.google.com ([209.85.210.196]:43467 "EHLO mail-pf1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725562AbfENFzQ (ORCPT ); Tue, 14 May 2019 01:55:16 -0400 Received: by mail-pf1-f196.google.com with SMTP id c6so8494725pfa.10; Mon, 13 May 2019 22:55:16 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=CMDRp8XpQweyoE6w7mWaIS4V4U3Zt6PA6daqDS60vy4=; b=AGETcZb5B5+JSFCrLzQCchKAqOSdHTu08ihur04wjJAh4hRZzLT5eq0cLyddtkUxpy 9EAUk0dM3Jh09plKuOu01QSRFeSHDwN3hbK/O01GgzEeO/4agp1pcwQBmYkoUTXNrK4S wt40Lc832cHqClBbr5NtBUsffKq8l/dvP7Yhcibu4GuO78iIy0BGaTxcM8tlriyAJKWY 4cUtkluCq3TE4EA20rAMgEqrIDKaiugh/VrCoj/ToAukkNJ5RdYQmCiul6xi/KaQoBfE +m9UVL+ZjktcaXrKq3w1kWnxRr+iVTyzx+3LC73cDhZ3dS+w4gjviHZfwq3pZdBNL78D TYOA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=CMDRp8XpQweyoE6w7mWaIS4V4U3Zt6PA6daqDS60vy4=; b=rCsH5uu8/TSUHIv4v97ozlyMtXMCqOxcGrC6tQGhEXWDt4aCcR2cxtagVCcIJSezbl 6kPD+UwH5qmFYrfdqtgUH46vmQbDBXg4SR5Vl+D6AWH14bUFodHdQoPAXJ8k2CmSjnVe 9m9TJtNFfVy0TnZMvoh9+cb6XOpgWvkGHo96Mrh57AtUXHF5eBtUuIVgN2CYVPdqXyiB sGYGq6ymSYdKVkHdhoPyplDw//gp2WyZz2vfnM1QK6PMQOUiAELIf81Ekey64oNdL0X1 h6bNdj9pXnQ9HGKegAdTNv5UATzAr41f9wG3Y0CYldxnkfGHG5/kvwAKYKKbiYIiIH91 Ly8Q== X-Gm-Message-State: APjAAAU4lyIpFpNshLhKYXe+31UDKkf/5JCFHekCFjIl242nBYZT9hnP 76PHxwTe0dcXn6NgEn+Ba5D4w+sy X-Received: by 2002:a63:309:: with SMTP id 9mr36437674pgd.49.1557813315521; Mon, 13 May 2019 22:55:15 -0700 (PDT) Received: from localhost.localdomain ([203.205.141.123]) by smtp.googlemail.com with ESMTPSA id f87sm22808814pff.56.2019.05.13.22.55.13 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Mon, 13 May 2019 22:55:15 -0700 (PDT) From: Wanpeng Li X-Google-Original-From: Wanpeng Li To: linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: Paolo Bonzini , =?UTF-8?q?Radim=20Kr=C4=8Dm=C3=A1=C5=99?= , Sean Christopherson , Liran Alon , Konrad Rzeszutek Wilk Subject: [PATCH v2] KVM: X86: Emulate MSR_IA32_MISC_ENABLE MWAIT bit Date: Tue, 14 May 2019 13:55:09 +0800 Message-Id: <1557813309-8524-1-git-send-email-wanpengli@tencent.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Wanpeng Li MSR IA32_MSIC_ENABLE bit 18, according to SDM: | When this bit is set to 0, the MONITOR feature flag is not set (CPUID.01H:ECX[bit 3] = 0). | This indicates that MONITOR/MWAIT are not supported. | | Software attempts to execute MONITOR/MWAIT will cause #UD when this bit is 0. | | When this bit is set to 1 (default), MONITOR/MWAIT are supported (CPUID.01H:ECX[bit 3] = 1). The CPUID.01H:ECX[bit 3] ought to mirror the value of the MSR bit, CPUID.01H:ECX[bit 3] is a better guard than kvm_mwait_in_guest(). kvm_mwait_in_guest() affects the behavior of MONITOR/MWAIT, not its guest visibility. This patch implements toggling of the CPUID bit based on guest writes to the MSR. Cc: Paolo Bonzini Cc: Radim Krčmář Cc: Sean Christopherson Cc: Liran Alon Cc: Konrad Rzeszutek Wilk Signed-off-by: Wanpeng Li --- v1 -> v2: * to configure MSR_IA32_MISC_ENABLE_MWAIT bit in userspace * implements toggling of the CPUID bit based on guest writes to the MSR arch/x86/kvm/cpuid.c | 8 ++++++++ arch/x86/kvm/x86.c | 9 +++++++++ 2 files changed, 17 insertions(+) diff --git a/arch/x86/kvm/cpuid.c b/arch/x86/kvm/cpuid.c index fd39516..0f82393 100644 --- a/arch/x86/kvm/cpuid.c +++ b/arch/x86/kvm/cpuid.c @@ -137,6 +137,14 @@ int kvm_update_cpuid(struct kvm_vcpu *vcpu) (best->eax & (1 << KVM_FEATURE_PV_UNHALT))) best->eax &= ~(1 << KVM_FEATURE_PV_UNHALT); + best = kvm_find_cpuid_entry(vcpu, 0x1, 0); + if (best) { + if (vcpu->arch.ia32_misc_enable_msr & MSR_IA32_MISC_ENABLE_MWAIT) + best->ecx |= F(MWAIT); + else + best->ecx &= ~F(MWAIT); + } + /* Update physical-address width */ vcpu->arch.maxphyaddr = cpuid_query_maxphyaddr(vcpu); kvm_mmu_reset_context(vcpu); diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 3bbf3ab..4ed45ab 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -2506,6 +2506,15 @@ int kvm_set_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info) } break; case MSR_IA32_MISC_ENABLE: + if ((vcpu->arch.ia32_misc_enable_msr ^ data) & MSR_IA32_MISC_ENABLE_MWAIT) { + if ((vcpu->arch.ia32_misc_enable_msr & MSR_IA32_MISC_ENABLE_MWAIT) && + !(data & MSR_IA32_MISC_ENABLE_MWAIT)) { + if (!guest_cpuid_has(vcpu, X86_FEATURE_XMM3)) + return 1; + } + vcpu->arch.ia32_misc_enable_msr = data; + kvm_update_cpuid(vcpu); + } vcpu->arch.ia32_misc_enable_msr = data; break; case MSR_IA32_SMBASE: -- 2.7.4