lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<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

Powered by Openwall GNU/*/Linux Powered by OpenVZ