Received: by 10.223.185.116 with SMTP id b49csp1569904wrg; Wed, 21 Feb 2018 22:34:34 -0800 (PST) X-Google-Smtp-Source: AH8x226Ev6kg1CF41N4g9lS5bwPdSOVt6z39MkTgYPRG7RcfQ843G9OTFDmbv1PAAbP7qGJBDvuY X-Received: by 10.99.117.6 with SMTP id q6mr4778343pgc.146.1519281274025; Wed, 21 Feb 2018 22:34:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519281273; cv=none; d=google.com; s=arc-20160816; b=Tn9nL1eMjLMlFNj5ez4r1h9xZNYLYQenAa7H6HZtZ0WlSKnSz/g3Ve6af2UE4lQCgz Wlo2r3XeP6ueO2dXq7AaY1S8XlEtzH+jIuyZ9zYV3qUDBvDjGStiD2F+HQRwy4rJk1J0 6NEDrlWTKNchmJjb1naHkN6EzB4u0pC2D3u+z5raqrCGLm1UQWXL7/g0TTGfuYMsc4rV gC8owApcf4AjQpqI5xNQlCxEyH2+aRSwe8AFZjJbQk2hp3KnOUjCSGmcCc3Fjp0Ps7Vi lnJnUVFz0p3tC9ocgq0CFKXP9sqYMxQDH8rxwEk0oCl4dTv36V0qWSvzBJ9PHx7u7YOj +T/Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=hdbUEKAL3kgwZu5dEDZrVUtOyL7mPTecRPsqYilmY10=; b=A+iMFNMSheHyUdQh+3BITEctyziQMS/rNzt5l5hFUJ8aEwOb1AAqgNq9UejAg9Zj9k hiIMJYswh6lwFf3/aP+FkVIgkJMAVrN09iPc4NYUlXfH5PFEVhqJMTuN1P4tRrAyaNFS xiAp3GUhfEUH9dyeNl0NQw842n7bdcDNaW/ScVW4P9394/DvAf9oQ++WC6lXMZUgvanP fUnOewXkCzwYsqp/kbErP/cqte0HLdeWO7yyhupdmJYIphX0vN6OfLOi2PoQlTW4B6Sd j4V6WxcetTapZbsipecAS/Imyjrf9iDGNm8Mi0g5AfZrUEq+umHls/OuUAI75OsGzy/k 2U0w== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y7-v6si1092151plh.806.2018.02.21.22.34.16; Wed, 21 Feb 2018 22:34:33 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752541AbeBVGdg (ORCPT + 99 others); Thu, 22 Feb 2018 01:33:36 -0500 Received: from mga03.intel.com ([134.134.136.65]:55370 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752399AbeBVGde (ORCPT ); Thu, 22 Feb 2018 01:33:34 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by orsmga103.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 21 Feb 2018 22:33:33 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.47,377,1515484800"; d="scan'208";a="31891775" Received: from otc-nc-03.jf.intel.com ([10.54.39.38]) by fmsmga004.fm.intel.com with ESMTP; 21 Feb 2018 22:33:32 -0800 From: Ashok Raj To: bp@suse.de Cc: Ashok Raj , X86 ML , LKML , Thomas Gleixner , Ingo Molnar , Tony Luck , Andi Kleen , Tom Lendacky , Arjan Van De Ven Subject: [v2 1/3] x86/microcode/intel: Check microcode revision before updating sibling threads Date: Wed, 21 Feb 2018 22:33:23 -0800 Message-Id: <1519281205-58951-2-git-send-email-ashok.raj@intel.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1519281205-58951-1-git-send-email-ashok.raj@intel.com> References: <1519281205-58951-1-git-send-email-ashok.raj@intel.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org After updating microcode on one of the threads in the core, the thread sibling automatically gets the update since the microcode resources are shared. Check the ucode revision on the CPU before performing a ucode update. Signed-off-by: Ashok Raj Cc: X86 ML Cc: LKML Cc: Thomas Gleixner Cc: Ingo Molnar Cc: Tony Luck Cc: Andi Kleen Cc: Boris Petkov Cc: Tom Lendacky Cc: Arjan Van De Ven Updates: v2: Address Boris's to cleanup apply_microcode_intel v3: Fixups per Ingo: Spell Checks --- arch/x86/kernel/cpu/microcode/intel.c | 28 +++++++++++++++++++++++++--- 1 file changed, 25 insertions(+), 3 deletions(-) diff --git a/arch/x86/kernel/cpu/microcode/intel.c b/arch/x86/kernel/cpu/microcode/intel.c index 09b95a7..137c9f5 100644 --- a/arch/x86/kernel/cpu/microcode/intel.c +++ b/arch/x86/kernel/cpu/microcode/intel.c @@ -589,6 +589,18 @@ static int apply_microcode_early(struct ucode_cpu_info *uci, bool early) if (!mc) return 0; + rev = intel_get_microcode_revision(); + + /* + * Its possible the microcode got updated + * because its sibling update was done earlier. + * Skip the update in that case. + */ + if (rev >= mc->hdr.rev) { + uci->cpu_sig.rev = rev; + return UCODE_OK; + } + /* write microcode via MSR 0x79 */ native_wrmsrl(MSR_IA32_UCODE_WRITE, (unsigned long)mc->bits); @@ -776,7 +788,7 @@ static enum ucode_state apply_microcode_intel(int cpu) { struct microcode_intel *mc; struct ucode_cpu_info *uci; - struct cpuinfo_x86 *c; + struct cpuinfo_x86 *c = &cpu_data(cpu); static int prev_rev; u32 rev; @@ -793,6 +805,18 @@ static enum ucode_state apply_microcode_intel(int cpu) return UCODE_NFOUND; } + rev = intel_get_microcode_revision(); + /* + * Its possible the microcode got updated + * because its sibling update was done earlier. + * Skip the update in that case. + */ + if (rev >= mc->hdr.rev) { + uci->cpu_sig.rev = rev; + c->microcode = rev; + return UCODE_OK; + } + /* write microcode via MSR 0x79 */ wrmsrl(MSR_IA32_UCODE_WRITE, (unsigned long)mc->bits); @@ -813,8 +837,6 @@ static enum ucode_state apply_microcode_intel(int cpu) prev_rev = rev; } - c = &cpu_data(cpu); - uci->cpu_sig.rev = rev; c->microcode = rev; -- 2.7.4