u-boot/board/synopsys/iot_devkit/u-boot.lds
Andrew Scull 99e2fbcb69 linker_lists: Rename sections to remove . prefix
Rename the sections used to implement linker lists so they begin with
'__u_boot_list' rather than '.u_boot_list'. The double underscore at the
start is still distinct from the single underscore used by the symbol
names.

Having a '.' in the section names conflicts with clang's ASAN
instrumentation which tries to add redzones between the linker list
elements, causing expected accesses to fail. However, clang doesn't try
to add redzones to user sections, which are names with all alphanumeric
and underscore characters.

Signed-off-by: Andrew Scull <ascull@google.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
2022-06-23 12:58:18 -04:00

78 lines
1.3 KiB
Text

/*
* Copyright (C) 2018 Synopsys, Inc. All rights reserved.
*
* SPDX-License-Identifier: GPL-2.0+
*/
#include <config.h>
#include <system-constants.h>
MEMORY {
ROM : ORIGIN = ROM_BASE, LENGTH = ROM_SIZE
RAM : ORIGIN = RAM_DATA_BASE, LENGTH = RAM_DATA_SIZE
}
OUTPUT_FORMAT("elf32-littlearc", "elf32-littlearc", "elf32-littlearc")
OUTPUT_ARCH(arc)
ENTRY(_start)
SECTIONS
{
. = CONFIG_SYS_MONITOR_BASE;
__image_copy_start = .;
.ivt :
{
__ivt_start = .;
KEEP(*(.ivt));
__ivt_end = .;
} > ROM
. = ALIGN(1024);
.text : {
__text_start = .;
arch/arc/lib/start.o (.text*)
*(.text*)
__text_end = .;
} > ROM
. = ALIGN(4);
.rodata : {
*(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*)))
} > ROM
. = ALIGN(4);
__u_boot_list : {
KEEP(*(SORT(__u_boot_list*)));
/* Mark RAM's LMA */
. = ALIGN(4);
__rom_end = .;
} > ROM
.data : {
/* Mark RAM's VMA */
. = ALIGN(4);
/*
* Everything between __ram_start and __ram_start will be
* copied from ROM to RAM in board_early_init_f().
*/
__ram_start = .;
*(.data*)
__ram_end = .;
} > RAM AT > ROM
.bss : {
. = ALIGN(1024);
__bss_start = .;
*(.bss*)
__bss_end = .;
} > RAM
/* Keep relocation-related symbols to make linker happy */
__rel_dyn_start = .;
__rel_dyn_end = .;
__image_copy_end = .;
__init_end = .;
}