bfd/
[deliverable/binutils-gdb.git] / gdb / dbxread.c
CommitLineData
c906108c 1/* Read dbx symbol tables and convert to internal format, for GDB.
197e01b6 2 Copyright (C) 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995,
131fe1bb 3 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2008.
c906108c
SS
4 Free Software Foundation, Inc.
5
c5aa993b 6 This file is part of GDB.
c906108c 7
c5aa993b
JM
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
a9762ec7 10 the Free Software Foundation; either version 3 of the License, or
c5aa993b 11 (at your option) any later version.
c906108c 12
c5aa993b
JM
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.
c906108c 17
c5aa993b 18 You should have received a copy of the GNU General Public License
a9762ec7 19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
c906108c
SS
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
1f04aa62 38#if defined(__CYGNUSCLIB__)
c906108c
SS
39#include <sys/types.h>
40#include <fcntl.h>
41#endif
42
04ea0df1 43#include "gdb_obstack.h"
c906108c 44#include "gdb_stat.h"
c906108c
SS
45#include "symtab.h"
46#include "breakpoint.h"
c906108c
SS
47#include "target.h"
48#include "gdbcore.h" /* for bfd stuff */
c5aa993b 49#include "libaout.h" /* FIXME Secret internal BFD stuff for a.out */
c906108c
SS
50#include "objfiles.h"
51#include "buildsym.h"
52#include "stabsread.h"
53#include "gdb-stabs.h"
54#include "demangle.h"
c906108c 55#include "complaints.h"
015a42b4 56#include "cp-abi.h"
91f54576 57
7c8a5605 58#include "gdb_assert.h"
91f54576 59#include "gdb_string.h"
c906108c
SS
60
61#include "aout/aout64.h"
62#include "aout/stab_gnu.h" /* We always use GNU stabs, not native, now */
c906108c 63\f
c5aa993b 64
c906108c
SS
65/* We put a pointer to this structure in the read_symtab_private field
66 of the psymtab. */
67
c5aa993b
JM
68struct symloc
69 {
c5aa993b
JM
70 /* Offset within the file symbol table of first local symbol for this
71 file. */
c906108c 72
c5aa993b 73 int ldsymoff;
c906108c 74
c5aa993b
JM
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. */
c906108c 80
c5aa993b 81 int ldsymlen;
c906108c 82
c5aa993b 83 /* The size of each symbol in the symbol file (in external form). */
c906108c 84
c5aa993b 85 int symbol_size;
c906108c 86
c5aa993b
JM
87 /* Further information needed to locate the symbols if they are in
88 an ELF file. */
c906108c 89
c5aa993b
JM
90 int symbol_offset;
91 int string_offset;
92 int file_string_offset;
93 };
c906108c
SS
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)
c906108c 102\f
c5aa993b 103
c906108c
SS
104/* Remember what we deduced to be the source language of this psymtab. */
105
106static enum language psymtab_language = language_unknown;
107
c906108c
SS
108/* The BFD for this file -- implicit parameter to next_symbol_text. */
109
110static 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
116static unsigned symbol_size;
117
118/* This is the offset of the symbol table in the executable file. */
119
120static unsigned symbol_table_offset;
121
122/* This is the offset of the string table in the executable file. */
123
124static 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
132static unsigned int file_string_table_offset;
133static 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
139static 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
144static 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
152static 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
157static int has_line_numbers;
158
159/* Complaints about the symbols we have encountered. */
160
23136709
KB
161static void
162unknown_symtype_complaint (const char *arg1)
163{
e2e0b3e5 164 complaint (&symfile_complaints, _("unknown symbol type %s"), arg1);
23136709 165}
c906108c 166
23136709
KB
167static void
168lbrac_mismatch_complaint (int arg1)
169{
170 complaint (&symfile_complaints,
e2e0b3e5 171 _("N_LBRAC/N_RBRAC symbol mismatch at symtab pos %d"), arg1);
23136709 172}
c906108c 173
23136709
KB
174static void
175repeated_header_complaint (const char *arg1, int arg2)
176{
177 complaint (&symfile_complaints,
063e58ba
MD
178 _("\"repeated\" header file %s not previously seen, at symtab \
179pos %d"),
23136709
KB
180 arg1, arg2);
181}
1f077a3e 182
7a292a7a
SS
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
192static void
c5aa993b 193find_text_range (bfd * sym_bfd, struct objfile *objfile)
7a292a7a
SS
194{
195 asection *sec;
196 int found_any = 0;
b9179dbc
EZ
197 CORE_ADDR start = 0;
198 CORE_ADDR end = 0;
c5aa993b 199
7a292a7a
SS
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 {
c5aa993b
JM
208 if (sec_start < start)
209 start = sec_start;
210 if (sec_end > end)
211 end = sec_end;
7a292a7a
SS
212 }
213 else
214 {
215 start = sec_start;
216 end = sec_end;
217 }
218
219 found_any = 1;
220 }
221
c5aa993b 222 if (!found_any)
8a3fe4f8 223 error (_("Can't find any code sections in symbol file"));
7a292a7a
SS
224
225 DBX_TEXT_ADDR (objfile) = start;
226 DBX_TEXT_SIZE (objfile) = end - start;
227}
c5aa993b 228\f
7a292a7a
SS
229
230
c906108c
SS
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
236struct 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 */
245static struct header_file_location *bincl_list, *next_bincl;
246static int bincls_allocated;
247
248/* Local function prototypes */
249
a14ed312 250extern void _initialize_dbxread (void);
392a587b 251
a14ed312 252static void read_ofile_symtab (struct partial_symtab *);
c906108c 253
a14ed312 254static void dbx_psymtab_to_symtab (struct partial_symtab *);
c906108c 255
a14ed312 256static void dbx_psymtab_to_symtab_1 (struct partial_symtab *);
c906108c 257
a14ed312 258static void read_dbx_dynamic_symtab (struct objfile *objfile);
c906108c 259
a14ed312 260static void read_dbx_symtab (struct objfile *);
c906108c 261
a14ed312 262static void free_bincl_list (struct objfile *);
c906108c 263
a14ed312 264static struct partial_symtab *find_corresponding_bincl_psymtab (char *, int);
c906108c 265
a14ed312 266static void add_bincl_to_list (struct partial_symtab *, char *, int);
c906108c 267
a14ed312 268static void init_bincl_list (int, struct objfile *);
c906108c 269
a14ed312 270static char *dbx_next_symbol_text (struct objfile *);
c906108c 271
a14ed312 272static void fill_symbuf (bfd *);
c906108c 273
a14ed312 274static void dbx_symfile_init (struct objfile *);
c906108c 275
a14ed312 276static void dbx_new_init (struct objfile *);
c906108c 277
a14ed312 278static void dbx_symfile_read (struct objfile *, int);
c906108c 279
a14ed312 280static void dbx_symfile_finish (struct objfile *);
c906108c 281
a14ed312 282static void record_minimal_symbol (char *, CORE_ADDR, int, struct objfile *);
c906108c 283
a14ed312 284static void add_new_header_file (char *, int);
c906108c 285
a14ed312 286static void add_old_header_file (char *, int);
c906108c 287
a14ed312 288static void add_this_object_header_file (int);
c906108c 289
a14ed312
KB
290static struct partial_symtab *start_psymtab (struct objfile *, char *,
291 CORE_ADDR, int,
292 struct partial_symbol **,
293 struct partial_symbol **);
d4f3574e 294
c906108c
SS
295/* Free up old header file tables */
296
d3d55eeb 297void
fba45db2 298free_header_files (void)
c906108c
SS
299{
300 if (this_object_header_files)
301 {
b8c9b27d 302 xfree (this_object_header_files);
c906108c
SS
303 this_object_header_files = NULL;
304 }
305 n_allocated_this_object_header_files = 0;
306}
307
308/* Allocate new header file tables */
309
d3d55eeb 310void
fba45db2 311init_header_files (void)
c906108c
SS
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
320static void
fba45db2 321add_this_object_header_file (int i)
c906108c
SS
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,
c5aa993b 328 n_allocated_this_object_header_files * sizeof (int));
c906108c
SS
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
339static void
fba45db2 340add_old_header_file (char *name, int instance)
c906108c 341{
52f0bd74
AC
342 struct header_file *p = HEADER_FILES (current_objfile);
343 int i;
c906108c
SS
344
345 for (i = 0; i < N_HEADER_FILES (current_objfile); i++)
6314a349 346 if (strcmp (p[i].name, name) == 0 && instance == p[i].instance)
c906108c
SS
347 {
348 add_this_object_header_file (i);
349 return;
350 }
23136709 351 repeated_header_complaint (name, symnum);
c906108c
SS
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
365static void
fba45db2 366add_new_header_file (char *name, int instance)
c906108c 367{
52f0bd74
AC
368 int i;
369 struct header_file *hfile;
c906108c
SS
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;
c5aa993b 397 hfile->name = savestring (name, strlen (name));
c906108c
SS
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
408static struct type **
fba45db2 409explicit_lookup_type (int real_filenum, int index)
c906108c 410{
52f0bd74 411 struct header_file *f = &HEADER_FILES (current_objfile)[real_filenum];
c906108c
SS
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],
c5aa993b 419 '\0', f->length * sizeof (struct type *) / 2);
c906108c
SS
420 }
421 return &f->vector[index];
422}
423#endif
424\f
425static void
fba45db2
KB
426record_minimal_symbol (char *name, CORE_ADDR address, int type,
427 struct objfile *objfile)
c906108c
SS
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;
b8fbeb18 437 section = SECT_OFF_TEXT (objfile);
c906108c
SS
438 bfd_section = DBX_TEXT_SECTION (objfile);
439 break;
440 case N_DATA | N_EXT:
441 ms_type = mst_data;
b8fbeb18 442 section = SECT_OFF_DATA (objfile);
c906108c
SS
443 bfd_section = DBX_DATA_SECTION (objfile);
444 break;
445 case N_BSS | N_EXT:
446 ms_type = mst_bss;
b8fbeb18 447 section = SECT_OFF_BSS (objfile);
c906108c
SS
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;
b8fbeb18 458 section = SECT_OFF_DATA (objfile);
c906108c
SS
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
c5aa993b
JM
463 of going over many .o files, it doesn't make sense to have one
464 file local. */
c906108c 465 ms_type = mst_file_data;
b8fbeb18 466 section = SECT_OFF_DATA (objfile);
c906108c
SS
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;
b8fbeb18 475 section = SECT_OFF_TEXT (objfile);
c906108c
SS
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.
c5aa993b
JM
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 '_'. */
91f54576 485 if (name[8] == 'C' && strcmp ("__DYNAMIC", name) == 0)
c906108c
SS
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;
015a42b4 493 if (is_vtable_name (tempstring))
c906108c
SS
494 ms_type = mst_data;
495 }
b8fbeb18 496 section = SECT_OFF_DATA (objfile);
c906108c
SS
497 bfd_section = DBX_DATA_SECTION (objfile);
498 break;
499 case N_BSS:
500 ms_type = mst_file_bss;
b8fbeb18 501 section = SECT_OFF_BSS (objfile);
c906108c
SS
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;
c5aa993b 509 }
c906108c
SS
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
c906108c
SS
524 MAINLINE is true if we are reading the main symbol
525 table (as opposed to a shared lib or dynamically loaded file). */
526
527static void
9df3df99 528dbx_symfile_read (struct objfile *objfile, int mainline)
c906108c
SS
529{
530 bfd *sym_bfd;
531 int val;
532 struct cleanup *back_to;
533
c906108c
SS
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))
c2d11a7d 551 || (0 == strncmp (bfd_get_target (sym_bfd), "epoc-pe", 7))
c906108c
SS
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
ef96bde8
EZ
560 || (objfile->global_psymbols.size == 0
561 && objfile->static_psymbols.size == 0))
c906108c
SS
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 ();
a0b3c4fd 568 back_to = make_cleanup (really_free_pendings, 0);
c906108c
SS
569
570 init_minimal_symbol_collection ();
56e290f4 571 make_cleanup_discard_minimal_symbols ();
c906108c 572
d4f3574e 573 /* Read stabs data from executable file and define symbols. */
c906108c 574
d4f3574e 575 read_dbx_symtab (objfile);
c906108c
SS
576
577 /* Add the dynamic symbols. */
578
96baa820 579 read_dbx_dynamic_symtab (objfile);
c906108c
SS
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
593static void
fba45db2 594dbx_new_init (struct objfile *ignore)
c906108c
SS
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
c5aa993b 615#define DBX_STRINGTAB_SIZE_SIZE sizeof(long) /* FIXME */
c906108c
SS
616
617static void
fba45db2 618dbx_symfile_init (struct objfile *objfile)
c906108c
SS
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 */
0a6ddd08 627 objfile->deprecated_sym_stab_info = (struct dbx_symfile_info *)
7936743b 628 xmalloc (sizeof (struct dbx_symfile_info));
063e58ba
MD
629 memset (objfile->deprecated_sym_stab_info, 0,
630 sizeof (struct dbx_symfile_info));
c906108c
SS
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;
c5aa993b 643
c906108c
SS
644 text_sect = bfd_get_section_by_name (sym_bfd, ".text");
645 if (!text_sect)
8a3fe4f8 646 error (_("Can't find .text section in symbol file"));
c906108c
SS
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
8b92e4d5
EZ
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.
c906108c
SS
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
8b92e4d5 660 that we put in on the objfile_obstack, we can't do this since gdb gets
c906108c
SS
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
c5aa993b
JM
670 will never be zero, even when there is no string table. This
671 would appear to be a bug in bfd. */
c906108c
SS
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);
c5aa993b 680
4efb68b1
AC
681 memset (size_temp, 0, sizeof (size_temp));
682 val = bfd_bread (size_temp, sizeof (size_temp), sym_bfd);
c906108c
SS
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);
c5aa993b 705
c906108c
SS
706 if (DBX_STRINGTAB_SIZE (objfile) < sizeof (size_temp)
707 || DBX_STRINGTAB_SIZE (objfile) > bfd_get_size (sym_bfd))
8a3fe4f8 708 error (_("ridiculous string table size (%d bytes)."),
c906108c 709 DBX_STRINGTAB_SIZE (objfile));
c5aa993b 710
c906108c 711 DBX_STRINGTAB (objfile) =
8b92e4d5 712 (char *) obstack_alloc (&objfile->objfile_obstack,
c906108c
SS
713 DBX_STRINGTAB_SIZE (objfile));
714 OBJSTAT (objfile, sz_strtab += DBX_STRINGTAB_SIZE (objfile));
c5aa993b 715
c906108c 716 /* Now read in the string table in one big gulp. */
c5aa993b 717
c906108c
SS
718 val = bfd_seek (sym_bfd, STRING_TABLE_OFFSET, SEEK_SET);
719 if (val < 0)
720 perror_with_name (name);
3a42e9d0
AM
721 val = bfd_bread (DBX_STRINGTAB (objfile),
722 DBX_STRINGTAB_SIZE (objfile),
723 sym_bfd);
c906108c
SS
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
735static void
fba45db2 736dbx_symfile_finish (struct objfile *objfile)
c906108c 737{
0a6ddd08 738 if (objfile->deprecated_sym_stab_info != NULL)
c906108c
SS
739 {
740 if (HEADER_FILES (objfile) != NULL)
741 {
aa1ee363
AC
742 int i = N_HEADER_FILES (objfile);
743 struct header_file *hfiles = HEADER_FILES (objfile);
c906108c
SS
744
745 while (--i >= 0)
746 {
b8c9b27d
KB
747 xfree (hfiles[i].name);
748 xfree (hfiles[i].vector);
c906108c 749 }
b8c9b27d 750 xfree (hfiles);
c906108c 751 }
0a6ddd08 752 xfree (objfile->deprecated_sym_stab_info);
c906108c
SS
753 }
754 free_header_files ();
755}
c906108c 756\f
c5aa993b 757
c906108c
SS
758/* Buffer for reading the symbol table entries. */
759static struct external_nlist symbuf[4096];
760static int symbuf_idx;
761static int symbuf_end;
762
c906108c
SS
763/* Name of last function encountered. Used in Solaris to approximate
764 object file boundaries. */
765static 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? */
774static 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). */
779static struct stab_section_list *symbuf_sections;
780static unsigned int symbuf_left;
781static unsigned int symbuf_read;
782
086df311
DJ
783/* This variable stores a global stabs buffer, if we read stabs into
784 memory in one chunk in order to process relocations. */
785static bfd_byte *stabs_data;
786
c906108c
SS
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
793static void
fba45db2 794fill_symbuf (bfd *sym_bfd)
c906108c
SS
795{
796 unsigned int count;
797 int nbytes;
798
086df311
DJ
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 }
c906108c
SS
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);
086df311 826 nbytes = bfd_bread (symbuf, count, sym_bfd);
c906108c
SS
827 }
828
c906108c
SS
829 if (nbytes < 0)
830 perror_with_name (bfd_get_filename (sym_bfd));
831 else if (nbytes == 0)
8a3fe4f8 832 error (_("Premature end of file reading symbol table"));
c906108c
SS
833 symbuf_end = nbytes / symbol_size;
834 symbuf_idx = 0;
835 symbuf_left -= nbytes;
836 symbuf_read += nbytes;
837}
838
086df311
DJ
839static void
840stabs_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
c906108c
SS
851#define INTERNALIZE_SYMBOL(intern, extern, abfd) \
852 { \
c906108c 853 (intern).n_strx = bfd_h_get_32 (abfd, (extern)->e_strx); \
83b94be5
AM
854 (intern).n_type = bfd_h_get_8 (abfd, (extern)->e_type); \
855 (intern).n_other = 0; \
c906108c 856 (intern).n_desc = bfd_h_get_16 (abfd, (extern)->e_desc); \
40b3352b
L
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); \
c906108c
SS
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
872static char *
fba45db2 873dbx_next_symbol_text (struct objfile *objfile)
c906108c
SS
874{
875 struct internal_nlist nlist;
876
877 if (symbuf_idx == symbuf_end)
878 fill_symbuf (symfile_bfd);
879
880 symnum++;
c5aa993b 881 INTERNALIZE_SYMBOL (nlist, &symbuf[symbuf_idx], symfile_bfd);
c906108c
SS
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
892static void
fba45db2 893init_bincl_list (int number, struct objfile *objfile)
c906108c
SS
894{
895 bincls_allocated = number;
896 next_bincl = bincl_list = (struct header_file_location *)
7936743b 897 xmalloc (bincls_allocated * sizeof (struct header_file_location));
c906108c
SS
898}
899
900/* Add a bincl to the list. */
901
902static void
fba45db2 903add_bincl_to_list (struct partial_symtab *pst, char *name, int instance)
c906108c
SS
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 *)
0efffb96
AC
910 xrealloc ((char *) bincl_list,
911 bincls_allocated * sizeof (struct header_file_location));
c906108c
SS
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
923static struct partial_symtab *
fba45db2 924find_corresponding_bincl_psymtab (char *name, int instance)
c906108c
SS
925{
926 struct header_file_location *bincl;
927
928 for (bincl = bincl_list; bincl < next_bincl; bincl++)
929 if (bincl->instance == instance
6314a349 930 && strcmp (name, bincl->name) == 0)
c906108c
SS
931 return bincl->pst;
932
23136709 933 repeated_header_complaint (name, symnum);
c906108c
SS
934 return (struct partial_symtab *) 0;
935}
936
937/* Free the storage allocated for the bincl list. */
938
939static void
fba45db2 940free_bincl_list (struct objfile *objfile)
c906108c 941{
2dc74dc1 942 xfree (bincl_list);
c906108c
SS
943 bincls_allocated = 0;
944}
945
74b7792f
AC
946static void
947do_free_bincl_list_cleanup (void *objfile)
948{
949 free_bincl_list (objfile);
950}
951
952static struct cleanup *
953make_cleanup_free_bincl_list (struct objfile *objfile)
954{
955 return make_cleanup (do_free_bincl_list_cleanup, objfile);
956}
957
6a34fd2f
EZ
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
962static char *
83b94be5 963set_namestring (struct objfile *objfile, const struct internal_nlist *nlist)
6a34fd2f
EZ
964{
965 char *namestring;
966
83b94be5
AM
967 if (((unsigned) nlist->n_strx + file_string_table_offset)
968 >= DBX_STRINGTAB_SIZE (objfile))
6a34fd2f 969 {
e2e0b3e5 970 complaint (&symfile_complaints, _("bad string table offset in symbol %d"),
23136709 971 symnum);
6a34fd2f
EZ
972 namestring = "<bad string table offset>";
973 }
974 else
83b94be5
AM
975 namestring = (nlist->n_strx + file_string_table_offset
976 + DBX_STRINGTAB (objfile));
6a34fd2f
EZ
977 return namestring;
978}
979
c906108c
SS
980/* Scan a SunOs dynamic symbol table for symbols of interest and
981 add them to the minimal symbol table. */
982
983static void
fba45db2 984read_dbx_dynamic_symtab (struct objfile *objfile)
c906108c
SS
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);
b8c9b27d 1015 back_to = make_cleanup (xfree, dynsyms);
c906108c
SS
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 {
063e58ba
MD
1042 sym_value += ANOFFSET (objfile->section_offsets,
1043 SECT_OFF_TEXT (objfile));
c906108c
SS
1044 type = N_TEXT;
1045 }
1046 else if (bfd_get_section_flags (abfd, sec) & SEC_DATA)
1047 {
063e58ba
MD
1048 sym_value += ANOFFSET (objfile->section_offsets,
1049 SECT_OFF_DATA (objfile));
c906108c
SS
1050 type = N_DATA;
1051 }
1052 else if (bfd_get_section_flags (abfd, sec) & SEC_ALLOC)
1053 {
063e58ba
MD
1054 sym_value += ANOFFSET (objfile->section_offsets,
1055 SECT_OFF_BSS (objfile));
c906108c
SS
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 }
c5aa993b 1079
c906108c 1080 dynrels = (arelent **) xmalloc (dynrel_size);
b8c9b27d 1081 make_cleanup (xfree, dynrels);
c906108c
SS
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 =
063e58ba
MD
1096 rel->address + ANOFFSET (objfile->section_offsets,
1097 SECT_OFF_DATA (objfile));
c906108c
SS
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
a78f21af 1126static CORE_ADDR
4867e41e
DM
1127find_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}
4867e41e 1169
23136709
KB
1170static void
1171function_outside_compilation_unit_complaint (const char *arg1)
1172{
1173 complaint (&symfile_complaints,
063e58ba
MD
1174 _("function `%s' appears to be defined outside of all compilation \
1175units"),
23136709
KB
1176 arg1);
1177}
1178
d4f3574e
SS
1179/* Setup partial_symtab's describing each source file for which
1180 debugging information is available. */
c906108c
SS
1181
1182static void
fba45db2 1183read_dbx_symtab (struct objfile *objfile)
c906108c 1184{
5e2b427d 1185 struct gdbarch *gdbarch = get_objfile_arch (objfile);
52f0bd74 1186 struct external_nlist *bufp = 0; /* =0 avoids gcc -Wall glitch */
c906108c 1187 struct internal_nlist nlist;
d4f3574e
SS
1188 CORE_ADDR text_addr;
1189 int text_size;
c906108c 1190
52f0bd74 1191 char *namestring;
c906108c
SS
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;
7c8a5605 1199 int data_sect_index;
c906108c
SS
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
d4f3574e
SS
1213 text_addr = DBX_TEXT_ADDR (objfile);
1214 text_size = DBX_TEXT_SIZE (objfile);
1215
c906108c
SS
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);
c5aa993b 1222
c906108c
SS
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);
74b7792f 1238 back_to = make_cleanup_free_bincl_list (objfile);
c906108c
SS
1239
1240 last_source_file = NULL;
1241
96baa820 1242 lowest_text_address = (CORE_ADDR) -1;
c906108c
SS
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
4f49b26b
JB
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. */
7c8a5605
JB
1271 data_sect_index = objfile->sect_index_data;
1272 if (data_sect_index == -1)
1273 data_sect_index = SECT_OFF_BSS (objfile);
2a13f9bc
JB
1274 if (data_sect_index == -1)
1275 data_sect_index = SECT_OFF_RODATA (objfile);
d646061f
JB
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. */
7c8a5605 1282
c906108c
SS
1283 for (symnum = 0; symnum < DBX_SYMCOUNT (objfile); symnum++)
1284 {
1285 /* Get the symbol for this run and pull out some info */
c5aa993b 1286 QUIT; /* allow this to be interruptable */
c906108c
SS
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
c5aa993b
JM
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.
6a34fd2f 1313 */
c5aa993b 1314
6a34fd2f
EZ
1315 switch (nlist.n_type)
1316 {
6a34fd2f
EZ
1317 /*
1318 * Standard, external, non-debugger, symbols
1319 */
1320
9ce5d3bb
DE
1321 case N_TEXT | N_EXT:
1322 case N_NBTEXT | N_EXT:
063e58ba
MD
1323 nlist.n_value += ANOFFSET (objfile->section_offsets,
1324 SECT_OFF_TEXT (objfile));
6a34fd2f
EZ
1325 goto record_it;
1326
9ce5d3bb
DE
1327 case N_DATA | N_EXT:
1328 case N_NBDATA | N_EXT:
063e58ba
MD
1329 nlist.n_value += ANOFFSET (objfile->section_offsets,
1330 SECT_OFF_DATA (objfile));
6a34fd2f
EZ
1331 goto record_it;
1332
9ce5d3bb
DE
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? */
063e58ba
MD
1337 nlist.n_value += ANOFFSET (objfile->section_offsets,
1338 SECT_OFF_BSS (objfile));
6a34fd2f
EZ
1339 goto record_it;
1340
9ce5d3bb 1341 case N_ABS | N_EXT:
6a34fd2f 1342 record_it:
83b94be5 1343 namestring = set_namestring (objfile, &nlist);
6a34fd2f 1344
9ce5d3bb 1345 bss_ext_symbol:
6a34fd2f
EZ
1346 record_minimal_symbol (namestring, nlist.n_value,
1347 nlist.n_type, objfile); /* Always */
1348 continue;
1349
1350 /* Standard, local, non-debugger, symbols */
1351
9ce5d3bb 1352 case N_NBTEXT:
6a34fd2f
EZ
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
9ce5d3bb
DE
1359 case N_FN:
1360 case N_FN_SEQ:
1361 case N_TEXT:
063e58ba
MD
1362 nlist.n_value += ANOFFSET (objfile->section_offsets,
1363 SECT_OFF_TEXT (objfile));
83b94be5 1364 namestring = set_namestring (objfile, &nlist);
6a34fd2f
EZ
1365
1366 if ((namestring[0] == '-' && namestring[1] == 'l')
1367 || (namestring[(nsl = strlen (namestring)) - 1] == 'o'
1368 && namestring[nsl - 2] == '.'))
9ce5d3bb
DE
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 }
6a34fd2f 1389 else
9ce5d3bb 1390 goto record_it;
6a34fd2f
EZ
1391 continue;
1392
9ce5d3bb 1393 case N_DATA:
063e58ba
MD
1394 nlist.n_value += ANOFFSET (objfile->section_offsets,
1395 SECT_OFF_DATA (objfile));
6a34fd2f
EZ
1396 goto record_it;
1397
9ce5d3bb 1398 case N_UNDF | N_EXT:
6a34fd2f 1399 if (nlist.n_value != 0)
9ce5d3bb
DE
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
83b94be5 1406 namestring = set_namestring (objfile, &nlist);
9ce5d3bb
DE
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 }
6a34fd2f
EZ
1415 continue; /* Just undefined, not COMMON */
1416
9ce5d3bb 1417 case N_UNDF:
6a34fd2f 1418 if (processing_acc_compilation && nlist.n_strx == 1)
9ce5d3bb
DE
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 }
6a34fd2f
EZ
1434 continue;
1435
1436 /* Lots of symbol types we can just ignore. */
1437
9ce5d3bb
DE
1438 case N_ABS:
1439 case N_NBDATA:
1440 case N_NBBSS:
6a34fd2f
EZ
1441 continue;
1442
1443 /* Keep going . . . */
1444
1445 /*
1446 * Special symbol types for GNU
1447 */
9ce5d3bb
DE
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:
6a34fd2f
EZ
1459 continue;
1460
1461 /*
1462 * Debugger symbols
1463 */
1464
9ce5d3bb 1465 case N_SO:
6a34fd2f
EZ
1466 {
1467 CORE_ADDR valu;
1468 static int prev_so_symnum = -10;
1469 static int first_so_symnum;
1470 char *p;
57c22c6c 1471 static char *dirname_nso;
6a34fd2f
EZ
1472 int prev_textlow_not_set;
1473
063e58ba
MD
1474 valu = nlist.n_value + ANOFFSET (objfile->section_offsets,
1475 SECT_OFF_TEXT (objfile));
6a34fd2f
EZ
1476
1477 prev_textlow_not_set = textlow_not_set;
1478
6a34fd2f
EZ
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
203c3895 1483 if (nlist.n_value == 0
5e2b427d 1484 && gdbarch_sofun_address_maybe_missing (gdbarch))
6a34fd2f
EZ
1485 {
1486 textlow_not_set = 1;
1487 valu = 0;
1488 }
1489 else
1490 textlow_not_set = 0;
203c3895 1491
6a34fd2f
EZ
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,
5afc051b 1502 valu > pst->texthigh ? valu : pst->texthigh,
6a34fd2f
EZ
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
83b94be5 1515 namestring = set_namestring (objfile, &nlist);
6a34fd2f
EZ
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')
57c22c6c
BR
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 }
6a34fd2f
EZ
1534
1535 /* Some other compilers (C++ ones in particular) emit useless
131fe1bb
DE
1536 SOs for non-existant .c files. We ignore all subsequent SOs
1537 that immediately follow the first. */
6a34fd2f
EZ
1538
1539 if (!pst)
57c22c6c 1540 {
9ce5d3bb
DE
1541 pst = start_psymtab (objfile,
1542 namestring, valu,
1543 first_so_symnum * symbol_size,
1544 objfile->global_psymbols.next,
1545 objfile->static_psymbols.next);
57c22c6c
BR
1546 pst->dirname = dirname_nso;
1547 dirname_nso = NULL;
1548 }
6a34fd2f
EZ
1549 continue;
1550 }
1551
9ce5d3bb 1552 case N_BINCL:
6a34fd2f
EZ
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
83b94be5 1559 namestring = set_namestring (objfile, &nlist);
6a34fd2f
EZ
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))
d7f98cce 1569 psymtab_language = tmp_language;
6a34fd2f
EZ
1570
1571 if (pst == NULL)
9ce5d3bb
DE
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 \
063e58ba 1577pos %d"),
9ce5d3bb
DE
1578 namestring, symnum);
1579 continue;
1580 }
6a34fd2f
EZ
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
9ce5d3bb 1588 case N_SOL:
6a34fd2f
EZ
1589 {
1590 enum language tmp_language;
1591 /* Mark down an include file in the current psymtab */
1592
83b94be5 1593 namestring = set_namestring (objfile, &nlist);
6a34fd2f
EZ
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))
d7f98cce 1603 psymtab_language = tmp_language;
6a34fd2f
EZ
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). */
6314a349 1615 if (pst && strcmp (namestring, pst->filename) == 0)
9ce5d3bb 1616 continue;
6a34fd2f 1617 {
aa1ee363 1618 int i;
6a34fd2f 1619 for (i = 0; i < includes_used; i++)
6314a349 1620 if (strcmp (namestring, psymtab_include_list[i]) == 0)
6a34fd2f
EZ
1621 {
1622 i = -1;
1623 break;
1624 }
1625 if (i == -1)
1626 continue;
1627 }
1628
9ce5d3bb 1629 record_include_file:
6a34fd2f
EZ
1630
1631 psymtab_include_list[includes_used++] = namestring;
1632 if (includes_used >= includes_allocated)
9ce5d3bb
DE
1633 {
1634 char **orig = psymtab_include_list;
6a34fd2f 1635
9ce5d3bb 1636 psymtab_include_list = (char **)
83b94be5 1637 alloca ((includes_allocated *= 2) * sizeof (char *));
9ce5d3bb
DE
1638 memcpy (psymtab_include_list, orig,
1639 includes_used * sizeof (char *));
1640 }
6a34fd2f
EZ
1641 continue;
1642 }
9ce5d3bb
DE
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
063e58ba 1651 data or bss (sigh FIXME). */
6a34fd2f
EZ
1652
1653 /* Following may probably be ignored; I'll leave them here
1654 for now (until I do Pascal and Modula 2 extensions). */
1655
9ce5d3bb 1656 case N_PC: /* I may or may not need this; I
063e58ba 1657 suspect not. */
9ce5d3bb
DE
1658 case N_M2C: /* I suspect that I can ignore this here. */
1659 case N_SCOPE: /* Same. */
131fe1bb
DE
1660 {
1661 char *p;
6a34fd2f 1662
83b94be5 1663 namestring = set_namestring (objfile, &nlist);
6a34fd2f
EZ
1664
1665 /* See if this is an end of function stab. */
1666 if (pst && nlist.n_type == N_FUN && *namestring == '\000')
9ce5d3bb
DE
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 }
6a34fd2f
EZ
1678
1679 p = (char *) strchr (namestring, ':');
1680 if (!p)
9ce5d3bb 1681 continue; /* Not a debugging symbol. */
6a34fd2f 1682
6a34fd2f
EZ
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])
9ce5d3bb
DE
1691 {
1692 case 'S':
1693 nlist.n_value += ANOFFSET (objfile->section_offsets,
1694 data_sect_index);
1695
5e2b427d
UW
1696 if (gdbarch_static_transform_name_p (gdbarch))
1697 namestring = gdbarch_static_transform_name (gdbarch,
1698 namestring);
9ce5d3bb
DE
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;
131fe1bb 1706
9ce5d3bb
DE
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;
6a34fd2f 1718
9ce5d3bb
DE
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;
131fe1bb 1747
9ce5d3bb
DE
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++;
6a34fd2f 1788
9ce5d3bb 1789 /* Skip over the colon. */
6a34fd2f 1790 p++;
9ce5d3bb 1791 }
6a34fd2f 1792
9ce5d3bb
DE
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;
131fe1bb 1828
9ce5d3bb
DE
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;
6a34fd2f 1836
9ce5d3bb
DE
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))
5e2b427d 1855 && gdbarch_sofun_address_maybe_missing (gdbarch))
9ce5d3bb
DE
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
5e2b427d 1870 && gdbarch_sofun_address_maybe_missing (gdbarch))
9ce5d3bb
DE
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;
6a34fd2f 1901
9ce5d3bb
DE
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))
5e2b427d 1923 && gdbarch_sofun_address_maybe_missing (gdbarch))
9ce5d3bb
DE
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
5e2b427d 1938 && gdbarch_sofun_address_maybe_missing (gdbarch))
9ce5d3bb
DE
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;
6a34fd2f 1969
9ce5d3bb
DE
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;
6a34fd2f 1988
9ce5d3bb
DE
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;
6a34fd2f 1998
9ce5d3bb
DE
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. */
6a34fd2f 2006
9ce5d3bb
DE
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 }
131fe1bb 2014 }
6a34fd2f 2015
9ce5d3bb 2016 case N_EXCL:
6a34fd2f 2017
83b94be5 2018 namestring = set_namestring (objfile, &nlist);
6a34fd2f
EZ
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 *));
4efb68b1 2055 memcpy (dependency_list, orig,
6a34fd2f
EZ
2056 (dependencies_used
2057 * sizeof (struct partial_symtab *)));
2058#ifdef DEBUG_INFO
063e58ba
MD
2059 fprintf_unfiltered (gdb_stderr,
2060 "Had to reallocate dependency list.\n");
2061 fprintf_unfiltered (gdb_stderr,
2062 "New dependencies allocated: %d\n",
6a34fd2f
EZ
2063 dependencies_allocated);
2064#endif
2065 }
2066 }
2067 }
2068 continue;
2069
9ce5d3bb 2070 case N_ENDM:
6a34fd2f 2071 /* Solaris 2 end of module, finish current partial symbol table.
5afc051b 2072 end_psymtab will set pst->texthigh to the proper value, which
6a34fd2f
EZ
2073 is necessary if a module compiled without debugging info
2074 follows this module. */
5e2b427d 2075 if (pst && gdbarch_sofun_address_maybe_missing (gdbarch))
9ce5d3bb
DE
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 }
6a34fd2f 2085 continue;
c906108c 2086
9ce5d3bb 2087 case N_RBRAC:
6a34fd2f
EZ
2088#ifdef HANDLE_RBRAC
2089 HANDLE_RBRAC (nlist.n_value);
2090 continue;
2091#endif
9ce5d3bb
DE
2092 case N_EINCL:
2093 case N_DSLINE:
2094 case N_BSLINE:
2095 case N_SSYM: /* Claim: Structure or union element.
063e58ba 2096 Hopefully, I can ignore this. */
9ce5d3bb
DE
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:
6a34fd2f
EZ
2117 /* These symbols aren't interesting; don't worry about them */
2118
2119 continue;
2120
9ce5d3bb 2121 default:
6a34fd2f
EZ
2122 /* If we haven't found it yet, ignore it. It's probably some
2123 new type we don't know about yet. */
bb599908 2124 unknown_symtype_complaint (hex_string (nlist.n_type));
6a34fd2f
EZ
2125 continue;
2126 }
c906108c
SS
2127 }
2128
2129 /* If there's stuff to be cleaned up, clean it up. */
c906108c
SS
2130 if (pst)
2131 {
2132 /* Don't set pst->texthigh lower than it already is. */
2133 CORE_ADDR text_end =
6a34fd2f 2134 (lowest_text_address == (CORE_ADDR) -1
063e58ba
MD
2135 ? (text_addr + ANOFFSET (objfile->section_offsets,
2136 SECT_OFF_TEXT (objfile)))
6a34fd2f
EZ
2137 : lowest_text_address)
2138 + text_size;
c906108c
SS
2139
2140 end_psymtab (pst, psymtab_include_list, includes_used,
2141 symnum * symbol_size,
5afc051b 2142 text_end > pst->texthigh ? text_end : pst->texthigh,
c906108c
SS
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
d4f3574e 2156static struct partial_symtab *
fba45db2
KB
2157start_psymtab (struct objfile *objfile, char *filename, CORE_ADDR textlow,
2158 int ldsymoff, struct partial_symbol **global_syms,
2159 struct partial_symbol **static_syms)
c906108c
SS
2160{
2161 struct partial_symtab *result =
d4f3574e 2162 start_psymtab_common (objfile, objfile->section_offsets,
c5aa993b 2163 filename, textlow, global_syms, static_syms);
c906108c
SS
2164
2165 result->read_symtab_private = (char *)
8b92e4d5 2166 obstack_alloc (&objfile->objfile_obstack, sizeof (struct symloc));
c5aa993b 2167 LDSYMOFF (result) = ldsymoff;
c906108c 2168 result->read_symtab = dbx_psymtab_to_symtab;
c5aa993b
JM
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;
c906108c 2173
31d99776 2174#ifdef HAVE_ELF
c906108c
SS
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);
31d99776 2180#endif
c906108c
SS
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
2193struct partial_symtab *
fba45db2
KB
2194end_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)
c906108c
SS
2198{
2199 int i;
c5aa993b 2200 struct objfile *objfile = pst->objfile;
5e2b427d 2201 struct gdbarch *gdbarch = get_objfile_arch (objfile);
c906108c
SS
2202
2203 if (capping_symbol_offset != -1)
c5aa993b 2204 LDSYMLEN (pst) = capping_symbol_offset - LDSYMOFF (pst);
5afc051b 2205 pst->texthigh = capping_text;
c906108c 2206
c906108c
SS
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.
6a34fd2f 2210 The first trick is: if we see a static
c906108c
SS
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
6a34fd2f 2216 in the .o file. Also, there's a hack in
c906108c
SS
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
203c3895 2222 if (pst->texthigh == 0 && last_function_name
5e2b427d 2223 && gdbarch_sofun_address_maybe_missing (gdbarch))
c906108c
SS
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;
c5aa993b 2236
c906108c
SS
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)
5afc051b 2249 pst->texthigh = SYMBOL_VALUE_ADDRESS (minsym) + MSYMBOL_SIZE (minsym);
c906108c
SS
2250
2251 last_function_name = NULL;
2252 }
2253
5e2b427d 2254 if (!gdbarch_sofun_address_maybe_missing (gdbarch))
203c3895 2255 ;
c906108c 2256 /* this test will be true if the last .o file is only data */
203c3895 2257 else if (textlow_not_set)
5afc051b 2258 pst->textlow = pst->texthigh;
c906108c
SS
2259 else
2260 {
2261 struct partial_symtab *p1;
2262
2263 /* If we know our own starting text address, then walk through all other
c5aa993b
JM
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. */
c906108c
SS
2268
2269 ALL_OBJFILE_PSYMTABS (objfile, p1)
c5aa993b 2270 {
5afc051b 2271 if (p1->texthigh == 0 && p1->textlow != 0 && p1 != pst)
c5aa993b 2272 {
5afc051b 2273 p1->texthigh = pst->textlow;
c5aa993b 2274 /* if this file has only data, then make textlow match texthigh */
5afc051b
JB
2275 if (p1->textlow == 0)
2276 p1->textlow = p1->texthigh;
c5aa993b
JM
2277 }
2278 }
c906108c
SS
2279 }
2280
2281 /* End of kludge for patching Solaris textlow and texthigh. */
c906108c
SS
2282
2283 pst->n_global_syms =
063e58ba
MD
2284 objfile->global_psymbols.next - (objfile->global_psymbols.list
2285 + pst->globals_offset);
c906108c 2286 pst->n_static_syms =
063e58ba
MD
2287 objfile->static_psymbols.next - (objfile->static_psymbols.list
2288 + pst->statics_offset);
c906108c
SS
2289
2290 pst->number_of_dependencies = number_dependencies;
2291 if (number_dependencies)
2292 {
2293 pst->dependencies = (struct partial_symtab **)
8b92e4d5 2294 obstack_alloc (&objfile->objfile_obstack,
83b94be5 2295 number_dependencies * sizeof (struct partial_symtab *));
c906108c 2296 memcpy (pst->dependencies, dependency_list,
c5aa993b 2297 number_dependencies * sizeof (struct partial_symtab *));
c906108c
SS
2298 }
2299 else
2300 pst->dependencies = 0;
2301
2302 for (i = 0; i < num_includes; i++)
2303 {
2304 struct partial_symtab *subpst =
c5aa993b 2305 allocate_psymtab (include_list[i], objfile);
c906108c 2306
b8fbeb18 2307 /* Copy the sesction_offsets array from the main psymtab. */
c906108c
SS
2308 subpst->section_offsets = pst->section_offsets;
2309 subpst->read_symtab_private =
8b92e4d5 2310 (char *) obstack_alloc (&objfile->objfile_obstack,
c5aa993b
JM
2311 sizeof (struct symloc));
2312 LDSYMOFF (subpst) =
2313 LDSYMLEN (subpst) =
5afc051b
JB
2314 subpst->textlow =
2315 subpst->texthigh = 0;
c906108c
SS
2316
2317 /* We could save slight bits of space by only making one of these,
c5aa993b 2318 shared by the entire set of include files. FIXME-someday. */
c906108c 2319 subpst->dependencies = (struct partial_symtab **)
8b92e4d5 2320 obstack_alloc (&objfile->objfile_obstack,
c906108c
SS
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 =
c5aa993b
JM
2327 subpst->statics_offset =
2328 subpst->n_static_syms = 0;
c906108c
SS
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
c5aa993b 2349 it is on the obstack, but we can forget to chain it on the list. */
c906108c 2350 /* Empty psymtabs happen as a result of header files which don't have
c5aa993b
JM
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. */
c906108c
SS
2355
2356 discard_psymtab (pst);
2357
2358 /* Indicate that psymtab was thrown away. */
c5aa993b 2359 pst = (struct partial_symtab *) NULL;
c906108c
SS
2360 }
2361 return pst;
2362}
2363\f
2364static void
fba45db2 2365dbx_psymtab_to_symtab_1 (struct partial_symtab *pst)
c906108c
SS
2366{
2367 struct cleanup *old_chain;
2368 int i;
c5aa993b 2369
c906108c
SS
2370 if (!pst)
2371 return;
2372
2373 if (pst->readin)
2374 {
063e58ba
MD
2375 fprintf_unfiltered (gdb_stderr, "Psymtab for %s already read in. \
2376Shouldn't happen.\n",
c5aa993b 2377 pst->filename);
c906108c
SS
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);
c5aa993b 2393 wrap_here (""); /* Flush output */
c906108c
SS
2394 gdb_flush (gdb_stdout);
2395 }
2396 dbx_psymtab_to_symtab_1 (pst->dependencies[i]);
2397 }
2398
c5aa993b 2399 if (LDSYMLEN (pst)) /* Otherwise it's a dummy */
c906108c
SS
2400 {
2401 /* Init stuff necessary for reading in symbols */
2402 stabsread_init ();
2403 buildsym_init ();
a0b3c4fd 2404 old_chain = make_cleanup (really_free_pendings, 0);
c906108c
SS
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);
c906108c
SS
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
2421static void
fba45db2 2422dbx_psymtab_to_symtab (struct partial_symtab *pst)
c906108c
SS
2423{
2424 bfd *sym_bfd;
086df311 2425 struct cleanup *back_to = NULL;
c906108c
SS
2426
2427 if (!pst)
2428 return;
2429
2430 if (pst->readin)
2431 {
063e58ba
MD
2432 fprintf_unfiltered (gdb_stderr, "Psymtab for %s already read in. \
2433Shouldn't happen.\n",
c5aa993b 2434 pst->filename);
c906108c
SS
2435 return;
2436 }
2437
c5aa993b 2438 if (LDSYMLEN (pst) || pst->number_of_dependencies)
c906108c
SS
2439 {
2440 /* Print the message now, before reading the string table,
c5aa993b 2441 to avoid disconcerting pauses. */
c906108c
SS
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
086df311
DJ
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)
063e58ba
MD
2459 back_to = make_cleanup (free_current_contents,
2460 (void *) &stabs_data);
086df311
DJ
2461 }
2462
c906108c
SS
2463 dbx_psymtab_to_symtab_1 (pst);
2464
086df311
DJ
2465 if (back_to)
2466 do_cleanups (back_to);
2467
c906108c
SS
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. */
c5aa993b 2479
c906108c 2480static void
fba45db2 2481read_ofile_symtab (struct partial_symtab *pst)
c906108c 2482{
52f0bd74
AC
2483 char *namestring;
2484 struct external_nlist *bufp;
c906108c
SS
2485 struct internal_nlist nlist;
2486 unsigned char type;
2487 unsigned max_symnum;
52f0bd74 2488 bfd *abfd;
c906108c
SS
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;
c5aa993b
JM
2497 sym_offset = LDSYMOFF (pst);
2498 sym_size = LDSYMLEN (pst);
5afc051b
JB
2499 text_offset = pst->textlow;
2500 text_size = pst->texthigh - pst->textlow;
b8fbeb18
EZ
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. */
c906108c
SS
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;
086df311
DJ
2516 symbuf_read = 0;
2517 symbuf_left = sym_offset + sym_size;
c906108c
SS
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. */
c5aa993b 2525 if (!processing_acc_compilation && sym_offset >= (int) symbol_size)
c906108c 2526 {
086df311 2527 stabs_seek (sym_offset - symbol_size);
c906108c
SS
2528 fill_symbuf (abfd);
2529 bufp = &symbuf[symbuf_idx++];
2530 INTERNALIZE_SYMBOL (nlist, bufp, abfd);
2531 OBJSTAT (objfile, n_stabs++);
2532
83b94be5 2533 namestring = set_namestring (objfile, &nlist);
c906108c
SS
2534
2535 processing_gcc_compilation = 0;
2536 if (nlist.n_type == N_TEXT)
2537 {
2538 const char *tempstring = namestring;
2539
91f54576 2540 if (strcmp (namestring, GCC_COMPILED_FLAG_SYMBOL) == 0)
c906108c 2541 processing_gcc_compilation = 1;
91f54576 2542 else if (strcmp (namestring, GCC2_COMPILED_FLAG_SYMBOL) == 0)
c906108c
SS
2543 processing_gcc_compilation = 2;
2544 if (tempstring[0] == bfd_get_symbol_leading_char (symfile_bfd))
2545 ++tempstring;
91f54576 2546 if (strncmp (tempstring, "__gnu_compiled", 14) == 0)
c906108c
SS
2547 processing_gcc_compilation = 2;
2548 }
2549
2550 /* Try to select a C++ demangling based on the compilation unit
c5aa993b 2551 producer. */
c906108c 2552
8052a17a
JM
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. */
c906108c
SS
2556 if (processing_gcc_compilation)
2557 {
2558 if (AUTO_DEMANGLING)
2559 {
2560 set_demangling_style (GNU_DEMANGLING_STYLE_STRING);
2561 }
2562 }
8052a17a 2563#endif
c906108c
SS
2564 }
2565 else
2566 {
2567 /* The N_SO starting this symtab is the first symbol, so we
c5aa993b
JM
2568 better not check the symbol before it. I'm not this can
2569 happen, but it doesn't hurt to check for it. */
086df311 2570 stabs_seek (sym_offset);
c906108c
SS
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)
8a3fe4f8 2578 error (_("First symbol in segment of executable not a source symbol"));
c906108c
SS
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)
c5aa993b 2588 fill_symbuf (abfd);
c906108c
SS
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
83b94be5 2595 namestring = set_namestring (objfile, &nlist);
c906108c 2596
c5aa993b
JM
2597 if (type & N_STAB)
2598 {
c906108c
SS
2599 process_one_symbol (type, nlist.n_desc, nlist.n_value,
2600 namestring, section_offsets, objfile);
c5aa993b 2601 }
c906108c
SS
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
91f54576 2612 if (strcmp (namestring, GCC_COMPILED_FLAG_SYMBOL) == 0)
c906108c 2613 processing_gcc_compilation = 1;
91f54576 2614 else if (strcmp (namestring, GCC2_COMPILED_FLAG_SYMBOL) == 0)
c906108c
SS
2615 processing_gcc_compilation = 2;
2616
8052a17a
JM
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. */
c906108c
SS
2620 if (AUTO_DEMANGLING)
2621 {
2622 set_demangling_style (GNU_DEMANGLING_STYLE_STRING);
2623 }
8052a17a 2624#endif
c906108c 2625 }
c5aa993b
JM
2626 else if (type & N_EXT || type == (unsigned char) N_TEXT
2627 || type == (unsigned char) N_NBTEXT
2628 )
2629 {
c906108c
SS
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 ;
c5aa993b 2640 }
c906108c
SS
2641 }
2642
c906108c
SS
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,
5afc051b 2645 which comes from pst->textlow is correct. */
c906108c
SS
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
5afc051b 2651 from pst->textlow which is correct. */
c906108c
SS
2652 if (last_source_start_addr > text_offset)
2653 last_source_start_addr = text_offset;
2654
063e58ba
MD
2655 pst->symtab = end_symtab (text_offset + text_size, objfile,
2656 SECT_OFF_TEXT (objfile));
c906108c 2657
c906108c 2658 end_stabs ();
e9112110
PA
2659
2660 current_objfile = NULL;
c906108c 2661}
c906108c 2662\f
c5aa993b 2663
c906108c
SS
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.
e31272c3
MK
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. */
c906108c
SS
2678
2679void
fba45db2
KB
2680process_one_symbol (int type, int desc, CORE_ADDR valu, char *name,
2681 struct section_offsets *section_offsets,
2682 struct objfile *objfile)
c906108c 2683{
5e2b427d 2684 struct gdbarch *gdbarch = get_objfile_arch (objfile);
52f0bd74 2685 struct context_stack *new;
e31272c3
MK
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. */
c906108c
SS
2692 static CORE_ADDR function_start_offset;
2693
e31272c3
MK
2694 /* This holds the address of the start of a function, without the
2695 system peculiarities of function_start_offset. */
a1b9830c
DJ
2696 static CORE_ADDR last_function_start;
2697
54c7009d
EZ
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. */
a1b9830c
DJ
2702 static int sline_found_in_function = 1;
2703
e31272c3
MK
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. */
c906108c
SS
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)
e31272c3
MK
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 }
c906108c 2719
e31272c3
MK
2720 /* Something is wrong if we see real data before seeing a source
2721 file name. */
c906108c 2722
c5aa993b 2723 if (last_source_file == NULL && type != (unsigned char) N_SO)
c906108c
SS
2724 {
2725 /* Ignore any symbols which appear before an N_SO symbol.
c5aa993b
JM
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 (). */
c906108c
SS
2729 return;
2730 }
2731
2732 switch (type)
2733 {
2734 case N_FUN:
2735 case N_FNAME:
2736
2737 if (*name == '\000')
2738 {
e31272c3
MK
2739 /* This N_FUN marks the end of a function. This closes off
2740 the current block. */
0c5e171a
KD
2741
2742 if (context_stack_depth <= 0)
2743 {
23136709 2744 lbrac_mismatch_complaint (symnum);
0c5e171a
KD
2745 break;
2746 }
2747
6b37567a
JJ
2748 /* The following check is added before recording line 0 at
2749 end of function so as to handle hand-generated stabs
e31272c3
MK
2750 which may have an N_FUN stabs at the end of the function,
2751 but no N_SLINE stabs. */
6b37567a
JJ
2752 if (sline_found_in_function)
2753 record_line (current_subfile, 0, last_function_start + valu);
2754
c906108c
SS
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
a1b9830c
DJ
2771 sline_found_in_function = 0;
2772
e31272c3 2773 /* Relocate for dynamic loading. */
b8fbeb18 2774 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
5e2b427d 2775 valu = gdbarch_smash_text_address (gdbarch, valu);
a1b9830c
DJ
2776 last_function_start = valu;
2777
c906108c
SS
2778 goto define_a_symbol;
2779
2780 case N_LBRAC:
2781 /* This "symbol" just indicates the start of an inner lexical
c5aa993b 2782 context within a function. */
c906108c
SS
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
c906108c
SS
2796 new = push_context (desc, valu);
2797 break;
2798
2799 case N_RBRAC:
2800 /* This "symbol" just indicates the end of an inner lexical
c5aa993b 2801 context that was started with N_LBRAC. */
c906108c
SS
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
0c5e171a
KD
2815 if (context_stack_depth <= 0)
2816 {
23136709 2817 lbrac_mismatch_complaint (symnum);
0c5e171a
KD
2818 break;
2819 }
2820
c5aa993b 2821 new = pop_context ();
c906108c 2822 if (desc != new->depth)
23136709 2823 lbrac_mismatch_complaint (symnum);
c906108c 2824
35156bae 2825 if (local_symbols != NULL)
1f077a3e 2826 {
35156bae
DJ
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, _("\
e31272c3 2832misplaced N_LBRAC entry; discarding local symbols which have \
e2e0b3e5 2833no enclosing block"));
1f077a3e 2834 }
35156bae 2835 local_symbols = new->locals;
c906108c 2836
35156bae 2837 if (context_stack_depth > 1)
c906108c 2838 {
e31272c3
MK
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). */
c906108c
SS
2845 if (local_symbols != NULL)
2846 {
e31272c3
MK
2847 /* Muzzle a compiler bug that makes end < start.
2848
2849 ??? Which compilers? Is this ever harmful?. */
c906108c
SS
2850 if (new->start_addr > valu)
2851 {
23136709 2852 complaint (&symfile_complaints,
e2e0b3e5 2853 _("block start larger than block end"));
c906108c
SS
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
c906108c
SS
2870 break;
2871
2872 case N_FN:
2873 case N_FN_SEQ:
e31272c3
MK
2874 /* This kind of symbol indicates the start of an object file.
2875 Relocate for dynamic loading. */
b8fbeb18 2876 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
c906108c
SS
2877 break;
2878
2879 case N_SO:
e31272c3
MK
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. */
b8fbeb18 2884 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
c906108c
SS
2885
2886 n_opt_found = 0;
2887
c906108c
SS
2888 if (last_source_file)
2889 {
2890 /* Check if previous symbol was also an N_SO (with some
e31272c3
MK
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. */
c906108c
SS
2894 if (previous_stab_code == (unsigned char) N_SO)
2895 {
2896 patch_subfile_names (current_subfile, name);
2897 break; /* Ignore repeated SOs */
2898 }
b8fbeb18 2899 end_symtab (valu, objfile, SECT_OFF_TEXT (objfile));
c906108c
SS
2900 end_stabs ();
2901 }
2902
e31272c3
MK
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. */
c906108c
SS
2905 if (*name == '\000')
2906 break;
2907
2908 if (block_address_function_relative)
c5aa993b 2909 function_start_offset = 0;
c906108c
SS
2910
2911 start_stabs ();
2912 start_symtab (name, NULL, valu);
2913 record_debugformat ("stabs");
2914 break;
2915
2916 case N_SOL:
e31272c3
MK
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. */
b8fbeb18 2921 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
c906108c
SS
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:
e31272c3
MK
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. */
c906108c 2943
e31272c3
MK
2944 /* Relocate for dynamic loading and for ELF acc
2945 function-relative symbols. */
c906108c
SS
2946 valu += function_start_offset;
2947
ceddaf06
MK
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
a1b9830c
DJ
2962 if (within_function && sline_found_in_function == 0)
2963 {
ceddaf06
MK
2964 if (processing_gcc_compilation == 2)
2965 record_line (current_subfile, desc, last_function_start);
2966 else
2967 record_line (current_subfile, desc, valu);
a1b9830c
DJ
2968 sline_found_in_function = 1;
2969 }
2970 else
2971 record_line (current_subfile, desc, valu);
c906108c
SS
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
e31272c3
MK
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. */
c906108c 2985
e31272c3
MK
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. */
c5aa993b 2989 /* HORRID HACK DEPT. However, it's Sun's furgin' fault.
e31272c3
MK
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). */
c906108c
SS
2999 {
3000 char *p;
3001
e31272c3
MK
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. */
c906108c
SS
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
e31272c3
MK
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
c906108c 3020 symbol), we can get addr from the text offset. If
e31272c3
MK
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. */
b8fbeb18 3024 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
c906108c
SS
3025 goto define_a_symbol;
3026 }
3027 }
e31272c3
MK
3028 /* Since it's not the kludge case, re-dispatch to the right
3029 handler. */
c5aa993b
JM
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:
e31272c3 3039 internal_error (__FILE__, __LINE__,
e2e0b3e5 3040 _("failed internal consistency check"));
c5aa993b 3041 }
c906108c
SS
3042 }
3043
e31272c3
MK
3044 case_N_STSYM: /* Static symbol in data segment. */
3045 case N_DSLINE: /* Source line number, data segment. */
b8fbeb18 3046 valu += ANOFFSET (section_offsets, SECT_OFF_DATA (objfile));
c906108c
SS
3047 goto define_a_symbol;
3048
e31272c3
MK
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. */
b8fbeb18 3052 valu += ANOFFSET (section_offsets, SECT_OFF_BSS (objfile));
c906108c
SS
3053 goto define_a_symbol;
3054
e31272c3 3055 case_N_ROSYM: /* Static symbol in read-only data segment. */
b8fbeb18 3056 valu += ANOFFSET (section_offsets, SECT_OFF_RODATA (objfile));
c906108c
SS
3057 goto define_a_symbol;
3058
e31272c3
MK
3059 case N_ENTRY: /* Alternate entry point. */
3060 /* Relocate for dynamic loading. */
b8fbeb18 3061 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT (objfile));
c906108c
SS
3062 goto define_a_symbol;
3063
e31272c3
MK
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. */
c906108c 3067 default:
e31272c3
MK
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??? */
c906108c
SS
3076 case N_NBDATA:
3077 case N_NBBSS:
3078 case N_NBSTS:
3079 case N_NBLCS:
bb599908 3080 unknown_symtype_complaint (hex_string (type));
c906108c
SS
3081 /* FALLTHROUGH */
3082
e31272c3
MK
3083 /* The following symbol types don't need the address field
3084 relocated, since it is either unused, or is absolute. */
c906108c 3085 define_a_symbol:
e31272c3
MK
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. */
c906108c
SS
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
e31272c3
MK
3110 /* Deal with the SunPRO 3.0 compiler which omits the
3111 address from N_FUN symbols. */
c906108c 3112 if (type == N_FUN
e31272c3 3113 && valu == ANOFFSET (section_offsets,
203c3895 3114 SECT_OFF_TEXT (objfile))
5e2b427d 3115 && gdbarch_sofun_address_maybe_missing (gdbarch))
9a058a09
KB
3116 {
3117 CORE_ADDR minsym_valu =
3118 find_stab_function_addr (name, last_source_file, objfile);
3119
e31272c3
MK
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... */
9a058a09
KB
3126 if (minsym_valu != 0)
3127 valu = minsym_valu;
3128 }
c906108c 3129
c906108c 3130 if (block_address_function_relative)
e31272c3 3131 /* For Solaris 2 compilers, the block addresses and
c906108c 3132 N_SLINE's are relative to the start of the
e31272c3
MK
3133 function. On normal systems, and when using GCC on
3134 Solaris 2, these addresses are just absolute, or
c906108c
SS
3135 relative to the N_SO, depending on
3136 BLOCK_ADDRESS_ABSOLUTE. */
c5aa993b 3137 function_start_offset = valu;
c906108c
SS
3138
3139 within_function = 1;
c3f6f71d
JM
3140
3141 if (context_stack_depth > 1)
3142 {
23136709 3143 complaint (&symfile_complaints,
063e58ba
MD
3144 _("unmatched N_LBRAC before symtab pos %d"),
3145 symnum);
c3f6f71d
JM
3146 break;
3147 }
3148
c906108c
SS
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 }
c906108c
SS
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
c5aa993b
JM
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. */
e31272c3 3171 case N_OPT: /* Solaris 2: Compiler options. */
c906108c
SS
3172 if (name)
3173 {
6314a349 3174 if (strcmp (name, GCC2_COMPILED_FLAG_SYMBOL) == 0)
c906108c
SS
3175 {
3176 processing_gcc_compilation = 2;
8052a17a 3177#if 0 /* Works, but is experimental. -fnf */
e31272c3
MK
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. */
c906108c
SS
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
51cc5b07
AC
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
c5aa993b 3205 /* The following symbol types can be ignored. */
e31272c3
MK
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. */
c906108c
SS
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
c5aa993b 3220 symbol. */
c906108c
SS
3221 if (name[0] == '#')
3222 {
e31272c3
MK
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. */
c906108c
SS
3226
3227 char *s = name;
3228 int refnum;
3229
3230 /* If this stab defines a new reference ID that is not on the
c5aa993b 3231 reference list, then put it on the reference list.
c906108c 3232
c5aa993b
JM
3233 We go ahead and advance NAME past the reference, even though
3234 it is not strictly necessary at this time. */
c906108c
SS
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
c906108c
SS
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
3270void
fba45db2
KB
3271coffstab_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)
c906108c
SS
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. */
0a6ddd08 3284 info = objfile->deprecated_sym_stab_info;
c906108c
SS
3285
3286 DBX_TEXT_ADDR (objfile) = textaddr;
3287 DBX_TEXT_SIZE (objfile) = textsize;
3288
3289#define COFF_STABS_SYMBOL_SIZE 12 /* XXX FIXME XXX */
c5aa993b 3290 DBX_SYMBOL_SIZE (objfile) = COFF_STABS_SYMBOL_SIZE;
c906108c 3291 DBX_STRINGTAB_SIZE (objfile) = stabstrsize;
c5aa993b 3292
c906108c 3293 if (stabstrsize > bfd_get_size (sym_bfd))
8a3fe4f8 3294 error (_("ridiculous string table size: %d bytes"), stabstrsize);
c906108c 3295 DBX_STRINGTAB (objfile) = (char *)
8b92e4d5 3296 obstack_alloc (&objfile->objfile_obstack, stabstrsize + 1);
c5aa993b 3297 OBJSTAT (objfile, sz_strtab += stabstrsize + 1);
c906108c
SS
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);
3a42e9d0 3304 val = bfd_bread (DBX_STRINGTAB (objfile), stabstrsize, sym_bfd);
c906108c
SS
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
96baa820 3342 dbx_symfile_read (objfile, 0);
c906108c
SS
3343}
3344\f
3345/* Scan and build partial symbols for an ELF symbol file.
fea25152 3346 This ELF file has already been processed to get its minimal symbols.
c906108c
SS
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).
086df311 3356 STABSECT is the BFD section information for the .stab section.
c906108c
SS
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
3363void
fba45db2 3364elfstab_build_psymtabs (struct objfile *objfile, int mainline,
086df311 3365 asection *stabsect,
fba45db2 3366 file_ptr stabstroffset, unsigned int stabstrsize)
c906108c
SS
3367{
3368 int val;
3369 bfd *sym_bfd = objfile->obfd;
3370 char *name = bfd_get_filename (sym_bfd);
3371 struct dbx_symfile_info *info;
086df311 3372 struct cleanup *back_to = NULL;
c906108c
SS
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. */
0a6ddd08 3376 info = objfile->deprecated_sym_stab_info;
c906108c 3377
7a292a7a
SS
3378 /* Find the first and last text address. dbx_symfile_read seems to
3379 want this. */
3380 find_text_range (sym_bfd, objfile);
c906108c
SS
3381
3382#define ELF_STABS_SYMBOL_SIZE 12 /* XXX FIXME XXX */
c5aa993b 3383 DBX_SYMBOL_SIZE (objfile) = ELF_STABS_SYMBOL_SIZE;
086df311
DJ
3384 DBX_SYMCOUNT (objfile)
3385 = bfd_section_size (objfile->obfd, stabsect) / DBX_SYMBOL_SIZE (objfile);
c906108c 3386 DBX_STRINGTAB_SIZE (objfile) = stabstrsize;
086df311
DJ
3387 DBX_SYMTAB_OFFSET (objfile) = stabsect->filepos;
3388 DBX_STAB_SECTION (objfile) = stabsect;
c5aa993b 3389
c906108c 3390 if (stabstrsize > bfd_get_size (sym_bfd))
8a3fe4f8 3391 error (_("ridiculous string table size: %d bytes"), stabstrsize);
c906108c 3392 DBX_STRINGTAB (objfile) = (char *)
8b92e4d5 3393 obstack_alloc (&objfile->objfile_obstack, stabstrsize + 1);
c5aa993b 3394 OBJSTAT (objfile, sz_strtab += stabstrsize + 1);
c906108c
SS
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);
3a42e9d0 3401 val = bfd_bread (DBX_STRINGTAB (objfile), stabstrsize, sym_bfd);
c906108c
SS
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 ();
c906108c
SS
3409
3410 processing_acc_compilation = 1;
3411
086df311
DJ
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
c906108c
SS
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
7134143f
DJ
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. */
96baa820 3424 dbx_symfile_read (objfile, 0);
086df311
DJ
3425
3426 if (back_to)
3427 do_cleanups (back_to);
c906108c
SS
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
c5aa993b 3439 of the text segment).
c906108c 3440 MAINLINE is true if we are reading the main symbol table (as opposed to a
c5aa993b 3441 shared lib or dynamically loaded file).
c906108c
SS
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
3447void
fba45db2
KB
3448stabsect_build_psymtabs (struct objfile *objfile, int mainline, char *stab_name,
3449 char *stabstr_name, char *text_name)
c906108c
SS
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)
063e58ba
MD
3465 error (_("stabsect_build_psymtabs: Found stabs (%s), but not string \
3466section (%s)"),
c906108c
SS
3467 stab_name, stabstr_name);
3468
0a6ddd08 3469 objfile->deprecated_sym_stab_info = (struct dbx_symfile_info *)
c906108c 3470 xmalloc (sizeof (struct dbx_symfile_info));
063e58ba
MD
3471 memset (objfile->deprecated_sym_stab_info, 0,
3472 sizeof (struct dbx_symfile_info));
c906108c
SS
3473
3474 text_sect = bfd_get_section_by_name (sym_bfd, text_name);
3475 if (!text_sect)
8a3fe4f8 3476 error (_("Can't find %s section in symbol file"), text_name);
c906108c
SS
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
c5aa993b
JM
3480 DBX_SYMBOL_SIZE (objfile) = sizeof (struct external_nlist);
3481 DBX_SYMCOUNT (objfile) = bfd_section_size (sym_bfd, stabsect)
c906108c
SS
3482 / DBX_SYMBOL_SIZE (objfile);
3483 DBX_STRINGTAB_SIZE (objfile) = bfd_section_size (sym_bfd, stabstrsect);
c5aa993b
JM
3484 DBX_SYMTAB_OFFSET (objfile) = stabsect->filepos; /* XXX - FIXME: POKING INSIDE BFD DATA STRUCTURES */
3485
c906108c 3486 if (DBX_STRINGTAB_SIZE (objfile) > bfd_get_size (sym_bfd))
063e58ba
MD
3487 error (_("ridiculous string table size: %d bytes"),
3488 DBX_STRINGTAB_SIZE (objfile));
c906108c 3489 DBX_STRINGTAB (objfile) = (char *)
8b92e4d5 3490 obstack_alloc (&objfile->objfile_obstack, DBX_STRINGTAB_SIZE (objfile) + 1);
c906108c
SS
3491 OBJSTAT (objfile, sz_strtab += DBX_STRINGTAB_SIZE (objfile) + 1);
3492
3493 /* Now read in the string table in one big gulp. */
3494
c5aa993b
JM
3495 val = bfd_get_section_contents (sym_bfd, /* bfd */
3496 stabstrsect, /* bfd section */
063e58ba 3497 DBX_STRINGTAB (objfile), /* input buffer */
c5aa993b 3498 0, /* offset into section */
063e58ba 3499 DBX_STRINGTAB_SIZE (objfile)); /* amount to read */
c906108c
SS
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 ();
c906108c
SS
3508
3509 /* Now, do an incremental load */
3510
3511 processing_acc_compilation = 1;
96baa820 3512 dbx_symfile_read (objfile, 0);
c906108c
SS
3513}
3514\f
3515static struct sym_fns aout_sym_fns =
3516{
3517 bfd_target_aout_flavour,
063e58ba
MD
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() */
c5aa993b
JM
3520 dbx_symfile_read, /* sym_read: read a symbol file into symtab */
3521 dbx_symfile_finish, /* sym_finish: finished with file, cleanup */
063e58ba
MD
3522 default_symfile_offsets, /* sym_offsets: parse user's offsets to
3523 internal form */
31d99776
DJ
3524 default_symfile_segments, /* sym_segments: Get segment information from
3525 a file. */
c295b2e5 3526 NULL, /* sym_read_linetable */
c5aa993b 3527 NULL /* next: pointer to next struct sym_fns */
c906108c
SS
3528};
3529
3530void
fba45db2 3531_initialize_dbxread (void)
c906108c 3532{
c5aa993b 3533 add_symtab_fns (&aout_sym_fns);
c906108c 3534}
This page took 0.787545 seconds and 4 git commands to generate.