Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp1408074pxb; Fri, 21 Jan 2022 17:58:56 -0800 (PST) X-Google-Smtp-Source: ABdhPJwKpxUUMy9s56g7BHwujwhm/a6wwE3Rf6ld+5nmPIhCb5MagFvOOEF92NiIqCjBpJSRUIyy X-Received: by 2002:a17:902:bd05:b0:148:a2f7:9d87 with SMTP id p5-20020a170902bd0500b00148a2f79d87mr6077505pls.166.1642816736392; Fri, 21 Jan 2022 17:58:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642816736; cv=none; d=google.com; s=arc-20160816; b=HWC9NsJR3XWk7zG+aQF1W35vaDoMABUKjjUQYknvCiFf0XDABRgSzYwdpNZeHlcFhu OSCbW9EPS7xNEDB8Hl7PGKRsNY1Yg0tMNVCT3ftpSJypC0Z/6glq0FM8P6Wla5l8eslS q7fmmCowMedDeiFOZ1ceLAvfBwfyloz9c+czQp8ISDSVcSwUnKN7ngQXHaQ/v10gTeHo oM8ugmvQfYjMtWwMMWr/2HN8C9jKNmfG0M256xucgk3d/JI5mIMvEaKr39xfDbaIIWTa vBeTPobC2LAqiAAD5UukWo5z2dliT3nB4eaFScrJAps2fOxaRQNElAEk7IDNWJ3u3Lea zcXQ== 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; bh=U+Ao1Ny+asGkh/gUSZebqAT8SCOu6SI+vQSrvSJnPv8=; b=ebNgNmk4PHYR7J86+RUlv/r1+Fx1+dzcyc/uNjCMZl3BzAb4mVK4rQWi6pvVP8QG8M GVSYwyOHkPyMmvaJWAX0dY+xkEPViMTqGnVKr/znj4yuz04EtVF/1FaIwqdeRlhKJdMI fnivrSWP3DMLHXsRUsvADK0ITDvJpqpl/G4MlSRd954BN+W9TzGYyRnvYLUHYpciH1t6 3YJwuSqsI6hxiTllMXbUXVNVJtb+xQfnqxZqBZvRfo11dbdz/A3HgRvaGBcIMR87IthW HhhXAk3cTKc1WkVlY+IuhUSVbAZsR/Wyrlpq0peJwxtxvH6XaatgVUYwi1GRKZFE89DJ 273Q== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p1si13890150pjn.18.2022.01.21.17.58.44; Fri, 21 Jan 2022 17:58:56 -0800 (PST) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1349548AbiAUQh1 (ORCPT + 99 others); Fri, 21 Jan 2022 11:37:27 -0500 Received: from gloria.sntech.de ([185.11.138.130]:35292 "EHLO gloria.sntech.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1349364AbiAUQhF (ORCPT ); Fri, 21 Jan 2022 11:37:05 -0500 Received: from p508fcef5.dip0.t-ipconnect.de ([80.143.206.245] helo=phil.fritz.box) by gloria.sntech.de with esmtpsa (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1nAwuH-0008GA-PU; Fri, 21 Jan 2022 17:36:57 +0100 From: Heiko Stuebner To: palmer@dabbelt.com, paul.walmsley@sifive.com, aou@eecs.berkeley.edu Cc: linux-riscv@lists.infradead.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, robh+dt@kernel.org, wefu@redhat.com, liush@allwinnertech.com, guoren@kernel.org, atishp@atishpatra.org, anup@brainfault.org, drew@beagleboard.org, hch@lst.de, arnd@arndb.de, wens@csie.org, maxime@cerno.tech, dlustig@nvidia.com, gfavor@ventanamicro.com, andrea.mondelli@huawei.com, behrensj@mit.edu, xinhaoqu@huawei.com, huffman@cadence.com, mick@ics.forth.gr, allen.baum@esperantotech.com, jscheid@ventanamicro.com, rtrauben@gmail.com, samuel@sholland.org, cmuellner@linux.com, philipp.tomsich@vrull.eu, Heiko Stuebner Subject: [PATCH v5 03/14] riscv: allow different stages with alternatives Date: Fri, 21 Jan 2022 17:36:07 +0100 Message-Id: <20220121163618.351934-4-heiko@sntech.de> X-Mailer: git-send-email 2.30.2 In-Reply-To: <20220121163618.351934-1-heiko@sntech.de> References: <20220121163618.351934-1-heiko@sntech.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Future features may need to be applied at a different time during boot, so allow defining stages for alternatives and handling them differently depending on the stage. Also make the alternatives-location more flexible so that future stages may provide their own location. Signed-off-by: Heiko Stuebner --- arch/riscv/errata/sifive/errata.c | 3 ++- arch/riscv/include/asm/alternative.h | 5 ++++- arch/riscv/kernel/alternative.c | 25 +++++++++++++++++-------- 3 files changed, 23 insertions(+), 10 deletions(-) diff --git a/arch/riscv/errata/sifive/errata.c b/arch/riscv/errata/sifive/errata.c index f5e5ae70e829..4fe03ac41fd7 100644 --- a/arch/riscv/errata/sifive/errata.c +++ b/arch/riscv/errata/sifive/errata.c @@ -80,7 +80,8 @@ static void __init warn_miss_errata(u32 miss_errata) } void __init sifive_errata_patch_func(struct alt_entry *begin, struct alt_entry *end, - unsigned long archid, unsigned long impid) + unsigned long archid, unsigned long impid, + unsigned int stage) { struct alt_entry *alt; u32 cpu_req_errata = sifive_errata_probe(archid, impid); diff --git a/arch/riscv/include/asm/alternative.h b/arch/riscv/include/asm/alternative.h index e625d3cafbed..811bdd8027db 100644 --- a/arch/riscv/include/asm/alternative.h +++ b/arch/riscv/include/asm/alternative.h @@ -17,6 +17,8 @@ #include #include +#define RISCV_ALTERNATIVES_BOOT 0 /* alternatives applied during regular boot */ + void __init apply_boot_alternatives(void); struct alt_entry { @@ -33,7 +35,8 @@ struct errata_checkfunc_id { }; void sifive_errata_patch_func(struct alt_entry *begin, struct alt_entry *end, - unsigned long archid, unsigned long impid); + unsigned long archid, unsigned long impid, + unsigned int stage); #endif #endif diff --git a/arch/riscv/kernel/alternative.c b/arch/riscv/kernel/alternative.c index 3b15885db70b..ead00c508266 100644 --- a/arch/riscv/kernel/alternative.c +++ b/arch/riscv/kernel/alternative.c @@ -22,7 +22,8 @@ static struct cpu_manufacturer_info_t { } cpu_mfr_info; static void (*vendor_patch_func)(struct alt_entry *begin, struct alt_entry *end, - unsigned long archid, unsigned long impid); + unsigned long archid, unsigned long impid, + unsigned int stage); static inline void __init riscv_fill_cpu_mfr_info(void) { @@ -57,6 +58,18 @@ static void __init init_alternative(void) * a feature detect on the boot CPU). No need to worry about other CPUs * here. */ +static void __init _apply_alternatives(struct alt_entry *begin, + struct alt_entry *end, + unsigned int stage) +{ + if (!vendor_patch_func) + return; + + vendor_patch_func(begin, end, + cpu_mfr_info.arch_id, cpu_mfr_info.imp_id, + stage); +} + void __init apply_boot_alternatives(void) { /* If called on non-boot cpu things could go wrong */ @@ -64,11 +77,7 @@ void __init apply_boot_alternatives(void) init_alternative(); - if (!vendor_patch_func) - return; - - vendor_patch_func((struct alt_entry *)__alt_start, - (struct alt_entry *)__alt_end, - cpu_mfr_info.arch_id, cpu_mfr_info.imp_id); + _apply_alternatives((struct alt_entry *)__alt_start, + (struct alt_entry *)__alt_end, + RISCV_ALTERNATIVES_BOOT); } - -- 2.30.2