source: trunk/binutils/ld/ldemul.c@ 3054

Last change on this file since 3054 was 618, checked in by bird, 22 years ago

Joined the port of 2.11.2 with 2.14.

  • Property cvs2svn:cvs-rev set to 1.4
  • Property svn:eol-style set to native
  • Property svn:executable set to *
File size: 6.6 KB
Line 
1/* ldemul.c -- clearing house for ld emulation states
2 Copyright 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 2000, 2002, 2003
3 Free Software Foundation, Inc.
4
5This file is part of GLD, the Gnu Linker.
6
7GLD is free software; you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published by
9the Free Software Foundation; either version 2, or (at your option)
10any later version.
11
12GLD is distributed in the hope that it will be useful,
13but WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15GNU General Public License for more details.
16
17You should have received a copy of the GNU General Public License
18along with GLD; see the file COPYING. If not, write to the Free
19Software Foundation, 59 Temple Place - Suite 330, Boston, MA
2002111-1307, USA. */
21
22#include "bfd.h"
23#include "sysdep.h"
24#include "getopt.h"
25
26#include "ld.h"
27#include "ldmisc.h"
28#include "ldexp.h"
29#include "ldlang.h"
30#include "ldfile.h"
31#include "ldemul.h"
32#include "ldmain.h"
33#include "ldemul-list.h"
34
35ld_emulation_xfer_type *ld_emulation;
36
37void
38ldemul_hll (name)
39 char *name;
40{
41 ld_emulation->hll (name);
42}
43
44void
45ldemul_syslib (name)
46 char *name;
47{
48 ld_emulation->syslib (name);
49}
50
51void
52ldemul_after_parse ()
53{
54 ld_emulation->after_parse ();
55}
56
57void
58ldemul_before_parse ()
59{
60 ld_emulation->before_parse ();
61}
62
63void
64ldemul_after_open ()
65{
66 ld_emulation->after_open ();
67}
68
69void
70ldemul_after_allocation ()
71{
72 ld_emulation->after_allocation ();
73}
74
75void
76ldemul_before_allocation ()
77{
78 if (ld_emulation->before_allocation)
79 ld_emulation->before_allocation ();
80}
81
82void
83ldemul_set_output_arch ()
84{
85 ld_emulation->set_output_arch ();
86}
87
88void
89ldemul_finish ()
90{
91 if (ld_emulation->finish)
92 ld_emulation->finish ();
93}
94
95void
96ldemul_set_symbols ()
97{
98 if (ld_emulation->set_symbols)
99 ld_emulation->set_symbols ();
100}
101
102void
103ldemul_create_output_section_statements ()
104{
105 if (ld_emulation->create_output_section_statements)
106 ld_emulation->create_output_section_statements ();
107}
108
109char *
110ldemul_get_script (isfile)
111 int *isfile;
112{
113 return ld_emulation->get_script (isfile);
114}
115
116bfd_boolean
117ldemul_open_dynamic_archive (arch, search, entry)
118 const char *arch;
119 search_dirs_type *search;
120 lang_input_statement_type *entry;
121{
122 if (ld_emulation->open_dynamic_archive)
123 return (*ld_emulation->open_dynamic_archive) (arch, search, entry);
124 return FALSE;
125}
126
127bfd_boolean
128ldemul_place_orphan (file, s)
129 lang_input_statement_type *file;
130 asection *s;
131{
132 if (ld_emulation->place_orphan)
133 return (*ld_emulation->place_orphan) (file, s);
134 return FALSE;
135}
136
137void
138ldemul_add_options (ns, shortopts, nl, longopts, nrl, really_longopts)
139 int ns;
140 char **shortopts;
141 int nl;
142 struct option **longopts;
143 int nrl;
144 struct option **really_longopts;
145{
146 if (ld_emulation->add_options)
147 (*ld_emulation->add_options) (ns, shortopts, nl, longopts,
148 nrl, really_longopts);
149}
150
151bfd_boolean
152ldemul_handle_option (optc)
153 int optc;
154{
155 if (ld_emulation->handle_option)
156 return (*ld_emulation->handle_option) (optc);
157 return FALSE;
158}
159
160bfd_boolean
161ldemul_parse_args (argc, argv)
162 int argc;
163 char **argv;
164{
165 /* Try and use the emulation parser if there is one. */
166 if (ld_emulation->parse_args)
167 return (*ld_emulation->parse_args) (argc, argv);
168 return FALSE;
169}
170
171/* Let the emulation code handle an unrecognized file. */
172
173bfd_boolean
174ldemul_unrecognized_file (entry)
175 lang_input_statement_type *entry;
176{
177 if (ld_emulation->unrecognized_file)
178 return (*ld_emulation->unrecognized_file) (entry);
179 return FALSE;
180}
181
182/* Let the emulation code handle a recognized file. */
183
184bfd_boolean
185ldemul_recognized_file (entry)
186 lang_input_statement_type *entry;
187{
188 if (ld_emulation->recognized_file)
189 return (*ld_emulation->recognized_file) (entry);
190 return FALSE;
191}
192
193char *
194ldemul_choose_target (argc, argv)
195 int argc;
196 char **argv;
197{
198 return ld_emulation->choose_target (argc, argv);
199}
200
201
202/* The default choose_target function. */
203
204char *
205ldemul_default_target (argc, argv)
206 int argc ATTRIBUTE_UNUSED;
207 char **argv ATTRIBUTE_UNUSED;
208{
209 char *from_outside = getenv (TARGET_ENVIRON);
210 if (from_outside != (char *) NULL)
211 return from_outside;
212 return ld_emulation->target_name;
213}
214
215void
216after_parse_default ()
217{
218}
219
220void
221after_open_default ()
222{
223}
224
225void
226after_allocation_default ()
227{
228}
229
230void
231before_allocation_default ()
232{
233}
234
235void
236set_output_arch_default ()
237{
238 /* Set the output architecture and machine if possible. */
239 bfd_set_arch_mach (output_bfd,
240 ldfile_output_architecture, ldfile_output_machine);
241}
242
243void
244syslib_default (ignore)
245 char *ignore ATTRIBUTE_UNUSED;
246{
247 info_msg (_("%S SYSLIB ignored\n"));
248}
249
250void
251hll_default (ignore)
252 char *ignore ATTRIBUTE_UNUSED;
253{
254 info_msg (_("%S HLL ignored\n"));
255}
256
257ld_emulation_xfer_type *ld_emulations[] = { EMULATION_LIST };
258
259void
260ldemul_choose_mode (target)
261 char *target;
262{
263 ld_emulation_xfer_type **eptr = ld_emulations;
264 /* Ignore "gld" prefix. */
265 if (target[0] == 'g' && target[1] == 'l' && target[2] == 'd')
266 target += 3;
267 for (; *eptr; eptr++)
268 {
269 if (strcmp (target, (*eptr)->emulation_name) == 0)
270 {
271 ld_emulation = *eptr;
272 return;
273 }
274 }
275 einfo (_("%P: unrecognised emulation mode: %s\n"), target);
276 einfo (_("Supported emulations: "));
277 ldemul_list_emulations (stderr);
278 einfo ("%F\n");
279}
280
281void
282ldemul_list_emulations (f)
283 FILE *f;
284{
285 ld_emulation_xfer_type **eptr = ld_emulations;
286 bfd_boolean first = TRUE;
287
288 for (; *eptr; eptr++)
289 {
290 if (first)
291 first = FALSE;
292 else
293 fprintf (f, " ");
294 fprintf (f, "%s", (*eptr)->emulation_name);
295 }
296}
297
298void
299ldemul_list_emulation_options (f)
300 FILE *f;
301{
302 ld_emulation_xfer_type **eptr;
303 int options_found = 0;
304
305 for (eptr = ld_emulations; *eptr; eptr++)
306 {
307 ld_emulation_xfer_type *emul = *eptr;
308
309 if (emul->list_options)
310 {
311 fprintf (f, "%s: \n", emul->emulation_name);
312
313 emul->list_options (f);
314
315 options_found = 1;
316 }
317 }
318
319 if (! options_found)
320 fprintf (f, _(" no emulation specific options.\n"));
321}
322
323int
324ldemul_find_potential_libraries (name, entry)
325 char *name;
326 lang_input_statement_type *entry;
327{
328 if (ld_emulation->find_potential_libraries)
329 return ld_emulation->find_potential_libraries (name, entry);
330
331 return 0;
332}
333
334struct bfd_elf_version_expr *
335ldemul_new_vers_pattern (entry)
336 struct bfd_elf_version_expr *entry;
337{
338 if (ld_emulation->new_vers_pattern)
339 entry = (*ld_emulation->new_vers_pattern) (entry);
340 return entry;
341}
342
343/* Added by the EMX/OS2 port */
344void
345ldemul_finish_link (char *filename)
346{
347 if (ld_emulation->finish_link)
348 ld_emulation->finish_link (filename);
349}
Note: See TracBrowser for help on using the repository browser.