* ax-gdb.c (gen_var_ref): Use SYMBOL_LINKAGE_NAME.
[deliverable/binutils-gdb.git] / gdb / dbxread.c
1 /* Read dbx symbol tables and convert to internal format, for GDB.
2 Copyright (C) 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995,
3 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2008.
4 Free Software Foundation, Inc.
5
6 This file is part of GDB.
7
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
12
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
20
21 /* This module provides three functions: dbx_symfile_init,
22 which initializes to read a symbol file; dbx_new_init, which
23 discards existing cached information when all symbols are being
24 discarded; and dbx_symfile_read, which reads a symbol table
25 from a file.
26
27 dbx_symfile_read only does the minimum work necessary for letting the
28 user "name" things symbolically; it does not read the entire symtab.
29 Instead, it reads the external and static symbols and puts them in partial
30 symbol tables. When more extensive information is requested of a
31 file, the corresponding partial symbol table is mutated into a full
32 fledged symbol table by going back and reading the symbols
33 for real. dbx_psymtab_to_symtab() is the function that does this */
34
35 #include "defs.h"
36 #include "gdb_string.h"
37
38 #if defined(__CYGNUSCLIB__)
39 #include <sys/types.h>
40 #include <fcntl.h>
41 #endif
42
43 #include "gdb_obstack.h"
44 #include "gdb_stat.h"
45 #include "symtab.h"
46 #include "breakpoint.h"
47 #include "target.h"
48 #include "gdbcore.h" /* for bfd stuff */
49 #include "libaout.h" /* FIXME Secret internal BFD stuff for a.out */
50 #include "objfiles.h"
51 #include "buildsym.h"
52 #include "stabsread.h"
53 #include "gdb-stabs.h"
54 #include "demangle.h"
55 #include "complaints.h"
56 #include "cp-abi.h"
57
58 #include "gdb_assert.h"
59 #include "gdb_string.h"
60
61 #include "aout/aout64.h"
62 #include "aout/stab_gnu.h" /* We always use GNU stabs, not native, now */
63 \f
64
65 /* We put a pointer to this structure in the read_symtab_private field
66 of the psymtab. */
67
68 struct symloc
69 {
70 /* Offset within the file symbol table of first local symbol for this
71 file. */
72
73 int ldsymoff;
74
75 /* Length (in bytes) of the section of the symbol table devoted to
76 this file's symbols (actually, the section bracketed may contain
77 more than just this file's symbols). If ldsymlen is 0, the only
78 reason for this thing's existence is the dependency list. Nothing
79 else will happen when it is read in. */
80
81 int ldsymlen;
82
83 /* The size of each symbol in the symbol file (in external form). */
84
85 int symbol_size;
86
87 /* Further information needed to locate the symbols if they are in
88 an ELF file. */
89
90 int symbol_offset;
91 int string_offset;
92 int file_string_offset;
93 };
94
95 #define LDSYMOFF(p) (((struct symloc *)((p)->read_symtab_private))->ldsymoff)
96 #define LDSYMLEN(p) (((struct symloc *)((p)->read_symtab_private))->ldsymlen)
97 #define SYMLOC(p) ((struct symloc *)((p)->read_symtab_private))
98 #define SYMBOL_SIZE(p) (SYMLOC(p)->symbol_size)
99 #define SYMBOL_OFFSET(p) (SYMLOC(p)->symbol_offset)
100 #define STRING_OFFSET(p) (SYMLOC(p)->string_offset)
101 #define FILE_STRING_OFFSET(p) (SYMLOC(p)->file_string_offset)
102 \f
103
104 /* Remember what we deduced to be the source language of this psymtab. */
105
106 static enum language psymtab_language = language_unknown;
107
108 /* The BFD for this file -- implicit parameter to next_symbol_text. */
109
110 static bfd *symfile_bfd;
111
112 /* The size of each symbol in the symbol file (in external form).
113 This is set by dbx_symfile_read when building psymtabs, and by
114 dbx_psymtab_to_symtab when building symtabs. */
115
116 static unsigned symbol_size;
117
118 /* This is the offset of the symbol table in the executable file. */
119
120 static unsigned symbol_table_offset;
121
122 /* This is the offset of the string table in the executable file. */
123
124 static unsigned string_table_offset;
125
126 /* For elf+stab executables, the n_strx field is not a simple index
127 into the string table. Instead, each .o file has a base offset in
128 the string table, and the associated symbols contain offsets from
129 this base. The following two variables contain the base offset for
130 the current and next .o files. */
131
132 static unsigned int file_string_table_offset;
133 static unsigned int next_file_string_table_offset;
134
135 /* .o and NLM files contain unrelocated addresses which are based at
136 0. When non-zero, this flag disables some of the special cases for
137 Solaris elf+stab text addresses at location 0. */
138
139 static int symfile_relocatable = 0;
140
141 /* If this is nonzero, N_LBRAC, N_RBRAC, and N_SLINE entries are
142 relative to the function start address. */
143
144 static int block_address_function_relative = 0;
145 \f
146 /* The lowest text address we have yet encountered. This is needed
147 because in an a.out file, there is no header field which tells us
148 what address the program is actually going to be loaded at, so we
149 need to make guesses based on the symbols (which *are* relocated to
150 reflect the address it will be loaded at). */
151
152 static CORE_ADDR lowest_text_address;
153
154 /* Non-zero if there is any line number info in the objfile. Prevents
155 end_psymtab from discarding an otherwise empty psymtab. */
156
157 static int has_line_numbers;
158
159 /* Complaints about the symbols we have encountered. */
160
161 static void
162 unknown_symtype_complaint (const char *arg1)
163 {
164 complaint (&symfile_complaints, _("unknown symbol type %s"), arg1);
165 }
166
167 static void
168 lbrac_mismatch_complaint (int arg1)
169 {
170 complaint (&symfile_complaints,
171 _("N_LBRAC/N_RBRAC symbol mismatch at symtab pos %d"), arg1);
172 }
173
174 static void
175 repeated_header_complaint (const char *arg1, int arg2)
176 {
177 complaint (&symfile_complaints,
178 _("\"repeated\" header file %s not previously seen, at symtab \
179 pos %d"),
180 arg1, arg2);
181 }
182
183 /* find_text_range --- find start and end of loadable code sections
184
185 The find_text_range function finds the shortest address range that
186 encloses all sections containing executable code, and stores it in
187 objfile's text_addr and text_size members.
188
189 dbx_symfile_read will use this to finish off the partial symbol
190 table, in some cases. */
191
192 static void
193 find_text_range (bfd * sym_bfd, struct objfile *objfile)
194 {
195 asection *sec;
196 int found_any = 0;
197 CORE_ADDR start = 0;
198 CORE_ADDR end = 0;
199
200 for (sec = sym_bfd->sections; sec; sec = sec->next)
201 if (bfd_get_section_flags (sym_bfd, sec) & SEC_CODE)
202 {
203 CORE_ADDR sec_start = bfd_section_vma (sym_bfd, sec);
204 CORE_ADDR sec_end = sec_start + bfd_section_size (sym_bfd, sec);
205
206 if (found_any)
207 {
208 if (sec_start < start)
209 start = sec_start;
210 if (sec_end > end)
211 end = sec_end;
212 }
213 else
214 {
215 start = sec_start;
216 end = sec_end;
217 }
218
219 found_any = 1;
220 }
221
222 if (!found_any)
223 error (_("Can't find any code sections in symbol file"));
224
225 DBX_TEXT_ADDR (objfile) = start;
226 DBX_TEXT_SIZE (objfile) = end - start;
227 }
228 \f
229
230
231 /* During initial symbol readin, we need to have a structure to keep
232 track of which psymtabs have which bincls in them. This structure
233 is used during readin to setup the list of dependencies within each
234 partial symbol table. */
235
236 struct header_file_location
237 {
238 char *name; /* Name of header file */
239 int instance; /* See above */
240 struct partial_symtab *pst; /* Partial symtab that has the
241 BINCL/EINCL defs for this file */
242 };
243
244 /* The actual list and controling variables */
245 static struct header_file_location *bincl_list, *next_bincl;
246 static int bincls_allocated;
247
248 /* Local function prototypes */
249
250 extern void _initialize_dbxread (void);
251
252 static void read_ofile_symtab (struct partial_symtab *);
253
254 static void dbx_psymtab_to_symtab (struct partial_symtab *);
255
256 static void dbx_psymtab_to_symtab_1 (struct partial_symtab *);
257
258 static void read_dbx_dynamic_symtab (struct objfile *objfile);
259
260 static void read_dbx_symtab (struct objfile *);
261
262 static void free_bincl_list (struct objfile *);
263
264 static struct partial_symtab *find_corresponding_bincl_psymtab (char *, int);
265
266 static void add_bincl_to_list (struct partial_symtab *, char *, int);
267
268 static void init_bincl_list (int, struct objfile *);
269
270 static char *dbx_next_symbol_text (struct objfile *);
271
272 static void fill_symbuf (bfd *);
273
274 static void dbx_symfile_init (struct objfile *);
275
276 static void dbx_new_init (struct objfile *);
277
278 static void dbx_symfile_read (struct objfile *, int);
279
280 static void dbx_symfile_finish (struct objfile *);
281
282 static void record_minimal_symbol (char *, CORE_ADDR, int, struct objfile *);
283
284 static void add_new_header_file (char *, int);
285
286 static void add_old_header_file (char *, int);
287
288 static void add_this_object_header_file (int);
289
290 static struct partial_symtab *start_psymtab (struct objfile *, char *,
291 CORE_ADDR, int,
292 struct partial_symbol **,
293 struct partial_symbol **);
294
295 /* Free up old header file tables */
296
297 void
298 free_header_files (void)
299 {
300 if (this_object_header_files)
301 {
302 xfree (this_object_header_files);
303 this_object_header_files = NULL;
304 }
305 n_allocated_this_object_header_files = 0;
306 }
307
308 /* Allocate new header file tables */
309
310 void
311 init_header_files (void)
312 {
313 n_allocated_this_object_header_files = 10;
314 this_object_header_files = (int *) xmalloc (10 * sizeof (int));
315 }
316
317 /* Add header file number I for this object file
318 at the next successive FILENUM. */
319
320 static void
321 add_this_object_header_file (int i)
322 {
323 if (n_this_object_header_files == n_allocated_this_object_header_files)
324 {
325 n_allocated_this_object_header_files *= 2;
326 this_object_header_files
327 = (int *) xrealloc ((char *) this_object_header_files,
328 n_allocated_this_object_header_files * sizeof (int));
329 }
330
331 this_object_header_files[n_this_object_header_files++] = i;
332 }
333
334 /* Add to this file an "old" header file, one already seen in
335 a previous object file. NAME is the header file's name.
336 INSTANCE is its instance code, to select among multiple
337 symbol tables for the same header file. */
338
339 static void
340 add_old_header_file (char *name, int instance)
341 {
342 struct header_file *p = HEADER_FILES (current_objfile);
343 int i;
344
345 for (i = 0; i < N_HEADER_FILES (current_objfile); i++)
346 if (strcmp (p[i].name, name) == 0 && instance == p[i].instance)
347 {
348 add_this_object_header_file (i);
349 return;
350 }
351 repeated_header_complaint (name, symnum);
352 }
353
354 /* Add to this file a "new" header file: definitions for its types follow.
355 NAME is the header file's name.
356 Most often this happens only once for each distinct header file,
357 but not necessarily. If it happens more than once, INSTANCE has
358 a different value each time, and references to the header file
359 use INSTANCE values to select among them.
360
361 dbx output contains "begin" and "end" markers for each new header file,
362 but at this level we just need to know which files there have been;
363 so we record the file when its "begin" is seen and ignore the "end". */
364
365 static void
366 add_new_header_file (char *name, int instance)
367 {
368 int i;
369 struct header_file *hfile;
370
371 /* Make sure there is room for one more header file. */
372
373 i = N_ALLOCATED_HEADER_FILES (current_objfile);
374
375 if (N_HEADER_FILES (current_objfile) == i)
376 {
377 if (i == 0)
378 {
379 N_ALLOCATED_HEADER_FILES (current_objfile) = 10;
380 HEADER_FILES (current_objfile) = (struct header_file *)
381 xmalloc (10 * sizeof (struct header_file));
382 }
383 else
384 {
385 i *= 2;
386 N_ALLOCATED_HEADER_FILES (current_objfile) = i;
387 HEADER_FILES (current_objfile) = (struct header_file *)
388 xrealloc ((char *) HEADER_FILES (current_objfile),
389 (i * sizeof (struct header_file)));
390 }
391 }
392
393 /* Create an entry for this header file. */
394
395 i = N_HEADER_FILES (current_objfile)++;
396 hfile = HEADER_FILES (current_objfile) + i;
397 hfile->name = savestring (name, strlen (name));
398 hfile->instance = instance;
399 hfile->length = 10;
400 hfile->vector
401 = (struct type **) xmalloc (10 * sizeof (struct type *));
402 memset (hfile->vector, 0, 10 * sizeof (struct type *));
403
404 add_this_object_header_file (i);
405 }
406
407 #if 0
408 static struct type **
409 explicit_lookup_type (int real_filenum, int index)
410 {
411 struct header_file *f = &HEADER_FILES (current_objfile)[real_filenum];
412
413 if (index >= f->length)
414 {
415 f->length *= 2;
416 f->vector = (struct type **)
417 xrealloc (f->vector, f->length * sizeof (struct type *));
418 memset (&f->vector[f->length / 2],
419 '\0', f->length * sizeof (struct type *) / 2);
420 }
421 return &f->vector[index];
422 }
423 #endif
424 \f
425 static void
426 record_minimal_symbol (char *name, CORE_ADDR address, int type,
427 struct objfile *objfile)
428 {
429 enum minimal_symbol_type ms_type;
430 int section;
431 asection *bfd_section;
432
433 switch (type)
434 {
435 case N_TEXT | N_EXT:
436 ms_type = mst_text;
437 section = SECT_OFF_TEXT (objfile);
438 bfd_section = DBX_TEXT_SECTION (objfile);
439 break;
440 case N_DATA | N_EXT:
441 ms_type = mst_data;
442 section = SECT_OFF_DATA (objfile);
443 bfd_section = DBX_DATA_SECTION (objfile);
444 break;
445 case N_BSS | N_EXT:
446 ms_type = mst_bss;
447 section = SECT_OFF_BSS (objfile);
448 bfd_section = DBX_BSS_SECTION (objfile);
449 break;
450 case N_ABS | N_EXT:
451 ms_type = mst_abs;
452 section = -1;
453 bfd_section = NULL;
454 break;
455 #ifdef N_SETV
456 case N_SETV | N_EXT:
457 ms_type = mst_data;
458 section = SECT_OFF_DATA (objfile);
459 bfd_section = DBX_DATA_SECTION (objfile);
460 break;
461 case N_SETV:
462 /* I don't think this type actually exists; since a N_SETV is the result
463 of going over many .o files, it doesn't make sense to have one
464 file local. */
465 ms_type = mst_file_data;
466 section = SECT_OFF_DATA (objfile);
467 bfd_section = DBX_DATA_SECTION (objfile);
468 break;
469 #endif
470 case N_TEXT:
471 case N_NBTEXT:
472 case N_FN:
473 case N_FN_SEQ:
474 ms_type = mst_file_text;
475 section = SECT_OFF_TEXT (objfile);
476 bfd_section = DBX_TEXT_SECTION (objfile);
477 break;
478 case N_DATA:
479 ms_type = mst_file_data;
480
481 /* Check for __DYNAMIC, which is used by Sun shared libraries.
482 Record it as global even if it's local, not global, so
483 lookup_minimal_symbol can find it. We don't check symbol_leading_char
484 because for SunOS4 it always is '_'. */
485 if (name[8] == 'C' && strcmp ("__DYNAMIC", name) == 0)
486 ms_type = mst_data;
487
488 /* Same with virtual function tables, both global and static. */
489 {
490 char *tempstring = name;
491 if (tempstring[0] == bfd_get_symbol_leading_char (objfile->obfd))
492 ++tempstring;
493 if (is_vtable_name (tempstring))
494 ms_type = mst_data;
495 }
496 section = SECT_OFF_DATA (objfile);
497 bfd_section = DBX_DATA_SECTION (objfile);
498 break;
499 case N_BSS:
500 ms_type = mst_file_bss;
501 section = SECT_OFF_BSS (objfile);
502 bfd_section = DBX_BSS_SECTION (objfile);
503 break;
504 default:
505 ms_type = mst_unknown;
506 section = -1;
507 bfd_section = NULL;
508 break;
509 }
510
511 if ((ms_type == mst_file_text || ms_type == mst_text)
512 && address < lowest_text_address)
513 lowest_text_address = address;
514
515 prim_record_minimal_symbol_and_info
516 (name, address, ms_type, NULL, section, bfd_section, objfile);
517 }
518 \f
519 /* Scan and build partial symbols for a symbol file.
520 We have been initialized by a call to dbx_symfile_init, which
521 put all the relevant info into a "struct dbx_symfile_info",
522 hung off the objfile structure.
523
524 MAINLINE is true if we are reading the main symbol
525 table (as opposed to a shared lib or dynamically loaded file). */
526
527 static void
528 dbx_symfile_read (struct objfile *objfile, int mainline)
529 {
530 bfd *sym_bfd;
531 int val;
532 struct cleanup *back_to;
533
534 sym_bfd = objfile->obfd;
535
536 /* .o and .nlm files are relocatables with text, data and bss segs based at
537 0. This flag disables special (Solaris stabs-in-elf only) fixups for
538 symbols with a value of 0. */
539
540 symfile_relocatable = bfd_get_file_flags (sym_bfd) & HAS_RELOC;
541
542 /* This is true for Solaris (and all other systems which put stabs
543 in sections, hopefully, since it would be silly to do things
544 differently from Solaris), and false for SunOS4 and other a.out
545 file formats. */
546 block_address_function_relative =
547 ((0 == strncmp (bfd_get_target (sym_bfd), "elf", 3))
548 || (0 == strncmp (bfd_get_target (sym_bfd), "som", 3))
549 || (0 == strncmp (bfd_get_target (sym_bfd), "coff", 4))
550 || (0 == strncmp (bfd_get_target (sym_bfd), "pe", 2))
551 || (0 == strncmp (bfd_get_target (sym_bfd), "epoc-pe", 7))
552 || (0 == strncmp (bfd_get_target (sym_bfd), "nlm", 3)));
553
554 val = bfd_seek (sym_bfd, DBX_SYMTAB_OFFSET (objfile), SEEK_SET);
555 if (val < 0)
556 perror_with_name (objfile->name);
557
558 /* If we are reinitializing, or if we have never loaded syms yet, init */
559 if (mainline
560 || (objfile->global_psymbols.size == 0
561 && objfile->static_psymbols.size == 0))
562 init_psymbol_list (objfile, DBX_SYMCOUNT (objfile));
563
564 symbol_size = DBX_SYMBOL_SIZE (objfile);
565 symbol_table_offset = DBX_SYMTAB_OFFSET (objfile);
566
567 free_pending_blocks ();
568 back_to = make_cleanup (really_free_pendings, 0);
569
570 init_minimal_symbol_collection ();
571 make_cleanup_discard_minimal_symbols ();
572
573 /* Read stabs data from executable file and define symbols. */
574
575 read_dbx_symtab (objfile);
576
577 /* Add the dynamic symbols. */
578
579 read_dbx_dynamic_symtab (objfile);
580
581 /* Install any minimal symbols that have been collected as the current
582 minimal symbols for this objfile. */
583
584 install_minimal_symbols (objfile);
585
586 do_cleanups (back_to);
587 }
588
589 /* Initialize anything that needs initializing when a completely new
590 symbol file is specified (not just adding some symbols from another
591 file, e.g. a shared library). */
592
593 static void
594 dbx_new_init (struct objfile *ignore)
595 {
596 stabsread_new_init ();
597 buildsym_new_init ();
598 init_header_files ();
599 }
600
601
602 /* dbx_symfile_init ()
603 is the dbx-specific initialization routine for reading symbols.
604 It is passed a struct objfile which contains, among other things,
605 the BFD for the file whose symbols are being read, and a slot for a pointer
606 to "private data" which we fill with goodies.
607
608 We read the string table into malloc'd space and stash a pointer to it.
609
610 Since BFD doesn't know how to read debug symbols in a format-independent
611 way (and may never do so...), we have to do it ourselves. We will never
612 be called unless this is an a.out (or very similar) file.
613 FIXME, there should be a cleaner peephole into the BFD environment here. */
614
615 #define DBX_STRINGTAB_SIZE_SIZE sizeof(long) /* FIXME */
616
617 static void
618 dbx_symfile_init (struct objfile *objfile)
619 {
620 int val;
621 bfd *sym_bfd = objfile->obfd;
622 char *name = bfd_get_filename (sym_bfd);
623 asection *text_sect;
624 unsigned char size_temp[DBX_STRINGTAB_SIZE_SIZE];
625
626 /* Allocate struct to keep track of the symfile */
627 objfile->deprecated_sym_stab_info = (struct dbx_symfile_info *)
628 xmalloc (sizeof (struct dbx_symfile_info));
629 memset (objfile->deprecated_sym_stab_info, 0,
630 sizeof (struct dbx_symfile_info));
631
632 DBX_TEXT_SECTION (objfile) = bfd_get_section_by_name (sym_bfd, ".text");
633 DBX_DATA_SECTION (objfile) = bfd_get_section_by_name (sym_bfd, ".data");
634 DBX_BSS_SECTION (objfile) = bfd_get_section_by_name (sym_bfd, ".bss");
635
636 /* FIXME POKING INSIDE BFD DATA STRUCTURES */
637 #define STRING_TABLE_OFFSET (sym_bfd->origin + obj_str_filepos (sym_bfd))
638 #define SYMBOL_TABLE_OFFSET (sym_bfd->origin + obj_sym_filepos (sym_bfd))
639
640 /* FIXME POKING INSIDE BFD DATA STRUCTURES */
641
642 DBX_SYMFILE_INFO (objfile)->stab_section_info = NULL;
643
644 text_sect = bfd_get_section_by_name (sym_bfd, ".text");
645 if (!text_sect)
646 error (_("Can't find .text section in symbol file"));
647 DBX_TEXT_ADDR (objfile) = bfd_section_vma (sym_bfd, text_sect);
648 DBX_TEXT_SIZE (objfile) = bfd_section_size (sym_bfd, text_sect);
649
650 DBX_SYMBOL_SIZE (objfile) = obj_symbol_entry_size (sym_bfd);
651 DBX_SYMCOUNT (objfile) = bfd_get_symcount (sym_bfd);
652 DBX_SYMTAB_OFFSET (objfile) = SYMBOL_TABLE_OFFSET;
653
654 /* Read the string table and stash it away in the objfile_obstack.
655 When we blow away the objfile the string table goes away as well.
656 Note that gdb used to use the results of attempting to malloc the
657 string table, based on the size it read, as a form of sanity check
658 for botched byte swapping, on the theory that a byte swapped string
659 table size would be so totally bogus that the malloc would fail. Now
660 that we put in on the objfile_obstack, we can't do this since gdb gets
661 a fatal error (out of virtual memory) if the size is bogus. We can
662 however at least check to see if the size is less than the size of
663 the size field itself, or larger than the size of the entire file.
664 Note that all valid string tables have a size greater than zero, since
665 the bytes used to hold the size are included in the count. */
666
667 if (STRING_TABLE_OFFSET == 0)
668 {
669 /* It appears that with the existing bfd code, STRING_TABLE_OFFSET
670 will never be zero, even when there is no string table. This
671 would appear to be a bug in bfd. */
672 DBX_STRINGTAB_SIZE (objfile) = 0;
673 DBX_STRINGTAB (objfile) = NULL;
674 }
675 else
676 {
677 val = bfd_seek (sym_bfd, STRING_TABLE_OFFSET, SEEK_SET);
678 if (val < 0)
679 perror_with_name (name);
680
681 memset (size_temp, 0, sizeof (size_temp));
682 val = bfd_bread (size_temp, sizeof (size_temp), sym_bfd);
683 if (val < 0)
684 {
685 perror_with_name (name);
686 }
687 else if (val == 0)
688 {
689 /* With the existing bfd code, STRING_TABLE_OFFSET will be set to
690 EOF if there is no string table, and attempting to read the size
691 from EOF will read zero bytes. */
692 DBX_STRINGTAB_SIZE (objfile) = 0;
693 DBX_STRINGTAB (objfile) = NULL;
694 }
695 else
696 {
697 /* Read some data that would appear to be the string table size.
698 If there really is a string table, then it is probably the right
699 size. Byteswap if necessary and validate the size. Note that
700 the minimum is DBX_STRINGTAB_SIZE_SIZE. If we just read some
701 random data that happened to be at STRING_TABLE_OFFSET, because
702 bfd can't tell us there is no string table, the sanity checks may
703 or may not catch this. */
704 DBX_STRINGTAB_SIZE (objfile) = bfd_h_get_32 (sym_bfd, size_temp);
705
706 if (DBX_STRINGTAB_SIZE (objfile) < sizeof (size_temp)
707 || DBX_STRINGTAB_SIZE (objfile) > bfd_get_size (sym_bfd))
708 error (_("ridiculous string table size (%d bytes)."),
709 DBX_STRINGTAB_SIZE (objfile));
710
711 DBX_STRINGTAB (objfile) =
712 (char *) obstack_alloc (&objfile->objfile_obstack,
713 DBX_STRINGTAB_SIZE (objfile));
714 OBJSTAT (objfile, sz_strtab += DBX_STRINGTAB_SIZE (objfile));
715
716 /* Now read in the string table in one big gulp. */
717
718 val = bfd_seek (sym_bfd, STRING_TABLE_OFFSET, SEEK_SET);
719 if (val < 0)
720 perror_with_name (name);
721 val = bfd_bread (DBX_STRINGTAB (objfile),
722 DBX_STRINGTAB_SIZE (objfile),
723 sym_bfd);
724 if (val != DBX_STRINGTAB_SIZE (objfile))
725 perror_with_name (name);
726 }
727 }
728 }
729
730 /* Perform any local cleanups required when we are done with a particular
731 objfile. I.E, we are in the process of discarding all symbol information
732 for an objfile, freeing up all memory held for it, and unlinking the
733 objfile struct from the global list of known objfiles. */
734
735 static void
736 dbx_symfile_finish (struct objfile *objfile)
737 {
738 if (objfile->deprecated_sym_stab_info != NULL)
739 {
740 if (HEADER_FILES (objfile) != NULL)
741 {
742 int i = N_HEADER_FILES (objfile);
743 struct header_file *hfiles = HEADER_FILES (objfile);
744
745 while (--i >= 0)
746 {
747 xfree (hfiles[i].name);
748 xfree (hfiles[i].vector);
749 }
750 xfree (hfiles);
751 }
752 xfree (objfile->deprecated_sym_stab_info);
753 }
754 free_header_files ();
755 }
756 \f
757
758 /* Buffer for reading the symbol table entries. */
759 static struct external_nlist symbuf[4096];
760 static int symbuf_idx;
761 static int symbuf_end;
762
763 /* Name of last function encountered. Used in Solaris to approximate
764 object file boundaries. */
765 static char *last_function_name;
766
767 /* The address in memory of the string table of the object file we are
768 reading (which might not be the "main" object file, but might be a
769 shared library or some other dynamically loaded thing). This is
770 set by read_dbx_symtab when building psymtabs, and by
771 read_ofile_symtab when building symtabs, and is used only by
772 next_symbol_text. FIXME: If that is true, we don't need it when
773 building psymtabs, right? */
774 static char *stringtab_global;
775
776 /* These variables are used to control fill_symbuf when the stabs
777 symbols are not contiguous (as may be the case when a COFF file is
778 linked using --split-by-reloc). */
779 static struct stab_section_list *symbuf_sections;
780 static unsigned int symbuf_left;
781 static unsigned int symbuf_read;
782
783 /* This variable stores a global stabs buffer, if we read stabs into
784 memory in one chunk in order to process relocations. */
785 static bfd_byte *stabs_data;
786
787 /* Refill the symbol table input buffer
788 and set the variables that control fetching entries from it.
789 Reports an error if no data available.
790 This function can read past the end of the symbol table
791 (into the string table) but this does no harm. */
792
793 static void
794 fill_symbuf (bfd *sym_bfd)
795 {
796 unsigned int count;
797 int nbytes;
798
799 if (stabs_data)
800 {
801 nbytes = sizeof (symbuf);
802 if (nbytes > symbuf_left)
803 nbytes = symbuf_left;
804 memcpy (symbuf, stabs_data + symbuf_read, nbytes);
805 }
806 else if (symbuf_sections == NULL)
807 {
808 count = sizeof (symbuf);
809 nbytes = bfd_bread (symbuf, count, sym_bfd);
810 }
811 else
812 {
813 if (symbuf_left <= 0)
814 {
815 file_ptr filepos = symbuf_sections->section->filepos;
816 if (bfd_seek (sym_bfd, filepos, SEEK_SET) != 0)
817 perror_with_name (bfd_get_filename (sym_bfd));
818 symbuf_left = bfd_section_size (sym_bfd, symbuf_sections->section);
819 symbol_table_offset = filepos - symbuf_read;
820 symbuf_sections = symbuf_sections->next;
821 }
822
823 count = symbuf_left;
824 if (count > sizeof (symbuf))
825 count = sizeof (symbuf);
826 nbytes = bfd_bread (symbuf, count, sym_bfd);
827 }
828
829 if (nbytes < 0)
830 perror_with_name (bfd_get_filename (sym_bfd));
831 else if (nbytes == 0)
832 error (_("Premature end of file reading symbol table"));
833 symbuf_end = nbytes / symbol_size;
834 symbuf_idx = 0;
835 symbuf_left -= nbytes;
836 symbuf_read += nbytes;
837 }
838
839 static void
840 stabs_seek (int sym_offset)
841 {
842 if (stabs_data)
843 {
844 symbuf_read += sym_offset;
845 symbuf_left -= sym_offset;
846 }
847 else
848 bfd_seek (symfile_bfd, sym_offset, SEEK_CUR);
849 }
850
851 #define INTERNALIZE_SYMBOL(intern, extern, abfd) \
852 { \
853 (intern).n_strx = bfd_h_get_32 (abfd, (extern)->e_strx); \
854 (intern).n_type = bfd_h_get_8 (abfd, (extern)->e_type); \
855 (intern).n_other = 0; \
856 (intern).n_desc = bfd_h_get_16 (abfd, (extern)->e_desc); \
857 if (bfd_get_sign_extend_vma (abfd)) \
858 (intern).n_value = bfd_h_get_signed_32 (abfd, (extern)->e_value); \
859 else \
860 (intern).n_value = bfd_h_get_32 (abfd, (extern)->e_value); \
861 }
862
863 /* Invariant: The symbol pointed to by symbuf_idx is the first one
864 that hasn't been swapped. Swap the symbol at the same time
865 that symbuf_idx is incremented. */
866
867 /* dbx allows the text of a symbol name to be continued into the
868 next symbol name! When such a continuation is encountered
869 (a \ at the end of the text of a name)
870 call this function to get the continuation. */
871
872 static char *
873 dbx_next_symbol_text (struct objfile *objfile)
874 {
875 struct internal_nlist nlist;
876
877 if (symbuf_idx == symbuf_end)
878 fill_symbuf (symfile_bfd);
879
880 symnum++;
881 INTERNALIZE_SYMBOL (nlist, &symbuf[symbuf_idx], symfile_bfd);
882 OBJSTAT (objfile, n_stabs++);
883
884 symbuf_idx++;
885
886 return nlist.n_strx + stringtab_global + file_string_table_offset;
887 }
888 \f
889 /* Initialize the list of bincls to contain none and have some
890 allocated. */
891
892 static void
893 init_bincl_list (int number, struct objfile *objfile)
894 {
895 bincls_allocated = number;
896 next_bincl = bincl_list = (struct header_file_location *)
897 xmalloc (bincls_allocated * sizeof (struct header_file_location));
898 }
899
900 /* Add a bincl to the list. */
901
902 static void
903 add_bincl_to_list (struct partial_symtab *pst, char *name, int instance)
904 {
905 if (next_bincl >= bincl_list + bincls_allocated)
906 {
907 int offset = next_bincl - bincl_list;
908 bincls_allocated *= 2;
909 bincl_list = (struct header_file_location *)
910 xrealloc ((char *) bincl_list,
911 bincls_allocated * sizeof (struct header_file_location));
912 next_bincl = bincl_list + offset;
913 }
914 next_bincl->pst = pst;
915 next_bincl->instance = instance;
916 next_bincl++->name = name;
917 }
918
919 /* Given a name, value pair, find the corresponding
920 bincl in the list. Return the partial symtab associated
921 with that header_file_location. */
922
923 static struct partial_symtab *
924 find_corresponding_bincl_psymtab (char *name, int instance)
925 {
926 struct header_file_location *bincl;
927
928 for (bincl = bincl_list; bincl < next_bincl; bincl++)
929 if (bincl->instance == instance
930 && strcmp (name, bincl->name) == 0)
931 return bincl->pst;
932
933 repeated_header_complaint (name, symnum);
934 return (struct partial_symtab *) 0;
935 }
936
937 /* Free the storage allocated for the bincl list. */
938
939 static void
940 free_bincl_list (struct objfile *objfile)
941 {
942 xfree (bincl_list);
943 bincls_allocated = 0;
944 }
945
946 static void
947 do_free_bincl_list_cleanup (void *objfile)
948 {
949 free_bincl_list (objfile);
950 }
951
952 static struct cleanup *
953 make_cleanup_free_bincl_list (struct objfile *objfile)
954 {
955 return make_cleanup (do_free_bincl_list_cleanup, objfile);
956 }
957
958 /* Set namestring based on nlist. If the string table index is invalid,
959 give a fake name, and print a single error message per symbol file read,
960 rather than abort the symbol reading or flood the user with messages. */
961
962 static char *
963 set_namestring (struct objfile *objfile, const struct internal_nlist *nlist)
964 {
965 char *namestring;
966
967 if (((unsigned) nlist->n_strx + file_string_table_offset)
968 >= DBX_STRINGTAB_SIZE (objfile))
969 {
970 complaint (&symfile_complaints, _("bad string table offset in symbol %d"),
971 symnum);
972 namestring = "<bad string table offset>";
973 }
974 else
975 namestring = (nlist->n_strx + file_string_table_offset
976 + DBX_STRINGTAB (objfile));
977 return namestring;
978 }
979
980 /* Scan a SunOs dynamic symbol table for symbols of interest and
981 add them to the minimal symbol table. */
982
983 static void
984 read_dbx_dynamic_symtab (struct objfile *objfile)
985 {
986 bfd *abfd = objfile->obfd;
987 struct cleanup *back_to;
988 int counter;
989 long dynsym_size;
990 long dynsym_count;
991 asymbol **dynsyms;
992 asymbol **symptr;
993 arelent **relptr;
994 long dynrel_size;
995 long dynrel_count;
996 arelent **dynrels;
997 CORE_ADDR sym_value;
998 char *name;
999
1000 /* Check that the symbol file has dynamic symbols that we know about.
1001 bfd_arch_unknown can happen if we are reading a sun3 symbol file
1002 on a sun4 host (and vice versa) and bfd is not configured
1003 --with-target=all. This would trigger an assertion in bfd/sunos.c,
1004 so we ignore the dynamic symbols in this case. */
1005 if (bfd_get_flavour (abfd) != bfd_target_aout_flavour
1006 || (bfd_get_file_flags (abfd) & DYNAMIC) == 0
1007 || bfd_get_arch (abfd) == bfd_arch_unknown)
1008 return;
1009
1010 dynsym_size = bfd_get_dynamic_symtab_upper_bound (abfd);
1011 if (dynsym_size < 0)
1012 return;
1013
1014 dynsyms = (asymbol **) xmalloc (dynsym_size);
1015 back_to = make_cleanup (xfree, dynsyms);
1016
1017 dynsym_count = bfd_canonicalize_dynamic_symtab (abfd, dynsyms);
1018 if (dynsym_count < 0)
1019 {
1020 do_cleanups (back_to);
1021 return;
1022 }
1023
1024 /* Enter dynamic symbols into the minimal symbol table
1025 if this is a stripped executable. */
1026 if (bfd_get_symcount (abfd) <= 0)
1027 {
1028 symptr = dynsyms;
1029 for (counter = 0; counter < dynsym_count; counter++, symptr++)
1030 {
1031 asymbol *sym = *symptr;
1032 asection *sec;
1033 int type;
1034
1035 sec = bfd_get_section (sym);
1036
1037 /* BFD symbols are section relative. */
1038 sym_value = sym->value + sec->vma;
1039
1040 if (bfd_get_section_flags (abfd, sec) & SEC_CODE)
1041 {
1042 sym_value += ANOFFSET (objfile->section_offsets,
1043 SECT_OFF_TEXT (objfile));
1044 type = N_TEXT;
1045 }
1046 else if (bfd_get_section_flags (abfd, sec) & SEC_DATA)
1047 {
1048 sym_value += ANOFFSET (objfile->section_offsets,
1049 SECT_OFF_DATA (objfile));
1050 type = N_DATA;
1051 }
1052 else if (bfd_get_section_flags (abfd, sec) & SEC_ALLOC)
1053 {
1054 sym_value += ANOFFSET (objfile->section_offsets,
1055 SECT_OFF_BSS (objfile));
1056 type = N_BSS;
1057 }
1058 else
1059 continue;
1060
1061 if (sym->flags & BSF_GLOBAL)
1062 type |= N_EXT;
1063
1064 record_minimal_symbol ((char *) bfd_asymbol_name (sym), sym_value,
1065 type, objfile);
1066 }
1067 }
1068
1069 /* Symbols from shared libraries have a dynamic relocation entry
1070 that points to the associated slot in the procedure linkage table.
1071 We make a mininal symbol table entry with type mst_solib_trampoline
1072 at the address in the procedure linkage table. */
1073 dynrel_size = bfd_get_dynamic_reloc_upper_bound (abfd);
1074 if (dynrel_size < 0)
1075 {
1076 do_cleanups (back_to);
1077 return;
1078 }
1079
1080 dynrels = (arelent **) xmalloc (dynrel_size);
1081 make_cleanup (xfree, dynrels);
1082
1083 dynrel_count = bfd_canonicalize_dynamic_reloc (abfd, dynrels, dynsyms);
1084 if (dynrel_count < 0)
1085 {
1086 do_cleanups (back_to);
1087 return;
1088 }
1089
1090 for (counter = 0, relptr = dynrels;
1091 counter < dynrel_count;
1092 counter++, relptr++)
1093 {
1094 arelent *rel = *relptr;
1095 CORE_ADDR address =
1096 rel->address + ANOFFSET (objfile->section_offsets,
1097 SECT_OFF_DATA (objfile));
1098
1099 switch (bfd_get_arch (abfd))
1100 {
1101 case bfd_arch_sparc:
1102 if (rel->howto->type != RELOC_JMP_SLOT)
1103 continue;
1104 break;
1105 case bfd_arch_m68k:
1106 /* `16' is the type BFD produces for a jump table relocation. */
1107 if (rel->howto->type != 16)
1108 continue;
1109
1110 /* Adjust address in the jump table to point to
1111 the start of the bsr instruction. */
1112 address -= 2;
1113 break;
1114 default:
1115 continue;
1116 }
1117
1118 name = (char *) bfd_asymbol_name (*rel->sym_ptr_ptr);
1119 prim_record_minimal_symbol (name, address, mst_solib_trampoline,
1120 objfile);
1121 }
1122
1123 do_cleanups (back_to);
1124 }
1125
1126 static CORE_ADDR
1127 find_stab_function_addr (char *namestring, char *filename,
1128 struct objfile *objfile)
1129 {
1130 struct minimal_symbol *msym;
1131 char *p;
1132 int n;
1133
1134 p = strchr (namestring, ':');
1135 if (p == NULL)
1136 p = namestring;
1137 n = p - namestring;
1138 p = alloca (n + 2);
1139 strncpy (p, namestring, n);
1140 p[n] = 0;
1141
1142 msym = lookup_minimal_symbol (p, filename, objfile);
1143 if (msym == NULL)
1144 {
1145 /* Sun Fortran appends an underscore to the minimal symbol name,
1146 try again with an appended underscore if the minimal symbol
1147 was not found. */
1148 p[n] = '_';
1149 p[n + 1] = 0;
1150 msym = lookup_minimal_symbol (p, filename, objfile);
1151 }
1152
1153 if (msym == NULL && filename != NULL)
1154 {
1155 /* Try again without the filename. */
1156 p[n] = 0;
1157 msym = lookup_minimal_symbol (p, NULL, objfile);
1158 }
1159 if (msym == NULL && filename != NULL)
1160 {
1161 /* And try again for Sun Fortran, but without the filename. */
1162 p[n] = '_';
1163 p[n + 1] = 0;
1164 msym = lookup_minimal_symbol (p, NULL, objfile);
1165 }
1166
1167 return msym == NULL ? 0 : SYMBOL_VALUE_ADDRESS (msym);
1168 }
1169
1170 static void
1171 function_outside_compilation_unit_complaint (const char *arg1)
1172 {
1173 complaint (&symfile_complaints,
1174 _("function `%s' appears to be defined outside of all compilation \
1175 units"),
1176 arg1);
1177 }
1178
1179 /* Setup partial_symtab's describing each source file for which
1180 debugging information is available. */
1181
1182 static void
1183 read_dbx_symtab (struct objfile *objfile)
1184 {
1185 struct gdbarch *gdbarch = get_objfile_arch (objfile);
1186 struct external_nlist *bufp = 0; /* =0 avoids gcc -Wall glitch */
1187 struct internal_nlist nlist;
1188 CORE_ADDR text_addr;
1189 int text_size;
1190
1191 char *namestring;
1192 int nsl;
1193 int past_first_source_file = 0;
1194 CORE_ADDR last_o_file_start = 0;
1195 CORE_ADDR last_function_start = 0;
1196 struct cleanup *back_to;
1197 bfd *abfd;
1198 int textlow_not_set;
1199 int data_sect_index;
1200
1201 /* Current partial symtab */
1202 struct partial_symtab *pst;
1203
1204 /* List of current psymtab's include files */
1205 char **psymtab_include_list;
1206 int includes_allocated;
1207 int includes_used;
1208
1209 /* Index within current psymtab dependency list */
1210 struct partial_symtab **dependency_list;
1211 int dependencies_used, dependencies_allocated;
1212
1213 text_addr = DBX_TEXT_ADDR (objfile);
1214 text_size = DBX_TEXT_SIZE (objfile);
1215
1216 /* FIXME. We probably want to change stringtab_global rather than add this
1217 while processing every symbol entry. FIXME. */
1218 file_string_table_offset = 0;
1219 next_file_string_table_offset = 0;
1220
1221 stringtab_global = DBX_STRINGTAB (objfile);
1222
1223 pst = (struct partial_symtab *) 0;
1224
1225 includes_allocated = 30;
1226 includes_used = 0;
1227 psymtab_include_list = (char **) alloca (includes_allocated *
1228 sizeof (char *));
1229
1230 dependencies_allocated = 30;
1231 dependencies_used = 0;
1232 dependency_list =
1233 (struct partial_symtab **) alloca (dependencies_allocated *
1234 sizeof (struct partial_symtab *));
1235
1236 /* Init bincl list */
1237 init_bincl_list (20, objfile);
1238 back_to = make_cleanup_free_bincl_list (objfile);
1239
1240 last_source_file = NULL;
1241
1242 lowest_text_address = (CORE_ADDR) -1;
1243
1244 symfile_bfd = objfile->obfd; /* For next_text_symbol */
1245 abfd = objfile->obfd;
1246 symbuf_end = symbuf_idx = 0;
1247 next_symbol_text_func = dbx_next_symbol_text;
1248 textlow_not_set = 1;
1249 has_line_numbers = 0;
1250
1251 /* FIXME: jimb/2003-09-12: We don't apply the right section's offset
1252 to global and static variables. The stab for a global or static
1253 variable doesn't give us any indication of which section it's in,
1254 so we can't tell immediately which offset in
1255 objfile->section_offsets we should apply to the variable's
1256 address.
1257
1258 We could certainly find out which section contains the variable
1259 by looking up the variable's unrelocated address with
1260 find_pc_section, but that would be expensive; this is the
1261 function that constructs the partial symbol tables by examining
1262 every symbol in the entire executable, and it's
1263 performance-critical. So that expense would not be welcome. I'm
1264 not sure what to do about this at the moment.
1265
1266 What we have done for years is to simply assume that the .data
1267 section's offset is appropriate for all global and static
1268 variables. Recently, this was expanded to fall back to the .bss
1269 section's offset if there is no .data section, and then to the
1270 .rodata section's offset. */
1271 data_sect_index = objfile->sect_index_data;
1272 if (data_sect_index == -1)
1273 data_sect_index = SECT_OFF_BSS (objfile);
1274 if (data_sect_index == -1)
1275 data_sect_index = SECT_OFF_RODATA (objfile);
1276
1277 /* If data_sect_index is still -1, that's okay. It's perfectly fine
1278 for the file to have no .data, no .bss, and no .text at all, if
1279 it also has no global or static variables. If it does, we will
1280 get an internal error from an ANOFFSET macro below when we try to
1281 use data_sect_index. */
1282
1283 for (symnum = 0; symnum < DBX_SYMCOUNT (objfile); symnum++)
1284 {
1285 /* Get the symbol for this run and pull out some info */
1286 QUIT; /* allow this to be interruptable */
1287 if (symbuf_idx == symbuf_end)
1288 fill_symbuf (abfd);
1289 bufp = &symbuf[symbuf_idx++];
1290
1291 /*
1292 * Special case to speed up readin.
1293 */
1294 if (bfd_h_get_8 (abfd, bufp->e_type) == N_SLINE)
1295 {
1296 has_line_numbers = 1;
1297 continue;
1298 }
1299
1300 INTERNALIZE_SYMBOL (nlist, bufp, abfd);
1301 OBJSTAT (objfile, n_stabs++);
1302
1303 /* Ok. There is a lot of code duplicated in the rest of this
1304 switch statement (for efficiency reasons). Since I don't
1305 like duplicating code, I will do my penance here, and
1306 describe the code which is duplicated:
1307
1308 *) The assignment to namestring.
1309 *) The call to strchr.
1310 *) The addition of a partial symbol the the two partial
1311 symbol lists. This last is a large section of code, so
1312 I've imbedded it in the following macro.
1313 */
1314
1315 switch (nlist.n_type)
1316 {
1317 /*
1318 * Standard, external, non-debugger, symbols
1319 */
1320
1321 case N_TEXT | N_EXT:
1322 case N_NBTEXT | N_EXT:
1323 nlist.n_value += ANOFFSET (objfile->section_offsets,
1324 SECT_OFF_TEXT (objfile));
1325 goto record_it;
1326
1327 case N_DATA | N_EXT:
1328 case N_NBDATA | N_EXT:
1329 nlist.n_value += ANOFFSET (objfile->section_offsets,
1330 SECT_OFF_DATA (objfile));
1331 goto record_it;
1332
1333 case N_BSS:
1334 case N_BSS | N_EXT:
1335 case N_NBBSS | N_EXT:
1336 case N_SETV | N_EXT: /* FIXME, is this in BSS? */
1337 nlist.n_value += ANOFFSET (objfile->section_offsets,
1338 SECT_OFF_BSS (objfile));
1339 goto record_it;
1340
1341 case N_ABS | N_EXT:
1342 record_it:
1343 namestring = set_namestring (objfile, &nlist);
1344
1345 bss_ext_symbol:
1346 record_minimal_symbol (namestring, nlist.n_value,
1347 nlist.n_type, objfile); /* Always */
1348 continue;
1349
1350 /* Standard, local, non-debugger, symbols */
1351
1352 case N_NBTEXT:
1353
1354 /* We need to be able to deal with both N_FN or N_TEXT,
1355 because we have no way of knowing whether the sys-supplied ld
1356 or GNU ld was used to make the executable. Sequents throw
1357 in another wrinkle -- they renumbered N_FN. */
1358
1359 case N_FN:
1360 case N_FN_SEQ:
1361 case N_TEXT:
1362 nlist.n_value += ANOFFSET (objfile->section_offsets,
1363 SECT_OFF_TEXT (objfile));
1364 namestring = set_namestring (objfile, &nlist);
1365
1366 if ((namestring[0] == '-' && namestring[1] == 'l')
1367 || (namestring[(nsl = strlen (namestring)) - 1] == 'o'
1368 && namestring[nsl - 2] == '.'))
1369 {
1370 if (past_first_source_file && pst
1371 /* The gould NP1 uses low values for .o and -l symbols
1372 which are not the address. */
1373 && nlist.n_value >= pst->textlow)
1374 {
1375 end_psymtab (pst, psymtab_include_list, includes_used,
1376 symnum * symbol_size,
1377 nlist.n_value > pst->texthigh
1378 ? nlist.n_value : pst->texthigh,
1379 dependency_list, dependencies_used,
1380 textlow_not_set);
1381 pst = (struct partial_symtab *) 0;
1382 includes_used = 0;
1383 dependencies_used = 0;
1384 }
1385 else
1386 past_first_source_file = 1;
1387 last_o_file_start = nlist.n_value;
1388 }
1389 else
1390 goto record_it;
1391 continue;
1392
1393 case N_DATA:
1394 nlist.n_value += ANOFFSET (objfile->section_offsets,
1395 SECT_OFF_DATA (objfile));
1396 goto record_it;
1397
1398 case N_UNDF | N_EXT:
1399 if (nlist.n_value != 0)
1400 {
1401 /* This is a "Fortran COMMON" symbol. See if the target
1402 environment knows where it has been relocated to. */
1403
1404 CORE_ADDR reladdr;
1405
1406 namestring = set_namestring (objfile, &nlist);
1407 if (target_lookup_symbol (namestring, &reladdr))
1408 {
1409 continue; /* Error in lookup; ignore symbol for now. */
1410 }
1411 nlist.n_type ^= (N_BSS ^ N_UNDF); /* Define it as a bss-symbol */
1412 nlist.n_value = reladdr;
1413 goto bss_ext_symbol;
1414 }
1415 continue; /* Just undefined, not COMMON */
1416
1417 case N_UNDF:
1418 if (processing_acc_compilation && nlist.n_strx == 1)
1419 {
1420 /* Deal with relative offsets in the string table
1421 used in ELF+STAB under Solaris. If we want to use the
1422 n_strx field, which contains the name of the file,
1423 we must adjust file_string_table_offset *before* calling
1424 set_namestring(). */
1425 past_first_source_file = 1;
1426 file_string_table_offset = next_file_string_table_offset;
1427 next_file_string_table_offset =
1428 file_string_table_offset + nlist.n_value;
1429 if (next_file_string_table_offset < file_string_table_offset)
1430 error (_("string table offset backs up at %d"), symnum);
1431 /* FIXME -- replace error() with complaint. */
1432 continue;
1433 }
1434 continue;
1435
1436 /* Lots of symbol types we can just ignore. */
1437
1438 case N_ABS:
1439 case N_NBDATA:
1440 case N_NBBSS:
1441 continue;
1442
1443 /* Keep going . . . */
1444
1445 /*
1446 * Special symbol types for GNU
1447 */
1448 case N_INDR:
1449 case N_INDR | N_EXT:
1450 case N_SETA:
1451 case N_SETA | N_EXT:
1452 case N_SETT:
1453 case N_SETT | N_EXT:
1454 case N_SETD:
1455 case N_SETD | N_EXT:
1456 case N_SETB:
1457 case N_SETB | N_EXT:
1458 case N_SETV:
1459 continue;
1460
1461 /*
1462 * Debugger symbols
1463 */
1464
1465 case N_SO:
1466 {
1467 CORE_ADDR valu;
1468 static int prev_so_symnum = -10;
1469 static int first_so_symnum;
1470 char *p;
1471 static char *dirname_nso;
1472 int prev_textlow_not_set;
1473
1474 valu = nlist.n_value + ANOFFSET (objfile->section_offsets,
1475 SECT_OFF_TEXT (objfile));
1476
1477 prev_textlow_not_set = textlow_not_set;
1478
1479 /* A zero value is probably an indication for the SunPRO 3.0
1480 compiler. end_psymtab explicitly tests for zero, so
1481 don't relocate it. */
1482
1483 if (nlist.n_value == 0
1484 && gdbarch_sofun_address_maybe_missing (gdbarch))
1485 {
1486 textlow_not_set = 1;
1487 valu = 0;
1488 }
1489 else
1490 textlow_not_set = 0;
1491
1492 past_first_source_file = 1;
1493
1494 if (prev_so_symnum != symnum - 1)
1495 { /* Here if prev stab wasn't N_SO */
1496 first_so_symnum = symnum;
1497
1498 if (pst)
1499 {
1500 end_psymtab (pst, psymtab_include_list, includes_used,
1501 symnum * symbol_size,
1502 valu > pst->texthigh ? valu : pst->texthigh,
1503 dependency_list, dependencies_used,
1504 prev_textlow_not_set);
1505 pst = (struct partial_symtab *) 0;
1506 includes_used = 0;
1507 dependencies_used = 0;
1508 }
1509 }
1510
1511 prev_so_symnum = symnum;
1512
1513 /* End the current partial symtab and start a new one */
1514
1515 namestring = set_namestring (objfile, &nlist);
1516
1517 /* Null name means end of .o file. Don't start a new one. */
1518 if (*namestring == '\000')
1519 continue;
1520
1521 /* Some compilers (including gcc) emit a pair of initial N_SOs.
1522 The first one is a directory name; the second the file name.
1523 If pst exists, is empty, and has a filename ending in '/',
1524 we assume the previous N_SO was a directory name. */
1525
1526 p = strrchr (namestring, '/');
1527 if (p && *(p + 1) == '\000')
1528 {
1529 /* Save the directory name SOs locally, then save it into
1530 the psymtab when it's created below. */
1531 dirname_nso = namestring;
1532 continue;
1533 }
1534
1535 /* Some other compilers (C++ ones in particular) emit useless
1536 SOs for non-existant .c files. We ignore all subsequent SOs
1537 that immediately follow the first. */
1538
1539 if (!pst)
1540 {
1541 pst = start_psymtab (objfile,
1542 namestring, valu,
1543 first_so_symnum * symbol_size,
1544 objfile->global_psymbols.next,
1545 objfile->static_psymbols.next);
1546 pst->dirname = dirname_nso;
1547 dirname_nso = NULL;
1548 }
1549 continue;
1550 }
1551
1552 case N_BINCL:
1553 {
1554 enum language tmp_language;
1555 /* Add this bincl to the bincl_list for future EXCLs. No
1556 need to save the string; it'll be around until
1557 read_dbx_symtab function returns */
1558
1559 namestring = set_namestring (objfile, &nlist);
1560 tmp_language = deduce_language_from_filename (namestring);
1561
1562 /* Only change the psymtab's language if we've learned
1563 something useful (eg. tmp_language is not language_unknown).
1564 In addition, to match what start_subfile does, never change
1565 from C++ to C. */
1566 if (tmp_language != language_unknown
1567 && (tmp_language != language_c
1568 || psymtab_language != language_cplus))
1569 psymtab_language = tmp_language;
1570
1571 if (pst == NULL)
1572 {
1573 /* FIXME: we should not get here without a PST to work on.
1574 Attempt to recover. */
1575 complaint (&symfile_complaints,
1576 _("N_BINCL %s not in entries for any file, at symtab \
1577 pos %d"),
1578 namestring, symnum);
1579 continue;
1580 }
1581 add_bincl_to_list (pst, namestring, nlist.n_value);
1582
1583 /* Mark down an include file in the current psymtab */
1584
1585 goto record_include_file;
1586 }
1587
1588 case N_SOL:
1589 {
1590 enum language tmp_language;
1591 /* Mark down an include file in the current psymtab */
1592
1593 namestring = set_namestring (objfile, &nlist);
1594 tmp_language = deduce_language_from_filename (namestring);
1595
1596 /* Only change the psymtab's language if we've learned
1597 something useful (eg. tmp_language is not language_unknown).
1598 In addition, to match what start_subfile does, never change
1599 from C++ to C. */
1600 if (tmp_language != language_unknown
1601 && (tmp_language != language_c
1602 || psymtab_language != language_cplus))
1603 psymtab_language = tmp_language;
1604
1605 /* In C++, one may expect the same filename to come round many
1606 times, when code is coming alternately from the main file
1607 and from inline functions in other files. So I check to see
1608 if this is a file we've seen before -- either the main
1609 source file, or a previously included file.
1610
1611 This seems to be a lot of time to be spending on N_SOL, but
1612 things like "break c-exp.y:435" need to work (I
1613 suppose the psymtab_include_list could be hashed or put
1614 in a binary tree, if profiling shows this is a major hog). */
1615 if (pst && strcmp (namestring, pst->filename) == 0)
1616 continue;
1617 {
1618 int i;
1619 for (i = 0; i < includes_used; i++)
1620 if (strcmp (namestring, psymtab_include_list[i]) == 0)
1621 {
1622 i = -1;
1623 break;
1624 }
1625 if (i == -1)
1626 continue;
1627 }
1628
1629 record_include_file:
1630
1631 psymtab_include_list[includes_used++] = namestring;
1632 if (includes_used >= includes_allocated)
1633 {
1634 char **orig = psymtab_include_list;
1635
1636 psymtab_include_list = (char **)
1637 alloca ((includes_allocated *= 2) * sizeof (char *));
1638 memcpy (psymtab_include_list, orig,
1639 includes_used * sizeof (char *));
1640 }
1641 continue;
1642 }
1643 case N_LSYM: /* Typedef or automatic variable. */
1644 case N_STSYM: /* Data seg var -- static */
1645 case N_LCSYM: /* BSS " */
1646 case N_ROSYM: /* Read-only data seg var -- static. */
1647 case N_NBSTS: /* Gould nobase. */
1648 case N_NBLCS: /* symbols. */
1649 case N_FUN:
1650 case N_GSYM: /* Global (extern) variable; can be
1651 data or bss (sigh FIXME). */
1652
1653 /* Following may probably be ignored; I'll leave them here
1654 for now (until I do Pascal and Modula 2 extensions). */
1655
1656 case N_PC: /* I may or may not need this; I
1657 suspect not. */
1658 case N_M2C: /* I suspect that I can ignore this here. */
1659 case N_SCOPE: /* Same. */
1660 {
1661 char *p;
1662
1663 namestring = set_namestring (objfile, &nlist);
1664
1665 /* See if this is an end of function stab. */
1666 if (pst && nlist.n_type == N_FUN && *namestring == '\000')
1667 {
1668 CORE_ADDR valu;
1669
1670 /* It's value is the size (in bytes) of the function for
1671 function relative stabs, or the address of the function's
1672 end for old style stabs. */
1673 valu = nlist.n_value + last_function_start;
1674 if (pst->texthigh == 0 || valu > pst->texthigh)
1675 pst->texthigh = valu;
1676 break;
1677 }
1678
1679 p = (char *) strchr (namestring, ':');
1680 if (!p)
1681 continue; /* Not a debugging symbol. */
1682
1683 /* Main processing section for debugging symbols which
1684 the initial read through the symbol tables needs to worry
1685 about. If we reach this point, the symbol which we are
1686 considering is definitely one we are interested in.
1687 p must also contain the (valid) index into the namestring
1688 which indicates the debugging type symbol. */
1689
1690 switch (p[1])
1691 {
1692 case 'S':
1693 nlist.n_value += ANOFFSET (objfile->section_offsets,
1694 data_sect_index);
1695
1696 if (gdbarch_static_transform_name_p (gdbarch))
1697 namestring = gdbarch_static_transform_name (gdbarch,
1698 namestring);
1699
1700 add_psymbol_to_list (namestring, p - namestring,
1701 VAR_DOMAIN, LOC_STATIC,
1702 &objfile->static_psymbols,
1703 0, nlist.n_value,
1704 psymtab_language, objfile);
1705 continue;
1706
1707 case 'G':
1708 nlist.n_value += ANOFFSET (objfile->section_offsets,
1709 data_sect_index);
1710 /* The addresses in these entries are reported to be
1711 wrong. See the code that reads 'G's for symtabs. */
1712 add_psymbol_to_list (namestring, p - namestring,
1713 VAR_DOMAIN, LOC_STATIC,
1714 &objfile->global_psymbols,
1715 0, nlist.n_value,
1716 psymtab_language, objfile);
1717 continue;
1718
1719 case 'T':
1720 /* When a 'T' entry is defining an anonymous enum, it
1721 may have a name which is the empty string, or a
1722 single space. Since they're not really defining a
1723 symbol, those shouldn't go in the partial symbol
1724 table. We do pick up the elements of such enums at
1725 'check_enum:', below. */
1726 if (p >= namestring + 2
1727 || (p == namestring + 1
1728 && namestring[0] != ' '))
1729 {
1730 add_psymbol_to_list (namestring, p - namestring,
1731 STRUCT_DOMAIN, LOC_TYPEDEF,
1732 &objfile->static_psymbols,
1733 nlist.n_value, 0,
1734 psymtab_language, objfile);
1735 if (p[2] == 't')
1736 {
1737 /* Also a typedef with the same name. */
1738 add_psymbol_to_list (namestring, p - namestring,
1739 VAR_DOMAIN, LOC_TYPEDEF,
1740 &objfile->static_psymbols,
1741 nlist.n_value, 0,
1742 psymtab_language, objfile);
1743 p += 1;
1744 }
1745 }
1746 goto check_enum;
1747
1748 case 't':
1749 if (p != namestring) /* a name is there, not just :T... */
1750 {
1751 add_psymbol_to_list (namestring, p - namestring,
1752 VAR_DOMAIN, LOC_TYPEDEF,
1753 &objfile->static_psymbols,
1754 nlist.n_value, 0,
1755 psymtab_language, objfile);
1756 }
1757 check_enum:
1758 /* If this is an enumerated type, we need to
1759 add all the enum constants to the partial symbol
1760 table. This does not cover enums without names, e.g.
1761 "enum {a, b} c;" in C, but fortunately those are
1762 rare. There is no way for GDB to find those from the
1763 enum type without spending too much time on it. Thus
1764 to solve this problem, the compiler needs to put out the
1765 enum in a nameless type. GCC2 does this. */
1766
1767 /* We are looking for something of the form
1768 <name> ":" ("t" | "T") [<number> "="] "e"
1769 {<constant> ":" <value> ","} ";". */
1770
1771 /* Skip over the colon and the 't' or 'T'. */
1772 p += 2;
1773 /* This type may be given a number. Also, numbers can come
1774 in pairs like (0,26). Skip over it. */
1775 while ((*p >= '0' && *p <= '9')
1776 || *p == '(' || *p == ',' || *p == ')'
1777 || *p == '=')
1778 p++;
1779
1780 if (*p++ == 'e')
1781 {
1782 /* The aix4 compiler emits extra crud before the members. */
1783 if (*p == '-')
1784 {
1785 /* Skip over the type (?). */
1786 while (*p != ':')
1787 p++;
1788
1789 /* Skip over the colon. */
1790 p++;
1791 }
1792
1793 /* We have found an enumerated type. */
1794 /* According to comments in read_enum_type
1795 a comma could end it instead of a semicolon.
1796 I don't know where that happens.
1797 Accept either. */
1798 while (*p && *p != ';' && *p != ',')
1799 {
1800 char *q;
1801
1802 /* Check for and handle cretinous dbx symbol name
1803 continuation! */
1804 if (*p == '\\' || (*p == '?' && p[1] == '\0'))
1805 p = next_symbol_text (objfile);
1806
1807 /* Point to the character after the name
1808 of the enum constant. */
1809 for (q = p; *q && *q != ':'; q++)
1810 ;
1811 /* Note that the value doesn't matter for
1812 enum constants in psymtabs, just in symtabs. */
1813 add_psymbol_to_list (p, q - p,
1814 VAR_DOMAIN, LOC_CONST,
1815 &objfile->static_psymbols, 0,
1816 0, psymtab_language, objfile);
1817 /* Point past the name. */
1818 p = q;
1819 /* Skip over the value. */
1820 while (*p && *p != ',')
1821 p++;
1822 /* Advance past the comma. */
1823 if (*p)
1824 p++;
1825 }
1826 }
1827 continue;
1828
1829 case 'c':
1830 /* Constant, e.g. from "const" in Pascal. */
1831 add_psymbol_to_list (namestring, p - namestring,
1832 VAR_DOMAIN, LOC_CONST,
1833 &objfile->static_psymbols, nlist.n_value,
1834 0, psymtab_language, objfile);
1835 continue;
1836
1837 case 'f':
1838 if (! pst)
1839 {
1840 int name_len = p - namestring;
1841 char *name = xmalloc (name_len + 1);
1842 memcpy (name, namestring, name_len);
1843 name[name_len] = '\0';
1844 function_outside_compilation_unit_complaint (name);
1845 xfree (name);
1846 }
1847 nlist.n_value += ANOFFSET (objfile->section_offsets,
1848 SECT_OFF_TEXT (objfile));
1849 /* Kludges for ELF/STABS with Sun ACC */
1850 last_function_name = namestring;
1851 /* Do not fix textlow==0 for .o or NLM files, as 0 is a legit
1852 value for the bottom of the text seg in those cases. */
1853 if (nlist.n_value == ANOFFSET (objfile->section_offsets,
1854 SECT_OFF_TEXT (objfile))
1855 && gdbarch_sofun_address_maybe_missing (gdbarch))
1856 {
1857 CORE_ADDR minsym_valu =
1858 find_stab_function_addr (namestring,
1859 pst ? pst->filename : NULL,
1860 objfile);
1861 /* find_stab_function_addr will return 0 if the minimal
1862 symbol wasn't found. (Unfortunately, this might also
1863 be a valid address.) Anyway, if it *does* return 0,
1864 it is likely that the value was set correctly to begin
1865 with... */
1866 if (minsym_valu != 0)
1867 nlist.n_value = minsym_valu;
1868 }
1869 if (pst && textlow_not_set
1870 && gdbarch_sofun_address_maybe_missing (gdbarch))
1871 {
1872 pst->textlow = nlist.n_value;
1873 textlow_not_set = 0;
1874 }
1875 /* End kludge. */
1876
1877 /* Keep track of the start of the last function so we
1878 can handle end of function symbols. */
1879 last_function_start = nlist.n_value;
1880
1881 /* In reordered executables this function may lie outside
1882 the bounds created by N_SO symbols. If that's the case
1883 use the address of this function as the low bound for
1884 the partial symbol table. */
1885 if (pst
1886 && (textlow_not_set
1887 || (nlist.n_value < pst->textlow
1888 && (nlist.n_value
1889 != ANOFFSET (objfile->section_offsets,
1890 SECT_OFF_TEXT (objfile))))))
1891 {
1892 pst->textlow = nlist.n_value;
1893 textlow_not_set = 0;
1894 }
1895 add_psymbol_to_list (namestring, p - namestring,
1896 VAR_DOMAIN, LOC_BLOCK,
1897 &objfile->static_psymbols,
1898 0, nlist.n_value,
1899 psymtab_language, objfile);
1900 continue;
1901
1902 /* Global functions were ignored here, but now they
1903 are put into the global psymtab like one would expect.
1904 They're also in the minimal symbol table. */
1905 case 'F':
1906 if (! pst)
1907 {
1908 int name_len = p - namestring;
1909 char *name = xmalloc (name_len + 1);
1910 memcpy (name, namestring, name_len);
1911 name[name_len] = '\0';
1912 function_outside_compilation_unit_complaint (name);
1913 xfree (name);
1914 }
1915 nlist.n_value += ANOFFSET (objfile->section_offsets,
1916 SECT_OFF_TEXT (objfile));
1917 /* Kludges for ELF/STABS with Sun ACC */
1918 last_function_name = namestring;
1919 /* Do not fix textlow==0 for .o or NLM files, as 0 is a legit
1920 value for the bottom of the text seg in those cases. */
1921 if (nlist.n_value == ANOFFSET (objfile->section_offsets,
1922 SECT_OFF_TEXT (objfile))
1923 && gdbarch_sofun_address_maybe_missing (gdbarch))
1924 {
1925 CORE_ADDR minsym_valu =
1926 find_stab_function_addr (namestring,
1927 pst ? pst->filename : NULL,
1928 objfile);
1929 /* find_stab_function_addr will return 0 if the minimal
1930 symbol wasn't found. (Unfortunately, this might also
1931 be a valid address.) Anyway, if it *does* return 0,
1932 it is likely that the value was set correctly to begin
1933 with... */
1934 if (minsym_valu != 0)
1935 nlist.n_value = minsym_valu;
1936 }
1937 if (pst && textlow_not_set
1938 && gdbarch_sofun_address_maybe_missing (gdbarch))
1939 {
1940 pst->textlow = nlist.n_value;
1941 textlow_not_set = 0;
1942 }
1943 /* End kludge. */
1944
1945 /* Keep track of the start of the last function so we
1946 can handle end of function symbols. */
1947 last_function_start = nlist.n_value;
1948
1949 /* In reordered executables this function may lie outside
1950 the bounds created by N_SO symbols. If that's the case
1951 use the address of this function as the low bound for
1952 the partial symbol table. */
1953 if (pst
1954 && (textlow_not_set
1955 || (nlist.n_value < pst->textlow
1956 && (nlist.n_value
1957 != ANOFFSET (objfile->section_offsets,
1958 SECT_OFF_TEXT (objfile))))))
1959 {
1960 pst->textlow = nlist.n_value;
1961 textlow_not_set = 0;
1962 }
1963 add_psymbol_to_list (namestring, p - namestring,
1964 VAR_DOMAIN, LOC_BLOCK,
1965 &objfile->global_psymbols,
1966 0, nlist.n_value,
1967 psymtab_language, objfile);
1968 continue;
1969
1970 /* Two things show up here (hopefully); static symbols of
1971 local scope (static used inside braces) or extensions
1972 of structure symbols. We can ignore both. */
1973 case 'V':
1974 case '(':
1975 case '0':
1976 case '1':
1977 case '2':
1978 case '3':
1979 case '4':
1980 case '5':
1981 case '6':
1982 case '7':
1983 case '8':
1984 case '9':
1985 case '-':
1986 case '#': /* for symbol identification (used in live ranges) */
1987 continue;
1988
1989 case ':':
1990 /* It is a C++ nested symbol. We don't need to record it
1991 (I don't think); if we try to look up foo::bar::baz,
1992 then symbols for the symtab containing foo should get
1993 read in, I think. */
1994 /* Someone says sun cc puts out symbols like
1995 /foo/baz/maclib::/usr/local/bin/maclib,
1996 which would get here with a symbol type of ':'. */
1997 continue;
1998
1999 default:
2000 /* Unexpected symbol descriptor. The second and subsequent stabs
2001 of a continued stab can show up here. The question is
2002 whether they ever can mimic a normal stab--it would be
2003 nice if not, since we certainly don't want to spend the
2004 time searching to the end of every string looking for
2005 a backslash. */
2006
2007 complaint (&symfile_complaints, _("unknown symbol descriptor `%c'"),
2008 p[1]);
2009
2010 /* Ignore it; perhaps it is an extension that we don't
2011 know about. */
2012 continue;
2013 }
2014 }
2015
2016 case N_EXCL:
2017
2018 namestring = set_namestring (objfile, &nlist);
2019
2020 /* Find the corresponding bincl and mark that psymtab on the
2021 psymtab dependency list */
2022 {
2023 struct partial_symtab *needed_pst =
2024 find_corresponding_bincl_psymtab (namestring, nlist.n_value);
2025
2026 /* If this include file was defined earlier in this file,
2027 leave it alone. */
2028 if (needed_pst == pst)
2029 continue;
2030
2031 if (needed_pst)
2032 {
2033 int i;
2034 int found = 0;
2035
2036 for (i = 0; i < dependencies_used; i++)
2037 if (dependency_list[i] == needed_pst)
2038 {
2039 found = 1;
2040 break;
2041 }
2042
2043 /* If it's already in the list, skip the rest. */
2044 if (found)
2045 continue;
2046
2047 dependency_list[dependencies_used++] = needed_pst;
2048 if (dependencies_used >= dependencies_allocated)
2049 {
2050 struct partial_symtab **orig = dependency_list;
2051 dependency_list =
2052 (struct partial_symtab **)
2053 alloca ((dependencies_allocated *= 2)
2054 * sizeof (struct partial_symtab *));
2055 memcpy (dependency_list, orig,
2056 (dependencies_used
2057 * sizeof (struct partial_symtab *)));
2058 #ifdef DEBUG_INFO
2059 fprintf_unfiltered (gdb_stderr,
2060 "Had to reallocate dependency list.\n");
2061 fprintf_unfiltered (gdb_stderr,
2062 "New dependencies allocated: %d\n",
2063 dependencies_allocated);
2064 #endif
2065 }
2066 }
2067 }
2068 continue;
2069
2070 case N_ENDM:
2071 /* Solaris 2 end of module, finish current partial symbol table.
2072 end_psymtab will set pst->texthigh to the proper value, which
2073 is necessary if a module compiled without debugging info
2074 follows this module. */
2075 if (pst && gdbarch_sofun_address_maybe_missing (gdbarch))
2076 {
2077 end_psymtab (pst, psymtab_include_list, includes_used,
2078 symnum * symbol_size,
2079 (CORE_ADDR) 0,
2080 dependency_list, dependencies_used, textlow_not_set);
2081 pst = (struct partial_symtab *) 0;
2082 includes_used = 0;
2083 dependencies_used = 0;
2084 }
2085 continue;
2086
2087 case N_RBRAC:
2088 #ifdef HANDLE_RBRAC
2089 HANDLE_RBRAC (nlist.n_value);
2090 continue;
2091 #endif
2092 case N_EINCL:
2093 case N_DSLINE:
2094 case N_BSLINE:
2095 case N_SSYM: /* Claim: Structure or union element.
2096 Hopefully, I can ignore this. */
2097 case N_ENTRY: /* Alternate entry point; can ignore. */
2098 case N_MAIN: /* Can definitely ignore this. */
2099 case N_CATCH: /* These are GNU C++ extensions */
2100 case N_EHDECL: /* that can safely be ignored here. */
2101 case N_LENG:
2102 case N_BCOMM:
2103 case N_ECOMM:
2104 case N_ECOML:
2105 case N_FNAME:
2106 case N_SLINE:
2107 case N_RSYM:
2108 case N_PSYM:
2109 case N_LBRAC:
2110 case N_NSYMS: /* Ultrix 4.0: symbol count */
2111 case N_DEFD: /* GNU Modula-2 */
2112 case N_ALIAS: /* SunPro F77: alias name, ignore for now. */
2113
2114 case N_OBJ: /* useless types from Solaris */
2115 case N_OPT:
2116 case N_PATCH:
2117 /* These symbols aren't interesting; don't worry about them */
2118
2119 continue;
2120
2121 default:
2122 /* If we haven't found it yet, ignore it. It's probably some
2123 new type we don't know about yet. */
2124 unknown_symtype_complaint (hex_string (nlist.n_type));
2125 continue;
2126 }
2127 }
2128
2129 /* If there's stuff to be cleaned up, clean it up. */
2130 if (pst)
2131 {
2132 /* Don't set pst->texthigh lower than it already is. */
2133 CORE_ADDR text_end =
2134 (lowest_text_address == (CORE_ADDR) -1
2135 ? (text_addr + ANOFFSET (objfile->section_offsets,
2136 SECT_OFF_TEXT (objfile)))
2137 : lowest_text_address)
2138 + text_size;
2139
2140 end_psymtab (pst, psymtab_include_list, includes_used,
2141 symnum * symbol_size,
2142 text_end > pst->texthigh ? text_end : pst->texthigh,
2143 dependency_list, dependencies_used, textlow_not_set);
2144 }
2145
2146 do_cleanups (back_to);
2147 }
2148
2149 /* Allocate and partially fill a partial symtab. It will be
2150 completely filled at the end of the symbol list.
2151
2152 SYMFILE_NAME is the name of the symbol-file we are reading from, and ADDR
2153 is the address relative to which its symbols are (incremental) or 0
2154 (normal). */
2155
2156 static struct partial_symtab *
2157 start_psymtab (struct objfile *objfile, char *filename, CORE_ADDR textlow,
2158 int ldsymoff, struct partial_symbol **global_syms,
2159 struct partial_symbol **static_syms)
2160 {
2161 struct partial_symtab *result =
2162 start_psymtab_common (objfile, objfile->section_offsets,
2163 filename, textlow, global_syms, static_syms);
2164
2165 result->read_symtab_private = (char *)
2166 obstack_alloc (&objfile->objfile_obstack, sizeof (struct symloc));
2167 LDSYMOFF (result) = ldsymoff;
2168 result->read_symtab = dbx_psymtab_to_symtab;
2169 SYMBOL_SIZE (result) = symbol_size;
2170 SYMBOL_OFFSET (result) = symbol_table_offset;
2171 STRING_OFFSET (result) = string_table_offset;
2172 FILE_STRING_OFFSET (result) = file_string_table_offset;
2173
2174 #ifdef HAVE_ELF
2175 /* If we're handling an ELF file, drag some section-relocation info
2176 for this source file out of the ELF symbol table, to compensate for
2177 Sun brain death. This replaces the section_offsets in this psymtab,
2178 if successful. */
2179 elfstab_offset_sections (objfile, result);
2180 #endif
2181
2182 /* Deduce the source language from the filename for this psymtab. */
2183 psymtab_language = deduce_language_from_filename (filename);
2184
2185 return result;
2186 }
2187
2188 /* Close off the current usage of PST.
2189 Returns PST or NULL if the partial symtab was empty and thrown away.
2190
2191 FIXME: List variables and peculiarities of same. */
2192
2193 struct partial_symtab *
2194 end_psymtab (struct partial_symtab *pst, char **include_list, int num_includes,
2195 int capping_symbol_offset, CORE_ADDR capping_text,
2196 struct partial_symtab **dependency_list, int number_dependencies,
2197 int textlow_not_set)
2198 {
2199 int i;
2200 struct objfile *objfile = pst->objfile;
2201 struct gdbarch *gdbarch = get_objfile_arch (objfile);
2202
2203 if (capping_symbol_offset != -1)
2204 LDSYMLEN (pst) = capping_symbol_offset - LDSYMOFF (pst);
2205 pst->texthigh = capping_text;
2206
2207 /* Under Solaris, the N_SO symbols always have a value of 0,
2208 instead of the usual address of the .o file. Therefore,
2209 we have to do some tricks to fill in texthigh and textlow.
2210 The first trick is: if we see a static
2211 or global function, and the textlow for the current pst
2212 is not set (ie: textlow_not_set), then we use that function's
2213 address for the textlow of the pst. */
2214
2215 /* Now, to fill in texthigh, we remember the last function seen
2216 in the .o file. Also, there's a hack in
2217 bfd/elf.c and gdb/elfread.c to pass the ELF st_size field
2218 to here via the misc_info field. Therefore, we can fill in
2219 a reliable texthigh by taking the address plus size of the
2220 last function in the file. */
2221
2222 if (pst->texthigh == 0 && last_function_name
2223 && gdbarch_sofun_address_maybe_missing (gdbarch))
2224 {
2225 char *p;
2226 int n;
2227 struct minimal_symbol *minsym;
2228
2229 p = strchr (last_function_name, ':');
2230 if (p == NULL)
2231 p = last_function_name;
2232 n = p - last_function_name;
2233 p = alloca (n + 2);
2234 strncpy (p, last_function_name, n);
2235 p[n] = 0;
2236
2237 minsym = lookup_minimal_symbol (p, pst->filename, objfile);
2238 if (minsym == NULL)
2239 {
2240 /* Sun Fortran appends an underscore to the minimal symbol name,
2241 try again with an appended underscore if the minimal symbol
2242 was not found. */
2243 p[n] = '_';
2244 p[n + 1] = 0;
2245 minsym = lookup_minimal_symbol (p, pst->filename, objfile);
2246 }
2247
2248 if (minsym)
2249 pst->texthigh = SYMBOL_VALUE_ADDRESS (minsym) + MSYMBOL_SIZE (minsym);
2250
2251 last_function_name = NULL;
2252 }
2253
2254 if (!gdbarch_sofun_address_maybe_missing (gdbarch))
2255 ;
2256 /* this test will be true if the last .o file is only data */
2257 else if (textlow_not_set)
2258 pst->textlow = pst->texthigh;
2259 else
2260 {
2261 struct partial_symtab *p1;
2262
2263 /* If we know our own starting text address, then walk through all other
2264 psymtabs for this objfile, and if any didn't know their ending text
2265 address, set it to our starting address. Take care to not set our
2266 own ending address to our starting address, nor to set addresses on
2267 `dependency' files that have both textlow and texthigh zero. */
2268
2269 ALL_OBJFILE_PSYMTABS (objfile, p1)
2270 {
2271 if (p1->texthigh == 0 && p1->textlow != 0 && p1 != pst)
2272 {
2273 p1->texthigh = pst->textlow;
2274 /* if this file has only data, then make textlow match texthigh */
2275 if (p1->textlow == 0)
2276 p1->textlow = p1->texthigh;
2277 }
2278 }
2279 }
2280
2281 /* End of kludge for patching Solaris textlow and texthigh. */
2282
2283 pst->n_global_syms =
2284 objfile->global_psymbols.next - (objfile->global_psymbols.list
2285 + pst->globals_offset);
2286 pst->n_static_syms =
2287 objfile->static_psymbols.next - (objfile->static_psymbols.list
2288 + pst->statics_offset);
2289
2290 pst->number_of_dependencies = number_dependencies;
2291 if (number_dependencies)
2292 {
2293 pst->dependencies = (struct partial_symtab **)
2294 obstack_alloc (&objfile->objfile_obstack,
2295 number_dependencies * sizeof (struct partial_symtab *));
2296 memcpy (pst->dependencies, dependency_list,
2297 number_dependencies * sizeof (struct partial_symtab *));
2298 }
2299 else
2300 pst->dependencies = 0;
2301
2302 for (i = 0; i < num_includes; i++)
2303 {
2304 struct partial_symtab *subpst =
2305 allocate_psymtab (include_list[i], objfile);
2306
2307 /* Copy the sesction_offsets array from the main psymtab. */
2308 subpst->section_offsets = pst->section_offsets;
2309 subpst->read_symtab_private =
2310 (char *) obstack_alloc (&objfile->objfile_obstack,
2311 sizeof (struct symloc));
2312 LDSYMOFF (subpst) =
2313 LDSYMLEN (subpst) =
2314 subpst->textlow =
2315 subpst->texthigh = 0;
2316
2317 /* We could save slight bits of space by only making one of these,
2318 shared by the entire set of include files. FIXME-someday. */
2319 subpst->dependencies = (struct partial_symtab **)
2320 obstack_alloc (&objfile->objfile_obstack,
2321 sizeof (struct partial_symtab *));
2322 subpst->dependencies[0] = pst;
2323 subpst->number_of_dependencies = 1;
2324
2325 subpst->globals_offset =
2326 subpst->n_global_syms =
2327 subpst->statics_offset =
2328 subpst->n_static_syms = 0;
2329
2330 subpst->readin = 0;
2331 subpst->symtab = 0;
2332 subpst->read_symtab = pst->read_symtab;
2333 }
2334
2335 sort_pst_symbols (pst);
2336
2337 /* If there is already a psymtab or symtab for a file of this name, remove it.
2338 (If there is a symtab, more drastic things also happen.)
2339 This happens in VxWorks. */
2340 free_named_symtabs (pst->filename);
2341
2342 if (num_includes == 0
2343 && number_dependencies == 0
2344 && pst->n_global_syms == 0
2345 && pst->n_static_syms == 0
2346 && has_line_numbers == 0)
2347 {
2348 /* Throw away this psymtab, it's empty. We can't deallocate it, since
2349 it is on the obstack, but we can forget to chain it on the list. */
2350 /* Empty psymtabs happen as a result of header files which don't have
2351 any symbols in them. There can be a lot of them. But this check
2352 is wrong, in that a psymtab with N_SLINE entries but nothing else
2353 is not empty, but we don't realize that. Fixing that without slowing
2354 things down might be tricky. */
2355
2356 discard_psymtab (pst);
2357
2358 /* Indicate that psymtab was thrown away. */
2359 pst = (struct partial_symtab *) NULL;
2360 }
2361 return pst;
2362 }
2363 \f
2364 static void
2365 dbx_psymtab_to_symtab_1 (struct partial_symtab *pst)
2366 {
2367 struct cleanup *old_chain;
2368 int i;
2369
2370 if (!pst)
2371 return;
2372
2373 if (pst->readin)
2374 {
2375 fprintf_unfiltered (gdb_stderr, "Psymtab for %s already read in. \
2376 Shouldn't happen.\n",
2377 pst->filename);
2378 return;
2379 }
2380
2381 /* Read in all partial symtabs on which this one is dependent */
2382 for (i = 0; i < pst->number_of_dependencies; i++)
2383 if (!pst->dependencies[i]->readin)
2384 {
2385 /* Inform about additional files that need to be read in. */
2386 if (info_verbose)
2387 {
2388 fputs_filtered (" ", gdb_stdout);
2389 wrap_here ("");
2390 fputs_filtered ("and ", gdb_stdout);
2391 wrap_here ("");
2392 printf_filtered ("%s...", pst->dependencies[i]->filename);
2393 wrap_here (""); /* Flush output */
2394 gdb_flush (gdb_stdout);
2395 }
2396 dbx_psymtab_to_symtab_1 (pst->dependencies[i]);
2397 }
2398
2399 if (LDSYMLEN (pst)) /* Otherwise it's a dummy */
2400 {
2401 /* Init stuff necessary for reading in symbols */
2402 stabsread_init ();
2403 buildsym_init ();
2404 old_chain = make_cleanup (really_free_pendings, 0);
2405 file_string_table_offset = FILE_STRING_OFFSET (pst);
2406 symbol_size = SYMBOL_SIZE (pst);
2407
2408 /* Read in this file's symbols */
2409 bfd_seek (pst->objfile->obfd, SYMBOL_OFFSET (pst), SEEK_SET);
2410 read_ofile_symtab (pst);
2411
2412 do_cleanups (old_chain);
2413 }
2414
2415 pst->readin = 1;
2416 }
2417
2418 /* Read in all of the symbols for a given psymtab for real.
2419 Be verbose about it if the user wants that. */
2420
2421 static void
2422 dbx_psymtab_to_symtab (struct partial_symtab *pst)
2423 {
2424 bfd *sym_bfd;
2425 struct cleanup *back_to = NULL;
2426
2427 if (!pst)
2428 return;
2429
2430 if (pst->readin)
2431 {
2432 fprintf_unfiltered (gdb_stderr, "Psymtab for %s already read in. \
2433 Shouldn't happen.\n",
2434 pst->filename);
2435 return;
2436 }
2437
2438 if (LDSYMLEN (pst) || pst->number_of_dependencies)
2439 {
2440 /* Print the message now, before reading the string table,
2441 to avoid disconcerting pauses. */
2442 if (info_verbose)
2443 {
2444 printf_filtered ("Reading in symbols for %s...", pst->filename);
2445 gdb_flush (gdb_stdout);
2446 }
2447
2448 sym_bfd = pst->objfile->obfd;
2449
2450 next_symbol_text_func = dbx_next_symbol_text;
2451
2452 if (DBX_STAB_SECTION (pst->objfile))
2453 {
2454 stabs_data
2455 = symfile_relocate_debug_section (pst->objfile->obfd,
2456 DBX_STAB_SECTION (pst->objfile),
2457 NULL);
2458 if (stabs_data)
2459 back_to = make_cleanup (free_current_contents,
2460 (void *) &stabs_data);
2461 }
2462
2463 dbx_psymtab_to_symtab_1 (pst);
2464
2465 if (back_to)
2466 do_cleanups (back_to);
2467
2468 /* Match with global symbols. This only needs to be done once,
2469 after all of the symtabs and dependencies have been read in. */
2470 scan_file_globals (pst->objfile);
2471
2472 /* Finish up the debug error message. */
2473 if (info_verbose)
2474 printf_filtered ("done.\n");
2475 }
2476 }
2477
2478 /* Read in a defined section of a specific object file's symbols. */
2479
2480 static void
2481 read_ofile_symtab (struct partial_symtab *pst)
2482 {
2483 char *namestring;
2484 struct external_nlist *bufp;
2485 struct internal_nlist nlist;
2486 unsigned char type;
2487 unsigned max_symnum;
2488 bfd *abfd;
2489 struct objfile *objfile;
2490 int sym_offset; /* Offset to start of symbols to read */
2491 int sym_size; /* Size of symbols to read */
2492 CORE_ADDR text_offset; /* Start of text segment for symbols */
2493 int text_size; /* Size of text segment for symbols */
2494 struct section_offsets *section_offsets;
2495
2496 objfile = pst->objfile;
2497 sym_offset = LDSYMOFF (pst);
2498 sym_size = LDSYMLEN (pst);
2499 text_offset = pst->textlow;
2500 text_size = pst->texthigh - pst->textlow;
2501 /* This cannot be simply objfile->section_offsets because of
2502 elfstab_offset_sections() which initializes the psymtab section
2503 offsets information in a special way, and that is different from
2504 objfile->section_offsets. */
2505 section_offsets = pst->section_offsets;
2506
2507 current_objfile = objfile;
2508 subfile_stack = NULL;
2509
2510 stringtab_global = DBX_STRINGTAB (objfile);
2511 last_source_file = NULL;
2512
2513 abfd = objfile->obfd;
2514 symfile_bfd = objfile->obfd; /* Implicit param to next_text_symbol */
2515 symbuf_end = symbuf_idx = 0;
2516 symbuf_read = 0;
2517 symbuf_left = sym_offset + sym_size;
2518
2519 /* It is necessary to actually read one symbol *before* the start
2520 of this symtab's symbols, because the GCC_COMPILED_FLAG_SYMBOL
2521 occurs before the N_SO symbol.
2522
2523 Detecting this in read_dbx_symtab
2524 would slow down initial readin, so we look for it here instead. */
2525 if (!processing_acc_compilation && sym_offset >= (int) symbol_size)
2526 {
2527 stabs_seek (sym_offset - symbol_size);
2528 fill_symbuf (abfd);
2529 bufp = &symbuf[symbuf_idx++];
2530 INTERNALIZE_SYMBOL (nlist, bufp, abfd);
2531 OBJSTAT (objfile, n_stabs++);
2532
2533 namestring = set_namestring (objfile, &nlist);
2534
2535 processing_gcc_compilation = 0;
2536 if (nlist.n_type == N_TEXT)
2537 {
2538 const char *tempstring = namestring;
2539
2540 if (strcmp (namestring, GCC_COMPILED_FLAG_SYMBOL) == 0)
2541 processing_gcc_compilation = 1;
2542 else if (strcmp (namestring, GCC2_COMPILED_FLAG_SYMBOL) == 0)
2543 processing_gcc_compilation = 2;
2544 if (tempstring[0] == bfd_get_symbol_leading_char (symfile_bfd))
2545 ++tempstring;
2546 if (strncmp (tempstring, "__gnu_compiled", 14) == 0)
2547 processing_gcc_compilation = 2;
2548 }
2549
2550 /* Try to select a C++ demangling based on the compilation unit
2551 producer. */
2552
2553 #if 0
2554 /* For now, stay with AUTO_DEMANGLING for g++ output, as we don't
2555 know whether it will use the old style or v3 mangling. */
2556 if (processing_gcc_compilation)
2557 {
2558 if (AUTO_DEMANGLING)
2559 {
2560 set_demangling_style (GNU_DEMANGLING_STYLE_STRING);
2561 }
2562 }
2563 #endif
2564 }
2565 else
2566 {
2567 /* The N_SO starting this symtab is the first symbol, so we
2568 better not check the symbol before it. I'm not this can
2569 happen, but it doesn't hurt to check for it. */
2570 stabs_seek (sym_offset);
2571 processing_gcc_compilation = 0;
2572 }
2573
2574 if (symbuf_idx == symbuf_end)
2575 fill_symbuf (abfd);
2576 bufp = &symbuf[symbuf_idx];
2577 if (bfd_h_get_8 (abfd, bufp->e_type) != N_SO)
2578 error (_("First symbol in segment of executable not a source symbol"));
2579
2580 max_symnum = sym_size / symbol_size;
2581
2582 for (symnum = 0;
2583 symnum < max_symnum;
2584 symnum++)
2585 {
2586 QUIT; /* Allow this to be interruptable */
2587 if (symbuf_idx == symbuf_end)
2588 fill_symbuf (abfd);
2589 bufp = &symbuf[symbuf_idx++];
2590 INTERNALIZE_SYMBOL (nlist, bufp, abfd);
2591 OBJSTAT (objfile, n_stabs++);
2592
2593 type = bfd_h_get_8 (abfd, bufp->e_type);
2594
2595 namestring = set_namestring (objfile, &nlist);
2596
2597 if (type & N_STAB)
2598 {
2599 process_one_symbol (type, nlist.n_desc, nlist.n_value,
2600 namestring, section_offsets, objfile);
2601 }
2602 /* We skip checking for a new .o or -l file; that should never
2603 happen in this routine. */
2604 else if (type == N_TEXT)
2605 {
2606 /* I don't think this code will ever be executed, because
2607 the GCC_COMPILED_FLAG_SYMBOL usually is right before
2608 the N_SO symbol which starts this source file.
2609 However, there is no reason not to accept
2610 the GCC_COMPILED_FLAG_SYMBOL anywhere. */
2611
2612 if (strcmp (namestring, GCC_COMPILED_FLAG_SYMBOL) == 0)
2613 processing_gcc_compilation = 1;
2614 else if (strcmp (namestring, GCC2_COMPILED_FLAG_SYMBOL) == 0)
2615 processing_gcc_compilation = 2;
2616
2617 #if 0
2618 /* For now, stay with AUTO_DEMANGLING for g++ output, as we don't
2619 know whether it will use the old style or v3 mangling. */
2620 if (AUTO_DEMANGLING)
2621 {
2622 set_demangling_style (GNU_DEMANGLING_STYLE_STRING);
2623 }
2624 #endif
2625 }
2626 else if (type & N_EXT || type == (unsigned char) N_TEXT
2627 || type == (unsigned char) N_NBTEXT
2628 )
2629 {
2630 /* Global symbol: see if we came across a dbx defintion for
2631 a corresponding symbol. If so, store the value. Remove
2632 syms from the chain when their values are stored, but
2633 search the whole chain, as there may be several syms from
2634 different files with the same name. */
2635 /* This is probably not true. Since the files will be read
2636 in one at a time, each reference to a global symbol will
2637 be satisfied in each file as it appears. So we skip this
2638 section. */
2639 ;
2640 }
2641 }
2642
2643 /* In a Solaris elf file, this variable, which comes from the
2644 value of the N_SO symbol, will still be 0. Luckily, text_offset,
2645 which comes from pst->textlow is correct. */
2646 if (last_source_start_addr == 0)
2647 last_source_start_addr = text_offset;
2648
2649 /* In reordered executables last_source_start_addr may not be the
2650 lower bound for this symtab, instead use text_offset which comes
2651 from pst->textlow which is correct. */
2652 if (last_source_start_addr > text_offset)
2653 last_source_start_addr = text_offset;
2654
2655 pst->symtab = end_symtab (text_offset + text_size, objfile,
2656 SECT_OFF_TEXT (objfile));
2657
2658 end_stabs ();
2659
2660 current_objfile = NULL;
2661 }
2662 \f
2663
2664 /* This handles a single symbol from the symbol-file, building symbols
2665 into a GDB symtab. It takes these arguments and an implicit argument.
2666
2667 TYPE is the type field of the ".stab" symbol entry.
2668 DESC is the desc field of the ".stab" entry.
2669 VALU is the value field of the ".stab" entry.
2670 NAME is the symbol name, in our address space.
2671 SECTION_OFFSETS is a set of amounts by which the sections of this
2672 object file were relocated when it was loaded into memory. Note
2673 that these section_offsets are not the objfile->section_offsets but
2674 the pst->section_offsets. All symbols that refer to memory
2675 locations need to be offset by these amounts.
2676 OBJFILE is the object file from which we are reading symbols. It
2677 is used in end_symtab. */
2678
2679 void
2680 process_one_symbol (int type, int desc, CORE_ADDR valu, char *name,
2681 struct section_offsets *section_offsets,
2682 struct objfile *objfile)
2683 {
2684 struct gdbarch *gdbarch = get_objfile_arch (objfile);
2685 struct context_stack *new;
2686 /* This remembers the address of the start of a function. It is
2687 used because in Solaris 2, N_LBRAC, N_RBRAC, and N_SLINE entries
2688 are relative to the current function's start address. On systems
2689 other than Solaris 2, this just holds the SECT_OFF_TEXT value,
2690 and is used to relocate these symbol types rather than
2691 SECTION_OFFSETS. */
2692 static CORE_ADDR function_start_offset;
2693
2694 /* This holds the address of the start of a function, without the
2695 system peculiarities of function_start_offset. */
2696 static CORE_ADDR last_function_start;
2697
2698 /* If this is nonzero, we've seen an N_SLINE since the start of the
2699 current function. We use this to tell us to move the first sline
2700 to the beginning of the function regardless of what its given
2701 value is. */
2702 static int sline_found_in_function = 1;
2703
2704 /* If this is nonzero, we've seen a non-gcc N_OPT symbol for this
2705 source file. Used to detect the SunPRO solaris compiler. */
2706 static int n_opt_found;
2707
2708 /* The stab type used for the definition of the last function.
2709 N_STSYM or N_GSYM for SunOS4 acc; N_FUN for other compilers. */
2710 static int function_stab_type = 0;
2711
2712 if (!block_address_function_relative)
2713 {
2714 /* N_LBRAC, N_RBRAC and N_SLINE entries are not relative to the
2715 function start address, so just use the text offset. */
2716 function_start_offset =
2717 ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
2718 }
2719
2720 /* Something is wrong if we see real data before seeing a source
2721 file name. */
2722
2723 if (last_source_file == NULL && type != (unsigned char) N_SO)
2724 {
2725 /* Ignore any symbols which appear before an N_SO symbol.
2726 Currently no one puts symbols there, but we should deal
2727 gracefully with the case. A complain()t might be in order,
2728 but this should not be an error (). */
2729 return;
2730 }
2731
2732 switch (type)
2733 {
2734 case N_FUN:
2735 case N_FNAME:
2736
2737 if (*name == '\000')
2738 {
2739 /* This N_FUN marks the end of a function. This closes off
2740 the current block. */
2741
2742 if (context_stack_depth <= 0)
2743 {
2744 lbrac_mismatch_complaint (symnum);
2745 break;
2746 }
2747
2748 /* The following check is added before recording line 0 at
2749 end of function so as to handle hand-generated stabs
2750 which may have an N_FUN stabs at the end of the function,
2751 but no N_SLINE stabs. */
2752 if (sline_found_in_function)
2753 record_line (current_subfile, 0, last_function_start + valu);
2754
2755 within_function = 0;
2756 new = pop_context ();
2757
2758 /* Make a block for the local symbols within. */
2759 finish_block (new->name, &local_symbols, new->old_blocks,
2760 new->start_addr, new->start_addr + valu,
2761 objfile);
2762
2763 /* May be switching to an assembler file which may not be using
2764 block relative stabs, so reset the offset. */
2765 if (block_address_function_relative)
2766 function_start_offset = 0;
2767
2768 break;
2769 }
2770
2771 sline_found_in_function = 0;
2772
2773 /* Relocate for dynamic loading. */
2774 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
2775 valu = gdbarch_smash_text_address (gdbarch, valu);
2776 last_function_start = valu;
2777
2778 goto define_a_symbol;
2779
2780 case N_LBRAC:
2781 /* This "symbol" just indicates the start of an inner lexical
2782 context within a function. */
2783
2784 /* Ignore extra outermost context from SunPRO cc and acc. */
2785 if (n_opt_found && desc == 1)
2786 break;
2787
2788 if (block_address_function_relative)
2789 /* Relocate for Sun ELF acc fn-relative syms. */
2790 valu += function_start_offset;
2791 else
2792 /* On most machines, the block addresses are relative to the
2793 N_SO, the linker did not relocate them (sigh). */
2794 valu += last_source_start_addr;
2795
2796 new = push_context (desc, valu);
2797 break;
2798
2799 case N_RBRAC:
2800 /* This "symbol" just indicates the end of an inner lexical
2801 context that was started with N_LBRAC. */
2802
2803 /* Ignore extra outermost context from SunPRO cc and acc. */
2804 if (n_opt_found && desc == 1)
2805 break;
2806
2807 if (block_address_function_relative)
2808 /* Relocate for Sun ELF acc fn-relative syms. */
2809 valu += function_start_offset;
2810 else
2811 /* On most machines, the block addresses are relative to the
2812 N_SO, the linker did not relocate them (sigh). */
2813 valu += last_source_start_addr;
2814
2815 if (context_stack_depth <= 0)
2816 {
2817 lbrac_mismatch_complaint (symnum);
2818 break;
2819 }
2820
2821 new = pop_context ();
2822 if (desc != new->depth)
2823 lbrac_mismatch_complaint (symnum);
2824
2825 if (local_symbols != NULL)
2826 {
2827 /* GCC development snapshots from March to December of
2828 2000 would output N_LSYM entries after N_LBRAC
2829 entries. As a consequence, these symbols are simply
2830 discarded. Complain if this is the case. */
2831 complaint (&symfile_complaints, _("\
2832 misplaced N_LBRAC entry; discarding local symbols which have \
2833 no enclosing block"));
2834 }
2835 local_symbols = new->locals;
2836
2837 if (context_stack_depth > 1)
2838 {
2839 /* This is not the outermost LBRAC...RBRAC pair in the
2840 function, its local symbols preceded it, and are the ones
2841 just recovered from the context stack. Define the block
2842 for them (but don't bother if the block contains no
2843 symbols. Should we complain on blocks without symbols?
2844 I can't think of any useful purpose for them). */
2845 if (local_symbols != NULL)
2846 {
2847 /* Muzzle a compiler bug that makes end < start.
2848
2849 ??? Which compilers? Is this ever harmful?. */
2850 if (new->start_addr > valu)
2851 {
2852 complaint (&symfile_complaints,
2853 _("block start larger than block end"));
2854 new->start_addr = valu;
2855 }
2856 /* Make a block for the local symbols within. */
2857 finish_block (0, &local_symbols, new->old_blocks,
2858 new->start_addr, valu, objfile);
2859 }
2860 }
2861 else
2862 {
2863 /* This is the outermost LBRAC...RBRAC pair. There is no
2864 need to do anything; leave the symbols that preceded it
2865 to be attached to the function's own block. We need to
2866 indicate that we just moved outside of the function. */
2867 within_function = 0;
2868 }
2869
2870 break;
2871
2872 case N_FN:
2873 case N_FN_SEQ:
2874 /* This kind of symbol indicates the start of an object file.
2875 Relocate for dynamic loading. */
2876 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
2877 break;
2878
2879 case N_SO:
2880 /* This type of symbol indicates the start of data for one
2881 source file. Finish the symbol table of the previous source
2882 file (if any) and start accumulating a new symbol table.
2883 Relocate for dynamic loading. */
2884 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
2885
2886 n_opt_found = 0;
2887
2888 if (last_source_file)
2889 {
2890 /* Check if previous symbol was also an N_SO (with some
2891 sanity checks). If so, that one was actually the
2892 directory name, and the current one is the real file
2893 name. Patch things up. */
2894 if (previous_stab_code == (unsigned char) N_SO)
2895 {
2896 patch_subfile_names (current_subfile, name);
2897 break; /* Ignore repeated SOs */
2898 }
2899 end_symtab (valu, objfile, SECT_OFF_TEXT (objfile));
2900 end_stabs ();
2901 }
2902
2903 /* Null name means this just marks the end of text for this .o
2904 file. Don't start a new symtab in this case. */
2905 if (*name == '\000')
2906 break;
2907
2908 if (block_address_function_relative)
2909 function_start_offset = 0;
2910
2911 start_stabs ();
2912 start_symtab (name, NULL, valu);
2913 record_debugformat ("stabs");
2914 break;
2915
2916 case N_SOL:
2917 /* This type of symbol indicates the start of data for a
2918 sub-source-file, one whose contents were copied or included
2919 in the compilation of the main source file (whose name was
2920 given in the N_SO symbol). Relocate for dynamic loading. */
2921 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
2922 start_subfile (name, current_subfile->dirname);
2923 break;
2924
2925 case N_BINCL:
2926 push_subfile ();
2927 add_new_header_file (name, valu);
2928 start_subfile (name, current_subfile->dirname);
2929 break;
2930
2931 case N_EINCL:
2932 start_subfile (pop_subfile (), current_subfile->dirname);
2933 break;
2934
2935 case N_EXCL:
2936 add_old_header_file (name, valu);
2937 break;
2938
2939 case N_SLINE:
2940 /* This type of "symbol" really just records one line-number --
2941 core-address correspondence. Enter it in the line list for
2942 this symbol table. */
2943
2944 /* Relocate for dynamic loading and for ELF acc
2945 function-relative symbols. */
2946 valu += function_start_offset;
2947
2948 /* GCC 2.95.3 emits the first N_SLINE stab somwehere in the
2949 middle of the prologue instead of right at the start of the
2950 function. To deal with this we record the address for the
2951 first N_SLINE stab to be the start of the function instead of
2952 the listed location. We really shouldn't to this. When
2953 compiling with optimization, this first N_SLINE stab might be
2954 optimized away. Other (non-GCC) compilers don't emit this
2955 stab at all. There is no real harm in having an extra
2956 numbered line, although it can be a bit annoying for the
2957 user. However, it totally screws up our testsuite.
2958
2959 So for now, keep adjusting the address of the first N_SLINE
2960 stab, but only for code compiled with GCC. */
2961
2962 if (within_function && sline_found_in_function == 0)
2963 {
2964 if (processing_gcc_compilation == 2)
2965 record_line (current_subfile, desc, last_function_start);
2966 else
2967 record_line (current_subfile, desc, valu);
2968 sline_found_in_function = 1;
2969 }
2970 else
2971 record_line (current_subfile, desc, valu);
2972 break;
2973
2974 case N_BCOMM:
2975 common_block_start (name, objfile);
2976 break;
2977
2978 case N_ECOMM:
2979 common_block_end (objfile);
2980 break;
2981
2982 /* The following symbol types need to have the appropriate
2983 offset added to their value; then we process symbol
2984 definitions in the name. */
2985
2986 case N_STSYM: /* Static symbol in data segment. */
2987 case N_LCSYM: /* Static symbol in BSS segment. */
2988 case N_ROSYM: /* Static symbol in read-only data segment. */
2989 /* HORRID HACK DEPT. However, it's Sun's furgin' fault.
2990 Solaris 2's stabs-in-elf makes *most* symbols relative but
2991 leaves a few absolute (at least for Solaris 2.1 and version
2992 2.0.1 of the SunPRO compiler). N_STSYM and friends sit on
2993 the fence. .stab "foo:S...",N_STSYM is absolute (ld
2994 relocates it) .stab "foo:V...",N_STSYM is relative (section
2995 base subtracted). This leaves us no choice but to search for
2996 the 'S' or 'V'... (or pass the whole section_offsets stuff
2997 down ONE MORE function call level, which we really don't want
2998 to do). */
2999 {
3000 char *p;
3001
3002 /* Normal object file and NLMs have non-zero text seg offsets,
3003 but don't need their static syms offset in this fashion.
3004 XXX - This is really a crock that should be fixed in the
3005 solib handling code so that I don't have to work around it
3006 here. */
3007
3008 if (!symfile_relocatable)
3009 {
3010 p = strchr (name, ':');
3011 if (p != 0 && p[1] == 'S')
3012 {
3013 /* The linker relocated it. We don't want to add an
3014 elfstab_offset_sections-type offset, but we *do*
3015 want to add whatever solib.c passed to
3016 symbol_file_add as addr (this is known to affect
3017 SunOS 4, and I suspect ELF too). Since
3018 elfstab_offset_sections currently does not muck
3019 with the text offset (there is no Ttext.text
3020 symbol), we can get addr from the text offset. If
3021 elfstab_offset_sections ever starts dealing with
3022 the text offset, and we still need to do this, we
3023 need to invent a SECT_OFF_ADDR_KLUDGE or something. */
3024 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
3025 goto define_a_symbol;
3026 }
3027 }
3028 /* Since it's not the kludge case, re-dispatch to the right
3029 handler. */
3030 switch (type)
3031 {
3032 case N_STSYM:
3033 goto case_N_STSYM;
3034 case N_LCSYM:
3035 goto case_N_LCSYM;
3036 case N_ROSYM:
3037 goto case_N_ROSYM;
3038 default:
3039 internal_error (__FILE__, __LINE__,
3040 _("failed internal consistency check"));
3041 }
3042 }
3043
3044 case_N_STSYM: /* Static symbol in data segment. */
3045 case N_DSLINE: /* Source line number, data segment. */
3046 valu += ANOFFSET (section_offsets, SECT_OFF_DATA (objfile));
3047 goto define_a_symbol;
3048
3049 case_N_LCSYM: /* Static symbol in BSS segment. */
3050 case N_BSLINE: /* Source line number, BSS segment. */
3051 /* N_BROWS: overlaps with N_BSLINE. */
3052 valu += ANOFFSET (section_offsets, SECT_OFF_BSS (objfile));
3053 goto define_a_symbol;
3054
3055 case_N_ROSYM: /* Static symbol in read-only data segment. */
3056 valu += ANOFFSET (section_offsets, SECT_OFF_RODATA (objfile));
3057 goto define_a_symbol;
3058
3059 case N_ENTRY: /* Alternate entry point. */
3060 /* Relocate for dynamic loading. */
3061 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
3062 goto define_a_symbol;
3063
3064 /* The following symbol types we don't know how to process.
3065 Handle them in a "default" way, but complain to people who
3066 care. */
3067 default:
3068 case N_CATCH: /* Exception handler catcher. */
3069 case N_EHDECL: /* Exception handler name. */
3070 case N_PC: /* Global symbol in Pascal. */
3071 case N_M2C: /* Modula-2 compilation unit. */
3072 /* N_MOD2: overlaps with N_EHDECL. */
3073 case N_SCOPE: /* Modula-2 scope information. */
3074 case N_ECOML: /* End common (local name). */
3075 case N_NBTEXT: /* Gould Non-Base-Register symbols??? */
3076 case N_NBDATA:
3077 case N_NBBSS:
3078 case N_NBSTS:
3079 case N_NBLCS:
3080 unknown_symtype_complaint (hex_string (type));
3081 /* FALLTHROUGH */
3082
3083 /* The following symbol types don't need the address field
3084 relocated, since it is either unused, or is absolute. */
3085 define_a_symbol:
3086 case N_GSYM: /* Global variable. */
3087 case N_NSYMS: /* Number of symbols (Ultrix). */
3088 case N_NOMAP: /* No map? (Ultrix). */
3089 case N_RSYM: /* Register variable. */
3090 case N_DEFD: /* Modula-2 GNU module dependency. */
3091 case N_SSYM: /* Struct or union element. */
3092 case N_LSYM: /* Local symbol in stack. */
3093 case N_PSYM: /* Parameter variable. */
3094 case N_LENG: /* Length of preceding symbol type. */
3095 if (name)
3096 {
3097 int deftype;
3098 char *colon_pos = strchr (name, ':');
3099 if (colon_pos == NULL)
3100 deftype = '\0';
3101 else
3102 deftype = colon_pos[1];
3103
3104 switch (deftype)
3105 {
3106 case 'f':
3107 case 'F':
3108 function_stab_type = type;
3109
3110 /* Deal with the SunPRO 3.0 compiler which omits the
3111 address from N_FUN symbols. */
3112 if (type == N_FUN
3113 && valu == ANOFFSET (section_offsets,
3114 SECT_OFF_TEXT (objfile))
3115 && gdbarch_sofun_address_maybe_missing (gdbarch))
3116 {
3117 CORE_ADDR minsym_valu =
3118 find_stab_function_addr (name, last_source_file, objfile);
3119
3120 /* The function find_stab_function_addr will return
3121 0 if the minimal symbol wasn't found.
3122 (Unfortunately, this might also be a valid
3123 address.) Anyway, if it *does* return 0, it is
3124 likely that the value was set correctly to begin
3125 with... */
3126 if (minsym_valu != 0)
3127 valu = minsym_valu;
3128 }
3129
3130 if (block_address_function_relative)
3131 /* For Solaris 2 compilers, the block addresses and
3132 N_SLINE's are relative to the start of the
3133 function. On normal systems, and when using GCC on
3134 Solaris 2, these addresses are just absolute, or
3135 relative to the N_SO, depending on
3136 BLOCK_ADDRESS_ABSOLUTE. */
3137 function_start_offset = valu;
3138
3139 within_function = 1;
3140
3141 if (context_stack_depth > 1)
3142 {
3143 complaint (&symfile_complaints,
3144 _("unmatched N_LBRAC before symtab pos %d"),
3145 symnum);
3146 break;
3147 }
3148
3149 if (context_stack_depth > 0)
3150 {
3151 new = pop_context ();
3152 /* Make a block for the local symbols within. */
3153 finish_block (new->name, &local_symbols, new->old_blocks,
3154 new->start_addr, valu, objfile);
3155 }
3156
3157 new = push_context (0, valu);
3158 new->name = define_symbol (valu, name, desc, type, objfile);
3159 break;
3160
3161 default:
3162 define_symbol (valu, name, desc, type, objfile);
3163 break;
3164 }
3165 }
3166 break;
3167
3168 /* We use N_OPT to carry the gcc2_compiled flag. Sun uses it
3169 for a bunch of other flags, too. Someday we may parse their
3170 flags; for now we ignore theirs and hope they'll ignore ours. */
3171 case N_OPT: /* Solaris 2: Compiler options. */
3172 if (name)
3173 {
3174 if (strcmp (name, GCC2_COMPILED_FLAG_SYMBOL) == 0)
3175 {
3176 processing_gcc_compilation = 2;
3177 #if 0 /* Works, but is experimental. -fnf */
3178 /* For now, stay with AUTO_DEMANGLING for g++ output, as
3179 we don't know whether it will use the old style or v3
3180 mangling. */
3181 if (AUTO_DEMANGLING)
3182 {
3183 set_demangling_style (GNU_DEMANGLING_STYLE_STRING);
3184 }
3185 #endif
3186 }
3187 else
3188 n_opt_found = 1;
3189 }
3190 break;
3191
3192 case N_MAIN: /* Name of main routine. */
3193 /* FIXME: If one has a symbol file with N_MAIN and then replaces
3194 it with a symbol file with "main" and without N_MAIN. I'm
3195 not sure exactly what rule to follow but probably something
3196 like: N_MAIN takes precedence over "main" no matter what
3197 objfile it is in; If there is more than one N_MAIN, choose
3198 the one in the symfile_objfile; If there is more than one
3199 N_MAIN within a given objfile, complain() and choose
3200 arbitrarily. (kingdon) */
3201 if (name != NULL)
3202 set_main_name (name);
3203 break;
3204
3205 /* The following symbol types can be ignored. */
3206 case N_OBJ: /* Solaris 2: Object file dir and name. */
3207 case N_PATCH: /* Solaris 2: Patch Run Time Checker. */
3208 /* N_UNDF: Solaris 2: File separator mark. */
3209 /* N_UNDF: -- we will never encounter it, since we only process
3210 one file's symbols at once. */
3211 case N_ENDM: /* Solaris 2: End of module. */
3212 case N_ALIAS: /* SunPro F77: alias name, ignore for now. */
3213 break;
3214 }
3215
3216 /* '#' is a GNU C extension to allow one symbol to refer to another
3217 related symbol.
3218
3219 Generally this is used so that an alias can refer to its main
3220 symbol. */
3221 if (name[0] == '#')
3222 {
3223 /* Initialize symbol reference names and determine if this is a
3224 definition. If a symbol reference is being defined, go ahead
3225 and add it. Otherwise, just return. */
3226
3227 char *s = name;
3228 int refnum;
3229
3230 /* If this stab defines a new reference ID that is not on the
3231 reference list, then put it on the reference list.
3232
3233 We go ahead and advance NAME past the reference, even though
3234 it is not strictly necessary at this time. */
3235 refnum = symbol_reference_defined (&s);
3236 if (refnum >= 0)
3237 if (!ref_search (refnum))
3238 ref_add (refnum, 0, name, valu);
3239 name = s;
3240 }
3241
3242 previous_stab_code = type;
3243 }
3244 \f
3245 /* FIXME: The only difference between this and elfstab_build_psymtabs
3246 is the call to install_minimal_symbols for elf, and the support for
3247 split sections. If the differences are really that small, the code
3248 should be shared. */
3249
3250 /* Scan and build partial symbols for an coff symbol file.
3251 The coff file has already been processed to get its minimal symbols.
3252
3253 This routine is the equivalent of dbx_symfile_init and dbx_symfile_read
3254 rolled into one.
3255
3256 OBJFILE is the object file we are reading symbols from.
3257 ADDR is the address relative to which the symbols are (e.g.
3258 the base address of the text segment).
3259 MAINLINE is true if we are reading the main symbol
3260 table (as opposed to a shared lib or dynamically loaded file).
3261 TEXTADDR is the address of the text section.
3262 TEXTSIZE is the size of the text section.
3263 STABSECTS is the list of .stab sections in OBJFILE.
3264 STABSTROFFSET and STABSTRSIZE define the location in OBJFILE where the
3265 .stabstr section exists.
3266
3267 This routine is mostly copied from dbx_symfile_init and dbx_symfile_read,
3268 adjusted for coff details. */
3269
3270 void
3271 coffstab_build_psymtabs (struct objfile *objfile, int mainline,
3272 CORE_ADDR textaddr, unsigned int textsize,
3273 struct stab_section_list *stabsects,
3274 file_ptr stabstroffset, unsigned int stabstrsize)
3275 {
3276 int val;
3277 bfd *sym_bfd = objfile->obfd;
3278 char *name = bfd_get_filename (sym_bfd);
3279 struct dbx_symfile_info *info;
3280 unsigned int stabsize;
3281
3282 /* There is already a dbx_symfile_info allocated by our caller.
3283 It might even contain some info from the coff symtab to help us. */
3284 info = objfile->deprecated_sym_stab_info;
3285
3286 DBX_TEXT_ADDR (objfile) = textaddr;
3287 DBX_TEXT_SIZE (objfile) = textsize;
3288
3289 #define COFF_STABS_SYMBOL_SIZE 12 /* XXX FIXME XXX */
3290 DBX_SYMBOL_SIZE (objfile) = COFF_STABS_SYMBOL_SIZE;
3291 DBX_STRINGTAB_SIZE (objfile) = stabstrsize;
3292
3293 if (stabstrsize > bfd_get_size (sym_bfd))
3294 error (_("ridiculous string table size: %d bytes"), stabstrsize);
3295 DBX_STRINGTAB (objfile) = (char *)
3296 obstack_alloc (&objfile->objfile_obstack, stabstrsize + 1);
3297 OBJSTAT (objfile, sz_strtab += stabstrsize + 1);
3298
3299 /* Now read in the string table in one big gulp. */
3300
3301 val = bfd_seek (sym_bfd, stabstroffset, SEEK_SET);
3302 if (val < 0)
3303 perror_with_name (name);
3304 val = bfd_bread (DBX_STRINGTAB (objfile), stabstrsize, sym_bfd);
3305 if (val != stabstrsize)
3306 perror_with_name (name);
3307
3308 stabsread_new_init ();
3309 buildsym_new_init ();
3310 free_header_files ();
3311 init_header_files ();
3312
3313 processing_acc_compilation = 1;
3314
3315 /* In a coff file, we've already installed the minimal symbols that came
3316 from the coff (non-stab) symbol table, so always act like an
3317 incremental load here. */
3318 if (stabsects->next == NULL)
3319 {
3320 stabsize = bfd_section_size (sym_bfd, stabsects->section);
3321 DBX_SYMCOUNT (objfile) = stabsize / DBX_SYMBOL_SIZE (objfile);
3322 DBX_SYMTAB_OFFSET (objfile) = stabsects->section->filepos;
3323 }
3324 else
3325 {
3326 struct stab_section_list *stabsect;
3327
3328 DBX_SYMCOUNT (objfile) = 0;
3329 for (stabsect = stabsects; stabsect != NULL; stabsect = stabsect->next)
3330 {
3331 stabsize = bfd_section_size (sym_bfd, stabsect->section);
3332 DBX_SYMCOUNT (objfile) += stabsize / DBX_SYMBOL_SIZE (objfile);
3333 }
3334
3335 DBX_SYMTAB_OFFSET (objfile) = stabsects->section->filepos;
3336
3337 symbuf_sections = stabsects->next;
3338 symbuf_left = bfd_section_size (sym_bfd, stabsects->section);
3339 symbuf_read = 0;
3340 }
3341
3342 dbx_symfile_read (objfile, 0);
3343 }
3344 \f
3345 /* Scan and build partial symbols for an ELF symbol file.
3346 This ELF file has already been processed to get its minimal symbols.
3347
3348 This routine is the equivalent of dbx_symfile_init and dbx_symfile_read
3349 rolled into one.
3350
3351 OBJFILE is the object file we are reading symbols from.
3352 ADDR is the address relative to which the symbols are (e.g.
3353 the base address of the text segment).
3354 MAINLINE is true if we are reading the main symbol
3355 table (as opposed to a shared lib or dynamically loaded file).
3356 STABSECT is the BFD section information for the .stab section.
3357 STABSTROFFSET and STABSTRSIZE define the location in OBJFILE where the
3358 .stabstr section exists.
3359
3360 This routine is mostly copied from dbx_symfile_init and dbx_symfile_read,
3361 adjusted for elf details. */
3362
3363 void
3364 elfstab_build_psymtabs (struct objfile *objfile, int mainline,
3365 asection *stabsect,
3366 file_ptr stabstroffset, unsigned int stabstrsize)
3367 {
3368 int val;
3369 bfd *sym_bfd = objfile->obfd;
3370 char *name = bfd_get_filename (sym_bfd);
3371 struct dbx_symfile_info *info;
3372 struct cleanup *back_to = NULL;
3373
3374 /* There is already a dbx_symfile_info allocated by our caller.
3375 It might even contain some info from the ELF symtab to help us. */
3376 info = objfile->deprecated_sym_stab_info;
3377
3378 /* Find the first and last text address. dbx_symfile_read seems to
3379 want this. */
3380 find_text_range (sym_bfd, objfile);
3381
3382 #define ELF_STABS_SYMBOL_SIZE 12 /* XXX FIXME XXX */
3383 DBX_SYMBOL_SIZE (objfile) = ELF_STABS_SYMBOL_SIZE;
3384 DBX_SYMCOUNT (objfile)
3385 = bfd_section_size (objfile->obfd, stabsect) / DBX_SYMBOL_SIZE (objfile);
3386 DBX_STRINGTAB_SIZE (objfile) = stabstrsize;
3387 DBX_SYMTAB_OFFSET (objfile) = stabsect->filepos;
3388 DBX_STAB_SECTION (objfile) = stabsect;
3389
3390 if (stabstrsize > bfd_get_size (sym_bfd))
3391 error (_("ridiculous string table size: %d bytes"), stabstrsize);
3392 DBX_STRINGTAB (objfile) = (char *)
3393 obstack_alloc (&objfile->objfile_obstack, stabstrsize + 1);
3394 OBJSTAT (objfile, sz_strtab += stabstrsize + 1);
3395
3396 /* Now read in the string table in one big gulp. */
3397
3398 val = bfd_seek (sym_bfd, stabstroffset, SEEK_SET);
3399 if (val < 0)
3400 perror_with_name (name);
3401 val = bfd_bread (DBX_STRINGTAB (objfile), stabstrsize, sym_bfd);
3402 if (val != stabstrsize)
3403 perror_with_name (name);
3404
3405 stabsread_new_init ();
3406 buildsym_new_init ();
3407 free_header_files ();
3408 init_header_files ();
3409
3410 processing_acc_compilation = 1;
3411
3412 symbuf_read = 0;
3413 symbuf_left = bfd_section_size (objfile->obfd, stabsect);
3414 stabs_data = symfile_relocate_debug_section (objfile->obfd, stabsect, NULL);
3415 if (stabs_data)
3416 back_to = make_cleanup (free_current_contents, (void *) &stabs_data);
3417
3418 /* In an elf file, we've already installed the minimal symbols that came
3419 from the elf (non-stab) symbol table, so always act like an
3420 incremental load here. dbx_symfile_read should not generate any new
3421 minimal symbols, since we will have already read the ELF dynamic symbol
3422 table and normal symbol entries won't be in the ".stab" section; but in
3423 case it does, it will install them itself. */
3424 dbx_symfile_read (objfile, 0);
3425
3426 if (back_to)
3427 do_cleanups (back_to);
3428 }
3429 \f
3430 /* Scan and build partial symbols for a file with special sections for stabs
3431 and stabstrings. The file has already been processed to get its minimal
3432 symbols, and any other symbols that might be necessary to resolve GSYMs.
3433
3434 This routine is the equivalent of dbx_symfile_init and dbx_symfile_read
3435 rolled into one.
3436
3437 OBJFILE is the object file we are reading symbols from.
3438 ADDR is the address relative to which the symbols are (e.g. the base address
3439 of the text segment).
3440 MAINLINE is true if we are reading the main symbol table (as opposed to a
3441 shared lib or dynamically loaded file).
3442 STAB_NAME is the name of the section that contains the stabs.
3443 STABSTR_NAME is the name of the section that contains the stab strings.
3444
3445 This routine is mostly copied from dbx_symfile_init and dbx_symfile_read. */
3446
3447 void
3448 stabsect_build_psymtabs (struct objfile *objfile, int mainline, char *stab_name,
3449 char *stabstr_name, char *text_name)
3450 {
3451 int val;
3452 bfd *sym_bfd = objfile->obfd;
3453 char *name = bfd_get_filename (sym_bfd);
3454 asection *stabsect;
3455 asection *stabstrsect;
3456 asection *text_sect;
3457
3458 stabsect = bfd_get_section_by_name (sym_bfd, stab_name);
3459 stabstrsect = bfd_get_section_by_name (sym_bfd, stabstr_name);
3460
3461 if (!stabsect)
3462 return;
3463
3464 if (!stabstrsect)
3465 error (_("stabsect_build_psymtabs: Found stabs (%s), but not string \
3466 section (%s)"),
3467 stab_name, stabstr_name);
3468
3469 objfile->deprecated_sym_stab_info = (struct dbx_symfile_info *)
3470 xmalloc (sizeof (struct dbx_symfile_info));
3471 memset (objfile->deprecated_sym_stab_info, 0,
3472 sizeof (struct dbx_symfile_info));
3473
3474 text_sect = bfd_get_section_by_name (sym_bfd, text_name);
3475 if (!text_sect)
3476 error (_("Can't find %s section in symbol file"), text_name);
3477 DBX_TEXT_ADDR (objfile) = bfd_section_vma (sym_bfd, text_sect);
3478 DBX_TEXT_SIZE (objfile) = bfd_section_size (sym_bfd, text_sect);
3479
3480 DBX_SYMBOL_SIZE (objfile) = sizeof (struct external_nlist);
3481 DBX_SYMCOUNT (objfile) = bfd_section_size (sym_bfd, stabsect)
3482 / DBX_SYMBOL_SIZE (objfile);
3483 DBX_STRINGTAB_SIZE (objfile) = bfd_section_size (sym_bfd, stabstrsect);
3484 DBX_SYMTAB_OFFSET (objfile) = stabsect->filepos; /* XXX - FIXME: POKING INSIDE BFD DATA STRUCTURES */
3485
3486 if (DBX_STRINGTAB_SIZE (objfile) > bfd_get_size (sym_bfd))
3487 error (_("ridiculous string table size: %d bytes"),
3488 DBX_STRINGTAB_SIZE (objfile));
3489 DBX_STRINGTAB (objfile) = (char *)
3490 obstack_alloc (&objfile->objfile_obstack, DBX_STRINGTAB_SIZE (objfile) + 1);
3491 OBJSTAT (objfile, sz_strtab += DBX_STRINGTAB_SIZE (objfile) + 1);
3492
3493 /* Now read in the string table in one big gulp. */
3494
3495 val = bfd_get_section_contents (sym_bfd, /* bfd */
3496 stabstrsect, /* bfd section */
3497 DBX_STRINGTAB (objfile), /* input buffer */
3498 0, /* offset into section */
3499 DBX_STRINGTAB_SIZE (objfile)); /* amount to read */
3500
3501 if (!val)
3502 perror_with_name (name);
3503
3504 stabsread_new_init ();
3505 buildsym_new_init ();
3506 free_header_files ();
3507 init_header_files ();
3508
3509 /* Now, do an incremental load */
3510
3511 processing_acc_compilation = 1;
3512 dbx_symfile_read (objfile, 0);
3513 }
3514 \f
3515 static struct sym_fns aout_sym_fns =
3516 {
3517 bfd_target_aout_flavour,
3518 dbx_new_init, /* sym_new_init: init anything gbl to entire symtab */
3519 dbx_symfile_init, /* sym_init: read initial info, setup for sym_read() */
3520 dbx_symfile_read, /* sym_read: read a symbol file into symtab */
3521 dbx_symfile_finish, /* sym_finish: finished with file, cleanup */
3522 default_symfile_offsets, /* sym_offsets: parse user's offsets to
3523 internal form */
3524 default_symfile_segments, /* sym_segments: Get segment information from
3525 a file. */
3526 NULL, /* sym_read_linetable */
3527 NULL /* next: pointer to next struct sym_fns */
3528 };
3529
3530 void
3531 _initialize_dbxread (void)
3532 {
3533 add_symtab_fns (&aout_sym_fns);
3534 }
This page took 0.099946 seconds and 5 git commands to generate.