Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp4390734ybz; Mon, 20 Apr 2020 22:57:26 -0700 (PDT) X-Google-Smtp-Source: APiQypK0/HEQW7wtdLOKn+08E1HwTbTjCKcq2BsuQE/eWBKaJPdzOopQPy9QESnlBJxLRxakWjjy X-Received: by 2002:a05:6402:1651:: with SMTP id s17mr4792480edx.173.1587448646737; Mon, 20 Apr 2020 22:57:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587448646; cv=none; d=google.com; s=arc-20160816; b=SysdmK5xOOM7Av+UBKsC3lPs/8Kgj3Ft6jnagHl4rhP3HDk40pI6E39/zdmOhLzgfL 8BF+UpWCxQWGuhcYo46zmCWVf6tVAgNGjbQSqoryoLKS6DWxKfc8y3YW0zhbKayHb2NV X9h4Cr65VIRjIIU7QkpK9W7XPFuSnHOfkPm1PsJfGFcNg1vK6OlK50TCcAV+8KzawMlQ lguu7dlMm5grVaYrG2m7dtzMLRCsFNMVW36jjabfbmGoakeSC9lGwU0pGB3EHYLgAZ+b LL9XcItWJUzCaVl+Zrf7aFlgd3hrUQhgYdEIE0YEhKeUAp06cvZ7SjKZffIaLEb4u4bR rFMw== 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:dkim-signature; bh=Z5Z8TxDpfpq46U3YN9YJd2JyxrStWGfHfkoRCinx7nc=; b=TvzqiKKEi/5sj4qE//3FMI9JO8wmlOLEPjfFhyBS6rnAm2x8wARJSTDA4E9szX6rm4 gwr40+HRLvF1+dteG1zeqThrFTbvHVmQjdvchKO8fcTh0xtHvi9fsCCHjhNXZXdk8TnA 0ts/FiwYBxHgFuDT+dg239OSMHiW5IunvJ4Bp6WVMm8FACCtJLb486DQabvTWN9w0ud4 ADA22dTo2EWEGb+C15cK0UnqibaKDNzGcZLaC/r9Jx0cl6MlNggnWAvCll3i+EgkHd2g KuP/10Gt/NxtOn53mzKR6bo4M0s1oRloXVRCsiQh0r1fD17CUcW8OSVmlwuNoBtz+G9l YDoA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=E+z3Lwkp; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t12si974984ejb.508.2020.04.20.22.57.03; Mon, 20 Apr 2020 22:57:26 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=E+z3Lwkp; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726364AbgDUFxy (ORCPT + 99 others); Tue, 21 Apr 2020 01:53:54 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53644 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1725881AbgDUFxy (ORCPT ); Tue, 21 Apr 2020 01:53:54 -0400 Received: from mail-lj1-x241.google.com (mail-lj1-x241.google.com [IPv6:2a00:1450:4864:20::241]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6CBADC061A0F for ; Mon, 20 Apr 2020 22:53:52 -0700 (PDT) Received: by mail-lj1-x241.google.com with SMTP id b2so7178557ljp.4 for ; Mon, 20 Apr 2020 22:53:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=Z5Z8TxDpfpq46U3YN9YJd2JyxrStWGfHfkoRCinx7nc=; b=E+z3Lwkp7GrGVa6EW6FWpo7WynP0tYQAvY5UQdBxXFLEqa5ntyGpEaYZzgq+4yIxWq psdcM+Ni5aNXdBGiZPYXCDv4ky9kexaKWXYZ6pDm4uu5Dymt7mcxHIBKh15FdZ6NwDvt VNf8x1Pf03iAbqfHmfl4Ws3n7v7AYW2XcUJXO9GZcf4vsdPRvvvgaf1m0OIXBGZsclrD Q0CNbMKqALCXutX6nt7Vjcx3EuO7HUtayChRu8C/bpJ1OhsMswPme8t4Gum/6cCy3GvD FzKyVn9XGXVU3w5l7Hm5vcZdXH2w2Uy3tpkCtM/BYF29e70MB05RUZcHINlURUUUj2Vp +2AA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=Z5Z8TxDpfpq46U3YN9YJd2JyxrStWGfHfkoRCinx7nc=; b=pgyOJD8yhIF56lGqxdN2R2SuEsUXFtWkjVzHXPTLEWV2xqf0dwJ99OSEh/NonXrg7R BvLbs0I0PGQCgNFSYnqDUq6eqjiqYnBDh7xZT+C0alisymjgryJ8hx5wtP4j/p+/7cWr Jz8MMXE8Zb8JdU5Exw9u161zs87d0MeLAyhk4X/GZqE1fTJ7KjPfotF4if+yjDxfqyhk uyracmYLq9+ir5/Ko3dIGOdw0yxozifz9FRHoVnVNnuj5EwgCrQyJd5MCZoKpr4y1/ux 9vn50BDXAY2JX7QNvdpwYUS9zdGF0sDpbTcVkOZDB5IKv3yxH+AUjPtUBDqplrNjhZ7N XIcQ== X-Gm-Message-State: AGi0PuYolr4C+qx6U/9LvSmwgQFEHUcIKiFmhiR19h4kz6P3TLMOYUt/ 0r2NZXjNpGa2opDB0hGwkcIalBV7TkA= X-Received: by 2002:a2e:a548:: with SMTP id e8mr12307260ljn.151.1587448430689; Mon, 20 Apr 2020 22:53:50 -0700 (PDT) Received: from test.lan ([91.105.39.216]) by smtp.gmail.com with ESMTPSA id o17sm1177930lff.70.2020.04.20.22.53.49 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Mon, 20 Apr 2020 22:53:50 -0700 (PDT) From: Evalds Iodzevics To: linux-kernel@vger.kernel.org Cc: gregkh@linuxfoundation.org, tglx@linutronix.de, ben@decadent.org.uk, Evalds Iodzevics Subject: [PATCH v2] x86/microcode/intel: replace sync_core() with native_cpuid_reg(eax) Date: Tue, 21 Apr 2020 11:53:44 +0300 Message-Id: <20200421085344.1804-1-evalds.iodzevics@gmail.com> X-Mailer: git-send-email 2.17.4 In-Reply-To: <20200420120037.1537-1-evalds.iodzevics@gmail.com> References: <20200420120037.1537-1-evalds.iodzevics@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Intel it is required to do CPUID(1) before reading the microcode revision MSR. Current code in 4.4 an 4.9 relies on sync_core() to call CPUID, unfortunately on 32 bit machines code inside sync_core() always jumps past CPUID instruction as it depends on data structure boot_cpu_data witch are not populated correctly so early in boot sequence. It depends on: commit 5dedade6dfa2 ("x86/CPU: Add native CPUID variants returning a single datum") This patch is for 4.4 but also should apply to 4.9 Signed-off-by: Evalds Iodzevics --- arch/x86/include/asm/microcode_intel.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arch/x86/include/asm/microcode_intel.h b/arch/x86/include/asm/microcode_intel.h index 90343ba50485..92ce9c8a508b 100644 --- a/arch/x86/include/asm/microcode_intel.h +++ b/arch/x86/include/asm/microcode_intel.h @@ -60,7 +60,7 @@ static inline u32 intel_get_microcode_revision(void) native_wrmsrl(MSR_IA32_UCODE_REV, 0); /* As documented in the SDM: Do a CPUID 1 here */ - sync_core(); + native_cpuid_eax(1); /* get the current revision from MSR 0x8B */ native_rdmsr(MSR_IA32_UCODE_REV, dummy, rev); -- 2.17.4