From 35130e73da95371af99734cda3ef8915a6eb5e7a Mon Sep 17 00:00:00 2001 From: Dimitar Dimitrov Date: Thu, 4 May 2023 12:41:55 +0100 Subject: [PATCH] ld: pru: Place exception-handling sections correctly * scripttempl/pru.sc (OUTPUT_SECTION_ALIGN): New helper variable to place at end of DMEM output sections. (.data): Use the helper variable. (.eh_frame): New output section. (.gnu_extab): Ditto. (.gcc_except_table): Ditto. (.resource_table): Use the helper variable. --- ld/ChangeLog | 10 ++++++++++ ld/scripttempl/pru.sc | 34 ++++++++++++++++++++++++++-------- 2 files changed, 36 insertions(+), 8 deletions(-) diff --git a/ld/ChangeLog b/ld/ChangeLog index f941b138c17..dcdf27cf423 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,13 @@ +2023-05-04 Dimitar Dimitrov + + * scripttempl/pru.sc (OUTPUT_SECTION_ALIGN): New helper variable + to place at end of DMEM output sections. + (.data): Use the helper variable. + (.eh_frame): New output section. + (.gnu_extab): Ditto. + (.gcc_except_table): Ditto. + (.resource_table): Use the helper variable. + 2023-04-27 Nick Clifton * ldmisc.c (vfinfo): Add support for %x and %lx. diff --git a/ld/scripttempl/pru.sc b/ld/scripttempl/pru.sc index 8531cb8d5be..3ff86bc61c7 100644 --- a/ld/scripttempl/pru.sc +++ b/ld/scripttempl/pru.sc @@ -24,6 +24,12 @@ ENTRY (_start) EOF +OUTPUT_SECTION_ALIGN=" + ${RELOCATING+/* In case this is the last input section, + align to keep the loadable segment size a multiple of the common page size. + Some SoCs have stricter memory size requirements than others. */ + . = ALIGN (CONSTANT (COMMONPAGESIZE));}" + cat < dmem} + + .eh_frame ${RELOCATING-0} : + { + KEEP (*(.eh_frame))${RELOCATING+ *(.eh_frame.*)} + ${OUTPUT_SECTION_ALIGN} + } ${RELOCATING+ > dmem} + + .gnu_extab ${RELOCATING-0} : + { + *(.gnu_extab) + ${OUTPUT_SECTION_ALIGN} + } ${RELOCATING+ > dmem} + + .gcc_except_table ${RELOCATING-0} : + { + *(.gcc_except_table${RELOCATING+ .gcc_except_table.*}) + ${OUTPUT_SECTION_ALIGN} } ${RELOCATING+ > dmem} /* Linux remoteproc loader requires the resource_table section @@ -175,10 +196,7 @@ SECTIONS .resource_table ${RELOCATING-0} ${RELOCATING+ ALIGN (CONSTANT (MAXPAGESIZE))} : { KEEP (*(.resource_table)) - ${RELOCATING+/* In case this is the last input section, align to - keep the loadable segment size a multiple of the common page size. - Some SoCs have stricter memory size requirements than others. */ - . = ALIGN (CONSTANT (COMMONPAGESIZE));} + ${OUTPUT_SECTION_ALIGN} } ${RELOCATING+ > dmem} /* Global data not cleared after reset. */ -- 2.30.2