[PATCH] RISC-V: errata: Use medany for relocatable builds
Alexandre Ghiti
alex at ghiti.fr
Fri Mar 28 01:18:01 PDT 2025
On 26/03/2025 23:45, Palmer Dabbelt wrote:
> We're trying to mix non-PIC/PIE objects into the otherwise-PIE
> relocatable kernels, to avoid GOT/PLT references during early boot
> alternative resolution (which happens before the GOT/PLT are set up).
>
> riscv64-unknown-linux-gnu-ld: arch/riscv/errata/sifive/errata.o: relocation R_RISCV_HI20 against `tlb_flush_all_threshold' can not be used when making a shared object; recompile with -fPIC
> riscv64-unknown-linux-gnu-ld: arch/riscv/errata/thead/errata.o: relocation R_RISCV_HI20 against `riscv_cbom_block_size' can not be used when making a shared object; recompile with -fPIC
thead erratas are already compiled with medany if
CONFIG_RISCV_ALTERNATIVE_EARLY is set
(https://elixir.bootlin.com/linux/v6.14-rc6/source/arch/riscv/errata/thead/Makefile#L2)
so why isn't it enough?
>
> Fixes: 8dc2a7e8027f ("riscv: Fix relocatable kernels with early alternatives using -fno-pie")
> Signed-off-by: Palmer Dabbelt <palmer at rivosinc.com>
> ---
> I'm not 100% sure it's possible to expose this without Samuel's NOMMU
> relocatable builds, see
> <https://lore.kernel.org/all/mhng-517c0318-c8fb-4c4a-aa0e-0d08f8d34d78@palmer-ri-x1c9/>
> ---
> arch/riscv/errata/Makefile | 6 +++++-
> 1 file changed, 5 insertions(+), 1 deletion(-)
>
> diff --git a/arch/riscv/errata/Makefile b/arch/riscv/errata/Makefile
> index f0da9d7b39c3..bc6c77ba837d 100644
> --- a/arch/riscv/errata/Makefile
> +++ b/arch/riscv/errata/Makefile
> @@ -1,5 +1,9 @@
> ifdef CONFIG_RELOCATABLE
> -KBUILD_CFLAGS += -fno-pie
> +# We can't use PIC/PIE when handling early-boot errata parsing, as the kernel
> +# doesn't have a GOT setup at that point. So instead just use medany: it's
> +# usually position-independent, so it should be good enough for the errata
> +# handling.
> +KBUILD_CFLAGS += -fno-pie -mcmodel=medany
> endif
>
> ifdef CONFIG_RISCV_ALTERNATIVE_EARLY
More information about the linux-riscv
mailing list