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