Add support for the readnever concept
[deliverable/binutils-gdb.git] / gdb / xcoffread.c
CommitLineData
c906108c 1/* Read AIX xcoff symbol tables and convert to internal format, for GDB.
61baf725 2 Copyright (C) 1986-2017 Free Software Foundation, Inc.
c906108c
SS
3 Derived from coffread.c, dbxread.c, and a lot of hacking.
4 Contributed by IBM Corporation.
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#include "defs.h"
22#include "bfd.h"
23
24#include <sys/types.h>
25#include <fcntl.h>
26#include <ctype.h>
c0ccb908 27#ifdef HAVE_SYS_FILE_H
c906108c
SS
28#include <sys/file.h>
29#endif
53ce3c39 30#include <sys/stat.h>
c906108c
SS
31
32#include "coff/internal.h"
33#include "libcoff.h" /* FIXME, internal data from BFD */
11ed25ac
KB
34#include "coff/xcoff.h"
35#include "libxcoff.h"
c906108c 36#include "coff/rs6000.h"
63807e1d 37#include "xcoffread.h"
c906108c
SS
38
39#include "symtab.h"
40#include "gdbtypes.h"
9ab9195f 41/* FIXME: ezannoni/2004-02-13 Verify if the include below is really needed. */
c906108c
SS
42#include "symfile.h"
43#include "objfiles.h"
44#include "buildsym.h"
45#include "stabsread.h"
46#include "expression.h"
c906108c 47#include "complaints.h"
ccefe4c4 48#include "psympriv.h"
c906108c
SS
49
50#include "gdb-stabs.h"
51
52/* For interface with stabsread.c. */
53#include "aout/stab_gnu.h"
54
c906108c 55\f
b8b98ad1
TT
56/* Key for XCOFF-associated data. */
57
58static const struct objfile_data *xcoff_objfile_data_key;
59
c906108c
SS
60/* We put a pointer to this structure in the read_symtab_private field
61 of the psymtab. */
62
c5aa993b
JM
63struct symloc
64 {
c906108c 65
c5aa993b 66 /* First symbol number for this file. */
c906108c 67
c5aa993b 68 int first_symnum;
c906108c 69
c5aa993b
JM
70 /* Number of symbols in the section of the symbol table devoted to
71 this file's symbols (actually, the section bracketed may contain
72 more than just this file's symbols). If numsyms is 0, the only
73 reason for this thing's existence is the dependency list. Nothing
74 else will happen when it is read in. */
c906108c 75
c5aa993b 76 int numsyms;
c906108c 77
3e43a32a
MS
78 /* Position of the start of the line number information for this
79 psymtab. */
c5aa993b
JM
80 unsigned int lineno_off;
81 };
c906108c 82
581e13c1 83/* Remember what we deduced to be the source language of this psymtab. */
c906108c
SS
84
85static enum language psymtab_language = language_unknown;
c906108c 86\f
c5aa993b 87
581e13c1 88/* Simplified internal version of coff symbol table information. */
c906108c 89
c5aa993b
JM
90struct coff_symbol
91 {
92 char *c_name;
581e13c1
MS
93 int c_symnum; /* Symbol number of this entry. */
94 int c_naux; /* 0 if syment only, 1 if syment + auxent. */
086850b2 95 CORE_ADDR c_value;
c5aa993b
JM
96 unsigned char c_sclass;
97 int c_secnum;
98 unsigned int c_type;
99 };
c906108c 100
581e13c1 101/* Last function's saved coff symbol `cs'. */
c906108c
SS
102
103static struct coff_symbol fcn_cs_saved;
104
105static bfd *symfile_bfd;
106
107/* Core address of start and end of text of current source file.
108 This is calculated from the first function seen after a C_FILE
581e13c1 109 symbol. */
c906108c
SS
110
111
112static CORE_ADDR cur_src_end_addr;
113
114/* Core address of the end of the first object file. */
115
116static CORE_ADDR first_object_file_end;
117
581e13c1 118/* Initial symbol-table-debug-string vector length. */
c906108c
SS
119
120#define INITIAL_STABVECTOR_LENGTH 40
121
c906108c
SS
122/* Size of a COFF symbol. I think it is always 18, so I'm not sure
123 there is any reason not to just use a #define, but might as well
124 ask BFD for the size and store it here, I guess. */
125
c5aa993b 126static unsigned local_symesz;
c906108c 127
c5aa993b
JM
128struct coff_symfile_info
129 {
581e13c1
MS
130 file_ptr min_lineno_offset; /* Where in file lowest line#s are. */
131 file_ptr max_lineno_offset; /* 1+last byte of line#s in file. */
c906108c 132
c5aa993b
JM
133 /* Pointer to the string table. */
134 char *strtbl;
c906108c 135
c5aa993b
JM
136 /* Pointer to debug section. */
137 char *debugsec;
c906108c 138
c5aa993b
JM
139 /* Pointer to the a.out symbol table. */
140 char *symtbl;
c906108c 141
c5aa993b
JM
142 /* Number of symbols in symtbl. */
143 int symtbl_num_syms;
c906108c 144
c5aa993b
JM
145 /* Offset in data section to TOC anchor. */
146 CORE_ADDR toc_offset;
147 };
c906108c 148
b8b98ad1
TT
149/* Convenience macro to access the per-objfile XCOFF data. */
150
151#define XCOFF_DATA(objfile) \
152 ((struct coff_symfile_info *) objfile_data ((objfile), \
153 xcoff_objfile_data_key))
154
316a8b21
TG
155/* XCOFF names for dwarf sections. There is no compressed sections. */
156
157static const struct dwarf2_debug_sections dwarf2_xcoff_names = {
158 { ".dwinfo", NULL },
159 { ".dwabrev", NULL },
160 { ".dwline", NULL },
161 { ".dwloc", NULL },
43988095 162 { NULL, NULL }, /* debug_loclists */
33f914a1
DE
163 /* AIX XCOFF defines one, named DWARF section for macro debug information.
164 XLC does not generate debug_macinfo for DWARF4 and below.
165 The section is assigned to debug_macro for DWARF5 and above. */
166 { NULL, NULL },
167 { ".dwmac", NULL },
316a8b21 168 { ".dwstr", NULL },
43988095 169 { NULL, NULL }, /* debug_line_str */
316a8b21 170 { ".dwrnges", NULL },
43988095 171 { NULL, NULL }, /* debug_rnglists */
33f914a1 172 { ".dwpbtyp", NULL },
3019eac3 173 { NULL, NULL }, /* debug_addr */
316a8b21
TG
174 { ".dwframe", NULL },
175 { NULL, NULL }, /* eh_frame */
24d3216f
TT
176 { NULL, NULL }, /* gdb_index */
177 23
316a8b21
TG
178};
179
23136709
KB
180static void
181bf_notfound_complaint (void)
182{
3e43a32a
MS
183 complaint (&symfile_complaints,
184 _("line numbers off, `.bf' symbol not found"));
23136709 185}
c906108c 186
23136709
KB
187static void
188ef_complaint (int arg1)
189{
190 complaint (&symfile_complaints,
e2e0b3e5 191 _("Mismatched .ef symbol ignored starting at symnum %d"), arg1);
23136709 192}
c906108c 193
23136709
KB
194static void
195eb_complaint (int arg1)
196{
197 complaint (&symfile_complaints,
e2e0b3e5 198 _("Mismatched .eb symbol ignored starting at symnum %d"), arg1);
23136709 199}
c906108c 200
b15cc25c 201static void xcoff_initial_scan (struct objfile *, symfile_add_flags);
c906108c 202
8dddcb8f
TT
203static void scan_xcoff_symtab (minimal_symbol_reader &,
204 struct objfile *);
c906108c 205
a121b7c1 206static const char *xcoff_next_symbol_text (struct objfile *);
c906108c 207
a14ed312 208static void record_include_begin (struct coff_symbol *);
c906108c
SS
209
210static void
a14ed312
KB
211enter_line_range (struct subfile *, unsigned, unsigned,
212 CORE_ADDR, CORE_ADDR, unsigned *);
c906108c 213
a14ed312 214static void init_stringtab (bfd *, file_ptr, struct objfile *);
c906108c 215
a14ed312 216static void xcoff_symfile_init (struct objfile *);
c906108c 217
a14ed312 218static void xcoff_new_init (struct objfile *);
c906108c 219
a14ed312 220static void xcoff_symfile_finish (struct objfile *);
c906108c 221
a14ed312 222static char *coff_getfilename (union internal_auxent *, struct objfile *);
c906108c 223
a14ed312 224static void read_symbol (struct internal_syment *, int);
c906108c 225
a14ed312 226static int read_symbol_lineno (int);
c906108c 227
470d5666 228static CORE_ADDR read_symbol_nvalue (int);
c906108c 229
a14ed312
KB
230static struct symbol *process_xcoff_symbol (struct coff_symbol *,
231 struct objfile *);
c906108c 232
5c80ed9d 233static void read_xcoff_symtab (struct objfile *, struct partial_symtab *);
c906108c
SS
234
235#if 0
a14ed312 236static void add_stab_to_list (char *, struct pending_stabs **);
c906108c
SS
237#endif
238
a14ed312 239static int compare_lte (const void *, const void *);
c906108c 240
a14ed312 241static struct linetable *arrange_linetable (struct linetable *);
c906108c 242
a14ed312 243static void record_include_end (struct coff_symbol *);
c906108c 244
a14ed312 245static void process_linenos (CORE_ADDR, CORE_ADDR);
c906108c 246\f
c5aa993b 247
c906108c
SS
248/* Translate from a COFF section number (target_index) to a SECT_OFF_*
249 code. */
a14ed312
KB
250static int secnum_to_section (int, struct objfile *);
251static asection *secnum_to_bfd_section (int, struct objfile *);
c906108c 252
c5aa993b
JM
253struct find_targ_sec_arg
254 {
255 int targ_index;
256 int *resultp;
257 asection **bfd_sect;
b8fbeb18 258 struct objfile *objfile;
c5aa993b 259 };
c906108c 260
a14ed312 261static void find_targ_sec (bfd *, asection *, void *);
c906108c 262
c5aa993b 263static void
4efb68b1 264find_targ_sec (bfd *abfd, asection *sect, void *obj)
c906108c 265{
c5aa993b 266 struct find_targ_sec_arg *args = (struct find_targ_sec_arg *) obj;
b8fbeb18 267 struct objfile *objfile = args->objfile;
a109c7c1 268
c906108c
SS
269 if (sect->target_index == args->targ_index)
270 {
271 /* This is the section. Figure out what SECT_OFF_* code it is. */
272 if (bfd_get_section_flags (abfd, sect) & SEC_CODE)
b8fbeb18 273 *args->resultp = SECT_OFF_TEXT (objfile);
c906108c 274 else if (bfd_get_section_flags (abfd, sect) & SEC_LOAD)
b8fbeb18 275 *args->resultp = SECT_OFF_DATA (objfile);
c906108c 276 else
65cf3563 277 *args->resultp = gdb_bfd_section_index (abfd, sect);
c906108c
SS
278 *args->bfd_sect = sect;
279 }
280}
281
ec92004f
JB
282/* Search all BFD sections for the section whose target_index is
283 equal to N_SCNUM. Set *BFD_SECT to that section. The section's
284 associated index in the objfile's section_offset table is also
285 stored in *SECNUM.
286
287 If no match is found, *BFD_SECT is set to NULL, and *SECNUM
288 is set to the text section's number. */
a109c7c1 289
ec92004f
JB
290static void
291xcoff_secnum_to_sections (int n_scnum, struct objfile *objfile,
292 asection **bfd_sect, int *secnum)
293{
c906108c 294 struct find_targ_sec_arg args;
ec92004f
JB
295
296 args.targ_index = n_scnum;
297 args.resultp = secnum;
298 args.bfd_sect = bfd_sect;
b8fbeb18 299 args.objfile = objfile;
ec92004f
JB
300
301 *bfd_sect = NULL;
302 *secnum = SECT_OFF_TEXT (objfile);
303
c906108c 304 bfd_map_over_sections (objfile->obfd, find_targ_sec, &args);
c906108c
SS
305}
306
ec92004f
JB
307/* Return the section number (SECT_OFF_*) that N_SCNUM points to. */
308
309static int
310secnum_to_section (int n_scnum, struct objfile *objfile)
311{
312 int secnum;
313 asection *ignored;
314
315 xcoff_secnum_to_sections (n_scnum, objfile, &ignored, &secnum);
316 return secnum;
317}
318
319/* Return the BFD section that N_SCNUM points to. */
320
c906108c 321static asection *
ec92004f 322secnum_to_bfd_section (int n_scnum, struct objfile *objfile)
c906108c 323{
ec92004f
JB
324 int ignored;
325 asection *bfd_sect;
a109c7c1 326
ec92004f
JB
327 xcoff_secnum_to_sections (n_scnum, objfile, &bfd_sect, &ignored);
328 return bfd_sect;
c906108c
SS
329}
330\f
581e13c1 331/* add a given stab string into given stab vector. */
c906108c
SS
332
333#if 0
334
335static void
fba45db2 336add_stab_to_list (char *stabname, struct pending_stabs **stabvector)
c906108c 337{
c5aa993b
JM
338 if (*stabvector == NULL)
339 {
340 *stabvector = (struct pending_stabs *)
341 xmalloc (sizeof (struct pending_stabs) +
342 INITIAL_STABVECTOR_LENGTH * sizeof (char *));
343 (*stabvector)->count = 0;
344 (*stabvector)->length = INITIAL_STABVECTOR_LENGTH;
345 }
346 else if ((*stabvector)->count >= (*stabvector)->length)
347 {
348 (*stabvector)->length += INITIAL_STABVECTOR_LENGTH;
349 *stabvector = (struct pending_stabs *)
350 xrealloc ((char *) *stabvector, sizeof (struct pending_stabs) +
3e43a32a 351 (*stabvector)->length * sizeof (char *));
c5aa993b
JM
352 }
353 (*stabvector)->stab[(*stabvector)->count++] = stabname;
c906108c
SS
354}
355
356#endif
c5aa993b 357\f/* *INDENT-OFF* */
c906108c
SS
358/* Linenos are processed on a file-by-file basis.
359
360 Two reasons:
361
c5aa993b 362 1) xlc (IBM's native c compiler) postpones static function code
581e13c1 363 emission to the end of a compilation unit. This way it can
c5aa993b 364 determine if those functions (statics) are needed or not, and
581e13c1 365 can do some garbage collection (I think). This makes line
c5aa993b
JM
366 numbers and corresponding addresses unordered, and we end up
367 with a line table like:
368
369
370 lineno addr
371 foo() 10 0x100
372 20 0x200
373 30 0x300
374
375 foo3() 70 0x400
376 80 0x500
377 90 0x600
378
379 static foo2()
380 40 0x700
381 50 0x800
382 60 0x900
383
384 and that breaks gdb's binary search on line numbers, if the
581e13c1 385 above table is not sorted on line numbers. And that sort
c5aa993b
JM
386 should be on function based, since gcc can emit line numbers
387 like:
388
389 10 0x100 - for the init/test part of a for stmt.
390 20 0x200
391 30 0x300
392 10 0x400 - for the increment part of a for stmt.
393
581e13c1 394 arrange_linetable() will do this sorting.
c5aa993b
JM
395
396 2) aix symbol table might look like:
397
398 c_file // beginning of a new file
399 .bi // beginning of include file
400 .ei // end of include file
401 .bi
402 .ei
403
404 basically, .bi/.ei pairs do not necessarily encapsulate
581e13c1 405 their scope. They need to be recorded, and processed later
c5aa993b
JM
406 on when we come the end of the compilation unit.
407 Include table (inclTable) and process_linenos() handle
408 that. */
9846de1b 409/* *INDENT-ON* */
c906108c 410
c5aa993b
JM
411
412
581e13c1 413/* compare line table entry addresses. */
c906108c
SS
414
415static int
fba45db2 416compare_lte (const void *lte1p, const void *lte2p)
c906108c
SS
417{
418 struct linetable_entry *lte1 = (struct linetable_entry *) lte1p;
419 struct linetable_entry *lte2 = (struct linetable_entry *) lte2p;
a109c7c1 420
c906108c
SS
421 return lte1->pc - lte2->pc;
422}
423
581e13c1
MS
424/* Given a line table with function entries are marked, arrange its
425 functions in ascending order and strip off function entry markers
426 and return it in a newly created table. If the old one is good
427 enough, return the old one. */
c906108c
SS
428/* FIXME: I think all this stuff can be replaced by just passing
429 sort_linevec = 1 to end_symtab. */
430
431static struct linetable *
b095261a 432arrange_linetable (struct linetable *oldLineTb)
c906108c 433{
c5aa993b
JM
434 int ii, jj, newline, /* new line count */
435 function_count; /* # of functions */
c906108c 436
c5aa993b
JM
437 struct linetable_entry *fentry; /* function entry vector */
438 int fentry_size; /* # of function entries */
439 struct linetable *newLineTb; /* new line table */
a85c52f2 440 int extra_lines = 0;
c906108c
SS
441
442#define NUM_OF_FUNCTIONS 20
443
444 fentry_size = NUM_OF_FUNCTIONS;
8d749320 445 fentry = XNEWVEC (struct linetable_entry, fentry_size);
c906108c 446
c5aa993b
JM
447 for (function_count = 0, ii = 0; ii < oldLineTb->nitems; ++ii)
448 {
c5aa993b 449 if (oldLineTb->item[ii].line == 0)
581e13c1 450 { /* Function entry found. */
c5aa993b 451 if (function_count >= fentry_size)
581e13c1 452 { /* Make sure you have room. */
c5aa993b
JM
453 fentry_size *= 2;
454 fentry = (struct linetable_entry *)
3e43a32a
MS
455 xrealloc (fentry,
456 fentry_size * sizeof (struct linetable_entry));
c5aa993b
JM
457 }
458 fentry[function_count].line = ii;
459 fentry[function_count].pc = oldLineTb->item[ii].pc;
460 ++function_count;
a85c52f2
UW
461
462 /* If the function was compiled with XLC, we may have to add an
463 extra line entry later. Reserve space for that. */
464 if (ii + 1 < oldLineTb->nitems
465 && oldLineTb->item[ii].pc != oldLineTb->item[ii + 1].pc)
466 extra_lines++;
c5aa993b 467 }
c906108c 468 }
c906108c 469
c5aa993b
JM
470 if (function_count == 0)
471 {
b8c9b27d 472 xfree (fentry);
c5aa993b
JM
473 return oldLineTb;
474 }
c906108c 475 else if (function_count > 1)
3e43a32a
MS
476 qsort (fentry, function_count,
477 sizeof (struct linetable_entry), compare_lte);
c906108c 478
581e13c1 479 /* Allocate a new line table. */
c906108c
SS
480 newLineTb = (struct linetable *)
481 xmalloc
c5aa993b 482 (sizeof (struct linetable) +
a85c52f2 483 (oldLineTb->nitems - function_count + extra_lines) * sizeof (struct linetable_entry));
c906108c 484
581e13c1
MS
485 /* If line table does not start with a function beginning, copy up until
486 a function begin. */
c906108c
SS
487
488 newline = 0;
489 if (oldLineTb->item[0].line != 0)
c5aa993b
JM
490 for (newline = 0;
491 newline < oldLineTb->nitems && oldLineTb->item[newline].line; ++newline)
c906108c
SS
492 newLineTb->item[newline] = oldLineTb->item[newline];
493
581e13c1 494 /* Now copy function lines one by one. */
c906108c 495
c5aa993b
JM
496 for (ii = 0; ii < function_count; ++ii)
497 {
a85c52f2
UW
498 /* If the function was compiled with XLC, we may have to add an
499 extra line to cover the function prologue. */
500 jj = fentry[ii].line;
501 if (jj + 1 < oldLineTb->nitems
502 && oldLineTb->item[jj].pc != oldLineTb->item[jj + 1].pc)
503 {
504 newLineTb->item[newline] = oldLineTb->item[jj];
505 newLineTb->item[newline].line = oldLineTb->item[jj + 1].line;
506 newline++;
507 }
508
c5aa993b
JM
509 for (jj = fentry[ii].line + 1;
510 jj < oldLineTb->nitems && oldLineTb->item[jj].line != 0;
511 ++jj, ++newline)
512 newLineTb->item[newline] = oldLineTb->item[jj];
513 }
b8c9b27d 514 xfree (fentry);
a85c52f2
UW
515 /* The number of items in the line table must include these
516 extra lines which were added in case of XLC compiled functions. */
517 newLineTb->nitems = oldLineTb->nitems - function_count + extra_lines;
c5aa993b
JM
518 return newLineTb;
519}
c906108c
SS
520
521/* include file support: C_BINCL/C_EINCL pairs will be kept in the
581e13c1 522 following `IncludeChain'. At the end of each symtab (end_symtab),
c906108c 523 we will determine if we should create additional symtab's to
581e13c1 524 represent if (the include files. */
c906108c
SS
525
526
c5aa993b
JM
527typedef struct _inclTable
528{
529 char *name; /* include filename */
c906108c
SS
530
531 /* Offsets to the line table. end points to the last entry which is
532 part of this include file. */
c5aa993b
JM
533 int begin, end;
534
c906108c 535 struct subfile *subfile;
581e13c1 536 unsigned funStartLine; /* Start line # of its function. */
c5aa993b
JM
537}
538InclTable;
c906108c
SS
539
540#define INITIAL_INCLUDE_TABLE_LENGTH 20
c5aa993b
JM
541static InclTable *inclTable; /* global include table */
542static int inclIndx; /* last entry to table */
543static int inclLength; /* table length */
544static int inclDepth; /* nested include depth */
c906108c 545
a14ed312 546static void allocate_include_entry (void);
c906108c
SS
547
548static void
fba45db2 549record_include_begin (struct coff_symbol *cs)
c906108c
SS
550{
551 if (inclDepth)
552 {
553 /* In xcoff, we assume include files cannot be nested (not in .c files
c5aa993b 554 of course, but in corresponding .s files.). */
c906108c
SS
555
556 /* This can happen with old versions of GCC.
c5aa993b
JM
557 GCC 2.3.3-930426 does not exhibit this on a test case which
558 a user said produced the message for him. */
e2e0b3e5 559 complaint (&symfile_complaints, _("Nested C_BINCL symbols"));
c906108c
SS
560 }
561 ++inclDepth;
562
563 allocate_include_entry ();
564
c5aa993b
JM
565 inclTable[inclIndx].name = cs->c_name;
566 inclTable[inclIndx].begin = cs->c_value;
c906108c
SS
567}
568
569static void
fba45db2 570record_include_end (struct coff_symbol *cs)
c906108c 571{
c5aa993b 572 InclTable *pTbl;
c906108c
SS
573
574 if (inclDepth == 0)
575 {
e2e0b3e5 576 complaint (&symfile_complaints, _("Mismatched C_BINCL/C_EINCL pair"));
c906108c
SS
577 }
578
579 allocate_include_entry ();
580
c5aa993b 581 pTbl = &inclTable[inclIndx];
c906108c
SS
582 pTbl->end = cs->c_value;
583
584 --inclDepth;
585 ++inclIndx;
586}
587
588static void
fba45db2 589allocate_include_entry (void)
c906108c
SS
590{
591 if (inclTable == NULL)
592 {
8d749320 593 inclTable = XCNEWVEC (InclTable, INITIAL_INCLUDE_TABLE_LENGTH);
c906108c
SS
594 inclLength = INITIAL_INCLUDE_TABLE_LENGTH;
595 inclIndx = 0;
596 }
597 else if (inclIndx >= inclLength)
598 {
599 inclLength += INITIAL_INCLUDE_TABLE_LENGTH;
8d749320 600 inclTable = XRESIZEVEC (InclTable, inclTable, inclLength);
c5aa993b
JM
601 memset (inclTable + inclLength - INITIAL_INCLUDE_TABLE_LENGTH,
602 '\0', sizeof (InclTable) * INITIAL_INCLUDE_TABLE_LENGTH);
c906108c
SS
603 }
604}
605
606/* Global variable to pass the psymtab down to all the routines involved
607 in psymtab to symtab processing. */
608static struct partial_symtab *this_symtab_psymtab;
609
5c80ed9d
TT
610/* Objfile related to this_symtab_psymtab; set at the same time. */
611static struct objfile *this_symtab_objfile;
612
c906108c 613/* given the start and end addresses of a compilation unit (or a csect,
581e13c1 614 at times) process its lines and create appropriate line vectors. */
c906108c
SS
615
616static void
fba45db2 617process_linenos (CORE_ADDR start, CORE_ADDR end)
c906108c
SS
618{
619 int offset, ii;
b8b98ad1 620 file_ptr max_offset
5c80ed9d 621 = XCOFF_DATA (this_symtab_objfile)->max_lineno_offset;
c906108c
SS
622
623 /* subfile structure for the main compilation unit. */
624 struct subfile main_subfile;
625
626 /* In the main source file, any time we see a function entry, we
627 reset this variable to function's absolute starting line number.
628 All the following line numbers in the function are relative to
629 this, and we record absolute line numbers in record_line(). */
630
631 unsigned int main_source_baseline = 0;
632
633 unsigned *firstLine;
634
635 offset =
c5aa993b 636 ((struct symloc *) this_symtab_psymtab->read_symtab_private)->lineno_off;
c906108c
SS
637 if (offset == 0)
638 goto return_after_cleanup;
639
640 memset (&main_subfile, '\0', sizeof (main_subfile));
641
642 if (inclIndx == 0)
581e13c1
MS
643 /* All source lines were in the main source file. None in include
644 files. */
c906108c 645
c5aa993b
JM
646 enter_line_range (&main_subfile, offset, 0, start, end,
647 &main_source_baseline);
c906108c
SS
648
649 else
650 {
651 /* There was source with line numbers in include files. */
7a78ae4e
ND
652
653 int linesz =
5c80ed9d 654 coff_data (this_symtab_objfile->obfd)->local_linesz;
c906108c 655 main_source_baseline = 0;
7a78ae4e 656
c5aa993b 657 for (ii = 0; ii < inclIndx; ++ii)
c906108c
SS
658 {
659 struct subfile *tmpSubfile;
660
661 /* If there is main file source before include file, enter it. */
662 if (offset < inclTable[ii].begin)
663 {
664 enter_line_range
7a78ae4e 665 (&main_subfile, offset, inclTable[ii].begin - linesz,
c906108c
SS
666 start, 0, &main_source_baseline);
667 }
668
46212e0b 669 if (strcmp (inclTable[ii].name, get_last_source_file ()) == 0)
c5933f6d
JB
670 {
671 /* The entry in the include table refers to the main source
581e13c1 672 file. Add the lines to the main subfile. */
c5933f6d
JB
673
674 main_source_baseline = inclTable[ii].funStartLine;
675 enter_line_range
676 (&main_subfile, inclTable[ii].begin, inclTable[ii].end,
677 start, 0, &main_source_baseline);
678 inclTable[ii].subfile = &main_subfile;
679 }
680 else
681 {
c5933f6d 682 /* Have a new subfile for the include file. */
c906108c 683
8d749320 684 tmpSubfile = inclTable[ii].subfile = XNEW (struct subfile);
c906108c 685
c5933f6d
JB
686 memset (tmpSubfile, '\0', sizeof (struct subfile));
687 firstLine = &(inclTable[ii].funStartLine);
688
689 /* Enter include file's lines now. */
690 enter_line_range (tmpSubfile, inclTable[ii].begin,
691 inclTable[ii].end, start, 0, firstLine);
692 }
c906108c
SS
693
694 if (offset <= inclTable[ii].end)
7a78ae4e 695 offset = inclTable[ii].end + linesz;
c906108c
SS
696 }
697
698 /* All the include files' line have been processed at this point. Now,
c5aa993b 699 enter remaining lines of the main file, if any left. */
7a78ae4e 700 if (offset < max_offset + 1 - linesz)
c906108c 701 {
c5aa993b 702 enter_line_range (&main_subfile, offset, 0, start, end,
c906108c
SS
703 &main_source_baseline);
704 }
705 }
706
707 /* Process main file's line numbers. */
708 if (main_subfile.line_vector)
709 {
710 struct linetable *lineTb, *lv;
711
712 lv = main_subfile.line_vector;
713
581e13c1
MS
714 /* Line numbers are not necessarily ordered. xlc compilation will
715 put static function to the end. */
c906108c
SS
716
717 lineTb = arrange_linetable (lv);
718 if (lv == lineTb)
719 {
720 current_subfile->line_vector = (struct linetable *)
721 xrealloc (lv, (sizeof (struct linetable)
722 + lv->nitems * sizeof (struct linetable_entry)));
723 }
724 else
725 {
b8c9b27d 726 xfree (lv);
c906108c
SS
727 current_subfile->line_vector = lineTb;
728 }
729
c5aa993b 730 current_subfile->line_vector_length =
c906108c
SS
731 current_subfile->line_vector->nitems;
732 }
733
734 /* Now, process included files' line numbers. */
735
c5aa993b 736 for (ii = 0; ii < inclIndx; ++ii)
c906108c 737 {
c5933f6d 738 if (inclTable[ii].subfile != ((struct subfile *) &main_subfile)
3e43a32a
MS
739 && (inclTable[ii].subfile)->line_vector) /* Useless if!!!
740 FIXMEmgo */
c906108c
SS
741 {
742 struct linetable *lineTb, *lv;
743
744 lv = (inclTable[ii].subfile)->line_vector;
745
581e13c1
MS
746 /* Line numbers are not necessarily ordered. xlc compilation will
747 put static function to the end. */
c906108c
SS
748
749 lineTb = arrange_linetable (lv);
750
751 push_subfile ();
752
753 /* For the same include file, we might want to have more than one
754 subfile. This happens if we have something like:
755
c5aa993b
JM
756 ......
757 #include "foo.h"
758 ......
759 #include "foo.h"
760 ......
c906108c 761
581e13c1 762 while foo.h including code in it. (stupid but possible)
c906108c
SS
763 Since start_subfile() looks at the name and uses an
764 existing one if finds, we need to provide a fake name and
765 fool it. */
766
767#if 0
4d663531 768 start_subfile (inclTable[ii].name);
c906108c
SS
769#else
770 {
771 /* Pick a fake name that will produce the same results as this
772 one when passed to deduce_language_from_filename. Kludge on
773 top of kludge. */
a121b7c1 774 const char *fakename = strrchr (inclTable[ii].name, '.');
a109c7c1 775
c906108c
SS
776 if (fakename == NULL)
777 fakename = " ?";
4d663531 778 start_subfile (fakename);
b8c9b27d 779 xfree (current_subfile->name);
c906108c 780 }
c2d11a7d 781 current_subfile->name = xstrdup (inclTable[ii].name);
c906108c
SS
782#endif
783
784 if (lv == lineTb)
785 {
786 current_subfile->line_vector =
787 (struct linetable *) xrealloc
c5aa993b
JM
788 (lv, (sizeof (struct linetable)
789 + lv->nitems * sizeof (struct linetable_entry)));
c906108c
SS
790
791 }
792 else
793 {
b8c9b27d 794 xfree (lv);
c906108c
SS
795 current_subfile->line_vector = lineTb;
796 }
797
c5aa993b 798 current_subfile->line_vector_length =
c906108c 799 current_subfile->line_vector->nitems;
4d663531 800 start_subfile (pop_subfile ());
c906108c
SS
801 }
802 }
803
c5aa993b 804return_after_cleanup:
c906108c
SS
805
806 /* We don't want to keep alloc/free'ing the global include file table. */
807 inclIndx = 0;
c906108c
SS
808}
809
c295b2e5 810static void
f56ce883 811aix_process_linenos (struct objfile *objfile)
c906108c 812{
316a8b21
TG
813 /* There is no linenos to read if there are only dwarf info. */
814 if (this_symtab_psymtab == NULL)
815 return;
816
581e13c1 817 /* Process line numbers and enter them into line vector. */
c906108c
SS
818 process_linenos (last_source_start_addr, cur_src_end_addr);
819}
820
821
822/* Enter a given range of lines into the line vector.
823 can be called in the following two ways:
3e43a32a
MS
824 enter_line_range (subfile, beginoffset, endoffset,
825 startaddr, 0, firstLine) or
826 enter_line_range (subfile, beginoffset, 0,
827 startaddr, endaddr, firstLine)
c906108c
SS
828
829 endoffset points to the last line table entry that we should pay
830 attention to. */
831
832static void
3e43a32a
MS
833enter_line_range (struct subfile *subfile, unsigned beginoffset,
834 unsigned endoffset, /* offsets to line table */
fba45db2
KB
835 CORE_ADDR startaddr, /* offsets to line table */
836 CORE_ADDR endaddr, unsigned *firstLine)
c906108c 837{
5c80ed9d 838 struct objfile *objfile = this_symtab_objfile;
fbf65064 839 struct gdbarch *gdbarch = get_objfile_arch (objfile);
c906108c
SS
840 unsigned int curoffset;
841 CORE_ADDR addr;
7a78ae4e 842 void *ext_lnno;
c906108c
SS
843 struct internal_lineno int_lnno;
844 unsigned int limit_offset;
845 bfd *abfd;
7a78ae4e 846 int linesz;
c906108c
SS
847
848 if (endoffset == 0 && startaddr == 0 && endaddr == 0)
849 return;
850 curoffset = beginoffset;
b8b98ad1 851 limit_offset = XCOFF_DATA (objfile)->max_lineno_offset;
c906108c
SS
852
853 if (endoffset != 0)
854 {
855 if (endoffset >= limit_offset)
856 {
23136709 857 complaint (&symfile_complaints,
e2e0b3e5 858 _("Bad line table offset in C_EINCL directive"));
c906108c
SS
859 return;
860 }
861 limit_offset = endoffset;
862 }
863 else
864 limit_offset -= 1;
7a78ae4e 865
fbf65064 866 abfd = objfile->obfd;
7a78ae4e
ND
867 linesz = coff_data (abfd)->local_linesz;
868 ext_lnno = alloca (linesz);
c906108c
SS
869
870 while (curoffset <= limit_offset)
871 {
872 bfd_seek (abfd, curoffset, SEEK_SET);
3a42e9d0 873 bfd_bread (ext_lnno, linesz, abfd);
7a78ae4e 874 bfd_coff_swap_lineno_in (abfd, ext_lnno, &int_lnno);
c906108c
SS
875
876 /* Find the address this line represents. */
877 addr = (int_lnno.l_lnno
878 ? int_lnno.l_addr.l_paddr
879 : read_symbol_nvalue (int_lnno.l_addr.l_symndx));
fbf65064 880 addr += ANOFFSET (objfile->section_offsets, SECT_OFF_TEXT (objfile));
c906108c
SS
881
882 if (addr < startaddr || (endaddr && addr >= endaddr))
883 return;
884
885 if (int_lnno.l_lnno == 0)
886 {
887 *firstLine = read_symbol_lineno (int_lnno.l_addr.l_symndx);
fbf65064 888 record_line (subfile, 0, gdbarch_addr_bits_remove (gdbarch, addr));
c906108c
SS
889 --(*firstLine);
890 }
891 else
fbf65064
UW
892 record_line (subfile, *firstLine + int_lnno.l_lnno,
893 gdbarch_addr_bits_remove (gdbarch, addr));
7a78ae4e 894 curoffset += linesz;
c906108c
SS
895 }
896}
897
898
899/* Save the vital information for use when closing off the current file.
900 NAME is the file name the symbols came from, START_ADDR is the first
901 text address for the file, and SIZE is the number of bytes of text. */
902
903#define complete_symtab(name, start_addr) { \
46212e0b 904 set_last_source_file (name); \
1b36a34b 905 last_source_start_addr = start_addr; \
c906108c
SS
906}
907
908
909/* Refill the symbol table input buffer
910 and set the variables that control fetching entries from it.
911 Reports an error if no data available.
912 This function can read past the end of the symbol table
913 (into the string table) but this does no harm. */
914
8dddcb8f 915/* Create a new minimal symbol (using record_with_info).
ec92004f 916
4d1eb6b4 917 Creation of all new minimal symbols should go through this function
8dddcb8f 918 rather than calling the various record functions in order
4d1eb6b4
JB
919 to make sure that all symbol addresses get properly relocated.
920
ec92004f
JB
921 Arguments are:
922
923 NAME - the symbol's name (but if NAME starts with a period, that
924 leading period is discarded).
4d1eb6b4
JB
925 ADDRESS - the symbol's address, prior to relocation. This function
926 relocates the address before recording the minimal symbol.
ec92004f
JB
927 MS_TYPE - the symbol's type.
928 N_SCNUM - the symbol's XCOFF section number.
929 OBJFILE - the objfile associated with the minimal symbol. */
c906108c 930
ec92004f 931static void
8dddcb8f
TT
932record_minimal_symbol (minimal_symbol_reader &reader,
933 const char *name, CORE_ADDR address,
ec92004f
JB
934 enum minimal_symbol_type ms_type,
935 int n_scnum,
936 struct objfile *objfile)
937{
ec92004f
JB
938 if (name[0] == '.')
939 ++name;
940
8dddcb8f
TT
941 reader.record_with_info (name, address, ms_type,
942 secnum_to_section (n_scnum, objfile));
ec92004f 943}
c906108c 944
581e13c1
MS
945/* xcoff has static blocks marked in `.bs', `.es' pairs. They cannot be
946 nested. At any given time, a symbol can only be in one static block.
947 This is the base address of current static block, zero if non exists. */
c5aa993b 948
c906108c
SS
949static int static_block_base = 0;
950
951/* Section number for the current static block. */
952
953static int static_block_section = -1;
954
581e13c1 955/* true if space for symbol name has been allocated. */
c906108c
SS
956
957static int symname_alloced = 0;
958
959/* Next symbol to read. Pointer into raw seething symbol table. */
960
961static char *raw_symbol;
962
963/* This is the function which stabsread.c calls to get symbol
964 continuations. */
965
a121b7c1 966static const char *
fba45db2 967xcoff_next_symbol_text (struct objfile *objfile)
c906108c
SS
968{
969 struct internal_syment symbol;
a121b7c1 970 const char *retval;
a109c7c1 971
581e13c1 972 /* FIXME: is this the same as the passed arg? */
5c80ed9d
TT
973 if (this_symtab_objfile)
974 objfile = this_symtab_objfile;
c906108c
SS
975
976 bfd_coff_swap_sym_in (objfile->obfd, raw_symbol, &symbol);
977 if (symbol.n_zeroes)
978 {
e2e0b3e5 979 complaint (&symfile_complaints, _("Unexpected symbol continuation"));
c906108c
SS
980
981 /* Return something which points to '\0' and hope the symbol reading
c5aa993b 982 code does something reasonable. */
c906108c
SS
983 retval = "";
984 }
985 else if (symbol.n_sclass & 0x80)
986 {
b8b98ad1 987 retval = XCOFF_DATA (objfile)->debugsec + symbol.n_offset;
3e43a32a 988 raw_symbol += coff_data (objfile->obfd)->local_symesz;
c906108c
SS
989 ++symnum;
990 }
991 else
992 {
e2e0b3e5 993 complaint (&symfile_complaints, _("Unexpected symbol continuation"));
c906108c
SS
994
995 /* Return something which points to '\0' and hope the symbol reading
c5aa993b 996 code does something reasonable. */
c906108c
SS
997 retval = "";
998 }
999 return retval;
1000}
1001
1002/* Read symbols for a given partial symbol table. */
1003
1004static void
5c80ed9d 1005read_xcoff_symtab (struct objfile *objfile, struct partial_symtab *pst)
c906108c 1006{
c906108c 1007 bfd *abfd = objfile->obfd;
581e13c1 1008 char *raw_auxptr; /* Pointer to first raw aux entry for sym. */
b8b98ad1
TT
1009 struct coff_symfile_info *xcoff = XCOFF_DATA (objfile);
1010 char *strtbl = xcoff->strtbl;
1011 char *debugsec = xcoff->debugsec;
554d387d 1012 const char *debugfmt = bfd_xcoff_is_xcoff64 (abfd) ? "XCOFF64" : "XCOFF";
c906108c
SS
1013
1014 struct internal_syment symbol[1];
1015 union internal_auxent main_aux;
1016 struct coff_symbol cs[1];
1017 CORE_ADDR file_start_addr = 0;
1018 CORE_ADDR file_end_addr = 0;
1019
1020 int next_file_symnum = -1;
1021 unsigned int max_symnum;
1022 int just_started = 1;
1023 int depth = 0;
086850b2 1024 CORE_ADDR fcn_start_addr = 0;
c906108c 1025
238ae9af 1026 struct coff_symbol fcn_stab_saved = { 0 };
c906108c 1027
581e13c1 1028 /* fcn_cs_saved is global because process_xcoff_symbol needs it. */
3672b1be 1029 union internal_auxent fcn_aux_saved = main_aux;
fe978cb0 1030 struct context_stack *newobj;
c906108c 1031
9a1e3f00 1032 const char *filestring = pst->filename; /* Name of the current file. */
c906108c 1033
40301fb7 1034 const char *last_csect_name; /* Last seen csect's name. */
c906108c
SS
1035
1036 this_symtab_psymtab = pst;
5c80ed9d 1037 this_symtab_objfile = objfile;
c906108c
SS
1038
1039 /* Get the appropriate COFF "constants" related to the file we're
581e13c1 1040 handling. */
c906108c
SS
1041 local_symesz = coff_data (abfd)->local_symesz;
1042
46212e0b 1043 set_last_source_file (NULL);
c906108c 1044 last_csect_name = 0;
c906108c
SS
1045
1046 start_stabs ();
5ffa0793
PA
1047 start_symtab (objfile, filestring, (char *) NULL, file_start_addr,
1048 language_unknown);
7a78ae4e 1049 record_debugformat (debugfmt);
c5aa993b 1050 symnum = ((struct symloc *) pst->read_symtab_private)->first_symnum;
c906108c 1051 max_symnum =
c5aa993b 1052 symnum + ((struct symloc *) pst->read_symtab_private)->numsyms;
c906108c
SS
1053 first_object_file_end = 0;
1054
b8b98ad1 1055 raw_symbol = xcoff->symtbl + symnum * local_symesz;
c906108c
SS
1056
1057 while (symnum < max_symnum)
1058 {
c906108c
SS
1059 QUIT; /* make this command interruptable. */
1060
1061 /* READ_ONE_SYMBOL (symbol, cs, symname_alloced); */
581e13c1 1062 /* read one symbol into `cs' structure. After processing the
c5aa993b 1063 whole symbol table, only string table will be kept in memory,
581e13c1 1064 symbol table and debug section of xcoff will be freed. Thus
c5aa993b 1065 we can mark symbols with names in string table as
581e13c1 1066 `alloced'. */
c906108c
SS
1067 {
1068 int ii;
1069
1070 /* Swap and align the symbol into a reasonable C structure. */
1071 bfd_coff_swap_sym_in (abfd, raw_symbol, symbol);
1072
1073 cs->c_symnum = symnum;
1074 cs->c_naux = symbol->n_numaux;
1075 if (symbol->n_zeroes)
1076 {
1077 symname_alloced = 0;
1078 /* We must use the original, unswapped, name here so the name field
1079 pointed to by cs->c_name will persist throughout xcoffread. If
1080 we use the new field, it gets overwritten for each symbol. */
c5aa993b 1081 cs->c_name = ((struct external_syment *) raw_symbol)->e.e_name;
c906108c
SS
1082 /* If it's exactly E_SYMNMLEN characters long it isn't
1083 '\0'-terminated. */
1084 if (cs->c_name[E_SYMNMLEN - 1] != '\0')
1085 {
1086 char *p;
a109c7c1 1087
224c3ddb
SM
1088 p = (char *) obstack_alloc (&objfile->objfile_obstack,
1089 E_SYMNMLEN + 1);
c906108c
SS
1090 strncpy (p, cs->c_name, E_SYMNMLEN);
1091 p[E_SYMNMLEN] = '\0';
1092 cs->c_name = p;
1093 symname_alloced = 1;
1094 }
1095 }
1096 else if (symbol->n_sclass & 0x80)
1097 {
1098 cs->c_name = debugsec + symbol->n_offset;
1099 symname_alloced = 0;
1100 }
1101 else
1102 {
1103 /* in string table */
c5aa993b 1104 cs->c_name = strtbl + (int) symbol->n_offset;
c906108c
SS
1105 symname_alloced = 1;
1106 }
1107 cs->c_value = symbol->n_value;
1108 cs->c_sclass = symbol->n_sclass;
1109 cs->c_secnum = symbol->n_scnum;
c5aa993b 1110 cs->c_type = (unsigned) symbol->n_type;
c906108c 1111
7a78ae4e 1112 raw_symbol += local_symesz;
c906108c
SS
1113 ++symnum;
1114
1115 /* Save addr of first aux entry. */
1116 raw_auxptr = raw_symbol;
1117
1118 /* Skip all the auxents associated with this symbol. */
1119 for (ii = symbol->n_numaux; ii; --ii)
1120 {
1121 raw_symbol += coff_data (abfd)->local_auxesz;
1122 ++symnum;
1123 }
1124 }
1125
581e13c1 1126 /* if symbol name starts with ".$" or "$", ignore it. */
c906108c
SS
1127 if (cs->c_name[0] == '$'
1128 || (cs->c_name[1] == '$' && cs->c_name[0] == '.'))
1129 continue;
1130
1131 if (cs->c_symnum == next_file_symnum && cs->c_sclass != C_FILE)
1132 {
46212e0b 1133 if (get_last_source_file ())
c906108c 1134 {
43f3e411
DE
1135 pst->compunit_symtab = end_symtab (cur_src_end_addr,
1136 SECT_OFF_TEXT (objfile));
c906108c
SS
1137 end_stabs ();
1138 }
1139
1140 start_stabs ();
5ffa0793
PA
1141 start_symtab (objfile, "_globals_", (char *) NULL, (CORE_ADDR) 0,
1142 language_unknown);
7a78ae4e 1143 record_debugformat (debugfmt);
c906108c 1144 cur_src_end_addr = first_object_file_end;
581e13c1 1145 /* Done with all files, everything from here on is globals. */
c906108c
SS
1146 }
1147
55bcecda
UW
1148 if (cs->c_sclass == C_EXT || cs->c_sclass == C_HIDEXT ||
1149 cs->c_sclass == C_WEAKEXT)
c906108c
SS
1150 {
1151 /* Dealing with a symbol with a csect entry. */
1152
1153#define CSECT(PP) ((PP)->x_csect)
1154#define CSECT_LEN(PP) (CSECT(PP).x_scnlen.l)
1155#define CSECT_ALIGN(PP) (SMTYP_ALIGN(CSECT(PP).x_smtyp))
1156#define CSECT_SMTYP(PP) (SMTYP_SMTYP(CSECT(PP).x_smtyp))
1157#define CSECT_SCLAS(PP) (CSECT(PP).x_smclas)
1158
55bcecda
UW
1159 /* Convert the auxent to something we can access.
1160 XCOFF can have more than one auxiliary entries.
1161
1162 Actual functions will have two auxiliary entries, one to have the
1163 function size and other to have the smtype/smclass (LD/PR).
1164
1165 c_type value of main symbol table will be set only in case of
1166 C_EXT/C_HIDEEXT/C_WEAKEXT storage class symbols.
1167 Bit 10 of type is set if symbol is a function, ie the value is set
1168 to 32(0x20). So we need to read the first function auxiliay entry
1169 which contains the size. */
1170 if (cs->c_naux > 1 && ISFCN (cs->c_type))
1171 {
1172 /* a function entry point. */
1173
1174 fcn_start_addr = cs->c_value;
1175
1176 /* save the function header info, which will be used
1177 when `.bf' is seen. */
1178 fcn_cs_saved = *cs;
1179
1180 /* Convert the auxent to something we can access. */
1181 bfd_coff_swap_aux_in (abfd, raw_auxptr, cs->c_type, cs->c_sclass,
1182 0, cs->c_naux, &fcn_aux_saved);
1183 continue;
1184 }
1185 /* Read the csect auxiliary header, which is always the last by
1186 onvention. */
1187 bfd_coff_swap_aux_in (abfd,
1188 raw_auxptr
1189 + ((coff_data (abfd)->local_symesz)
1190 * (cs->c_naux - 1)),
1191 cs->c_type, cs->c_sclass,
1192 cs->c_naux - 1, cs->c_naux,
1193 &main_aux);
c906108c
SS
1194
1195 switch (CSECT_SMTYP (&main_aux))
1196 {
1197
1198 case XTY_ER:
1199 /* Ignore all external references. */
1200 continue;
1201
1202 case XTY_SD:
1203 /* A section description. */
1204 {
1205 switch (CSECT_SCLAS (&main_aux))
1206 {
1207
1208 case XMC_PR:
1209 {
1210
1211 /* A program csect is seen. We have to allocate one
c5aa993b
JM
1212 symbol table for each program csect. Normally gdb
1213 prefers one symtab for each source file. In case
1214 of AIX, one source file might include more than one
1215 [PR] csect, and they don't have to be adjacent in
581e13c1 1216 terms of the space they occupy in memory. Thus, one
c5aa993b
JM
1217 single source file might get fragmented in the
1218 memory and gdb's file start and end address
1219 approach does not work! GCC (and I think xlc) seem
1220 to put all the code in the unnamed program csect. */
c906108c
SS
1221
1222 if (last_csect_name)
1223 {
1224 complete_symtab (filestring, file_start_addr);
1225 cur_src_end_addr = file_end_addr;
43f3e411 1226 end_symtab (file_end_addr, SECT_OFF_TEXT (objfile));
c906108c
SS
1227 end_stabs ();
1228 start_stabs ();
1229 /* Give all csects for this source file the same
1230 name. */
4d663531 1231 start_symtab (objfile, filestring, NULL,
5ffa0793 1232 (CORE_ADDR) 0, language_unknown);
7a78ae4e 1233 record_debugformat (debugfmt);
c906108c
SS
1234 }
1235
1236 /* If this is the very first csect seen,
581e13c1 1237 basically `__start'. */
c906108c
SS
1238 if (just_started)
1239 {
1240 first_object_file_end
1241 = cs->c_value + CSECT_LEN (&main_aux);
1242 just_started = 0;
1243 }
1244
1245 file_start_addr =
1246 cs->c_value + ANOFFSET (objfile->section_offsets,
b8fbeb18 1247 SECT_OFF_TEXT (objfile));
c906108c
SS
1248 file_end_addr = file_start_addr + CSECT_LEN (&main_aux);
1249
40301fb7
JB
1250 if (cs->c_name && (cs->c_name[0] == '.' || cs->c_name[0] == '@'))
1251 last_csect_name = cs->c_name;
c906108c
SS
1252 }
1253 continue;
1254
1255 /* All other symbols are put into the minimal symbol
1256 table only. */
1257
1258 case XMC_RW:
1259 continue;
1260
1261 case XMC_TC0:
1262 continue;
1263
1264 case XMC_TC:
1265 continue;
1266
1267 default:
1268 /* Ignore the symbol. */
1269 continue;
1270 }
1271 }
1272 break;
1273
1274 case XTY_LD:
1275
1276 switch (CSECT_SCLAS (&main_aux))
1277 {
55bcecda
UW
1278 /* We never really come to this part as this case has been
1279 handled in ISFCN check above.
1280 This and other cases of XTY_LD are kept just for
1281 reference. */
c906108c 1282 case XMC_PR:
c906108c
SS
1283 continue;
1284
1285 case XMC_GL:
581e13c1 1286 /* shared library function trampoline code entry point. */
c906108c
SS
1287 continue;
1288
1289 case XMC_DS:
1290 /* The symbols often have the same names as debug symbols for
1291 functions, and confuse lookup_symbol. */
1292 continue;
1293
1294 default:
1295 /* xlc puts each variable in a separate csect, so we get
1296 an XTY_SD for each variable. But gcc puts several
1297 variables in a csect, so that each variable only gets
581e13c1 1298 an XTY_LD. This will typically be XMC_RW; I suspect
c906108c
SS
1299 XMC_RO and XMC_BS might be possible too.
1300 These variables are put in the minimal symbol table
1301 only. */
1302 continue;
1303 }
1304 break;
1305
1306 case XTY_CM:
1307 /* Common symbols are put into the minimal symbol table only. */
1308 continue;
1309
1310 default:
1311 break;
1312 }
1313 }
1314
1315 switch (cs->c_sclass)
1316 {
c906108c
SS
1317 case C_FILE:
1318
1319 /* c_value field contains symnum of next .file entry in table
581e13c1 1320 or symnum of first global after last .file. */
c906108c
SS
1321
1322 next_file_symnum = cs->c_value;
1323
1324 /* Complete symbol table for last object file containing
581e13c1 1325 debugging information. */
c906108c
SS
1326
1327 /* Whether or not there was a csect in the previous file, we
1328 have to call `end_stabs' and `start_stabs' to reset
1329 type_vector, line_vector, etc. structures. */
1330
1331 complete_symtab (filestring, file_start_addr);
1332 cur_src_end_addr = file_end_addr;
4d663531 1333 end_symtab (file_end_addr, SECT_OFF_TEXT (objfile));
c906108c
SS
1334 end_stabs ();
1335
3e43a32a
MS
1336 /* XCOFF, according to the AIX 3.2 documentation, puts the
1337 filename in cs->c_name. But xlc 1.3.0.2 has decided to
1338 do things the standard COFF way and put it in the auxent.
1339 We use the auxent if the symbol is ".file" and an auxent
1340 exists, otherwise use the symbol itself. Simple
1341 enough. */
c906108c
SS
1342 if (!strcmp (cs->c_name, ".file") && cs->c_naux > 0)
1343 {
1344 bfd_coff_swap_aux_in (abfd, raw_auxptr, cs->c_type, cs->c_sclass,
1345 0, cs->c_naux, &main_aux);
1346 filestring = coff_getfilename (&main_aux, objfile);
1347 }
1348 else
1349 filestring = cs->c_name;
1350
1351 start_stabs ();
5ffa0793
PA
1352 start_symtab (objfile, filestring, (char *) NULL, (CORE_ADDR) 0,
1353 language_unknown);
7a78ae4e 1354 record_debugformat (debugfmt);
c906108c
SS
1355 last_csect_name = 0;
1356
581e13c1 1357 /* reset file start and end addresses. A compilation unit
3e43a32a 1358 with no text (only data) should have zero file
581e13c1 1359 boundaries. */
c906108c
SS
1360 file_start_addr = file_end_addr = 0;
1361 break;
1362
1363 case C_FUN:
1364 fcn_stab_saved = *cs;
1365 break;
1366
1367 case C_FCN:
7ecb6532 1368 if (strcmp (cs->c_name, ".bf") == 0)
c906108c
SS
1369 {
1370 CORE_ADDR off = ANOFFSET (objfile->section_offsets,
b8fbeb18 1371 SECT_OFF_TEXT (objfile));
a109c7c1 1372
c906108c
SS
1373 bfd_coff_swap_aux_in (abfd, raw_auxptr, cs->c_type, cs->c_sclass,
1374 0, cs->c_naux, &main_aux);
1375
1376 within_function = 1;
1377
fe978cb0 1378 newobj = push_context (0, fcn_start_addr + off);
c906108c 1379
fe978cb0 1380 newobj->name = define_symbol
c906108c
SS
1381 (fcn_cs_saved.c_value + off,
1382 fcn_stab_saved.c_name, 0, 0, objfile);
fe978cb0
PA
1383 if (newobj->name != NULL)
1384 SYMBOL_SECTION (newobj->name) = SECT_OFF_TEXT (objfile);
c906108c 1385 }
7ecb6532 1386 else if (strcmp (cs->c_name, ".ef") == 0)
c906108c 1387 {
c906108c
SS
1388 bfd_coff_swap_aux_in (abfd, raw_auxptr, cs->c_type, cs->c_sclass,
1389 0, cs->c_naux, &main_aux);
1390
1391 /* The value of .ef is the address of epilogue code;
c5aa993b 1392 not useful for gdb. */
c906108c 1393 /* { main_aux.x_sym.x_misc.x_lnsz.x_lnno
c5aa993b 1394 contains number of lines to '}' */
c906108c
SS
1395
1396 if (context_stack_depth <= 0)
581e13c1 1397 { /* We attempted to pop an empty context stack. */
23136709 1398 ef_complaint (cs->c_symnum);
c906108c
SS
1399 within_function = 0;
1400 break;
1401 }
fe978cb0 1402 newobj = pop_context ();
c906108c 1403 /* Stack must be empty now. */
fe978cb0 1404 if (context_stack_depth > 0 || newobj == NULL)
c906108c 1405 {
23136709 1406 ef_complaint (cs->c_symnum);
c906108c
SS
1407 within_function = 0;
1408 break;
1409 }
1410
fe978cb0 1411 finish_block (newobj->name, &local_symbols, newobj->old_blocks,
63e43d3a 1412 NULL, newobj->start_addr,
c906108c
SS
1413 (fcn_cs_saved.c_value
1414 + fcn_aux_saved.x_sym.x_misc.x_fsize
1415 + ANOFFSET (objfile->section_offsets,
4d663531 1416 SECT_OFF_TEXT (objfile))));
c906108c
SS
1417 within_function = 0;
1418 }
1419 break;
1420
1421 case C_BSTAT:
1422 /* Begin static block. */
1423 {
1424 struct internal_syment symbol;
1425
1426 read_symbol (&symbol, cs->c_value);
1427 static_block_base = symbol.n_value;
1428 static_block_section =
1429 secnum_to_section (symbol.n_scnum, objfile);
1430 }
1431 break;
1432
1433 case C_ESTAT:
1434 /* End of static block. */
1435 static_block_base = 0;
1436 static_block_section = -1;
1437 break;
1438
1439 case C_ARG:
1440 case C_REGPARM:
1441 case C_REG:
1442 case C_TPDEF:
1443 case C_STRTAG:
1444 case C_UNTAG:
1445 case C_ENTAG:
1446 {
3e43a32a
MS
1447 complaint (&symfile_complaints,
1448 _("Unrecognized storage class %d."),
23136709 1449 cs->c_sclass);
c906108c
SS
1450 }
1451 break;
1452
1453 case C_LABEL:
1454 case C_NULL:
1455 /* Ignore these. */
1456 break;
1457
1458 case C_HIDEXT:
1459 case C_STAT:
1460 break;
1461
1462 case C_BINCL:
1463 /* beginning of include file */
1464 /* In xlc output, C_BINCL/C_EINCL pair doesn't show up in sorted
581e13c1
MS
1465 order. Thus, when wee see them, we might not know enough info
1466 to process them. Thus, we'll be saving them into a table
1467 (inclTable) and postpone their processing. */
c906108c
SS
1468
1469 record_include_begin (cs);
1470 break;
1471
1472 case C_EINCL:
1473 /* End of include file. */
1474 /* See the comment after case C_BINCL. */
1475 record_include_end (cs);
1476 break;
1477
1478 case C_BLOCK:
7ecb6532 1479 if (strcmp (cs->c_name, ".bb") == 0)
c906108c
SS
1480 {
1481 depth++;
fe978cb0 1482 newobj = push_context (depth,
c906108c
SS
1483 (cs->c_value
1484 + ANOFFSET (objfile->section_offsets,
b8fbeb18 1485 SECT_OFF_TEXT (objfile))));
c906108c 1486 }
7ecb6532 1487 else if (strcmp (cs->c_name, ".eb") == 0)
c906108c
SS
1488 {
1489 if (context_stack_depth <= 0)
581e13c1 1490 { /* We attempted to pop an empty context stack. */
23136709 1491 eb_complaint (cs->c_symnum);
c906108c
SS
1492 break;
1493 }
fe978cb0
PA
1494 newobj = pop_context ();
1495 if (depth-- != newobj->depth)
c906108c 1496 {
23136709 1497 eb_complaint (cs->c_symnum);
c906108c
SS
1498 break;
1499 }
1500 if (local_symbols && context_stack_depth > 0)
1501 {
1502 /* Make a block for the local symbols within. */
63e43d3a
PMR
1503 finish_block (newobj->name, &local_symbols,
1504 newobj->old_blocks, NULL,
fe978cb0 1505 newobj->start_addr,
c906108c
SS
1506 (cs->c_value
1507 + ANOFFSET (objfile->section_offsets,
4d663531 1508 SECT_OFF_TEXT (objfile))));
c906108c 1509 }
fe978cb0 1510 local_symbols = newobj->locals;
c906108c
SS
1511 }
1512 break;
1513
1514 default:
1515 process_xcoff_symbol (cs, objfile);
1516 break;
1517 }
1518 }
1519
46212e0b 1520 if (get_last_source_file ())
c906108c 1521 {
43f3e411 1522 struct compunit_symtab *cust;
c906108c
SS
1523
1524 complete_symtab (filestring, file_start_addr);
1525 cur_src_end_addr = file_end_addr;
43f3e411 1526 cust = end_symtab (file_end_addr, SECT_OFF_TEXT (objfile));
c906108c 1527 /* When reading symbols for the last C_FILE of the objfile, try
43f3e411 1528 to make sure that we set pst->compunit_symtab to the symtab for the
c906108c
SS
1529 file, not to the _globals_ symtab. I'm not sure whether this
1530 actually works right or when/if it comes up. */
43f3e411
DE
1531 if (pst->compunit_symtab == NULL)
1532 pst->compunit_symtab = cust;
c906108c
SS
1533 end_stabs ();
1534 }
1535}
1536
1537#define SYMBOL_DUP(SYMBOL1, SYMBOL2) \
8d749320 1538 (SYMBOL2) = XOBNEW (&objfile->objfile_obstack, struct symbol); \
c906108c 1539 *(SYMBOL2) = *(SYMBOL1);
c5aa993b
JM
1540
1541
c906108c 1542#define SYMNAME_ALLOC(NAME, ALLOCED) \
10f0c4bb
TT
1543 ((ALLOCED) ? (NAME) : obstack_copy0 (&objfile->objfile_obstack, \
1544 (NAME), strlen (NAME)))
c906108c
SS
1545
1546
581e13c1 1547/* process one xcoff symbol. */
c906108c
SS
1548
1549static struct symbol *
aa1ee363 1550process_xcoff_symbol (struct coff_symbol *cs, struct objfile *objfile)
c906108c
SS
1551{
1552 struct symbol onesymbol;
52f0bd74 1553 struct symbol *sym = &onesymbol;
c906108c
SS
1554 struct symbol *sym2 = NULL;
1555 char *name, *pp;
1556
1557 int sec;
1558 CORE_ADDR off;
1559
1560 if (cs->c_secnum < 0)
1561 {
1562 /* The value is a register number, offset within a frame, etc.,
c5aa993b 1563 and does not get relocated. */
c906108c
SS
1564 off = 0;
1565 sec = -1;
1566 }
1567 else
1568 {
1569 sec = secnum_to_section (cs->c_secnum, objfile);
1570 off = ANOFFSET (objfile->section_offsets, sec);
1571 }
1572
1573 name = cs->c_name;
1574 if (name[0] == '.')
1575 ++name;
1576
38bf1463 1577 initialize_objfile_symbol (sym);
c906108c
SS
1578
1579 /* default assumptions */
7a78ae4e 1580 SYMBOL_VALUE_ADDRESS (sym) = cs->c_value + off;
176620f1 1581 SYMBOL_DOMAIN (sym) = VAR_DOMAIN;
c906108c
SS
1582 SYMBOL_SECTION (sym) = secnum_to_section (cs->c_secnum, objfile);
1583
1584 if (ISFCN (cs->c_type))
1585 {
1586 /* At this point, we don't know the type of the function. This
c5aa993b
JM
1587 will be patched with the type from its stab entry later on in
1588 patch_block_stabs (), unless the file was compiled without -g. */
c906108c 1589
224c3ddb
SM
1590 SYMBOL_SET_LINKAGE_NAME (sym, ((const char *)
1591 SYMNAME_ALLOC (name, symname_alloced)));
46bf5051 1592 SYMBOL_TYPE (sym) = objfile_type (objfile)->nodebug_text_symbol;
c906108c 1593
f1e6e072 1594 SYMBOL_ACLASS_INDEX (sym) = LOC_BLOCK;
c906108c
SS
1595 SYMBOL_DUP (sym, sym2);
1596
55bcecda 1597 if (cs->c_sclass == C_EXT || C_WEAKEXT)
c906108c
SS
1598 add_symbol_to_list (sym2, &global_symbols);
1599 else if (cs->c_sclass == C_HIDEXT || cs->c_sclass == C_STAT)
1600 add_symbol_to_list (sym2, &file_symbols);
1601 }
1602 else
1603 {
581e13c1 1604 /* In case we can't figure out the type, provide default. */
46bf5051 1605 SYMBOL_TYPE (sym) = objfile_type (objfile)->nodebug_data_symbol;
c906108c
SS
1606
1607 switch (cs->c_sclass)
1608 {
1609#if 0
c5aa993b
JM
1610 /* The values of functions and global symbols are now resolved
1611 via the global_sym_chain in stabsread.c. */
c906108c
SS
1612 case C_FUN:
1613 if (fcn_cs_saved.c_sclass == C_EXT)
1614 add_stab_to_list (name, &global_stabs);
1615 else
1616 add_stab_to_list (name, &file_stabs);
1617 break;
1618
1619 case C_GSYM:
1620 add_stab_to_list (name, &global_stabs);
1621 break;
1622#endif
1623
1624 case C_BCOMM:
1625 common_block_start (cs->c_name, objfile);
1626 break;
1627
1628 case C_ECOMM:
1629 common_block_end (objfile);
1630 break;
1631
1632 default:
e2e0b3e5 1633 complaint (&symfile_complaints, _("Unexpected storage class: %d"),
23136709 1634 cs->c_sclass);
c906108c
SS
1635 /* FALLTHROUGH */
1636
1637 case C_DECL:
1638 case C_PSYM:
1639 case C_RPSYM:
1640 case C_ECOML:
1641 case C_LSYM:
1642 case C_RSYM:
1643 case C_GSYM:
1644
1645 {
1646 sym = define_symbol (cs->c_value + off, cs->c_name, 0, 0, objfile);
1647 if (sym != NULL)
1648 {
1649 SYMBOL_SECTION (sym) = sec;
1650 }
1651 return sym;
1652 }
1653
1654 case C_STSYM:
1655
1656 /* For xlc (not GCC), the 'V' symbol descriptor is used for
1657 all statics and we need to distinguish file-scope versus
1658 function-scope using within_function. We do this by
1659 changing the string we pass to define_symbol to use 'S'
1660 where we need to, which is not necessarily super-clean,
1661 but seems workable enough. */
1662
9b13a2db
PM
1663 if (*name == ':')
1664 return NULL;
1665
ed4b0e6a 1666 pp = strchr (name, ':');
9b13a2db 1667 if (pp == NULL)
c906108c
SS
1668 return NULL;
1669
1670 ++pp;
1671 if (*pp == 'V' && !within_function)
1672 *pp = 'S';
1673 sym = define_symbol ((cs->c_value
1674 + ANOFFSET (objfile->section_offsets,
1675 static_block_section)),
1676 cs->c_name, 0, 0, objfile);
1677 if (sym != NULL)
1678 {
7a78ae4e 1679 SYMBOL_VALUE_ADDRESS (sym) += static_block_base;
c906108c
SS
1680 SYMBOL_SECTION (sym) = static_block_section;
1681 }
1682 return sym;
1683
1684 }
1685 }
1686 return sym2;
1687}
1688
1689/* Extract the file name from the aux entry of a C_FILE symbol.
1690 Result is in static storage and is only good for temporary use. */
1691
1692static char *
fba45db2 1693coff_getfilename (union internal_auxent *aux_entry, struct objfile *objfile)
c906108c
SS
1694{
1695 static char buffer[BUFSIZ];
1696
1697 if (aux_entry->x_file.x_n.x_zeroes == 0)
b8b98ad1
TT
1698 strcpy (buffer, (XCOFF_DATA (objfile)->strtbl
1699 + aux_entry->x_file.x_n.x_offset));
c906108c
SS
1700 else
1701 {
1702 strncpy (buffer, aux_entry->x_file.x_fname, FILNMLEN);
1703 buffer[FILNMLEN] = '\0';
1704 }
1705 return (buffer);
1706}
1707
1708/* Set *SYMBOL to symbol number symno in symtbl. */
1709static void
fba45db2 1710read_symbol (struct internal_syment *symbol, int symno)
c906108c 1711{
5c80ed9d 1712 struct coff_symfile_info *xcoff = XCOFF_DATA (this_symtab_objfile);
b8b98ad1
TT
1713 int nsyms = xcoff->symtbl_num_syms;
1714 char *stbl = xcoff->symtbl;
a109c7c1 1715
c906108c
SS
1716 if (symno < 0 || symno >= nsyms)
1717 {
e2e0b3e5 1718 complaint (&symfile_complaints, _("Invalid symbol offset"));
c906108c
SS
1719 symbol->n_value = 0;
1720 symbol->n_scnum = -1;
1721 return;
1722 }
5c80ed9d 1723 bfd_coff_swap_sym_in (this_symtab_objfile->obfd,
c5aa993b 1724 stbl + (symno * local_symesz),
c906108c
SS
1725 symbol);
1726}
c5aa993b 1727
c906108c
SS
1728/* Get value corresponding to symbol number symno in symtbl. */
1729
470d5666 1730static CORE_ADDR
fba45db2 1731read_symbol_nvalue (int symno)
c906108c
SS
1732{
1733 struct internal_syment symbol[1];
1734
1735 read_symbol (symbol, symno);
c5aa993b 1736 return symbol->n_value;
c906108c
SS
1737}
1738
1739
1740/* Find the address of the function corresponding to symno, where
1741 symno is the symbol pointed to by the linetable. */
1742
1743static int
fba45db2 1744read_symbol_lineno (int symno)
c906108c 1745{
5c80ed9d 1746 struct objfile *objfile = this_symtab_objfile;
7af35dad 1747 int xcoff64 = bfd_xcoff_is_xcoff64 (objfile->obfd);
7a78ae4e 1748
b8b98ad1 1749 struct coff_symfile_info *info = XCOFF_DATA (objfile);
7a78ae4e
ND
1750 int nsyms = info->symtbl_num_syms;
1751 char *stbl = info->symtbl;
1752 char *strtbl = info->strtbl;
1753
c906108c
SS
1754 struct internal_syment symbol[1];
1755 union internal_auxent main_aux[1];
1756
1757 if (symno < 0)
1758 {
23136709 1759 bf_notfound_complaint ();
c906108c
SS
1760 return 0;
1761 }
1762
1763 /* Note that just searching for a short distance (e.g. 50 symbols)
1764 is not enough, at least in the following case.
1765
1766 .extern foo
1767 [many .stabx entries]
1768 [a few functions, referring to foo]
1769 .globl foo
1770 .bf
1771
1772 What happens here is that the assembler moves the .stabx entries
1773 to right before the ".bf" for foo, but the symbol for "foo" is before
1774 all the stabx entries. See PR gdb/2222. */
1775
1776 /* Maintaining a table of .bf entries might be preferable to this search.
1777 If I understand things correctly it would need to be done only for
1778 the duration of a single psymtab to symtab conversion. */
1779 while (symno < nsyms)
1780 {
1781 bfd_coff_swap_sym_in (symfile_bfd,
1782 stbl + (symno * local_symesz), symbol);
7a78ae4e
ND
1783 if (symbol->n_sclass == C_FCN)
1784 {
1785 char *name = xcoff64 ? strtbl + symbol->n_offset : symbol->n_name;
a109c7c1 1786
7ecb6532 1787 if (strcmp (name, ".bf") == 0)
7a78ae4e
ND
1788 goto gotit;
1789 }
c906108c
SS
1790 symno += symbol->n_numaux + 1;
1791 }
1792
23136709 1793 bf_notfound_complaint ();
c906108c
SS
1794 return 0;
1795
1796gotit:
581e13c1 1797 /* Take aux entry and return its lineno. */
c906108c 1798 symno++;
7a78ae4e 1799 bfd_coff_swap_aux_in (objfile->obfd, stbl + symno * local_symesz,
c906108c
SS
1800 symbol->n_type, symbol->n_sclass,
1801 0, symbol->n_numaux, main_aux);
1802
1803 return main_aux->x_sym.x_misc.x_lnsz.x_lnno;
1804}
1805
581e13c1 1806/* Support for line number handling. */
c906108c
SS
1807
1808/* This function is called for every section; it finds the outer limits
1809 * of the line table (minimum and maximum file offset) so that the
1810 * mainline code can read the whole thing for efficiency.
1811 */
1812static void
7be0c536 1813find_linenos (struct bfd *abfd, struct bfd_section *asect, void *vpinfo)
c906108c
SS
1814{
1815 struct coff_symfile_info *info;
1816 int size, count;
1817 file_ptr offset, maxoff;
1818
1819 count = asect->lineno_count;
1820
7ecb6532 1821 if (strcmp (asect->name, ".text") != 0 || count == 0)
c906108c
SS
1822 return;
1823
1824 size = count * coff_data (abfd)->local_linesz;
c5aa993b 1825 info = (struct coff_symfile_info *) vpinfo;
c906108c
SS
1826 offset = asect->line_filepos;
1827 maxoff = offset + size;
1828
1829 if (offset < info->min_lineno_offset || info->min_lineno_offset == 0)
1830 info->min_lineno_offset = offset;
1831
1832 if (maxoff > info->max_lineno_offset)
1833 info->max_lineno_offset = maxoff;
1834}
1835\f
c906108c 1836static void
5c80ed9d 1837xcoff_psymtab_to_symtab_1 (struct objfile *objfile, struct partial_symtab *pst)
c906108c 1838{
c906108c 1839 int i;
c5aa993b 1840
c906108c
SS
1841 if (!pst)
1842 return;
1843
1844 if (pst->readin)
1845 {
1846 fprintf_unfiltered
1847 (gdb_stderr, "Psymtab for %s already read in. Shouldn't happen.\n",
1848 pst->filename);
1849 return;
1850 }
1851
581e13c1 1852 /* Read in all partial symtabs on which this one is dependent. */
c906108c
SS
1853 for (i = 0; i < pst->number_of_dependencies; i++)
1854 if (!pst->dependencies[i]->readin)
1855 {
1856 /* Inform about additional files that need to be read in. */
1857 if (info_verbose)
1858 {
1859 fputs_filtered (" ", gdb_stdout);
1860 wrap_here ("");
1861 fputs_filtered ("and ", gdb_stdout);
1862 wrap_here ("");
1863 printf_filtered ("%s...", pst->dependencies[i]->filename);
c5aa993b 1864 wrap_here (""); /* Flush output */
c906108c
SS
1865 gdb_flush (gdb_stdout);
1866 }
5c80ed9d 1867 xcoff_psymtab_to_symtab_1 (objfile, pst->dependencies[i]);
c906108c
SS
1868 }
1869
c5aa993b 1870 if (((struct symloc *) pst->read_symtab_private)->numsyms != 0)
c906108c
SS
1871 {
1872 /* Init stuff necessary for reading in symbols. */
1873 stabsread_init ();
1874 buildsym_init ();
c906108c 1875
33c7c59d 1876 scoped_free_pendings free_pending;
5c80ed9d 1877 read_xcoff_symtab (objfile, pst);
c906108c
SS
1878 }
1879
1880 pst->readin = 1;
1881}
1882
c906108c 1883/* Read in all of the symbols for a given psymtab for real.
257e7a09 1884 Be verbose about it if the user wants that. SELF is not NULL. */
c906108c
SS
1885
1886static void
257e7a09 1887xcoff_read_symtab (struct partial_symtab *self, struct objfile *objfile)
c906108c 1888{
257e7a09 1889 if (self->readin)
c906108c
SS
1890 {
1891 fprintf_unfiltered
1892 (gdb_stderr, "Psymtab for %s already read in. Shouldn't happen.\n",
257e7a09 1893 self->filename);
c906108c
SS
1894 return;
1895 }
1896
257e7a09
YQ
1897 if (((struct symloc *) self->read_symtab_private)->numsyms != 0
1898 || self->number_of_dependencies)
c906108c
SS
1899 {
1900 /* Print the message now, before reading the string table,
c5aa993b 1901 to avoid disconcerting pauses. */
c906108c
SS
1902 if (info_verbose)
1903 {
257e7a09 1904 printf_filtered ("Reading in symbols for %s...", self->filename);
c906108c
SS
1905 gdb_flush (gdb_stdout);
1906 }
1907
c906108c
SS
1908 next_symbol_text_func = xcoff_next_symbol_text;
1909
257e7a09 1910 xcoff_psymtab_to_symtab_1 (objfile, self);
c906108c
SS
1911
1912 /* Match with global symbols. This only needs to be done once,
1913 after all of the symtabs and dependencies have been read in. */
5c80ed9d 1914 scan_file_globals (objfile);
c906108c
SS
1915
1916 /* Finish up the debug error message. */
1917 if (info_verbose)
1918 printf_filtered ("done.\n");
1919 }
1920}
1921\f
1922static void
fba45db2 1923xcoff_new_init (struct objfile *objfile)
c906108c
SS
1924{
1925 stabsread_new_init ();
1926 buildsym_new_init ();
1927}
1928
1929/* Do initialization in preparation for reading symbols from OBJFILE.
c5aa993b 1930
c906108c
SS
1931 We will only be called if this is an XCOFF or XCOFF-like file.
1932 BFD handles figuring out the format of the file, and code in symfile.c
1933 uses BFD's determination to vector to us. */
1934
1935static void
fba45db2 1936xcoff_symfile_init (struct objfile *objfile)
c906108c 1937{
b8b98ad1
TT
1938 struct coff_symfile_info *xcoff;
1939
581e13c1 1940 /* Allocate struct to keep track of the symfile. */
b8b98ad1
TT
1941 xcoff = XNEW (struct coff_symfile_info);
1942 set_objfile_data (objfile, xcoff_objfile_data_key, xcoff);
c906108c
SS
1943
1944 /* XCOFF objects may be reordered, so set OBJF_REORDERED. If we
1945 find this causes a significant slowdown in gdb then we could
1946 set it in the debug symbol readers only when necessary. */
1947 objfile->flags |= OBJF_REORDERED;
c906108c
SS
1948}
1949
1950/* Perform any local cleanups required when we are done with a particular
1951 objfile. I.E, we are in the process of discarding all symbol information
1952 for an objfile, freeing up all memory held for it, and unlinking the
581e13c1 1953 objfile struct from the global list of known objfiles. */
c906108c
SS
1954
1955static void
fba45db2 1956xcoff_symfile_finish (struct objfile *objfile)
c906108c 1957{
c906108c
SS
1958 /* Start with a fresh include table for the next objfile. */
1959 if (inclTable)
1960 {
b8c9b27d 1961 xfree (inclTable);
c906108c
SS
1962 inclTable = NULL;
1963 }
1964 inclIndx = inclLength = inclDepth = 0;
316a8b21
TG
1965
1966 dwarf2_free_objfile (objfile);
c906108c
SS
1967}
1968
1969
1970static void
fba45db2 1971init_stringtab (bfd *abfd, file_ptr offset, struct objfile *objfile)
c906108c
SS
1972{
1973 long length;
1974 int val;
1975 unsigned char lengthbuf[4];
1976 char *strtbl;
b8b98ad1 1977 struct coff_symfile_info *xcoff = XCOFF_DATA (objfile);
c906108c 1978
b8b98ad1 1979 xcoff->strtbl = NULL;
c906108c
SS
1980
1981 if (bfd_seek (abfd, offset, SEEK_SET) < 0)
8a3fe4f8 1982 error (_("cannot seek to string table in %s: %s"),
c906108c
SS
1983 bfd_get_filename (abfd), bfd_errmsg (bfd_get_error ()));
1984
3a42e9d0 1985 val = bfd_bread ((char *) lengthbuf, sizeof lengthbuf, abfd);
c906108c
SS
1986 length = bfd_h_get_32 (abfd, lengthbuf);
1987
1988 /* If no string table is needed, then the file may end immediately
1989 after the symbols. Just return with `strtbl' set to NULL. */
1990
1991 if (val != sizeof lengthbuf || length < sizeof lengthbuf)
1992 return;
1993
581e13c1
MS
1994 /* Allocate string table from objfile_obstack. We will need this table
1995 as long as we have its symbol table around. */
c906108c 1996
4a146b47 1997 strtbl = (char *) obstack_alloc (&objfile->objfile_obstack, length);
b8b98ad1 1998 xcoff->strtbl = strtbl;
c906108c
SS
1999
2000 /* Copy length buffer, the first byte is usually zero and is
2001 used for stabs with a name length of zero. */
2002 memcpy (strtbl, lengthbuf, sizeof lengthbuf);
2003 if (length == sizeof lengthbuf)
2004 return;
2005
3a42e9d0 2006 val = bfd_bread (strtbl + sizeof lengthbuf, length - sizeof lengthbuf, abfd);
c906108c
SS
2007
2008 if (val != length - sizeof lengthbuf)
8a3fe4f8 2009 error (_("cannot read string table from %s: %s"),
c906108c
SS
2010 bfd_get_filename (abfd), bfd_errmsg (bfd_get_error ()));
2011 if (strtbl[length - 1] != '\0')
3e43a32a
MS
2012 error (_("bad symbol file: string table "
2013 "does not end with null character"));
c906108c
SS
2014
2015 return;
2016}
2017\f
2018/* If we have not yet seen a function for this psymtab, this is 0. If we
2019 have seen one, it is the offset in the line numbers of the line numbers
2020 for the psymtab. */
2021static unsigned int first_fun_line_offset;
2022
c906108c
SS
2023/* Allocate and partially fill a partial symtab. It will be
2024 completely filled at the end of the symbol list.
2025
2026 SYMFILE_NAME is the name of the symbol-file we are reading from, and ADDR
2027 is the address relative to which its symbols are (incremental) or 0
581e13c1 2028 (normal). */
c906108c
SS
2029
2030static struct partial_symtab *
0d5cff50
DE
2031xcoff_start_psymtab (struct objfile *objfile,
2032 const char *filename, int first_symnum,
af5bf4ad
SM
2033 std::vector<partial_symbol *> &global_psymbols,
2034 std::vector<partial_symbol *> &static_psymbols)
c906108c
SS
2035{
2036 struct partial_symtab *result =
18a94d75 2037 start_psymtab_common (objfile,
a109c7c1
MS
2038 filename,
2039 /* We fill in textlow later. */
2040 0,
af5bf4ad 2041 global_psymbols, static_psymbols);
c906108c 2042
8d749320
SM
2043 result->read_symtab_private =
2044 XOBNEW (&objfile->objfile_obstack, struct symloc);
c5aa993b 2045 ((struct symloc *) result->read_symtab_private)->first_symnum = first_symnum;
257e7a09 2046 result->read_symtab = xcoff_read_symtab;
c906108c 2047
581e13c1 2048 /* Deduce the source language from the filename for this psymtab. */
c906108c
SS
2049 psymtab_language = deduce_language_from_filename (filename);
2050
2051 return result;
2052}
2053
581e13c1 2054/* Close off the current usage of PST.
c906108c
SS
2055 Returns PST, or NULL if the partial symtab was empty and thrown away.
2056
2057 CAPPING_SYMBOL_NUMBER is the end of pst (exclusive).
2058
2059 INCLUDE_LIST, NUM_INCLUDES, DEPENDENCY_LIST, and NUMBER_DEPENDENCIES
2060 are the information for includes and dependencies. */
2061
2062static struct partial_symtab *
5c80ed9d
TT
2063xcoff_end_psymtab (struct objfile *objfile, struct partial_symtab *pst,
2064 const char **include_list, int num_includes,
2065 int capping_symbol_number,
fba45db2
KB
2066 struct partial_symtab **dependency_list,
2067 int number_dependencies, int textlow_not_set)
c906108c
SS
2068{
2069 int i;
c906108c
SS
2070
2071 if (capping_symbol_number != -1)
c5aa993b 2072 ((struct symloc *) pst->read_symtab_private)->numsyms =
c906108c 2073 capping_symbol_number
c5aa993b
JM
2074 - ((struct symloc *) pst->read_symtab_private)->first_symnum;
2075 ((struct symloc *) pst->read_symtab_private)->lineno_off =
c906108c
SS
2076 first_fun_line_offset;
2077 first_fun_line_offset = 0;
8763cede
DE
2078
2079 end_psymtab_common (objfile, pst);
c906108c
SS
2080
2081 pst->number_of_dependencies = number_dependencies;
2082 if (number_dependencies)
2083 {
8d749320
SM
2084 pst->dependencies = XOBNEWVEC (&objfile->objfile_obstack,
2085 struct partial_symtab *,
2086 number_dependencies);
c906108c 2087 memcpy (pst->dependencies, dependency_list,
c5aa993b 2088 number_dependencies * sizeof (struct partial_symtab *));
c906108c
SS
2089 }
2090 else
2091 pst->dependencies = 0;
2092
2093 for (i = 0; i < num_includes; i++)
2094 {
2095 struct partial_symtab *subpst =
a109c7c1 2096 allocate_psymtab (include_list[i], objfile);
c906108c 2097
e38df1d0
TT
2098 subpst->read_symtab_private = obstack_alloc (&objfile->objfile_obstack,
2099 sizeof (struct symloc));
c5aa993b
JM
2100 ((struct symloc *) subpst->read_symtab_private)->first_symnum = 0;
2101 ((struct symloc *) subpst->read_symtab_private)->numsyms = 0;
c906108c
SS
2102 subpst->textlow = 0;
2103 subpst->texthigh = 0;
2104
2105 /* We could save slight bits of space by only making one of these,
c5aa993b 2106 shared by the entire set of include files. FIXME-someday. */
8d749320
SM
2107 subpst->dependencies =
2108 XOBNEW (&objfile->objfile_obstack, struct partial_symtab *);
c906108c
SS
2109 subpst->dependencies[0] = pst;
2110 subpst->number_of_dependencies = 1;
2111
2112 subpst->globals_offset =
2113 subpst->n_global_syms =
c5aa993b
JM
2114 subpst->statics_offset =
2115 subpst->n_static_syms = 0;
c906108c
SS
2116
2117 subpst->readin = 0;
43f3e411 2118 subpst->compunit_symtab = NULL;
c906108c
SS
2119 subpst->read_symtab = pst->read_symtab;
2120 }
2121
c906108c
SS
2122 if (num_includes == 0
2123 && number_dependencies == 0
2124 && pst->n_global_syms == 0
2125 && pst->n_static_syms == 0)
2126 {
2127 /* Throw away this psymtab, it's empty. We can't deallocate it, since
c5aa993b 2128 it is on the obstack, but we can forget to chain it on the list. */
c906108c 2129 /* Empty psymtabs happen as a result of header files which don't have
c5aa993b 2130 any symbols in them. There can be a lot of them. */
c906108c 2131
5c80ed9d 2132 discard_psymtab (objfile, pst);
c906108c
SS
2133
2134 /* Indicate that psymtab was thrown away. */
be903358 2135 pst = NULL;
c906108c
SS
2136 }
2137 return pst;
2138}
2139
c906108c
SS
2140/* Swap raw symbol at *RAW and put the name in *NAME, the symbol in
2141 *SYMBOL, the first auxent in *AUX. Advance *RAW and *SYMNUMP over
2142 the symbol and its auxents. */
2143
2144static void
fba45db2 2145swap_sym (struct internal_syment *symbol, union internal_auxent *aux,
0d5cff50 2146 const char **name, char **raw, unsigned int *symnump,
fba45db2 2147 struct objfile *objfile)
c906108c
SS
2148{
2149 bfd_coff_swap_sym_in (objfile->obfd, *raw, symbol);
2150 if (symbol->n_zeroes)
2151 {
2152 /* If it's exactly E_SYMNMLEN characters long it isn't
c5aa993b 2153 '\0'-terminated. */
c906108c
SS
2154 if (symbol->n_name[E_SYMNMLEN - 1] != '\0')
2155 {
2156 /* FIXME: wastes memory for symbols which we don't end up putting
2157 into the minimal symbols. */
2158 char *p;
a109c7c1 2159
224c3ddb
SM
2160 p = (char *) obstack_alloc (&objfile->objfile_obstack,
2161 E_SYMNMLEN + 1);
c906108c
SS
2162 strncpy (p, symbol->n_name, E_SYMNMLEN);
2163 p[E_SYMNMLEN] = '\0';
2164 *name = p;
2165 }
2166 else
2167 /* Point to the unswapped name as that persists as long as the
2168 objfile does. */
c5aa993b 2169 *name = ((struct external_syment *) *raw)->e.e_name;
c906108c
SS
2170 }
2171 else if (symbol->n_sclass & 0x80)
2172 {
b8b98ad1 2173 *name = XCOFF_DATA (objfile)->debugsec + symbol->n_offset;
c906108c
SS
2174 }
2175 else
2176 {
b8b98ad1 2177 *name = XCOFF_DATA (objfile)->strtbl + symbol->n_offset;
c906108c
SS
2178 }
2179 ++*symnump;
2180 *raw += coff_data (objfile->obfd)->local_symesz;
2181 if (symbol->n_numaux > 0)
2182 {
2183 bfd_coff_swap_aux_in (objfile->obfd, *raw, symbol->n_type,
2184 symbol->n_sclass, 0, symbol->n_numaux, aux);
2185
2186 *symnump += symbol->n_numaux;
2187 *raw += coff_data (objfile->obfd)->local_symesz * symbol->n_numaux;
2188 }
2189}
2190
23136709
KB
2191static void
2192function_outside_compilation_unit_complaint (const char *arg1)
2193{
2194 complaint (&symfile_complaints,
3e43a32a
MS
2195 _("function `%s' appears to be defined "
2196 "outside of all compilation units"),
23136709
KB
2197 arg1);
2198}
2199
c906108c 2200static void
8dddcb8f
TT
2201scan_xcoff_symtab (minimal_symbol_reader &reader,
2202 struct objfile *objfile)
c906108c 2203{
40c58d95 2204 struct gdbarch *gdbarch = get_objfile_arch (objfile);
581e13c1 2205 CORE_ADDR toc_offset = 0; /* toc offset value in data section. */
0d5cff50 2206 const char *filestring = NULL;
c906108c 2207
0d5cff50 2208 const char *namestring;
c906108c
SS
2209 bfd *abfd;
2210 asection *bfd_sect;
2211 unsigned int nsyms;
2212
2213 /* Current partial symtab */
2214 struct partial_symtab *pst;
2215
581e13c1 2216 /* List of current psymtab's include files. */
0d5cff50 2217 const char **psymtab_include_list;
c906108c
SS
2218 int includes_allocated;
2219 int includes_used;
2220
581e13c1 2221 /* Index within current psymtab dependency list. */
c906108c
SS
2222 struct partial_symtab **dependency_list;
2223 int dependencies_used, dependencies_allocated;
2224
2225 char *sraw_symbol;
2226 struct internal_syment symbol;
96baa820 2227 union internal_auxent main_aux[5];
c906108c
SS
2228 unsigned int ssymnum;
2229
0d5cff50 2230 const char *last_csect_name = NULL; /* Last seen csect's name and value. */
c906108c
SS
2231 CORE_ADDR last_csect_val = 0;
2232 int last_csect_sec = 0;
581e13c1 2233 int misc_func_recorded = 0; /* true if any misc. function. */
c906108c
SS
2234 int textlow_not_set = 1;
2235
2236 pst = (struct partial_symtab *) 0;
2237
2238 includes_allocated = 30;
2239 includes_used = 0;
0d5cff50
DE
2240 psymtab_include_list = (const char **) alloca (includes_allocated *
2241 sizeof (const char *));
c906108c
SS
2242
2243 dependencies_allocated = 30;
2244 dependencies_used = 0;
2245 dependency_list =
2246 (struct partial_symtab **) alloca (dependencies_allocated *
2247 sizeof (struct partial_symtab *));
2248
46212e0b 2249 set_last_source_file (NULL);
c906108c
SS
2250
2251 abfd = objfile->obfd;
13c763f4 2252 next_symbol_text_func = xcoff_next_symbol_text;
c906108c 2253
b8b98ad1
TT
2254 sraw_symbol = XCOFF_DATA (objfile)->symtbl;
2255 nsyms = XCOFF_DATA (objfile)->symtbl_num_syms;
c906108c
SS
2256 ssymnum = 0;
2257 while (ssymnum < nsyms)
2258 {
7a78ae4e 2259 int sclass;
c906108c
SS
2260
2261 QUIT;
2262
7a78ae4e
ND
2263 bfd_coff_swap_sym_in (abfd, sraw_symbol, &symbol);
2264 sclass = symbol.n_sclass;
2265
c906108c
SS
2266 switch (sclass)
2267 {
2268 case C_EXT:
2269 case C_HIDEXT:
55bcecda 2270 case C_WEAKEXT:
c906108c
SS
2271 {
2272 /* The CSECT auxent--always the last auxent. */
2273 union internal_auxent csect_aux;
2274 unsigned int symnum_before = ssymnum;
2275
96baa820 2276 swap_sym (&symbol, &main_aux[0], &namestring, &sraw_symbol,
c906108c
SS
2277 &ssymnum, objfile);
2278 if (symbol.n_numaux > 1)
2279 {
2280 bfd_coff_swap_aux_in
2281 (objfile->obfd,
c5aa993b 2282 sraw_symbol - coff_data (abfd)->local_symesz,
c906108c
SS
2283 symbol.n_type,
2284 symbol.n_sclass,
2285 symbol.n_numaux - 1,
2286 symbol.n_numaux,
2287 &csect_aux);
2288 }
2289 else
96baa820 2290 csect_aux = main_aux[0];
c906108c 2291
977adac5
ND
2292 /* If symbol name starts with ".$" or "$", ignore it. */
2293 if (namestring[0] == '$'
c906108c
SS
2294 || (namestring[0] == '.' && namestring[1] == '$'))
2295 break;
2296
2297 switch (csect_aux.x_csect.x_smtyp & 0x7)
2298 {
2299 case XTY_SD:
2300 switch (csect_aux.x_csect.x_smclas)
2301 {
2302 case XMC_PR:
2303 if (last_csect_name)
2304 {
2305 /* If no misc. function recorded in the last
581e13c1 2306 seen csect, enter it as a function. This
c906108c
SS
2307 will take care of functions like strcmp()
2308 compiled by xlc. */
2309
2310 if (!misc_func_recorded)
2311 {
ec92004f 2312 record_minimal_symbol
8dddcb8f 2313 (reader, last_csect_name, last_csect_val,
ec92004f
JB
2314 mst_text, last_csect_sec, objfile);
2315 misc_func_recorded = 1;
c906108c
SS
2316 }
2317
2318 if (pst != NULL)
2319 {
2320 /* We have to allocate one psymtab for
2321 each program csect, because their text
2322 sections need not be adjacent. */
2323 xcoff_end_psymtab
5c80ed9d
TT
2324 (objfile, pst, psymtab_include_list,
2325 includes_used, symnum_before, dependency_list,
c906108c
SS
2326 dependencies_used, textlow_not_set);
2327 includes_used = 0;
2328 dependencies_used = 0;
2329 /* Give all psymtabs for this source file the same
2330 name. */
2331 pst = xcoff_start_psymtab
d4f3574e 2332 (objfile,
c906108c
SS
2333 filestring,
2334 symnum_before,
af5bf4ad
SM
2335 objfile->global_psymbols,
2336 objfile->static_psymbols);
c906108c
SS
2337 }
2338 }
977adac5
ND
2339 /* Activate the misc_func_recorded mechanism for
2340 compiler- and linker-generated CSECTs like ".strcmp"
2341 and "@FIX1". */
2342 if (namestring && (namestring[0] == '.'
2343 || namestring[0] == '@'))
c906108c
SS
2344 {
2345 last_csect_name = namestring;
2346 last_csect_val = symbol.n_value;
ec92004f 2347 last_csect_sec = symbol.n_scnum;
c906108c
SS
2348 }
2349 if (pst != NULL)
2350 {
2351 CORE_ADDR highval =
a109c7c1
MS
2352 symbol.n_value + csect_aux.x_csect.x_scnlen.l;
2353
c906108c
SS
2354 if (highval > pst->texthigh)
2355 pst->texthigh = highval;
2356 if (pst->textlow == 0 || symbol.n_value < pst->textlow)
2357 pst->textlow = symbol.n_value;
2358 }
2359 misc_func_recorded = 0;
2360 break;
2361
2362 case XMC_RW:
6904b546 2363 case XMC_TD:
c906108c
SS
2364 /* Data variables are recorded in the minimal symbol
2365 table, except for section symbols. */
2366 if (*namestring != '.')
4d1eb6b4 2367 record_minimal_symbol
8dddcb8f 2368 (reader, namestring, symbol.n_value,
c906108c 2369 sclass == C_HIDEXT ? mst_file_data : mst_data,
4d1eb6b4 2370 symbol.n_scnum, objfile);
c906108c
SS
2371 break;
2372
2373 case XMC_TC0:
2374 if (toc_offset)
8a3fe4f8 2375 warning (_("More than one XMC_TC0 symbol found."));
c906108c
SS
2376 toc_offset = symbol.n_value;
2377
3e43a32a
MS
2378 /* Make TOC offset relative to start address of
2379 section. */
c906108c
SS
2380 bfd_sect = secnum_to_bfd_section (symbol.n_scnum, objfile);
2381 if (bfd_sect)
2382 toc_offset -= bfd_section_vma (objfile->obfd, bfd_sect);
2383 break;
2384
2385 case XMC_TC:
2386 /* These symbols tell us where the TOC entry for a
2387 variable is, not the variable itself. */
2388 break;
2389
2390 default:
2391 break;
2392 }
2393 break;
2394
2395 case XTY_LD:
2396 switch (csect_aux.x_csect.x_smclas)
2397 {
2398 case XMC_PR:
2399 /* A function entry point. */
2400
2401 if (first_fun_line_offset == 0 && symbol.n_numaux > 1)
2402 first_fun_line_offset =
96baa820 2403 main_aux[0].x_sym.x_fcnary.x_fcn.x_lnnoptr;
a2e3e93f
SM
2404
2405 record_minimal_symbol
8dddcb8f 2406 (reader, namestring, symbol.n_value,
a2e3e93f
SM
2407 sclass == C_HIDEXT ? mst_file_text : mst_text,
2408 symbol.n_scnum, objfile);
2409 misc_func_recorded = 1;
c906108c
SS
2410 break;
2411
2412 case XMC_GL:
2413 /* shared library function trampoline code entry
581e13c1 2414 point. */
c906108c
SS
2415
2416 /* record trampoline code entries as
2417 mst_solib_trampoline symbol. When we lookup mst
2418 symbols, we will choose mst_text over
581e13c1 2419 mst_solib_trampoline. */
ec92004f 2420 record_minimal_symbol
8dddcb8f 2421 (reader, namestring, symbol.n_value,
ec92004f
JB
2422 mst_solib_trampoline, symbol.n_scnum, objfile);
2423 misc_func_recorded = 1;
c906108c
SS
2424 break;
2425
2426 case XMC_DS:
2427 /* The symbols often have the same names as
2428 debug symbols for functions, and confuse
2429 lookup_symbol. */
2430 break;
2431
2432 default:
2433
2434 /* xlc puts each variable in a separate csect,
2435 so we get an XTY_SD for each variable. But
2436 gcc puts several variables in a csect, so
2437 that each variable only gets an XTY_LD. We
2438 still need to record them. This will
2439 typically be XMC_RW; I suspect XMC_RO and
2440 XMC_BS might be possible too. */
2441 if (*namestring != '.')
4d1eb6b4 2442 record_minimal_symbol
8dddcb8f 2443 (reader, namestring, symbol.n_value,
c906108c 2444 sclass == C_HIDEXT ? mst_file_data : mst_data,
4d1eb6b4 2445 symbol.n_scnum, objfile);
c906108c
SS
2446 break;
2447 }
2448 break;
2449
2450 case XTY_CM:
2451 switch (csect_aux.x_csect.x_smclas)
2452 {
2453 case XMC_RW:
2454 case XMC_BS:
2455 /* Common variables are recorded in the minimal symbol
2456 table, except for section symbols. */
2457 if (*namestring != '.')
4d1eb6b4 2458 record_minimal_symbol
8dddcb8f 2459 (reader, namestring, symbol.n_value,
c906108c 2460 sclass == C_HIDEXT ? mst_file_bss : mst_bss,
4d1eb6b4 2461 symbol.n_scnum, objfile);
c906108c
SS
2462 break;
2463 }
2464 break;
2465
2466 default:
2467 break;
2468 }
2469 }
2470 break;
2471 case C_FILE:
2472 {
2473 unsigned int symnum_before;
2474
2475 symnum_before = ssymnum;
96baa820 2476 swap_sym (&symbol, &main_aux[0], &namestring, &sraw_symbol,
c906108c
SS
2477 &ssymnum, objfile);
2478
2479 /* See if the last csect needs to be recorded. */
2480
2481 if (last_csect_name && !misc_func_recorded)
2482 {
c906108c
SS
2483 /* If no misc. function recorded in the last seen csect, enter
2484 it as a function. This will take care of functions like
2485 strcmp() compiled by xlc. */
2486
8dddcb8f 2487 record_minimal_symbol (reader, last_csect_name, last_csect_val,
ec92004f
JB
2488 mst_text, last_csect_sec, objfile);
2489 misc_func_recorded = 1;
c906108c
SS
2490 }
2491
2492 if (pst)
2493 {
5c80ed9d
TT
2494 xcoff_end_psymtab (objfile, pst, psymtab_include_list,
2495 includes_used, symnum_before,
2496 dependency_list, dependencies_used,
2497 textlow_not_set);
c906108c
SS
2498 includes_used = 0;
2499 dependencies_used = 0;
2500 }
2501 first_fun_line_offset = 0;
2502
2503 /* XCOFF, according to the AIX 3.2 documentation, puts the
2504 filename in cs->c_name. But xlc 1.3.0.2 has decided to
2505 do things the standard COFF way and put it in the auxent.
2506 We use the auxent if the symbol is ".file" and an auxent
2507 exists, otherwise use the symbol itself. */
2508 if (!strcmp (namestring, ".file") && symbol.n_numaux > 0)
2509 {
96baa820 2510 filestring = coff_getfilename (&main_aux[0], objfile);
c906108c
SS
2511 }
2512 else
2513 filestring = namestring;
2514
d4f3574e 2515 pst = xcoff_start_psymtab (objfile,
c906108c
SS
2516 filestring,
2517 symnum_before,
af5bf4ad
SM
2518 objfile->global_psymbols,
2519 objfile->static_psymbols);
c906108c
SS
2520 last_csect_name = NULL;
2521 }
2522 break;
2523
2524 default:
2525 {
23136709 2526 complaint (&symfile_complaints,
3e43a32a
MS
2527 _("Storage class %d not recognized during scan"),
2528 sclass);
c906108c
SS
2529 }
2530 /* FALLTHROUGH */
2531
2532 /* C_FCN is .bf and .ef symbols. I think it is sufficient
2533 to handle only the C_FUN and C_EXT. */
2534 case C_FCN:
2535
2536 case C_BSTAT:
2537 case C_ESTAT:
2538 case C_ARG:
2539 case C_REGPARM:
2540 case C_REG:
2541 case C_TPDEF:
2542 case C_STRTAG:
2543 case C_UNTAG:
2544 case C_ENTAG:
2545 case C_LABEL:
2546 case C_NULL:
2547
2548 /* C_EINCL means we are switching back to the main file. But there
2549 is no reason to care; the only thing we want to know about
2550 includes is the names of all the included (.h) files. */
2551 case C_EINCL:
2552
2553 case C_BLOCK:
2554
2555 /* I don't think C_STAT is used in xcoff; C_HIDEXT appears to be
2556 used instead. */
2557 case C_STAT:
2558
2559 /* I don't think the name of the common block (as opposed to the
2560 variables within it) is something which is user visible
2561 currently. */
2562 case C_BCOMM:
2563 case C_ECOMM:
2564
2565 case C_PSYM:
2566 case C_RPSYM:
2567
2568 /* I think we can ignore C_LSYM; types on xcoff seem to use C_DECL
2569 so C_LSYM would appear to be only for locals. */
2570 case C_LSYM:
2571
2572 case C_AUTO:
2573 case C_RSYM:
2574 {
2575 /* We probably could save a few instructions by assuming that
2576 C_LSYM, C_PSYM, etc., never have auxents. */
7a78ae4e 2577 int naux1 = symbol.n_numaux + 1;
a109c7c1 2578
c906108c 2579 ssymnum += naux1;
7a78ae4e 2580 sraw_symbol += bfd_coff_symesz (abfd) * naux1;
c906108c
SS
2581 }
2582 break;
2583
2584 case C_BINCL:
d5d0a62f 2585 {
581e13c1 2586 /* Mark down an include file in the current psymtab. */
d5d0a62f 2587 enum language tmp_language;
a109c7c1 2588
d5d0a62f
EZ
2589 swap_sym (&symbol, &main_aux[0], &namestring, &sraw_symbol,
2590 &ssymnum, objfile);
2591
2592 tmp_language = deduce_language_from_filename (namestring);
2593
2594 /* Only change the psymtab's language if we've learned
2595 something useful (eg. tmp_language is not language_unknown).
2596 In addition, to match what start_subfile does, never change
2597 from C++ to C. */
2598 if (tmp_language != language_unknown
2599 && (tmp_language != language_c
2600 || psymtab_language != language_cplus))
2601 psymtab_language = tmp_language;
2602
2603 /* In C++, one may expect the same filename to come round many
2604 times, when code is coming alternately from the main file
581e13c1 2605 and from inline functions in other files. So I check to see
d5d0a62f
EZ
2606 if this is a file we've seen before -- either the main
2607 source file, or a previously included file.
2608
2609 This seems to be a lot of time to be spending on N_SOL, but
2610 things like "break c-exp.y:435" need to work (I
2611 suppose the psymtab_include_list could be hashed or put
2612 in a binary tree, if profiling shows this is a major hog). */
7ecb6532 2613 if (pst && strcmp (namestring, pst->filename) == 0)
d5d0a62f 2614 continue;
a109c7c1 2615
d5d0a62f 2616 {
aa1ee363 2617 int i;
a109c7c1 2618
d5d0a62f 2619 for (i = 0; i < includes_used; i++)
7ecb6532 2620 if (strcmp (namestring, psymtab_include_list[i]) == 0)
d5d0a62f
EZ
2621 {
2622 i = -1;
2623 break;
2624 }
2625 if (i == -1)
2626 continue;
2627 }
2628 psymtab_include_list[includes_used++] = namestring;
2629 if (includes_used >= includes_allocated)
2630 {
0d5cff50 2631 const char **orig = psymtab_include_list;
c906108c 2632
0d5cff50 2633 psymtab_include_list = (const char **)
d5d0a62f 2634 alloca ((includes_allocated *= 2) *
0d5cff50 2635 sizeof (const char *));
4efb68b1 2636 memcpy (psymtab_include_list, orig,
0d5cff50 2637 includes_used * sizeof (const char *));
d5d0a62f
EZ
2638 }
2639 continue;
2640 }
c906108c
SS
2641 case C_FUN:
2642 /* The value of the C_FUN is not the address of the function (it
2643 appears to be the address before linking), but as long as it
2644 is smaller than the actual address, then find_pc_partial_function
2645 will use the minimal symbols instead. I hope. */
2646
2647 case C_GSYM:
2648 case C_ECOML:
2649 case C_DECL:
2650 case C_STSYM:
d5d0a62f 2651 {
e28566f7 2652 const char *p;
a109c7c1 2653
d5d0a62f
EZ
2654 swap_sym (&symbol, &main_aux[0], &namestring, &sraw_symbol,
2655 &ssymnum, objfile);
2656
ed4b0e6a 2657 p = strchr (namestring, ':');
d5d0a62f
EZ
2658 if (!p)
2659 continue; /* Not a debugging symbol. */
2660
2661 /* Main processing section for debugging symbols which
2662 the initial read through the symbol tables needs to worry
2663 about. If we reach this point, the symbol which we are
2664 considering is definitely one we are interested in.
2665 p must also contain the (valid) index into the namestring
2666 which indicates the debugging type symbol. */
2667
2668 switch (p[1])
2669 {
2670 case 'S':
3e43a32a
MS
2671 symbol.n_value += ANOFFSET (objfile->section_offsets,
2672 SECT_OFF_DATA (objfile));
149ad273 2673
5e2b427d 2674 if (gdbarch_static_transform_name_p (gdbarch))
149ad273 2675 namestring = gdbarch_static_transform_name
5e2b427d 2676 (gdbarch, namestring);
149ad273 2677
04a679b8 2678 add_psymbol_to_list (namestring, p - namestring, 1,
176620f1 2679 VAR_DOMAIN, LOC_STATIC,
d5d0a62f 2680 &objfile->static_psymbols,
1762568f 2681 symbol.n_value,
d5d0a62f
EZ
2682 psymtab_language, objfile);
2683 continue;
2684
2685 case 'G':
3e43a32a
MS
2686 symbol.n_value += ANOFFSET (objfile->section_offsets,
2687 SECT_OFF_DATA (objfile));
d5d0a62f 2688 /* The addresses in these entries are reported to be
581e13c1 2689 wrong. See the code that reads 'G's for symtabs. */
04a679b8 2690 add_psymbol_to_list (namestring, p - namestring, 1,
176620f1 2691 VAR_DOMAIN, LOC_STATIC,
d5d0a62f 2692 &objfile->global_psymbols,
1762568f 2693 symbol.n_value,
d5d0a62f
EZ
2694 psymtab_language, objfile);
2695 continue;
2696
2697 case 'T':
2698 /* When a 'T' entry is defining an anonymous enum, it
2699 may have a name which is the empty string, or a
2700 single space. Since they're not really defining a
2701 symbol, those shouldn't go in the partial symbol
2702 table. We do pick up the elements of such enums at
2703 'check_enum:', below. */
2704 if (p >= namestring + 2
2705 || (p == namestring + 1
2706 && namestring[0] != ' '))
2707 {
04a679b8 2708 add_psymbol_to_list (namestring, p - namestring, 1,
176620f1 2709 STRUCT_DOMAIN, LOC_TYPEDEF,
d5d0a62f 2710 &objfile->static_psymbols,
1762568f 2711 0, psymtab_language, objfile);
d5d0a62f
EZ
2712 if (p[2] == 't')
2713 {
2714 /* Also a typedef with the same name. */
04a679b8 2715 add_psymbol_to_list (namestring, p - namestring, 1,
176620f1 2716 VAR_DOMAIN, LOC_TYPEDEF,
d5d0a62f 2717 &objfile->static_psymbols,
1762568f 2718 0, psymtab_language, objfile);
d5d0a62f
EZ
2719 p += 1;
2720 }
d5d0a62f
EZ
2721 }
2722 goto check_enum;
2723
2724 case 't':
581e13c1 2725 if (p != namestring) /* a name is there, not just :T... */
d5d0a62f 2726 {
04a679b8 2727 add_psymbol_to_list (namestring, p - namestring, 1,
176620f1 2728 VAR_DOMAIN, LOC_TYPEDEF,
d5d0a62f 2729 &objfile->static_psymbols,
1762568f 2730 0, psymtab_language, objfile);
d5d0a62f
EZ
2731 }
2732 check_enum:
2733 /* If this is an enumerated type, we need to
2734 add all the enum constants to the partial symbol
2735 table. This does not cover enums without names, e.g.
2736 "enum {a, b} c;" in C, but fortunately those are
2737 rare. There is no way for GDB to find those from the
2738 enum type without spending too much time on it. Thus
2739 to solve this problem, the compiler needs to put out the
2740 enum in a nameless type. GCC2 does this. */
2741
2742 /* We are looking for something of the form
2743 <name> ":" ("t" | "T") [<number> "="] "e"
2744 {<constant> ":" <value> ","} ";". */
2745
2746 /* Skip over the colon and the 't' or 'T'. */
2747 p += 2;
2748 /* This type may be given a number. Also, numbers can come
2749 in pairs like (0,26). Skip over it. */
2750 while ((*p >= '0' && *p <= '9')
2751 || *p == '(' || *p == ',' || *p == ')'
2752 || *p == '=')
2753 p++;
2754
2755 if (*p++ == 'e')
2756 {
3e43a32a
MS
2757 /* The aix4 compiler emits extra crud before the
2758 members. */
d5d0a62f
EZ
2759 if (*p == '-')
2760 {
2761 /* Skip over the type (?). */
2762 while (*p != ':')
2763 p++;
2764
2765 /* Skip over the colon. */
2766 p++;
2767 }
2768
2769 /* We have found an enumerated type. */
2770 /* According to comments in read_enum_type
2771 a comma could end it instead of a semicolon.
2772 I don't know where that happens.
2773 Accept either. */
2774 while (*p && *p != ';' && *p != ',')
2775 {
e28566f7 2776 const char *q;
d5d0a62f
EZ
2777
2778 /* Check for and handle cretinous dbx symbol name
2779 continuation! */
2780 if (*p == '\\' || (*p == '?' && p[1] == '\0'))
2781 p = next_symbol_text (objfile);
2782
2783 /* Point to the character after the name
2784 of the enum constant. */
2785 for (q = p; *q && *q != ':'; q++)
2786 ;
2787 /* Note that the value doesn't matter for
2788 enum constants in psymtabs, just in symtabs. */
04a679b8 2789 add_psymbol_to_list (p, q - p, 1,
176620f1 2790 VAR_DOMAIN, LOC_CONST,
1762568f 2791 &objfile->static_psymbols,
d5d0a62f
EZ
2792 0, psymtab_language, objfile);
2793 /* Point past the name. */
2794 p = q;
2795 /* Skip over the value. */
2796 while (*p && *p != ',')
2797 p++;
2798 /* Advance past the comma. */
2799 if (*p)
2800 p++;
2801 }
2802 }
2803 continue;
2804
2805 case 'c':
2806 /* Constant, e.g. from "const" in Pascal. */
04a679b8 2807 add_psymbol_to_list (namestring, p - namestring, 1,
176620f1 2808 VAR_DOMAIN, LOC_CONST,
1762568f 2809 &objfile->static_psymbols,
d5d0a62f
EZ
2810 0, psymtab_language, objfile);
2811 continue;
2812
2813 case 'f':
2814 if (! pst)
2815 {
2816 int name_len = p - namestring;
224c3ddb 2817 char *name = (char *) xmalloc (name_len + 1);
a109c7c1 2818
d5d0a62f
EZ
2819 memcpy (name, namestring, name_len);
2820 name[name_len] = '\0';
23136709 2821 function_outside_compilation_unit_complaint (name);
d5d0a62f
EZ
2822 xfree (name);
2823 }
3e43a32a
MS
2824 symbol.n_value += ANOFFSET (objfile->section_offsets,
2825 SECT_OFF_TEXT (objfile));
04a679b8 2826 add_psymbol_to_list (namestring, p - namestring, 1,
176620f1 2827 VAR_DOMAIN, LOC_BLOCK,
d5d0a62f 2828 &objfile->static_psymbols,
1762568f 2829 symbol.n_value,
d5d0a62f
EZ
2830 psymtab_language, objfile);
2831 continue;
2832
2833 /* Global functions were ignored here, but now they
2834 are put into the global psymtab like one would expect.
2835 They're also in the minimal symbol table. */
2836 case 'F':
2837 if (! pst)
2838 {
2839 int name_len = p - namestring;
224c3ddb 2840 char *name = (char *) xmalloc (name_len + 1);
a109c7c1 2841
d5d0a62f
EZ
2842 memcpy (name, namestring, name_len);
2843 name[name_len] = '\0';
23136709 2844 function_outside_compilation_unit_complaint (name);
d5d0a62f
EZ
2845 xfree (name);
2846 }
9f1d5432
PH
2847
2848 /* We need only the minimal symbols for these
581e13c1 2849 loader-generated definitions. Keeping the global
9f1d5432 2850 symbols leads to "in psymbols but not in symbols"
581e13c1 2851 errors. */
61012eef 2852 if (startswith (namestring, "@FIX"))
9f1d5432
PH
2853 continue;
2854
3e43a32a
MS
2855 symbol.n_value += ANOFFSET (objfile->section_offsets,
2856 SECT_OFF_TEXT (objfile));
04a679b8 2857 add_psymbol_to_list (namestring, p - namestring, 1,
176620f1 2858 VAR_DOMAIN, LOC_BLOCK,
d5d0a62f 2859 &objfile->global_psymbols,
1762568f 2860 symbol.n_value,
d5d0a62f
EZ
2861 psymtab_language, objfile);
2862 continue;
2863
2864 /* Two things show up here (hopefully); static symbols of
2865 local scope (static used inside braces) or extensions
2866 of structure symbols. We can ignore both. */
2867 case 'V':
2868 case '(':
2869 case '0':
2870 case '1':
2871 case '2':
2872 case '3':
2873 case '4':
2874 case '5':
2875 case '6':
2876 case '7':
2877 case '8':
2878 case '9':
2879 case '-':
3e43a32a
MS
2880 case '#': /* For symbol identification (used in
2881 live ranges). */
d5d0a62f
EZ
2882 continue;
2883
2884 case ':':
2885 /* It is a C++ nested symbol. We don't need to record it
2886 (I don't think); if we try to look up foo::bar::baz,
2887 then symbols for the symtab containing foo should get
2888 read in, I think. */
2889 /* Someone says sun cc puts out symbols like
2890 /foo/baz/maclib::/usr/local/bin/maclib,
2891 which would get here with a symbol type of ':'. */
2892 continue;
2893
2894 default:
3e43a32a
MS
2895 /* Unexpected symbol descriptor. The second and
2896 subsequent stabs of a continued stab can show up
2897 here. The question is whether they ever can mimic
2898 a normal stab--it would be nice if not, since we
2899 certainly don't want to spend the time searching to
2900 the end of every string looking for a
2901 backslash. */
d5d0a62f 2902
23136709 2903 complaint (&symfile_complaints,
e2e0b3e5 2904 _("unknown symbol descriptor `%c'"), p[1]);
d5d0a62f
EZ
2905
2906 /* Ignore it; perhaps it is an extension that we don't
2907 know about. */
2908 continue;
2909 }
2910 }
c906108c
SS
2911 }
2912 }
2913
2914 if (pst)
2915 {
5c80ed9d 2916 xcoff_end_psymtab (objfile, pst, psymtab_include_list, includes_used,
c906108c
SS
2917 ssymnum, dependency_list,
2918 dependencies_used, textlow_not_set);
2919 }
2920
581e13c1
MS
2921 /* Record the toc offset value of this symbol table into objfile
2922 structure. If no XMC_TC0 is found, toc_offset should be zero.
2923 Another place to obtain this information would be file auxiliary
2924 header. */
c906108c 2925
b8b98ad1 2926 XCOFF_DATA (objfile)->toc_offset = toc_offset;
c906108c
SS
2927}
2928
2929/* Return the toc offset value for a given objfile. */
2930
2931CORE_ADDR
63807e1d 2932xcoff_get_toc_offset (struct objfile *objfile)
c906108c
SS
2933{
2934 if (objfile)
b8b98ad1 2935 return XCOFF_DATA (objfile)->toc_offset;
c906108c
SS
2936 return 0;
2937}
2938
2939/* Scan and build partial symbols for a symbol file.
2940 We have been initialized by a call to dbx_symfile_init, which
2941 put all the relevant info into a "struct dbx_symfile_info",
2942 hung off the objfile structure.
2943
2944 SECTION_OFFSETS contains offsets relative to which the symbols in the
581e13c1
MS
2945 various sections are (depending where the sections were actually
2946 loaded). */
c906108c
SS
2947
2948static void
b15cc25c 2949xcoff_initial_scan (struct objfile *objfile, symfile_add_flags symfile_flags)
c906108c
SS
2950{
2951 bfd *abfd;
2952 int val;
c5aa993b
JM
2953 int num_symbols; /* # of symbols */
2954 file_ptr symtab_offset; /* symbol table and */
2955 file_ptr stringtab_offset; /* string table file offsets */
c906108c 2956 struct coff_symfile_info *info;
4262abfb 2957 const char *name;
c906108c
SS
2958 unsigned int size;
2959
b8b98ad1 2960 info = XCOFF_DATA (objfile);
c906108c 2961 symfile_bfd = abfd = objfile->obfd;
4262abfb 2962 name = objfile_name (objfile);
c906108c
SS
2963
2964 num_symbols = bfd_get_symcount (abfd); /* # of symbols */
2965 symtab_offset = obj_sym_filepos (abfd); /* symbol table file offset */
2966 stringtab_offset = symtab_offset +
c5aa993b 2967 num_symbols * coff_data (abfd)->local_symesz;
c906108c
SS
2968
2969 info->min_lineno_offset = 0;
2970 info->max_lineno_offset = 0;
2971 bfd_map_over_sections (abfd, find_linenos, info);
2972
2973 if (num_symbols > 0)
2974 {
2975 /* Read the string table. */
2976 init_stringtab (abfd, stringtab_offset, objfile);
2977
97cbe998
SDJ
2978 /* Read the .debug section, if present and if we're not ignoring
2979 it. */
2980 if (!(objfile->flags & OBJF_READNEVER))
2981 {
2982 struct bfd_section *secp;
2983 bfd_size_type length;
2984 bfd_byte *debugsec = NULL;
c906108c 2985
97cbe998
SDJ
2986 secp = bfd_get_section_by_name (abfd, ".debug");
2987 if (secp)
2988 {
2989 length = bfd_section_size (abfd, secp);
2990 if (length)
2991 {
2992 debugsec
2993 = (bfd_byte *) obstack_alloc (&objfile->objfile_obstack,
2994 length);
c906108c 2995
97cbe998
SDJ
2996 if (!bfd_get_full_section_contents (abfd, secp, &debugsec))
2997 {
2998 error (_("Error reading .debug section of `%s': %s"),
2999 name, bfd_errmsg (bfd_get_error ()));
3000 }
3001 }
3002 }
3003 info->debugsec = (char *) debugsec;
3004 }
c906108c
SS
3005 }
3006
3007 /* Read the symbols. We keep them in core because we will want to
3008 access them randomly in read_symbol*. */
3009 val = bfd_seek (abfd, symtab_offset, SEEK_SET);
3010 if (val < 0)
8a3fe4f8 3011 error (_("Error reading symbols from %s: %s"),
c906108c
SS
3012 name, bfd_errmsg (bfd_get_error ()));
3013 size = coff_data (abfd)->local_symesz * num_symbols;
224c3ddb 3014 info->symtbl = (char *) obstack_alloc (&objfile->objfile_obstack, size);
b8b98ad1
TT
3015 info->symtbl_num_syms = num_symbols;
3016
3017 val = bfd_bread (info->symtbl, size, abfd);
c906108c 3018 if (val != size)
e2e0b3e5 3019 perror_with_name (_("reading symbol table"));
c906108c 3020
581e13c1 3021 /* If we are reinitializing, or if we have never loaded syms yet, init. */
af5bf4ad
SM
3022 if (objfile->global_psymbols.capacity () == 0
3023 && objfile->static_psymbols.capacity () == 0)
c906108c
SS
3024 /* I'm not sure how how good num_symbols is; the rule of thumb in
3025 init_psymbol_list was developed for a.out. On the one hand,
3026 num_symbols includes auxents. On the other hand, it doesn't
3027 include N_SLINE. */
3028 init_psymbol_list (objfile, num_symbols);
3029
3030 free_pending_blocks ();
c906108c 3031
33c7c59d 3032 scoped_free_pendings free_pending;
d25e8719 3033 minimal_symbol_reader reader (objfile);
c906108c
SS
3034
3035 /* Now that the symbol table data of the executable file are all in core,
3036 process them and define symbols accordingly. */
3037
8dddcb8f 3038 scan_xcoff_symtab (reader, objfile);
c906108c
SS
3039
3040 /* Install any minimal symbols that have been collected as the current
581e13c1 3041 minimal symbols for this objfile. */
c906108c 3042
d25e8719 3043 reader.install ();
c906108c 3044
316a8b21
TG
3045 /* DWARF2 sections. */
3046
3047 if (dwarf2_has_info (objfile, &dwarf2_xcoff_names))
3048 dwarf2_build_psymtabs (objfile);
3049
3050 dwarf2_build_frame_info (objfile);
c906108c
SS
3051}
3052\f
d4f3574e 3053static void
3e43a32a 3054xcoff_symfile_offsets (struct objfile *objfile,
66f65e2b 3055 const struct section_addr_info *addrs)
c906108c 3056{
4d1eb6b4 3057 const char *first_section_name;
c906108c 3058
4d1eb6b4 3059 default_symfile_offsets (objfile, addrs);
c906108c 3060
4d1eb6b4
JB
3061 /* Oneof the weird side-effects of default_symfile_offsets is that
3062 it sometimes sets some section indices to zero for sections that,
3063 in fact do not exist. See the body of default_symfile_offsets
3064 for more info on when that happens. Undo that, as this then allows
3065 us to test whether the associated section exists or not, and then
3066 access it quickly (without searching it again). */
b8fbeb18 3067
4d1eb6b4
JB
3068 if (objfile->num_sections == 0)
3069 return; /* Is that even possible? Better safe than sorry. */
b8fbeb18 3070
4d1eb6b4
JB
3071 first_section_name
3072 = bfd_section_name (objfile->obfd, objfile->sections[0].the_bfd_section);
b8fbeb18 3073
4d1eb6b4
JB
3074 if (objfile->sect_index_text == 0
3075 && strcmp (first_section_name, ".text") != 0)
3076 objfile->sect_index_text = -1;
b8fbeb18 3077
4d1eb6b4
JB
3078 if (objfile->sect_index_data == 0
3079 && strcmp (first_section_name, ".data") != 0)
3080 objfile->sect_index_data = -1;
3081
3082 if (objfile->sect_index_bss == 0
3083 && strcmp (first_section_name, ".bss") != 0)
3084 objfile->sect_index_bss = -1;
3085
3086 if (objfile->sect_index_rodata == 0
3087 && strcmp (first_section_name, ".rodata") != 0)
3088 objfile->sect_index_rodata = -1;
c906108c
SS
3089}
3090
3091/* Register our ability to parse symbols for xcoff BFD files. */
3092
00b5771c 3093static const struct sym_fns xcoff_sym_fns =
c906108c
SS
3094{
3095
7a78ae4e 3096 /* It is possible that coff and xcoff should be merged as
c906108c
SS
3097 they do have fundamental similarities (for example, the extra storage
3098 classes used for stabs could presumably be recognized in any COFF file).
3099 However, in addition to obvious things like all the csect hair, there are
3100 some subtler differences between xcoffread.c and coffread.c, notably
3101 the fact that coffread.c has no need to read in all the symbols, but
3102 xcoffread.c reads all the symbols and does in fact randomly access them
3103 (in C_BSTAT and line number processing). */
3104
3e43a32a
MS
3105 xcoff_new_init, /* init anything gbl to entire symtab */
3106 xcoff_symfile_init, /* read initial info, setup for sym_read() */
3107 xcoff_initial_scan, /* read a symbol file into symtab */
b11896a5 3108 NULL, /* sym_read_psymbols */
3e43a32a
MS
3109 xcoff_symfile_finish, /* finished with file, cleanup */
3110 xcoff_symfile_offsets, /* xlate offsets ext->int form */
3111 default_symfile_segments, /* Get segment information from a file. */
3112 aix_process_linenos,
3113 default_symfile_relocate, /* Relocate a debug section. */
55aa24fb 3114 NULL, /* sym_probe_fns */
00b5771c 3115 &psym_functions
c906108c
SS
3116};
3117
d5367fe1
JB
3118/* Same as xcoff_get_n_import_files, but for core files. */
3119
3120static int
3121xcoff_get_core_n_import_files (bfd *abfd)
3122{
3123 asection *sect = bfd_get_section_by_name (abfd, ".ldinfo");
3124 gdb_byte buf[4];
3125 file_ptr offset = 0;
3126 int n_entries = 0;
3127
3128 if (sect == NULL)
3129 return -1; /* Not a core file. */
3130
3131 for (offset = 0; offset < bfd_get_section_size (sect);)
3132 {
3133 int next;
3134
3135 n_entries++;
3136
3137 if (!bfd_get_section_contents (abfd, sect, buf, offset, 4))
3138 return -1;
3139 next = bfd_get_32 (abfd, buf);
3140 if (next == 0)
3141 break; /* This is the last entry. */
3142 offset += next;
3143 }
3144
3145 /* Return the number of entries, excluding the first one, which is
3146 the path to the executable that produced this core file. */
3147 return n_entries - 1;
3148}
3149
3150/* Return the number of import files (shared libraries) that the given
3151 BFD depends on. Return -1 if this number could not be computed. */
3152
3153int
3154xcoff_get_n_import_files (bfd *abfd)
3155{
3156 asection *sect = bfd_get_section_by_name (abfd, ".loader");
3157 gdb_byte buf[4];
3158 int l_nimpid;
3159
3160 /* If the ".loader" section does not exist, the objfile is probably
3161 not an executable. Might be a core file... */
3162 if (sect == NULL)
3163 return xcoff_get_core_n_import_files (abfd);
3164
3165 /* The number of entries in the Import Files Table is stored in
3166 field l_nimpid. This field is always at offset 16, and is
3167 always 4 bytes long. Read those 4 bytes. */
3168
3169 if (!bfd_get_section_contents (abfd, sect, buf, 16, 4))
3170 return -1;
3171 l_nimpid = bfd_get_32 (abfd, buf);
3172
3173 /* By convention, the first entry is the default LIBPATH value
3174 to be used by the system loader, so it does not count towards
3175 the number of import files. */
3176 return l_nimpid - 1;
3177}
3178
b8b98ad1
TT
3179/* Free the per-objfile xcoff data. */
3180
3181static void
3182xcoff_free_info (struct objfile *objfile, void *arg)
3183{
3184 xfree (arg);
3185}
3186
c906108c 3187void
fba45db2 3188_initialize_xcoffread (void)
c906108c 3189{
c256e171 3190 add_symtab_fns (bfd_target_xcoff_flavour, &xcoff_sym_fns);
b8b98ad1
TT
3191
3192 xcoff_objfile_data_key = register_objfile_data_with_cleanup (NULL,
3193 xcoff_free_info);
c906108c 3194}
This page took 2.962137 seconds and 4 git commands to generate.