[PATCH v2 11/15] arm: riscv: efi: Export _start symbol from crt0_*_efi stubs
Heinrich Schuchardt
xypron.glpk at gmx.de
Mon Mar 17 09:43:35 CET 2025
On 3/15/25 23:18, Sam Edwards wrote:
> While the _start label is only intended for use locally to populate the
> (hand-written) PE header, the linker script includes ENTRY(_start) which
> designates it as the entry point in the output ELF, resulting in linker
> warnings under some linkers (e.g. LLVM's lld) due to _start not being a
> globally-visible symbol. Since ELF is only an intermediary build
> format, and the aforementioned PE header correctly points to _start, the
> ENTRY(_start) directive could easily be removed to silence this warning.
>
> However, since some developers who are debugging EFI by analyzing the
> intermediary ELF may appreciate having correct entry-point information,
> this patch instead promotes the _start labels to global symbols,
> silencing the linker warning and making the intermediary ELF reflect the
> true entry point.
>
> This patch doesn't affect the final output binaries in any way.
>
> Signed-off-by: Sam Edwards <CFSworks at gmail.com>
Reviewed-by: Heinrich Schuchardt <xypron.glpk at gmx.de>
> ---
> arch/arm/lib/crt0_aarch64_efi.S | 1 +
> arch/arm/lib/crt0_arm_efi.S | 1 +
> arch/riscv/lib/crt0_riscv_efi.S | 1 +
> 3 files changed, 3 insertions(+)
>
> diff --git a/arch/arm/lib/crt0_aarch64_efi.S b/arch/arm/lib/crt0_aarch64_efi.S
> index e21b54fdbcb..003d5f83041 100644
> --- a/arch/arm/lib/crt0_aarch64_efi.S
> +++ b/arch/arm/lib/crt0_aarch64_efi.S
> @@ -144,6 +144,7 @@ section_table:
> IMAGE_SCN_CNT_INITIALIZED_DATA)
>
> .align 12
> + .globl _start
> _start:
> stp x29, x30, [sp, #-32]!
> mov x29, sp
> diff --git a/arch/arm/lib/crt0_arm_efi.S b/arch/arm/lib/crt0_arm_efi.S
> index 235b3a0c48f..593ee1e194a 100644
> --- a/arch/arm/lib/crt0_arm_efi.S
> +++ b/arch/arm/lib/crt0_arm_efi.S
> @@ -143,6 +143,7 @@ section_table:
> IMAGE_SCN_CNT_INITIALIZED_DATA)
>
> .align 12
> + .globl _start
> _start:
> stmfd sp!, {r0-r2, lr}
>
> diff --git a/arch/riscv/lib/crt0_riscv_efi.S b/arch/riscv/lib/crt0_riscv_efi.S
> index 9eacbe4a859..f170e4b26d6 100644
> --- a/arch/riscv/lib/crt0_riscv_efi.S
> +++ b/arch/riscv/lib/crt0_riscv_efi.S
> @@ -179,6 +179,7 @@ section_table:
> IMAGE_SCN_CNT_INITIALIZED_DATA)
>
> .align 12
> + .globl _start
> _start:
> addi sp, sp, -(SIZE_LONG * 3)
> SAVE_LONG(a0, 0)
More information about the U-Boot
mailing list