Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3560333pxk; Mon, 5 Oct 2020 12:57:26 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxKx2wtnAFgn3QbgDkSKGPhFlofVnaRGrfHWLhwDa/2fJbtGIxWosRA+Wb7rJnflr6tCOTN X-Received: by 2002:a05:6402:a42:: with SMTP id bt2mr1345704edb.193.1601927845909; Mon, 05 Oct 2020 12:57:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601927845; cv=none; d=google.com; s=arc-20160816; b=po5K43DsUQrJhitEoB7KKwIwMXi0K/gnR5FI5uhgt5o6F0Oh4br3t+5N4w/YRk1uBB wHFGtJloeNIpEb05fSZmhTtWvmDbZCxH5eNXTQP/4OwuUTddRiRyK2uYlZ9ICDwDlJcU DuqB7bhLfrVy/Pg8uxujXZTivH/0HClIUdlACwvW4Iz82TuEaFOqJ9nQk44hs4yT2zx6 lKFmxj/d/g93wan1NYLIj7XsH0poTVSSXV7Orl+fDbv7mrRKgtlt7PRp8TAJL0Do8XDc chYwxGjh/7f63WadPxax9KjuEInV8AeKrYXX9TtcOEJHbq+l0a8GJ18hRJ1JuLLV4WCi ehqw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :ironport-sdr:ironport-sdr; bh=uTcbIuw1T19agdpiP/5qEAIVZS28s+lNz1UrCchhfPw=; b=d9aOaxYZKZovcWY0w3lb/iAsiqR+aYFUvj15yPXffLD9akdMAwPUCcjXi0aMC906+A NDv36+1YaSD+QB9qKbKyjthyrwmuB+CInYjuLRI59RHsdXidgsXqKDvTyK/D+319FaRp 4KLc+4ZmlKRJWqquqMnMRVnx5R2EJ7nDgKZMMgU2H91yhyyDase1LD8/5lVbrFGwsEMp 4BJ52jwC+zgtMSMCFMLlipq+5GzqQLM9v4DeADOlToGKZBZaRSRpfOPc7y73+PuIDaAh 72/WsilPFTtwN7JzoCUToFk3o9PBLEkCD6iO9Wd0+Zez9MXqPetQfPK9uUYf3LjeSGl5 9v3Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x8si361653ejf.748.2020.10.05.12.56.52; Mon, 05 Oct 2020 12:57:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729503AbgJETzw (ORCPT + 99 others); Mon, 5 Oct 2020 15:55:52 -0400 Received: from mga01.intel.com ([192.55.52.88]:42023 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729424AbgJETzw (ORCPT ); Mon, 5 Oct 2020 15:55:52 -0400 IronPort-SDR: PcqCs+WCA38lv1njoTZGWKkjJPcX2ca6RnholZCh8/AELOwOC1JzY/liz8yPAfJobq66zY+Yt0 fSm4sLescFeA== X-IronPort-AV: E=McAfee;i="6000,8403,9765"; a="181660128" X-IronPort-AV: E=Sophos;i="5.77,340,1596524400"; d="scan'208";a="181660128" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga007.jf.intel.com ([10.7.209.58]) by fmsmga101.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 05 Oct 2020 12:55:37 -0700 IronPort-SDR: DbCMeOUhst1V5ODW4G0ihEwi7ZnnQ0aARCr7wK7vaGF+RFPiaUir8bElz/dTo4u2gU2TqX6Jkk ZnjIIuAyZG8g== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.77,340,1596524400"; d="scan'208";a="353550110" Received: from sjchrist-coffee.jf.intel.com ([10.54.74.160]) by orsmga007.jf.intel.com with ESMTP; 05 Oct 2020 12:55:36 -0700 From: Sean Christopherson To: Paolo Bonzini Cc: Sean Christopherson , Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel , kvm@vger.kernel.org, linux-kernel@vger.kernel.org, Alexander Graf , Aaron Lewis , Peter Xu Subject: [PATCH 1/2] KVM: VMX: Fix x2APIC MSR intercept handling on !APICV platforms Date: Mon, 5 Oct 2020 12:55:31 -0700 Message-Id: <20201005195532.8674-2-sean.j.christopherson@intel.com> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20201005195532.8674-1-sean.j.christopherson@intel.com> References: <20201005195532.8674-1-sean.j.christopherson@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Peter Xu Fix an inverted flag for intercepting x2APIC MSRs and intercept writes by default, even when APICV is enabled. Fixes: 3eb900173c71 ("KVM: x86: VMX: Prevent MSR passthrough when MSR access is denied") Not-signed-off-by: Peter Xu [sean: added changelog] Signed-off-by: Sean Christopherson --- arch/x86/kvm/vmx/vmx.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/arch/x86/kvm/vmx/vmx.c b/arch/x86/kvm/vmx/vmx.c index 4551a7e80ebc..25ef0b22ac9e 100644 --- a/arch/x86/kvm/vmx/vmx.c +++ b/arch/x86/kvm/vmx/vmx.c @@ -3787,9 +3787,10 @@ static void vmx_update_msr_bitmap_x2apic(struct kvm_vcpu *vcpu, u8 mode) int msr; for (msr = 0x800; msr <= 0x8ff; msr++) { - bool intercepted = !!(mode & MSR_BITMAP_MODE_X2APIC_APICV); + bool apicv = !!(mode & MSR_BITMAP_MODE_X2APIC_APICV); - vmx_set_intercept_for_msr(vcpu, msr, MSR_TYPE_RW, intercepted); + vmx_set_intercept_for_msr(vcpu, msr, MSR_TYPE_R, !apicv); + vmx_set_intercept_for_msr(vcpu, msr, MSR_TYPE_W, true); } if (mode & MSR_BITMAP_MODE_X2APIC) { -- 2.28.0