Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp1186624imc; Mon, 11 Mar 2019 08:15:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqwqcG1RoXDhpQNwysQHamrTv9Dc8p/nHpROK4xKLh6qY3XCtkny3ceXatainrnXY6fIkKVc X-Received: by 2002:a63:561f:: with SMTP id k31mr3013568pgb.319.1552317308640; Mon, 11 Mar 2019 08:15:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552317308; cv=none; d=google.com; s=arc-20160816; b=wMmhSNp4QT6lkTqTbNpQnKoP0SDveg5+Z55xTfjUDFXjgGoj33IILm3gezFTxotcCn FpL55z/9YY3+BpcVB8YCkZz0Wad+ZWsaJxarqDhPmZMihM6YfiZI1RJCtr+D8V/343aC DkV/mghqvt8Bl5SvFrOak6XsEcRXxvb4i9roCQLLT1cHq+xeWh4A3T0sE01uLIN8wdeF qTa2tOL5VO0zQSpMnJ7dZ81ufLqVADEHDTSVS95OKV3H0Vv8DAaGsnDNQtF1sI4oNumW vI/gVqvhX8ytcHcZD6b8Xc8UfAzjbU3we1HxXKYmHXHTh89cPxXFQ1ZS8RzDJ26xFfvj dNZA== 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:date:cc:to:from:subject:message-id; bh=WoxOIQcR/IhhQK4GQUmA/FLb0JePMziheuKOwt/bxmY=; b=u3Jw+FmPMi6R4odLbjn8soq4TjYjZe4P3jrhh11trO5EZ0CBiiHQ2yb0eKypvJjBu4 zHWzu190RwgLyOnhkNfWN1ryjz0oNVRX+ujFRHTJZsgI676GtwC9I/xkZHoB/Q6kL/kR mLLpesK0UXcqD4TI1TE+tIG4WP9oQxDwVUzXTHCt1/u1EAzRYn21puFg8v5DjZiC7uH3 edxjDw7YZ21p1AHmTjiELaswDD87pKEMc73zIJQRHLolccUsHr7+xQWayUKGWN2+P7Ux p91QyUivhqNIn9gZtVy/xyvYVSMvodo7ZfwHoNW6kf127qjKWBRJJtxHQdxEaEpuZv9c AMkA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c3si5888325pld.178.2019.03.11.08.14.52; Mon, 11 Mar 2019 08:15:08 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727066AbfCKPOP (ORCPT + 99 others); Mon, 11 Mar 2019 11:14:15 -0400 Received: from mga06.intel.com ([134.134.136.31]:53902 "EHLO mga06.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725845AbfCKPOP (ORCPT ); Mon, 11 Mar 2019 11:14:15 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga001.fm.intel.com ([10.253.24.23]) by orsmga104.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 11 Mar 2019 08:14:13 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.58,468,1544515200"; d="scan'208";a="153975284" Received: from lxy-dell.sh.intel.com ([10.239.159.147]) by fmsmga001.fm.intel.com with ESMTP; 11 Mar 2019 08:14:12 -0700 Message-ID: Subject: Re: [PATCH v4 17/17] kvm: vmx: Emulate TEST_CTL MSR From: Xiaoyao Li To: Paolo Bonzini Cc: linux-kernel , x86 , kvm@vger.kernel.org Date: Mon, 11 Mar 2019 23:10:58 +0800 In-Reply-To: <7a10bb11-e9bf-f49c-6575-25c3da08cfac@redhat.com> References: <1551494711-213533-1-git-send-email-fenghua.yu@intel.com> <1551494711-213533-18-git-send-email-fenghua.yu@intel.com> <58653d477d78b2a69927d8707522d91f091bcb52.camel@linux.intel.com> <7a10bb11-e9bf-f49c-6575-25c3da08cfac@redhat.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.28.5 (3.28.5-2.el7) Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 2019-03-11 at 14:31 +0100, Paolo Bonzini wrote: > On 09/03/19 03:31, Xiaoyao Li wrote: > > Hi, Paolo, > > > > Do you have any comments on this patch? > > > > We are preparing v5 patches for split lock detection, if you have any > > comments > > about this one, please let me know. > > No, my only comment is that it should be placed _before_ the other two > for bisectability. I think I have already sent that small remark. > > Thanks, > > Paolo I cannot find the small remark you sent before. Maybe I missed something. But I'am confused why it should be placed _before_ the other two. This patch just use the vmx->core_capability that defined it the previous patch. > > Thanks, > > Xiaoyao > > > > On Fri, 2019-03-01 at 18:45 -0800, Fenghua Yu wrote: > > > From: Xiaoyao Li > > > > > > A control bit (bit 29) in TEST_CTL MSR 0x33 will be introduced in > > > future x86 processors. When bit 29 is set, the processor causes #AC > > > exception for split locked accesses at all CPL. > > > > > > Please check the latest Intel Software Developer's Manual > > > for more detailed information on the MSR and the split lock bit. > > > > > > 1. Since the kernel chooses to enable AC split lock by default, which > > > means if we don't emulate TEST_CTL MSR for guest, guest will run with > > > this feature enable while does not known it. Thus existing guests with > > > buggy firmware (like OVMF) and old kernels having the cross cache line > > > issues will fail the boot due to #AC. > > > > > > So we should emulate TEST_CTL MSR, and set it zero to disable AC split > > > lock by default. Whether and when to enable it is left to guest firmware > > > and guest kernel. > > > > > > 2. Host and guest can enable AC split lock independently, so using > > > msr autoload to switch it during VM entry/exit. > > > > > > Signed-off-by: Xiaoyao Li > > > Signed-off-by: Fenghua Yu > > > --- > > > arch/x86/kvm/vmx/vmx.c | 35 +++++++++++++++++++++++++++++++++++ > > > arch/x86/kvm/vmx/vmx.h | 1 + > > > 2 files changed, 36 insertions(+) > > > > > > diff --git a/arch/x86/kvm/vmx/vmx.c b/arch/x86/kvm/vmx/vmx.c > > > index 3e03c6e1e558..c0c5e8621afa 100644 > > > --- a/arch/x86/kvm/vmx/vmx.c > > > +++ b/arch/x86/kvm/vmx/vmx.c > > > @@ -1659,6 +1659,12 @@ static int vmx_get_msr(struct kvm_vcpu *vcpu, > > > struct > > > msr_data *msr_info) > > > u32 index; > > > > > > switch (msr_info->index) { > > > + case MSR_TEST_CTL: > > > + if (!msr_info->host_initiated && > > > + !(vmx->core_capability & CORE_CAP_SPLIT_LOCK_DETECT)) > > > + return 1; > > > + msr_info->data = vmx->msr_test_ctl; > > > + break; > > > #ifdef CONFIG_X86_64 > > > case MSR_FS_BASE: > > > msr_info->data = vmcs_readl(GUEST_FS_BASE); > > > @@ -1805,6 +1811,14 @@ static int vmx_set_msr(struct kvm_vcpu *vcpu, > > > struct > > > msr_data *msr_info) > > > u32 index; > > > > > > switch (msr_index) { > > > + case MSR_TEST_CTL: > > > + if (!(vmx->core_capability & CORE_CAP_SPLIT_LOCK_DETECT)) > > > + return 1; > > > + > > > + if (data & ~TEST_CTL_ENABLE_SPLIT_LOCK_DETECT) > > > + return 1; > > > + vmx->msr_test_ctl = data; > > > + break; > > > case MSR_EFER: > > > ret = kvm_set_msr_common(vcpu, msr_info); > > > break; > > > @@ -4108,6 +4122,9 @@ static void vmx_vcpu_setup(struct vcpu_vmx *vmx) > > > > > > vmx->arch_capabilities = kvm_get_arch_capabilities(); > > > > > > + /* disable AC split lock by default */ > > > + vmx->msr_test_ctl = 0; > > > + > > > vm_exit_controls_init(vmx, vmx_vmexit_ctrl()); > > > > > > /* 22.2.1, 20.8.1 */ > > > @@ -4145,6 +4162,7 @@ static void vmx_vcpu_reset(struct kvm_vcpu *vcpu, > > > bool > > > init_event) > > > > > > vmx->rmode.vm86_active = 0; > > > vmx->spec_ctrl = 0; > > > + vmx->msr_test_ctl = 0; > > > > > > vcpu->arch.microcode_version = 0x100000000ULL; > > > vmx->vcpu.arch.regs[VCPU_REGS_RDX] = get_rdx_init_val(); > > > @@ -6344,6 +6362,21 @@ static void atomic_switch_perf_msrs(struct vcpu_vmx > > > *vmx) > > > msrs[i].host, false); > > > } > > > > > > +static void atomic_switch_msr_test_ctl(struct vcpu_vmx *vmx) > > > +{ > > > + u64 host_msr_test_ctl; > > > + > > > + if (!boot_cpu_has(X86_FEATURE_SPLIT_LOCK_DETECT)) > > > + return; > > > + > > > + rdmsrl(MSR_TEST_CTL, host_msr_test_ctl); > > > + if (host_msr_test_ctl == vmx->msr_test_ctl) > > > + clear_atomic_switch_msr(vmx, MSR_TEST_CTL); > > > + else > > > + add_atomic_switch_msr(vmx, MSR_TEST_CTL, vmx->msr_test_ctl, > > > + host_msr_test_ctl, false); > > > +} > > > + > > > static void vmx_arm_hv_timer(struct vcpu_vmx *vmx, u32 val) > > > { > > > vmcs_write32(VMX_PREEMPTION_TIMER_VALUE, val); > > > @@ -6585,6 +6618,8 @@ static void vmx_vcpu_run(struct kvm_vcpu *vcpu) > > > > > > atomic_switch_perf_msrs(vmx); > > > > > > + atomic_switch_msr_test_ctl(vmx); > > > + > > > vmx_update_hv_timer(vcpu); > > > > > > /* > > > diff --git a/arch/x86/kvm/vmx/vmx.h b/arch/x86/kvm/vmx/vmx.h > > > index cc22379991f3..e8831609c6c3 100644 > > > --- a/arch/x86/kvm/vmx/vmx.h > > > +++ b/arch/x86/kvm/vmx/vmx.h > > > @@ -191,6 +191,7 @@ struct vcpu_vmx { > > > u64 msr_guest_kernel_gs_base; > > > #endif > > > > > > + u64 msr_test_ctl; > > > u64 core_capability; > > > u64 arch_capabilities; > > > u64 spec_ctrl; > >