Received: by 10.223.185.116 with SMTP id b49csp6016622wrg; Wed, 28 Feb 2018 02:32:06 -0800 (PST) X-Google-Smtp-Source: AH8x227+Nqsr7sujgQTj6yTKJXZG5VIh5C/87cw93rDVdJFMnyGv9jZzoRV/BZQJKppitYgeVsT5 X-Received: by 10.99.144.74 with SMTP id a71mr13681654pge.244.1519813926687; Wed, 28 Feb 2018 02:32:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519813926; cv=none; d=google.com; s=arc-20160816; b=vQFncc8EpldeWeTqvEX9FMj/nsVqM4iQDV98TAPxKBFokAqXfhHjZOQLfQ/Hu1G2aT xgo7zvJ59Bj6vKTVzt9tYJ9uMC1giVQ8PZ77X9yExhMBCV5ZmRwW6gtuMSiFXv9aOubj squQX3W0XmNoDfQMnouRx811IHPLtTHrEDdJRH8sX2gWTczZAVbvtSriaGTUJl2gsJof kozJ1exKLEhDfKRCtcq65OAmbsAyQJ6cl89eOJ0/TYyWyC1P+1nkrilymtT4sIRSEn0K SGhGaFtx9CkNaoLSmeggLyGhNnCMG1oiNvhN91kTFQ7vZNmFpGBeogt8vpD8sK9DcBU1 seww== 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=D+LDBE1qF5bj0GcLmE63m8cJiEoR9bWLR/X/7uzJ3VI=; b=h8jx2gkJI+AokKH9VkuOPEhL1GMUbvObbRoXG4qBL0p19HIhijJIRZbXdeQetS9tNL f0ugpJI+Af9kD2ZG39QHHX0uu3bKvnIN5yjriSlr540rwfE8D4ab12XPEwJ2sX+oBrKA lxI8FEqj9861BFm8OWHqsi5tiGnN8OqKoZL77X3dEQcIzboLRsNFReV5RW47ICSITd85 MiEK+ZonoLgDBlW38omLg6OmLLAYo6Y8YiF9gItba9F9SgM0TDETz2ebX3S0KpqqQYqT TEdktQNZ1OduDt/aiAhGStkV77T0I6N/Yf5rE8eOggOGIzGPPoj8WYX/lPutvpUOTDiB hKnQ== 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 33-v6si1056227plk.576.2018.02.28.02.31.51; Wed, 28 Feb 2018 02:32:06 -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 S1752601AbeB1KaX (ORCPT + 99 others); Wed, 28 Feb 2018 05:30:23 -0500 Received: from mail.skyhub.de ([5.9.137.197]:37172 "EHLO mail.skyhub.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752500AbeB1K3T (ORCPT ); Wed, 28 Feb 2018 05:29:19 -0500 X-Virus-Scanned: Nedap ESD1 at mail.skyhub.de Received: from mail.skyhub.de ([127.0.0.1]) by localhost (blast.alien8.de [127.0.0.1]) (amavisd-new, port 10026) with ESMTP id qjm8ln45HMZP; Wed, 28 Feb 2018 11:29:18 +0100 (CET) Received: from pd.tnic (p200300EC2BCC7700C0F39F3CF1943F44.dip0.t-ipconnect.de [IPv6:2003:ec:2bcc:7700:c0f3:9f3c:f194:3f44]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.skyhub.de (SuperMail on ZX Spectrum 128k) with ESMTPSA id 433571EC0646; Wed, 28 Feb 2018 11:29:18 +0100 (CET) From: Borislav Petkov To: X86 ML Cc: Arjan Van De Ven , Ashok Raj , Tom Lendacky , LKML Subject: [PATCH 6/7] x86/microcode: Request microcode on the BSP Date: Wed, 28 Feb 2018 11:28:45 +0100 Message-Id: <20180228102846.13447-7-bp@alien8.de> X-Mailer: git-send-email 2.13.0 In-Reply-To: <20180228102846.13447-1-bp@alien8.de> References: <20180228102846.13447-1-bp@alien8.de> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Borislav Petkov ... so that any newer version can land in the cache and can later be fished out by the application functions. Do that before grabbing the hotplug lock. Signed-off-by: Borislav Petkov --- arch/x86/kernel/cpu/microcode/core.c | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/arch/x86/kernel/cpu/microcode/core.c b/arch/x86/kernel/cpu/microcode/core.c index fa32cb3dcca5..5dd157d48606 100644 --- a/arch/x86/kernel/cpu/microcode/core.c +++ b/arch/x86/kernel/cpu/microcode/core.c @@ -499,15 +499,10 @@ static int check_online_cpus(void) static enum ucode_state reload_for_cpu(int cpu) { struct ucode_cpu_info *uci = ucode_cpu_info + cpu; - enum ucode_state ustate; if (!uci->valid) return UCODE_OK; - ustate = microcode_ops->request_microcode_fw(cpu, µcode_pdev->dev, true); - if (ustate != UCODE_OK) - return ustate; - return apply_microcode_on_target(cpu); } @@ -515,11 +510,11 @@ static ssize_t reload_store(struct device *dev, struct device_attribute *attr, const char *buf, size_t size) { + int cpu, bsp = boot_cpu_data.cpu_index; enum ucode_state tmp_ret = UCODE_OK; bool do_callback = false; unsigned long val; ssize_t ret = 0; - int cpu; ret = kstrtoul(buf, 0, &val); if (ret) @@ -528,6 +523,10 @@ static ssize_t reload_store(struct device *dev, if (val != 1) return size; + tmp_ret = microcode_ops->request_microcode_fw(bsp, µcode_pdev->dev, true); + if (tmp_ret != UCODE_OK) + return size; + get_online_cpus(); ret = check_online_cpus(); -- 2.13.0