Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp500713pxv; Fri, 9 Jul 2021 02:52:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxioTalhUsteqW1grBGmyLmZGSac6MYVlhsc/XT01OtW21XFhPM7BzJXRSau/9QOf9WARDn X-Received: by 2002:a17:906:c49:: with SMTP id t9mr9091545ejf.405.1625824371613; Fri, 09 Jul 2021 02:52:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625824371; cv=none; d=google.com; s=arc-20160816; b=VFWMNpcIYDYk3u0/AnQFwMycBRWaUfwgFAm7alu76C8CQXNhEFwdfhjwLYvn+Vl0gx QfpbUak7F3RntRyc0KOIK+IK6H0pwo/Mk5RnUZeZ19H1tPbLWouRN28bkLb8r+Mh7C/e 2KVM1dbr6BSvmPrNhRojgBoMJAkuh9dcdPz9q9NiV6oViOAzba0JPeFmPQzQQnPfxl/o V1H1K/j1JCO7TWqvLlDz+/KJCFbdknATCPoU8yFVZVw+acfpPB1nY/2ka9aJ8P8Rt4b6 F2d9QPF2JePtURKszkelzgN6KRwn/2TulDcFGnaAiNJTC5tE3QC/Fzopw3MjLcAy3eSA D+dg== 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; bh=YChEYlKFa7otoCVTt+WEpUu9Et+wNnjzjnd2qR4tqYU=; b=BNQDC6NAb2nalpZ03OF+kH2i4Q8+GkN+gYcWj6go5QjAFRyA/3NXduRz88YJ1OJ+xg C2n2NerfEVC+O1tiGQ3uwZimqF5AfLUsbnaEKimFfWTuyMCpLK8ifPYXSRuDlQ5BjEkG 9IYHbhqbY9EgR7/I2j1vfd/31Xn4CX/w4Se8LgU1OpJT41BntXpBmVzw7nHpocjn6Cvs hHp4TFYTEt7EiYwNKqY1X5zedCjhJeU4RtjjtDd6UP0rEV8O46tbJ4OyD2XREoWILh5B LEcFCnVmS4Ygw0nuz+5yfPRA6Q5XminT6nznlTws9JVX7JrOLEWsPfpaRNwiYVBBQMf1 uLLQ== 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 eb8si7214272edb.495.2021.07.09.02.52.29; Fri, 09 Jul 2021 02:52:51 -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 S232111AbhGIJyE (ORCPT + 99 others); Fri, 9 Jul 2021 05:54:04 -0400 Received: from mga05.intel.com ([192.55.52.43]:54437 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232118AbhGIJyC (ORCPT ); Fri, 9 Jul 2021 05:54:02 -0400 X-IronPort-AV: E=McAfee;i="6200,9189,10039"; a="295316512" X-IronPort-AV: E=Sophos;i="5.84,226,1620716400"; d="scan'208";a="295316512" Received: from fmsmga002.fm.intel.com ([10.253.24.26]) by fmsmga105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 09 Jul 2021 02:51:19 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.84,226,1620716400"; d="scan'208";a="498856312" Received: from michael-optiplex-9020.sh.intel.com ([10.239.159.182]) by fmsmga002.fm.intel.com with ESMTP; 09 Jul 2021 02:51:17 -0700 From: Yang Weijiang To: pbonzini@redhat.com, seanjc@google.com, vkuznets@redhat.com, jmattson@google.com, wei.w.wang@intel.com, like.xu.linux@gmail.com, kvm@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Yang Weijiang Subject: [PATCH v5 06/13] KVM: x86/vmx: Save/Restore host MSR_ARCH_LBR_CTL state Date: Fri, 9 Jul 2021 18:05:04 +0800 Message-Id: <1625825111-6604-7-git-send-email-weijiang.yang@intel.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1625825111-6604-1-git-send-email-weijiang.yang@intel.com> References: <1625825111-6604-1-git-send-email-weijiang.yang@intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If host is using MSR_ARCH_LBR_CTL then save it before vm-entry and reload it after vm-exit. Co-developed-by: Like Xu Signed-off-by: Like Xu Signed-off-by: Yang Weijiang --- arch/x86/kvm/vmx/vmx.c | 23 +++++++++++++++++++++++ arch/x86/kvm/vmx/vmx.h | 1 + 2 files changed, 24 insertions(+) diff --git a/arch/x86/kvm/vmx/vmx.c b/arch/x86/kvm/vmx/vmx.c index 1a79ac1757af..0d714e76e2d5 100644 --- a/arch/x86/kvm/vmx/vmx.c +++ b/arch/x86/kvm/vmx/vmx.c @@ -1397,6 +1397,26 @@ void vmx_vcpu_load_vmcs(struct kvm_vcpu *vcpu, int cpu, decache_tsc_multiplier(vmx); } +static inline unsigned long get_lbrctlmsr(void) +{ + unsigned long lbrctlmsr = 0; + + if (!static_cpu_has(X86_FEATURE_ARCH_LBR)) + return 0; + + rdmsrl(MSR_ARCH_LBR_CTL, lbrctlmsr); + + return lbrctlmsr; +} + +static inline void update_lbrctlmsr(unsigned long lbrctlmsr) +{ + if (!static_cpu_has(X86_FEATURE_ARCH_LBR)) + return; + + wrmsrl(MSR_ARCH_LBR_CTL, lbrctlmsr); +} + /* * Switches to specified vcpu, until a matching vcpu_put(), but assumes * vcpu mutex is already taken. @@ -1410,6 +1430,7 @@ static void vmx_vcpu_load(struct kvm_vcpu *vcpu, int cpu) vmx_vcpu_pi_load(vcpu, cpu); vmx->host_debugctlmsr = get_debugctlmsr(); + vmx->host_lbrctlmsr = get_lbrctlmsr(); } static void vmx_vcpu_put(struct kvm_vcpu *vcpu) @@ -6797,6 +6818,8 @@ static fastpath_t vmx_vcpu_run(struct kvm_vcpu *vcpu) /* MSR_IA32_DEBUGCTLMSR is zeroed on vmexit. Restore it if needed */ if (vmx->host_debugctlmsr) update_debugctlmsr(vmx->host_debugctlmsr); + if (vmx->host_lbrctlmsr) + update_lbrctlmsr(vmx->host_lbrctlmsr); #ifndef CONFIG_X86_64 /* diff --git a/arch/x86/kvm/vmx/vmx.h b/arch/x86/kvm/vmx/vmx.h index cc362e2d3eaa..69e243fea23d 100644 --- a/arch/x86/kvm/vmx/vmx.h +++ b/arch/x86/kvm/vmx/vmx.h @@ -328,6 +328,7 @@ struct vcpu_vmx { u64 current_tsc_ratio; unsigned long host_debugctlmsr; + unsigned long host_lbrctlmsr; /* * Only bits masked by msr_ia32_feature_control_valid_bits can be set in -- 2.21.1