gas/testsuite/
[deliverable/binutils-gdb.git] / ld / emultempl / sunos.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 is generated by a shell script. DO NOT EDIT! */
10
11 /* SunOS emulation code for ${EMULATION_NAME}
12 Copyright 1991, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001,
13 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2012
14 Free Software Foundation, Inc.
15 Written by Steve Chamberlain <sac@cygnus.com>
16 SunOS shared library support by Ian Lance Taylor <ian@cygnus.com>
17
18 This file is part of the GNU Binutils.
19
20 This program is free software; you can redistribute it and/or modify
21 it under the terms of the GNU General Public License as published by
22 the Free Software Foundation; either version 3 of the License, or
23 (at your option) any later version.
24
25 This program is distributed in the hope that it will be useful,
26 but WITHOUT ANY WARRANTY; without even the implied warranty of
27 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
28 GNU General Public License for more details.
29
30 You should have received a copy of the GNU General Public License
31 along with this program; if not, write to the Free Software
32 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
33 MA 02110-1301, USA. */
34
35 #define TARGET_IS_${EMULATION_NAME}
36
37 #include "sysdep.h"
38 #include "bfd.h"
39 #include "bfdlink.h"
40 #include "libiberty.h"
41 #include "safe-ctype.h"
42
43 #include "ld.h"
44 #include "ldmain.h"
45 #include "ldmisc.h"
46 #include "ldexp.h"
47 #include "ldlang.h"
48 #include "ldfile.h"
49 #include "ldemul.h"
50
51 #ifdef HAVE_DIRENT_H
52 # include <dirent.h>
53 #else
54 # define dirent direct
55 # ifdef HAVE_SYS_NDIR_H
56 # include <sys/ndir.h>
57 # endif
58 # ifdef HAVE_SYS_DIR_H
59 # include <sys/dir.h>
60 # endif
61 # ifdef HAVE_NDIR_H
62 # include <ndir.h>
63 # endif
64 #endif
65
66 static void gld${EMULATION_NAME}_find_so
67 (lang_input_statement_type *);
68 static char *gld${EMULATION_NAME}_search_dir
69 (const char *, const char *, bfd_boolean *);
70 static void gld${EMULATION_NAME}_check_needed
71 (lang_input_statement_type *);
72 static bfd_boolean gld${EMULATION_NAME}_search_needed
73 (const char *, const char *);
74 static bfd_boolean gld${EMULATION_NAME}_try_needed
75 (const char *, const char *);
76 static void gld${EMULATION_NAME}_find_assignment
77 (lang_statement_union_type *);
78 static void gld${EMULATION_NAME}_find_exp_assignment
79 (etree_type *);
80 static void gld${EMULATION_NAME}_count_need
81 (lang_input_statement_type *);
82 static void gld${EMULATION_NAME}_set_need
83 (lang_input_statement_type *);
84
85 static void
86 gld${EMULATION_NAME}_before_parse (void)
87 {
88 ldfile_set_output_arch ("${OUTPUT_ARCH}", bfd_arch_`echo ${ARCH} | sed -e 's/:.*//'`);
89 input_flags.dynamic = TRUE;
90 config.has_shared = TRUE;
91 }
92
93 /* This is called after the command line arguments have been parsed,
94 but before the linker script has been read. If this is a native
95 linker, we add the directories in LD_LIBRARY_PATH to the search
96 list. */
97
98 static void
99 gld${EMULATION_NAME}_set_symbols (void)
100 {
101 EOF
102 if [ "x${host}" = "x${target}" ] ; then
103 case " ${EMULATION_LIBPATH} " in
104 *" ${EMULATION_NAME} "*)
105 fragment <<EOF
106 const char *env;
107
108 env = (const char *) getenv ("LD_LIBRARY_PATH");
109 if (env != NULL)
110 {
111 char *l;
112
113 l = xstrdup (env);
114 while (1)
115 {
116 char *c;
117
118 c = strchr (l, ':');
119 if (c != NULL)
120 *c++ = '\0';
121 if (*l != '\0')
122 ldfile_add_library_path (l, FALSE);
123 if (c == NULL)
124 break;
125 l = c;
126 }
127 }
128 EOF
129 ;;
130 esac
131 fi
132 fragment <<EOF
133 }
134
135 /* Despite the name, we use this routine to search for dynamic
136 libraries. On SunOS this requires a directory search. We need to
137 find the .so file with the highest version number. The user may
138 restrict the major version by saying, e.g., -lc.1. Also, if we
139 find a .so file, we need to look for a the same file after
140 replacing .so with .sa; if it exists, it will be an archive which
141 provide some initializations for data symbols, and we need to
142 search it after including the .so file. */
143
144 static void
145 gld${EMULATION_NAME}_create_output_section_statements (void)
146 {
147 lang_for_each_input_file (gld${EMULATION_NAME}_find_so);
148 }
149
150 /* Search the directory for a .so file for each library search. */
151
152 static void
153 gld${EMULATION_NAME}_find_so (lang_input_statement_type *inp)
154 {
155 search_dirs_type *search;
156 char *found = NULL;
157 char *alc;
158 struct stat st;
159
160 if (! inp->flags.search_dirs
161 || ! inp->flags.maybe_archive
162 || ! inp->flags.dynamic)
163 return;
164
165 ASSERT (CONST_STRNEQ (inp->local_sym_name, "-l"));
166
167 for (search = search_head; search != NULL; search = search->next)
168 {
169 bfd_boolean found_static;
170
171 found = gld${EMULATION_NAME}_search_dir (search->name, inp->filename,
172 &found_static);
173 if (found != NULL || found_static)
174 break;
175 }
176
177 if (found == NULL)
178 {
179 /* We did not find a matching .so file. This isn't an error,
180 since there might still be a matching .a file, which will be
181 found by the usual search. */
182 return;
183 }
184
185 /* Replace the filename with the one we have found. */
186 alc = (char *) xmalloc (strlen (search->name) + strlen (found) + 2);
187 sprintf (alc, "%s/%s", search->name, found);
188 inp->filename = alc;
189
190 /* Turn off the search_dirs_flag to prevent ldfile_open_file from
191 searching for this file again. */
192 inp->flags.search_dirs = FALSE;
193
194 free (found);
195
196 /* Now look for the same file name, but with .sa instead of .so. If
197 found, add it to the list of input files. */
198 alc = (char *) xmalloc (strlen (inp->filename) + 1);
199 strcpy (alc, inp->filename);
200 strstr (alc + strlen (search->name), ".so")[2] = 'a';
201 if (stat (alc, &st) != 0)
202 free (alc);
203 else
204 {
205 lang_input_statement_type *sa;
206
207 /* Add the .sa file to the statement list just before the .so
208 file. This is really a hack. */
209 sa = ((lang_input_statement_type *)
210 xmalloc (sizeof (lang_input_statement_type)));
211 *sa = *inp;
212
213 inp->filename = alc;
214 inp->local_sym_name = alc;
215
216 inp->header.next = (lang_statement_union_type *) sa;
217 inp->next_real_file = (lang_statement_union_type *) sa;
218 }
219 }
220
221 /* Search a directory for a .so file. */
222
223 static char *
224 gld${EMULATION_NAME}_search_dir
225 (const char *dirname, const char *filename, bfd_boolean *found_static)
226 {
227 int force_maj, force_min;
228 const char *dot;
229 unsigned int len;
230 char *alc;
231 char *found;
232 int max_maj, max_min;
233 DIR *dir;
234 struct dirent *entry;
235 unsigned int dirnamelen;
236 char *full_path;
237 int statval;
238 struct stat st;
239
240 *found_static = FALSE;
241
242 force_maj = -1;
243 force_min = -1;
244 dot = strchr (filename, '.');
245 if (dot == NULL)
246 {
247 len = strlen (filename);
248 alc = NULL;
249 }
250 else
251 {
252 force_maj = atoi (dot + 1);
253
254 len = dot - filename;
255 alc = (char *) xmalloc (len + 1);
256 strncpy (alc, filename, len);
257 alc[len] = '\0';
258 filename = alc;
259
260 dot = strchr (dot + 1, '.');
261 if (dot != NULL)
262 force_min = atoi (dot + 1);
263 }
264
265 found = NULL;
266 max_maj = max_min = 0;
267
268 dir = opendir (dirname);
269 if (dir == NULL)
270 return NULL;
271 dirnamelen = strlen (dirname);
272
273 while ((entry = readdir (dir)) != NULL)
274 {
275 const char *s;
276 int found_maj, found_min;
277
278 if (! CONST_STRNEQ (entry->d_name, "lib")
279 || strncmp (entry->d_name + 3, filename, len) != 0)
280 continue;
281
282 if (dot == NULL
283 && strcmp (entry->d_name + 3 + len, ".a") == 0)
284 {
285 *found_static = TRUE;
286 continue;
287 }
288
289 /* We accept libfoo.so without a version number, even though the
290 native linker does not. This is more convenient for packages
291 which just generate .so files for shared libraries, as on ELF
292 systems. */
293 if (! CONST_STRNEQ (entry->d_name + 3 + len, ".so"))
294 continue;
295 if (entry->d_name[6 + len] == '\0')
296 ;
297 else if (entry->d_name[6 + len] == '.'
298 && ISDIGIT (entry->d_name[7 + len]))
299 ;
300 else
301 continue;
302
303 for (s = entry->d_name + 6 + len; *s != '\0'; s++)
304 if (*s != '.' && ! ISDIGIT (*s))
305 break;
306 if (*s != '\0')
307 continue;
308
309 /* We've found a .so file. Work out the major and minor
310 version numbers. */
311 found_maj = 0;
312 found_min = 0;
313 sscanf (entry->d_name + 3 + len, ".so.%d.%d",
314 &found_maj, &found_min);
315
316 if ((force_maj != -1 && force_maj != found_maj)
317 || (force_min != -1 && force_min != found_min))
318 continue;
319
320 /* Make sure the file really exists (ignore broken symlinks). */
321 full_path = xmalloc (dirnamelen + 1 + strlen (entry->d_name) + 1);
322 sprintf (full_path, "%s/%s", dirname, entry->d_name);
323 statval = stat (full_path, &st);
324 free (full_path);
325 if (statval != 0)
326 continue;
327
328 /* We've found a match for the name we are searching for. See
329 if this is the version we should use. If the major and minor
330 versions match, we use the last entry in alphabetical order;
331 I don't know if this is how SunOS distinguishes libc.so.1.8
332 from libc.so.1.8.1, but it ought to suffice. */
333 if (found == NULL
334 || (found_maj > max_maj)
335 || (found_maj == max_maj
336 && (found_min > max_min
337 || (found_min == max_min
338 && strcmp (entry->d_name, found) > 0))))
339 {
340 if (found != NULL)
341 free (found);
342 found = (char *) xmalloc (strlen (entry->d_name) + 1);
343 strcpy (found, entry->d_name);
344 max_maj = found_maj;
345 max_min = found_min;
346 }
347 }
348
349 closedir (dir);
350
351 if (alc != NULL)
352 free (alc);
353
354 return found;
355 }
356
357 /* These variables are required to pass information back and forth
358 between after_open and check_needed. */
359
360 static struct bfd_link_needed_list *global_needed;
361 static bfd_boolean global_found;
362
363 /* This is called after all the input files have been opened. */
364
365 static void
366 gld${EMULATION_NAME}_after_open (void)
367 {
368 struct bfd_link_needed_list *needed, *l;
369
370 after_open_default ();
371
372 /* We only need to worry about this when doing a final link. */
373 if (link_info.relocatable || link_info.shared)
374 return;
375
376 /* Get the list of files which appear in ld_need entries in dynamic
377 objects included in the link. For each such file, we want to
378 track down the corresponding library, and include the symbol
379 table in the link. This is what the runtime dynamic linker will
380 do. Tracking the files down here permits one dynamic object to
381 include another without requiring special action by the person
382 doing the link. Note that the needed list can actually grow
383 while we are stepping through this loop. */
384 needed = bfd_sunos_get_needed_list (link_info.output_bfd, &link_info);
385 for (l = needed; l != NULL; l = l->next)
386 {
387 struct bfd_link_needed_list *ll;
388 const char *lname;
389 search_dirs_type *search;
390
391 lname = l->name;
392
393 /* If we've already seen this file, skip it. */
394 for (ll = needed; ll != l; ll = ll->next)
395 if (strcmp (ll->name, lname) == 0)
396 break;
397 if (ll != l)
398 continue;
399
400 /* See if this file was included in the link explicitly. */
401 global_needed = l;
402 global_found = FALSE;
403 lang_for_each_input_file (gld${EMULATION_NAME}_check_needed);
404 if (global_found)
405 continue;
406
407 if (! CONST_STRNEQ (lname, "-l"))
408 {
409 bfd *abfd;
410
411 abfd = bfd_openr (lname, bfd_get_target (link_info.output_bfd));
412 if (abfd != NULL)
413 {
414 if (! bfd_check_format (abfd, bfd_object))
415 {
416 (void) bfd_close (abfd);
417 abfd = NULL;
418 }
419 }
420 if (abfd != NULL)
421 {
422 if ((bfd_get_file_flags (abfd) & DYNAMIC) == 0)
423 {
424 (void) bfd_close (abfd);
425 abfd = NULL;
426 }
427 }
428 if (abfd != NULL)
429 {
430 /* We've found the needed dynamic object. */
431 if (! bfd_link_add_symbols (abfd, &link_info))
432 einfo ("%F%B: could not read symbols: %E\n", abfd);
433 }
434 else
435 {
436 einfo ("%P: warning: %s, needed by %B, not found\n",
437 lname, l->by);
438 }
439
440 continue;
441 }
442
443 lname += 2;
444
445 /* We want to search for the file in the same way that the
446 dynamic linker will search. That means that we want to use
447 rpath_link, rpath or -L, then the environment variable
448 LD_LIBRARY_PATH (native only), then (if rpath was used) the
449 linker script LIB_SEARCH_DIRS. */
450 if (gld${EMULATION_NAME}_search_needed (command_line.rpath_link,
451 lname))
452 continue;
453 if (command_line.rpath != NULL)
454 {
455 if (gld${EMULATION_NAME}_search_needed (command_line.rpath, lname))
456 continue;
457 }
458 else
459 {
460 for (search = search_head; search != NULL; search = search->next)
461 if (gld${EMULATION_NAME}_try_needed (search->name, lname))
462 break;
463 if (search != NULL)
464 continue;
465 }
466 EOF
467 if [ "x${host}" = "x${target}" ] ; then
468 case " ${EMULATION_LIBPATH} " in
469 *" ${EMULATION_NAME} "*)
470 fragment <<EOF
471 {
472 const char *lib_path;
473
474 lib_path = (const char *) getenv ("LD_LIBRARY_PATH");
475 if (gld${EMULATION_NAME}_search_needed (lib_path, lname))
476 continue;
477 }
478 EOF
479 ;;
480 esac
481 fi
482 fragment <<EOF
483 if (command_line.rpath != NULL)
484 {
485 for (search = search_head; search != NULL; search = search->next)
486 {
487 if (search->cmdline)
488 continue;
489 if (gld${EMULATION_NAME}_try_needed (search->name, lname))
490 break;
491 }
492 if (search != NULL)
493 continue;
494 }
495
496 einfo ("%P: warning: %s, needed by %B, not found\n",
497 l->name, l->by);
498 }
499 }
500
501 /* Search for a needed file in a path. */
502
503 static bfd_boolean
504 gld${EMULATION_NAME}_search_needed (const char *path, const char *name)
505 {
506 const char *s;
507
508 if (path == NULL || *path == '\0')
509 return FALSE;
510 while (1)
511 {
512 const char *dir;
513 char *dircopy;
514
515 s = strchr (path, ':');
516 if (s == NULL)
517 {
518 dircopy = NULL;
519 dir = path;
520 }
521 else
522 {
523 dircopy = (char *) xmalloc (s - path + 1);
524 memcpy (dircopy, path, s - path);
525 dircopy[s - path] = '\0';
526 dir = dircopy;
527 }
528
529 if (gld${EMULATION_NAME}_try_needed (dir, name))
530 return TRUE;
531
532 if (dircopy != NULL)
533 free (dircopy);
534
535 if (s == NULL)
536 break;
537 path = s + 1;
538 }
539
540 return FALSE;
541 }
542
543 /* This function is called for each possible directory for a needed
544 dynamic object. */
545
546 static bfd_boolean
547 gld${EMULATION_NAME}_try_needed (const char *dir, const char *name)
548 {
549 char *file;
550 char *alc;
551 bfd_boolean ignore;
552 bfd *abfd;
553
554 file = gld${EMULATION_NAME}_search_dir (dir, name, &ignore);
555 if (file == NULL)
556 return FALSE;
557
558 alc = (char *) xmalloc (strlen (dir) + strlen (file) + 2);
559 sprintf (alc, "%s/%s", dir, file);
560 free (file);
561 abfd = bfd_openr (alc, bfd_get_target (link_info.output_bfd));
562 if (abfd == NULL)
563 return FALSE;
564 if (! bfd_check_format (abfd, bfd_object))
565 {
566 (void) bfd_close (abfd);
567 return FALSE;
568 }
569 if ((bfd_get_file_flags (abfd) & DYNAMIC) == 0)
570 {
571 (void) bfd_close (abfd);
572 return FALSE;
573 }
574
575 /* We've found the needed dynamic object. */
576
577 /* Add this file into the symbol table. */
578 if (! bfd_link_add_symbols (abfd, &link_info))
579 einfo ("%F%B: could not read symbols: %E\n", abfd);
580
581 return TRUE;
582 }
583
584 /* See if we have already included a needed object in the link. This
585 does not have to be precise, as it does no harm to include a
586 dynamic object more than once. */
587
588 static void
589 gld${EMULATION_NAME}_check_needed (lang_input_statement_type *s)
590 {
591 if (s->filename == NULL)
592 return;
593 if (! CONST_STRNEQ (global_needed->name, "-l"))
594 {
595 if (strcmp (s->filename, global_needed->name) == 0)
596 global_found = TRUE;
597 }
598 else
599 {
600 const char *sname, *lname;
601 const char *sdot, *ldot;
602 int lmaj, lmin, smaj, smin;
603
604 lname = global_needed->name + 2;
605
606 sname = strrchr (s->filename, '/');
607 if (sname == NULL)
608 sname = s->filename;
609 else
610 ++sname;
611
612 if (! CONST_STRNEQ (sname, "lib"))
613 return;
614 sname += 3;
615
616 ldot = strchr (lname, '.');
617 if (ldot == NULL)
618 ldot = lname + strlen (lname);
619
620 sdot = strstr (sname, ".so.");
621 if (sdot == NULL)
622 return;
623
624 if (sdot - sname != ldot - lname
625 || strncmp (lname, sname, sdot - sname) != 0)
626 return;
627
628 lmaj = lmin = -1;
629 sscanf (ldot, ".%d.%d", &lmaj, &lmin);
630 smaj = smin = -1;
631 sscanf (sdot, ".so.%d.%d", &smaj, &smin);
632 if ((smaj != lmaj && smaj != -1 && lmaj != -1)
633 || (smin != lmin && smin != -1 && lmin != -1))
634 return;
635
636 global_found = TRUE;
637 }
638 }
639
640 /* We need to use static variables to pass information around the call
641 to lang_for_each_statement. Ick. */
642
643 static const char *find_assign;
644 static bfd_boolean found_assign;
645
646 /* We need to use static variables to pass information around the call
647 to lang_for_each_input_file. Ick. */
648
649 static bfd_size_type need_size;
650 static bfd_size_type need_entries;
651 static bfd_byte *need_contents;
652 static bfd_byte *need_pinfo;
653 static bfd_byte *need_pnames;
654
655 /* The size of one entry in the .need section, not including the file
656 name. */
657
658 #define NEED_ENTRY_SIZE (16)
659
660 /* This is called after the sections have been attached to output
661 sections, but before any sizes or addresses have been set. */
662
663 static void
664 gld${EMULATION_NAME}_before_allocation (void)
665 {
666 struct bfd_link_hash_entry *hdyn = NULL;
667 asection *sneed;
668 asection *srules;
669 asection *sdyn;
670
671 /* The SunOS native linker creates a shared library whenever there
672 are any undefined symbols in a link, unless -e is used. This is
673 pretty weird, but we are compatible. */
674 if (! link_info.shared && ! link_info.relocatable && ! entry_from_cmdline)
675 {
676 struct bfd_link_hash_entry *h;
677
678 for (h = link_info.hash->undefs; h != NULL; h = h->u.undef.next)
679 {
680 if (h->type == bfd_link_hash_undefined
681 && h->u.undef.abfd != NULL
682 && (h->u.undef.abfd->flags & DYNAMIC) == 0
683 && strcmp (h->root.string, "__DYNAMIC") != 0
684 && strcmp (h->root.string, "__GLOBAL_OFFSET_TABLE_") != 0)
685 {
686 find_assign = h->root.string;
687 found_assign = FALSE;
688 lang_for_each_statement (gld${EMULATION_NAME}_find_assignment);
689 if (! found_assign)
690 {
691 link_info.shared = TRUE;
692 break;
693 }
694 }
695 }
696 }
697
698 if (link_info.shared)
699 {
700 lang_output_section_statement_type *os;
701
702 /* Set the .text section to start at 0x20, not 0x2020. FIXME:
703 This is too magical. */
704 os = lang_output_section_statement_lookup (".text", 0, TRUE);
705 if (os->addr_tree == NULL)
706 os->addr_tree = exp_intop (0x20);
707 }
708
709 /* We need to create a __DYNAMIC symbol. We don't do this in the
710 linker script because we want to set the value to the start of
711 the dynamic section if there is one, or to zero if there isn't
712 one. We need to create the symbol before calling
713 size_dynamic_sections, although we can't set the value until
714 afterward. */
715 if (! link_info.relocatable)
716 {
717 hdyn = bfd_link_hash_lookup (link_info.hash, "__DYNAMIC", TRUE, FALSE,
718 FALSE);
719 if (hdyn == NULL)
720 einfo ("%P%F: bfd_link_hash_lookup: %E\n");
721 if (! bfd_sunos_record_link_assignment (link_info.output_bfd, &link_info,
722 "__DYNAMIC"))
723 einfo ("%P%F: failed to record assignment to __DYNAMIC: %E\n");
724 }
725
726 /* If we are going to make any variable assignments, we need to let
727 the backend linker know about them in case the variables are
728 referred to by dynamic objects. */
729 lang_for_each_statement (gld${EMULATION_NAME}_find_assignment);
730
731 /* Let the backend linker work out the sizes of any sections
732 required by dynamic linking. */
733 if (! bfd_sunos_size_dynamic_sections (link_info.output_bfd, &link_info,
734 &sdyn, &sneed, &srules))
735 einfo ("%P%F: failed to set dynamic section sizes: %E\n");
736
737 if (sneed != NULL)
738 {
739 /* Set up the .need section. See the description of the ld_need
740 field in include/aout/sun4.h. */
741
742 need_entries = 0;
743 need_size = 0;
744
745 lang_for_each_input_file (gld${EMULATION_NAME}_count_need);
746
747 /* We should only have a .need section if we have at least one
748 dynamic object. */
749 ASSERT (need_entries != 0);
750
751 sneed->size = need_size;
752 sneed->contents = (bfd_byte *) xmalloc (need_size);
753
754 need_contents = sneed->contents;
755 need_pinfo = sneed->contents;
756 need_pnames = sneed->contents + need_entries * 16;
757
758 lang_for_each_input_file (gld${EMULATION_NAME}_set_need);
759
760 ASSERT ((bfd_size_type) (need_pnames - sneed->contents) == need_size);
761 }
762
763 if (srules != NULL)
764 {
765 /* Set up the .rules section. This is just a PATH like string
766 of the -L arguments given on the command line. We permit the
767 user to specify the directories using the -rpath command line
768 option. */
769 if (command_line.rpath)
770 {
771 srules->size = strlen (command_line.rpath);
772 srules->contents = (bfd_byte *) command_line.rpath;
773 }
774 else
775 {
776 unsigned int size;
777 search_dirs_type *search;
778
779 size = 0;
780 for (search = search_head; search != NULL; search = search->next)
781 if (search->cmdline)
782 size += strlen (search->name) + 1;
783 srules->size = size;
784 if (size > 0)
785 {
786 char *p;
787
788 srules->contents = (bfd_byte *) xmalloc (size);
789 p = (char *) srules->contents;
790 *p = '\0';
791 for (search = search_head; search != NULL; search = search->next)
792 {
793 if (search->cmdline)
794 {
795 if (p != (char *) srules->contents)
796 *p++ = ':';
797 strcpy (p, search->name);
798 p += strlen (p);
799 }
800 }
801 }
802 }
803 }
804
805 /* We must assign a value to __DYNAMIC. It should be zero if we are
806 not doing a dynamic link, or the start of the .dynamic section if
807 we are doing one. */
808 if (! link_info.relocatable)
809 {
810 hdyn->type = bfd_link_hash_defined;
811 hdyn->u.def.value = 0;
812 if (sdyn != NULL)
813 hdyn->u.def.section = sdyn;
814 else
815 hdyn->u.def.section = bfd_abs_section_ptr;
816 }
817
818 before_allocation_default ();
819 }
820
821 /* This is called by the before_allocation routine via
822 lang_for_each_statement. It does one of two things: if the
823 variable find_assign is set, it sets found_assign if it finds an
824 assignment to that variable; otherwise it tells the backend linker
825 about all assignment statements, in case they are assignments to
826 symbols which are referred to by dynamic objects. */
827
828 static void
829 gld${EMULATION_NAME}_find_assignment (lang_statement_union_type *s)
830 {
831 if (s->header.type == lang_assignment_statement_enum
832 && (find_assign == NULL || ! found_assign))
833 gld${EMULATION_NAME}_find_exp_assignment (s->assignment_statement.exp);
834 }
835
836 /* Look through an expression for an assignment statement. */
837
838 static void
839 gld${EMULATION_NAME}_find_exp_assignment (etree_type *exp)
840 {
841 switch (exp->type.node_class)
842 {
843 case etree_assign:
844 if (find_assign != NULL)
845 {
846 if (strcmp (find_assign, exp->assign.dst) == 0)
847 found_assign = TRUE;
848 return;
849 }
850
851 if (strcmp (exp->assign.dst, ".") != 0)
852 {
853 if (! bfd_sunos_record_link_assignment (link_info.output_bfd,
854 &link_info,
855 exp->assign.dst))
856 einfo ("%P%F: failed to record assignment to %s: %E\n",
857 exp->assign.dst);
858 }
859 gld${EMULATION_NAME}_find_exp_assignment (exp->assign.src);
860 break;
861
862 case etree_binary:
863 gld${EMULATION_NAME}_find_exp_assignment (exp->binary.lhs);
864 gld${EMULATION_NAME}_find_exp_assignment (exp->binary.rhs);
865 break;
866
867 case etree_trinary:
868 gld${EMULATION_NAME}_find_exp_assignment (exp->trinary.cond);
869 gld${EMULATION_NAME}_find_exp_assignment (exp->trinary.lhs);
870 gld${EMULATION_NAME}_find_exp_assignment (exp->trinary.rhs);
871 break;
872
873 case etree_unary:
874 gld${EMULATION_NAME}_find_exp_assignment (exp->unary.child);
875 break;
876
877 default:
878 break;
879 }
880 }
881
882 /* Work out the size of the .need section, and the number of entries.
883 The backend will set the ld_need field of the dynamic linking
884 information to point to the .need section. See include/aout/sun4.h
885 for more information. */
886
887 static void
888 gld${EMULATION_NAME}_count_need (lang_input_statement_type *inp)
889 {
890 if (inp->the_bfd != NULL
891 && (inp->the_bfd->flags & DYNAMIC) != 0)
892 {
893 ++need_entries;
894 need_size += NEED_ENTRY_SIZE;
895 if (! inp->flags.maybe_archive)
896 need_size += strlen (inp->filename) + 1;
897 else
898 {
899 ASSERT (inp->local_sym_name[0] == '-'
900 && inp->local_sym_name[1] == 'l');
901 need_size += strlen (inp->local_sym_name + 2) + 1;
902 }
903 }
904 }
905
906 /* Fill in the contents of the .need section. */
907
908 static void
909 gld${EMULATION_NAME}_set_need (lang_input_statement_type *inp)
910 {
911 if (inp->the_bfd != NULL
912 && (inp->the_bfd->flags & DYNAMIC) != 0)
913 {
914 bfd_size_type c;
915
916 /* To really fill in the .need section contents, we need to know
917 the final file position of the section, but we don't.
918 Instead, we use offsets, and rely on the BFD backend to
919 finish the section up correctly. FIXME: Talk about lack of
920 referential locality. */
921 bfd_put_32 (link_info.output_bfd, need_pnames - need_contents,
922 need_pinfo);
923 if (! inp->flags.maybe_archive)
924 {
925 bfd_put_32 (link_info.output_bfd, (bfd_vma) 0, need_pinfo + 4);
926 bfd_put_16 (link_info.output_bfd, (bfd_vma) 0, need_pinfo + 8);
927 bfd_put_16 (link_info.output_bfd, (bfd_vma) 0, need_pinfo + 10);
928 strcpy ((char *) need_pnames, inp->filename);
929 }
930 else
931 {
932 char *verstr;
933 int maj, min;
934
935 bfd_put_32 (link_info.output_bfd, (bfd_vma) 0x80000000,
936 need_pinfo + 4);
937 maj = 0;
938 min = 0;
939 verstr = strstr (inp->filename, ".so.");
940 if (verstr != NULL)
941 sscanf (verstr, ".so.%d.%d", &maj, &min);
942 bfd_put_16 (link_info.output_bfd, (bfd_vma) maj, need_pinfo + 8);
943 bfd_put_16 (link_info.output_bfd, (bfd_vma) min, need_pinfo + 10);
944 strcpy ((char *) need_pnames, inp->local_sym_name + 2);
945 }
946
947 c = (need_pinfo - need_contents) / NEED_ENTRY_SIZE;
948 if (c + 1 >= need_entries)
949 bfd_put_32 (link_info.output_bfd, (bfd_vma) 0, need_pinfo + 12);
950 else
951 bfd_put_32 (link_info.output_bfd, (bfd_vma) (c + 1) * NEED_ENTRY_SIZE,
952 need_pinfo + 12);
953
954 need_pinfo += NEED_ENTRY_SIZE;
955 need_pnames += strlen ((char *) need_pnames) + 1;
956 }
957 }
958
959 static char *
960 gld${EMULATION_NAME}_get_script (int *isfile)
961 EOF
962
963 if test -n "$COMPILE_IN"
964 then
965 # Scripts compiled in.
966
967 # sed commands to quote an ld script as a C string.
968 sc="-f stringify.sed"
969
970 fragment <<EOF
971 {
972 *isfile = 0;
973
974 if (link_info.relocatable && config.build_constructors)
975 return
976 EOF
977 sed $sc ldscripts/${EMULATION_NAME}.xu >> e${EMULATION_NAME}.c
978 echo ' ; else if (link_info.relocatable) return' >> e${EMULATION_NAME}.c
979 sed $sc ldscripts/${EMULATION_NAME}.xr >> e${EMULATION_NAME}.c
980 echo ' ; else if (!config.text_read_only) return' >> e${EMULATION_NAME}.c
981 sed $sc ldscripts/${EMULATION_NAME}.xbn >> e${EMULATION_NAME}.c
982 echo ' ; else if (!config.magic_demand_paged) return' >> e${EMULATION_NAME}.c
983 sed $sc ldscripts/${EMULATION_NAME}.xn >> e${EMULATION_NAME}.c
984 echo ' ; else return' >> e${EMULATION_NAME}.c
985 sed $sc ldscripts/${EMULATION_NAME}.x >> e${EMULATION_NAME}.c
986 echo '; }' >> e${EMULATION_NAME}.c
987
988 else
989 # Scripts read from the filesystem.
990
991 fragment <<EOF
992 {
993 *isfile = 1;
994
995 if (link_info.relocatable && config.build_constructors)
996 return "ldscripts/${EMULATION_NAME}.xu";
997 else if (link_info.relocatable)
998 return "ldscripts/${EMULATION_NAME}.xr";
999 else if (!config.text_read_only)
1000 return "ldscripts/${EMULATION_NAME}.xbn";
1001 else if (!config.magic_demand_paged)
1002 return "ldscripts/${EMULATION_NAME}.xn";
1003 else
1004 return "ldscripts/${EMULATION_NAME}.x";
1005 }
1006 EOF
1007
1008 fi
1009
1010 fragment <<EOF
1011
1012 struct ld_emulation_xfer_struct ld_${EMULATION_NAME}_emulation =
1013 {
1014 gld${EMULATION_NAME}_before_parse,
1015 syslib_default,
1016 hll_default,
1017 after_parse_default,
1018 gld${EMULATION_NAME}_after_open,
1019 after_allocation_default,
1020 set_output_arch_default,
1021 ldemul_default_target,
1022 gld${EMULATION_NAME}_before_allocation,
1023 gld${EMULATION_NAME}_get_script,
1024 "${EMULATION_NAME}",
1025 "${OUTPUT_FORMAT}",
1026 finish_default,
1027 gld${EMULATION_NAME}_create_output_section_statements,
1028 NULL, /* open dynamic archive */
1029 NULL, /* place orphan */
1030 gld${EMULATION_NAME}_set_symbols,
1031 NULL, /* parse args */
1032 NULL, /* add_options */
1033 NULL, /* handle_option */
1034 NULL, /* unrecognized file */
1035 NULL, /* list options */
1036 NULL, /* recognized file */
1037 NULL, /* find_potential_libraries */
1038 NULL /* new_vers_pattern */
1039 };
1040 EOF
This page took 0.050092 seconds and 4 git commands to generate.