Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751990AbeAPUMA (ORCPT + 1 other); Tue, 16 Jan 2018 15:12:00 -0500 Received: from mga02.intel.com ([134.134.136.20]:46253 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750861AbeAPUL7 (ORCPT ); Tue, 16 Jan 2018 15:11:59 -0500 X-Amp-Result: UNSCANNABLE X-Amp-File-Uploaded: False X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.46,369,1511856000"; d="scan'208";a="26971299" Date: Tue, 16 Jan 2018 12:11:58 -0800 From: "Luck, Tony" To: Borislav Petkov Cc: Jia Zhang , "hmh@hmh.eng.br" , "mingo@redhat.com" , "hpa@zytor.com" , "tglx@linutronix.de" , "x86@kernel.org" , "linux-kernel@vger.kernel.org" Subject: Re: [PATCH v2] x86/microcode/intel: Extend BDW late-loading with LLC size check Message-ID: <20180116201158.7mu6pj6ynqrfdxe4@agluck-desk> References: <1516021917-48335-1-git-send-email-zhang.jia@linux.alibaba.com> <20180115184616.r6pypjegywyd7ncm@pd.tnic> <2ddaecd3-c121-cb37-219e-0e7b1d17c22e@linux.alibaba.com> <3908561D78D1C84285E8C5FCA982C28F7B333F37@FMSMSX154.amr.corp.intel.com> <20180116200149.zffwdbjwj53ba7oj@pd.tnic> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180116200149.zffwdbjwj53ba7oj@pd.tnic> User-Agent: NeoMutt/20170609 (1.8.3) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Return-Path: On Tue, Jan 16, 2018 at 09:01:49PM +0100, Borislav Petkov wrote: > On Tue, Jan 16, 2018 at 05:24:27PM +0000, Luck, Tony wrote: > > > I'll look for someone who can confirm the 2.5MB/core detail. > > > > Ok ... re-read the erratum. The 2.5MB/core is clear. The E5+E7 is clear. > > > > No mention of the platform ID, but Jia is dropping that part. > > > > Boris ... what specific questions remain? > > This magic: > > llc_size_per_core(c) > 2621440 > > as a reliable detection characteristic whether the patch is good to > apply late. There must be a more reliable way to detect that. > > Also, the testing order is: > > llc_size_per_core(c) > 2621440 && > c->microcode < 0x0b000021) { > > so if the LLC size per core check fails, the microcode revision being < > 0x0b000021 doesn't matter. I.e., on machines with LLC-per-core < 2.5M, > we can update even with revisions < 0x0b000021. > > Is that ordering correct? I think so. The erratum (see below) says the problem only occurs on the large-cache SKUs. So we only need to avoid the update if we are on a big cache SKU that is also running old microcode. > Also, this heuristic is not documented in the public doc AFAICT - I'm > guessing that'll change soon...? Here's what I see in the public doc. for BDF90: Problem: An uncorrectable error (IA32_MC3_STATUS.MCACOD=0400 and IA32_MC3_STATUS.MSCOD=0080) may be logged for processors that have more than 2.5MB last-level-cache per core on attempting to load a microcode update or execute an authenticated code module. This issue does not occur with microcode updates with a signature of 0x0b000021 and greater. -Tony