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