On Tue, Oct 08, 2013 at 09:37:39PM +0100, Mark Salter wrote:
> The arm64 linker script doesn't use the PAGE_ALIGNED_DATA macro which
> leads to a ".data..page_aligned" section being placed between the end
> of .data and start of .bss:
> 
>  % readelf -e vmlinux
>    ...
>  Section to Segment mapping:
>   Segment Sections...
>    00     .head.text .text .text.init .rodata __ksymtab __ksymtab_gpl \
>           __ksymtab_strings __param __modver __ex_table .notes \
>           .init.text .init.data .data..percpu .data .data..page_aligned .bss
> 
> This causes problems for the EFI stub which may have to relocate the
> kernel image based on stext and _edata symbols.
> 
> This patch adds PAGE_ALIGNED_DATA() to the linker script inside the
> the .data section.
> 
> Signed-off-by: Mark Salter <msal...@redhat.com>
> ---
>  arch/arm64/kernel/vmlinux.lds.S | 1 +
>  1 file changed, 1 insertion(+)
> 
> diff --git a/arch/arm64/kernel/vmlinux.lds.S b/arch/arm64/kernel/vmlinux.lds.S
> index f8ab9d8..e441556 100644
> --- a/arch/arm64/kernel/vmlinux.lds.S
> +++ b/arch/arm64/kernel/vmlinux.lds.S
> @@ -110,6 +110,7 @@ SECTIONS
>                */
>               INIT_TASK_DATA(THREAD_SIZE)
>               NOSAVE_DATA
> +             PAGE_ALIGNED_DATA(PAGE_SIZE)
>               CACHELINE_ALIGNED_DATA(64)
>               READ_MOSTLY_DATA(64)

Can we just replace this chunk with RW_DATA_SECTION(64, PAGE_SIZE,
THREAD_SIZE) instead?

Will
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to