ld:
[external/binutils.git] / ld / emultempl / beos.em
1 # This shell script emits a C file. -*- C -*-
2 # It does some substitutions.
3 if [ -z "$MACHINE" ]; then
4   OUTPUT_ARCH=${ARCH}
5 else
6   OUTPUT_ARCH=${ARCH}:${MACHINE}
7 fi
8 cat >e${EMULATION_NAME}.c <<EOF
9 /* This file is part of GLD, the Gnu Linker.
10    Copyright 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
11    2005 Free Software Foundation, Inc.
12
13 This program is free software; you can redistribute it and/or modify
14 it under the terms of the GNU General Public License as published by
15 the Free Software Foundation; either version 2 of the License, or
16 (at your option) any later version.
17
18 This program is distributed in the hope that it will be useful,
19 but WITHOUT ANY WARRANTY; without even the implied warranty of
20 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21 GNU General Public License for more details.
22
23 You should have received a copy of the GNU General Public License
24 along with this program; if not, write to the Free Software
25 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.  */
26
27 /* For WINDOWS_NT */
28 /* The original file generated returned different default scripts depending
29    on whether certain switches were set, but these switches pertain to the
30    Linux system and that particular version of coff.  In the NT case, we
31    only determine if the subsystem is console or windows in order to select
32    the correct entry point by default. */
33
34 #include "bfd.h"
35 #include "sysdep.h"
36 #include "bfdlink.h"
37 #include "getopt.h"
38 #include "libiberty.h"
39 #include "ld.h"
40 #include "ldmain.h"
41 #include "ldexp.h"
42 #include "ldlang.h"
43 #include "ldfile.h"
44 #include "ldemul.h"
45 #include <ldgram.h>
46 #include "ldlex.h"
47 #include "ldmisc.h"
48 #include "ldctor.h"
49 #include "coff/internal.h"
50 #include "../bfd/libcoff.h"
51
52 #define TARGET_IS_${EMULATION_NAME}
53
54 static struct internal_extra_pe_aouthdr pe;
55 static int dll;
56
57 extern const char *output_filename;
58
59 static void
60 gld_${EMULATION_NAME}_before_parse (void)
61 {
62   ldfile_set_output_arch ("${OUTPUT_ARCH}", bfd_arch_`echo ${ARCH} | sed -e 's/:.*//'`);
63   output_filename = "a.exe";
64 }
65 \f
66 /* PE format extra command line options.  */
67
68 /* Used for setting flags in the PE header. */
69 #define OPTION_BASE_FILE                (300  + 1)
70 #define OPTION_DLL                      (OPTION_BASE_FILE + 1)
71 #define OPTION_FILE_ALIGNMENT           (OPTION_DLL + 1)
72 #define OPTION_IMAGE_BASE               (OPTION_FILE_ALIGNMENT + 1)
73 #define OPTION_MAJOR_IMAGE_VERSION      (OPTION_IMAGE_BASE + 1)
74 #define OPTION_MAJOR_OS_VERSION         (OPTION_MAJOR_IMAGE_VERSION + 1)
75 #define OPTION_MAJOR_SUBSYSTEM_VERSION  (OPTION_MAJOR_OS_VERSION + 1)
76 #define OPTION_MINOR_IMAGE_VERSION      (OPTION_MAJOR_SUBSYSTEM_VERSION + 1)
77 #define OPTION_MINOR_OS_VERSION         (OPTION_MINOR_IMAGE_VERSION + 1)
78 #define OPTION_MINOR_SUBSYSTEM_VERSION  (OPTION_MINOR_OS_VERSION + 1)
79 #define OPTION_SECTION_ALIGNMENT        (OPTION_MINOR_SUBSYSTEM_VERSION + 1)
80 #define OPTION_STACK                    (OPTION_SECTION_ALIGNMENT + 1)
81 #define OPTION_SUBSYSTEM                (OPTION_STACK + 1)
82 #define OPTION_HEAP                     (OPTION_SUBSYSTEM + 1)
83
84 static void
85 gld${EMULATION_NAME}_add_options
86   (int ns ATTRIBUTE_UNUSED, char **shortopts ATTRIBUTE_UNUSED, int nl,
87    struct option **longopts, int nrl ATTRIBUTE_UNUSED,
88    struct option **really_longopts ATTRIBUTE_UNUSED)
89 {
90   static const struct option xtra_long[] = {
91     /* PE options */
92     {"base-file", required_argument, NULL, OPTION_BASE_FILE},
93     {"dll", no_argument, NULL, OPTION_DLL},
94     {"file-alignment", required_argument, NULL, OPTION_FILE_ALIGNMENT},
95     {"heap", required_argument, NULL, OPTION_HEAP},
96     {"image-base", required_argument, NULL, OPTION_IMAGE_BASE},
97     {"major-image-version", required_argument, NULL, OPTION_MAJOR_IMAGE_VERSION},
98     {"major-os-version", required_argument, NULL, OPTION_MAJOR_OS_VERSION},
99     {"major-subsystem-version", required_argument, NULL, OPTION_MAJOR_SUBSYSTEM_VERSION},
100     {"minor-image-version", required_argument, NULL, OPTION_MINOR_IMAGE_VERSION},
101     {"minor-os-version", required_argument, NULL, OPTION_MINOR_OS_VERSION},
102     {"minor-subsystem-version", required_argument, NULL, OPTION_MINOR_SUBSYSTEM_VERSION},
103     {"section-alignment", required_argument, NULL, OPTION_SECTION_ALIGNMENT},
104     {"stack", required_argument, NULL, OPTION_STACK},
105     {"subsystem", required_argument, NULL, OPTION_SUBSYSTEM},
106     {NULL, no_argument, NULL, 0}
107   };
108
109   *longopts = (struct option *)
110     xrealloc (*longopts, nl * sizeof (struct option) + sizeof (xtra_long));
111   memcpy (*longopts + nl, &xtra_long, sizeof (xtra_long));
112 }
113
114
115 /* PE/WIN32; added routines to get the subsystem type, heap and/or stack
116    parameters which may be input from the command line */
117
118 typedef struct {
119   void *ptr;
120   int size;
121   int value;
122   char *symbol;
123   int inited;
124 } definfo;
125
126 #define D(field,symbol,def)  {&pe.field,sizeof(pe.field), def, symbol,0}
127
128 static definfo init[] =
129 {
130   /* imagebase must be first */
131 #define IMAGEBASEOFF 0
132   D(ImageBase,"__image_base__", BEOS_EXE_IMAGE_BASE),
133 #define DLLOFF 1
134   {&dll, sizeof(dll), 0, "__dll__", 0},
135   D(SectionAlignment,"__section_alignment__", PE_DEF_SECTION_ALIGNMENT),
136   D(FileAlignment,"__file_alignment__", PE_DEF_FILE_ALIGNMENT),
137   D(MajorOperatingSystemVersion,"__major_os_version__", 4),
138   D(MinorOperatingSystemVersion,"__minor_os_version__", 0),
139   D(MajorImageVersion,"__major_image_version__", 1),
140   D(MinorImageVersion,"__minor_image_version__", 0),
141   D(MajorSubsystemVersion,"__major_subsystem_version__", 4),
142   D(MinorSubsystemVersion,"__minor_subsystem_version__", 0),
143   D(Subsystem,"__subsystem__", 3),
144   D(SizeOfStackReserve,"__size_of_stack_reserve__", 0x2000000),
145   D(SizeOfStackCommit,"__size_of_stack_commit__", 0x1000),
146   D(SizeOfHeapReserve,"__size_of_heap_reserve__", 0x100000),
147   D(SizeOfHeapCommit,"__size_of_heap_commit__", 0x1000),
148   D(LoaderFlags,"__loader_flags__", 0x0),
149   { NULL, 0, 0, NULL, 0 }
150 };
151
152
153 static void
154 set_pe_name (char *name, long val)
155 {
156   int i;
157   /* Find the name and set it. */
158   for (i = 0; init[i].ptr; i++)
159     {
160       if (strcmp (name, init[i].symbol) == 0)
161         {
162           init[i].value = val;
163           init[i].inited = 1;
164           return;
165         }
166     }
167   abort();
168 }
169
170
171 static void
172 set_pe_subsystem (void)
173 {
174   const char *sver;
175   int len;
176   int i;
177   static const struct
178     {
179       const char *name;
180       const int value;
181       const char *entry;
182     }
183   v[] =
184     {
185       { "native", 1, "_NtProcessStartup" },
186       { "windows", 2, "_WinMainCRTStartup" },
187       { "wwindows", 2, "_wWinMainCRTStartup" },
188       { "console", 3, "_mainCRTStartup" },
189       { "wconsole", 3, "_wmainCRTStartup" },
190       { "posix", 7, "___PosixProcessStartup"},
191       { 0, 0, 0 }
192     };
193
194   sver = strchr (optarg, ':');
195   if (sver == NULL)
196     len = strlen (optarg);
197   else
198     {
199       char *end;
200
201       len = sver - optarg;
202       set_pe_name ("__major_subsystem_version__",
203                    strtoul (sver + 1, &end, 0));
204       if (*end == '.')
205         set_pe_name ("__minor_subsystem_version__",
206                      strtoul (end + 1, &end, 0));
207       if (*end != '\0')
208         einfo ("%P: warning: bad version number in -subsystem option\n");
209     }
210
211   for (i = 0; v[i].name; i++)
212     {
213       if (strncmp (optarg, v[i].name, len) == 0
214           && v[i].name[len] == '\0')
215         {
216           set_pe_name ("__subsystem__", v[i].value);
217
218           /* If the subsystem is windows, we use a different entry
219              point.  */
220           lang_default_entry (v[i].entry);
221
222           return;
223         }
224     }
225   einfo ("%P%F: invalid subsystem type %s\n", optarg);
226 }
227
228
229 static void
230 set_pe_value (char *name)
231 {
232   char *end;
233   set_pe_name (name,  strtoul (optarg, &end, 0));
234   if (end == optarg)
235     {
236       einfo ("%P%F: invalid hex number for PE parameter '%s'\n", optarg);
237     }
238
239   optarg = end;
240 }
241
242 static void
243 set_pe_stack_heap (char *resname, char *comname)
244 {
245   set_pe_value (resname);
246   if (*optarg == ',')
247     {
248       optarg++;
249       set_pe_value (comname);
250     }
251   else if (*optarg)
252     {
253       einfo ("%P%F: strange hex info for PE parameter '%s'\n", optarg);
254     }
255 }
256
257
258 static bfd_boolean
259 gld${EMULATION_NAME}_handle_option (int optc)
260 {
261   switch (optc)
262     {
263     default:
264       return FALSE;
265
266     case OPTION_BASE_FILE:
267       link_info.base_file = fopen (optarg, FOPEN_WB);
268       if (link_info.base_file == NULL)
269         {
270           fprintf (stderr, "%s: Can't open base file %s\n",
271                    program_name, optarg);
272           xexit (1);
273         }
274       break;
275
276       /* PE options */
277     case OPTION_HEAP:
278       set_pe_stack_heap ("__size_of_heap_reserve__", "__size_of_heap_commit__");
279       break;
280     case OPTION_STACK:
281       set_pe_stack_heap ("__size_of_stack_reserve__", "__size_of_stack_commit__");
282       break;
283     case OPTION_SUBSYSTEM:
284       set_pe_subsystem ();
285       break;
286     case OPTION_MAJOR_OS_VERSION:
287       set_pe_value ("__major_os_version__");
288       break;
289     case OPTION_MINOR_OS_VERSION:
290       set_pe_value ("__minor_os_version__");
291       break;
292     case OPTION_MAJOR_SUBSYSTEM_VERSION:
293       set_pe_value ("__major_subsystem_version__");
294       break;
295     case OPTION_MINOR_SUBSYSTEM_VERSION:
296       set_pe_value ("__minor_subsystem_version__");
297       break;
298     case OPTION_MAJOR_IMAGE_VERSION:
299       set_pe_value ("__major_image_version__");
300       break;
301     case OPTION_MINOR_IMAGE_VERSION:
302       set_pe_value ("__minor_image_version__");
303       break;
304     case OPTION_FILE_ALIGNMENT:
305       set_pe_value ("__file_alignment__");
306       break;
307     case OPTION_SECTION_ALIGNMENT:
308       set_pe_value ("__section_alignment__");
309       break;
310     case OPTION_DLL:
311       set_pe_name ("__dll__", 1);
312       break;
313     case OPTION_IMAGE_BASE:
314       set_pe_value ("__image_base__");
315       break;
316     }
317   return TRUE;
318 }
319 \f
320 /* Assign values to the special symbols before the linker script is
321    read.  */
322
323 static void
324 gld_${EMULATION_NAME}_set_symbols (void)
325 {
326   /* Run through and invent symbols for all the
327      names and insert the defaults. */
328   int j;
329   lang_statement_list_type *save;
330
331   if (!init[IMAGEBASEOFF].inited)
332     {
333       if (link_info.relocatable)
334         init[IMAGEBASEOFF].value = 0;
335       else if (init[DLLOFF].value)
336         init[IMAGEBASEOFF].value = BEOS_DLL_IMAGE_BASE;
337       else
338         init[IMAGEBASEOFF].value = BEOS_EXE_IMAGE_BASE;
339     }
340
341   /* Don't do any symbol assignments if this is a relocatable link.  */
342   if (link_info.relocatable)
343     return;
344
345   /* Glue the assignments into the abs section */
346   save = stat_ptr;
347
348   stat_ptr = &(abs_output_section->children);
349
350   for (j = 0; init[j].ptr; j++)
351     {
352       long val = init[j].value;
353       lang_add_assignment (exp_assop ('=', init[j].symbol, exp_intop (val)));
354       if (init[j].size == sizeof(short))
355         *(short *)init[j].ptr = val;
356       else if (init[j].size == sizeof(int))
357         *(int *)init[j].ptr = val;
358       else if (init[j].size == sizeof(long))
359         *(long *)init[j].ptr = val;
360       /* This might be a long long or other special type.  */
361       else if (init[j].size == sizeof(bfd_vma))
362         *(bfd_vma *)init[j].ptr = val;
363       else      abort();
364     }
365   /* Restore the pointer. */
366   stat_ptr = save;
367
368   if (pe.FileAlignment >
369       pe.SectionAlignment)
370     {
371       einfo ("%P: warning, file alignment > section alignment.\n");
372     }
373 }
374
375 static void
376 gld_${EMULATION_NAME}_after_open (void)
377 {
378   /* Pass the wacky PE command line options into the output bfd.
379      FIXME: This should be done via a function, rather than by
380      including an internal BFD header.  */
381   if (!coff_data(output_bfd)->pe)
382     {
383       einfo ("%F%P: PE operations on non PE file.\n");
384     }
385
386   pe_data(output_bfd)->pe_opthdr = pe;
387   pe_data(output_bfd)->dll = init[DLLOFF].value;
388
389 }
390 \f
391 /* Callback functions for qsort in sort_sections. */
392
393 static int
394 sort_by_file_name (const void *a, const void *b)
395 {
396   const lang_statement_union_type *const *ra = a;
397   const lang_statement_union_type *const *rb = b;
398   int i, a_sec, b_sec;
399
400   i = strcmp ((*ra)->input_section.ifile->the_bfd->my_archive->filename,
401               (*rb)->input_section.ifile->the_bfd->my_archive->filename);
402   if (i != 0)
403     return i;
404
405   i = strcmp ((*ra)->input_section.ifile->filename,
406                  (*rb)->input_section.ifile->filename);
407   if (i != 0)
408     return i;
409   /* the tail idata4/5 are the only ones without relocs to an
410      idata$6 section unless we are importing by ordinal,
411      so sort them to last to terminate the IAT
412      and HNT properly. if no reloc this one is import by ordinal
413      so we have to sort by section contents */
414
415   if ( ((*ra)->input_section.section->reloc_count + (*rb)->input_section.section->reloc_count) )
416     {
417        i =  (((*ra)->input_section.section->reloc_count >
418                  (*rb)->input_section.section->reloc_count) ? -1 : 0);
419        if ( i != 0)
420          return i;
421
422         return  (((*ra)->input_section.section->reloc_count >
423                  (*rb)->input_section.section->reloc_count) ? 0 : 1);
424     }
425   else
426     {
427        if ( (strcmp( (*ra)->input_section.section->name, ".idata$6") == 0) )
428           return 0; /* don't sort .idata$6 or .idata$7 FIXME dlltool eliminate .idata$7 */
429
430        if (! bfd_get_section_contents ((*ra)->input_section.ifile->the_bfd,
431          (*ra)->input_section.section, &a_sec, (file_ptr) 0, (bfd_size_type)sizeof(a_sec)))
432             einfo ("%F%B: Can't read contents of section .idata: %E\n",
433                  (*ra)->input_section.ifile->the_bfd);
434
435        if (! bfd_get_section_contents ((*rb)->input_section.ifile->the_bfd,
436         (*rb)->input_section.section, &b_sec, (file_ptr) 0, (bfd_size_type)sizeof(b_sec) ))
437            einfo ("%F%B: Can't read contents of section .idata: %E\n",
438                 (*rb)->input_section.ifile->the_bfd);
439
440       i =  ((a_sec < b_sec) ? -1 : 0);
441       if ( i != 0)
442         return i;
443       return  ((a_sec < b_sec) ? 0 : 1);
444    }
445 return 0;
446 }
447
448 static int
449 sort_by_section_name (const void *a, const void *b)
450 {
451   const lang_statement_union_type *const *ra = a;
452   const lang_statement_union_type *const *rb = b;
453   int i;
454   i = strcmp ((*ra)->input_section.section->name,
455                  (*rb)->input_section.section->name);
456 /* this is a hack to make .stab and .stabstr last, so we don't have
457    to fix strip/objcopy for .reloc sections.
458    FIXME stripping images with a .rsrc section still needs to be fixed */
459   if ( i != 0)
460     {
461       if ((strncmp ((*ra)->input_section.section->name, ".stab", 5) == 0)
462            && (strncmp ((*rb)->input_section.section->name, ".stab", 5) != 0))
463          return 1;
464       return i;
465     }
466   return i;
467 }
468
469 /* Subroutine of sort_sections to a contiguous subset of a list of sections.
470    NEXT_AFTER is the element after the last one to sort.
471    The result is a pointer to the last element's "next" pointer.  */
472
473 static lang_statement_union_type **
474 sort_sections_1 (lang_statement_union_type **startptr,
475                  lang_statement_union_type *next_after,
476                  int count,
477                  int (*sort_func) (const void *, const void *))
478 {
479   lang_statement_union_type **vec;
480   lang_statement_union_type *p;
481   int i;
482   lang_statement_union_type **ret;
483
484   if (count == 0)
485     return startptr;
486
487   vec = ((lang_statement_union_type **)
488          xmalloc (count * sizeof (lang_statement_union_type *)));
489
490   for (p = *startptr, i = 0; i < count; i++, p = p->header.next)
491     vec[i] = p;
492
493   qsort (vec, count, sizeof (vec[0]), sort_func);
494
495   /* Fill in the next pointers again. */
496   *startptr = vec[0];
497   for (i = 0; i < count - 1; i++)
498     vec[i]->header.next = vec[i + 1];
499   vec[i]->header.next = next_after;
500   ret = &vec[i]->header.next;
501   free (vec);
502   return ret;
503 }
504
505 /* Sort the .idata\$foo input sections of archives into filename order.
506    The reason is so dlltool can arrange to have the pe dll import information
507    generated correctly - the head of the list goes into dh.o, the tail into
508    dt.o, and the guts into ds[nnnn].o.  Note that this is only needed for the
509    .idata section.
510    FIXME: This may no longer be necessary with grouped sections.  Instead of
511    sorting on dh.o, ds[nnnn].o, dt.o, one could, for example, have dh.o use
512    .idata\$4h, have ds[nnnn].o use .idata\$4s[nnnn], and have dt.o use .idata\$4t.
513    This would have to be elaborated upon to handle multiple dll's
514    [assuming such an eloboration is possible of course].
515
516    We also sort sections in '\$' wild statements.  These are created by the
517    place_orphans routine to implement grouped sections.  */
518
519 static void
520 sort_sections (lang_statement_union_type *s)
521 {
522   for (; s ; s = s->header.next)
523     switch (s->header.type)
524       {
525       case lang_output_section_statement_enum:
526         sort_sections (s->output_section_statement.children.head);
527         break;
528       case lang_wild_statement_enum:
529         {
530           lang_statement_union_type **p = &s->wild_statement.children.head;
531           struct wildcard_list *sec;
532
533           for (sec = s->wild_statement.section_list; sec; sec = sec->next)
534             {
535               /* Is this the .idata section?  */
536               if (sec->spec.name != NULL
537                   && strncmp (sec->spec.name, ".idata", 6) == 0)
538                 {
539                   /* Sort the children.  We want to sort any objects in
540                      the same archive.  In order to handle the case of
541                      including a single archive multiple times, we sort
542                      all the children by archive name and then by object
543                      name.  After sorting them, we re-thread the pointer
544                      chain.  */
545
546                   while (*p)
547                     {
548                       lang_statement_union_type *start = *p;
549                       if (start->header.type != lang_input_section_enum
550                           || !start->input_section.ifile->the_bfd->my_archive)
551                         p = &(start->header.next);
552                       else
553                         {
554                           lang_statement_union_type *end;
555                           int count;
556
557                           for (end = start, count = 0;
558                                end && (end->header.type
559                                        == lang_input_section_enum);
560                                end = end->header.next)
561                             count++;
562
563                           p = sort_sections_1 (p, end, count,
564                                                sort_by_file_name);
565                         }
566                     }
567                   break;
568                 }
569
570               /* If this is a collection of grouped sections, sort them.
571                  The linker script must explicitly mention "*(.foo\$)" or
572                  "*(.foo\$*)".  Don't sort them if \$ is not the last
573                  character (not sure if this is really useful, but it
574                  allows explicitly mentioning some \$ sections and letting
575                  the linker handle the rest).  */
576               if (sec->spec.name != NULL)
577                 {
578                   char *q = strchr (sec->spec.name, '\$');
579
580                   if (q != NULL
581                       && (q[1] == '\0'
582                           || (q[1] == '*' && q[2] == '\0')))
583                     {
584                       lang_statement_union_type *end;
585                       int count;
586
587                       for (end = *p, count = 0; end; end = end->header.next)
588                         {
589                           if (end->header.type != lang_input_section_enum)
590                             abort ();
591                           count++;
592                         }
593                       (void) sort_sections_1 (p, end, count,
594                                               sort_by_section_name);
595                     }
596                   break;
597                 }
598             }
599         }
600         break;
601       default:
602         break;
603       }
604 }
605
606 static void
607 gld_${EMULATION_NAME}_before_allocation (void)
608 {
609   extern lang_statement_list_type *stat_ptr;
610
611 #ifdef TARGET_IS_ppcpe
612   /* Here we rummage through the found bfds to collect toc information */
613   {
614     LANG_FOR_EACH_INPUT_STATEMENT (is)
615       {
616         if (!ppc_process_before_allocation(is->the_bfd, &link_info))
617           {
618             einfo("Errors encountered processing file %s\n", is->filename);
619           }
620       }
621   }
622
623   /* We have seen it all. Allocate it, and carry on */
624   ppc_allocate_toc_section (&link_info);
625 #else
626 #ifdef TARGET_IS_armpe
627   /* FIXME: we should be able to set the size of the interworking stub
628      section.
629
630      Here we rummage through the found bfds to collect glue
631      information.  FIXME: should this be based on a command line
632      option?  krk@cygnus.com */
633   {
634     LANG_FOR_EACH_INPUT_STATEMENT (is)
635       {
636         if (!arm_process_before_allocation (is->the_bfd, & link_info))
637           {
638             einfo ("Errors encountered processing file %s", is->filename);
639           }
640       }
641   }
642
643   /* We have seen it all. Allocate it, and carry on */
644   arm_allocate_interworking_sections (& link_info);
645 #endif /* TARGET_IS_armpe */
646 #endif /* TARGET_IS_ppcpe */
647
648   sort_sections (stat_ptr->head);
649
650   if (!link_info.relocatable)
651     strip_excluded_output_sections ();
652 }
653 \f
654 /* Place an orphan section.  We use this to put sections with a '\$' in them
655    into the right place.  Any section with a '\$' in them (e.g. .text\$foo)
656    gets mapped to the output section with everything from the '\$' on stripped
657    (e.g. .text).
658    See the Microsoft Portable Executable and Common Object File Format
659    Specification 4.1, section 4.2, Grouped Sections.
660
661    FIXME: This is now handled by the linker script using wildcards,
662    but I'm leaving this here in case we want to enable it for sections
663    which are not mentioned in the linker script.  */
664
665 static bfd_boolean
666 gld${EMULATION_NAME}_place_orphan (lang_input_statement_type *file, asection *s)
667 {
668   const char *secname;
669   char *output_secname, *ps;
670   lang_output_section_statement_type *os;
671   lang_statement_union_type *l;
672
673   if ((s->flags & SEC_ALLOC) == 0)
674     return FALSE;
675
676   /* Don't process grouped sections unless doing a final link.
677      If they're marked as COMDAT sections, we don't want .text\$foo to
678      end up in .text and then have .text disappear because it's marked
679      link-once-discard.  */
680   if (link_info.relocatable)
681     return FALSE;
682
683   secname = bfd_get_section_name (s->owner, s);
684
685   /* Everything from the '\$' on gets deleted so don't allow '\$' as the
686      first character.  */
687   if (*secname == '\$')
688     einfo ("%P%F: section %s has '\$' as first character\n", secname);
689   if (strchr (secname + 1, '\$') == NULL)
690     return FALSE;
691
692   /* Look up the output section.  The Microsoft specs say sections names in
693      image files never contain a '\$'.  Fortunately, lang_..._lookup creates
694      the section if it doesn't exist.  */
695   output_secname = xstrdup (secname);
696   ps = strchr (output_secname + 1, '\$');
697   *ps = 0;
698   os = lang_output_section_statement_lookup (output_secname);
699
700   /* Find the '\$' wild statement for this section.  We currently require the
701      linker script to explicitly mention "*(.foo\$)".
702      FIXME: ppcpe.sc has .CRT\$foo in the .rdata section.  According to the
703      Microsoft docs this isn't correct so it's not (currently) handled.  */
704
705   ps[0] = '\$';
706   ps[1] = 0;
707   for (l = os->children.head; l; l = l->header.next)
708     if (l->header.type == lang_wild_statement_enum)
709       {
710         struct wildcard_list *sec;
711
712         for (sec = l->wild_statement.section_list; sec; sec = sec->next)
713           if (sec->spec.name && strcmp (sec->spec.name, output_secname) == 0)
714             break;
715         if (sec)
716           break;
717       }
718   ps[0] = 0;
719   if (l == NULL)
720     einfo ("%P%F: *(%s\$) missing from linker script\n", output_secname);
721
722   /* Link the input section in and we're done for now.
723      The sections still have to be sorted, but that has to wait until
724      all such sections have been processed by us.  The sorting is done by
725      sort_sections.  */
726   lang_add_section (&l->wild_statement.children, s, os, file);
727
728   return TRUE;
729 }
730 \f
731 static char *
732 gld_${EMULATION_NAME}_get_script (int *isfile)
733 EOF
734 # Scripts compiled in.
735 # sed commands to quote an ld script as a C string.
736 sc="-f stringify.sed"
737
738 cat >>e${EMULATION_NAME}.c <<EOF
739 {
740   *isfile = 0;
741
742   if (link_info.relocatable && config.build_constructors)
743     return
744 EOF
745 sed $sc ldscripts/${EMULATION_NAME}.xu                 >> e${EMULATION_NAME}.c
746 echo '  ; else if (link_info.relocatable) return'     >> e${EMULATION_NAME}.c
747 sed $sc ldscripts/${EMULATION_NAME}.xr                 >> e${EMULATION_NAME}.c
748 echo '  ; else if (!config.text_read_only) return'     >> e${EMULATION_NAME}.c
749 sed $sc ldscripts/${EMULATION_NAME}.xbn                >> e${EMULATION_NAME}.c
750 echo '  ; else if (!config.magic_demand_paged) return' >> e${EMULATION_NAME}.c
751 sed $sc ldscripts/${EMULATION_NAME}.xn                 >> e${EMULATION_NAME}.c
752 echo '  ; else return'                                 >> e${EMULATION_NAME}.c
753 sed $sc ldscripts/${EMULATION_NAME}.x                  >> e${EMULATION_NAME}.c
754 echo '; }'                                             >> e${EMULATION_NAME}.c
755
756 cat >>e${EMULATION_NAME}.c <<EOF
757
758
759 struct ld_emulation_xfer_struct ld_${EMULATION_NAME}_emulation =
760 {
761   gld_${EMULATION_NAME}_before_parse,
762   syslib_default,
763   hll_default,
764   after_parse_default,
765   gld_${EMULATION_NAME}_after_open,
766   after_allocation_default,
767   set_output_arch_default,
768   ldemul_default_target,
769   gld_${EMULATION_NAME}_before_allocation,
770   gld_${EMULATION_NAME}_get_script,
771   "${EMULATION_NAME}",
772   "${OUTPUT_FORMAT}",
773   NULL, /* finish */
774   NULL, /* create output section statements */
775   NULL, /* open dynamic archive */
776   gld${EMULATION_NAME}_place_orphan,
777   gld_${EMULATION_NAME}_set_symbols,
778   NULL, /* parse_args */
779   gld${EMULATION_NAME}_add_options,
780   gld${EMULATION_NAME}_handle_option,
781   NULL, /* unrecognized file */
782   NULL, /* list options */
783   NULL, /* recognized file */
784   NULL, /* find_potential_libraries */
785   NULL  /* new_vers_pattern */
786 };
787 EOF