Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp3829666ybf; Tue, 3 Mar 2020 13:42:59 -0800 (PST) X-Google-Smtp-Source: ADFU+vtJEhaycrQLVarpR9yzEI/UXrqkh9Y8LJ2wac/gjJIjv3K6QeDMt+j83z6Ftu8CmTuktY7x X-Received: by 2002:a05:6808:902:: with SMTP id w2mr435310oih.170.1583271779137; Tue, 03 Mar 2020 13:42:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1583271779; cv=none; d=google.com; s=arc-20160816; b=vU8M4XbdWYXnqzyqp7N6qphKdhPtsNLZjndhjIJLXn+Hqu0QJSo9bxZo9dn9EWFbqA 4PpOdPNlaZgGXEj2Q/X4EIT+TfPBlDmgMVPRCo8iaMytlteNGnXqZYB87chDIAFbTexc V64GFJaoV1kA2WSJW609h2VUmiBL/sldHxMMbmWiEMCWhQoBpTMXFF6B0SF40W7gGEZ3 XomUUqsn5vEXDq09JhhYAx9Mh9Nd0DBLziG9dy7OVMy91O0NlfknTLV7tze87XM6QYq+ xVKFkCaaIO5oPGiM22En66FJ/zqPBSxR7DmfoRusijrWThTH6eMzb4F1b/x+JCKJVHjo cHUA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=fOz2wSYQ8Wmee/T890uYxW1flDBHOoY8t9qc9JreX9s=; b=nMsjTRxnGIwr2Bf4Opcdhv7KIomIOLqi5KOV6LX2yPJnQUBNmUxva/PqwdEgxLajSg yJiTe/gQiMrVJfwHZ8KyPSVGsMVkK57WRzO7epdaxk7Mas3NcxDkDuKP5WAY7ylQP8qI r9MhQIM6BdZ3Ejrk5t2vbqSAqbnbXVPnG6cP1V5Yi0495Xii04duJNeAFHph36lmo4BG RcDcuWw8QUauZIXDkUbAhrvpyYS5/3TblvW0L041pcqEJG8sc24HXhdb3s4VALu7848g aB3I7duU5jsMIvbllf7NRKCJrxikX2Vw81edoQ32MgzpCioIAd5finBnefSHS0jbp01V hjaA== 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 e81si9148334ote.13.2020.03.03.13.42.47; Tue, 03 Mar 2020 13:42:59 -0800 (PST) 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 S1729774AbgCCTSf (ORCPT + 99 others); Tue, 3 Mar 2020 14:18:35 -0500 Received: from mga12.intel.com ([192.55.52.136]:14351 "EHLO mga12.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729138AbgCCTSe (ORCPT ); Tue, 3 Mar 2020 14:18:34 -0500 X-Amp-Result: UNKNOWN X-Amp-Original-Verdict: FILE UNKNOWN X-Amp-File-Uploaded: False Received: from orsmga005.jf.intel.com ([10.7.209.41]) by fmsmga106.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 03 Mar 2020 11:18:34 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.70,511,1574150400"; d="scan'208";a="412858229" Received: from sjchrist-coffee.jf.intel.com (HELO linux.intel.com) ([10.54.74.202]) by orsmga005.jf.intel.com with ESMTP; 03 Mar 2020 11:18:33 -0800 Date: Tue, 3 Mar 2020 11:18:33 -0800 From: Sean Christopherson To: Xiaoyao Li Cc: Thomas Gleixner , Ingo Molnar , Borislav Petkov , hpa@zytor.com, Paolo Bonzini , Andy Lutomirski , tony.luck@intel.com, peterz@infradead.org, fenghua.yu@intel.com, x86@kernel.org, kvm@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v3 3/8] x86/split_lock: Cache the value of MSR_TEST_CTRL in percpu data Message-ID: <20200303191833.GT1439@linux.intel.com> References: <20200206070412.17400-1-xiaoyao.li@intel.com> <20200206070412.17400-4-xiaoyao.li@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200206070412.17400-4-xiaoyao.li@intel.com> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Feb 06, 2020 at 03:04:07PM +0800, Xiaoyao Li wrote: > Cache the value of MSR_TEST_CTRL in percpu data msr_test_ctrl_cache, > which will be used by KVM module. > > It also avoids an expensive RDMSR instruction if SLD needs to be context > switched. > > Suggested-by: Sean Christopherson > Signed-off-by: Xiaoyao Li > --- > arch/x86/include/asm/cpu.h | 2 ++ > arch/x86/kernel/cpu/intel.c | 19 ++++++++++++------- > 2 files changed, 14 insertions(+), 7 deletions(-) > > diff --git a/arch/x86/include/asm/cpu.h b/arch/x86/include/asm/cpu.h > index ff567afa6ee1..2b20829db450 100644 > --- a/arch/x86/include/asm/cpu.h > +++ b/arch/x86/include/asm/cpu.h > @@ -27,6 +27,8 @@ struct x86_cpu { > }; > > #ifdef CONFIG_HOTPLUG_CPU > +DECLARE_PER_CPU(u64, msr_test_ctrl_cache); > + > extern int arch_register_cpu(int num); > extern void arch_unregister_cpu(int); > extern void start_cpu0(void); > diff --git a/arch/x86/kernel/cpu/intel.c b/arch/x86/kernel/cpu/intel.c > index 49535ed81c22..ff27d026cb4a 100644 > --- a/arch/x86/kernel/cpu/intel.c > +++ b/arch/x86/kernel/cpu/intel.c > @@ -46,6 +46,9 @@ enum split_lock_detect_state { > */ > static enum split_lock_detect_state sld_state = sld_off; > > +DEFINE_PER_CPU(u64, msr_test_ctrl_cache); > +EXPORT_PER_CPU_SYMBOL_GPL(msr_test_ctrl_cache); > + > /* > * Processors which have self-snooping capability can handle conflicting > * memory type across CPUs by snooping its own cache. However, there exists > @@ -1043,20 +1046,22 @@ static void __init split_lock_setup(void) > */ > static void __sld_msr_set(bool on) > { > - u64 test_ctrl_val; > - > - rdmsrl(MSR_TEST_CTRL, test_ctrl_val); > - > if (on) > - test_ctrl_val |= MSR_TEST_CTRL_SPLIT_LOCK_DETECT; > + this_cpu_or(msr_test_ctrl_cache, MSR_TEST_CTRL_SPLIT_LOCK_DETECT); > else > - test_ctrl_val &= ~MSR_TEST_CTRL_SPLIT_LOCK_DETECT; > + this_cpu_and(msr_test_ctrl_cache, ~MSR_TEST_CTRL_SPLIT_LOCK_DETECT); Updating the cache is at best unnecessary, and at worst dangerous, e.g. it incorrectly implies that the cached value of SPLIT_LOCK_DETECT is reliable. Tony's patch[*] is more what I had in mind, the only question is whether the kernel should be paranoid about other bits in MSR_TEST_CTL. [*] 20200206004944.GA11455@agluck-desk2.amr.corp.intel.com > - wrmsrl(MSR_TEST_CTRL, test_ctrl_val); > + wrmsrl(MSR_TEST_CTRL, this_cpu_read(msr_test_ctrl_cache)); > } > > static void split_lock_init(void) > { > + u64 test_ctrl_val; > + > + /* Cache MSR TEST_CTRL */ > + rdmsrl(MSR_TEST_CTRL, test_ctrl_val); > + this_cpu_write(msr_test_ctrl_cache, test_ctrl_val); > + > if (sld_state == sld_off) > return; > > -- > 2.23.0 >