mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-18 12:24:38 +08:00
0f088b2a94
PR ld/11539 bfd * coffcode.h (coff_bfd_gc_sections): Define default to bfd_coff_gc_sections function. * cofflink.c (init_reloc_cookie): Copy and adjust coff related code about gc-sections from elflink.c to here. (fini_reloc_cookie): Likewise. (init_reloc_cookie_rels): Likewise. (fini_reloc_cookie_rels): Likewise. (init_reloc_cookie_for_section): Likewise. (fini_reloc_cookie_for_section): Likewise. (_bfd_coff_gc_mark_hook): Likewise. (_bfd_coff_gc_mark_rsec): Likewise. (_bfd_coff_gc_mark_reloc): Likewise. (_bfd_coff_gc_mark): Likewise. (_bfd_coff_gc_mark_extra_sections): Likewise. (coff_gc_sweep_symbol_info): Likewise. (coff_gc_sweep_symbol): Likewise. (gc_sweep_hook_fn): Likewise. (coff_gc_sweep): Likewise. (bfd_coff_gc_sections): Likewise. (_bfd_coff_gc_keep): Likewise. * libcoff.h (coff_reloc_cookie): New struct. (bfd_coff_gc_sections): New prototype. (coff_gc_mark_hook_fn): New type. ld * scripttempl/pep.sc: Mark .idata*, .CRT*, .tls*, .rsrc*, .init, .ctor*, .dtor*, .fini, .jcr, .eh_frame, .pdata. .xdata, and .gcc_except_table sections as KEEP. * scripttempl/pe.sc: Likewise.
415 lines
11 KiB
Scala
415 lines
11 KiB
Scala
# Linker script for PE.
|
|
#
|
|
# Copyright (C) 2014-2015 Free Software Foundation, Inc.
|
|
#
|
|
# Copying and distribution of this file, with or without modification,
|
|
# are permitted in any medium without royalty provided the copyright
|
|
# notice and this notice are preserved.
|
|
|
|
if test -z "${RELOCATEABLE_OUTPUT_FORMAT}"; then
|
|
RELOCATEABLE_OUTPUT_FORMAT=${OUTPUT_FORMAT}
|
|
fi
|
|
|
|
# We can't easily and portably get an unquoted $ in a shell
|
|
# substitution, so we do this instead.
|
|
# Sorting of the .foo$* sections is required by the definition of
|
|
# grouped sections in PE.
|
|
# Sorting of the file names in R_IDATA is required by the
|
|
# current implementation of dlltool (this could probably be changed to
|
|
# use grouped sections instead).
|
|
if test "${RELOCATING}"; then
|
|
R_TEXT='*(SORT(.text$*))'
|
|
if test "x$LD_FLAG" = "xauto_import" ; then
|
|
R_DATA='*(SORT(.data$*))
|
|
*(.rdata)
|
|
*(SORT(.rdata$*))'
|
|
R_RDATA=''
|
|
else
|
|
R_DATA='*(SORT(.data$*))'
|
|
R_RDATA='*(.rdata)
|
|
*(SORT(.rdata$*))'
|
|
fi
|
|
R_IDATA234='
|
|
KEEP (SORT(*)(.idata$2))
|
|
KEEP (SORT(*)(.idata$3))
|
|
/* These zeroes mark the end of the import list. */
|
|
LONG (0); LONG (0); LONG (0); LONG (0); LONG (0);
|
|
KEEP (SORT(*)(.idata$4))'
|
|
R_IDATA5='SORT(*)(.idata$5)'
|
|
R_IDATA67='
|
|
KEEP (SORT(*)(.idata$6))
|
|
KEEP (SORT(*)(.idata$7))'
|
|
R_CRT_XC='KEEP (*(SORT(.CRT$XC*))) /* C initialization */'
|
|
R_CRT_XI='KEEP (*(SORT(.CRT$XI*))) /* C++ initialization */'
|
|
R_CRT_XL='KEEP (*(SORT(.CRT$XL*))) /* TLS callbacks */'
|
|
R_CRT_XP='KEEP (*(SORT(.CRT$XP*))) /* Pre-termination */'
|
|
R_CRT_XT='KEEP (*(SORT(.CRT$XT*))) /* Termination */'
|
|
R_TLS='
|
|
KEEP (*(.tls$AAA))
|
|
KEEP (*(.tls))
|
|
KEEP (*(.tls$))
|
|
KEEP (*(SORT(.tls$*)))
|
|
KEEP (*(.tls$ZZZ))'
|
|
R_RSRC='
|
|
KEEP (*(.rsrc))
|
|
KEEP (*(.rsrc$*))'
|
|
else
|
|
R_TEXT=
|
|
R_DATA=
|
|
R_RDATA='*(.rdata)'
|
|
R_IDATA234=
|
|
R_IDATA5=
|
|
R_IDATA67=
|
|
R_CRT=
|
|
R_RSRC='*(.rsrc)'
|
|
fi
|
|
|
|
cat <<EOF
|
|
/* Copyright (C) 2014-2015 Free Software Foundation, Inc.
|
|
|
|
Copying and distribution of this script, with or without modification,
|
|
are permitted in any medium without royalty provided the copyright
|
|
notice and this notice are preserved. */
|
|
|
|
${RELOCATING+OUTPUT_FORMAT(${OUTPUT_FORMAT})}
|
|
${RELOCATING-OUTPUT_FORMAT(${RELOCATEABLE_OUTPUT_FORMAT})}
|
|
${OUTPUT_ARCH+OUTPUT_ARCH(${OUTPUT_ARCH})}
|
|
|
|
${LIB_SEARCH_DIRS}
|
|
|
|
SECTIONS
|
|
{
|
|
${RELOCATING+/* Make the virtual address and file offset synced if the alignment is}
|
|
${RELOCATING+ lower than the target page size. */}
|
|
${RELOCATING+. = SIZEOF_HEADERS;}
|
|
${RELOCATING+. = ALIGN(__section_alignment__);}
|
|
.text ${RELOCATING+ __image_base__ + ( __section_alignment__ < ${TARGET_PAGE_SIZE} ? . : __section_alignment__ )} :
|
|
{
|
|
${RELOCATING+ KEEP(*(.init))}
|
|
*(.text)
|
|
${R_TEXT}
|
|
${RELOCATING+ *(.text.*)}
|
|
${RELOCATING+ *(.gnu.linkonce.t.*)}
|
|
*(.glue_7t)
|
|
*(.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); }
|
|
${RELOCATING+ KEEP (*(.fini))}
|
|
/* ??? Why is .gcc_exc here? */
|
|
${RELOCATING+ *(.gcc_exc)}
|
|
${RELOCATING+PROVIDE (etext = .);}
|
|
${RELOCATING+ KEEP (*(.gcc_except_table))}
|
|
}
|
|
|
|
/* The Cygwin32 library uses a section to avoid copying certain data
|
|
on fork. This used to be named ".data$nocopy". The linker used
|
|
to include this between __data_start__ and __data_end__, but that
|
|
breaks building the cygwin32 dll. Instead, we name the section
|
|
".data_cygwin_nocopy" and explicitly include it after __data_end__. */
|
|
|
|
.data ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
${RELOCATING+__data_start__ = . ;}
|
|
*(.data)
|
|
*(.data2)
|
|
${R_DATA}
|
|
KEEP(*(.jcr))
|
|
${RELOCATING+__data_end__ = . ;}
|
|
${RELOCATING+*(.data_cygwin_nocopy)}
|
|
}
|
|
|
|
.rdata ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
${R_RDATA}
|
|
${RELOCATING+__rt_psrelocs_start = .;}
|
|
*(.rdata_runtime_pseudo_reloc)
|
|
${RELOCATING+__rt_psrelocs_end = .;}
|
|
}
|
|
${RELOCATING+__rt_psrelocs_size = __rt_psrelocs_end - __rt_psrelocs_start;}
|
|
${RELOCATING+___RUNTIME_PSEUDO_RELOC_LIST_END__ = .;}
|
|
${RELOCATING+__RUNTIME_PSEUDO_RELOC_LIST_END__ = .;}
|
|
${RELOCATING+___RUNTIME_PSEUDO_RELOC_LIST__ = . - __rt_psrelocs_size;}
|
|
${RELOCATING+__RUNTIME_PSEUDO_RELOC_LIST__ = . - __rt_psrelocs_size;}
|
|
|
|
.eh_frame ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
KEEP (*(.eh_frame*))
|
|
}
|
|
|
|
.pdata ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
KEEP(*(.pdata*))
|
|
}
|
|
|
|
.xdata ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
KEEP(*(.xdata*))
|
|
}
|
|
|
|
.bss ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
${RELOCATING+__bss_start__ = . ;}
|
|
*(.bss)
|
|
*(COMMON)
|
|
${RELOCATING+__bss_end__ = . ;}
|
|
}
|
|
|
|
.edata ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
*(.edata)
|
|
}
|
|
|
|
/DISCARD/ :
|
|
{
|
|
*(.debug\$S)
|
|
*(.debug\$T)
|
|
*(.debug\$F)
|
|
*(.drectve)
|
|
${RELOCATING+ *(.note.GNU-stack)}
|
|
${RELOCATING+ *(.gnu.lto_*)}
|
|
}
|
|
|
|
.idata ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
/* This cannot currently be handled with grouped sections.
|
|
See pep.em:sort_sections. */
|
|
${R_IDATA234}
|
|
${RELOCATING+__IAT_start__ = .;}
|
|
${R_IDATA5}
|
|
${RELOCATING+__IAT_end__ = .;}
|
|
${R_IDATA67}
|
|
}
|
|
.CRT ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
${RELOCATING+___crt_xc_start__ = . ;}
|
|
${R_CRT_XC}
|
|
${RELOCATING+___crt_xc_end__ = . ;}
|
|
${RELOCATING+___crt_xi_start__ = . ;}
|
|
${R_CRT_XI}
|
|
${RELOCATING+___crt_xi_end__ = . ;}
|
|
${RELOCATING+___crt_xl_start__ = . ;}
|
|
${R_CRT_XL}
|
|
/* ___crt_xl_end__ is defined in the TLS Directory support code */
|
|
${RELOCATING+___crt_xp_start__ = . ;}
|
|
${R_CRT_XP}
|
|
${RELOCATING+___crt_xp_end__ = . ;}
|
|
${RELOCATING+___crt_xt_start__ = . ;}
|
|
${R_CRT_XT}
|
|
${RELOCATING+___crt_xt_end__ = . ;}
|
|
}
|
|
|
|
/* Windows TLS expects .tls\$AAA to be at the start and .tls\$ZZZ to be
|
|
at the end of the .tls section. This is important because _tls_start MUST
|
|
be at the beginning of the section to enable SECREL32 relocations with TLS
|
|
data. */
|
|
.tls ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
${RELOCATING+___tls_start__ = . ;}
|
|
${R_TLS}
|
|
${RELOCATING+___tls_end__ = . ;}
|
|
}
|
|
|
|
.endjunk ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
/* end is deprecated, don't use it */
|
|
${RELOCATING+PROVIDE (end = .);}
|
|
${RELOCATING+PROVIDE ( _end = .);}
|
|
${RELOCATING+ __end__ = .;}
|
|
}
|
|
|
|
.rsrc ${RELOCATING+BLOCK(__section_alignment__)} : SUBALIGN(4)
|
|
{
|
|
${R_RSRC}
|
|
}
|
|
|
|
.reloc ${RELOCATING+BLOCK(__section_alignment__)} :
|
|
{
|
|
*(.reloc)
|
|
}
|
|
|
|
.stab ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.stab)
|
|
}
|
|
|
|
.stabstr ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.stabstr)
|
|
}
|
|
|
|
/* DWARF debug sections.
|
|
Symbols in the DWARF debugging sections are relative to the beginning
|
|
of the section. Unlike other targets that fake this by putting the
|
|
section VMA at 0, the PE format will not allow it. */
|
|
|
|
/* DWARF 1.1 and DWARF 2. */
|
|
.debug_aranges ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_aranges)
|
|
}
|
|
.zdebug_aranges ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_aranges)
|
|
}
|
|
|
|
.debug_pubnames ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_pubnames)
|
|
}
|
|
.zdebug_pubnames ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_pubnames)
|
|
}
|
|
|
|
.debug_pubtypes ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_pubtypes)
|
|
}
|
|
.zdebug_pubtypes ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_pubtypes)
|
|
}
|
|
|
|
/* DWARF 2. */
|
|
.debug_info ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_info${RELOCATING+ .gnu.linkonce.wi.*})
|
|
}
|
|
.zdebug_info ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_info${RELOCATING+ .zdebug.gnu.linkonce.wi.*})
|
|
}
|
|
|
|
.debug_abbrev ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_abbrev)
|
|
}
|
|
.zdebug_abbrev ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_abbrev)
|
|
}
|
|
|
|
.debug_line ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_line)
|
|
}
|
|
.zdebug_line ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_line)
|
|
}
|
|
|
|
.debug_frame ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_frame)
|
|
}
|
|
.zdebug_frame ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_frame)
|
|
}
|
|
|
|
.debug_str ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_str)
|
|
}
|
|
.zdebug_str ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_str)
|
|
}
|
|
|
|
.debug_loc ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_loc)
|
|
}
|
|
.zdebug_loc ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_loc)
|
|
}
|
|
|
|
.debug_macinfo ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_macinfo)
|
|
}
|
|
.zdebug_macinfo ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_macinfo)
|
|
}
|
|
|
|
/* SGI/MIPS DWARF 2 extensions. */
|
|
.debug_weaknames ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_weaknames)
|
|
}
|
|
.zdebug_weaknames ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_weaknames)
|
|
}
|
|
|
|
.debug_funcnames ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_funcnames)
|
|
}
|
|
.zdebug_funcnames ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_funcnames)
|
|
}
|
|
|
|
.debug_typenames ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_typenames)
|
|
}
|
|
.zdebug_typenames ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_typenames)
|
|
}
|
|
|
|
.debug_varnames ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_varnames)
|
|
}
|
|
.zdebug_varnames ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_varnames)
|
|
}
|
|
|
|
.debug_macro ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_macro)
|
|
}
|
|
.zdebug_macro ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_macro)
|
|
}
|
|
|
|
/* DWARF 3. */
|
|
.debug_ranges ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_ranges)
|
|
}
|
|
.zdebug_ranges ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_ranges)
|
|
}
|
|
|
|
/* DWARF 4. */
|
|
.debug_types ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.debug_types${RELOCATING+ .gnu.linkonce.wt.*})
|
|
}
|
|
.zdebug_types ${RELOCATING+BLOCK(__section_alignment__)} ${RELOCATING+(NOLOAD)} :
|
|
{
|
|
*(.zdebug_types${RELOCATING+ .zdebug.gnu.linkonce.wt.*})
|
|
}
|
|
}
|
|
EOF
|