]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - ld/emultempl/pe.em
* ldemul.h (ldemul_place_orphan): Update prototype.
[thirdparty/binutils-gdb.git] / ld / emultempl / pe.em
CommitLineData
252b5132
RH
1# This shell script emits a C file. -*- C -*-
2# It does some substitutions.
e60cc415 3test -z "${ENTRY}" && ENTRY="_mainCRTStartup"
3fc90ddb 4if [ -z "$MACHINE" ]; then
86af25fe
L
5 OUTPUT_ARCH=${ARCH}
6else
7 OUTPUT_ARCH=${ARCH}:${MACHINE}
8fi
361d94e7
ILT
9rm -f e${EMULATION_NAME}.c
10(echo;echo;echo;echo;echo)>e${EMULATION_NAME}.c # there, now line numbers match ;-)
92b93329 11fragment <<EOF
f96b4a7b 12/* Copyright 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
f13a99db 13 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
252b5132 14
f96b4a7b
NC
15 This file is part of the GNU Binutils.
16
2fa9fc65
NC
17 This program is free software; you can redistribute it and/or modify
18 it under the terms of the GNU General Public License as published by
f96b4a7b 19 the Free Software Foundation; either version 3 of the License, or
2fa9fc65 20 (at your option) any later version.
252b5132 21
2fa9fc65
NC
22 This program is distributed in the hope that it will be useful,
23 but WITHOUT ANY WARRANTY; without even the implied warranty of
24 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
25 GNU General Public License for more details.
252b5132 26
2fa9fc65
NC
27 You should have received a copy of the GNU General Public License
28 along with this program; if not, write to the Free Software
f96b4a7b
NC
29 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
30 MA 02110-1301, USA. */
31
252b5132
RH
32
33/* For WINDOWS_NT */
34/* The original file generated returned different default scripts depending
35 on whether certain switches were set, but these switches pertain to the
36 Linux system and that particular version of coff. In the NT case, we
37 only determine if the subsystem is console or windows in order to select
3fc90ddb
AJ
38 the correct entry point by default. */
39
db09f25b
AM
40#define TARGET_IS_${EMULATION_NAME}
41
42/* Do this before including bfd.h, so we prototype the right functions. */
db09f25b 43
7148cc28
NC
44#if defined(TARGET_IS_armpe) \
45 || defined(TARGET_IS_arm_epoc_pe) \
46 || defined(TARGET_IS_arm_wince_pe)
47#define bfd_arm_allocate_interworking_sections \
48 bfd_${EMULATION_NAME}_allocate_interworking_sections
49#define bfd_arm_get_bfd_for_interworking \
50 bfd_${EMULATION_NAME}_get_bfd_for_interworking
51#define bfd_arm_process_before_allocation \
52 bfd_${EMULATION_NAME}_process_before_allocation
53#endif
92b93329 54
252b5132 55#include "sysdep.h"
3db64b00 56#include "bfd.h"
252b5132
RH
57#include "bfdlink.h"
58#include "getopt.h"
59#include "libiberty.h"
60#include "ld.h"
61#include "ldmain.h"
252b5132
RH
62#include "ldexp.h"
63#include "ldlang.h"
b71e2778 64#include "ldfile.h"
252b5132 65#include "ldemul.h"
df2a7313 66#include <ldgram.h>
252b5132
RH
67#include "ldlex.h"
68#include "ldmisc.h"
69#include "ldctor.h"
252b5132 70#include "coff/internal.h"
71add731 71
26d2d8a2
BF
72/* FIXME: See bfd/peXXigen.c for why we include an architecture specific
73 header in generic PE code. */
74#include "coff/i386.h"
75#include "coff/pe.h"
76
71add731
ILT
77/* FIXME: This is a BFD internal header file, and we should not be
78 using it here. */
252b5132 79#include "../bfd/libcoff.h"
71add731 80
252b5132 81#include "deffile.h"
1069dd8d 82#include "pe-dll.h"
29e1a6e4 83#include "safe-ctype.h"
14fe918e 84
2be9b2c7
ILT
85/* Permit the emulation parameters to override the default section
86 alignment by setting OVERRIDE_SECTION_ALIGNMENT. FIXME: This makes
87 it seem that include/coff/internal.h should not define
88 PE_DEF_SECTION_ALIGNMENT. */
89#if PE_DEF_SECTION_ALIGNMENT != ${OVERRIDE_SECTION_ALIGNMENT:-PE_DEF_SECTION_ALIGNMENT}
90#undef PE_DEF_SECTION_ALIGNMENT
91#define PE_DEF_SECTION_ALIGNMENT ${OVERRIDE_SECTION_ALIGNMENT}
92#endif
93
7148cc28
NC
94#if defined(TARGET_IS_i386pe) \
95 || defined(TARGET_IS_shpe) \
96 || defined(TARGET_IS_mipspe) \
97 || defined(TARGET_IS_armpe) \
98 || defined(TARGET_IS_arm_epoc_pe) \
99 || defined(TARGET_IS_arm_wince_pe)
344a211f
NC
100#define DLL_SUPPORT
101#endif
c6c37250 102
344a211f 103#if defined(TARGET_IS_i386pe) || ! defined(DLL_SUPPORT)
c6c37250 104#define PE_DEF_SUBSYSTEM 3
344a211f
NC
105#else
106#undef NT_EXE_IMAGE_BASE
107#undef PE_DEF_SECTION_ALIGNMENT
108#undef PE_DEF_FILE_ALIGNMENT
109#define NT_EXE_IMAGE_BASE 0x00010000
7148cc28
NC
110
111#if defined(TARGET_IS_armpe) || defined(TARGET_IS_arm_wince_pe)
344a211f
NC
112#define PE_DEF_SECTION_ALIGNMENT 0x00001000
113#define PE_DEF_SUBSYSTEM 9
114#else
115#define PE_DEF_SECTION_ALIGNMENT 0x00000400
116#define PE_DEF_SUBSYSTEM 2
117#endif
118#define PE_DEF_FILE_ALIGNMENT 0x00000200
119#endif
c6c37250 120
00479ba8 121#define U(S) ${INITIAL_SYMBOL_CHAR} S
252b5132
RH
122
123static struct internal_extra_pe_aouthdr pe;
124static int dll;
26d2d8a2 125static flagword real_flags = 0;
252b5132 126static int support_old_code = 0;
6f798e5c 127static char * thumb_entry_symbol = NULL;
252b5132
RH
128static lang_assignment_statement_type *image_base_statement = 0;
129
f0c87f88 130#ifdef DLL_SUPPORT
4cd89863 131static int pe_enable_stdcall_fixup = -1; /* 0=disable 1=enable. */
690a460e
NC
132static char *pe_out_def_filename = NULL;
133static char *pe_implib_filename = NULL;
5f577f7d 134static int pe_enable_auto_image_base = 0;
627427de 135static char *pe_dll_search_prefix = NULL;
f0c87f88 136#endif
252b5132
RH
137
138extern const char *output_filename;
139
140static void
0c7a8e5a 141gld_${EMULATION_NAME}_before_parse (void)
252b5132 142{
5e2f1575 143 ldfile_set_output_arch ("${OUTPUT_ARCH}", bfd_arch_`echo ${ARCH} | sed -e 's/:.*//'`);
db8d4f23 144 output_filename = "${EXECUTABLE_NAME:-a.exe}";
c6c37250 145#ifdef DLL_SUPPORT
b34976b6 146 config.dynamic_link = TRUE;
252b5132 147 config.has_shared = 1;
e0076ab3 148 link_info.pei386_auto_import = -1;
2c7fd14a 149 link_info.pei386_runtime_pseudo_reloc = -1;
344a211f
NC
150
151#if (PE_DEF_SUBSYSTEM == 9) || (PE_DEF_SUBSYSTEM == 2)
7148cc28 152#if defined TARGET_IS_mipspe || defined TARGET_IS_armpe || defined TARGET_IS_arm_wince_pe
a359509e 153 lang_default_entry ("WinMainCRTStartup");
344a211f 154#else
a359509e 155 lang_default_entry ("_WinMainCRTStartup");
344a211f 156#endif
e60cc415
DS
157#else
158 lang_default_entry ("${ENTRY}");
344a211f 159#endif
252b5132
RH
160#endif
161}
162\f
163/* PE format extra command line options. */
164
4cd89863 165/* Used for setting flags in the PE header. */
252b5132
RH
166#define OPTION_BASE_FILE (300 + 1)
167#define OPTION_DLL (OPTION_BASE_FILE + 1)
168#define OPTION_FILE_ALIGNMENT (OPTION_DLL + 1)
169#define OPTION_IMAGE_BASE (OPTION_FILE_ALIGNMENT + 1)
170#define OPTION_MAJOR_IMAGE_VERSION (OPTION_IMAGE_BASE + 1)
171#define OPTION_MAJOR_OS_VERSION (OPTION_MAJOR_IMAGE_VERSION + 1)
172#define OPTION_MAJOR_SUBSYSTEM_VERSION (OPTION_MAJOR_OS_VERSION + 1)
173#define OPTION_MINOR_IMAGE_VERSION (OPTION_MAJOR_SUBSYSTEM_VERSION + 1)
174#define OPTION_MINOR_OS_VERSION (OPTION_MINOR_IMAGE_VERSION + 1)
175#define OPTION_MINOR_SUBSYSTEM_VERSION (OPTION_MINOR_OS_VERSION + 1)
176#define OPTION_SECTION_ALIGNMENT (OPTION_MINOR_SUBSYSTEM_VERSION + 1)
0c7a8e5a
AM
177#define OPTION_STACK (OPTION_SECTION_ALIGNMENT + 1)
178#define OPTION_SUBSYSTEM (OPTION_STACK + 1)
252b5132
RH
179#define OPTION_HEAP (OPTION_SUBSYSTEM + 1)
180#define OPTION_SUPPORT_OLD_CODE (OPTION_HEAP + 1)
181#define OPTION_OUT_DEF (OPTION_SUPPORT_OLD_CODE + 1)
182#define OPTION_EXPORT_ALL (OPTION_OUT_DEF + 1)
183#define OPTION_EXCLUDE_SYMBOLS (OPTION_EXPORT_ALL + 1)
184#define OPTION_KILL_ATS (OPTION_EXCLUDE_SYMBOLS + 1)
185#define OPTION_STDCALL_ALIASES (OPTION_KILL_ATS + 1)
186#define OPTION_ENABLE_STDCALL_FIXUP (OPTION_STDCALL_ALIASES + 1)
187#define OPTION_DISABLE_STDCALL_FIXUP (OPTION_ENABLE_STDCALL_FIXUP + 1)
188#define OPTION_IMPLIB_FILENAME (OPTION_DISABLE_STDCALL_FIXUP + 1)
6f798e5c 189#define OPTION_THUMB_ENTRY (OPTION_IMPLIB_FILENAME + 1)
870df5dc
NC
190#define OPTION_WARN_DUPLICATE_EXPORTS (OPTION_THUMB_ENTRY + 1)
191#define OPTION_IMP_COMPAT (OPTION_WARN_DUPLICATE_EXPORTS + 1)
5f577f7d
DD
192#define OPTION_ENABLE_AUTO_IMAGE_BASE (OPTION_IMP_COMPAT + 1)
193#define OPTION_DISABLE_AUTO_IMAGE_BASE (OPTION_ENABLE_AUTO_IMAGE_BASE + 1)
1122a5fc
NC
194#define OPTION_DLL_SEARCH_PREFIX (OPTION_DISABLE_AUTO_IMAGE_BASE + 1)
195#define OPTION_NO_DEFAULT_EXCLUDES (OPTION_DLL_SEARCH_PREFIX + 1)
decc3638
CW
196#define OPTION_DLL_ENABLE_AUTO_IMPORT (OPTION_NO_DEFAULT_EXCLUDES + 1)
197#define OPTION_DLL_DISABLE_AUTO_IMPORT (OPTION_DLL_ENABLE_AUTO_IMPORT + 1)
198#define OPTION_ENABLE_EXTRA_PE_DEBUG (OPTION_DLL_DISABLE_AUTO_IMPORT + 1)
70b0be79 199#define OPTION_EXCLUDE_LIBS (OPTION_ENABLE_EXTRA_PE_DEBUG + 1)
2fa9fc65
NC
200#define OPTION_DLL_ENABLE_RUNTIME_PSEUDO_RELOC \
201 (OPTION_EXCLUDE_LIBS + 1)
202#define OPTION_DLL_DISABLE_RUNTIME_PSEUDO_RELOC \
203 (OPTION_DLL_ENABLE_RUNTIME_PSEUDO_RELOC + 1)
26d2d8a2
BF
204#define OPTION_LARGE_ADDRESS_AWARE \
205 (OPTION_DLL_DISABLE_RUNTIME_PSEUDO_RELOC + 1)
252b5132 206
3bcf5557 207static void
0c7a8e5a
AM
208gld${EMULATION_NAME}_add_options
209 (int ns ATTRIBUTE_UNUSED, char **shortopts ATTRIBUTE_UNUSED, int nl,
210 struct option **longopts, int nrl ATTRIBUTE_UNUSED,
211 struct option **really_longopts ATTRIBUTE_UNUSED)
3bcf5557
AM
212{
213 static const struct option xtra_long[] = {
214 /* PE options */
215 {"base-file", required_argument, NULL, OPTION_BASE_FILE},
216 {"dll", no_argument, NULL, OPTION_DLL},
217 {"file-alignment", required_argument, NULL, OPTION_FILE_ALIGNMENT},
218 {"heap", required_argument, NULL, OPTION_HEAP},
219 {"image-base", required_argument, NULL, OPTION_IMAGE_BASE},
220 {"major-image-version", required_argument, NULL, OPTION_MAJOR_IMAGE_VERSION},
221 {"major-os-version", required_argument, NULL, OPTION_MAJOR_OS_VERSION},
222 {"major-subsystem-version", required_argument, NULL, OPTION_MAJOR_SUBSYSTEM_VERSION},
223 {"minor-image-version", required_argument, NULL, OPTION_MINOR_IMAGE_VERSION},
224 {"minor-os-version", required_argument, NULL, OPTION_MINOR_OS_VERSION},
225 {"minor-subsystem-version", required_argument, NULL, OPTION_MINOR_SUBSYSTEM_VERSION},
226 {"section-alignment", required_argument, NULL, OPTION_SECTION_ALIGNMENT},
227 {"stack", required_argument, NULL, OPTION_STACK},
228 {"subsystem", required_argument, NULL, OPTION_SUBSYSTEM},
229 {"support-old-code", no_argument, NULL, OPTION_SUPPORT_OLD_CODE},
230 {"thumb-entry", required_argument, NULL, OPTION_THUMB_ENTRY},
c6c37250 231#ifdef DLL_SUPPORT
3bcf5557
AM
232 /* getopt allows abbreviations, so we do this to stop it from treating -o
233 as an abbreviation for this option */
234 {"output-def", required_argument, NULL, OPTION_OUT_DEF},
235 {"output-def", required_argument, NULL, OPTION_OUT_DEF},
236 {"export-all-symbols", no_argument, NULL, OPTION_EXPORT_ALL},
237 {"exclude-symbols", required_argument, NULL, OPTION_EXCLUDE_SYMBOLS},
238 {"exclude-libs", required_argument, NULL, OPTION_EXCLUDE_LIBS},
239 {"kill-at", no_argument, NULL, OPTION_KILL_ATS},
240 {"add-stdcall-alias", no_argument, NULL, OPTION_STDCALL_ALIASES},
241 {"enable-stdcall-fixup", no_argument, NULL, OPTION_ENABLE_STDCALL_FIXUP},
242 {"disable-stdcall-fixup", no_argument, NULL, OPTION_DISABLE_STDCALL_FIXUP},
243 {"out-implib", required_argument, NULL, OPTION_IMPLIB_FILENAME},
244 {"warn-duplicate-exports", no_argument, NULL, OPTION_WARN_DUPLICATE_EXPORTS},
245 /* getopt() allows abbreviations, so we do this to stop it from
246 treating -c as an abbreviation for these --compat-implib. */
247 {"compat-implib", no_argument, NULL, OPTION_IMP_COMPAT},
248 {"compat-implib", no_argument, NULL, OPTION_IMP_COMPAT},
249 {"enable-auto-image-base", no_argument, NULL, OPTION_ENABLE_AUTO_IMAGE_BASE},
250 {"disable-auto-image-base", no_argument, NULL, OPTION_DISABLE_AUTO_IMAGE_BASE},
251 {"dll-search-prefix", required_argument, NULL, OPTION_DLL_SEARCH_PREFIX},
252 {"no-default-excludes", no_argument, NULL, OPTION_NO_DEFAULT_EXCLUDES},
253 {"enable-auto-import", no_argument, NULL, OPTION_DLL_ENABLE_AUTO_IMPORT},
254 {"disable-auto-import", no_argument, NULL, OPTION_DLL_DISABLE_AUTO_IMPORT},
255 {"enable-extra-pe-debug", no_argument, NULL, OPTION_ENABLE_EXTRA_PE_DEBUG},
256 {"enable-runtime-pseudo-reloc", no_argument, NULL, OPTION_DLL_ENABLE_RUNTIME_PSEUDO_RELOC},
257 {"disable-runtime-pseudo-reloc", no_argument, NULL, OPTION_DLL_DISABLE_RUNTIME_PSEUDO_RELOC},
252b5132 258#endif
26d2d8a2 259 {"large-address-aware", no_argument, NULL, OPTION_LARGE_ADDRESS_AWARE},
3bcf5557
AM
260 {NULL, no_argument, NULL, 0}
261 };
252b5132 262
3bcf5557
AM
263 *longopts = (struct option *)
264 xrealloc (*longopts, nl * sizeof (struct option) + sizeof (xtra_long));
265 memcpy (*longopts + nl, &xtra_long, sizeof (xtra_long));
266}
252b5132
RH
267
268/* PE/WIN32; added routines to get the subsystem type, heap and/or stack
4cd89863 269 parameters which may be input from the command line. */
252b5132
RH
270
271typedef struct
272{
273 void *ptr;
274 int size;
275 int value;
276 char *symbol;
277 int inited;
278} definfo;
279
280#define D(field,symbol,def) {&pe.field,sizeof(pe.field), def, symbol,0}
281
282static definfo init[] =
283{
284 /* imagebase must be first */
285#define IMAGEBASEOFF 0
286 D(ImageBase,"__image_base__", NT_EXE_IMAGE_BASE),
287#define DLLOFF 1
1069dd8d 288 {&dll, sizeof(dll), 0, "__dll__", 0},
dffc6a64
KT
289#define MSIMAGEBASEOFF 2
290 D(ImageBase, U ("__ImageBase"), NT_EXE_IMAGE_BASE),
252b5132
RH
291 D(SectionAlignment,"__section_alignment__", PE_DEF_SECTION_ALIGNMENT),
292 D(FileAlignment,"__file_alignment__", PE_DEF_FILE_ALIGNMENT),
293 D(MajorOperatingSystemVersion,"__major_os_version__", 4),
294 D(MinorOperatingSystemVersion,"__minor_os_version__", 0),
295 D(MajorImageVersion,"__major_image_version__", 1),
296 D(MinorImageVersion,"__minor_image_version__", 0),
7148cc28 297#if defined(TARGET_IS_armpe) || defined(TARGET_IS_arm_wince_pe)
53baae48 298 D(MajorSubsystemVersion,"__major_subsystem_version__", 3),
344a211f 299#else
252b5132 300 D(MajorSubsystemVersion,"__major_subsystem_version__", 4),
344a211f 301#endif
252b5132 302 D(MinorSubsystemVersion,"__minor_subsystem_version__", 0),
2be9b2c7 303 D(Subsystem,"__subsystem__", ${SUBSYSTEM}),
3763134d 304 D(SizeOfStackReserve,"__size_of_stack_reserve__", 0x200000),
252b5132
RH
305 D(SizeOfStackCommit,"__size_of_stack_commit__", 0x1000),
306 D(SizeOfHeapReserve,"__size_of_heap_reserve__", 0x100000),
307 D(SizeOfHeapCommit,"__size_of_heap_commit__", 0x1000),
308 D(LoaderFlags,"__loader_flags__", 0x0),
309 { NULL, 0, 0, NULL, 0 }
310};
311
4cd89863 312
252b5132 313static void
0c7a8e5a 314gld_${EMULATION_NAME}_list_options (FILE *file)
252b5132
RH
315{
316 fprintf (file, _(" --base_file <basefile> Generate a base file for relocatable DLLs\n"));
317 fprintf (file, _(" --dll Set image base to the default for DLLs\n"));
318 fprintf (file, _(" --file-alignment <size> Set file alignment\n"));
319 fprintf (file, _(" --heap <size> Set initial size of the heap\n"));
320 fprintf (file, _(" --image-base <address> Set start address of the executable\n"));
321 fprintf (file, _(" --major-image-version <number> Set version number of the executable\n"));
322 fprintf (file, _(" --major-os-version <number> Set minimum required OS version\n"));
323 fprintf (file, _(" --major-subsystem-version <number> Set minimum required OS subsystem version\n"));
324 fprintf (file, _(" --minor-image-version <number> Set revision number of the executable\n"));
325 fprintf (file, _(" --minor-os-version <number> Set minimum required OS revision\n"));
326 fprintf (file, _(" --minor-subsystem-version <number> Set minimum required OS subsystem revision\n"));
327 fprintf (file, _(" --section-alignment <size> Set section alignment\n"));
328 fprintf (file, _(" --stack <size> Set size of the initial stack\n"));
329 fprintf (file, _(" --subsystem <name>[:<version>] Set required OS subsystem [& version]\n"));
330 fprintf (file, _(" --support-old-code Support interworking with old code\n"));
6f798e5c 331 fprintf (file, _(" --thumb-entry=<symbol> Set the entry point to be Thumb <symbol>\n"));
c6c37250 332#ifdef DLL_SUPPORT
252b5132
RH
333 fprintf (file, _(" --add-stdcall-alias Export symbols with and without @nn\n"));
334 fprintf (file, _(" --disable-stdcall-fixup Don't link _sym to _sym@nn\n"));
335 fprintf (file, _(" --enable-stdcall-fixup Link _sym to _sym@nn without warnings\n"));
336 fprintf (file, _(" --exclude-symbols sym,sym,... Exclude symbols from automatic export\n"));
b34976b6 337 fprintf (file, _(" --exclude-libs lib,lib,... Exclude libraries from automatic export\n"));
252b5132
RH
338 fprintf (file, _(" --export-all-symbols Automatically export all globals to DLL\n"));
339 fprintf (file, _(" --kill-at Remove @nn from exported symbols\n"));
340 fprintf (file, _(" --out-implib <file> Generate import library\n"));
341 fprintf (file, _(" --output-def <file> Generate a .DEF file for the built DLL\n"));
0752a404 342 fprintf (file, _(" --warn-duplicate-exports Warn about duplicate exports.\n"));
e3c8793a
NC
343 fprintf (file, _(" --compat-implib Create backward compatible import libs;\n\
344 create __imp_<SYMBOL> as well.\n"));
345 fprintf (file, _(" --enable-auto-image-base Automatically choose image base for DLLs\n\
346 unless user specifies one\n"));
5f577f7d 347 fprintf (file, _(" --disable-auto-image-base Do not auto-choose image base. (default)\n"));
489d0400
NC
348 fprintf (file, _(" --dll-search-prefix=<string> When linking dynamically to a dll without\n\
349 an importlib, use <string><basename>.dll\n\
e3c8793a 350 in preference to lib<basename>.dll \n"));
489d0400 351 fprintf (file, _(" --enable-auto-import Do sophistcated linking of _sym to\n\
e3c8793a 352 __imp_sym for DATA references\n"));
decc3638 353 fprintf (file, _(" --disable-auto-import Do not auto-import DATA items from DLLs\n"));
2fa9fc65 354 fprintf (file, _(" --enable-runtime-pseudo-reloc Work around auto-import limitations by\n\
489d0400
NC
355 adding pseudo-relocations resolved at\n\
356 runtime.\n"));
2fa9fc65
NC
357 fprintf (file, _(" --disable-runtime-pseudo-reloc Do not add runtime pseudo-relocations for\n\
358 auto-imported DATA.\n"));
e3c8793a
NC
359 fprintf (file, _(" --enable-extra-pe-debug Enable verbose debug output when building\n\
360 or linking to DLLs (esp. auto-import)\n"));
252b5132 361#endif
26d2d8a2
BF
362 fprintf (file, _(" --large-address-aware Executable supports virtual addresses\n\
363 greater than 2 gigabytes\n"));
252b5132
RH
364}
365
4cd89863 366
252b5132 367static void
0c7a8e5a 368set_pe_name (char *name, long val)
252b5132
RH
369{
370 int i;
4cd89863
NC
371
372 /* Find the name and set it. */
252b5132
RH
373 for (i = 0; init[i].ptr; i++)
374 {
375 if (strcmp (name, init[i].symbol) == 0)
376 {
377 init[i].value = val;
378 init[i].inited = 1;
dffc6a64
KT
379 if (strcmp (name,"__image_base__") == 0)
380 set_pe_name (U ("__ImageBase"), val);
252b5132
RH
381 return;
382 }
383 }
939ba9d0 384 abort ();
252b5132
RH
385}
386
387
388static void
0c7a8e5a 389set_pe_subsystem (void)
252b5132
RH
390{
391 const char *sver;
33f362e1
NC
392 const char *entry;
393 const char *initial_symbol_char;
394 char *end;
252b5132
RH
395 int len;
396 int i;
33f362e1
NC
397 int subsystem;
398 unsigned long temp_subsystem;
3fc90ddb 399 static const struct
252b5132
RH
400 {
401 const char *name;
402 const int value;
403 const char *entry;
404 }
405 v[] =
406 {
33f362e1 407 { "native", 1, "NtProcessStartup" },
2be9b2c7
ILT
408 { "windows", 2, "WinMainCRTStartup" },
409 { "console", 3, "mainCRTStartup" },
33f362e1 410 { "posix", 7, "__PosixProcessStartup"},
00479ba8 411 { "wince", 9, "WinMainCRTStartup" },
33f362e1
NC
412 { "xbox", 14, "mainCRTStartup" },
413 { NULL, 0, NULL }
252b5132 414 };
33f362e1
NC
415 /* Entry point name for arbitrary subsystem numbers. */
416 static const char default_entry[] = "mainCRTStartup";
252b5132 417
33f362e1 418 /* Check for the presence of a version number. */
252b5132
RH
419 sver = strchr (optarg, ':');
420 if (sver == NULL)
421 len = strlen (optarg);
422 else
423 {
252b5132
RH
424 len = sver - optarg;
425 set_pe_name ("__major_subsystem_version__",
426 strtoul (sver + 1, &end, 0));
427 if (*end == '.')
428 set_pe_name ("__minor_subsystem_version__",
429 strtoul (end + 1, &end, 0));
430 if (*end != '\0')
431 einfo (_("%P: warning: bad version number in -subsystem option\n"));
432 }
433
33f362e1
NC
434 /* Check for numeric subsystem. */
435 temp_subsystem = strtoul (optarg, & end, 0);
436 if ((*end == ':' || *end == '\0') && (temp_subsystem < 65536))
252b5132 437 {
33f362e1
NC
438 /* Search list for a numeric match to use its entry point. */
439 for (i = 0; v[i].name; i++)
440 if (v[i].value == (int) temp_subsystem)
441 break;
442
443 /* If no match, use the default. */
444 if (v[i].name != NULL)
445 entry = v[i].entry;
446 else
447 entry = default_entry;
448
449 /* Use this subsystem. */
450 subsystem = (int) temp_subsystem;
451 }
452 else
453 {
454 /* Search for subsystem by name. */
455 for (i = 0; v[i].name; i++)
456 if (strncmp (optarg, v[i].name, len) == 0
457 && v[i].name[len] == '\0')
458 break;
252b5132 459
33f362e1
NC
460 if (v[i].name == NULL)
461 {
462 einfo (_("%P%F: invalid subsystem type %s\n"), optarg);
252b5132
RH
463 return;
464 }
33f362e1
NC
465
466 entry = v[i].entry;
467 subsystem = v[i].value;
252b5132 468 }
3fc90ddb 469
33f362e1
NC
470 set_pe_name ("__subsystem__", subsystem);
471
472 initial_symbol_char = ${INITIAL_SYMBOL_CHAR};
473 if (*initial_symbol_char != '\0')
474 {
475 char *alc_entry;
476
a359509e 477 /* lang_default_entry expects its argument to be permanently
33f362e1
NC
478 allocated, so we don't free this string. */
479 alc_entry = xmalloc (strlen (initial_symbol_char)
480 + strlen (entry)
481 + 1);
482 strcpy (alc_entry, initial_symbol_char);
483 strcat (alc_entry, entry);
484 entry = alc_entry;
485 }
486
a359509e 487 lang_default_entry (entry);
33f362e1
NC
488
489 return;
252b5132
RH
490}
491
492
252b5132 493static void
0c7a8e5a 494set_pe_value (char *name)
252b5132
RH
495{
496 char *end;
3fc90ddb 497
252b5132 498 set_pe_name (name, strtoul (optarg, &end, 0));
3fc90ddb 499
252b5132
RH
500 if (end == optarg)
501 einfo (_("%P%F: invalid hex number for PE parameter '%s'\n"), optarg);
502
503 optarg = end;
504}
505
4cd89863 506
252b5132 507static void
0c7a8e5a 508set_pe_stack_heap (char *resname, char *comname)
252b5132
RH
509{
510 set_pe_value (resname);
3fc90ddb 511
252b5132
RH
512 if (*optarg == ',')
513 {
514 optarg++;
515 set_pe_value (comname);
516 }
517 else if (*optarg)
518 einfo (_("%P%F: strange hex info for PE parameter '%s'\n"), optarg);
519}
520
521
3bcf5557 522static bfd_boolean
0c7a8e5a 523gld${EMULATION_NAME}_handle_option (int optc)
252b5132 524{
252b5132
RH
525 switch (optc)
526 {
527 default:
3bcf5557 528 return FALSE;
252b5132
RH
529
530 case OPTION_BASE_FILE:
0c7a8e5a 531 link_info.base_file = fopen (optarg, FOPEN_WB);
252b5132
RH
532 if (link_info.base_file == NULL)
533 {
534 /* xgettext:c-format */
535 fprintf (stderr, _("%s: Can't open base file %s\n"),
536 program_name, optarg);
537 xexit (1);
538 }
539 break;
540
4cd89863 541 /* PE options. */
3fc90ddb 542 case OPTION_HEAP:
252b5132
RH
543 set_pe_stack_heap ("__size_of_heap_reserve__", "__size_of_heap_commit__");
544 break;
3fc90ddb 545 case OPTION_STACK:
252b5132
RH
546 set_pe_stack_heap ("__size_of_stack_reserve__", "__size_of_stack_commit__");
547 break;
548 case OPTION_SUBSYSTEM:
549 set_pe_subsystem ();
550 break;
551 case OPTION_MAJOR_OS_VERSION:
552 set_pe_value ("__major_os_version__");
553 break;
554 case OPTION_MINOR_OS_VERSION:
555 set_pe_value ("__minor_os_version__");
556 break;
557 case OPTION_MAJOR_SUBSYSTEM_VERSION:
558 set_pe_value ("__major_subsystem_version__");
559 break;
560 case OPTION_MINOR_SUBSYSTEM_VERSION:
561 set_pe_value ("__minor_subsystem_version__");
562 break;
563 case OPTION_MAJOR_IMAGE_VERSION:
564 set_pe_value ("__major_image_version__");
565 break;
566 case OPTION_MINOR_IMAGE_VERSION:
567 set_pe_value ("__minor_image_version__");
568 break;
569 case OPTION_FILE_ALIGNMENT:
570 set_pe_value ("__file_alignment__");
571 break;
572 case OPTION_SECTION_ALIGNMENT:
573 set_pe_value ("__section_alignment__");
574 break;
575 case OPTION_DLL:
576 set_pe_name ("__dll__", 1);
577 break;
578 case OPTION_IMAGE_BASE:
579 set_pe_value ("__image_base__");
580 break;
581 case OPTION_SUPPORT_OLD_CODE:
582 support_old_code = 1;
583 break;
6f798e5c
NC
584 case OPTION_THUMB_ENTRY:
585 thumb_entry_symbol = optarg;
586 break;
c6c37250 587#ifdef DLL_SUPPORT
252b5132
RH
588 case OPTION_OUT_DEF:
589 pe_out_def_filename = xstrdup (optarg);
590 break;
591 case OPTION_EXPORT_ALL:
592 pe_dll_export_everything = 1;
593 break;
594 case OPTION_EXCLUDE_SYMBOLS:
70b0be79
CF
595 pe_dll_add_excludes (optarg, 0);
596 break;
597 case OPTION_EXCLUDE_LIBS:
598 pe_dll_add_excludes (optarg, 1);
252b5132
RH
599 break;
600 case OPTION_KILL_ATS:
601 pe_dll_kill_ats = 1;
602 break;
603 case OPTION_STDCALL_ALIASES:
604 pe_dll_stdcall_aliases = 1;
605 break;
606 case OPTION_ENABLE_STDCALL_FIXUP:
607 pe_enable_stdcall_fixup = 1;
608 break;
609 case OPTION_DISABLE_STDCALL_FIXUP:
610 pe_enable_stdcall_fixup = 0;
611 break;
612 case OPTION_IMPLIB_FILENAME:
613 pe_implib_filename = xstrdup (optarg);
614 break;
870df5dc
NC
615 case OPTION_WARN_DUPLICATE_EXPORTS:
616 pe_dll_warn_dup_exports = 1;
617 break;
618 case OPTION_IMP_COMPAT:
619 pe_dll_compat_implib = 1;
620 break;
5f577f7d
DD
621 case OPTION_ENABLE_AUTO_IMAGE_BASE:
622 pe_enable_auto_image_base = 1;
623 break;
624 case OPTION_DISABLE_AUTO_IMAGE_BASE:
625 pe_enable_auto_image_base = 0;
626 break;
627427de 627 case OPTION_DLL_SEARCH_PREFIX:
939ba9d0 628 pe_dll_search_prefix = xstrdup (optarg);
627427de 629 break;
1122a5fc
NC
630 case OPTION_NO_DEFAULT_EXCLUDES:
631 pe_dll_do_default_excludes = 0;
632 break;
decc3638 633 case OPTION_DLL_ENABLE_AUTO_IMPORT:
e0076ab3 634 link_info.pei386_auto_import = 1;
decc3638
CW
635 break;
636 case OPTION_DLL_DISABLE_AUTO_IMPORT:
e0076ab3 637 link_info.pei386_auto_import = 0;
decc3638 638 break;
2fa9fc65
NC
639 case OPTION_DLL_ENABLE_RUNTIME_PSEUDO_RELOC:
640 link_info.pei386_runtime_pseudo_reloc = 1;
641 break;
642 case OPTION_DLL_DISABLE_RUNTIME_PSEUDO_RELOC:
643 link_info.pei386_runtime_pseudo_reloc = 0;
644 break;
decc3638
CW
645 case OPTION_ENABLE_EXTRA_PE_DEBUG:
646 pe_dll_extra_pe_debug = 1;
647 break;
c6c37250 648#endif
26d2d8a2
BF
649 case OPTION_LARGE_ADDRESS_AWARE:
650 real_flags |= IMAGE_FILE_LARGE_ADDRESS_AWARE;
651 break;
252b5132 652 }
3bcf5557 653 return TRUE;
252b5132
RH
654}
655\f
5f577f7d 656
2ef53d66 657#ifdef DLL_SUPPORT
3fc90ddb 658static unsigned long
5f577f7d
DD
659strhash (const char *str)
660{
661 const unsigned char *s;
662 unsigned long hash;
663 unsigned int c;
664 unsigned int len;
665
666 hash = 0;
667 len = 0;
668 s = (const unsigned char *) str;
669 while ((c = *s++) != '\0')
670 {
671 hash += c + (c << 17);
672 hash ^= hash >> 2;
673 ++len;
674 }
675 hash += len + (len << 17);
676 hash ^= hash >> 2;
677
678 return hash;
679}
680
4cd89863
NC
681/* Use the output file to create a image base for relocatable DLLs. */
682
5f577f7d
DD
683static unsigned long
684compute_dll_image_base (const char *ofile)
685{
686 unsigned long hash = strhash (ofile);
2c7fd14a 687 return 0x61300000 + ((hash << 16) & 0x0FFC0000);
5f577f7d 688}
2ef53d66 689#endif
5f577f7d 690
252b5132
RH
691/* Assign values to the special symbols before the linker script is
692 read. */
693
694static void
0c7a8e5a 695gld_${EMULATION_NAME}_set_symbols (void)
252b5132
RH
696{
697 /* Run through and invent symbols for all the
4cd89863 698 names and insert the defaults. */
252b5132
RH
699 int j;
700 lang_statement_list_type *save;
701
702 if (!init[IMAGEBASEOFF].inited)
703 {
1049f94e 704 if (link_info.relocatable)
252b5132 705 init[IMAGEBASEOFF].value = 0;
db8acf26 706 else if (init[DLLOFF].value || (link_info.shared && !link_info.pie))
2ef53d66 707#ifdef DLL_SUPPORT
5f577f7d
DD
708 init[IMAGEBASEOFF].value = (pe_enable_auto_image_base) ?
709 compute_dll_image_base (output_filename) : NT_DLL_IMAGE_BASE;
2ef53d66
L
710#else
711 init[IMAGEBASEOFF].value = NT_DLL_IMAGE_BASE;
712#endif
252b5132
RH
713 else
714 init[IMAGEBASEOFF].value = NT_EXE_IMAGE_BASE;
dffc6a64 715 init[MSIMAGEBASEOFF].value = init[IMAGEBASEOFF].value;
252b5132
RH
716 }
717
1049f94e
AM
718 /* Don't do any symbol assignments if this is a relocatable link. */
719 if (link_info.relocatable)
252b5132
RH
720 return;
721
4cd89863 722 /* Glue the assignments into the abs section. */
252b5132
RH
723 save = stat_ptr;
724
725 stat_ptr = &(abs_output_section->children);
726
727 for (j = 0; init[j].ptr; j++)
728 {
729 long val = init[j].value;
730 lang_assignment_statement_type *rv;
2c382fb6
AM
731 rv = lang_add_assignment (exp_assop ('=', init[j].symbol,
732 exp_intop (val)));
939ba9d0
NC
733 if (init[j].size == sizeof (short))
734 *(short *) init[j].ptr = val;
735 else if (init[j].size == sizeof (int))
736 *(int *) init[j].ptr = val;
737 else if (init[j].size == sizeof (long))
738 *(long *) init[j].ptr = val;
252b5132 739 /* This might be a long long or other special type. */
939ba9d0
NC
740 else if (init[j].size == sizeof (bfd_vma))
741 *(bfd_vma *) init[j].ptr = val;
742 else abort ();
252b5132
RH
743 if (j == IMAGEBASEOFF)
744 image_base_statement = rv;
745 }
4cd89863 746 /* Restore the pointer. */
252b5132 747 stat_ptr = save;
3fc90ddb 748
252b5132
RH
749 if (pe.FileAlignment >
750 pe.SectionAlignment)
751 {
752 einfo (_("%P: warning, file alignment > section alignment.\n"));
753 }
754}
755
756/* This is called after the linker script and the command line options
757 have been read. */
758
759static void
0c7a8e5a 760gld_${EMULATION_NAME}_after_parse (void)
252b5132
RH
761{
762 /* The Windows libraries are designed for the linker to treat the
763 entry point as an undefined symbol. Otherwise, the .obj that
764 defines mainCRTStartup is brought in because it is the first
765 encountered in libc.lib and it has other symbols in it which will
766 be pulled in by the link process. To avoid this, we act as
767 though the user specified -u with the entry point symbol.
768
769 This function is called after the linker script and command line
770 options have been read, so at this point we know the right entry
771 point. This function is called before the input files are
772 opened, so registering the symbol as undefined will make a
773 difference. */
774
1049f94e 775 if (! link_info.relocatable && entry_symbol.name != NULL)
e3e942e9 776 ldlang_add_undef (entry_symbol.name);
252b5132
RH
777}
778
aa3d9aba
NC
779/* pe-dll.c directly accesses pe_data_import_dll,
780 so it must be defined outside of #ifdef DLL_SUPPORT.
781 Note - this variable is deliberately not initialised.
782 This allows it to be treated as a common varaible, and only
783 exist in one incarnation in a multiple target enabled linker. */
784char * pe_data_import_dll;
72358f65 785
2ef53d66 786#ifdef DLL_SUPPORT
252b5132
RH
787static struct bfd_link_hash_entry *pe_undef_found_sym;
788
b34976b6 789static bfd_boolean
0c7a8e5a 790pe_undef_cdecl_match (struct bfd_link_hash_entry *h, void *inf)
252b5132 791{
decc3638 792 int sl;
0c7a8e5a 793 char *string = inf;
4cd89863 794
0c7a8e5a 795 sl = strlen (string);
252b5132
RH
796 if (h->type == bfd_link_hash_defined
797 && strncmp (h->root.string, string, sl) == 0
798 && h->root.string[sl] == '@')
decc3638
CW
799 {
800 pe_undef_found_sym = h;
b34976b6 801 return FALSE;
decc3638 802 }
b34976b6 803 return TRUE;
252b5132
RH
804}
805
806static void
0c7a8e5a 807pe_fixup_stdcalls (void)
252b5132
RH
808{
809 static int gave_warning_message = 0;
810 struct bfd_link_hash_entry *undef, *sym;
c9e38879 811
3fc90ddb 812 if (pe_dll_extra_pe_debug)
c9e38879 813 printf ("%s\n", __FUNCTION__);
3fc90ddb 814
f6e332e6 815 for (undef = link_info.hash->undefs; undef; undef=undef->u.undef.next)
252b5132 816 if (undef->type == bfd_link_hash_undefined)
252b5132 817 {
c9e38879
NC
818 char* at = strchr (undef->root.string, '@');
819 int lead_at = (*undef->root.string == '@');
820 /* For now, don't try to fixup fastcall symbols. */
b34976b6 821
c9e38879
NC
822 if (at && !lead_at)
823 {
824 /* The symbol is a stdcall symbol, so let's look for a
825 cdecl symbol with the same name and resolve to that. */
826 char *cname = xstrdup (undef->root.string /* + lead_at */);
827 at = strchr (cname, '@');
828 *at = 0;
829 sym = bfd_link_hash_lookup (link_info.hash, cname, 0, 0, 1);
830
831 if (sym && sym->type == bfd_link_hash_defined)
832 {
833 undef->type = bfd_link_hash_defined;
834 undef->u.def.value = sym->u.def.value;
835 undef->u.def.section = sym->u.def.section;
4cd89863 836
c9e38879
NC
837 if (pe_enable_stdcall_fixup == -1)
838 {
839 einfo (_("Warning: resolving %s by linking to %s\n"),
840 undef->root.string, cname);
841 if (! gave_warning_message)
842 {
843 gave_warning_message = 1;
939ba9d0
NC
844 einfo (_("Use --enable-stdcall-fixup to disable these warnings\n"));
845 einfo (_("Use --disable-stdcall-fixup to disable these fixups\n"));
c9e38879
NC
846 }
847 }
848 }
849 }
850 else
851 {
852 /* The symbol is a cdecl symbol, so we look for stdcall
4cd89863 853 symbols - which means scanning the whole symbol table. */
c9e38879
NC
854 pe_undef_found_sym = 0;
855 bfd_link_hash_traverse (link_info.hash, pe_undef_cdecl_match,
0c7a8e5a 856 (char *) undef->root.string);
c9e38879
NC
857 sym = pe_undef_found_sym;
858 if (sym)
859 {
860 undef->type = bfd_link_hash_defined;
861 undef->u.def.value = sym->u.def.value;
862 undef->u.def.section = sym->u.def.section;
4cd89863 863
c9e38879
NC
864 if (pe_enable_stdcall_fixup == -1)
865 {
866 einfo (_("Warning: resolving %s by linking to %s\n"),
867 undef->root.string, sym->root.string);
868 if (! gave_warning_message)
869 {
870 gave_warning_message = 1;
939ba9d0
NC
871 einfo (_("Use --enable-stdcall-fixup to disable these warnings\n"));
872 einfo (_("Use --disable-stdcall-fixup to disable these fixups\n"));
c9e38879
NC
873 }
874 }
875 }
876 }
252b5132 877 }
252b5132 878}
decc3638
CW
879
880static int
0c7a8e5a 881make_import_fixup (arelent *rel, asection *s)
decc3638 882{
fc0a2244 883 struct bfd_symbol *sym = *rel->sym_ptr_ptr;
c99b8138 884 char addend[4];
decc3638 885
3fc90ddb 886 if (pe_dll_extra_pe_debug)
c9e38879 887 printf ("arelent: %s@%#lx: add=%li\n", sym->name,
0af1713e 888 (unsigned long) rel->address, (long) rel->addend);
0d888aac 889
c99b8138 890 if (! bfd_get_section_contents (s->owner, s, addend, rel->address, sizeof (addend)))
c9e38879
NC
891 einfo (_("%C: Cannot get section contents - auto-import exception\n"),
892 s->owner, s, rel->address);
0d888aac 893
c99b8138 894 pe_create_import_fixup (rel, s, bfd_get_32 (s->owner, addend));
0d888aac 895
decc3638
CW
896 return 1;
897}
898
decc3638 899static void
0c7a8e5a 900pe_find_data_imports (void)
decc3638
CW
901{
902 struct bfd_link_hash_entry *undef, *sym;
c9e38879 903
4cd89863
NC
904 if (link_info.pei386_auto_import == 0)
905 return;
906
f6e332e6 907 for (undef = link_info.hash->undefs; undef; undef=undef->u.undef.next)
decc3638
CW
908 {
909 if (undef->type == bfd_link_hash_undefined)
1af699f4
AM
910 {
911 /* C++ symbols are *long*. */
912 char buf[4096];
c9e38879
NC
913
914 if (pe_dll_extra_pe_debug)
915 printf ("%s:%s\n", __FUNCTION__, undef->root.string);
916
1af699f4 917 sprintf (buf, "__imp_%s", undef->root.string);
decc3638 918
1af699f4 919 sym = bfd_link_hash_lookup (link_info.hash, buf, 0, 0, 1);
c9e38879 920
1af699f4
AM
921 if (sym && sym->type == bfd_link_hash_defined)
922 {
4cd89863
NC
923 bfd *b = sym->u.def.section->owner;
924 asymbol **symbols;
5c1d2f5f 925 int nsyms, i;
4cd89863
NC
926
927 if (link_info.pei386_auto_import == -1)
8524166d
NC
928 {
929 static bfd_boolean warned = FALSE;
930
931 info_msg (_("Info: resolving %s by linking to %s (auto-import)\n"),
932 undef->root.string, buf);
933
934 /* PR linker/4844. */
935 if (! warned)
936 {
937 warned = TRUE;
938 einfo (_("%P: warning: auto-importing has been activated without --enable-auto-import specified on the command line.\n\
44e36d8a 939This should work unless it involves constant data structures referencing symbols from auto-imported DLLs.\n"));
8524166d
NC
940 }
941 }
4cd89863 942
5c1d2f5f
AM
943 if (!bfd_generic_link_read_symbols (b))
944 {
945 einfo (_("%B%F: could not read symbols: %E\n"), b);
946 return;
947 }
948
949 symbols = bfd_get_outsymbols (b);
950 nsyms = bfd_get_symcount (b);
4cd89863
NC
951
952 for (i = 0; i < nsyms; i++)
953 {
00479ba8 954 if (! CONST_STRNEQ (symbols[i]->name, U ("_head_")))
4cd89863
NC
955 continue;
956
957 if (pe_dll_extra_pe_debug)
958 printf ("->%s\n", symbols[i]->name);
959
960 pe_data_import_dll = (char*) (symbols[i]->name +
00479ba8 961 sizeof (U ("_head_")) - 1);
4cd89863
NC
962 break;
963 }
964
965 pe_walk_relocs_of_symbol (&link_info, undef->root.string,
966 make_import_fixup);
967
968 /* Let's differentiate it somehow from defined. */
969 undef->type = bfd_link_hash_defweak;
970 /* We replace original name with __imp_ prefixed, this
971 1) may trash memory 2) leads to duplicate symbol generation.
972 Still, IMHO it's better than having name poluted. */
973 undef->root.string = sym->root.string;
974 undef->u.def.value = sym->u.def.value;
975 undef->u.def.section = sym->u.def.section;
1af699f4
AM
976 }
977 }
decc3638
CW
978 }
979}
252b5132 980
b34976b6 981static bfd_boolean
0c7a8e5a 982pr_sym (struct bfd_hash_entry *h, void *inf ATTRIBUTE_UNUSED)
decc3638 983{
3fc90ddb 984 if (pe_dll_extra_pe_debug)
0c7a8e5a 985 printf ("+%s\n", h->string);
c9e38879 986
b34976b6 987 return TRUE;
decc3638 988}
4b83d615 989#endif /* DLL_SUPPORT */
decc3638
CW
990
991
252b5132 992static void
0c7a8e5a 993gld_${EMULATION_NAME}_after_open (void)
252b5132 994{
4b83d615 995#ifdef DLL_SUPPORT
3fc90ddb 996 if (pe_dll_extra_pe_debug)
decc3638
CW
997 {
998 bfd *a;
999 struct bfd_link_hash_entry *sym;
c9e38879 1000
decc3638
CW
1001 printf ("%s()\n", __FUNCTION__);
1002
f6e332e6 1003 for (sym = link_info.hash->undefs; sym; sym=sym->u.undef.next)
1af699f4 1004 printf ("-%s\n", sym->root.string);
0c7a8e5a 1005 bfd_hash_traverse (&link_info.hash->table, pr_sym, NULL);
decc3638
CW
1006
1007 for (a = link_info.input_bfds; a; a = a->link_next)
c9e38879 1008 printf ("*%s\n",a->filename);
decc3638 1009 }
4b83d615 1010#endif
3fc90ddb 1011
252b5132
RH
1012 /* Pass the wacky PE command line options into the output bfd.
1013 FIXME: This should be done via a function, rather than by
1014 including an internal BFD header. */
3fc90ddb 1015
f13a99db
AM
1016 if (coff_data (link_info.output_bfd) == NULL
1017 || coff_data (link_info.output_bfd)->pe == 0)
1018 einfo (_("%F%P: cannot perform PE operations on non PE output file '%B'.\n"),
1019 link_info.output_bfd);
252b5132 1020
f13a99db
AM
1021 pe_data (link_info.output_bfd)->pe_opthdr = pe;
1022 pe_data (link_info.output_bfd)->dll = init[DLLOFF].value;
1023 pe_data (link_info.output_bfd)->real_flags |= real_flags;
252b5132 1024
c6c37250 1025#ifdef DLL_SUPPORT
252b5132
RH
1026 if (pe_enable_stdcall_fixup) /* -1=warn or 1=disable */
1027 pe_fixup_stdcalls ();
1028
f13a99db 1029 pe_process_import_defs (link_info.output_bfd, &link_info);
939ba9d0 1030
3fc90ddb 1031 pe_find_data_imports ();
decc3638 1032
7148cc28
NC
1033#if defined (TARGET_IS_i386pe) \
1034 || defined (TARGET_IS_armpe) \
1035 || defined (TARGET_IS_arm_epoc_pe) \
1036 || defined (TARGET_IS_arm_wince_pe)
1049f94e 1037 if (!link_info.relocatable)
f13a99db 1038 pe_dll_build_sections (link_info.output_bfd, &link_info);
344a211f 1039 else
f13a99db 1040 pe_exe_build_sections (link_info.output_bfd, &link_info);
7148cc28
NC
1041#else
1042 if (link_info.shared)
f13a99db 1043 pe_dll_build_sections (link_info.output_bfd, &link_info);
344a211f 1044#endif
7148cc28 1045#endif /* DLL_SUPPORT */
252b5132 1046
7148cc28 1047#if defined(TARGET_IS_armpe) || defined(TARGET_IS_arm_epoc_pe) || defined(TARGET_IS_arm_wince_pe)
f13a99db 1048 if (strstr (bfd_get_target (link_info.output_bfd), "arm") == NULL)
f11523b0
NC
1049 {
1050 /* The arm backend needs special fields in the output hash structure.
1051 These will only be created if the output format is an arm format,
1052 hence we do not support linking and changing output formats at the
1053 same time. Use a link followed by objcopy to change output formats. */
1054 einfo ("%F%X%P: error: cannot change output format whilst linking ARM binaries\n");
1055 return;
1056 }
252b5132
RH
1057 {
1058 /* Find a BFD that can hold the interworking stubs. */
1059 LANG_FOR_EACH_INPUT_STATEMENT (is)
1060 {
7148cc28 1061 if (bfd_arm_get_bfd_for_interworking (is->the_bfd, & link_info))
252b5132
RH
1062 break;
1063 }
1064 }
1065#endif
c6c37250 1066
486e80e2 1067 {
486e80e2
DD
1068 /* This next chunk of code tries to detect the case where you have
1069 two import libraries for the same DLL (specifically,
1070 symbolically linking libm.a and libc.a in cygwin to
1071 libcygwin.a). In those cases, it's possible for function
1072 thunks from the second implib to be used but without the
1073 head/tail objects, causing an improper import table. We detect
1074 those cases and rename the "other" import libraries to match
1075 the one the head/tail come from, so that the linker will sort
4cd89863 1076 things nicely and produce a valid import table. */
486e80e2
DD
1077
1078 LANG_FOR_EACH_INPUT_STATEMENT (is)
1079 {
1080 if (is->the_bfd->my_archive)
1081 {
1082 int idata2 = 0, reloc_count=0, is_imp = 0;
1083 asection *sec;
3fc90ddb 1084
6e45556a 1085 /* See if this is an import library thunk. */
486e80e2
DD
1086 for (sec = is->the_bfd->sections; sec; sec = sec->next)
1087 {
1088 if (strcmp (sec->name, ".idata\$2") == 0)
1089 idata2 = 1;
0112cd26 1090 if (CONST_STRNEQ (sec->name, ".idata\$"))
486e80e2
DD
1091 is_imp = 1;
1092 reloc_count += sec->reloc_count;
1093 }
3fc90ddb 1094
486e80e2
DD
1095 if (is_imp && !idata2 && reloc_count)
1096 {
6e45556a
NC
1097 /* It is, look for the reference to head and see if it's
1098 from our own library. */
486e80e2
DD
1099 for (sec = is->the_bfd->sections; sec; sec = sec->next)
1100 {
1101 int i;
6e45556a 1102 long relsize;
102c86f8 1103 asymbol **symbols;
102c86f8
NC
1104 arelent **relocs;
1105 int nrelocs;
3fc90ddb 1106
102c86f8 1107 relsize = bfd_get_reloc_upper_bound (is->the_bfd, sec);
6e45556a
NC
1108 if (relsize < 1)
1109 break;
3fc90ddb 1110
5c1d2f5f 1111 if (!bfd_generic_link_read_symbols (is->the_bfd))
6e45556a 1112 {
5c1d2f5f
AM
1113 einfo (_("%B%F: could not read symbols: %E\n"),
1114 is->the_bfd);
6e45556a
NC
1115 return;
1116 }
5c1d2f5f 1117 symbols = bfd_get_outsymbols (is->the_bfd);
3fc90ddb 1118
102c86f8
NC
1119 relocs = (arelent **) xmalloc ((size_t) relsize);
1120 nrelocs = bfd_canonicalize_reloc (is->the_bfd, sec,
f6e332e6 1121 relocs, symbols);
6e45556a
NC
1122 if (nrelocs < 0)
1123 {
1124 free (relocs);
44e36d8a 1125 einfo ("%X%P: unable to process relocs: %E\n");
6e45556a
NC
1126 return;
1127 }
3fc90ddb 1128
6e45556a 1129 for (i = 0; i < nrelocs; i++)
486e80e2 1130 {
fc0a2244 1131 struct bfd_symbol *s;
6e45556a 1132 struct bfd_link_hash_entry * blhe;
2a08daf3 1133 char *other_bfd_filename;
6e45556a 1134 char *n;
3fc90ddb 1135
486e80e2 1136 s = (relocs[i]->sym_ptr_ptr)[0];
3fc90ddb 1137
6e45556a
NC
1138 if (s->flags & BSF_LOCAL)
1139 continue;
3fc90ddb 1140
6e45556a
NC
1141 /* Thunk section with reloc to another bfd. */
1142 blhe = bfd_link_hash_lookup (link_info.hash,
1143 s->name,
b34976b6 1144 FALSE, FALSE, TRUE);
3fc90ddb 1145
6e45556a
NC
1146 if (blhe == NULL
1147 || blhe->type != bfd_link_hash_defined)
1148 continue;
3fc90ddb 1149
2a08daf3
DS
1150 other_bfd_filename
1151 = blhe->u.def.section->owner->my_archive
1152 ? bfd_get_filename (blhe->u.def.section->owner->my_archive)
1153 : bfd_get_filename (blhe->u.def.section->owner);
3fc90ddb 1154
2a08daf3
DS
1155 if (strcmp (bfd_get_filename (is->the_bfd->my_archive),
1156 other_bfd_filename) == 0)
6e45556a 1157 continue;
3fc90ddb 1158
c034e3e0 1159 /* Rename this implib to match the other one. */
2a08daf3
DS
1160 n = xmalloc (strlen (other_bfd_filename) + 1);
1161 strcpy (n, other_bfd_filename);
1162 is->the_bfd->my_archive->filename = n;
486e80e2
DD
1163 }
1164
1165 free (relocs);
6e45556a
NC
1166 /* Note - we do not free the symbols,
1167 they are now cached in the BFD. */
486e80e2
DD
1168 }
1169 }
1170 }
1171 }
1172 }
1173
c6c37250 1174 {
f0c87f88 1175 int is_ms_arch = 0;
1069dd8d 1176 bfd *cur_arch = 0;
c6c37250 1177 lang_input_statement_type *is2;
44dbf363 1178 lang_input_statement_type *is3;
1069dd8d 1179
c6c37250
DD
1180 /* Careful - this is a shell script. Watch those dollar signs! */
1181 /* Microsoft import libraries have every member named the same,
1182 and not in the right order for us to link them correctly. We
1183 must detect these and rename the members so that they'll link
1184 correctly. There are three types of objects: the head, the
1185 thunks, and the sentinel(s). The head is easy; it's the one
1186 with idata2. We assume that the sentinels won't have relocs,
1187 and the thunks will. It's easier than checking the symbol
1069dd8d 1188 table for external references. */
c6c37250
DD
1189 LANG_FOR_EACH_INPUT_STATEMENT (is)
1190 {
1191 if (is->the_bfd->my_archive)
1192 {
44dbf363 1193 char *pnt;
c6c37250 1194 bfd *arch = is->the_bfd->my_archive;
44dbf363 1195
c6c37250
DD
1196 if (cur_arch != arch)
1197 {
1198 cur_arch = arch;
1199 is_ms_arch = 1;
44dbf363
NC
1200
1201 for (is3 = is;
1202 is3 && is3->the_bfd->my_archive == arch;
1203 is3 = (lang_input_statement_type *) is3->next)
1204 {
1af699f4 1205 /* A MS dynamic import library can also contain static
44dbf363
NC
1206 members, so look for the first element with a .dll
1207 extension, and use that for the remainder of the
1208 comparisons. */
1209 pnt = strrchr (is3->the_bfd->filename, '.');
07a68a80 1210 if (pnt != NULL && strcmp (pnt, ".dll") == 0)
ff71f4f7 1211 break;
44dbf363
NC
1212 }
1213
1214 if (is3 == NULL)
1215 is_ms_arch = 0;
1216 else
c6c37250 1217 {
44dbf363
NC
1218 /* OK, found one. Now look to see if the remaining
1219 (dynamic import) members use the same name. */
1220 for (is2 = is;
1221 is2 && is2->the_bfd->my_archive == arch;
1222 is2 = (lang_input_statement_type *) is2->next)
1223 {
1224 /* Skip static members, ie anything with a .obj
1225 extension. */
1226 pnt = strrchr (is2->the_bfd->filename, '.');
1227 if (pnt != NULL && strcmp (pnt, ".obj") == 0)
1228 continue;
1229
1230 if (strcmp (is3->the_bfd->filename,
1231 is2->the_bfd->filename))
1232 {
1233 is_ms_arch = 0;
1234 break;
1235 }
1236 }
c6c37250
DD
1237 }
1238 }
1239
44dbf363
NC
1240 /* This fragment might have come from an .obj file in a Microsoft
1241 import, and not an actual import record. If this is the case,
1242 then leave the filename alone. */
1243 pnt = strrchr (is->the_bfd->filename, '.');
1244
1245 if (is_ms_arch && (strcmp (pnt, ".dll") == 0))
c6c37250 1246 {
1069dd8d 1247 int idata2 = 0, reloc_count=0;
c6c37250
DD
1248 asection *sec;
1249 char *new_name, seq;
1069dd8d 1250
c6c37250
DD
1251 for (sec = is->the_bfd->sections; sec; sec = sec->next)
1252 {
1253 if (strcmp (sec->name, ".idata\$2") == 0)
1254 idata2 = 1;
1255 reloc_count += sec->reloc_count;
1256 }
1257
1258 if (idata2) /* .idata2 is the TOC */
1259 seq = 'a';
1260 else if (reloc_count > 0) /* thunks */
1261 seq = 'b';
1262 else /* sentinel */
1263 seq = 'c';
1264
e4e24acb 1265 new_name = xmalloc (strlen (is->the_bfd->filename) + 3);
c6c37250
DD
1266 sprintf (new_name, "%s.%c", is->the_bfd->filename, seq);
1267 is->the_bfd->filename = new_name;
1268
690a460e 1269 new_name = xmalloc (strlen (is->filename) + 3);
c6c37250
DD
1270 sprintf (new_name, "%s.%c", is->filename, seq);
1271 is->filename = new_name;
1272 }
1273 }
1274 }
1275 }
54727719
NC
1276
1277 {
1278 /* The following chunk of code tries to identify jump stubs in
1279 import libraries which are dead code and eliminates them
1280 from the final link. For each exported symbol <sym>, there
1281 is a object file in the import library with a .text section
1282 and several .idata$* sections. The .text section contains the
1283 symbol definition for <sym> which is a jump stub of the form
1284 jmp *__imp_<sym>. The .idata$5 contains the symbol definition
1285 for __imp_<sym> which is the address of the slot for <sym> in
1286 the import address table. When a symbol is imported explicitly
1287 using __declspec(dllimport) declaration, the compiler generates
1288 a reference to __imp_<sym> which directly resolves to the
1289 symbol in .idata$5, in which case the jump stub code is not
1290 needed. The following code tries to identify jump stub sections
1291 in import libraries which are not referred to by anyone and
1292 marks them for exclusion from the final link. */
1293 LANG_FOR_EACH_INPUT_STATEMENT (is)
1294 {
1295 if (is->the_bfd->my_archive)
1296 {
1297 int is_imp = 0;
1298 asection *sec, *stub_sec = NULL;
1299
1300 /* See if this is an import library thunk. */
1301 for (sec = is->the_bfd->sections; sec; sec = sec->next)
1302 {
1303 if (strncmp (sec->name, ".idata\$", 7) == 0)
1304 is_imp = 1;
1305 /* The section containing the jmp stub has code
1306 and has a reloc. */
1307 if ((sec->flags & SEC_CODE) && sec->reloc_count)
1308 stub_sec = sec;
1309 }
92b93329 1310
54727719
NC
1311 if (is_imp && stub_sec)
1312 {
54727719 1313 asymbol **symbols;
5c1d2f5f 1314 long nsyms, src_count;
54727719
NC
1315 struct bfd_link_hash_entry * blhe;
1316
5c1d2f5f
AM
1317 if (!bfd_generic_link_read_symbols (is->the_bfd))
1318 {
1319 einfo (_("%B%F: could not read symbols: %E\n"),
1320 is->the_bfd);
1321 return;
1322 }
1323 symbols = bfd_get_outsymbols (is->the_bfd);
1324 nsyms = bfd_get_symcount (is->the_bfd);
54727719 1325
5c1d2f5f 1326 for (src_count = 0; src_count < nsyms; src_count++)
54727719
NC
1327 {
1328 if (symbols[src_count]->section->id == stub_sec->id)
1329 {
1330 /* This symbol belongs to the section containing
1331 the stub. */
1332 blhe = bfd_link_hash_lookup (link_info.hash,
1333 symbols[src_count]->name,
1334 FALSE, FALSE, TRUE);
1335 /* If the symbol in the stub section has no other
1336 undefined references, exclude the stub section
1337 from the final link. */
1338 if (blhe && (blhe->type == bfd_link_hash_defined)
1339 && (blhe->u.undef.next == NULL))
1340 stub_sec->flags |= SEC_EXCLUDE;
1341 }
1342 }
54727719
NC
1343 }
1344 }
1345 }
1346 }
252b5132
RH
1347}
1348\f
3fc90ddb 1349static void
0c7a8e5a 1350gld_${EMULATION_NAME}_before_allocation (void)
252b5132
RH
1351{
1352#ifdef TARGET_IS_ppcpe
c9e38879 1353 /* Here we rummage through the found bfds to collect toc information. */
252b5132
RH
1354 {
1355 LANG_FOR_EACH_INPUT_STATEMENT (is)
1356 {
1357 if (!ppc_process_before_allocation (is->the_bfd, &link_info))
1358 {
1359 /* xgettext:c-format */
1360 einfo (_("Errors encountered processing file %s\n"), is->filename);
1361 }
1362 }
1363 }
1364
c9e38879 1365 /* We have seen it all. Allocate it, and carry on. */
252b5132
RH
1366 ppc_allocate_toc_section (&link_info);
1367#endif /* TARGET_IS_ppcpe */
1368
7148cc28 1369#if defined(TARGET_IS_armpe) || defined(TARGET_IS_arm_epoc_pe) || defined(TARGET_IS_arm_wince_pe)
252b5132
RH
1370 /* FIXME: we should be able to set the size of the interworking stub
1371 section.
1372
1373 Here we rummage through the found bfds to collect glue
1374 information. FIXME: should this be based on a command line
c9e38879 1375 option? krk@cygnus.com. */
252b5132
RH
1376 {
1377 LANG_FOR_EACH_INPUT_STATEMENT (is)
1378 {
7148cc28 1379 if (! bfd_arm_process_before_allocation
252b5132
RH
1380 (is->the_bfd, & link_info, support_old_code))
1381 {
1382 /* xgettext:c-format */
44e36d8a 1383 einfo (_("Errors encountered processing file %s for interworking\n"),
252b5132
RH
1384 is->filename);
1385 }
1386 }
1387 }
1388
c9e38879 1389 /* We have seen it all. Allocate it, and carry on. */
7148cc28
NC
1390 bfd_arm_allocate_interworking_sections (& link_info);
1391#endif /* TARGET_IS_armpe || TARGET_IS_arm_epoc_pe || TARGET_IS_arm_wince_pe */
8423293d 1392
1e035701 1393 before_allocation_default ();
252b5132
RH
1394}
1395\f
690a460e 1396#ifdef DLL_SUPPORT
252b5132 1397/* This is called when an input file isn't recognized as a BFD. We
c9e38879 1398 check here for .DEF files and pull them in automatically. */
690a460e 1399
252b5132 1400static int
0c7a8e5a 1401saw_option (char *option)
252b5132
RH
1402{
1403 int i;
c9e38879
NC
1404
1405 for (i = 0; init[i].ptr; i++)
252b5132
RH
1406 if (strcmp (init[i].symbol, option) == 0)
1407 return init[i].inited;
1408 return 0;
1409}
690a460e 1410#endif /* DLL_SUPPORT */
252b5132 1411
b34976b6 1412static bfd_boolean
0c7a8e5a 1413gld_${EMULATION_NAME}_unrecognized_file (lang_input_statement_type *entry ATTRIBUTE_UNUSED)
252b5132 1414{
c6c37250 1415#ifdef DLL_SUPPORT
252b5132
RH
1416 const char *ext = entry->filename + strlen (entry->filename) - 4;
1417
1418 if (strcmp (ext, ".def") == 0 || strcmp (ext, ".DEF") == 0)
252b5132 1419 {
f2d3750d 1420 pe_def_file = def_file_parse (entry->filename, pe_def_file);
c9e38879
NC
1421
1422 if (pe_def_file)
252b5132 1423 {
c9e38879
NC
1424 int i, buflen=0, len;
1425 char *buf;
252b5132 1426
c9e38879 1427 for (i = 0; i < pe_def_file->num_exports; i++)
252b5132 1428 {
939ba9d0 1429 len = strlen (pe_def_file->exports[i].internal_name);
c9e38879
NC
1430 if (buflen < len + 2)
1431 buflen = len + 2;
252b5132 1432 }
252b5132 1433
c9e38879 1434 buf = (char *) xmalloc (buflen);
252b5132 1435
c9e38879
NC
1436 for (i = 0; i < pe_def_file->num_exports; i++)
1437 {
1438 struct bfd_link_hash_entry *h;
1439
00479ba8 1440 sprintf (buf, "%s%s", U (""), pe_def_file->exports[i].internal_name);
c9e38879 1441
b34976b6 1442 h = bfd_link_hash_lookup (link_info.hash, buf, TRUE, TRUE, TRUE);
c9e38879
NC
1443 if (h == (struct bfd_link_hash_entry *) NULL)
1444 einfo (_("%P%F: bfd_link_hash_lookup failed: %E\n"));
1445 if (h->type == bfd_link_hash_new)
1446 {
1447 h->type = bfd_link_hash_undefined;
1448 h->u.undef.abfd = NULL;
1449 bfd_link_add_undef (link_info.hash, h);
1450 }
1451 }
1452 free (buf);
1453
1454 /* def_file_print (stdout, pe_def_file); */
1455 if (pe_def_file->is_dll == 1)
1456 link_info.shared = 1;
1457
1458 if (pe_def_file->base_address != (bfd_vma)(-1))
1459 {
f13a99db
AM
1460 pe.ImageBase
1461 = pe_data (link_info.output_bfd)->pe_opthdr.ImageBase
1462 = init[IMAGEBASEOFF].value
1463 = pe_def_file->base_address;
c9e38879
NC
1464 init[IMAGEBASEOFF].inited = 1;
1465 if (image_base_statement)
f13a99db
AM
1466 image_base_statement->exp = exp_assop ('=', "__image_base__",
1467 exp_intop (pe.ImageBase));
c9e38879 1468 }
252b5132 1469
c9e38879
NC
1470 if (pe_def_file->stack_reserve != -1
1471 && ! saw_option ("__size_of_stack_reserve__"))
1472 {
1473 pe.SizeOfStackReserve = pe_def_file->stack_reserve;
1474 if (pe_def_file->stack_commit != -1)
1475 pe.SizeOfStackCommit = pe_def_file->stack_commit;
1476 }
1477 if (pe_def_file->heap_reserve != -1
1478 && ! saw_option ("__size_of_heap_reserve__"))
1479 {
1480 pe.SizeOfHeapReserve = pe_def_file->heap_reserve;
1481 if (pe_def_file->heap_commit != -1)
1482 pe.SizeOfHeapCommit = pe_def_file->heap_commit;
1483 }
b34976b6 1484 return TRUE;
c9e38879 1485 }
252b5132 1486 }
252b5132 1487#endif
b34976b6 1488 return FALSE;
252b5132
RH
1489}
1490
b34976b6 1491static bfd_boolean
0c7a8e5a 1492gld_${EMULATION_NAME}_recognized_file (lang_input_statement_type *entry ATTRIBUTE_UNUSED)
252b5132 1493{
c6c37250 1494#ifdef DLL_SUPPORT
252b5132 1495#ifdef TARGET_IS_i386pe
c6c37250 1496 pe_dll_id_target ("pei-i386");
344a211f
NC
1497#endif
1498#ifdef TARGET_IS_shpe
1499 pe_dll_id_target ("pei-shl");
1500#endif
1501#ifdef TARGET_IS_mipspe
1502 pe_dll_id_target ("pei-mips");
1503#endif
1504#ifdef TARGET_IS_armpe
1505 pe_dll_id_target ("pei-arm-little");
7148cc28
NC
1506#endif
1507#ifdef TARGET_IS_arm_epoc_pe
1508 pe_dll_id_target ("epoc-pei-arm-little");
1509#endif
1510#ifdef TARGET_IS_arm_wince_pe
1511 pe_dll_id_target ("pei-arm-wince-little");
c6c37250 1512#endif
ff2bdb9c
CF
1513 if (pe_bfd_is_dll (entry->the_bfd))
1514 return pe_implied_import_dll (entry->filename);
252b5132 1515#endif
b34976b6 1516 return FALSE;
252b5132
RH
1517}
1518
1519static void
0c7a8e5a 1520gld_${EMULATION_NAME}_finish (void)
252b5132 1521{
7148cc28 1522#if defined(TARGET_IS_armpe) || defined(TARGET_IS_arm_epoc_pe) || defined(TARGET_IS_arm_wince_pe)
6f798e5c
NC
1523 struct bfd_link_hash_entry * h;
1524
1525 if (thumb_entry_symbol != NULL)
1526 {
b34976b6
AM
1527 h = bfd_link_hash_lookup (link_info.hash, thumb_entry_symbol,
1528 FALSE, FALSE, TRUE);
3fc90ddb 1529
6f798e5c
NC
1530 if (h != (struct bfd_link_hash_entry *) NULL
1531 && (h->type == bfd_link_hash_defined
1532 || h->type == bfd_link_hash_defweak)
1533 && h->u.def.section->output_section != NULL)
1534 {
1535 static char buffer[32];
1536 bfd_vma val;
3fc90ddb 1537
6f798e5c
NC
1538 /* Special procesing is required for a Thumb entry symbol. The
1539 bottom bit of its address must be set. */
1540 val = (h->u.def.value
f13a99db 1541 + bfd_get_section_vma (link_info.output_bfd,
6f798e5c
NC
1542 h->u.def.section->output_section)
1543 + h->u.def.section->output_offset);
3fc90ddb 1544
6f798e5c 1545 val |= 1;
3fc90ddb 1546
6f798e5c
NC
1547 /* Now convert this value into a string and store it in entry_symbol
1548 where the lang_finish() function will pick it up. */
1549 buffer[0] = '0';
1550 buffer[1] = 'x';
3fc90ddb 1551
6f798e5c 1552 sprintf_vma (buffer + 2, val);
3fc90ddb 1553
e3e942e9 1554 if (entry_symbol.name != NULL && entry_from_cmdline)
6f798e5c 1555 einfo (_("%P: warning: '--thumb-entry %s' is overriding '-e %s'\n"),
e3e942e9
AM
1556 thumb_entry_symbol, entry_symbol.name);
1557 entry_symbol.name = buffer;
6f798e5c
NC
1558 }
1559 else
c58dea77 1560 einfo (_("%P: warning: cannot find thumb start symbol %s\n"), thumb_entry_symbol);
6f798e5c 1561 }
7148cc28 1562#endif /* defined(TARGET_IS_armpe) || defined(TARGET_IS_arm_epoc_pe) || defined(TARGET_IS_arm_wince_pe) */
6f798e5c 1563
1e035701
AM
1564 finish_default ();
1565
c6c37250 1566#ifdef DLL_SUPPORT
2b817be1
NC
1567 if (link_info.shared
1568#if !defined(TARGET_IS_shpe) && !defined(TARGET_IS_mipspe)
1049f94e 1569 || (!link_info.relocatable && pe_def_file->num_exports != 0)
2b817be1
NC
1570#endif
1571 )
252b5132 1572 {
f13a99db 1573 pe_dll_fill_sections (link_info.output_bfd, &link_info);
252b5132
RH
1574 if (pe_implib_filename)
1575 pe_dll_generate_implib (pe_def_file, pe_implib_filename);
1576 }
344a211f 1577#if defined(TARGET_IS_shpe) || defined(TARGET_IS_mipspe)
690a460e 1578 /* ARM doesn't need relocs. */
344a211f
NC
1579 else
1580 {
f13a99db 1581 pe_exe_fill_sections (link_info.output_bfd, &link_info);
344a211f
NC
1582 }
1583#endif
3fc90ddb 1584
252b5132
RH
1585 if (pe_out_def_filename)
1586 pe_dll_generate_def_file (pe_out_def_filename);
690a460e 1587#endif /* DLL_SUPPORT */
decc3638 1588
c9e38879 1589 /* I don't know where .idata gets set as code, but it shouldn't be. */
decc3638 1590 {
f13a99db 1591 asection *asec = bfd_get_section_by_name (link_info.output_bfd, ".idata");
c9e38879 1592
decc3638
CW
1593 if (asec)
1594 {
1af699f4
AM
1595 asec->flags &= ~SEC_CODE;
1596 asec->flags |= SEC_DATA;
decc3638
CW
1597 }
1598 }
252b5132
RH
1599}
1600
1601\f
1602/* Place an orphan section.
1603
1604 We use this to put sections in a reasonable place in the file, and
1605 to ensure that they are aligned as required.
1606
1607 We handle grouped sections here as well. A section named .foo$nn
1608 goes into the output section .foo. All grouped sections are sorted
1609 by name.
1610
1611 Grouped sections for the default sections are handled by the
1612 default linker script using wildcards, and are sorted by
1613 sort_sections. */
1614
c2edb4b8 1615static lang_output_section_statement_type *
8a99a385
AM
1616gld_${EMULATION_NAME}_place_orphan (asection *s,
1617 const char *secname,
1618 int constraint)
252b5132 1619{
bcacc0f5 1620 const char *orig_secname = secname;
f0c87f88 1621 char *dollar = NULL;
aea4bd9d 1622 lang_output_section_statement_type *os;
5ba47421 1623 lang_statement_list_type add_child;
252b5132 1624
252b5132 1625 /* Look through the script to see where to place this section. */
afd7a018
AM
1626 if (!link_info.relocatable
1627 && (dollar = strchr (secname, '$')) != NULL)
6eec49fc 1628 {
bcacc0f5 1629 size_t len = dollar - secname;
afd7a018 1630 char *newname = xmalloc (len + 1);
bcacc0f5 1631 memcpy (newname, secname, len);
afd7a018
AM
1632 newname[len] = '\0';
1633 secname = newname;
6eec49fc 1634 }
252b5132 1635
5ba47421
AM
1636 lang_list_init (&add_child);
1637
8a99a385
AM
1638 if (constraint == 0
1639 && (os = lang_output_section_find (secname)) != NULL
bcacc0f5
AM
1640 && os->bfd_section != NULL
1641 && (os->bfd_section->flags == 0
ae7fb08f
AM
1642 || ((s->flags ^ os->bfd_section->flags)
1643 & (SEC_LOAD | SEC_ALLOC)) == 0))
5ba47421 1644 {
ae7fb08f 1645 /* We already have an output section statement with this
bcacc0f5 1646 name, and its bfd section has compatible flags.
afd7a018
AM
1647 If the section already exists but does not have any flags set,
1648 then it has been created by the linker, probably as a result of
1649 a --section-start command line switch. */
7b986e99 1650 lang_add_section (&add_child, s, os);
5ba47421
AM
1651 }
1652 else
252b5132 1653 {
afd7a018
AM
1654 static struct orphan_save hold[] =
1655 {
1656 { ".text",
1657 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_CODE,
1658 0, 0, 0, 0 },
1659 { ".rdata",
1660 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_READONLY | SEC_DATA,
1661 0, 0, 0, 0 },
1662 { ".data",
1663 SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_DATA,
1664 0, 0, 0, 0 },
1665 { ".bss",
1666 SEC_ALLOC,
1667 0, 0, 0, 0 }
1668 };
1669 enum orphan_save_index
1670 {
1671 orphan_text = 0,
1672 orphan_rodata,
1673 orphan_data,
1674 orphan_bss
1675 };
1676 static int orphan_init_done = 0;
6a345e87 1677 struct orphan_save *place;
afd7a018 1678 lang_output_section_statement_type *after;
252b5132 1679 etree_type *address;
afd7a018
AM
1680
1681 if (!orphan_init_done)
1682 {
1683 struct orphan_save *ho;
1684 for (ho = hold; ho < hold + sizeof (hold) / sizeof (hold[0]); ++ho)
1685 if (ho->name != NULL)
1686 {
1687 ho->os = lang_output_section_find (ho->name);
1688 if (ho->os != NULL && ho->os->flags == 0)
1689 ho->os->flags = ho->flags;
1690 }
1691 orphan_init_done = 1;
1692 }
252b5132
RH
1693
1694 /* Try to put the new output section in a reasonable place based
1695 on the section name and section flags. */
aea4bd9d 1696
252b5132 1697 place = NULL;
5ba47421
AM
1698 if ((s->flags & SEC_ALLOC) == 0)
1699 ;
afd7a018
AM
1700 else if ((s->flags & (SEC_LOAD | SEC_HAS_CONTENTS)) == 0)
1701 place = &hold[orphan_bss];
1702 else if ((s->flags & SEC_READONLY) == 0)
1703 place = &hold[orphan_data];
1704 else if ((s->flags & SEC_CODE) == 0)
1705 place = &hold[orphan_rodata];
1af699f4 1706 else
afd7a018 1707 place = &hold[orphan_text];
1af699f4 1708
afd7a018 1709 after = NULL;
1af699f4
AM
1710 if (place != NULL)
1711 {
afd7a018
AM
1712 if (place->os == NULL)
1713 place->os = lang_output_section_find (place->name);
1714 after = place->os;
1715 if (after == NULL)
390fbbf1 1716 after = lang_output_section_find_by_flags (s, &place->os, NULL);
afd7a018
AM
1717 if (after == NULL)
1718 /* *ABS* is always the first output section statement. */
1719 after = (&lang_output_section_statement.head
1720 ->output_section_statement);
252b5132
RH
1721 }
1722
afd7a018
AM
1723 /* All sections in an executable must be aligned to a page boundary. */
1724 address = exp_unop (ALIGN_K, exp_nameop (NAME, "__section_alignment__"));
8a99a385
AM
1725 os = lang_insert_orphan (s, secname, constraint, after, place, address,
1726 &add_child);
252b5132
RH
1727 }
1728
5ba47421 1729 {
aea4bd9d 1730 lang_statement_union_type **pl = &os->children.head;
252b5132 1731
5ba47421
AM
1732 if (dollar != NULL)
1733 {
b34976b6 1734 bfd_boolean found_dollar;
252b5132 1735
5ba47421
AM
1736 /* The section name has a '$'. Sort it with the other '$'
1737 sections. */
b34976b6 1738 found_dollar = FALSE;
bba1a0c0 1739 for ( ; *pl != NULL; pl = &(*pl)->header.next)
5ba47421
AM
1740 {
1741 lang_input_section_type *ls;
1742 const char *lname;
252b5132 1743
5ba47421
AM
1744 if ((*pl)->header.type != lang_input_section_enum)
1745 continue;
252b5132 1746
5ba47421 1747 ls = &(*pl)->input_section;
252b5132 1748
7b986e99 1749 lname = bfd_get_section_name (ls->section->owner, ls->section);
5ba47421
AM
1750 if (strchr (lname, '$') == NULL)
1751 {
1752 if (found_dollar)
1753 break;
1754 }
1755 else
1756 {
b34976b6 1757 found_dollar = TRUE;
afd7a018 1758 if (strcmp (orig_secname, lname) < 0)
5ba47421
AM
1759 break;
1760 }
1761 }
1762 }
1763
1764 if (add_child.head != NULL)
1765 {
bba1a0c0 1766 add_child.head->header.next = *pl;
5ba47421
AM
1767 *pl = add_child.head;
1768 }
1769 }
252b5132 1770
c2edb4b8 1771 return os;
252b5132
RH
1772}
1773
b34976b6 1774static bfd_boolean
0c7a8e5a
AM
1775gld_${EMULATION_NAME}_open_dynamic_archive
1776 (const char *arch ATTRIBUTE_UNUSED, search_dirs_type *search,
1777 lang_input_statement_type *entry)
690a460e 1778{
45e948fe
NC
1779 static const struct
1780 {
1781 const char * format;
1782 bfd_boolean use_prefix;
1783 }
1784 libname_fmt [] =
1785 {
1786 /* Preferred explicit import library for dll's. */
1787 { "lib%s.dll.a", FALSE },
1788 /* Alternate explicit import library for dll's. */
1789 { "%s.dll.a", FALSE },
1790 /* "libfoo.a" could be either an import lib or a static lib.
1791 For backwards compatibility, libfoo.a needs to precede
1792 libfoo.dll and foo.dll in the search. */
1793 { "lib%s.a", FALSE },
92b93329 1794 /* The 'native' spelling of an import lib name is "foo.lib". */
45e948fe
NC
1795 { "%s.lib", FALSE },
1796#ifdef DLL_SUPPORT
1797 /* Try "<prefix>foo.dll" (preferred dll name, if specified). */
1798 { "%s%s.dll", TRUE },
1799#endif
1800 /* Try "libfoo.dll" (default preferred dll name). */
1801 { "lib%s.dll", FALSE },
1802 /* Finally try 'native' dll name "foo.dll". */
1803 { "%s.dll", FALSE },
1804 /* Note: If adding more formats to this table, make sure to check to
1805 see if their length is longer than libname_fmt[0].format, and if
1806 so, update the call to xmalloc() below. */
1807 { NULL, FALSE }
1808 };
b1d9458a 1809 static unsigned int format_max_len = 0;
690a460e 1810 const char * filename;
45e948fe
NC
1811 char * full_string;
1812 char * base_string;
1813 unsigned int i;
1814
690a460e
NC
1815
1816 if (! entry->is_archive)
b34976b6 1817 return FALSE;
690a460e
NC
1818
1819 filename = entry->filename;
1820
b1d9458a
NC
1821 if (format_max_len == 0)
1822 /* We need to allow space in the memory that we are going to allocate
1823 for the characters in the format string. Since the format array is
1824 static we only need to calculate this information once. In theory
1825 this value could also be computed statically, but this introduces
1826 the possibility for a discrepancy and hence a possible memory
1827 corruption. The lengths we compute here will be too long because
1828 they will include any formating characters (%s) in the strings, but
1829 this will not matter. */
1830 for (i = 0; libname_fmt[i].format; i++)
1831 if (format_max_len < strlen (libname_fmt[i].format))
1832 format_max_len = strlen (libname_fmt[i].format);
1833
45e948fe
NC
1834 full_string = xmalloc (strlen (search->name)
1835 + strlen (filename)
b1d9458a 1836 + format_max_len
b9a69188 1837#ifdef DLL_SUPPORT
45e948fe
NC
1838 + (pe_dll_search_prefix
1839 ? strlen (pe_dll_search_prefix) : 0)
b9a69188 1840#endif
b1d9458a
NC
1841 /* Allow for the terminating NUL and for the path
1842 separator character that is inserted between
1843 search->name and the start of the format string. */
1844 + 2);
690a460e 1845
45e948fe
NC
1846 sprintf (full_string, "%s/", search->name);
1847 base_string = full_string + strlen (full_string);
690a460e 1848
45e948fe 1849 for (i = 0; libname_fmt[i].format; i++)
690a460e 1850 {
92b93329 1851#ifdef DLL_SUPPORT
45e948fe 1852 if (libname_fmt[i].use_prefix)
1af699f4 1853 {
45e948fe
NC
1854 if (!pe_dll_search_prefix)
1855 continue;
1856 sprintf (base_string, libname_fmt[i].format, pe_dll_search_prefix, filename);
1af699f4 1857 }
45e948fe
NC
1858 else
1859#endif
1860 sprintf (base_string, libname_fmt[i].format, filename);
1861
1862 if (ldfile_try_open_bfd (full_string, entry))
1863 break;
1864 }
1865
1866 if (!libname_fmt[i].format)
1867 {
1868 free (full_string);
1869 return FALSE;
690a460e 1870 }
602e90d3 1871
45e948fe 1872 entry->filename = full_string;
690a460e 1873
b34976b6 1874 return TRUE;
690a460e
NC
1875}
1876
344a211f 1877static int
0c7a8e5a
AM
1878gld_${EMULATION_NAME}_find_potential_libraries
1879 (char *name, lang_input_statement_type *entry)
344a211f
NC
1880{
1881 return ldfile_open_file_search (name, entry, "", ".lib");
1882}
252b5132
RH
1883\f
1884static char *
0c7a8e5a 1885gld_${EMULATION_NAME}_get_script (int *isfile)
252b5132
RH
1886EOF
1887# Scripts compiled in.
1888# sed commands to quote an ld script as a C string.
597e2591 1889sc="-f stringify.sed"
252b5132 1890
92b93329 1891fragment <<EOF
3fc90ddb 1892{
252b5132
RH
1893 *isfile = 0;
1894
1049f94e 1895 if (link_info.relocatable && config.build_constructors)
252b5132
RH
1896 return
1897EOF
1af699f4
AM
1898sed $sc ldscripts/${EMULATION_NAME}.xu >> e${EMULATION_NAME}.c
1899echo ' ; else if (link_info.relocatable) return' >> e${EMULATION_NAME}.c
1900sed $sc ldscripts/${EMULATION_NAME}.xr >> e${EMULATION_NAME}.c
1901echo ' ; else if (!config.text_read_only) return' >> e${EMULATION_NAME}.c
1902sed $sc ldscripts/${EMULATION_NAME}.xbn >> e${EMULATION_NAME}.c
1903echo ' ; else if (!config.magic_demand_paged) return' >> e${EMULATION_NAME}.c
1904sed $sc ldscripts/${EMULATION_NAME}.xn >> e${EMULATION_NAME}.c
e2a83dd0
NC
1905if test -n "$GENERATE_AUTO_IMPORT_SCRIPT" ; then
1906echo ' ; else if (link_info.pei386_auto_import == 1) return' >> e${EMULATION_NAME}.c
1907sed $sc ldscripts/${EMULATION_NAME}.xa >> e${EMULATION_NAME}.c
1908fi
1af699f4
AM
1909echo ' ; else return' >> e${EMULATION_NAME}.c
1910sed $sc ldscripts/${EMULATION_NAME}.x >> e${EMULATION_NAME}.c
1911echo '; }' >> e${EMULATION_NAME}.c
252b5132 1912
92b93329 1913fragment <<EOF
252b5132
RH
1914
1915
3fc90ddb 1916struct ld_emulation_xfer_struct ld_${EMULATION_NAME}_emulation =
252b5132
RH
1917{
1918 gld_${EMULATION_NAME}_before_parse,
1919 syslib_default,
1920 hll_default,
1921 gld_${EMULATION_NAME}_after_parse,
1922 gld_${EMULATION_NAME}_after_open,
1923 after_allocation_default,
1924 set_output_arch_default,
1925 ldemul_default_target,
1926 gld_${EMULATION_NAME}_before_allocation,
1927 gld_${EMULATION_NAME}_get_script,
1928 "${EMULATION_NAME}",
1929 "${OUTPUT_FORMAT}",
4cd89863
NC
1930 gld_${EMULATION_NAME}_finish,
1931 NULL, /* Create output section statements. */
690a460e 1932 gld_${EMULATION_NAME}_open_dynamic_archive,
252b5132
RH
1933 gld_${EMULATION_NAME}_place_orphan,
1934 gld_${EMULATION_NAME}_set_symbols,
3bcf5557
AM
1935 NULL, /* parse_args */
1936 gld${EMULATION_NAME}_add_options,
1937 gld${EMULATION_NAME}_handle_option,
252b5132
RH
1938 gld_${EMULATION_NAME}_unrecognized_file,
1939 gld_${EMULATION_NAME}_list_options,
344a211f 1940 gld_${EMULATION_NAME}_recognized_file,
fac1652d 1941 gld_${EMULATION_NAME}_find_potential_libraries,
4cd89863 1942 NULL /* new_vers_pattern. */
252b5132
RH
1943};
1944EOF