[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <a89f5970-5ea9-4d92-8952-6c26a22ac153@ghiti.fr>
Date: Tue, 24 Jun 2025 14:54:32 +0200
From: Alexandre Ghiti <alex@...ti.fr>
To: Changbin Du <changbin.du@...wei.com>,
Paul Walmsley <paul.walmsley@...ive.com>, Palmer Dabbelt
<palmer@...belt.com>, Albert Ou <aou@...s.berkeley.edu>
Cc: linux-riscv@...ts.infradead.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH] riscv: Prevent early kernel panic in instrumented
apply_early_boot_alternatives
Hi Changbin,
On 6/24/25 13:30, Changbin Du wrote:
> Under FTRACE=y, DYNAMIC_FTRACE=n, and RISCV_ALTERNATIVE_EARLY=n, the kernel
Your above config works fine for me, I guess you meant FUNCTION_TRACER
&& !DYNAMIC_FTRACE (which fails).
We were just talking with Andy about this configuration (FUNCTION_TRACER
&& !DYNAMIC_FTRACE): do we really want to support static ftrace? Andy
should send a patch soon to remove this possibility as IMO we don't want
to support it. Let's wait for this patch and the discussion that will
follow before merging your fix. I'll keep it in my list for 6.16 just in
case someone comes up with a good argument to keep it.
Thanks,
Alex
> panics upon returning from _mcount() in the early boot path. This occurs
> during _start_kernel() -> setup_vm() -> apply_early_boot_alternatives().
>
> The CC_FLAGS_FTRACE is only removed from alternative.c when
> CONFIG_RISCV_ALTERNATIVE_EARLY=y. Therefore, no function calls should be
> made to alternative.c during early boot in this configuration.
>
> Fixes: a35707c3d850 ("riscv: add memory-type errata for T-Head")
> Signed-off-by: Changbin Du <changbin.du@...wei.com>
> ---
> arch/riscv/include/asm/alternative.h | 6 ++++++
> arch/riscv/kernel/alternative.c | 4 ++--
> 2 files changed, 8 insertions(+), 2 deletions(-)
>
> diff --git a/arch/riscv/include/asm/alternative.h b/arch/riscv/include/asm/alternative.h
> index 3c2b59b25017..c670b0cc55f4 100644
> --- a/arch/riscv/include/asm/alternative.h
> +++ b/arch/riscv/include/asm/alternative.h
> @@ -31,7 +31,13 @@
> #define ALT_ALT_PTR(a) __ALT_PTR(a, alt_offset)
>
> void __init apply_boot_alternatives(void);
> +
> +# ifdef CONFIG_RISCV_ALTERNATIVE_EARLY
> void __init apply_early_boot_alternatives(void);
> +# else
> +static inline void apply_early_boot_alternatives(void) { }
> +# endif
> +
> void apply_module_alternatives(void *start, size_t length);
>
> void riscv_alternative_fix_offsets(void *alt_ptr, unsigned int len,
> diff --git a/arch/riscv/kernel/alternative.c b/arch/riscv/kernel/alternative.c
> index 7eb3cb1215c6..5406c3301627 100644
> --- a/arch/riscv/kernel/alternative.c
> +++ b/arch/riscv/kernel/alternative.c
> @@ -205,6 +205,7 @@ void __init apply_boot_alternatives(void)
> apply_vdso_alternatives();
> }
>
> +#ifdef CONFIG_RISCV_ALTERNATIVE_EARLY
> /*
> * apply_early_boot_alternatives() is called from setup_vm() with MMU-off.
> *
> @@ -219,12 +220,11 @@ void __init apply_boot_alternatives(void)
> */
> void __init apply_early_boot_alternatives(void)
> {
> -#ifdef CONFIG_RISCV_ALTERNATIVE_EARLY
> _apply_alternatives((struct alt_entry *)__alt_start,
> (struct alt_entry *)__alt_end,
> RISCV_ALTERNATIVES_EARLY_BOOT);
> -#endif
> }
> +#endif
>
> #ifdef CONFIG_MODULES
> void apply_module_alternatives(void *start, size_t length)
Powered by blists - more mailing lists