[PATCH v1 3/6] arm: Prepare linker scripts for memory permissions

Ilias Apalodimas ilias.apalodimas at linaro.org
Wed Feb 5 09:22:08 CET 2025


I'm just replying to myself here but I'll send a v2 when the patches
are reviewed.

I can add the linker under an ifdef, so u-boot size won't change
unless a Kconfig options is selected

/Ilias

On Wed, 5 Feb 2025 at 09:17, Ilias Apalodimas
<ilias.apalodimas at linaro.org> wrote:
>
> Upcoming patches are switching the memory mappings to RW, RO, RX
> after the U-Boot binary and its data are relocated. Add
> annotations in the linker scripts to and mark text, data, rodata
> sections and align them to a page boundary.
>
> It's worth noting that efi_runtime relocations are left untouched for
> now. The efi runtime regions can be relocated by the OS when the latter
> is calling SetVirtualAddressMap. Which means we have to configure the
> pages as RX for U-Boot but convert them to RWX just before
> ExitBootServices. It also needs extra code in efi_tuntime relocation
> code since R_AARCH64_NONE are emitted as well if we page align the
> section. Keep it out for now and we can fix it in future patches.
>
> Acked-by: Jerome Forissier <jerome.forissier at linaro.org>
> Signed-off-by: Ilias Apalodimas <ilias.apalodimas at linaro.org>
> ---
>  arch/arm/cpu/armv8/u-boot.lds  | 29 +++++++++++++++++------------
>  include/asm-generic/sections.h |  2 ++
>  2 files changed, 19 insertions(+), 12 deletions(-)
>
> diff --git a/arch/arm/cpu/armv8/u-boot.lds b/arch/arm/cpu/armv8/u-boot.lds
> index 857f44412e07..35afc3cbe7ec 100644
> --- a/arch/arm/cpu/armv8/u-boot.lds
> +++ b/arch/arm/cpu/armv8/u-boot.lds
> @@ -22,7 +22,7 @@ SECTIONS
>
>         . = ALIGN(8);
>         __image_copy_start = ADDR(.text);
> -       .text :
> +       .text ALIGN(4096):
>         {
>                 CPUDIR/start.o (.text*)
>         }
> @@ -36,9 +36,12 @@ SECTIONS
>                  __efi_runtime_stop = .;
>         }
>
> -       .text_rest :
> +       .text_rest ALIGN(4096) :
>         {
> +               __text_start = .;
>                 *(.text*)
> +               . = ALIGN(4096);
> +               __text_end = .;
>         }
>
>  #ifdef CONFIG_ARMV8_PSCI
> @@ -98,18 +101,20 @@ SECTIONS
>         }
>  #endif
>
> -       . = ALIGN(8);
> -       .rodata : { *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*))) }
> +       .rodata ALIGN(4096): {
> +           __start_rodata = .;
> +           *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*)))
> +           . = ALIGN(4096);
> +           __end_rodata = .;
> +       }
>
> -       . = ALIGN(8);
> -       .data : {
> +       .data ALIGN(4096) : {
> +           __start_data = .;
>                 *(.data*)
> +           . = ALIGN(4096);
> +           __end_data = .;
>         }
>
> -       . = ALIGN(8);
> -
> -       . = .;
> -
>         . = ALIGN(8);
>         __u_boot_list : {
>                 KEEP(*(SORT(__u_boot_list*)));
> @@ -136,10 +141,10 @@ SECTIONS
>         /*
>          * arch/arm/lib/crt0_64.S assumes __bss_start - __bss_end % 8 == 0
>          */
> -       .bss ALIGN(8) : {
> +       .bss ALIGN(4096) : {
>                 __bss_start = .;
>                 *(.bss*)
> -               . = ALIGN(8);
> +               . = ALIGN(4096);
>                 __bss_end = .;
>         }
>
> diff --git a/include/asm-generic/sections.h b/include/asm-generic/sections.h
> index 3fd5c772a1af..024b1adde270 100644
> --- a/include/asm-generic/sections.h
> +++ b/include/asm-generic/sections.h
> @@ -23,6 +23,7 @@ extern char __kprobes_text_start[], __kprobes_text_end[];
>  extern char __entry_text_start[], __entry_text_end[];
>  extern char __initdata_begin[], __initdata_end[];
>  extern char __start_rodata[], __end_rodata[];
> +extern char __start_data[], __end_data[];
>  extern char __efi_helloworld_begin[];
>  extern char __efi_helloworld_end[];
>  extern char __efi_var_file_begin[];
> @@ -63,6 +64,7 @@ static inline int arch_is_kernel_data(unsigned long addr)
>
>  /* Start of U-Boot text region */
>  extern char __text_start[];
> +extern char __text_end[];
>
>  /* This marks the text region which must be relocated */
>  extern char __image_copy_start[], __image_copy_end[];
> --
> 2.47.2
>


More information about the U-Boot mailing list