diff --git a/ld/ChangeLog b/ld/ChangeLog index b0191cfcce..12c3a74601 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,10 @@ +2017-08-10 Nick Clifton + + * scripttempl/pep.sc: Enclose __CTOR_LIST__, ___CTOR_LIST__, + __DTOR_LIST__ and ___DTOR_LIST__ in PROVIDE statements so that + they can be overrridden by crt input files. + * scripttempl/pe.sc: Likewise. + 2017-08-09 H.J. Lu * testsuite/config/default.exp (LD_CLASS): Check .libs/ld-new diff --git a/ld/scripttempl/pe.sc b/ld/scripttempl/pe.sc index 9f7b2b220e..5de44e561a 100644 --- a/ld/scripttempl/pe.sc +++ b/ld/scripttempl/pe.sc @@ -97,10 +97,24 @@ SECTIONS ${RELOCATING+ *(.gnu.linkonce.t.*)} ${RELOCATING+*(.glue_7t)} ${RELOCATING+*(.glue_7)} - ${CONSTRUCTING+ ___CTOR_LIST__ = .; __CTOR_LIST__ = . ; - LONG (-1);*(.ctors); *(.ctor); *(SORT(.ctors.*)); LONG (0); } - ${CONSTRUCTING+ ___DTOR_LIST__ = .; __DTOR_LIST__ = . ; - LONG (-1); *(.dtors); *(.dtor); *(SORT(.dtors.*)); LONG (0); } + ${CONSTRUCTING+ + PROVIDE(___CTOR_LIST__ = .); + PROVIDE(__CTOR_LIST__ = .); + LONG (-1); + KEEP(*(.ctors)); + KEEP(*(.ctor)); + KEEP(*(SORT_BY_NAME(.ctors.*))); + LONG (0); + } + ${CONSTRUCTING+ + PROVIDE(___DTOR_LIST__ = .); + PROVIDE(__DTOR_LIST__ = .); + LONG (-1); + KEEP(*(.dtors)); + KEEP(*(.dtor)); + KEEP(*(SORT_BY_NAME(.dtors.*))); + LONG (0); + } ${RELOCATING+ KEEP (*(.fini))} /* ??? Why is .gcc_exc here? */ ${RELOCATING+ *(.gcc_exc)} diff --git a/ld/scripttempl/pep.sc b/ld/scripttempl/pep.sc index 57eb75c51c..e972ec86a6 100644 --- a/ld/scripttempl/pep.sc +++ b/ld/scripttempl/pep.sc @@ -98,18 +98,24 @@ SECTIONS ${RELOCATING+*(.glue_7t)} ${RELOCATING+*(.glue_7)} ${CONSTRUCTING+. = ALIGN(8);} - ${CONSTRUCTING+ ___CTOR_LIST__ = .; __CTOR_LIST__ = . ; - LONG (-1); LONG (-1); - KEEP (*(.ctors)); - KEEP (*(.ctor)); - KEEP (*(SORT(.ctors.*))); - LONG (0); LONG (0); } - ${CONSTRUCTING+ ___DTOR_LIST__ = .; __DTOR_LIST__ = . ; - LONG (-1); LONG (-1); - KEEP (*(.dtors)); - KEEP (*(.dtor)); - KEEP (*(SORT(.dtors.*))); - LONG (0); LONG (0); } + ${CONSTRUCTING+ + PROVIDE(___CTOR_LIST__ = .); + PROVIDE(__CTOR_LIST__ = .); + LONG (-1); LONG (-1); + KEEP (*(.ctors)); + KEEP (*(.ctor)); + KEEP (*(SORT_BY_NAME(.ctors.*))); + LONG (0); LONG (0); + } + ${CONSTRUCTING+ + PROVIDE(___DTOR_LIST__ = .); + PROVIDE(__DTOR_LIST__ = .); + LONG (-1); LONG (-1); + KEEP (*(.dtors)); + KEEP (*(.dtor)); + KEEP (*(SORT_BY_NAME(.dtors.*))); + LONG (0); LONG (0); + } ${RELOCATING+ KEEP (*(.fini))} /* ??? Why is .gcc_exc here? */ ${RELOCATING+ *(.gcc_exc)}