Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3121651ybt; Mon, 22 Jun 2020 15:48:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzcD08vdlxJq42RlK5tvpeI6osn8Klbcm/AxTrjm2mU5qDV3pzvGPOz1fyoiDxhOWUSVGPT X-Received: by 2002:a17:906:b15:: with SMTP id u21mr12621447ejg.520.1592866100802; Mon, 22 Jun 2020 15:48:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592866100; cv=none; d=google.com; s=arc-20160816; b=JUiaewpaeyHfUTNNDcBBcszMGDjTNWqSodWOyz3LwApAeYsqDImApDuIjpBh82wMmh Ddom5lcS7Wf/q+WZfCtAvQOT0q2eToQAt2xHVdupGr2hRkci4eGswmsiERG0VWqonnXW J/FuaGPsTgfOxC+qUf4rQI86ksat89V3ARjWQWkszBkR6a6cuP1lxO8CAOl1KjgNr4/9 RK33970Tbgs9RFVBEsbKWQINq65BT0hmtiWaaaBENHHvRcheUGerhYarDXHXANiRtovy RETQC0GXEh9h6ayjNa5heWE80KzQPs5HXcNdQKa0YshR0UKbs36ffOKzsSzRxFu9UqVc sXuA== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :ironport-sdr:ironport-sdr; bh=i53XnkHnyM8nFzs0tNGqBjQkRwIwOCvzXUPgNS1dYaA=; b=nFK5nbUGyn/USN3eRTZgV09aZVTNRW+XYd7qAJe262XF4uZB8QLp2nxFyxkK+YcAy2 GpsFCQqJyIIU3bFo+MgK/UI3IrkLXhEWlZYo4PZv4ZXNwzBrkaMi/5eHaAu0Oy+ZfeGg njbWkgLCNX2FDOnyBRCF+vFurMD4bZ5d90MhUMN7Yc0Smy7FJ3pw6coPYrIkxy6w7YSJ GAMn6gGf1h8AP8oi8sJdQf2DLe0+nxJvcabuO52s6mz8ZBzj55JS/QWO+8e4OO9sCZuc cnKmDg+5TvSVDHJ5PhyjAbA74iyAPFls5D0KJuJBWclNp6q4uIaLntFmOksrDLd5OvsY OTMQ== 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 j12si8090428ejs.213.2020.06.22.15.47.58; Mon, 22 Jun 2020 15:48:20 -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 S1731558AbgFVWo7 (ORCPT + 99 others); Mon, 22 Jun 2020 18:44:59 -0400 Received: from mga18.intel.com ([134.134.136.126]:27426 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731186AbgFVWm5 (ORCPT ); Mon, 22 Jun 2020 18:42:57 -0400 IronPort-SDR: rrQdXBB1pzl7O0uBTA+CRVWxWpdN6M8nfQ0ZieKxjwMzK9pyi8AileE6z79hAs8BmYob0euarC PoUcUJg/XS3g== X-IronPort-AV: E=McAfee;i="6000,8403,9660"; a="131303574" X-IronPort-AV: E=Sophos;i="5.75,268,1589266800"; d="scan'208";a="131303574" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga008.fm.intel.com ([10.253.24.58]) by orsmga106.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Jun 2020 15:42:54 -0700 IronPort-SDR: FAzpuBBf11NBdp3BnF5sXwz5dNqTfJt2k/bHeEQM4oziqWdZgdT6N8zu6h9Cn0p5afhdaaPytx pL1960fCdI1w== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.75,268,1589266800"; d="scan'208";a="264634927" Received: from sjchrist-coffee.jf.intel.com ([10.54.74.152]) by fmsmga008.fm.intel.com with ESMTP; 22 Jun 2020 15:42:54 -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 Subject: [PATCH 09/15] KVM: VMX: Check guest support for RDTSCP before processing MSR_TSC_AUX Date: Mon, 22 Jun 2020 15:42:43 -0700 Message-Id: <20200622224249.29562-10-sean.j.christopherson@intel.com> X-Mailer: git-send-email 2.26.0 In-Reply-To: <20200622224249.29562-1-sean.j.christopherson@intel.com> References: <20200622224249.29562-1-sean.j.christopherson@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Check for RDTSCP support prior to checking if MSR_TSC_AUX is in the uret MSRs array so that the array lookup and manipulation are back-to-back. This paves the way toward adding a helper to wrap the lookup and manipulation. No functional change intended. Signed-off-by: Sean Christopherson --- arch/x86/kvm/vmx/vmx.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/arch/x86/kvm/vmx/vmx.c b/arch/x86/kvm/vmx/vmx.c index a0f4049d956f..954b9aa950f2 100644 --- a/arch/x86/kvm/vmx/vmx.c +++ b/arch/x86/kvm/vmx/vmx.c @@ -1751,9 +1751,11 @@ static void setup_msrs(struct vcpu_vmx *vmx) index = __vmx_find_uret_msr(vmx, MSR_EFER); if (index >= 0 && update_transition_efer(vmx, index)) move_msr_up(vmx, index, nr_active_uret_msrs++); - index = __vmx_find_uret_msr(vmx, MSR_TSC_AUX); - if (index >= 0 && guest_cpuid_has(&vmx->vcpu, X86_FEATURE_RDTSCP)) - move_msr_up(vmx, index, nr_active_uret_msrs++); + if (guest_cpuid_has(&vmx->vcpu, X86_FEATURE_RDTSCP)) { + index = __vmx_find_uret_msr(vmx, MSR_TSC_AUX); + if (index >= 0) + move_msr_up(vmx, index, nr_active_uret_msrs++); + } index = __vmx_find_uret_msr(vmx, MSR_IA32_TSX_CTRL); if (index >= 0) move_msr_up(vmx, index, nr_active_uret_msrs++); -- 2.26.0