[PATCH 15/17] efi_loader: Remove ENTRY(_start) from linker script
Heinrich Schuchardt
xypron.glpk at gmx.de
Mon Feb 24 10:36:50 CET 2025
On 2/24/25 06:55, Sam Edwards wrote:
> The EFI apps are built using ELF only as an intermediate "linker output"
> format, with the final PE header crafted within the ELF to take effect
> after the objcopy conversion to raw binary. As such, we really don't
> care what the ELF header indicates as the entry point.
>
> Because nothing that uses this linker script even defines a _start
> symbol, this directive has no effect. On GNU ld, it is silently ignored.
> On certain linkers (e.g. LLVM lld), a warning is logged. But in any
> case, no entry point is set.
I can understand the first part of your reasoning. But the statement
about _start is wrong. _start is defined on all EFI architectures, e.g.
arch/arm/lib/crt0_aarch64_efi.S:147:
_start
arch/riscv/lib/crt0_riscv_efi.S:182:
_start:
Why does lld complain? Is it because we lack
.globl _start
on ARM and RISC-V?
Best regards
Heinrich
>
> Therefore, remove it to silence warnings and avoid confusion.
>
> Signed-off-by: Sam Edwards <CFSworks at gmail.com>
> ---
> lib/efi_loader/elf_efi.ldsi | 1 -
> 1 file changed, 1 deletion(-)
>
> diff --git a/lib/efi_loader/elf_efi.ldsi b/lib/efi_loader/elf_efi.ldsi
> index 190a88fb69e..dc4d1a3660e 100644
> --- a/lib/efi_loader/elf_efi.ldsi
> +++ b/lib/efi_loader/elf_efi.ldsi
> @@ -10,7 +10,6 @@ PHDRS
> data PT_LOAD FLAGS(3); /* SHF_WRITE | SHF_ALLOC */
> }
>
> -ENTRY(_start)
> SECTIONS
> {
> .text 0x0 : {
More information about the U-Boot
mailing list