linker_script: replace common read-only data with RODATA_COMMON

The common section data are repeated in many linker scripts (often
twice in each script to support SEPARATE_CODE_AND_RODATA). When you
add a new read-only data section, you end up with touching lots of
places.

After this commit, you will only need to touch bl_common.ld.h when
you add a new section to RODATA_COMMON.

Replace a series of RO section with RODATA_COMMON, which contains
6 sections, some of which did not exist before.

This is not a big deal because unneeded data should not be compiled
in the first place. I believe this should be controlled by BL*_SOURCES
in Makefiles, not by linker scripts.

When I was working on this commit, the BL1 image size increased
due to the fconf_populator. Commit c452ba159c ("fconf: exclude
fconf_dyn_cfg_getter.c from BL1_SOURCES") fixed this issue.

I investigated BL1, BL2, BL2U, BL31 for plat=fvp, and BL2-AT-EL3,
BL31, BL31 for plat=uniphier. I did not see any more  unexpected
code addition.

Change-Id: I5d14d60dbe3c821765bce3ae538968ef266f1460
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
This commit is contained in:
Masahiro Yamada 2020-03-26 10:57:12 +09:00
parent 9fb288a03e
commit 0a0a7a9ac8
9 changed files with 26 additions and 35 deletions

View File

@ -45,8 +45,7 @@ SECTIONS
__RODATA_START__ = .;
*(SORT_BY_ALIGNMENT(.rodata*))
PARSER_LIB_DESCS
CPU_OPS
RODATA_COMMON
/*
* No need to pad out the .rodata section to a page boundary. Next is
@ -67,8 +66,7 @@ SECTIONS
*(SORT_BY_ALIGNMENT(.text*))
*(SORT_BY_ALIGNMENT(.rodata*))
PARSER_LIB_DESCS
CPU_OPS
RODATA_COMMON
*(.vectors)
__RO_END__ = .;

View File

@ -45,8 +45,7 @@ SECTIONS
__RODATA_START__ = .;
*(SORT_BY_ALIGNMENT(.rodata*))
FCONF_POPULATOR
PARSER_LIB_DESCS
RODATA_COMMON
. = ALIGN(PAGE_SIZE);
__RODATA_END__ = .;
@ -58,8 +57,7 @@ SECTIONS
*(SORT_BY_ALIGNMENT(.text*))
*(SORT_BY_ALIGNMENT(.rodata*))
FCONF_POPULATOR
PARSER_LIB_DESCS
RODATA_COMMON
*(.vectors)
__RO_END_UNALIGNED__ = .;

View File

@ -53,9 +53,7 @@ SECTIONS
__RODATA_START__ = .;
*(SORT_BY_ALIGNMENT(.rodata*))
PARSER_LIB_DESCS
CPU_OPS
GOT
RODATA_COMMON
. = ALIGN(PAGE_SIZE);
__RODATA_END__ = .;
@ -73,9 +71,7 @@ SECTIONS
*(SORT_BY_ALIGNMENT(.text*))
*(SORT_BY_ALIGNMENT(.rodata*))
CPU_OPS
PARSER_LIB_DESCS
GOT
RODATA_COMMON
*(.vectors)
__RO_END_UNALIGNED__ = .;

View File

@ -46,6 +46,9 @@ SECTIONS
.rodata . : {
__RODATA_START__ = .;
*(SORT_BY_ALIGNMENT(.rodata*))
RODATA_COMMON
. = ALIGN(PAGE_SIZE);
__RODATA_END__ = .;
} >RAM
@ -56,6 +59,8 @@ SECTIONS
*(SORT_BY_ALIGNMENT(.text*))
*(SORT_BY_ALIGNMENT(.rodata*))
RODATA_COMMON
*(.vectors)
__RO_END_UNALIGNED__ = .;
/*

View File

@ -47,11 +47,7 @@ SECTIONS
__RODATA_START__ = .;
*(SORT_BY_ALIGNMENT(.rodata*))
RT_SVC_DESCS
FCONF_POPULATOR
PMF_SVC_DESCS
CPU_OPS
GOT
RODATA_COMMON
/* Place pubsub sections for events */
. = ALIGN(8);
@ -67,11 +63,7 @@ SECTIONS
*(SORT_BY_ALIGNMENT(.text*))
*(SORT_BY_ALIGNMENT(.rodata*))
RT_SVC_DESCS
FCONF_POPULATOR
PMF_SVC_DESCS
CPU_OPS
GOT
RODATA_COMMON
/* Place pubsub sections for events */
. = ALIGN(8);

View File

@ -48,10 +48,7 @@ SECTIONS
__RODATA_START__ = .;
*(.rodata*)
RT_SVC_DESCS
FCONF_POPULATOR
PMF_SVC_DESCS
CPU_OPS
RODATA_COMMON
/* Place pubsub sections for events */
. = ALIGN(8);
@ -67,9 +64,7 @@ SECTIONS
*(.text*)
*(.rodata*)
RT_SVC_DESCS
FCONF_POPULATOR
CPU_OPS
RODATA_COMMON
/* Place pubsub sections for events */
. = ALIGN(8);

View File

@ -37,7 +37,7 @@ SECTIONS
__RODATA_START__ = .;
*(.rodata*)
GOT
RODATA_COMMON
. = ALIGN(PAGE_SIZE);
__RODATA_END__ = .;
@ -49,7 +49,7 @@ SECTIONS
*(.text*)
*(.rodata*)
GOT
RODATA_COMMON
*(.vectors)

View File

@ -56,6 +56,14 @@
*(.got) \
__GOT_END__ = .;
#define RODATA_COMMON \
RT_SVC_DESCS \
FCONF_POPULATOR \
PMF_SVC_DESCS \
PARSER_LIB_DESCS \
CPU_OPS \
GOT
#define STACK_SECTION \
stacks (NOLOAD) : { \
__STACKS_START__ = .; \

View File

@ -38,8 +38,7 @@ SECTIONS
*(.text*)
*(.rodata*)
RT_SVC_DESCS
CPU_OPS
RODATA_COMMON
__RO_END_UNALIGNED__ = .;
/*