]> Git Repo - binutils.git/blob - gdb/dbxread.c
* dbxread.c (dbx_symfile_init): Make size of the string table
[binutils.git] / gdb / dbxread.c
1 /* Read dbx symbol tables and convert to internal format, for GDB.
2    Copyright 1986, 1987, 1988, 1989, 1990, 1991 Free Software Foundation, Inc.
3
4 This file is part of GDB.
5
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
10
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
19
20 /* This module provides three functions: dbx_symfile_init,
21    which initializes to read a symbol file; dbx_new_init, which 
22    discards existing cached information when all symbols are being
23    discarded; and dbx_symfile_read, which reads a symbol table
24    from a file.
25
26    dbx_symfile_read only does the minimum work necessary for letting the
27    user "name" things symbolically; it does not read the entire symtab.
28    Instead, it reads the external and static symbols and puts them in partial
29    symbol tables.  When more extensive information is requested of a
30    file, the corresponding partial symbol table is mutated into a full
31    fledged symbol table by going back and reading the symbols
32    for real.  dbx_psymtab_to_symtab() is the function that does this */
33
34 #include "defs.h"
35 #include <string.h>
36
37 #if defined(USG) || defined(__CYGNUSCLIB__)
38 #include <sys/types.h>
39 #include <fcntl.h>
40 #define L_SET 0
41 #define L_INCR 1
42 #endif
43
44 #include <obstack.h>
45 #include <sys/param.h>
46 #ifndef NO_SYS_FILE
47 #include <sys/file.h>
48 #endif
49 #include <sys/stat.h>
50 #include <ctype.h>
51 #include "symtab.h"
52 #include "breakpoint.h"
53 #include "command.h"
54 #include "target.h"
55 #include "gdbcore.h"            /* for bfd stuff */
56 #include "libbfd.h"             /* FIXME Secret internal BFD stuff (bfd_read) */
57 #include "libaout.h"            /* FIXME Secret internal BFD stuff for a.out */
58 #include "symfile.h"
59 #include "objfiles.h"
60 #include "buildsym.h"
61 #include "stabsread.h"
62 #include "gdb-stabs.h"
63 #include "demangle.h"
64 #include "language.h"           /* Needed inside partial-stab.h */
65 #include "complaints.h"
66
67 #include "aout/aout64.h"
68 #include "aout/stab_gnu.h"      /* We always use GNU stabs, not native, now */
69
70 /* Each partial symbol table entry contains a pointer to private data for the
71    read_symtab() function to use when expanding a partial symbol table entry
72    to a full symbol table entry.
73
74    For dbxread this structure contains the offset within the file symbol table
75    of first local symbol for this file, and length (in bytes) of the section
76    of the symbol table devoted to this file's symbols (actually, the section
77    bracketed may contain more than just this file's symbols).  It also contains
78    further information needed to locate the symbols if they are in an ELF file.
79
80    If ldsymlen is 0, the only reason for this thing's existence is the
81    dependency list.  Nothing else will happen when it is read in.  */
82
83 #define LDSYMOFF(p) (((struct symloc *)((p)->read_symtab_private))->ldsymoff)
84 #define LDSYMLEN(p) (((struct symloc *)((p)->read_symtab_private))->ldsymlen)
85 #define SYMLOC(p) ((struct symloc *)((p)->read_symtab_private))
86 #define SYMBOL_SIZE(p) (SYMLOC(p)->symbol_size)
87 #define SYMBOL_OFFSET(p) (SYMLOC(p)->symbol_offset)
88 #define STRING_OFFSET(p) (SYMLOC(p)->string_offset)
89 #define FILE_STRING_OFFSET(p) (SYMLOC(p)->file_string_offset)
90
91 struct symloc {
92   int ldsymoff;
93   int ldsymlen;
94   int symbol_size;
95   int symbol_offset;
96   int string_offset;
97   int file_string_offset;
98 };
99
100 /* Macro to determine which symbols to ignore when reading the first symbol
101    of a file.  Some machines override this definition. */
102 #ifndef IGNORE_SYMBOL
103 /* This code is used on Ultrix systems.  Ignore it */
104 #define IGNORE_SYMBOL(type)  (type == (int)N_NSYMS)
105 #endif
106
107 /* Macro for name of symbol to indicate a file compiled with gcc. */
108 #ifndef GCC_COMPILED_FLAG_SYMBOL
109 #define GCC_COMPILED_FLAG_SYMBOL "gcc_compiled."
110 #endif
111
112 /* Macro for name of symbol to indicate a file compiled with gcc2. */
113 #ifndef GCC2_COMPILED_FLAG_SYMBOL
114 #define GCC2_COMPILED_FLAG_SYMBOL "gcc2_compiled."
115 #endif
116
117 /* Define this as 1 if a pcc declaration of a char or short argument
118    gives the correct address.  Otherwise assume pcc gives the
119    address of the corresponding int, which is not the same on a
120    big-endian machine.  */
121
122 #ifndef BELIEVE_PCC_PROMOTION
123 #define BELIEVE_PCC_PROMOTION 0
124 #endif
125
126 /* Remember what we deduced to be the source language of this psymtab. */
127
128 static enum language psymtab_language = language_unknown;
129
130 /* Nonzero means give verbose info on gdb action.  From main.c.  */
131 extern int info_verbose;
132
133 /* The BFD for this file -- implicit parameter to next_symbol_text.  */
134
135 static bfd *symfile_bfd;
136
137 /* The size of each symbol in the symbol file (in external form).
138    This is set by dbx_symfile_read when building psymtabs, and by
139    dbx_psymtab_to_symtab when building symtabs.  */
140
141 static unsigned symbol_size;
142
143 /* This is the offset of the symbol table in the executable file */
144 static unsigned symbol_table_offset;
145
146 /* This is the offset of the string table in the executable file */
147 static unsigned string_table_offset;
148
149 /* For elf+stab executables, the n_strx field is not a simple index
150    into the string table.  Instead, each .o file has a base offset
151    in the string table, and the associated symbols contain offsets
152    from this base.  The following two variables contain the base
153    offset for the current and next .o files. */
154 static unsigned int file_string_table_offset;
155 static unsigned int next_file_string_table_offset;
156
157 /* Complaints about the symbols we have encountered.  */
158
159 struct complaint lbrac_complaint = 
160   {"bad block start address patched", 0, 0};
161
162 struct complaint string_table_offset_complaint =
163   {"bad string table offset in symbol %d", 0, 0};
164
165 struct complaint unknown_symtype_complaint =
166   {"unknown symbol type %s", 0, 0};
167
168 struct complaint lbrac_rbrac_complaint =
169   {"block start larger than block end", 0, 0};
170
171 struct complaint lbrac_unmatched_complaint =
172   {"unmatched N_LBRAC before symtab pos %d", 0, 0};
173
174 struct complaint lbrac_mismatch_complaint =
175   {"N_LBRAC/N_RBRAC symbol mismatch at symtab pos %d", 0, 0};
176
177 struct complaint repeated_header_complaint =
178   {"\"repeated\" header file not previously seen, at symtab pos %d", 0, 0};
179
180 struct complaint repeated_header_name_complaint =
181   {"\"repeated\" header file not previously seen, named %s", 0, 0};
182 \f
183 /* During initial symbol readin, we need to have a structure to keep
184    track of which psymtabs have which bincls in them.  This structure
185    is used during readin to setup the list of dependencies within each
186    partial symbol table. */
187
188 struct header_file_location
189 {
190   char *name;                   /* Name of header file */
191   int instance;                 /* See above */
192   struct partial_symtab *pst;   /* Partial symtab that has the
193                                    BINCL/EINCL defs for this file */
194 };
195
196 /* The actual list and controling variables */
197 static struct header_file_location *bincl_list, *next_bincl;
198 static int bincls_allocated;
199
200 /* Local function prototypes */
201
202 static void
203 free_header_files PARAMS ((void));
204
205 static void
206 init_header_files PARAMS ((void));
207
208 static struct pending *
209 copy_pending PARAMS ((struct pending *, int, struct pending *));
210
211 static struct symtab *
212 read_ofile_symtab PARAMS ((struct objfile *, int, int, CORE_ADDR, int, 
213                            struct section_offsets *));
214
215 static void
216 dbx_psymtab_to_symtab PARAMS ((struct partial_symtab *));
217
218 static void
219 dbx_psymtab_to_symtab_1 PARAMS ((struct partial_symtab *));
220
221 static void
222 read_dbx_symtab PARAMS ((struct section_offsets *, struct objfile *,
223                          CORE_ADDR, int));
224
225 static void
226 free_bincl_list PARAMS ((struct objfile *));
227
228 static struct partial_symtab *
229 find_corresponding_bincl_psymtab PARAMS ((char *, int));
230
231 static void
232 add_bincl_to_list PARAMS ((struct partial_symtab *, char *, int));
233
234 static void
235 init_bincl_list PARAMS ((int, struct objfile *));
236
237 static void
238 init_psymbol_list PARAMS ((struct objfile *));
239
240 static char *
241 dbx_next_symbol_text PARAMS ((void));
242
243 static void
244 fill_symbuf PARAMS ((bfd *));
245
246 static void
247 dbx_symfile_init PARAMS ((struct objfile *));
248
249 static void
250 dbx_new_init PARAMS ((struct objfile *));
251
252 static void
253 dbx_symfile_read PARAMS ((struct objfile *, struct section_offsets *, int));
254
255 static void
256 dbx_symfile_finish PARAMS ((struct objfile *));
257
258 static void
259 record_minimal_symbol PARAMS ((char *, CORE_ADDR, int, struct objfile *));
260
261 static void
262 add_new_header_file PARAMS ((char *, int));
263
264 static void
265 add_old_header_file PARAMS ((char *, int));
266
267 static void
268 add_this_object_header_file PARAMS ((int));
269
270 /* Free up old header file tables */
271
272 static void
273 free_header_files ()
274 {
275   register int i;
276
277   if (header_files != NULL)
278     {
279       for (i = 0; i < n_header_files; i++)
280         {
281           free (header_files[i].name);
282         }
283       free ((PTR)header_files);
284       header_files = NULL;
285       n_header_files = 0;
286     }
287   if (this_object_header_files)
288     {
289       free ((PTR)this_object_header_files);
290       this_object_header_files = NULL;
291     }
292   n_allocated_header_files = 0;
293   n_allocated_this_object_header_files = 0;
294 }
295
296 /* Allocate new header file tables */
297
298 static void
299 init_header_files ()
300 {
301   n_header_files = 0;
302   n_allocated_header_files = 10;
303   header_files = (struct header_file *)
304     xmalloc (10 * sizeof (struct header_file));
305
306   n_allocated_this_object_header_files = 10;
307   this_object_header_files = (int *) xmalloc (10 * sizeof (int));
308 }
309
310 /* Add header file number I for this object file
311    at the next successive FILENUM.  */
312
313 static void
314 add_this_object_header_file (i)
315      int i;
316 {
317   if (n_this_object_header_files == n_allocated_this_object_header_files)
318     {
319       n_allocated_this_object_header_files *= 2;
320       this_object_header_files
321         = (int *) xrealloc ((char *) this_object_header_files,
322                             n_allocated_this_object_header_files * sizeof (int));
323     }
324
325   this_object_header_files[n_this_object_header_files++] = i;
326 }
327
328 /* Add to this file an "old" header file, one already seen in
329    a previous object file.  NAME is the header file's name.
330    INSTANCE is its instance code, to select among multiple
331    symbol tables for the same header file.  */
332
333 static void
334 add_old_header_file (name, instance)
335      char *name;
336      int instance;
337 {
338   register struct header_file *p = header_files;
339   register int i;
340
341   for (i = 0; i < n_header_files; i++)
342     if (STREQ (p[i].name, name) && instance == p[i].instance)
343       {
344         add_this_object_header_file (i);
345         return;
346       }
347   complain (&repeated_header_complaint, symnum);
348   complain (&repeated_header_name_complaint, name);
349 }
350
351 /* Add to this file a "new" header file: definitions for its types follow.
352    NAME is the header file's name.
353    Most often this happens only once for each distinct header file,
354    but not necessarily.  If it happens more than once, INSTANCE has
355    a different value each time, and references to the header file
356    use INSTANCE values to select among them.
357
358    dbx output contains "begin" and "end" markers for each new header file,
359    but at this level we just need to know which files there have been;
360    so we record the file when its "begin" is seen and ignore the "end".  */
361
362 static void
363 add_new_header_file (name, instance)
364      char *name;
365      int instance;
366 {
367   register int i;
368
369   /* Make sure there is room for one more header file.  */
370
371   if (n_header_files == n_allocated_header_files)
372     {
373       n_allocated_header_files *= 2;
374       header_files = (struct header_file *)
375         xrealloc ((char *) header_files,
376                   (n_allocated_header_files * sizeof (struct header_file)));
377     }
378
379   /* Create an entry for this header file.  */
380
381   i = n_header_files++;
382   header_files[i].name = savestring (name, strlen(name));
383   header_files[i].instance = instance;
384   header_files[i].length = 10;
385   header_files[i].vector
386     = (struct type **) xmalloc (10 * sizeof (struct type *));
387   memset (header_files[i].vector, 0, 10 * sizeof (struct type *));
388
389   add_this_object_header_file (i);
390 }
391
392 #if 0
393 static struct type **
394 explicit_lookup_type (real_filenum, index)
395      int real_filenum, index;
396 {
397   register struct header_file *f = &header_files[real_filenum];
398
399   if (index >= f->length)
400     {
401       f->length *= 2;
402       f->vector = (struct type **)
403         xrealloc (f->vector, f->length * sizeof (struct type *));
404       bzero (&f->vector[f->length / 2],
405              f->length * sizeof (struct type *) / 2);
406     }
407   return &f->vector[index];
408 }
409 #endif
410 \f
411 static void
412 record_minimal_symbol (name, address, type, objfile)
413      char *name;
414      CORE_ADDR address;
415      int type;
416      struct objfile *objfile;
417 {
418   enum minimal_symbol_type ms_type;
419
420   switch (type &~ N_EXT) {
421     case N_TEXT:  ms_type = mst_text; break;
422     case N_DATA:  ms_type = mst_data; break;
423     case N_BSS:   ms_type = mst_bss;  break;
424     case N_ABS:   ms_type = mst_abs;  break;
425 #ifdef N_SETV
426     case N_SETV:  ms_type = mst_data; break;
427 #endif
428     default:      ms_type = mst_unknown; break;
429   }
430
431   prim_record_minimal_symbol (obsavestring (name, strlen (name), &objfile -> symbol_obstack),
432                              address, ms_type);
433 }
434 \f
435 /* Scan and build partial symbols for a symbol file.
436    We have been initialized by a call to dbx_symfile_init, which 
437    put all the relevant info into a "struct dbx_symfile_info",
438    hung off the objfile structure.
439
440    SECTION_OFFSETS contains offsets relative to which the symbols in the
441    various sections are (depending where the sections were actually loaded).
442    MAINLINE is true if we are reading the main symbol
443    table (as opposed to a shared lib or dynamically loaded file).  */
444
445 static void
446 dbx_symfile_read (objfile, section_offsets, mainline)
447      struct objfile *objfile;
448      struct section_offsets *section_offsets;
449      int mainline;      /* FIXME comments above */
450 {
451   bfd *sym_bfd;
452   int val;
453
454   sym_bfd = objfile->obfd;
455   val = bfd_seek (objfile->obfd, DBX_SYMTAB_OFFSET (objfile), L_SET);
456   if (val < 0)
457     perror_with_name (objfile->name);
458
459   /* If we are reinitializing, or if we have never loaded syms yet, init */
460   if (mainline || objfile->global_psymbols.size == 0 || objfile->static_psymbols.size == 0)
461     init_psymbol_list (objfile);
462
463   symbol_size = DBX_SYMBOL_SIZE (objfile);
464   symbol_table_offset = DBX_SYMTAB_OFFSET (objfile);
465
466   pending_blocks = 0;
467   make_cleanup (really_free_pendings, 0);
468
469   init_minimal_symbol_collection ();
470   make_cleanup (discard_minimal_symbols, 0);
471
472   /* Now that the symbol table data of the executable file are all in core,
473      process them and define symbols accordingly.  */
474
475   read_dbx_symtab (section_offsets, objfile,
476                    bfd_section_vma  (sym_bfd, DBX_TEXT_SECT (objfile)),
477                    bfd_section_size (sym_bfd, DBX_TEXT_SECT (objfile)));
478
479   /* Install any minimal symbols that have been collected as the current
480      minimal symbols for this objfile. */
481
482   install_minimal_symbols (objfile);
483
484   if (!have_partial_symbols ()) {
485     wrap_here ("");
486     printf_filtered ("(no debugging symbols found)...");
487     wrap_here ("");
488   }
489 }
490
491 /* Initialize anything that needs initializing when a completely new
492    symbol file is specified (not just adding some symbols from another
493    file, e.g. a shared library).  */
494
495 static void
496 dbx_new_init (ignore)
497      struct objfile *ignore;
498 {
499   stabsread_new_init ();
500   buildsym_new_init ();
501   init_header_files ();
502 }
503
504
505 /* dbx_symfile_init ()
506    is the dbx-specific initialization routine for reading symbols.
507    It is passed a struct objfile which contains, among other things,
508    the BFD for the file whose symbols are being read, and a slot for a pointer
509    to "private data" which we fill with goodies.
510
511    We read the string table into malloc'd space and stash a pointer to it.
512
513    Since BFD doesn't know how to read debug symbols in a format-independent
514    way (and may never do so...), we have to do it ourselves.  We will never
515    be called unless this is an a.out (or very similar) file. 
516    FIXME, there should be a cleaner peephole into the BFD environment here.  */
517
518 #define DBX_STRINGTAB_SIZE_SIZE sizeof(long)   /* FIXME */
519
520 static void
521 dbx_symfile_init (objfile)
522      struct objfile *objfile;
523 {
524   int val;
525   bfd *sym_bfd = objfile->obfd;
526   char *name = bfd_get_filename (sym_bfd);
527   unsigned char size_temp[DBX_STRINGTAB_SIZE_SIZE];
528
529   /* Allocate struct to keep track of the symfile */
530   objfile->sym_private = (PTR)
531     xmmalloc (objfile -> md, sizeof (struct dbx_symfile_info));
532
533   /* FIXME POKING INSIDE BFD DATA STRUCTURES */
534 #define STRING_TABLE_OFFSET     (sym_bfd->origin + obj_str_filepos (sym_bfd))
535 #define SYMBOL_TABLE_OFFSET     (sym_bfd->origin + obj_sym_filepos (sym_bfd))
536
537   /* FIXME POKING INSIDE BFD DATA STRUCTURES */
538
539   DBX_SYMFILE_INFO (objfile)->stab_section_info = NULL;
540   DBX_TEXT_SECT (objfile) = bfd_get_section_by_name (sym_bfd, ".text");
541   if (!DBX_TEXT_SECT (objfile))
542     error ("Can't find .text section in symbol file");
543
544   DBX_SYMBOL_SIZE (objfile) = obj_symbol_entry_size (sym_bfd);
545   DBX_SYMCOUNT (objfile) = bfd_get_symcount (sym_bfd);
546   DBX_SYMTAB_OFFSET (objfile) = SYMBOL_TABLE_OFFSET;
547
548   /* Read the string table and stash it away in the psymbol_obstack.  It is
549      only needed as long as we need to expand psymbols into full symbols,
550      so when we blow away the psymbol the string table goes away as well.
551      Note that gdb used to use the results of attempting to malloc the
552      string table, based on the size it read, as a form of sanity check
553      for botched byte swapping, on the theory that a byte swapped string
554      table size would be so totally bogus that the malloc would fail.  Now
555      that we put in on the psymbol_obstack, we can't do this since gdb gets
556      a fatal error (out of virtual memory) if the size is bogus.  We can
557      however at least check to see if the size is less than the size of
558      the size field itself, or larger than the size of the entire file.
559      Note that all valid string tables have a size greater than zero, since
560      the bytes used to hold the size are included in the count. */
561
562   if (STRING_TABLE_OFFSET == 0)
563     {
564       DBX_STRINGTAB_SIZE (objfile) = 0;
565       DBX_STRINGTAB (objfile) = NULL;
566     }
567   else
568     {
569       val = bfd_seek (sym_bfd, STRING_TABLE_OFFSET, L_SET);
570       if (val < 0)
571         perror_with_name (name);
572       
573       memset ((PTR) size_temp, 0, sizeof (size_temp));
574       val = bfd_read ((PTR) size_temp, sizeof (size_temp), 1, sym_bfd);
575       if (val < 0)
576         perror_with_name (name);
577       
578       DBX_STRINGTAB_SIZE (objfile) = bfd_h_get_32 (sym_bfd, size_temp);
579       
580       if (DBX_STRINGTAB_SIZE (objfile) < sizeof (size_temp)
581           || DBX_STRINGTAB_SIZE (objfile) > bfd_get_size (sym_bfd))
582         error ("ridiculous string table size (%d bytes).",
583                DBX_STRINGTAB_SIZE (objfile));
584       
585       DBX_STRINGTAB (objfile) =
586         (char *) obstack_alloc (&objfile -> psymbol_obstack,
587                                 DBX_STRINGTAB_SIZE (objfile));
588       
589       /* Now read in the string table in one big gulp.  */
590       
591       val = bfd_seek (sym_bfd, STRING_TABLE_OFFSET, L_SET);
592       if (val < 0)
593         perror_with_name (name);
594       val = bfd_read (DBX_STRINGTAB (objfile), DBX_STRINGTAB_SIZE (objfile), 1,
595                       sym_bfd);
596       if (val != DBX_STRINGTAB_SIZE (objfile))
597         perror_with_name (name);
598     }
599 }
600
601 /* Perform any local cleanups required when we are done with a particular
602    objfile.  I.E, we are in the process of discarding all symbol information
603    for an objfile, freeing up all memory held for it, and unlinking the
604    objfile struct from the global list of known objfiles. */
605
606 static void
607 dbx_symfile_finish (objfile)
608      struct objfile *objfile;
609 {
610   if (objfile->sym_private != NULL)
611     {
612       mfree (objfile -> md, objfile->sym_private);
613     }
614   free_header_files ();
615 }
616
617 \f
618 /* Buffer for reading the symbol table entries.  */
619 static struct internal_nlist symbuf[4096];
620 static int symbuf_idx;
621 static int symbuf_end;
622
623 /* Name of last function encountered.  Used in Solaris to approximate
624    object file boundaries.  */
625 static char *last_function_name;
626
627 /* The address in memory of the string table of the object file we are
628    reading (which might not be the "main" object file, but might be a
629    shared library or some other dynamically loaded thing).  This is set
630    by read_dbx_symtab when building psymtabs, and by read_ofile_symtab 
631    when building symtabs, and is used only by next_symbol_text.  */
632 static char *stringtab_global;
633
634 /* Refill the symbol table input buffer
635    and set the variables that control fetching entries from it.
636    Reports an error if no data available.
637    This function can read past the end of the symbol table
638    (into the string table) but this does no harm.  */
639
640 static void
641 fill_symbuf (sym_bfd)
642      bfd *sym_bfd;
643 {
644   int nbytes = bfd_read ((PTR)symbuf, sizeof (symbuf), 1, sym_bfd);
645   if (nbytes < 0)
646     perror_with_name (bfd_get_filename (sym_bfd));
647   else if (nbytes == 0)
648     error ("Premature end of file reading symbol table");
649   symbuf_end = nbytes / symbol_size;
650   symbuf_idx = 0;
651 }
652
653 #define SWAP_SYMBOL(symp, abfd) \
654   { \
655     (symp)->n_strx = bfd_h_get_32(abfd,                 \
656                                 (unsigned char *)&(symp)->n_strx);      \
657     (symp)->n_desc = bfd_h_get_16 (abfd,                        \
658                                 (unsigned char *)&(symp)->n_desc);      \
659     (symp)->n_value = bfd_h_get_32 (abfd,                       \
660                                 (unsigned char *)&(symp)->n_value);     \
661   }
662
663 /* Invariant: The symbol pointed to by symbuf_idx is the first one
664    that hasn't been swapped.  Swap the symbol at the same time
665    that symbuf_idx is incremented.  */
666
667 /* dbx allows the text of a symbol name to be continued into the
668    next symbol name!  When such a continuation is encountered
669    (a \ at the end of the text of a name)
670    call this function to get the continuation.  */
671
672 static char *
673 dbx_next_symbol_text ()
674 {
675   if (symbuf_idx == symbuf_end)
676     fill_symbuf (symfile_bfd);
677   symnum++;
678   SWAP_SYMBOL(&symbuf[symbuf_idx], symfile_bfd);
679   return symbuf[symbuf_idx++].n_strx + stringtab_global
680           + file_string_table_offset;
681 }
682 \f
683 /* Initializes storage for all of the partial symbols that will be
684    created by read_dbx_symtab and subsidiaries.  */
685
686 static void
687 init_psymbol_list (objfile)
688      struct objfile *objfile;
689 {
690   /* Free any previously allocated psymbol lists.  */
691   if (objfile -> global_psymbols.list)
692     mfree (objfile -> md, (PTR)objfile -> global_psymbols.list);
693   if (objfile -> static_psymbols.list)
694     mfree (objfile -> md, (PTR)objfile -> static_psymbols.list);
695
696   /* Current best guess is that there are approximately a twentieth
697      of the total symbols (in a debugging file) are global or static
698      oriented symbols */
699   objfile -> global_psymbols.size = DBX_SYMCOUNT (objfile) / 10;
700   objfile -> static_psymbols.size = DBX_SYMCOUNT (objfile) / 10;
701   objfile -> global_psymbols.next = objfile -> global_psymbols.list = (struct partial_symbol *)
702     xmmalloc (objfile -> md, objfile -> global_psymbols.size * sizeof (struct partial_symbol));
703   objfile -> static_psymbols.next = objfile -> static_psymbols.list = (struct partial_symbol *)
704     xmmalloc (objfile -> md, objfile -> static_psymbols.size * sizeof (struct partial_symbol));
705 }
706
707 /* Initialize the list of bincls to contain none and have some
708    allocated.  */
709
710 static void
711 init_bincl_list (number, objfile)
712      int number;
713      struct objfile *objfile;
714 {
715   bincls_allocated = number;
716   next_bincl = bincl_list = (struct header_file_location *)
717     xmmalloc (objfile -> md, bincls_allocated * sizeof(struct header_file_location));
718 }
719
720 /* Add a bincl to the list.  */
721
722 static void
723 add_bincl_to_list (pst, name, instance)
724      struct partial_symtab *pst;
725      char *name;
726      int instance;
727 {
728   if (next_bincl >= bincl_list + bincls_allocated)
729     {
730       int offset = next_bincl - bincl_list;
731       bincls_allocated *= 2;
732       bincl_list = (struct header_file_location *)
733         xmrealloc (pst->objfile->md, (char *)bincl_list,
734                   bincls_allocated * sizeof (struct header_file_location));
735       next_bincl = bincl_list + offset;
736     }
737   next_bincl->pst = pst;
738   next_bincl->instance = instance;
739   next_bincl++->name = name;
740 }
741
742 /* Given a name, value pair, find the corresponding
743    bincl in the list.  Return the partial symtab associated
744    with that header_file_location.  */
745
746 static struct partial_symtab *
747 find_corresponding_bincl_psymtab (name, instance)
748      char *name;
749      int instance;
750 {
751   struct header_file_location *bincl;
752
753   for (bincl = bincl_list; bincl < next_bincl; bincl++)
754     if (bincl->instance == instance
755         && STREQ (name, bincl->name))
756       return bincl->pst;
757
758   return (struct partial_symtab *) 0;
759 }
760
761 /* Free the storage allocated for the bincl list.  */
762
763 static void
764 free_bincl_list (objfile)
765      struct objfile *objfile;
766 {
767   mfree (objfile -> md, (PTR)bincl_list);
768   bincls_allocated = 0;
769 }
770
771 /* Given pointers to an a.out symbol table in core containing dbx
772    style data, setup partial_symtab's describing each source file for
773    which debugging information is available.
774    SYMFILE_NAME is the name of the file we are reading from
775    and SECTION_OFFSETS is the set of offsets for the various sections
776    of the file (a set of zeros if the mainline program).  */
777
778 static void
779 read_dbx_symtab (section_offsets, objfile, text_addr, text_size)
780      struct section_offsets *section_offsets;
781      struct objfile *objfile;
782      CORE_ADDR text_addr;
783      int text_size;
784 {
785   register struct internal_nlist *bufp = 0;     /* =0 avoids gcc -Wall glitch */
786   register char *namestring;
787   int nsl;
788   int past_first_source_file = 0;
789   CORE_ADDR last_o_file_start = 0;
790   struct cleanup *old_chain;
791   bfd *abfd;
792
793   /* End of the text segment of the executable file.  */
794   CORE_ADDR end_of_text_addr;
795
796   /* Current partial symtab */
797   struct partial_symtab *pst;
798
799   /* List of current psymtab's include files */
800   char **psymtab_include_list;
801   int includes_allocated;
802   int includes_used;
803
804   /* Index within current psymtab dependency list */
805   struct partial_symtab **dependency_list;
806   int dependencies_used, dependencies_allocated;
807
808   /* FIXME.  We probably want to change stringtab_global rather than add this
809      while processing every symbol entry.  FIXME.  */
810   file_string_table_offset = 0;
811   next_file_string_table_offset = 0;
812
813   stringtab_global = DBX_STRINGTAB (objfile);
814   
815   pst = (struct partial_symtab *) 0;
816
817   includes_allocated = 30;
818   includes_used = 0;
819   psymtab_include_list = (char **) alloca (includes_allocated *
820                                            sizeof (char *));
821
822   dependencies_allocated = 30;
823   dependencies_used = 0;
824   dependency_list =
825     (struct partial_symtab **) alloca (dependencies_allocated *
826                                        sizeof (struct partial_symtab *));
827
828   old_chain = make_cleanup (free_objfile, objfile);
829
830   /* Init bincl list */
831   init_bincl_list (20, objfile);
832   make_cleanup (free_bincl_list, objfile);
833
834   last_source_file = NULL;
835
836 #ifdef END_OF_TEXT_DEFAULT
837   end_of_text_addr = END_OF_TEXT_DEFAULT;
838 #else
839   end_of_text_addr = text_addr + section_offsets->offsets[SECT_OFF_TEXT]
840                                + text_size;     /* Relocate */
841 #endif
842
843   symfile_bfd = objfile->obfd;  /* For next_text_symbol */
844   abfd = objfile->obfd;
845   symbuf_end = symbuf_idx = 0;
846   next_symbol_text_func = dbx_next_symbol_text;
847
848   for (symnum = 0; symnum < DBX_SYMCOUNT (objfile); symnum++)
849     {
850       /* Get the symbol for this run and pull out some info */
851       QUIT;     /* allow this to be interruptable */
852       if (symbuf_idx == symbuf_end)
853         fill_symbuf (abfd);
854       bufp = &symbuf[symbuf_idx++];
855
856       /*
857        * Special case to speed up readin.
858        */
859       if (bufp->n_type == (unsigned char)N_SLINE) continue;
860
861       SWAP_SYMBOL (bufp, abfd);
862
863       /* Ok.  There is a lot of code duplicated in the rest of this
864          switch statement (for efficiency reasons).  Since I don't
865          like duplicating code, I will do my penance here, and
866          describe the code which is duplicated:
867
868          *) The assignment to namestring.
869          *) The call to strchr.
870          *) The addition of a partial symbol the the two partial
871             symbol lists.  This last is a large section of code, so
872             I've imbedded it in the following macro.
873          */
874       
875 /* Set namestring based on bufp.  If the string table index is invalid, 
876    give a fake name, and print a single error message per symbol file read,
877    rather than abort the symbol reading or flood the user with messages.  */
878
879 /*FIXME: Too many adds and indirections in here for the inner loop.  */
880 #define SET_NAMESTRING()\
881   if (((unsigned)bufp->n_strx + file_string_table_offset) >=            \
882       DBX_STRINGTAB_SIZE (objfile)) {                                   \
883     complain (&string_table_offset_complaint, symnum);                  \
884     namestring = "foo";                                                 \
885   } else                                                                \
886     namestring = bufp->n_strx + file_string_table_offset +              \
887                  DBX_STRINGTAB (objfile)
888
889 #define CUR_SYMBOL_TYPE bufp->n_type
890 #define CUR_SYMBOL_VALUE bufp->n_value
891 #define DBXREAD_ONLY
892 #define START_PSYMTAB(ofile,secoff,fname,low,symoff,global_syms,static_syms)\
893   start_psymtab(ofile, secoff, fname, low, symoff, global_syms, static_syms)
894 #define END_PSYMTAB(pst,ilist,ninc,c_off,c_text,dep_list,n_deps)\
895   end_psymtab(pst,ilist,ninc,c_off,c_text,dep_list,n_deps)
896
897 #include "partial-stab.h"
898     }
899
900   /* If there's stuff to be cleaned up, clean it up.  */
901   if (DBX_SYMCOUNT (objfile) > 0                        /* We have some syms */
902 /*FIXME, does this have a bug at start address 0? */
903       && last_o_file_start
904       && objfile -> ei.entry_point < bufp->n_value
905       && objfile -> ei.entry_point >= last_o_file_start)
906     {
907       objfile -> ei.entry_file_lowpc = last_o_file_start;
908       objfile -> ei.entry_file_highpc = bufp->n_value;
909     }
910
911   if (pst)
912     {
913       end_psymtab (pst, psymtab_include_list, includes_used,
914                    symnum * symbol_size, end_of_text_addr,
915                    dependency_list, dependencies_used);
916     }
917
918   free_bincl_list (objfile);
919   discard_cleanups (old_chain);
920 }
921
922 /* Allocate and partially fill a partial symtab.  It will be
923    completely filled at the end of the symbol list.
924
925    SYMFILE_NAME is the name of the symbol-file we are reading from, and ADDR
926    is the address relative to which its symbols are (incremental) or 0
927    (normal). */
928
929
930 struct partial_symtab *
931 start_psymtab (objfile, section_offsets,
932                filename, textlow, ldsymoff, global_syms, static_syms)
933      struct objfile *objfile;
934      struct section_offsets *section_offsets;
935      char *filename;
936      CORE_ADDR textlow;
937      int ldsymoff;
938      struct partial_symbol *global_syms;
939      struct partial_symbol *static_syms;
940 {
941   struct partial_symtab *result =
942       start_psymtab_common(objfile, section_offsets,
943                            filename, textlow, global_syms, static_syms);
944
945   result->read_symtab_private = (char *)
946     obstack_alloc (&objfile -> psymbol_obstack, sizeof (struct symloc));
947   LDSYMOFF(result) = ldsymoff;
948   result->read_symtab = dbx_psymtab_to_symtab;
949   SYMBOL_SIZE(result) = symbol_size;
950   SYMBOL_OFFSET(result) = symbol_table_offset;
951   STRING_OFFSET(result) = string_table_offset;
952   FILE_STRING_OFFSET(result) = file_string_table_offset;
953
954   /* If we're handling an ELF file, drag some section-relocation info
955      for this source file out of the ELF symbol table, to compensate for
956      Sun brain death.  This replaces the section_offsets in this psymtab,
957      if successful.  */
958   elfstab_offset_sections (objfile, result);
959
960   /* Deduce the source language from the filename for this psymtab. */
961   psymtab_language = deduce_language_from_filename (filename);
962
963   return result;
964 }
965
966 /* Close off the current usage of a partial_symbol table entry.  This
967    involves setting the correct number of includes (with a realloc),
968    setting the high text mark, setting the symbol length in the
969    executable, and setting the length of the global and static lists
970    of psymbols.
971
972    The global symbols and static symbols are then seperately sorted.
973
974    Then the partial symtab is put on the global list.
975    *** List variables and peculiarities of same. ***
976    */
977
978 void
979 end_psymtab (pst, include_list, num_includes, capping_symbol_offset,
980              capping_text, dependency_list, number_dependencies)
981      struct partial_symtab *pst;
982      char **include_list;
983      int num_includes;
984      int capping_symbol_offset;
985      CORE_ADDR capping_text;
986      struct partial_symtab **dependency_list;
987      int number_dependencies;
988 /*     struct partial_symbol *capping_global, *capping_static;*/
989 {
990   int i;
991   struct partial_symtab *p1;
992   struct objfile *objfile = pst -> objfile;
993
994   if (capping_symbol_offset != -1)
995       LDSYMLEN(pst) = capping_symbol_offset - LDSYMOFF(pst);
996   pst->texthigh = capping_text;
997
998   /* Under Solaris, the N_SO symbols always have a value of 0,
999      instead of the usual address of the .o file.  Therefore,
1000      we have to do some tricks to fill in texthigh and textlow.
1001      The first trick is in partial-stab.h: if we see a static
1002      or global function, and the textlow for the current pst
1003      is still 0, then we use that function's address for 
1004      the textlow of the pst.
1005
1006      Now, to fill in texthigh, we remember the last function seen
1007      in the .o file (also in partial-stab.h).  Also, there's a hack in
1008      bfd/elf.c and gdb/elfread.c to pass the ELF st_size field
1009      to here via the misc_info field.  Therefore, we can fill in
1010      a reliable texthigh by taking the address plus size of the
1011      last function in the file.
1012
1013      Unfortunately, that does not cover the case where the last function
1014      in the file is static.  See the paragraph below for more comments
1015      on this situation.
1016
1017      Finally, if we have a valid textlow for the current file, we run
1018      down the partial_symtab_list filling in previous texthighs that
1019      are still unknown.  */
1020
1021   if (pst->texthigh == 0 && last_function_name) {
1022     char *p;
1023     int n;
1024     struct minimal_symbol *minsym;
1025
1026     p = strchr (last_function_name, ':');
1027     if (p == NULL)
1028       p = last_function_name;
1029     n = p - last_function_name;
1030     p = alloca (n + 1);
1031     strncpy (p, last_function_name, n);
1032     p[n] = 0;
1033     
1034     minsym = lookup_minimal_symbol (p, objfile);
1035
1036     if (minsym) {
1037       pst->texthigh = SYMBOL_VALUE_ADDRESS (minsym) +
1038         (int) MSYMBOL_INFO (minsym);
1039     } else {
1040       /* This file ends with a static function, and it's
1041          difficult to imagine how hard it would be to track down
1042          the elf symbol.  Luckily, most of the time no one will notice,
1043          since the next file will likely be compiled with -g, so
1044          the code below will copy the first fuction's start address 
1045          back to our texthigh variable.  (Also, if this file is the
1046          last one in a dynamically linked program, texthigh already
1047          has the right value.)  If the next file isn't compiled
1048          with -g, then the last function in this file winds up owning
1049          all of the text space up to the next -g file, or the end (minus
1050          shared libraries).  This only matters for single stepping,
1051          and even then it will still work, except that it will single
1052          step through all of the covered functions, instead of setting
1053          breakpoints around them as it usualy does.  This makes it
1054          pretty slow, but at least it doesn't fail.
1055
1056          We can fix this with a fairly big change to bfd, but we need
1057          to coordinate better with Cygnus if we want to do that.  FIXME.  */
1058     }
1059     last_function_name = NULL;
1060   }
1061
1062   /* this test will be true if the last .o file is only data */
1063   if (pst->textlow == 0)
1064     pst->textlow = pst->texthigh;
1065
1066   /* If we know our own starting text address, then walk through all other
1067      psymtabs for this objfile, and if any didn't know their ending text
1068      address, set it to our starting address.  Take care to not set our
1069      own ending address to our starting address, nor to set addresses on
1070      `dependency' files that have both textlow and texthigh zero.  */
1071   if (pst->textlow) {
1072     ALL_OBJFILE_PSYMTABS (objfile, p1) {
1073       if (p1->texthigh == 0  && p1->textlow != 0 && p1 != pst) {
1074         p1->texthigh = pst->textlow;
1075         /* if this file has only data, then make textlow match texthigh */
1076         if (p1->textlow == 0)
1077           p1->textlow = p1->texthigh;
1078       }
1079     }
1080   }
1081
1082   /* End of kludge for patching Solaris textlow and texthigh.  */
1083
1084
1085   pst->n_global_syms =
1086     objfile->global_psymbols.next - (objfile->global_psymbols.list + pst->globals_offset);
1087   pst->n_static_syms =
1088     objfile->static_psymbols.next - (objfile->static_psymbols.list + pst->statics_offset);
1089
1090   pst->number_of_dependencies = number_dependencies;
1091   if (number_dependencies)
1092     {
1093       pst->dependencies = (struct partial_symtab **)
1094         obstack_alloc (&objfile->psymbol_obstack,
1095                        number_dependencies * sizeof (struct partial_symtab *));
1096       memcpy (pst->dependencies, dependency_list,
1097              number_dependencies * sizeof (struct partial_symtab *));
1098     }
1099   else
1100     pst->dependencies = 0;
1101
1102   for (i = 0; i < num_includes; i++)
1103     {
1104       struct partial_symtab *subpst =
1105         allocate_psymtab (include_list[i], objfile);
1106
1107       subpst->section_offsets = pst->section_offsets;
1108       subpst->read_symtab_private =
1109           (char *) obstack_alloc (&objfile->psymbol_obstack,
1110                                   sizeof (struct symloc));
1111       LDSYMOFF(subpst) =
1112         LDSYMLEN(subpst) =
1113           subpst->textlow =
1114             subpst->texthigh = 0;
1115
1116       /* We could save slight bits of space by only making one of these,
1117          shared by the entire set of include files.  FIXME-someday.  */
1118       subpst->dependencies = (struct partial_symtab **)
1119         obstack_alloc (&objfile->psymbol_obstack,
1120                        sizeof (struct partial_symtab *));
1121       subpst->dependencies[0] = pst;
1122       subpst->number_of_dependencies = 1;
1123
1124       subpst->globals_offset =
1125         subpst->n_global_syms =
1126           subpst->statics_offset =
1127             subpst->n_static_syms = 0;
1128
1129       subpst->readin = 0;
1130       subpst->symtab = 0;
1131       subpst->read_symtab = dbx_psymtab_to_symtab;
1132     }
1133
1134   sort_pst_symbols (pst);
1135
1136   /* If there is already a psymtab or symtab for a file of this name, remove it.
1137      (If there is a symtab, more drastic things also happen.)
1138      This happens in VxWorks.  */
1139   free_named_symtabs (pst->filename);
1140
1141   if (num_includes == 0
1142    && number_dependencies == 0
1143    && pst->n_global_syms == 0
1144    && pst->n_static_syms == 0) {
1145     /* Throw away this psymtab, it's empty.  We can't deallocate it, since
1146        it is on the obstack, but we can forget to chain it on the list.  */
1147     struct partial_symtab *prev_pst;
1148
1149     /* First, snip it out of the psymtab chain */
1150
1151     if (pst->objfile->psymtabs == pst)
1152       pst->objfile->psymtabs = pst->next;
1153     else
1154       for (prev_pst = pst->objfile->psymtabs; prev_pst; prev_pst = pst->next)
1155         if (prev_pst->next == pst)
1156           prev_pst->next = pst->next;
1157
1158     /* Next, put it on a free list for recycling */
1159
1160     pst->next = pst->objfile->free_psymtabs;
1161     pst->objfile->free_psymtabs = pst;
1162   }
1163 }
1164 \f
1165 static void
1166 dbx_psymtab_to_symtab_1 (pst)
1167      struct partial_symtab *pst;
1168 {
1169   struct cleanup *old_chain;
1170   int i;
1171   
1172   if (!pst)
1173     return;
1174
1175   if (pst->readin)
1176     {
1177       fprintf (stderr, "Psymtab for %s already read in.  Shouldn't happen.\n",
1178                pst->filename);
1179       return;
1180     }
1181
1182   /* Read in all partial symtabs on which this one is dependent */
1183   for (i = 0; i < pst->number_of_dependencies; i++)
1184     if (!pst->dependencies[i]->readin)
1185       {
1186         /* Inform about additional files that need to be read in.  */
1187         if (info_verbose)
1188           {
1189             fputs_filtered (" ", stdout);
1190             wrap_here ("");
1191             fputs_filtered ("and ", stdout);
1192             wrap_here ("");
1193             printf_filtered ("%s...", pst->dependencies[i]->filename);
1194             wrap_here ("");             /* Flush output */
1195             fflush (stdout);
1196           }
1197         dbx_psymtab_to_symtab_1 (pst->dependencies[i]);
1198       }
1199
1200   if (LDSYMLEN(pst))            /* Otherwise it's a dummy */
1201     {
1202       /* Init stuff necessary for reading in symbols */
1203       stabsread_init ();
1204       buildsym_init ();
1205       old_chain = make_cleanup (really_free_pendings, 0);
1206       file_string_table_offset = FILE_STRING_OFFSET (pst);
1207       symbol_size = SYMBOL_SIZE (pst);
1208
1209       /* Read in this file's symbols */
1210       bfd_seek (pst->objfile->obfd, SYMBOL_OFFSET (pst), L_SET);
1211       pst->symtab =
1212         read_ofile_symtab (pst->objfile, LDSYMOFF(pst), LDSYMLEN(pst),
1213                            pst->textlow, pst->texthigh - pst->textlow,
1214                            pst->section_offsets);
1215       sort_symtab_syms (pst->symtab);
1216
1217       do_cleanups (old_chain);
1218     }
1219
1220   pst->readin = 1;
1221 }
1222
1223 /* Read in all of the symbols for a given psymtab for real.
1224    Be verbose about it if the user wants that.  */
1225
1226 static void
1227 dbx_psymtab_to_symtab (pst)
1228      struct partial_symtab *pst;
1229 {
1230   bfd *sym_bfd;
1231
1232   if (!pst)
1233     return;
1234
1235   if (pst->readin)
1236     {
1237       fprintf (stderr, "Psymtab for %s already read in.  Shouldn't happen.\n",
1238                pst->filename);
1239       return;
1240     }
1241
1242   if (LDSYMLEN(pst) || pst->number_of_dependencies)
1243     {
1244       /* Print the message now, before reading the string table,
1245          to avoid disconcerting pauses.  */
1246       if (info_verbose)
1247         {
1248           printf_filtered ("Reading in symbols for %s...", pst->filename);
1249           fflush (stdout);
1250         }
1251
1252       sym_bfd = pst->objfile->obfd;
1253
1254       next_symbol_text_func = dbx_next_symbol_text;
1255
1256       dbx_psymtab_to_symtab_1 (pst);
1257
1258       /* Match with global symbols.  This only needs to be done once,
1259          after all of the symtabs and dependencies have been read in.   */
1260       scan_file_globals (pst->objfile);
1261
1262       /* Finish up the debug error message.  */
1263       if (info_verbose)
1264         printf_filtered ("done.\n");
1265     }
1266 }
1267
1268 /* Read in a defined section of a specific object file's symbols.
1269   
1270    DESC is the file descriptor for the file, positioned at the
1271    beginning of the symtab
1272    SYM_OFFSET is the offset within the file of
1273    the beginning of the symbols we want to read
1274    SYM_SIZE is the size of the symbol info to read in.
1275    TEXT_OFFSET is the beginning of the text segment we are reading symbols for
1276    TEXT_SIZE is the size of the text segment read in.
1277    SECTION_OFFSETS are the relocation offsets which get added to each symbol. */
1278
1279 static struct symtab *
1280 read_ofile_symtab (objfile, sym_offset, sym_size, text_offset, text_size,
1281                    section_offsets)
1282      struct objfile *objfile;
1283      int sym_offset;
1284      int sym_size;
1285      CORE_ADDR text_offset;
1286      int text_size;
1287      struct section_offsets *section_offsets;
1288 {
1289   register char *namestring;
1290   register struct internal_nlist *bufp;
1291   unsigned char type;
1292   unsigned max_symnum;
1293   register bfd *abfd;
1294   struct symtab *rtn;
1295
1296   current_objfile = objfile;
1297   subfile_stack = NULL;
1298
1299   stringtab_global = DBX_STRINGTAB (objfile);
1300   last_source_file = NULL;
1301
1302   abfd = objfile->obfd;
1303   symfile_bfd = objfile->obfd;  /* Implicit param to next_text_symbol */
1304   symbuf_end = symbuf_idx = 0;
1305
1306   /* It is necessary to actually read one symbol *before* the start
1307      of this symtab's symbols, because the GCC_COMPILED_FLAG_SYMBOL
1308      occurs before the N_SO symbol.
1309
1310      Detecting this in read_dbx_symtab
1311      would slow down initial readin, so we look for it here instead.  */
1312   if (!processing_acc_compilation && sym_offset >= (int)symbol_size)
1313     {
1314       bfd_seek (symfile_bfd, sym_offset - symbol_size, L_INCR);
1315       fill_symbuf (abfd);
1316       bufp = &symbuf[symbuf_idx++];
1317       SWAP_SYMBOL (bufp, abfd);
1318
1319       SET_NAMESTRING ();
1320
1321       processing_gcc_compilation = 0;
1322       if (bufp->n_type == N_TEXT)
1323         {
1324           if (STREQ (namestring, GCC_COMPILED_FLAG_SYMBOL))
1325             processing_gcc_compilation = 1;
1326           else if (STREQ (namestring, GCC2_COMPILED_FLAG_SYMBOL))
1327             processing_gcc_compilation = 2;
1328         }
1329
1330       /* Try to select a C++ demangling based on the compilation unit
1331          producer. */
1332
1333       if (processing_gcc_compilation)
1334         {
1335 #if 1     /* Works, but is experimental.  -fnf */
1336           if (AUTO_DEMANGLING)
1337             {
1338               set_demangling_style (GNU_DEMANGLING_STYLE_STRING);
1339             }
1340 #endif
1341         }
1342     }
1343   else
1344     {
1345       /* The N_SO starting this symtab is the first symbol, so we
1346          better not check the symbol before it.  I'm not this can
1347          happen, but it doesn't hurt to check for it.  */
1348       bfd_seek (symfile_bfd, sym_offset, L_INCR);
1349       processing_gcc_compilation = 0;
1350     }
1351
1352   if (symbuf_idx == symbuf_end)
1353     fill_symbuf (abfd);
1354   bufp = &symbuf[symbuf_idx];
1355   if (bufp->n_type != (unsigned char)N_SO)
1356     error("First symbol in segment of executable not a source symbol");
1357
1358   max_symnum = sym_size / symbol_size;
1359
1360   for (symnum = 0;
1361        symnum < max_symnum;
1362        symnum++)
1363     {
1364       QUIT;                     /* Allow this to be interruptable */
1365       if (symbuf_idx == symbuf_end)
1366         fill_symbuf(abfd);
1367       bufp = &symbuf[symbuf_idx++];
1368       SWAP_SYMBOL (bufp, abfd);
1369
1370       type = bufp->n_type;
1371
1372       SET_NAMESTRING ();
1373
1374       if (type & N_STAB) {
1375           process_one_symbol (type, bufp->n_desc, bufp->n_value,
1376                               namestring, section_offsets, objfile);
1377       }
1378       /* We skip checking for a new .o or -l file; that should never
1379          happen in this routine. */
1380       else if (type == N_TEXT)
1381         {
1382           /* I don't think this code will ever be executed, because
1383              the GCC_COMPILED_FLAG_SYMBOL usually is right before
1384              the N_SO symbol which starts this source file.
1385              However, there is no reason not to accept
1386              the GCC_COMPILED_FLAG_SYMBOL anywhere.  */
1387
1388           if (STREQ (namestring, GCC_COMPILED_FLAG_SYMBOL))
1389             processing_gcc_compilation = 1;
1390           else if (STREQ (namestring, GCC2_COMPILED_FLAG_SYMBOL))
1391             processing_gcc_compilation = 2;
1392
1393 #if 1     /* Works, but is experimental.  -fnf */
1394           if (AUTO_DEMANGLING)
1395             {
1396               set_demangling_style (GNU_DEMANGLING_STYLE_STRING);
1397             }
1398 #endif
1399         }
1400       else if (type & N_EXT || type == (unsigned char)N_TEXT
1401                || type == (unsigned char)N_NBTEXT
1402                ) {
1403           /* Global symbol: see if we came across a dbx defintion for
1404              a corresponding symbol.  If so, store the value.  Remove
1405              syms from the chain when their values are stored, but
1406              search the whole chain, as there may be several syms from
1407              different files with the same name. */
1408           /* This is probably not true.  Since the files will be read
1409              in one at a time, each reference to a global symbol will
1410              be satisfied in each file as it appears. So we skip this
1411              section. */
1412           ;
1413         }
1414     }
1415
1416   current_objfile = NULL;
1417
1418   /* In a Solaris elf file, this variable, which comes from the
1419      value of the N_SO symbol, will still be 0.  Luckily, text_offset,
1420      which comes from pst->textlow is correct. */
1421   if (last_source_start_addr == 0)
1422     last_source_start_addr = text_offset;
1423
1424   rtn = end_symtab (text_offset + text_size, 0, 0, objfile);
1425   end_stabs ();
1426   return (rtn);
1427 }
1428 \f
1429 /* This handles a single symbol from the symbol-file, building symbols
1430    into a GDB symtab.  It takes these arguments and an implicit argument.
1431
1432    TYPE is the type field of the ".stab" symbol entry.
1433    DESC is the desc field of the ".stab" entry.
1434    VALU is the value field of the ".stab" entry.
1435    NAME is the symbol name, in our address space.
1436    SECTION_OFFSETS is a set of amounts by which the sections of this object
1437           file were relocated when it was loaded into memory.
1438           All symbols that refer
1439           to memory locations need to be offset by these amounts.
1440    OBJFILE is the object file from which we are reading symbols.
1441                It is used in end_symtab.  */
1442
1443 void
1444 process_one_symbol (type, desc, valu, name, section_offsets, objfile)
1445      int type, desc;
1446      CORE_ADDR valu;
1447      char *name;
1448      struct section_offsets *section_offsets;
1449      struct objfile *objfile;
1450 {
1451 #ifndef SUN_FIXED_LBRAC_BUG
1452   /* This records the last pc address we've seen.  We depend on there being
1453      an SLINE or FUN or SO before the first LBRAC, since the variable does
1454      not get reset in between reads of different symbol files.  */
1455   static CORE_ADDR last_pc_address;
1456 #endif
1457   register struct context_stack *new;
1458   /* This remembers the address of the start of a function.  It is used
1459      because in Solaris 2, N_LBRAC, N_RBRAC, and N_SLINE entries are
1460      relative to the current function's start address.  On systems
1461      other than Solaris 2, this just holds the SECT_OFF_TEXT value, and is
1462      used to relocate these symbol types rather than SECTION_OFFSETS.  */
1463   static CORE_ADDR function_start_offset;
1464   char *colon_pos;
1465
1466 #ifndef BLOCK_ADDRESS_FUNCTION_RELATIVE
1467   /* N_LBRAC, N_RBRAC and N_SLINE entries are not relative to the
1468      function start address, so just use the text offset.  */
1469   function_start_offset = ANOFFSET (section_offsets, SECT_OFF_TEXT);
1470 #endif
1471
1472   /* Something is wrong if we see real data before
1473      seeing a source file name.  */
1474
1475   if (last_source_file == NULL && type != (unsigned char)N_SO)
1476     {
1477       /* Currently this ignores N_ENTRY on Gould machines, N_NSYM on machines
1478          where that code is defined.  */
1479       if (IGNORE_SYMBOL (type))
1480         return;
1481
1482       /* FIXME, this should not be an error, since it precludes extending
1483          the symbol table information in this way...  */
1484       error ("Invalid symbol data: does not start by identifying a source file.");
1485     }
1486
1487   switch (type)
1488     {
1489     case N_FUN:
1490     case N_FNAME:
1491 #if 0
1492 /* It seems that the Sun ANSI C compiler (acc) replaces N_FUN with N_GSYM and
1493    N_STSYM with a type code of f or F.  Can't enable this until we get some
1494    stuff straightened out with psymtabs.  FIXME. */
1495
1496     case N_GSYM:
1497     case N_STSYM:
1498 #endif /* 0 */
1499
1500       /* Relocate for dynamic loading */
1501       valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1502
1503       /* Either of these types of symbols indicates the start of
1504          a new function.  We must process its "name" normally for dbx,
1505          but also record the start of a new lexical context, and possibly
1506          also the end of the lexical context for the previous function.  */
1507       /* This is not always true.  This type of symbol may indicate a
1508          text segment variable.  */
1509
1510       colon_pos = strchr (name, ':');
1511       if (!colon_pos++
1512           || (*colon_pos != 'f' && *colon_pos != 'F'))
1513         {
1514           define_symbol (valu, name, desc, type, objfile);
1515           break;
1516         }
1517
1518 #ifndef SUN_FIXED_LBRAC_BUG
1519       last_pc_address = valu;   /* Save for SunOS bug circumcision */
1520 #endif
1521
1522 #ifdef  BLOCK_ADDRESS_FUNCTION_RELATIVE
1523       /* On Solaris 2.0 compilers, the block addresses and N_SLINE's
1524          are relative to the start of the function.  On normal systems,
1525          and when using gcc on Solaris 2.0, these addresses are just
1526          absolute, or relative to the N_SO, depending on
1527          BLOCK_ADDRESS_ABSOLUTE.  */
1528       function_start_offset = valu;     
1529 #endif
1530
1531       within_function = 1;
1532       if (context_stack_depth > 0)
1533         {
1534           new = pop_context ();
1535           /* Make a block for the local symbols within.  */
1536           finish_block (new->name, &local_symbols, new->old_blocks,
1537                         new->start_addr, valu, objfile);
1538         }
1539       /* Stack must be empty now.  */
1540       if (context_stack_depth != 0)
1541         complain (&lbrac_unmatched_complaint, symnum);
1542
1543       new = push_context (0, valu);
1544       new->name = define_symbol (valu, name, desc, type, objfile);
1545       break;
1546
1547     case N_LBRAC:
1548       /* This "symbol" just indicates the start of an inner lexical
1549          context within a function.  */
1550
1551 #if defined(BLOCK_ADDRESS_ABSOLUTE) || defined(BLOCK_ADDRESS_FUNCTION_RELATIVE)
1552       /* Relocate for dynamic loading and Sun ELF acc fn-relative syms.  */
1553       valu += function_start_offset;
1554 #else
1555       /* On most machines, the block addresses are relative to the
1556          N_SO, the linker did not relocate them (sigh).  */
1557       valu += last_source_start_addr;
1558 #endif
1559
1560 #ifndef SUN_FIXED_LBRAC_BUG
1561       if (valu < last_pc_address) {
1562         /* Patch current LBRAC pc value to match last handy pc value */
1563         complain (&lbrac_complaint);
1564         valu = last_pc_address;
1565       }
1566 #endif
1567       new = push_context (desc, valu);
1568       break;
1569
1570     case N_RBRAC:
1571       /* This "symbol" just indicates the end of an inner lexical
1572          context that was started with N_LBRAC.  */
1573
1574 #if defined(BLOCK_ADDRESS_ABSOLUTE) || defined(BLOCK_ADDRESS_FUNCTION_RELATIVE)
1575       /* Relocate for dynamic loading and Sun ELF acc fn-relative syms.  */
1576       valu += function_start_offset;
1577 #else
1578       /* On most machines, the block addresses are relative to the
1579          N_SO, the linker did not relocate them (sigh).  */
1580       valu += last_source_start_addr;
1581 #endif
1582
1583       new = pop_context();
1584       if (desc != new->depth)
1585         complain (&lbrac_mismatch_complaint, symnum);
1586
1587       /* Some compilers put the variable decls inside of an
1588          LBRAC/RBRAC block.  This macro should be nonzero if this
1589          is true.  DESC is N_DESC from the N_RBRAC symbol.
1590          GCC_P is true if we've detected the GCC_COMPILED_SYMBOL
1591          or the GCC2_COMPILED_SYMBOL.  */
1592 #if !defined (VARIABLES_INSIDE_BLOCK)
1593 #define VARIABLES_INSIDE_BLOCK(desc, gcc_p) 0
1594 #endif
1595
1596       /* Can only use new->locals as local symbols here if we're in
1597          gcc or on a machine that puts them before the lbrack.  */
1598       if (!VARIABLES_INSIDE_BLOCK(desc, processing_gcc_compilation))
1599         local_symbols = new->locals;
1600
1601       /* If this is not the outermost LBRAC...RBRAC pair in the
1602          function, its local symbols preceded it, and are the ones
1603          just recovered from the context stack.  Defined the block for them.
1604
1605          If this is the outermost LBRAC...RBRAC pair, there is no
1606          need to do anything; leave the symbols that preceded it
1607          to be attached to the function's own block.  However, if
1608          it is so, we need to indicate that we just moved outside
1609          of the function.  */
1610       if (local_symbols
1611           && (context_stack_depth
1612               > !VARIABLES_INSIDE_BLOCK(desc, processing_gcc_compilation)))
1613         {
1614           /* FIXME Muzzle a compiler bug that makes end < start.  */
1615           if (new->start_addr > valu)
1616             {
1617               complain (&lbrac_rbrac_complaint);
1618               new->start_addr = valu;
1619             }
1620           /* Make a block for the local symbols within.  */
1621           finish_block (0, &local_symbols, new->old_blocks,
1622                         new->start_addr, valu, objfile);
1623         }
1624       else
1625         {
1626           within_function = 0;
1627         }
1628       if (VARIABLES_INSIDE_BLOCK(desc, processing_gcc_compilation))
1629         /* Now pop locals of block just finished.  */
1630         local_symbols = new->locals;
1631       break;
1632
1633     case N_FN:
1634     case N_FN_SEQ:
1635       /* This kind of symbol indicates the start of an object file.  */
1636       /* Relocate for dynamic loading */
1637       valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1638       break;
1639
1640     case N_SO:
1641       /* This type of symbol indicates the start of data
1642          for one source file.
1643          Finish the symbol table of the previous source file
1644          (if any) and start accumulating a new symbol table.  */
1645       /* Relocate for dynamic loading */
1646       valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1647
1648 #ifndef SUN_FIXED_LBRAC_BUG
1649       last_pc_address = valu;   /* Save for SunOS bug circumcision */
1650 #endif
1651   
1652 #ifdef PCC_SOL_BROKEN
1653       /* pcc bug, occasionally puts out SO for SOL.  */
1654       if (context_stack_depth > 0)
1655         {
1656           start_subfile (name, NULL);
1657           break;
1658         }
1659 #endif
1660       if (last_source_file)
1661         {
1662           /* Check if previous symbol was also an N_SO (with some
1663              sanity checks).  If so, that one was actually the directory
1664              name, and the current one is the real file name.
1665              Patch things up. */           
1666           if (previous_stab_code == (unsigned char) N_SO)
1667             {
1668               patch_subfile_names (current_subfile, name);
1669               break;            /* Ignore repeated SOs */
1670             }
1671           end_symtab (valu, 0, 0, objfile);
1672           end_stabs ();
1673         }
1674       start_stabs ();
1675       start_symtab (name, NULL, valu);
1676       break;
1677
1678
1679     case N_SOL:
1680       /* This type of symbol indicates the start of data for
1681          a sub-source-file, one whose contents were copied or
1682          included in the compilation of the main source file
1683          (whose name was given in the N_SO symbol.)  */
1684       /* Relocate for dynamic loading */
1685       valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1686       start_subfile (name, current_subfile->dirname);
1687       break;
1688
1689     case N_BINCL:
1690       push_subfile ();
1691       add_new_header_file (name, valu);
1692       start_subfile (name, current_subfile->dirname);
1693       break;
1694
1695     case N_EINCL:
1696       start_subfile (pop_subfile (), current_subfile->dirname);
1697       break;
1698
1699     case N_EXCL:
1700       add_old_header_file (name, valu);
1701       break;
1702
1703     case N_SLINE:
1704       /* This type of "symbol" really just records
1705          one line-number -- core-address correspondence.
1706          Enter it in the line list for this symbol table.  */
1707       /* Relocate for dynamic loading and for ELF acc fn-relative syms.  */
1708       valu += function_start_offset;
1709 #ifndef SUN_FIXED_LBRAC_BUG
1710       last_pc_address = valu;   /* Save for SunOS bug circumcision */
1711 #endif
1712       record_line (current_subfile, desc, valu);
1713       break;
1714
1715     case N_BCOMM:
1716       if (common_block)
1717         error ("Invalid symbol data: common within common at symtab pos %d",
1718                symnum);
1719       common_block = local_symbols;
1720       common_block_i = local_symbols ? local_symbols->nsyms : 0;
1721       break;
1722
1723     case N_ECOMM:
1724       /* Symbols declared since the BCOMM are to have the common block
1725          start address added in when we know it.  common_block points to
1726          the first symbol after the BCOMM in the local_symbols list;
1727          copy the list and hang it off the symbol for the common block name
1728          for later fixup.  */
1729       {
1730         int i;
1731         struct symbol *sym =
1732           (struct symbol *) xmmalloc (objfile -> md, sizeof (struct symbol));
1733         memset (sym, 0, sizeof *sym);
1734         SYMBOL_NAME (sym) = savestring (name, strlen (name));
1735         SYMBOL_CLASS (sym) = LOC_BLOCK;
1736         SYMBOL_NAMESPACE (sym) = (enum namespace)((long)
1737           copy_pending (local_symbols, common_block_i, common_block));
1738         i = hashname (SYMBOL_NAME (sym));
1739         SYMBOL_VALUE_CHAIN (sym) = global_sym_chain[i];
1740         global_sym_chain[i] = sym;
1741         common_block = 0;
1742         break;
1743       }
1744
1745     /* The following symbol types need to have the appropriate offset added
1746        to their value; then we process symbol definitions in the name.  */
1747
1748     case N_STSYM:               /* Static symbol in data seg */
1749     case N_LCSYM:               /* Static symbol in BSS seg */
1750     case N_ROSYM:               /* Static symbol in Read-only data seg */
1751      /* HORRID HACK DEPT.  However, it's Sun's furgin' fault.  FIXME.
1752         Solaris2's stabs-in-coff makes *most* symbols relative
1753         but leaves a few absolute.  N_STSYM and friends sit on the fence.
1754         .stab "foo:S...",N_STSYM        is absolute (ld relocates it)
1755         .stab "foo:V...",N_STSYM        is relative (section base subtracted).
1756         This leaves us no choice but to search for the 'S' or 'V'...
1757         (or pass the whole section_offsets stuff down ONE MORE function
1758         call level, which we really don't want to do).  */
1759       {
1760         char *p;
1761         p = strchr (name, ':');
1762         if (p != 0 && p[1] == 'S')
1763           {
1764             /* FIXME!  We relocate it by the TEXT offset, in case the
1765                whole module moved in memory.  But this is wrong, since
1766                the sections can side around independently.  */
1767             valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1768             goto define_a_symbol;
1769           }
1770         /* Since it's not the kludge case, re-dispatch to the right handler. */
1771         switch (type) {
1772         case N_STSYM:   goto case_N_STSYM;
1773         case N_LCSYM:   goto case_N_LCSYM;
1774         case N_ROSYM:   goto case_N_ROSYM;
1775         default:        abort();
1776         }
1777       }
1778
1779     case_N_STSYM:               /* Static symbol in data seg */
1780     case N_DSLINE:              /* Source line number, data seg */
1781       valu += ANOFFSET (section_offsets, SECT_OFF_DATA);
1782       goto define_a_symbol;
1783
1784     case_N_LCSYM:               /* Static symbol in BSS seg */
1785     case N_BSLINE:              /* Source line number, bss seg */
1786     /*   N_BROWS:       overlaps with N_BSLINE */
1787       valu += ANOFFSET (section_offsets, SECT_OFF_BSS);
1788       goto define_a_symbol;
1789
1790     case_N_ROSYM:               /* Static symbol in Read-only data seg */
1791       valu += ANOFFSET (section_offsets, SECT_OFF_RODATA);
1792       goto define_a_symbol;
1793
1794     case N_ENTRY:               /* Alternate entry point */
1795       /* Relocate for dynamic loading */
1796       valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
1797       goto define_a_symbol;
1798
1799     /* The following symbol types don't need the address field relocated,
1800        since it is either unused, or is absolute.  */
1801     define_a_symbol:
1802     case N_GSYM:                /* Global variable */
1803     case N_NSYMS:               /* Number of symbols (ultrix) */
1804     case N_NOMAP:               /* No map?  (ultrix) */
1805     case N_RSYM:                /* Register variable */
1806     case N_DEFD:                /* Modula-2 GNU module dependency */
1807     case N_SSYM:                /* Struct or union element */
1808     case N_LSYM:                /* Local symbol in stack */
1809     case N_PSYM:                /* Parameter variable */
1810     case N_LENG:                /* Length of preceding symbol type */
1811       if (name)
1812         define_symbol (valu, name, desc, type, objfile);
1813       break;
1814
1815     /* We use N_OPT to carry the gcc2_compiled flag.  Sun uses it
1816        for a bunch of other flags, too.  Someday we may parse their
1817        flags; for now we ignore theirs and hope they'll ignore ours.  */
1818     case N_OPT:                 /* Solaris 2:  Compiler options */
1819       if (name)
1820         {
1821           if (STREQ (name, GCC2_COMPILED_FLAG_SYMBOL))
1822             {
1823               processing_gcc_compilation = 2;
1824 #if 1         /* Works, but is experimental.  -fnf */
1825               if (AUTO_DEMANGLING)
1826                 {
1827                   set_demangling_style (GNU_DEMANGLING_STYLE_STRING);
1828                 }
1829 #endif
1830             }
1831         }
1832       break;
1833
1834     /* The following symbol types can be ignored.  */
1835     case N_OBJ:                 /* Solaris 2:  Object file dir and name */
1836     /*   N_UNDF:                   Solaris 2:  file separator mark */
1837     /*   N_UNDF: -- we will never encounter it, since we only process one
1838                     file's symbols at once.  */
1839     case N_ENDM:                /* Solaris 2:  End of module */
1840     case N_MAIN:                /* Name of main routine.  */
1841       break;
1842       
1843     /* The following symbol types we don't know how to process.  Handle
1844        them in a "default" way, but complain to people who care.  */
1845     default:
1846     case N_CATCH:               /* Exception handler catcher */
1847     case N_EHDECL:              /* Exception handler name */
1848     case N_PC:                  /* Global symbol in Pascal */
1849     case N_M2C:                 /* Modula-2 compilation unit */
1850     /*   N_MOD2:        overlaps with N_EHDECL */
1851     case N_SCOPE:               /* Modula-2 scope information */
1852     case N_ECOML:               /* End common (local name) */
1853     case N_NBTEXT:              /* Gould Non-Base-Register symbols??? */
1854     case N_NBDATA:
1855     case N_NBBSS:
1856     case N_NBSTS:
1857     case N_NBLCS:
1858       complain (&unknown_symtype_complaint, local_hex_string(type));
1859       if (name)
1860         define_symbol (valu, name, desc, type, objfile);
1861     }
1862
1863   previous_stab_code = type;
1864 }
1865 \f
1866 /* Copy a pending list, used to record the contents of a common
1867    block for later fixup.  */
1868 static struct pending *
1869 copy_pending (beg, begi, end)
1870     struct pending *beg;
1871     int begi;
1872     struct pending *end;
1873 {
1874   struct pending *new = 0;
1875   struct pending *next;
1876
1877   for (next = beg; next != 0 && (next != end || begi < end->nsyms);
1878        next = next->next, begi = 0)
1879     {
1880       register int j;
1881       for (j = begi; j < next->nsyms; j++)
1882         add_symbol_to_list (next->symbol[j], &new);
1883     }
1884   return new;
1885 }
1886 \f
1887 /* Scan and build partial symbols for an ELF symbol file.
1888    This ELF file has already been processed to get its minimal symbols,
1889    and any DWARF symbols that were in it.
1890
1891    This routine is the equivalent of dbx_symfile_init and dbx_symfile_read
1892    rolled into one.
1893
1894    OBJFILE is the object file we are reading symbols from.
1895    ADDR is the address relative to which the symbols are (e.g.
1896    the base address of the text segment).
1897    MAINLINE is true if we are reading the main symbol
1898    table (as opposed to a shared lib or dynamically loaded file).
1899    STABOFFSET and STABSIZE define the location in OBJFILE where the .stab
1900    section exists.
1901    STABSTROFFSET and STABSTRSIZE define the location in OBJFILE where the
1902    .stabstr section exists.
1903
1904    This routine is mostly copied from dbx_symfile_init and dbx_symfile_read,
1905    adjusted for elf details. */
1906
1907 void
1908 elfstab_build_psymtabs (objfile, section_offsets, mainline, 
1909                                staboffset, stabsize,
1910                                stabstroffset, stabstrsize)
1911       struct objfile *objfile;
1912       struct section_offsets *section_offsets;
1913       int mainline;
1914       file_ptr staboffset;
1915       unsigned int stabsize;
1916       file_ptr stabstroffset;
1917       unsigned int stabstrsize;
1918 {
1919   int val;
1920   bfd *sym_bfd = objfile->obfd;
1921   char *name = bfd_get_filename (sym_bfd);
1922   struct dbx_symfile_info *info;
1923
1924   /* There is already a dbx_symfile_info allocated by our caller.
1925      It might even contain some info from the ELF symtab to help us.  */
1926   info = (struct dbx_symfile_info *) objfile->sym_private;
1927
1928   DBX_TEXT_SECT (objfile) = bfd_get_section_by_name (sym_bfd, ".text");
1929   if (!DBX_TEXT_SECT (objfile))
1930     error ("Can't find .text section in symbol file");
1931
1932 #define ELF_STABS_SYMBOL_SIZE   12      /* XXX FIXME XXX */
1933   DBX_SYMBOL_SIZE    (objfile) = ELF_STABS_SYMBOL_SIZE;
1934   DBX_SYMCOUNT       (objfile) = stabsize / DBX_SYMBOL_SIZE (objfile);
1935   DBX_STRINGTAB_SIZE (objfile) = stabstrsize;
1936   DBX_SYMTAB_OFFSET  (objfile) = staboffset;
1937   
1938   if (stabstrsize < 0   /* FIXME:  stabstrsize is unsigned; never true! */
1939       || stabstrsize > bfd_get_size (sym_bfd))
1940     error ("ridiculous string table size: %d bytes", stabstrsize);
1941   DBX_STRINGTAB (objfile) = (char *)
1942     obstack_alloc (&objfile->psymbol_obstack, stabstrsize+1);
1943
1944   /* Now read in the string table in one big gulp.  */
1945
1946   val = bfd_seek (sym_bfd, stabstroffset, L_SET);
1947   if (val < 0)
1948     perror_with_name (name);
1949   val = bfd_read (DBX_STRINGTAB (objfile), stabstrsize, 1, sym_bfd);
1950   if (val != stabstrsize)
1951     perror_with_name (name);
1952
1953   stabsread_new_init ();
1954   buildsym_new_init ();
1955   free_header_files ();
1956   init_header_files ();
1957   install_minimal_symbols (objfile);
1958
1959   processing_acc_compilation = 1;
1960
1961   /* In an elf file, we've already installed the minimal symbols that came
1962      from the elf (non-stab) symbol table, so always act like an
1963      incremental load here. */
1964   dbx_symfile_read (objfile, section_offsets, 0);
1965 }
1966 \f
1967 /* Scan and build partial symbols for a PA symbol file.
1968    This PA file has already been processed to get its minimal symbols.
1969
1970    OBJFILE is the object file we are reading symbols from.
1971    ADDR is the address relative to which the symbols are (e.g.
1972    the base address of the text segment).
1973    MAINLINE is true if we are reading the main symbol
1974    table (as opposed to a shared lib or dynamically loaded file).
1975
1976    */
1977
1978 void
1979 pastab_build_psymtabs (objfile, section_offsets, mainline)
1980      struct objfile *objfile;
1981      struct section_offsets *section_offsets;
1982      int mainline;
1983 {
1984   free_header_files ();
1985   init_header_files ();
1986
1987   /* In a PA file, we've already installed the minimal symbols that came
1988      from the PA (non-stab) symbol table, so always act like an
1989      incremental load here. */
1990
1991   dbx_symfile_read (objfile, section_offsets, mainline);
1992 }
1993 \f
1994 /* Parse the user's idea of an offset for dynamic linking, into our idea
1995    of how to represent it for fast symbol reading.  */
1996
1997 static struct section_offsets *
1998 dbx_symfile_offsets (objfile, addr)
1999      struct objfile *objfile;
2000      CORE_ADDR addr;
2001 {
2002   struct section_offsets *section_offsets;
2003   int i;
2004  
2005   section_offsets = (struct section_offsets *)
2006     obstack_alloc (&objfile -> psymbol_obstack,
2007                    sizeof (struct section_offsets) +
2008                           sizeof (section_offsets->offsets) * (SECT_OFF_MAX-1));
2009
2010   for (i = 0; i < SECT_OFF_MAX; i++)
2011     ANOFFSET (section_offsets, i) = addr;
2012   
2013   return section_offsets;
2014 }
2015 \f
2016 /* Register our willingness to decode symbols for SunOS and a.out and
2017    b.out files handled by BFD... */
2018 static struct sym_fns sunos_sym_fns =
2019 {
2020   "sunOs",              /* sym_name: name or name prefix of BFD target type */
2021   6,                    /* sym_namelen: number of significant sym_name chars */
2022   dbx_new_init,         /* sym_new_init: init anything gbl to entire symtab */
2023   dbx_symfile_init,     /* sym_init: read initial info, setup for sym_read() */
2024   dbx_symfile_read,     /* sym_read: read a symbol file into symtab */
2025   dbx_symfile_finish,   /* sym_finish: finished with file, cleanup */
2026   dbx_symfile_offsets,  /* sym_offsets: parse user's offsets to internal form */
2027   NULL                  /* next: pointer to next struct sym_fns */
2028 };
2029
2030 static struct sym_fns aout_sym_fns =
2031 {
2032   "a.out",              /* sym_name: name or name prefix of BFD target type */
2033   5,                    /* sym_namelen: number of significant sym_name chars */
2034   dbx_new_init,         /* sym_new_init: init anything gbl to entire symtab */
2035   dbx_symfile_init,     /* sym_init: read initial info, setup for sym_read() */
2036   dbx_symfile_read,     /* sym_read: read a symbol file into symtab */
2037   dbx_symfile_finish,   /* sym_finish: finished with file, cleanup */
2038   dbx_symfile_offsets,  /* sym_offsets: parse user's offsets to internal form */
2039   NULL                  /* next: pointer to next struct sym_fns */
2040 };
2041
2042 static struct sym_fns bout_sym_fns =
2043 {
2044   "b.out",              /* sym_name: name or name prefix of BFD target type */
2045   5,                    /* sym_namelen: number of significant sym_name chars */
2046   dbx_new_init,         /* sym_new_init: init anything gbl to entire symtab */
2047   dbx_symfile_init,     /* sym_init: read initial info, setup for sym_read() */
2048   dbx_symfile_read,     /* sym_read: read a symbol file into symtab */
2049   dbx_symfile_finish,   /* sym_finish: finished with file, cleanup */
2050   dbx_symfile_offsets,  /* sym_offsets: parse user's offsets to internal form */
2051   NULL                  /* next: pointer to next struct sym_fns */
2052 };
2053
2054 void
2055 _initialize_dbxread ()
2056 {
2057   add_symtab_fns(&sunos_sym_fns);
2058   add_symtab_fns(&aout_sym_fns);
2059   add_symtab_fns(&bout_sym_fns);
2060 }
This page took 0.139111 seconds and 4 git commands to generate.