Received: by 2002:a05:6358:a55:b0:ec:fcf4:3ecf with SMTP id 21csp2067887rwb; Sun, 15 Jan 2023 08:41:14 -0800 (PST) X-Google-Smtp-Source: AMrXdXvl5qi8VxR6DeTAfbNlnBCUIuB9ZtZ4tPfnpcHL5k3EsaRRorUK6kkaYxt9t+NXrKNSZpu2 X-Received: by 2002:aa7:c398:0:b0:49d:a87f:ba70 with SMTP id k24-20020aa7c398000000b0049da87fba70mr5923654edq.38.1673800874606; Sun, 15 Jan 2023 08:41:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1673800874; cv=none; d=google.com; s=arc-20160816; b=Rm8kjwQmfmG/QpKAvU1pxeyecUrKCfyUshlxxj2h7oyuiZlmI1Vb05vciRMRNkjqC2 HrgMJ35F4HYZ58pG5td6KHLaXewiuWE8RXc/0OZEDY4pTYWRFhg4Kl6qQ6IlAwVeWAhg Ef56MiSB0Z1Fh5Ra0iCEo7xYKKKCT7vZGFiPvh54Sx5BT3iSdxQGyX8aiDXmfrmmRghl TK9DtMEat11zBvt8xnhX4Suvep7+xgmE72bx/2tqJWDVvnBcfIsawSeFWicrxjmEcTwQ WOu2I24mD8ActGIXKh9XBXHEyXkiydHfNbR6ah4YwwzV1dwawASbxrBmpZFmZM6n4np0 oMvg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=pElJTxX0bmKX/B8qMzoo2Bh8gUb/WJEbPgV8izl5XDU=; b=DAo/Rju9756E5rjsKdxAJoHgcdFlWTF+sqiYW7Sh0rl4LFaQ0TcVJssYTxYKnsQjpU vyXN0row4PTBqyPNuwula1eZHCZ0e+PzszO+wMUt7e+y1pCd3Ua5Oqpe3gCqn3HiAXaQ EIsVD5vINdJOEapn6ReH6CGINFHHyCiNWMAzeBq2tGj0/7nOqSd8U038IS07P7T9wqc4 Hc12/D7qLOB1den4iGaze4r5X/n9Q8LdR9IgVz16dSP71Co0Isr33U2C+8NXa7QGU+BB 6U0Ko1+W3LoL7jMZjz5/+0kVANGzXxohO7A8SNtdvro+vLsL7khXWDUQrO6c6g6aketX COUA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="IyaKhZ/O"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i10-20020a05640242ca00b0049e160ce989si1406201edc.306.2023.01.15.08.41.02; Sun, 15 Jan 2023 08:41:14 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="IyaKhZ/O"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231587AbjAOQBD (ORCPT + 52 others); Sun, 15 Jan 2023 11:01:03 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59870 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231539AbjAOQAt (ORCPT ); Sun, 15 Jan 2023 11:00:49 -0500 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7DEDD10426; Sun, 15 Jan 2023 08:00:30 -0800 (PST) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 2252FB80B57; Sun, 15 Jan 2023 16:00:29 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id D3D2FC4339B; Sun, 15 Jan 2023 16:00:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1673798427; bh=EUOTCCvK3BHS1pXfvH2BWP1K07d19xWmUCZHwihqXEQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=IyaKhZ/O6P3f7A84a7Mw65DbbtwySU8FHZUpDYH5rMVUn5TACJ0lE35OOY2tMrSCt lJp6+2oW4CX+R33fdtERPdljP4YWsgHv19MdNMi5SiHbKNVMQ3wyE+5X2/pHjVE0l+ hoV6VU4BGHlE+mYgCtrkDmAL+LkeXLtTIjQbYDyi4356m1BDtAvaU208rp/pC9QD9n 1Jr1e01kNzsfv+t92drf0Sc6Pw0MrtdEkw2AYvGVpQQ95eVR23t3GLmM8n/diSvSAK 4XtxUhihzUefRaNaGGnDWnr2vX6GvQkVmgGIEn/83x6uni6DB47U0FJK6U2nSLQFr4 vCqqiPbQzaVCg== From: Jisheng Zhang To: Paul Walmsley , Palmer Dabbelt , Albert Ou , Anup Patel , Atish Patra , Heiko Stuebner , Conor Dooley , Andrew Jones Cc: linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, kvm@vger.kernel.org, kvm-riscv@lists.infradead.org Subject: [PATCH v4 05/13] riscv: cpufeature: extend riscv_cpufeature_patch_func to all ISA extensions Date: Sun, 15 Jan 2023 23:49:45 +0800 Message-Id: <20230115154953.831-6-jszhang@kernel.org> X-Mailer: git-send-email 2.38.1 In-Reply-To: <20230115154953.831-1-jszhang@kernel.org> References: <20230115154953.831-1-jszhang@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org riscv_cpufeature_patch_func() currently only scans a limited set of cpufeatures, explicitly defined with macros. Extend it to probe for all ISA extensions. Signed-off-by: Jisheng Zhang Reviewed-by: Andrew Jones --- arch/riscv/include/asm/errata_list.h | 9 ++-- arch/riscv/kernel/cpufeature.c | 63 ++++------------------------ 2 files changed, 11 insertions(+), 61 deletions(-) diff --git a/arch/riscv/include/asm/errata_list.h b/arch/riscv/include/asm/errata_list.h index 4180312d2a70..274c6f889602 100644 --- a/arch/riscv/include/asm/errata_list.h +++ b/arch/riscv/include/asm/errata_list.h @@ -7,6 +7,7 @@ #include #include +#include #include #ifdef CONFIG_ERRATA_SIFIVE @@ -22,10 +23,6 @@ #define ERRATA_THEAD_NUMBER 3 #endif -#define CPUFEATURE_SVPBMT 0 -#define CPUFEATURE_ZICBOM 1 -#define CPUFEATURE_NUMBER 2 - #ifdef __ASSEMBLY__ #define ALT_INSN_FAULT(x) \ @@ -55,7 +52,7 @@ asm(ALTERNATIVE("sfence.vma %0", "sfence.vma", SIFIVE_VENDOR_ID, \ #define ALT_SVPBMT(_val, prot) \ asm(ALTERNATIVE_2("li %0, 0\t\nnop", \ "li %0, %1\t\nslli %0,%0,%3", 0, \ - CPUFEATURE_SVPBMT, CONFIG_RISCV_ISA_SVPBMT, \ + RISCV_ISA_EXT_SVPBMT, CONFIG_RISCV_ISA_SVPBMT, \ "li %0, %2\t\nslli %0,%0,%4", THEAD_VENDOR_ID, \ ERRATA_THEAD_PBMT, CONFIG_ERRATA_THEAD_PBMT) \ : "=r"(_val) \ @@ -129,7 +126,7 @@ asm volatile(ALTERNATIVE_2( \ "add a0, a0, %0\n\t" \ "2:\n\t" \ "bltu a0, %2, 3b\n\t" \ - "nop", 0, CPUFEATURE_ZICBOM, CONFIG_RISCV_ISA_ZICBOM, \ + "nop", 0, RISCV_ISA_EXT_ZICBOM, CONFIG_RISCV_ISA_ZICBOM, \ "mv a0, %1\n\t" \ "j 2f\n\t" \ "3:\n\t" \ diff --git a/arch/riscv/kernel/cpufeature.c b/arch/riscv/kernel/cpufeature.c index 37e8c5e69754..6db8b31d9149 100644 --- a/arch/riscv/kernel/cpufeature.c +++ b/arch/riscv/kernel/cpufeature.c @@ -275,58 +275,11 @@ void __init riscv_fill_hwcap(void) } #ifdef CONFIG_RISCV_ALTERNATIVE -static bool __init_or_module cpufeature_probe_svpbmt(unsigned int stage) -{ - if (!IS_ENABLED(CONFIG_RISCV_ISA_SVPBMT)) - return false; - - if (stage == RISCV_ALTERNATIVES_EARLY_BOOT) - return false; - - return riscv_isa_extension_available(NULL, SVPBMT); -} - -static bool __init_or_module cpufeature_probe_zicbom(unsigned int stage) -{ - if (!IS_ENABLED(CONFIG_RISCV_ISA_ZICBOM)) - return false; - - if (stage == RISCV_ALTERNATIVES_EARLY_BOOT) - return false; - - if (!riscv_isa_extension_available(NULL, ZICBOM)) - return false; - - return true; -} - -/* - * Probe presence of individual extensions. - * - * This code may also be executed before kernel relocation, so we cannot use - * addresses generated by the address-of operator as they won't be valid in - * this context. - */ -static u32 __init_or_module cpufeature_probe(unsigned int stage) -{ - u32 cpu_req_feature = 0; - - if (cpufeature_probe_svpbmt(stage)) - cpu_req_feature |= BIT(CPUFEATURE_SVPBMT); - - if (cpufeature_probe_zicbom(stage)) - cpu_req_feature |= BIT(CPUFEATURE_ZICBOM); - - return cpu_req_feature; -} - void __init_or_module riscv_cpufeature_patch_func(struct alt_entry *begin, struct alt_entry *end, unsigned int stage) { - u32 cpu_req_feature = cpufeature_probe(stage); struct alt_entry *alt; - u32 tmp; if (stage == RISCV_ALTERNATIVES_EARLY_BOOT) return; @@ -334,18 +287,18 @@ void __init_or_module riscv_cpufeature_patch_func(struct alt_entry *begin, for (alt = begin; alt < end; alt++) { if (alt->vendor_id != 0) continue; - if (alt->errata_id >= CPUFEATURE_NUMBER) { - WARN(1, "This feature id:%d is not in kernel cpufeature list", + if (alt->errata_id >= RISCV_ISA_EXT_MAX) { + WARN(1, "This extension id:%d is not in ISA extension list", alt->errata_id); continue; } - tmp = (1U << alt->errata_id); - if (cpu_req_feature & tmp) { - patch_text_nosync(alt->old_ptr, alt->alt_ptr, alt->alt_len); - riscv_alternative_fix_offsets(alt->old_ptr, alt->alt_len, - alt->old_ptr - alt->alt_ptr); - } + if (!__riscv_isa_extension_available(NULL, alt->errata_id)) + continue; + + patch_text_nosync(alt->old_ptr, alt->alt_ptr, alt->alt_len); + riscv_alternative_fix_offsets(alt->old_ptr, alt->alt_len, + alt->old_ptr - alt->alt_ptr); } } #endif -- 2.38.1