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