Received: by 10.223.164.221 with SMTP id h29csp3953054wrb; Thu, 19 Oct 2017 06:49:21 -0700 (PDT) X-Received: by 10.101.69.8 with SMTP id n8mr1439221pgq.79.1508420961061; Thu, 19 Oct 2017 06:49:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1508420961; cv=none; d=google.com; s=arc-20160816; b=cp2btm/s0Rimnr2ilkV1EoJTlvm+StpuDD32muJCbd2KziynUOfLBAJTlh2E5D743n HZxCGSSDwGSZ3PoTEtwOqG9qpGR7qMjqzYezbGp7LOnalt9Qn1ladrUEXHCdgMtON2F7 6Jg+5PQx9soID0MmnXP+qOKcXQLVMsXEkrRFeyPfVYnpTNYWfK3tyz0rZFawf3MGnpZ+ CA8SR/jHKlnmhajrGWmmxsecCp2d57dsAppfe+Y+/MCoPp11zTsZVhP+CxkKeT8aWJ6p Thl+5mQQlo7af+M+b31Mr+LGLOnyW961HGTUUsuPHkQjIyE1SAoOQczkVQNe+sLu23et 7ATw== 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 :arc-authentication-results; bh=oif5NND2eRYYPu/4o/GoopOsFR5fok8Swne34JqTHEU=; b=LoVncMlwlQKYawteyltAIzOp53rnXJOa0u5S4gd8A84u2zpiNEEqQ55k1V0MhMmkF5 5ft8Gy/5etxaGA8onZbSPbGvVtQHtzPQPR8Ea++kqnZMWb19yLvKaxn7gmDRafT4wm9f JNSl/BkY2GNh7P3pJ+1xrrGNYs0Xj4gCq8FgYFB3crWClYhSJKGrlEXBL12aJQ4/IcGJ akMrmoIGX1GMDfYtPZ9xLZfw1ORMvkN24aybvf01zLjU1kTShGsDqF1UcOhLO89x7oE7 yzjYC2VF/rGImETJ5Pq/IACzjujuP6DRF6cBYf0xVDCxw0UmAnotASda1VFFvTrL0Zt1 8jgQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Ls311V12; 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=NONE 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 n19si8700187pgd.755.2017.10.19.06.49.06; Thu, 19 Oct 2017 06:49:21 -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=Ls311V12; 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=NONE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753384AbdJSNsi (ORCPT + 99 others); Thu, 19 Oct 2017 09:48:38 -0400 Received: from mail-pf0-f193.google.com ([209.85.192.193]:45558 "EHLO mail-pf0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752902AbdJSNsg (ORCPT ); Thu, 19 Oct 2017 09:48:36 -0400 Received: by mail-pf0-f193.google.com with SMTP id d28so6638981pfe.2; Thu, 19 Oct 2017 06:48:36 -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=oif5NND2eRYYPu/4o/GoopOsFR5fok8Swne34JqTHEU=; b=Ls311V122YfJSw0wuwS0LR3+bAOx2qZ8sBlCRaLswoOmoq79iB8KnXIWgWk9u+8Vj/ oJjUfuLzhq0qz9YXQna5dxV9AqbLemiGVMsOjMYMwJUvRcrYHzzd336R8thcwdWZ/6ny jID+8+7ANbzIcTc5DL0wB+t4K5DrFVmdDe1bsJGcxuto8OfHCwa8jvcaHbfMIc8CEGcH ZfBeJeLfw4rBpIbFsx/kSh0vuqOqTlNJkHoxCZBNrAMXYl+irBoMD+kaTzhYuHW7FQkj /C3e92MKwhjiST8SUJ2Kvkcn/YMoY9mlf01w95h+0E3i8MvzqbEpIF6cg3vxvakVxLKB FeFg== 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=oif5NND2eRYYPu/4o/GoopOsFR5fok8Swne34JqTHEU=; b=GbOOmwZqpPRgo/XH6pJzeiD+/9ZanXCTeyt5tr6/W4DiZDizrumWBn04Db85Ex9eqJ d8xsOTjRMyQiQoMhdARzrRriVdHGYxyFKC6kyuQlMQ6mSXRL987T92iRlxssDJdvUBbT Ikp+ppB3py0HOSB9kFm+Xo3UffMa1b32Md1lpMgiyNXNfHXj1U5nzhnRJ/hPIB+G+o0h GsUdGBt9LCYEtYy8uDDJ2sJt/Plqju6qBnLjGfi3PZP0Dm6y2j4oeldr81O/zbn01is9 TfUTG1km4bz/JSfhOWZebSl6O8m4ZsDhFCo9DZzzswUnvxPVWXa+QYvXd87ZoV6cvb5H 8IWg== X-Gm-Message-State: AMCzsaXoyp8vzcAypFa5RBh6BT7bPj99U6T2bOFqgT/oNKybWTOdGBI8 ixa4MeHw1GUoAe9bjEAQplKdPg== X-Google-Smtp-Source: ABhQp+SqcsoTgr+A5gyJtvjO5Dhs3w2mCM8igLKnjnkn7fkadkd10SLCNmWutQlroLd5vCCAo24VlQ== X-Received: by 10.84.129.36 with SMTP id 33mr1596925plb.303.1508420915436; Thu, 19 Oct 2017 06:48:35 -0700 (PDT) Received: from localhost ([223.72.80.183]) by smtp.gmail.com with ESMTPSA id q7sm23268538pgn.56.2017.10.19.06.48.34 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 19 Oct 2017 06:48:34 -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?= , Wanpeng Li , Jim Mattson Subject: [PATCH v2] KVM: X86: #GP when guest attempts to write MCi_STATUS register w/o 0 Date: Thu, 19 Oct 2017 06:47:56 -0700 Message-Id: <1508420876-3780-1-git-send-email-wanpeng.li@hotmail.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 Both Intel SDM and AMD APM mentioned that MCi_STATUS, when the register is implemented, this register can be cleared by explicitly writing 0s to this register. Writing 1s to this register will cause a general-protection exception. The mce is emulated in qemu, so just the guest attempts to write 1 to this register should cause a #GP, this patch does it. Cc: Paolo Bonzini Cc: Radim Krčmář Cc: Jim Mattson Signed-off-by: Wanpeng Li --- v1 -> v2: * just #GP MCi_STATUS arch/x86/kvm/x86.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 5669af0..a8680ea 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -2006,10 +2006,12 @@ static void kvmclock_sync_fn(struct work_struct *work) KVMCLOCK_SYNC_PERIOD); } -static int set_msr_mce(struct kvm_vcpu *vcpu, u32 msr, u64 data) +static int set_msr_mce(struct kvm_vcpu *vcpu, struct msr_data *msr_info) { u64 mcg_cap = vcpu->arch.mcg_cap; unsigned bank_num = mcg_cap & 0xff; + u32 msr = msr_info->index; + u64 data = msr_info->data; switch (msr) { case MSR_IA32_MCG_STATUS: @@ -2034,6 +2036,9 @@ static int set_msr_mce(struct kvm_vcpu *vcpu, u32 msr, u64 data) if ((offset & 0x3) == 0 && data != 0 && (data | (1 << 10)) != ~(u64)0) return -1; + if (!msr_info->host_initiated && + (offset & 0x3) == 1 && data != 0) + return -1; vcpu->arch.mce_banks[offset] = data; break; } @@ -2283,7 +2288,7 @@ int kvm_set_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info) case MSR_IA32_MCG_CTL: case MSR_IA32_MCG_STATUS: case MSR_IA32_MC0_CTL ... MSR_IA32_MCx_CTL(KVM_MAX_MCE_BANKS) - 1: - return set_msr_mce(vcpu, msr, data); + return set_msr_mce(vcpu, msr_info); case MSR_K7_PERFCTR0 ... MSR_K7_PERFCTR3: case MSR_P6_PERFCTR0 ... MSR_P6_PERFCTR1: -- 2.7.4 From 1583039919237914125@xxx Fri Nov 03 10:21:52 +0000 2017 X-GM-THRID: 1583039919237914125 X-Gmail-Labels: Inbox,Category Forums,HistoricalUnread