daily update
[deliverable/binutils-gdb.git] / gdb / dwarf2read.c
CommitLineData
c906108c 1/* DWARF 2 debugging format support for GDB.
917c78fc 2
6aba47ca
DJ
3 Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003,
4 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
c906108c
SS
5
6 Adapted by Gary Funck (gary@intrepid.com), Intrepid Technology,
7 Inc. with support from Florida State University (under contract
8 with the Ada Joint Program Office), and Silicon Graphics, Inc.
9 Initial contribution by Brent Benson, Harris Computer Systems, Inc.,
10 based on Fred Fish's (Cygnus Support) implementation of DWARF 1
11 support in dwarfread.c
12
c5aa993b 13 This file is part of GDB.
c906108c 14
c5aa993b
JM
15 This program is free software; you can redistribute it and/or modify
16 it under the terms of the GNU General Public License as published by
17 the Free Software Foundation; either version 2 of the License, or (at
18 your option) any later version.
c906108c 19
c5aa993b
JM
20 This program is distributed in the hope that it will be useful, but
21 WITHOUT ANY WARRANTY; without even the implied warranty of
22 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
23 General Public License for more details.
c906108c 24
c5aa993b
JM
25 You should have received a copy of the GNU General Public License
26 along with this program; if not, write to the Free Software
197e01b6
EZ
27 Foundation, Inc., 51 Franklin Street, Fifth Floor,
28 Boston, MA 02110-1301, USA. */
c906108c
SS
29
30#include "defs.h"
31#include "bfd.h"
c906108c
SS
32#include "symtab.h"
33#include "gdbtypes.h"
c906108c
SS
34#include "objfiles.h"
35#include "elf/dwarf2.h"
36#include "buildsym.h"
37#include "demangle.h"
38#include "expression.h"
d5166ae1 39#include "filenames.h" /* for DOSish file names */
2e276125 40#include "macrotab.h"
c906108c
SS
41#include "language.h"
42#include "complaints.h"
357e46e7 43#include "bcache.h"
4c2df51b
DJ
44#include "dwarf2expr.h"
45#include "dwarf2loc.h"
9219021c 46#include "cp-support.h"
72bf9492 47#include "hashtab.h"
ae038cb0
DJ
48#include "command.h"
49#include "gdbcmd.h"
4c2df51b 50
c906108c
SS
51#include <fcntl.h>
52#include "gdb_string.h"
4bdf3d34 53#include "gdb_assert.h"
c906108c
SS
54#include <sys/types.h>
55
d8151005
DJ
56/* A note on memory usage for this file.
57
58 At the present time, this code reads the debug info sections into
59 the objfile's objfile_obstack. A definite improvement for startup
60 time, on platforms which do not emit relocations for debug
61 sections, would be to use mmap instead. The object's complete
62 debug information is loaded into memory, partly to simplify
63 absolute DIE references.
64
65 Whether using obstacks or mmap, the sections should remain loaded
66 until the objfile is released, and pointers into the section data
67 can be used for any other data associated to the objfile (symbol
68 names, type names, location expressions to name a few). */
69
88496bb5
MS
70#ifndef DWARF2_REG_TO_REGNUM
71#define DWARF2_REG_TO_REGNUM(REG) (REG)
72#endif
73
107d2387 74#if 0
357e46e7 75/* .debug_info header for a compilation unit
c906108c
SS
76 Because of alignment constraints, this structure has padding and cannot
77 be mapped directly onto the beginning of the .debug_info section. */
78typedef struct comp_unit_header
79 {
80 unsigned int length; /* length of the .debug_info
81 contribution */
82 unsigned short version; /* version number -- 2 for DWARF
83 version 2 */
84 unsigned int abbrev_offset; /* offset into .debug_abbrev section */
85 unsigned char addr_size; /* byte size of an address -- 4 */
86 }
87_COMP_UNIT_HEADER;
88#define _ACTUAL_COMP_UNIT_HEADER_SIZE 11
107d2387 89#endif
c906108c
SS
90
91/* .debug_pubnames header
92 Because of alignment constraints, this structure has padding and cannot
93 be mapped directly onto the beginning of the .debug_info section. */
94typedef struct pubnames_header
95 {
96 unsigned int length; /* length of the .debug_pubnames
97 contribution */
98 unsigned char version; /* version number -- 2 for DWARF
99 version 2 */
100 unsigned int info_offset; /* offset into .debug_info section */
101 unsigned int info_size; /* byte size of .debug_info section
102 portion */
103 }
104_PUBNAMES_HEADER;
105#define _ACTUAL_PUBNAMES_HEADER_SIZE 13
106
107/* .debug_pubnames header
108 Because of alignment constraints, this structure has padding and cannot
109 be mapped directly onto the beginning of the .debug_info section. */
110typedef struct aranges_header
111 {
112 unsigned int length; /* byte len of the .debug_aranges
113 contribution */
114 unsigned short version; /* version number -- 2 for DWARF
115 version 2 */
116 unsigned int info_offset; /* offset into .debug_info section */
117 unsigned char addr_size; /* byte size of an address */
118 unsigned char seg_size; /* byte size of segment descriptor */
119 }
120_ARANGES_HEADER;
121#define _ACTUAL_ARANGES_HEADER_SIZE 12
122
123/* .debug_line statement program prologue
124 Because of alignment constraints, this structure has padding and cannot
125 be mapped directly onto the beginning of the .debug_info section. */
126typedef struct statement_prologue
127 {
128 unsigned int total_length; /* byte length of the statement
129 information */
130 unsigned short version; /* version number -- 2 for DWARF
131 version 2 */
132 unsigned int prologue_length; /* # bytes between prologue &
133 stmt program */
134 unsigned char minimum_instruction_length; /* byte size of
135 smallest instr */
136 unsigned char default_is_stmt; /* initial value of is_stmt
137 register */
138 char line_base;
139 unsigned char line_range;
140 unsigned char opcode_base; /* number assigned to first special
141 opcode */
142 unsigned char *standard_opcode_lengths;
143 }
144_STATEMENT_PROLOGUE;
145
6502dd73
DJ
146static const struct objfile_data *dwarf2_objfile_data_key;
147
148struct dwarf2_per_objfile
149{
150 /* Sizes of debugging sections. */
151 unsigned int info_size;
152 unsigned int abbrev_size;
153 unsigned int line_size;
154 unsigned int pubnames_size;
155 unsigned int aranges_size;
156 unsigned int loc_size;
157 unsigned int macinfo_size;
158 unsigned int str_size;
159 unsigned int ranges_size;
160 unsigned int frame_size;
161 unsigned int eh_frame_size;
162
163 /* Loaded data from the sections. */
fe1b8b76
JB
164 gdb_byte *info_buffer;
165 gdb_byte *abbrev_buffer;
166 gdb_byte *line_buffer;
167 gdb_byte *str_buffer;
168 gdb_byte *macinfo_buffer;
169 gdb_byte *ranges_buffer;
170 gdb_byte *loc_buffer;
ae038cb0 171
10b3939b
DJ
172 /* A list of all the compilation units. This is used to locate
173 the target compilation unit of a particular reference. */
ae038cb0
DJ
174 struct dwarf2_per_cu_data **all_comp_units;
175
176 /* The number of compilation units in ALL_COMP_UNITS. */
177 int n_comp_units;
178
179 /* A chain of compilation units that are currently read in, so that
180 they can be freed later. */
181 struct dwarf2_per_cu_data *read_in_chain;
72dca2f5
FR
182
183 /* A flag indicating wether this objfile has a section loaded at a
184 VMA of 0. */
185 int has_section_at_zero;
6502dd73
DJ
186};
187
188static struct dwarf2_per_objfile *dwarf2_per_objfile;
c906108c 189
086df311
DJ
190static asection *dwarf_info_section;
191static asection *dwarf_abbrev_section;
192static asection *dwarf_line_section;
193static asection *dwarf_pubnames_section;
194static asection *dwarf_aranges_section;
195static asection *dwarf_loc_section;
196static asection *dwarf_macinfo_section;
197static asection *dwarf_str_section;
198static asection *dwarf_ranges_section;
199asection *dwarf_frame_section;
200asection *dwarf_eh_frame_section;
201
c906108c
SS
202/* names of the debugging sections */
203
204#define INFO_SECTION ".debug_info"
205#define ABBREV_SECTION ".debug_abbrev"
206#define LINE_SECTION ".debug_line"
207#define PUBNAMES_SECTION ".debug_pubnames"
208#define ARANGES_SECTION ".debug_aranges"
209#define LOC_SECTION ".debug_loc"
210#define MACINFO_SECTION ".debug_macinfo"
211#define STR_SECTION ".debug_str"
af34e669 212#define RANGES_SECTION ".debug_ranges"
b6af0555
JS
213#define FRAME_SECTION ".debug_frame"
214#define EH_FRAME_SECTION ".eh_frame"
c906108c
SS
215
216/* local data types */
217
57349743
JB
218/* We hold several abbreviation tables in memory at the same time. */
219#ifndef ABBREV_HASH_SIZE
220#define ABBREV_HASH_SIZE 121
221#endif
222
107d2387
AC
223/* The data in a compilation unit header, after target2host
224 translation, looks like this. */
c906108c 225struct comp_unit_head
a738430d
MK
226{
227 unsigned long length;
228 short version;
229 unsigned int abbrev_offset;
230 unsigned char addr_size;
231 unsigned char signed_addr_p;
57349743 232
a738430d
MK
233 /* Size of file offsets; either 4 or 8. */
234 unsigned int offset_size;
57349743 235
a738430d
MK
236 /* Size of the length field; either 4 or 12. */
237 unsigned int initial_length_size;
57349743 238
a738430d
MK
239 /* Offset to the first byte of this compilation unit header in the
240 .debug_info section, for resolving relative reference dies. */
241 unsigned int offset;
57349743 242
a738430d
MK
243 /* Pointer to this compilation unit header in the .debug_info
244 section. */
fe1b8b76 245 gdb_byte *cu_head_ptr;
57349743 246
a738430d
MK
247 /* Pointer to the first die of this compilation unit. This will be
248 the first byte following the compilation unit header. */
fe1b8b76 249 gdb_byte *first_die_ptr;
af34e669 250
a738430d
MK
251 /* Pointer to the next compilation unit header in the program. */
252 struct comp_unit_head *next;
0d53c4c4 253
a738430d
MK
254 /* Base address of this compilation unit. */
255 CORE_ADDR base_address;
0d53c4c4 256
a738430d
MK
257 /* Non-zero if base_address has been set. */
258 int base_known;
259};
c906108c 260
10b3939b
DJ
261/* Fixed size for the DIE hash table. */
262#ifndef REF_HASH_SIZE
263#define REF_HASH_SIZE 1021
264#endif
265
e7c27a73
DJ
266/* Internal state when decoding a particular compilation unit. */
267struct dwarf2_cu
268{
269 /* The objfile containing this compilation unit. */
270 struct objfile *objfile;
271
272 /* The header of the compilation unit.
273
274 FIXME drow/2003-11-10: Some of the things from the comp_unit_head
f3dd6933 275 should logically be moved to the dwarf2_cu structure. */
e7c27a73 276 struct comp_unit_head header;
e142c38c
DJ
277
278 struct function_range *first_fn, *last_fn, *cached_fn;
279
280 /* The language we are debugging. */
281 enum language language;
282 const struct language_defn *language_defn;
283
b0f35d58
DL
284 const char *producer;
285
e142c38c
DJ
286 /* The generic symbol table building routines have separate lists for
287 file scope symbols and all all other scopes (local scopes). So
288 we need to select the right one to pass to add_symbol_to_list().
289 We do it by keeping a pointer to the correct list in list_in_scope.
290
291 FIXME: The original dwarf code just treated the file scope as the
292 first local scope, and all other local scopes as nested local
293 scopes, and worked fine. Check to see if we really need to
294 distinguish these in buildsym.c. */
295 struct pending **list_in_scope;
296
297 /* Maintain an array of referenced fundamental types for the current
298 compilation unit being read. For DWARF version 1, we have to construct
299 the fundamental types on the fly, since no information about the
300 fundamental types is supplied. Each such fundamental type is created by
301 calling a language dependent routine to create the type, and then a
302 pointer to that type is then placed in the array at the index specified
303 by it's FT_<TYPENAME> value. The array has a fixed size set by the
304 FT_NUM_MEMBERS compile time constant, which is the number of predefined
305 fundamental types gdb knows how to construct. */
306 struct type *ftypes[FT_NUM_MEMBERS]; /* Fundamental types */
f3dd6933
DJ
307
308 /* DWARF abbreviation table associated with this compilation unit. */
309 struct abbrev_info **dwarf2_abbrevs;
310
311 /* Storage for the abbrev table. */
312 struct obstack abbrev_obstack;
72bf9492
DJ
313
314 /* Hash table holding all the loaded partial DIEs. */
315 htab_t partial_dies;
316
317 /* Storage for things with the same lifetime as this read-in compilation
318 unit, including partial DIEs. */
319 struct obstack comp_unit_obstack;
320
ae038cb0
DJ
321 /* When multiple dwarf2_cu structures are living in memory, this field
322 chains them all together, so that they can be released efficiently.
323 We will probably also want a generation counter so that most-recently-used
324 compilation units are cached... */
325 struct dwarf2_per_cu_data *read_in_chain;
326
327 /* Backchain to our per_cu entry if the tree has been built. */
328 struct dwarf2_per_cu_data *per_cu;
329
330 /* How many compilation units ago was this CU last referenced? */
331 int last_used;
332
10b3939b
DJ
333 /* A hash table of die offsets for following references. */
334 struct die_info *die_ref_table[REF_HASH_SIZE];
335
336 /* Full DIEs if read in. */
337 struct die_info *dies;
338
339 /* A set of pointers to dwarf2_per_cu_data objects for compilation
340 units referenced by this one. Only set during full symbol processing;
341 partial symbol tables do not have dependencies. */
342 htab_t dependencies;
343
cb1df416
DJ
344 /* Header data from the line table, during full symbol processing. */
345 struct line_header *line_header;
346
ae038cb0
DJ
347 /* Mark used when releasing cached dies. */
348 unsigned int mark : 1;
349
350 /* This flag will be set if this compilation unit might include
351 inter-compilation-unit references. */
352 unsigned int has_form_ref_addr : 1;
353
72bf9492
DJ
354 /* This flag will be set if this compilation unit includes any
355 DW_TAG_namespace DIEs. If we know that there are explicit
356 DIEs for namespaces, we don't need to try to infer them
357 from mangled names. */
358 unsigned int has_namespace_info : 1;
e7c27a73
DJ
359};
360
10b3939b
DJ
361/* Persistent data held for a compilation unit, even when not
362 processing it. We put a pointer to this structure in the
363 read_symtab_private field of the psymtab. If we encounter
364 inter-compilation-unit references, we also maintain a sorted
365 list of all compilation units. */
366
ae038cb0
DJ
367struct dwarf2_per_cu_data
368{
5afb4e99 369 /* The start offset and length of this compilation unit. 2**30-1
ae038cb0
DJ
370 bytes should suffice to store the length of any compilation unit
371 - if it doesn't, GDB will fall over anyway. */
372 unsigned long offset;
5afb4e99 373 unsigned long length : 30;
ae038cb0
DJ
374
375 /* Flag indicating this compilation unit will be read in before
376 any of the current compilation units are processed. */
377 unsigned long queued : 1;
378
5afb4e99
DJ
379 /* This flag will be set if we need to load absolutely all DIEs
380 for this compilation unit, instead of just the ones we think
381 are interesting. It gets set if we look for a DIE in the
382 hash table and don't find it. */
383 unsigned int load_all_dies : 1;
384
ae038cb0
DJ
385 /* Set iff currently read in. */
386 struct dwarf2_cu *cu;
1c379e20
DJ
387
388 /* If full symbols for this CU have been read in, then this field
389 holds a map of DIE offsets to types. It isn't always possible
390 to reconstruct this information later, so we have to preserve
391 it. */
1c379e20 392 htab_t type_hash;
10b3939b 393
31ffec48
DJ
394 /* The partial symbol table associated with this compilation unit,
395 or NULL for partial units (which do not have an associated
396 symtab). */
10b3939b 397 struct partial_symtab *psymtab;
ae038cb0
DJ
398};
399
debd256d
JB
400/* The line number information for a compilation unit (found in the
401 .debug_line section) begins with a "statement program header",
402 which contains the following information. */
403struct line_header
404{
405 unsigned int total_length;
406 unsigned short version;
407 unsigned int header_length;
408 unsigned char minimum_instruction_length;
409 unsigned char default_is_stmt;
410 int line_base;
411 unsigned char line_range;
412 unsigned char opcode_base;
413
414 /* standard_opcode_lengths[i] is the number of operands for the
415 standard opcode whose value is i. This means that
416 standard_opcode_lengths[0] is unused, and the last meaningful
417 element is standard_opcode_lengths[opcode_base - 1]. */
418 unsigned char *standard_opcode_lengths;
419
420 /* The include_directories table. NOTE! These strings are not
421 allocated with xmalloc; instead, they are pointers into
422 debug_line_buffer. If you try to free them, `free' will get
423 indigestion. */
424 unsigned int num_include_dirs, include_dirs_size;
425 char **include_dirs;
426
427 /* The file_names table. NOTE! These strings are not allocated
428 with xmalloc; instead, they are pointers into debug_line_buffer.
429 Don't try to free them directly. */
430 unsigned int num_file_names, file_names_size;
431 struct file_entry
c906108c 432 {
debd256d
JB
433 char *name;
434 unsigned int dir_index;
435 unsigned int mod_time;
436 unsigned int length;
aaa75496 437 int included_p; /* Non-zero if referenced by the Line Number Program. */
cb1df416 438 struct symtab *symtab; /* The associated symbol table, if any. */
debd256d
JB
439 } *file_names;
440
441 /* The start and end of the statement program following this
6502dd73 442 header. These point into dwarf2_per_objfile->line_buffer. */
fe1b8b76 443 gdb_byte *statement_program_start, *statement_program_end;
debd256d 444};
c906108c
SS
445
446/* When we construct a partial symbol table entry we only
447 need this much information. */
448struct partial_die_info
449 {
72bf9492 450 /* Offset of this DIE. */
c906108c 451 unsigned int offset;
72bf9492
DJ
452
453 /* DWARF-2 tag for this DIE. */
454 ENUM_BITFIELD(dwarf_tag) tag : 16;
455
456 /* Language code associated with this DIE. This is only used
457 for the compilation unit DIE. */
458 unsigned int language : 8;
459
460 /* Assorted flags describing the data found in this DIE. */
461 unsigned int has_children : 1;
462 unsigned int is_external : 1;
463 unsigned int is_declaration : 1;
464 unsigned int has_type : 1;
465 unsigned int has_specification : 1;
aaa75496 466 unsigned int has_stmt_list : 1;
72bf9492
DJ
467 unsigned int has_pc_info : 1;
468
469 /* Flag set if the SCOPE field of this structure has been
470 computed. */
471 unsigned int scope_set : 1;
472
fa4028e9
JB
473 /* Flag set if the DIE has a byte_size attribute. */
474 unsigned int has_byte_size : 1;
475
72bf9492
DJ
476 /* The name of this DIE. Normally the value of DW_AT_name, but
477 sometimes DW_TAG_MIPS_linkage_name or a string computed in some
478 other fashion. */
c906108c 479 char *name;
57c22c6c 480 char *dirname;
72bf9492
DJ
481
482 /* The scope to prepend to our children. This is generally
483 allocated on the comp_unit_obstack, so will disappear
484 when this compilation unit leaves the cache. */
485 char *scope;
486
487 /* The location description associated with this DIE, if any. */
488 struct dwarf_block *locdesc;
489
490 /* If HAS_PC_INFO, the PC range associated with this DIE. */
c906108c
SS
491 CORE_ADDR lowpc;
492 CORE_ADDR highpc;
72bf9492
DJ
493
494 /* Pointer into the info_buffer pointing at the target of
495 DW_AT_sibling, if any. */
fe1b8b76 496 gdb_byte *sibling;
72bf9492
DJ
497
498 /* If HAS_SPECIFICATION, the offset of the DIE referred to by
499 DW_AT_specification (or DW_AT_abstract_origin or
500 DW_AT_extension). */
501 unsigned int spec_offset;
502
aaa75496
JB
503 /* If HAS_STMT_LIST, the offset of the Line Number Information data. */
504 unsigned int line_offset;
505
72bf9492
DJ
506 /* Pointers to this DIE's parent, first child, and next sibling,
507 if any. */
508 struct partial_die_info *die_parent, *die_child, *die_sibling;
c906108c
SS
509 };
510
511/* This data structure holds the information of an abbrev. */
512struct abbrev_info
513 {
514 unsigned int number; /* number identifying abbrev */
515 enum dwarf_tag tag; /* dwarf tag */
f3dd6933
DJ
516 unsigned short has_children; /* boolean */
517 unsigned short num_attrs; /* number of attributes */
c906108c
SS
518 struct attr_abbrev *attrs; /* an array of attribute descriptions */
519 struct abbrev_info *next; /* next in chain */
520 };
521
522struct attr_abbrev
523 {
524 enum dwarf_attribute name;
525 enum dwarf_form form;
526 };
527
528/* This data structure holds a complete die structure. */
529struct die_info
530 {
c5aa993b 531 enum dwarf_tag tag; /* Tag indicating type of die */
c5aa993b
JM
532 unsigned int abbrev; /* Abbrev number */
533 unsigned int offset; /* Offset in .debug_info section */
534 unsigned int num_attrs; /* Number of attributes */
535 struct attribute *attrs; /* An array of attributes */
536 struct die_info *next_ref; /* Next die in ref hash table */
78ba4af6
JB
537
538 /* The dies in a compilation unit form an n-ary tree. PARENT
539 points to this die's parent; CHILD points to the first child of
540 this node; and all the children of a given node are chained
541 together via their SIBLING fields, terminated by a die whose
542 tag is zero. */
639d11d3
DC
543 struct die_info *child; /* Its first child, if any. */
544 struct die_info *sibling; /* Its next sibling, if any. */
545 struct die_info *parent; /* Its parent, if any. */
78ba4af6 546
c5aa993b 547 struct type *type; /* Cached type information */
c906108c
SS
548 };
549
550/* Attributes have a name and a value */
551struct attribute
552 {
553 enum dwarf_attribute name;
554 enum dwarf_form form;
555 union
556 {
557 char *str;
558 struct dwarf_block *blk;
ce5d95e1
JB
559 unsigned long unsnd;
560 long int snd;
c906108c
SS
561 CORE_ADDR addr;
562 }
563 u;
564 };
565
5fb290d7
DJ
566struct function_range
567{
568 const char *name;
569 CORE_ADDR lowpc, highpc;
570 int seen_line;
571 struct function_range *next;
572};
573
c906108c
SS
574/* Get at parts of an attribute structure */
575
576#define DW_STRING(attr) ((attr)->u.str)
577#define DW_UNSND(attr) ((attr)->u.unsnd)
578#define DW_BLOCK(attr) ((attr)->u.blk)
579#define DW_SND(attr) ((attr)->u.snd)
580#define DW_ADDR(attr) ((attr)->u.addr)
581
582/* Blocks are a bunch of untyped bytes. */
583struct dwarf_block
584 {
585 unsigned int size;
fe1b8b76 586 gdb_byte *data;
c906108c
SS
587 };
588
c906108c
SS
589#ifndef ATTR_ALLOC_CHUNK
590#define ATTR_ALLOC_CHUNK 4
591#endif
592
c906108c
SS
593/* Allocate fields for structs, unions and enums in this size. */
594#ifndef DW_FIELD_ALLOC_CHUNK
595#define DW_FIELD_ALLOC_CHUNK 4
596#endif
597
c906108c
SS
598/* A zeroed version of a partial die for initialization purposes. */
599static struct partial_die_info zeroed_partial_die;
600
c906108c
SS
601/* FIXME: We might want to set this from BFD via bfd_arch_bits_per_byte,
602 but this would require a corresponding change in unpack_field_as_long
603 and friends. */
604static int bits_per_byte = 8;
605
606/* The routines that read and process dies for a C struct or C++ class
607 pass lists of data member fields and lists of member function fields
608 in an instance of a field_info structure, as defined below. */
609struct field_info
c5aa993b
JM
610 {
611 /* List of data member and baseclasses fields. */
612 struct nextfield
613 {
614 struct nextfield *next;
615 int accessibility;
616 int virtuality;
617 struct field field;
618 }
619 *fields;
c906108c 620
c5aa993b
JM
621 /* Number of fields. */
622 int nfields;
c906108c 623
c5aa993b
JM
624 /* Number of baseclasses. */
625 int nbaseclasses;
c906108c 626
c5aa993b
JM
627 /* Set if the accesibility of one of the fields is not public. */
628 int non_public_fields;
c906108c 629
c5aa993b
JM
630 /* Member function fields array, entries are allocated in the order they
631 are encountered in the object file. */
632 struct nextfnfield
633 {
634 struct nextfnfield *next;
635 struct fn_field fnfield;
636 }
637 *fnfields;
c906108c 638
c5aa993b
JM
639 /* Member function fieldlist array, contains name of possibly overloaded
640 member function, number of overloaded member functions and a pointer
641 to the head of the member function field chain. */
642 struct fnfieldlist
643 {
644 char *name;
645 int length;
646 struct nextfnfield *head;
647 }
648 *fnfieldlists;
c906108c 649
c5aa993b
JM
650 /* Number of entries in the fnfieldlists array. */
651 int nfnfields;
652 };
c906108c 653
10b3939b
DJ
654/* One item on the queue of compilation units to read in full symbols
655 for. */
656struct dwarf2_queue_item
657{
658 struct dwarf2_per_cu_data *per_cu;
659 struct dwarf2_queue_item *next;
660};
661
662/* The current queue. */
663static struct dwarf2_queue_item *dwarf2_queue, *dwarf2_queue_tail;
664
ae038cb0
DJ
665/* Loaded secondary compilation units are kept in memory until they
666 have not been referenced for the processing of this many
667 compilation units. Set this to zero to disable caching. Cache
668 sizes of up to at least twenty will improve startup time for
669 typical inter-CU-reference binaries, at an obvious memory cost. */
670static int dwarf2_max_cache_age = 5;
920d2a44
AC
671static void
672show_dwarf2_max_cache_age (struct ui_file *file, int from_tty,
673 struct cmd_list_element *c, const char *value)
674{
675 fprintf_filtered (file, _("\
676The upper bound on the age of cached dwarf2 compilation units is %s.\n"),
677 value);
678}
679
ae038cb0 680
c906108c
SS
681/* Various complaints about symbol reading that don't abort the process */
682
4d3c2250
KB
683static void
684dwarf2_statement_list_fits_in_line_number_section_complaint (void)
2e276125 685{
4d3c2250 686 complaint (&symfile_complaints,
e2e0b3e5 687 _("statement list doesn't fit in .debug_line section"));
4d3c2250
KB
688}
689
690static void
691dwarf2_complex_location_expr_complaint (void)
2e276125 692{
e2e0b3e5 693 complaint (&symfile_complaints, _("location expression too complex"));
4d3c2250
KB
694}
695
4d3c2250
KB
696static void
697dwarf2_const_value_length_mismatch_complaint (const char *arg1, int arg2,
698 int arg3)
2e276125 699{
4d3c2250 700 complaint (&symfile_complaints,
e2e0b3e5 701 _("const value length mismatch for '%s', got %d, expected %d"), arg1,
4d3c2250
KB
702 arg2, arg3);
703}
704
705static void
706dwarf2_macros_too_long_complaint (void)
2e276125 707{
4d3c2250 708 complaint (&symfile_complaints,
e2e0b3e5 709 _("macro info runs off end of `.debug_macinfo' section"));
4d3c2250
KB
710}
711
712static void
713dwarf2_macro_malformed_definition_complaint (const char *arg1)
8e19ed76 714{
4d3c2250 715 complaint (&symfile_complaints,
e2e0b3e5 716 _("macro debug info contains a malformed macro definition:\n`%s'"),
4d3c2250
KB
717 arg1);
718}
719
720static void
721dwarf2_invalid_attrib_class_complaint (const char *arg1, const char *arg2)
8b2dbe47 722{
4d3c2250 723 complaint (&symfile_complaints,
e2e0b3e5 724 _("invalid attribute class or form for '%s' in '%s'"), arg1, arg2);
4d3c2250 725}
c906108c 726
c906108c
SS
727/* local function prototypes */
728
4efb68b1 729static void dwarf2_locate_sections (bfd *, asection *, void *);
c906108c
SS
730
731#if 0
a14ed312 732static void dwarf2_build_psymtabs_easy (struct objfile *, int);
c906108c
SS
733#endif
734
aaa75496
JB
735static void dwarf2_create_include_psymtab (char *, struct partial_symtab *,
736 struct objfile *);
737
738static void dwarf2_build_include_psymtabs (struct dwarf2_cu *,
739 struct partial_die_info *,
740 struct partial_symtab *);
741
a14ed312 742static void dwarf2_build_psymtabs_hard (struct objfile *, int);
c906108c 743
72bf9492
DJ
744static void scan_partial_symbols (struct partial_die_info *,
745 CORE_ADDR *, CORE_ADDR *,
746 struct dwarf2_cu *);
c906108c 747
72bf9492
DJ
748static void add_partial_symbol (struct partial_die_info *,
749 struct dwarf2_cu *);
63d06c5c 750
72bf9492 751static int pdi_needs_namespace (enum dwarf_tag tag);
91c24f0a 752
72bf9492
DJ
753static void add_partial_namespace (struct partial_die_info *pdi,
754 CORE_ADDR *lowpc, CORE_ADDR *highpc,
755 struct dwarf2_cu *cu);
63d06c5c 756
72bf9492
DJ
757static void add_partial_enumeration (struct partial_die_info *enum_pdi,
758 struct dwarf2_cu *cu);
91c24f0a 759
fe1b8b76
JB
760static gdb_byte *locate_pdi_sibling (struct partial_die_info *orig_pdi,
761 gdb_byte *info_ptr,
762 bfd *abfd,
763 struct dwarf2_cu *cu);
91c24f0a 764
a14ed312 765static void dwarf2_psymtab_to_symtab (struct partial_symtab *);
c906108c 766
a14ed312 767static void psymtab_to_symtab_1 (struct partial_symtab *);
c906108c 768
fe1b8b76 769gdb_byte *dwarf2_read_section (struct objfile *, asection *);
c906108c 770
e7c27a73 771static void dwarf2_read_abbrevs (bfd *abfd, struct dwarf2_cu *cu);
c906108c 772
f3dd6933 773static void dwarf2_free_abbrev_table (void *);
c906108c 774
fe1b8b76 775static struct abbrev_info *peek_die_abbrev (gdb_byte *, unsigned int *,
891d2f0b 776 struct dwarf2_cu *);
72bf9492 777
57349743 778static struct abbrev_info *dwarf2_lookup_abbrev (unsigned int,
e7c27a73 779 struct dwarf2_cu *);
c906108c 780
fe1b8b76 781static struct partial_die_info *load_partial_dies (bfd *, gdb_byte *, int,
72bf9492
DJ
782 struct dwarf2_cu *);
783
fe1b8b76
JB
784static gdb_byte *read_partial_die (struct partial_die_info *,
785 struct abbrev_info *abbrev, unsigned int,
786 bfd *, gdb_byte *, struct dwarf2_cu *);
c906108c 787
72bf9492 788static struct partial_die_info *find_partial_die (unsigned long,
10b3939b 789 struct dwarf2_cu *);
72bf9492
DJ
790
791static void fixup_partial_die (struct partial_die_info *,
792 struct dwarf2_cu *);
793
fe1b8b76
JB
794static gdb_byte *read_full_die (struct die_info **, bfd *, gdb_byte *,
795 struct dwarf2_cu *, int *);
c906108c 796
fe1b8b76
JB
797static gdb_byte *read_attribute (struct attribute *, struct attr_abbrev *,
798 bfd *, gdb_byte *, struct dwarf2_cu *);
c906108c 799
fe1b8b76
JB
800static gdb_byte *read_attribute_value (struct attribute *, unsigned,
801 bfd *, gdb_byte *, struct dwarf2_cu *);
a8329558 802
fe1b8b76 803static unsigned int read_1_byte (bfd *, gdb_byte *);
c906108c 804
fe1b8b76 805static int read_1_signed_byte (bfd *, gdb_byte *);
c906108c 806
fe1b8b76 807static unsigned int read_2_bytes (bfd *, gdb_byte *);
c906108c 808
fe1b8b76 809static unsigned int read_4_bytes (bfd *, gdb_byte *);
c906108c 810
fe1b8b76 811static unsigned long read_8_bytes (bfd *, gdb_byte *);
c906108c 812
fe1b8b76 813static CORE_ADDR read_address (bfd *, gdb_byte *ptr, struct dwarf2_cu *,
891d2f0b 814 unsigned int *);
c906108c 815
fe1b8b76 816static LONGEST read_initial_length (bfd *, gdb_byte *,
891d2f0b 817 struct comp_unit_head *, unsigned int *);
613e1657 818
fe1b8b76 819static LONGEST read_offset (bfd *, gdb_byte *, const struct comp_unit_head *,
891d2f0b 820 unsigned int *);
613e1657 821
fe1b8b76 822static gdb_byte *read_n_bytes (bfd *, gdb_byte *, unsigned int);
c906108c 823
fe1b8b76 824static char *read_string (bfd *, gdb_byte *, unsigned int *);
c906108c 825
fe1b8b76
JB
826static char *read_indirect_string (bfd *, gdb_byte *,
827 const struct comp_unit_head *,
828 unsigned int *);
4bdf3d34 829
fe1b8b76 830static unsigned long read_unsigned_leb128 (bfd *, gdb_byte *, unsigned int *);
c906108c 831
fe1b8b76 832static long read_signed_leb128 (bfd *, gdb_byte *, unsigned int *);
c906108c 833
fe1b8b76 834static gdb_byte *skip_leb128 (bfd *, gdb_byte *);
4bb7a0a7 835
e142c38c 836static void set_cu_language (unsigned int, struct dwarf2_cu *);
c906108c 837
e142c38c
DJ
838static struct attribute *dwarf2_attr (struct die_info *, unsigned int,
839 struct dwarf2_cu *);
c906108c 840
05cf31d1
JB
841static int dwarf2_flag_true_p (struct die_info *die, unsigned name,
842 struct dwarf2_cu *cu);
843
e142c38c 844static int die_is_declaration (struct die_info *, struct dwarf2_cu *cu);
3ca72b44 845
e142c38c
DJ
846static struct die_info *die_specification (struct die_info *die,
847 struct dwarf2_cu *);
63d06c5c 848
debd256d
JB
849static void free_line_header (struct line_header *lh);
850
aaa75496
JB
851static void add_file_name (struct line_header *, char *, unsigned int,
852 unsigned int, unsigned int);
853
debd256d
JB
854static struct line_header *(dwarf_decode_line_header
855 (unsigned int offset,
e7c27a73 856 bfd *abfd, struct dwarf2_cu *cu));
debd256d
JB
857
858static void dwarf_decode_lines (struct line_header *, char *, bfd *,
aaa75496 859 struct dwarf2_cu *, struct partial_symtab *);
c906108c 860
4f1520fb 861static void dwarf2_start_subfile (char *, char *, char *);
c906108c 862
a14ed312 863static struct symbol *new_symbol (struct die_info *, struct type *,
e7c27a73 864 struct dwarf2_cu *);
c906108c 865
a14ed312 866static void dwarf2_const_value (struct attribute *, struct symbol *,
e7c27a73 867 struct dwarf2_cu *);
c906108c 868
2df3850c
JM
869static void dwarf2_const_value_data (struct attribute *attr,
870 struct symbol *sym,
871 int bits);
872
e7c27a73 873static struct type *die_type (struct die_info *, struct dwarf2_cu *);
c906108c 874
e7c27a73
DJ
875static struct type *die_containing_type (struct die_info *,
876 struct dwarf2_cu *);
c906108c 877
e7c27a73 878static struct type *tag_type_to_type (struct die_info *, struct dwarf2_cu *);
c906108c 879
e7c27a73 880static void read_type_die (struct die_info *, struct dwarf2_cu *);
c906108c 881
086ed43d 882static char *determine_prefix (struct die_info *die, struct dwarf2_cu *);
63d06c5c 883
fe1b8b76
JB
884static char *typename_concat (struct obstack *,
885 const char *prefix,
886 const char *suffix,
987504bb 887 struct dwarf2_cu *);
63d06c5c 888
e7c27a73 889static void read_typedef (struct die_info *, struct dwarf2_cu *);
c906108c 890
e7c27a73 891static void read_base_type (struct die_info *, struct dwarf2_cu *);
c906108c 892
a02abb62
JB
893static void read_subrange_type (struct die_info *die, struct dwarf2_cu *cu);
894
e7c27a73 895static void read_file_scope (struct die_info *, struct dwarf2_cu *);
c906108c 896
e7c27a73 897static void read_func_scope (struct die_info *, struct dwarf2_cu *);
c906108c 898
e7c27a73 899static void read_lexical_block_scope (struct die_info *, struct dwarf2_cu *);
c906108c 900
a14ed312 901static int dwarf2_get_pc_bounds (struct die_info *,
e7c27a73 902 CORE_ADDR *, CORE_ADDR *, struct dwarf2_cu *);
c906108c 903
fae299cd
DC
904static void get_scope_pc_bounds (struct die_info *,
905 CORE_ADDR *, CORE_ADDR *,
906 struct dwarf2_cu *);
907
a14ed312 908static void dwarf2_add_field (struct field_info *, struct die_info *,
e7c27a73 909 struct dwarf2_cu *);
c906108c 910
a14ed312 911static void dwarf2_attach_fields_to_type (struct field_info *,
e7c27a73 912 struct type *, struct dwarf2_cu *);
c906108c 913
a14ed312 914static void dwarf2_add_member_fn (struct field_info *,
e26fb1d7 915 struct die_info *, struct type *,
e7c27a73 916 struct dwarf2_cu *);
c906108c 917
a14ed312 918static void dwarf2_attach_fn_fields_to_type (struct field_info *,
e7c27a73 919 struct type *, struct dwarf2_cu *);
c906108c 920
134d01f1
DJ
921static void read_structure_type (struct die_info *, struct dwarf2_cu *);
922
923static void process_structure_scope (struct die_info *, struct dwarf2_cu *);
c906108c 924
8176b9b8
DC
925static char *determine_class_name (struct die_info *die, struct dwarf2_cu *cu);
926
e7c27a73 927static void read_common_block (struct die_info *, struct dwarf2_cu *);
c906108c 928
e7c27a73 929static void read_namespace (struct die_info *die, struct dwarf2_cu *);
d9fa45fe 930
38d518c9 931static const char *namespace_name (struct die_info *die,
e142c38c 932 int *is_anonymous, struct dwarf2_cu *);
38d518c9 933
134d01f1
DJ
934static void read_enumeration_type (struct die_info *, struct dwarf2_cu *);
935
936static void process_enumeration_scope (struct die_info *, struct dwarf2_cu *);
c906108c 937
e7c27a73 938static struct type *dwarf_base_type (int, int, struct dwarf2_cu *);
c906108c 939
e7c27a73 940static CORE_ADDR decode_locdesc (struct dwarf_block *, struct dwarf2_cu *);
c906108c 941
e7c27a73 942static void read_array_type (struct die_info *, struct dwarf2_cu *);
c906108c 943
7ca2d3a3
DL
944static enum dwarf_array_dim_ordering read_array_order (struct die_info *,
945 struct dwarf2_cu *);
946
e7c27a73 947static void read_tag_pointer_type (struct die_info *, struct dwarf2_cu *);
c906108c 948
e7c27a73
DJ
949static void read_tag_ptr_to_member_type (struct die_info *,
950 struct dwarf2_cu *);
c906108c 951
e7c27a73 952static void read_tag_reference_type (struct die_info *, struct dwarf2_cu *);
c906108c 953
e7c27a73 954static void read_tag_const_type (struct die_info *, struct dwarf2_cu *);
c906108c 955
e7c27a73 956static void read_tag_volatile_type (struct die_info *, struct dwarf2_cu *);
c906108c 957
e7c27a73 958static void read_tag_string_type (struct die_info *, struct dwarf2_cu *);
c906108c 959
e7c27a73 960static void read_subroutine_type (struct die_info *, struct dwarf2_cu *);
c906108c 961
fe1b8b76 962static struct die_info *read_comp_unit (gdb_byte *, bfd *, struct dwarf2_cu *);
c906108c 963
fe1b8b76 964static struct die_info *read_die_and_children (gdb_byte *info_ptr, bfd *abfd,
e7c27a73 965 struct dwarf2_cu *,
fe1b8b76 966 gdb_byte **new_info_ptr,
639d11d3
DC
967 struct die_info *parent);
968
fe1b8b76 969static struct die_info *read_die_and_siblings (gdb_byte *info_ptr, bfd *abfd,
e7c27a73 970 struct dwarf2_cu *,
fe1b8b76 971 gdb_byte **new_info_ptr,
639d11d3
DC
972 struct die_info *parent);
973
a14ed312 974static void free_die_list (struct die_info *);
c906108c 975
e7c27a73 976static void process_die (struct die_info *, struct dwarf2_cu *);
c906108c 977
e142c38c 978static char *dwarf2_linkage_name (struct die_info *, struct dwarf2_cu *);
c906108c 979
e142c38c 980static char *dwarf2_name (struct die_info *die, struct dwarf2_cu *);
9219021c 981
e142c38c
DJ
982static struct die_info *dwarf2_extension (struct die_info *die,
983 struct dwarf2_cu *);
9219021c 984
a14ed312 985static char *dwarf_tag_name (unsigned int);
c906108c 986
a14ed312 987static char *dwarf_attr_name (unsigned int);
c906108c 988
a14ed312 989static char *dwarf_form_name (unsigned int);
c906108c 990
a14ed312 991static char *dwarf_stack_op_name (unsigned int);
c906108c 992
a14ed312 993static char *dwarf_bool_name (unsigned int);
c906108c 994
a14ed312 995static char *dwarf_type_encoding_name (unsigned int);
c906108c
SS
996
997#if 0
a14ed312 998static char *dwarf_cfi_name (unsigned int);
c906108c 999
a14ed312 1000struct die_info *copy_die (struct die_info *);
c906108c
SS
1001#endif
1002
f9aca02d 1003static struct die_info *sibling_die (struct die_info *);
c906108c 1004
f9aca02d 1005static void dump_die (struct die_info *);
c906108c 1006
f9aca02d 1007static void dump_die_list (struct die_info *);
c906108c 1008
10b3939b
DJ
1009static void store_in_ref_table (unsigned int, struct die_info *,
1010 struct dwarf2_cu *);
c906108c 1011
e142c38c
DJ
1012static unsigned int dwarf2_get_ref_die_offset (struct attribute *,
1013 struct dwarf2_cu *);
c906108c 1014
a02abb62
JB
1015static int dwarf2_get_attr_constant_value (struct attribute *, int);
1016
10b3939b
DJ
1017static struct die_info *follow_die_ref (struct die_info *,
1018 struct attribute *,
1019 struct dwarf2_cu *);
c906108c 1020
e142c38c
DJ
1021static struct type *dwarf2_fundamental_type (struct objfile *, int,
1022 struct dwarf2_cu *);
c906108c
SS
1023
1024/* memory allocation interface */
1025
7b5a2f43 1026static struct dwarf_block *dwarf_alloc_block (struct dwarf2_cu *);
c906108c 1027
f3dd6933 1028static struct abbrev_info *dwarf_alloc_abbrev (struct dwarf2_cu *);
c906108c 1029
a14ed312 1030static struct die_info *dwarf_alloc_die (void);
c906108c 1031
e142c38c 1032static void initialize_cu_func_list (struct dwarf2_cu *);
5fb290d7 1033
e142c38c
DJ
1034static void add_to_cu_func_list (const char *, CORE_ADDR, CORE_ADDR,
1035 struct dwarf2_cu *);
5fb290d7 1036
2e276125 1037static void dwarf_decode_macros (struct line_header *, unsigned int,
e7c27a73 1038 char *, bfd *, struct dwarf2_cu *);
2e276125 1039
8e19ed76
PS
1040static int attr_form_is_block (struct attribute *);
1041
4c2df51b
DJ
1042static void
1043dwarf2_symbol_mark_computed (struct attribute *attr, struct symbol *sym,
e7c27a73 1044 struct dwarf2_cu *cu);
4c2df51b 1045
fe1b8b76
JB
1046static gdb_byte *skip_one_die (gdb_byte *info_ptr, struct abbrev_info *abbrev,
1047 struct dwarf2_cu *cu);
4bb7a0a7 1048
72bf9492
DJ
1049static void free_stack_comp_unit (void *);
1050
72bf9492
DJ
1051static hashval_t partial_die_hash (const void *item);
1052
1053static int partial_die_eq (const void *item_lhs, const void *item_rhs);
1054
ae038cb0
DJ
1055static struct dwarf2_per_cu_data *dwarf2_find_containing_comp_unit
1056 (unsigned long offset, struct objfile *objfile);
1057
1058static struct dwarf2_per_cu_data *dwarf2_find_comp_unit
1059 (unsigned long offset, struct objfile *objfile);
1060
1061static void free_one_comp_unit (void *);
1062
1063static void free_cached_comp_units (void *);
1064
1065static void age_cached_comp_units (void);
1066
1067static void free_one_cached_comp_unit (void *);
1068
1c379e20
DJ
1069static void set_die_type (struct die_info *, struct type *,
1070 struct dwarf2_cu *);
1071
1c379e20
DJ
1072static void reset_die_and_siblings_types (struct die_info *,
1073 struct dwarf2_cu *);
1c379e20 1074
ae038cb0
DJ
1075static void create_all_comp_units (struct objfile *);
1076
31ffec48
DJ
1077static struct dwarf2_cu *load_full_comp_unit (struct dwarf2_per_cu_data *,
1078 struct objfile *);
10b3939b
DJ
1079
1080static void process_full_comp_unit (struct dwarf2_per_cu_data *);
1081
1082static void dwarf2_add_dependence (struct dwarf2_cu *,
1083 struct dwarf2_per_cu_data *);
1084
ae038cb0
DJ
1085static void dwarf2_mark (struct dwarf2_cu *);
1086
1087static void dwarf2_clear_marks (struct dwarf2_per_cu_data *);
1088
72019c9c
GM
1089static void read_set_type (struct die_info *, struct dwarf2_cu *);
1090
1091
c906108c
SS
1092/* Try to locate the sections we need for DWARF 2 debugging
1093 information and return true if we have enough to do something. */
1094
1095int
6502dd73 1096dwarf2_has_info (struct objfile *objfile)
c906108c 1097{
6502dd73
DJ
1098 struct dwarf2_per_objfile *data;
1099
1100 /* Initialize per-objfile state. */
1101 data = obstack_alloc (&objfile->objfile_obstack, sizeof (*data));
1102 memset (data, 0, sizeof (*data));
1103 set_objfile_data (objfile, dwarf2_objfile_data_key, data);
1104 dwarf2_per_objfile = data;
1105
188dd5d6
DJ
1106 dwarf_info_section = 0;
1107 dwarf_abbrev_section = 0;
1108 dwarf_line_section = 0;
1109 dwarf_str_section = 0;
1110 dwarf_macinfo_section = 0;
1111 dwarf_frame_section = 0;
1112 dwarf_eh_frame_section = 0;
1113 dwarf_ranges_section = 0;
1114 dwarf_loc_section = 0;
af34e669 1115
6502dd73 1116 bfd_map_over_sections (objfile->obfd, dwarf2_locate_sections, NULL);
188dd5d6 1117 return (dwarf_info_section != NULL && dwarf_abbrev_section != NULL);
c906108c
SS
1118}
1119
1120/* This function is mapped across the sections and remembers the
1121 offset and size of each of the debugging sections we are interested
1122 in. */
1123
1124static void
72dca2f5 1125dwarf2_locate_sections (bfd *abfd, asection *sectp, void *ignore_ptr)
c906108c 1126{
6314a349 1127 if (strcmp (sectp->name, INFO_SECTION) == 0)
c906108c 1128 {
2c500098 1129 dwarf2_per_objfile->info_size = bfd_get_section_size (sectp);
086df311 1130 dwarf_info_section = sectp;
c906108c 1131 }
6314a349 1132 else if (strcmp (sectp->name, ABBREV_SECTION) == 0)
c906108c 1133 {
2c500098 1134 dwarf2_per_objfile->abbrev_size = bfd_get_section_size (sectp);
086df311 1135 dwarf_abbrev_section = sectp;
c906108c 1136 }
6314a349 1137 else if (strcmp (sectp->name, LINE_SECTION) == 0)
c906108c 1138 {
2c500098 1139 dwarf2_per_objfile->line_size = bfd_get_section_size (sectp);
086df311 1140 dwarf_line_section = sectp;
c906108c 1141 }
6314a349 1142 else if (strcmp (sectp->name, PUBNAMES_SECTION) == 0)
c906108c 1143 {
2c500098 1144 dwarf2_per_objfile->pubnames_size = bfd_get_section_size (sectp);
086df311 1145 dwarf_pubnames_section = sectp;
c906108c 1146 }
6314a349 1147 else if (strcmp (sectp->name, ARANGES_SECTION) == 0)
c906108c 1148 {
2c500098 1149 dwarf2_per_objfile->aranges_size = bfd_get_section_size (sectp);
086df311 1150 dwarf_aranges_section = sectp;
c906108c 1151 }
6314a349 1152 else if (strcmp (sectp->name, LOC_SECTION) == 0)
c906108c 1153 {
2c500098 1154 dwarf2_per_objfile->loc_size = bfd_get_section_size (sectp);
086df311 1155 dwarf_loc_section = sectp;
c906108c 1156 }
6314a349 1157 else if (strcmp (sectp->name, MACINFO_SECTION) == 0)
c906108c 1158 {
2c500098 1159 dwarf2_per_objfile->macinfo_size = bfd_get_section_size (sectp);
0cf824c9 1160 dwarf_macinfo_section = sectp;
c906108c 1161 }
6314a349 1162 else if (strcmp (sectp->name, STR_SECTION) == 0)
c906108c 1163 {
2c500098 1164 dwarf2_per_objfile->str_size = bfd_get_section_size (sectp);
086df311 1165 dwarf_str_section = sectp;
c906108c 1166 }
6314a349 1167 else if (strcmp (sectp->name, FRAME_SECTION) == 0)
b6af0555 1168 {
2c500098 1169 dwarf2_per_objfile->frame_size = bfd_get_section_size (sectp);
086df311 1170 dwarf_frame_section = sectp;
b6af0555 1171 }
6314a349 1172 else if (strcmp (sectp->name, EH_FRAME_SECTION) == 0)
b6af0555 1173 {
3799ccc6
EZ
1174 flagword aflag = bfd_get_section_flags (ignore_abfd, sectp);
1175 if (aflag & SEC_HAS_CONTENTS)
1176 {
2c500098 1177 dwarf2_per_objfile->eh_frame_size = bfd_get_section_size (sectp);
3799ccc6
EZ
1178 dwarf_eh_frame_section = sectp;
1179 }
b6af0555 1180 }
6314a349 1181 else if (strcmp (sectp->name, RANGES_SECTION) == 0)
af34e669 1182 {
2c500098 1183 dwarf2_per_objfile->ranges_size = bfd_get_section_size (sectp);
6f10aeb1 1184 dwarf_ranges_section = sectp;
af34e669 1185 }
72dca2f5
FR
1186
1187 if ((bfd_get_section_flags (abfd, sectp) & SEC_LOAD)
1188 && bfd_section_vma (abfd, sectp) == 0)
1189 dwarf2_per_objfile->has_section_at_zero = 1;
c906108c
SS
1190}
1191
1192/* Build a partial symbol table. */
1193
1194void
fba45db2 1195dwarf2_build_psymtabs (struct objfile *objfile, int mainline)
c906108c 1196{
c906108c
SS
1197 /* We definitely need the .debug_info and .debug_abbrev sections */
1198
6502dd73
DJ
1199 dwarf2_per_objfile->info_buffer = dwarf2_read_section (objfile, dwarf_info_section);
1200 dwarf2_per_objfile->abbrev_buffer = dwarf2_read_section (objfile, dwarf_abbrev_section);
188dd5d6
DJ
1201
1202 if (dwarf_line_section)
6502dd73 1203 dwarf2_per_objfile->line_buffer = dwarf2_read_section (objfile, dwarf_line_section);
41ff2da1 1204 else
6502dd73 1205 dwarf2_per_objfile->line_buffer = NULL;
c906108c 1206
188dd5d6 1207 if (dwarf_str_section)
6502dd73 1208 dwarf2_per_objfile->str_buffer = dwarf2_read_section (objfile, dwarf_str_section);
4bdf3d34 1209 else
6502dd73 1210 dwarf2_per_objfile->str_buffer = NULL;
4bdf3d34 1211
188dd5d6 1212 if (dwarf_macinfo_section)
6502dd73 1213 dwarf2_per_objfile->macinfo_buffer = dwarf2_read_section (objfile,
086df311 1214 dwarf_macinfo_section);
2e276125 1215 else
6502dd73 1216 dwarf2_per_objfile->macinfo_buffer = NULL;
2e276125 1217
188dd5d6 1218 if (dwarf_ranges_section)
6502dd73 1219 dwarf2_per_objfile->ranges_buffer = dwarf2_read_section (objfile, dwarf_ranges_section);
af34e669 1220 else
6502dd73 1221 dwarf2_per_objfile->ranges_buffer = NULL;
af34e669 1222
188dd5d6 1223 if (dwarf_loc_section)
6502dd73 1224 dwarf2_per_objfile->loc_buffer = dwarf2_read_section (objfile, dwarf_loc_section);
0d53c4c4 1225 else
6502dd73 1226 dwarf2_per_objfile->loc_buffer = NULL;
0d53c4c4 1227
ef96bde8
EZ
1228 if (mainline
1229 || (objfile->global_psymbols.size == 0
1230 && objfile->static_psymbols.size == 0))
c906108c
SS
1231 {
1232 init_psymbol_list (objfile, 1024);
1233 }
1234
1235#if 0
1236 if (dwarf_aranges_offset && dwarf_pubnames_offset)
1237 {
d4f3574e 1238 /* Things are significantly easier if we have .debug_aranges and
c906108c
SS
1239 .debug_pubnames sections */
1240
d4f3574e 1241 dwarf2_build_psymtabs_easy (objfile, mainline);
c906108c
SS
1242 }
1243 else
1244#endif
1245 /* only test this case for now */
c5aa993b 1246 {
c906108c 1247 /* In this case we have to work a bit harder */
d4f3574e 1248 dwarf2_build_psymtabs_hard (objfile, mainline);
c906108c
SS
1249 }
1250}
1251
1252#if 0
1253/* Build the partial symbol table from the information in the
1254 .debug_pubnames and .debug_aranges sections. */
1255
1256static void
fba45db2 1257dwarf2_build_psymtabs_easy (struct objfile *objfile, int mainline)
c906108c
SS
1258{
1259 bfd *abfd = objfile->obfd;
1260 char *aranges_buffer, *pubnames_buffer;
1261 char *aranges_ptr, *pubnames_ptr;
1262 unsigned int entry_length, version, info_offset, info_size;
1263
1264 pubnames_buffer = dwarf2_read_section (objfile,
086df311 1265 dwarf_pubnames_section);
c906108c 1266 pubnames_ptr = pubnames_buffer;
6502dd73 1267 while ((pubnames_ptr - pubnames_buffer) < dwarf2_per_objfile->pubnames_size)
c906108c 1268 {
613e1657 1269 struct comp_unit_head cu_header;
891d2f0b 1270 unsigned int bytes_read;
613e1657
KB
1271
1272 entry_length = read_initial_length (abfd, pubnames_ptr, &cu_header,
891d2f0b 1273 &bytes_read);
613e1657 1274 pubnames_ptr += bytes_read;
c906108c
SS
1275 version = read_1_byte (abfd, pubnames_ptr);
1276 pubnames_ptr += 1;
1277 info_offset = read_4_bytes (abfd, pubnames_ptr);
1278 pubnames_ptr += 4;
1279 info_size = read_4_bytes (abfd, pubnames_ptr);
1280 pubnames_ptr += 4;
1281 }
1282
1283 aranges_buffer = dwarf2_read_section (objfile,
086df311 1284 dwarf_aranges_section);
c906108c
SS
1285
1286}
1287#endif
1288
107d2387 1289/* Read in the comp unit header information from the debug_info at
917c78fc 1290 info_ptr. */
107d2387 1291
fe1b8b76 1292static gdb_byte *
107d2387 1293read_comp_unit_head (struct comp_unit_head *cu_header,
fe1b8b76 1294 gdb_byte *info_ptr, bfd *abfd)
107d2387
AC
1295{
1296 int signed_addr;
891d2f0b 1297 unsigned int bytes_read;
613e1657
KB
1298 cu_header->length = read_initial_length (abfd, info_ptr, cu_header,
1299 &bytes_read);
1300 info_ptr += bytes_read;
107d2387
AC
1301 cu_header->version = read_2_bytes (abfd, info_ptr);
1302 info_ptr += 2;
613e1657
KB
1303 cu_header->abbrev_offset = read_offset (abfd, info_ptr, cu_header,
1304 &bytes_read);
1305 info_ptr += bytes_read;
107d2387
AC
1306 cu_header->addr_size = read_1_byte (abfd, info_ptr);
1307 info_ptr += 1;
1308 signed_addr = bfd_get_sign_extend_vma (abfd);
1309 if (signed_addr < 0)
8e65ff28 1310 internal_error (__FILE__, __LINE__,
e2e0b3e5 1311 _("read_comp_unit_head: dwarf from non elf file"));
107d2387
AC
1312 cu_header->signed_addr_p = signed_addr;
1313 return info_ptr;
1314}
1315
fe1b8b76
JB
1316static gdb_byte *
1317partial_read_comp_unit_head (struct comp_unit_head *header, gdb_byte *info_ptr,
72bf9492
DJ
1318 bfd *abfd)
1319{
fe1b8b76 1320 gdb_byte *beg_of_comp_unit = info_ptr;
72bf9492
DJ
1321
1322 info_ptr = read_comp_unit_head (header, info_ptr, abfd);
1323
2b949cb6 1324 if (header->version != 2 && header->version != 3)
8a3fe4f8
AC
1325 error (_("Dwarf Error: wrong version in compilation unit header "
1326 "(is %d, should be %d) [in module %s]"), header->version,
72bf9492
DJ
1327 2, bfd_get_filename (abfd));
1328
1329 if (header->abbrev_offset >= dwarf2_per_objfile->abbrev_size)
8a3fe4f8
AC
1330 error (_("Dwarf Error: bad offset (0x%lx) in compilation unit header "
1331 "(offset 0x%lx + 6) [in module %s]"),
72bf9492
DJ
1332 (long) header->abbrev_offset,
1333 (long) (beg_of_comp_unit - dwarf2_per_objfile->info_buffer),
1334 bfd_get_filename (abfd));
1335
1336 if (beg_of_comp_unit + header->length + header->initial_length_size
1337 > dwarf2_per_objfile->info_buffer + dwarf2_per_objfile->info_size)
8a3fe4f8
AC
1338 error (_("Dwarf Error: bad length (0x%lx) in compilation unit header "
1339 "(offset 0x%lx + 0) [in module %s]"),
72bf9492
DJ
1340 (long) header->length,
1341 (long) (beg_of_comp_unit - dwarf2_per_objfile->info_buffer),
1342 bfd_get_filename (abfd));
1343
1344 return info_ptr;
1345}
1346
aaa75496
JB
1347/* Allocate a new partial symtab for file named NAME and mark this new
1348 partial symtab as being an include of PST. */
1349
1350static void
1351dwarf2_create_include_psymtab (char *name, struct partial_symtab *pst,
1352 struct objfile *objfile)
1353{
1354 struct partial_symtab *subpst = allocate_psymtab (name, objfile);
1355
1356 subpst->section_offsets = pst->section_offsets;
1357 subpst->textlow = 0;
1358 subpst->texthigh = 0;
1359
1360 subpst->dependencies = (struct partial_symtab **)
1361 obstack_alloc (&objfile->objfile_obstack,
1362 sizeof (struct partial_symtab *));
1363 subpst->dependencies[0] = pst;
1364 subpst->number_of_dependencies = 1;
1365
1366 subpst->globals_offset = 0;
1367 subpst->n_global_syms = 0;
1368 subpst->statics_offset = 0;
1369 subpst->n_static_syms = 0;
1370 subpst->symtab = NULL;
1371 subpst->read_symtab = pst->read_symtab;
1372 subpst->readin = 0;
1373
1374 /* No private part is necessary for include psymtabs. This property
1375 can be used to differentiate between such include psymtabs and
10b3939b 1376 the regular ones. */
58a9656e 1377 subpst->read_symtab_private = NULL;
aaa75496
JB
1378}
1379
1380/* Read the Line Number Program data and extract the list of files
1381 included by the source file represented by PST. Build an include
1382 partial symtab for each of these included files.
1383
1384 This procedure assumes that there *is* a Line Number Program in
1385 the given CU. Callers should check that PDI->HAS_STMT_LIST is set
1386 before calling this procedure. */
1387
1388static void
1389dwarf2_build_include_psymtabs (struct dwarf2_cu *cu,
1390 struct partial_die_info *pdi,
1391 struct partial_symtab *pst)
1392{
1393 struct objfile *objfile = cu->objfile;
1394 bfd *abfd = objfile->obfd;
1395 struct line_header *lh;
1396
1397 lh = dwarf_decode_line_header (pdi->line_offset, abfd, cu);
1398 if (lh == NULL)
1399 return; /* No linetable, so no includes. */
1400
1401 dwarf_decode_lines (lh, NULL, abfd, cu, pst);
1402
1403 free_line_header (lh);
1404}
1405
1406
c906108c
SS
1407/* Build the partial symbol table by doing a quick pass through the
1408 .debug_info and .debug_abbrev sections. */
1409
1410static void
fba45db2 1411dwarf2_build_psymtabs_hard (struct objfile *objfile, int mainline)
c906108c
SS
1412{
1413 /* Instead of reading this into a big buffer, we should probably use
1414 mmap() on architectures that support it. (FIXME) */
1415 bfd *abfd = objfile->obfd;
fe1b8b76
JB
1416 gdb_byte *info_ptr;
1417 gdb_byte *beg_of_comp_unit;
c906108c
SS
1418 struct partial_die_info comp_unit_die;
1419 struct partial_symtab *pst;
ae038cb0 1420 struct cleanup *back_to;
e142c38c 1421 CORE_ADDR lowpc, highpc, baseaddr;
c906108c 1422
6502dd73 1423 info_ptr = dwarf2_per_objfile->info_buffer;
c906108c 1424
ae038cb0
DJ
1425 /* Any cached compilation units will be linked by the per-objfile
1426 read_in_chain. Make sure to free them when we're done. */
1427 back_to = make_cleanup (free_cached_comp_units, NULL);
1428
10b3939b
DJ
1429 create_all_comp_units (objfile);
1430
6502dd73 1431 /* Since the objects we're extracting from .debug_info vary in
af703f96 1432 length, only the individual functions to extract them (like
72bf9492 1433 read_comp_unit_head and load_partial_die) can really know whether
af703f96
JB
1434 the buffer is large enough to hold another complete object.
1435
6502dd73
DJ
1436 At the moment, they don't actually check that. If .debug_info
1437 holds just one extra byte after the last compilation unit's dies,
1438 then read_comp_unit_head will happily read off the end of the
1439 buffer. read_partial_die is similarly casual. Those functions
1440 should be fixed.
af703f96
JB
1441
1442 For this loop condition, simply checking whether there's any data
1443 left at all should be sufficient. */
6502dd73
DJ
1444 while (info_ptr < (dwarf2_per_objfile->info_buffer
1445 + dwarf2_per_objfile->info_size))
c906108c 1446 {
f3dd6933 1447 struct cleanup *back_to_inner;
e7c27a73 1448 struct dwarf2_cu cu;
72bf9492
DJ
1449 struct abbrev_info *abbrev;
1450 unsigned int bytes_read;
1451 struct dwarf2_per_cu_data *this_cu;
1452
c906108c 1453 beg_of_comp_unit = info_ptr;
c906108c 1454
72bf9492
DJ
1455 memset (&cu, 0, sizeof (cu));
1456
1457 obstack_init (&cu.comp_unit_obstack);
1458
1459 back_to_inner = make_cleanup (free_stack_comp_unit, &cu);
1460
e7c27a73 1461 cu.objfile = objfile;
72bf9492 1462 info_ptr = partial_read_comp_unit_head (&cu.header, info_ptr, abfd);
e7c27a73 1463
57349743 1464 /* Complete the cu_header */
6502dd73 1465 cu.header.offset = beg_of_comp_unit - dwarf2_per_objfile->info_buffer;
e7c27a73
DJ
1466 cu.header.first_die_ptr = info_ptr;
1467 cu.header.cu_head_ptr = beg_of_comp_unit;
57349743 1468
e142c38c
DJ
1469 cu.list_in_scope = &file_symbols;
1470
c906108c 1471 /* Read the abbrevs for this compilation unit into a table */
e7c27a73 1472 dwarf2_read_abbrevs (abfd, &cu);
72bf9492 1473 make_cleanup (dwarf2_free_abbrev_table, &cu);
c906108c 1474
10b3939b 1475 this_cu = dwarf2_find_comp_unit (cu.header.offset, objfile);
ae038cb0 1476
c906108c 1477 /* Read the compilation unit die */
72bf9492
DJ
1478 abbrev = peek_die_abbrev (info_ptr, &bytes_read, &cu);
1479 info_ptr = read_partial_die (&comp_unit_die, abbrev, bytes_read,
1480 abfd, info_ptr, &cu);
c906108c 1481
31ffec48
DJ
1482 if (comp_unit_die.tag == DW_TAG_partial_unit)
1483 {
1484 info_ptr = (beg_of_comp_unit + cu.header.length
1485 + cu.header.initial_length_size);
1486 do_cleanups (back_to_inner);
1487 continue;
1488 }
1489
c906108c 1490 /* Set the language we're debugging */
e142c38c 1491 set_cu_language (comp_unit_die.language, &cu);
c906108c
SS
1492
1493 /* Allocate a new partial symbol table structure */
d4f3574e 1494 pst = start_psymtab_common (objfile, objfile->section_offsets,
96baa820 1495 comp_unit_die.name ? comp_unit_die.name : "",
c906108c
SS
1496 comp_unit_die.lowpc,
1497 objfile->global_psymbols.next,
1498 objfile->static_psymbols.next);
1499
ae038cb0
DJ
1500 if (comp_unit_die.dirname)
1501 pst->dirname = xstrdup (comp_unit_die.dirname);
57c22c6c 1502
10b3939b
DJ
1503 pst->read_symtab_private = (char *) this_cu;
1504
613e1657 1505 baseaddr = ANOFFSET (objfile->section_offsets, SECT_OFF_TEXT (objfile));
c906108c
SS
1506
1507 /* Store the function that reads in the rest of the symbol table */
1508 pst->read_symtab = dwarf2_psymtab_to_symtab;
1509
10b3939b
DJ
1510 /* If this compilation unit was already read in, free the
1511 cached copy in order to read it in again. This is
1512 necessary because we skipped some symbols when we first
1513 read in the compilation unit (see load_partial_dies).
1514 This problem could be avoided, but the benefit is
1515 unclear. */
1516 if (this_cu->cu != NULL)
1517 free_one_cached_comp_unit (this_cu->cu);
ae038cb0 1518
10b3939b 1519 cu.per_cu = this_cu;
ae038cb0 1520
10b3939b
DJ
1521 /* Note that this is a pointer to our stack frame, being
1522 added to a global data structure. It will be cleaned up
1523 in free_stack_comp_unit when we finish with this
1524 compilation unit. */
1525 this_cu->cu = &cu;
ae038cb0 1526
10b3939b 1527 this_cu->psymtab = pst;
ae038cb0 1528
c906108c
SS
1529 /* Check if comp unit has_children.
1530 If so, read the rest of the partial symbols from this comp unit.
1531 If not, there's no more debug_info for this comp unit. */
1532 if (comp_unit_die.has_children)
1533 {
72bf9492
DJ
1534 struct partial_die_info *first_die;
1535
91c24f0a
DC
1536 lowpc = ((CORE_ADDR) -1);
1537 highpc = ((CORE_ADDR) 0);
1538
72bf9492
DJ
1539 first_die = load_partial_dies (abfd, info_ptr, 1, &cu);
1540
1541 scan_partial_symbols (first_die, &lowpc, &highpc, &cu);
c906108c 1542
91c24f0a
DC
1543 /* If we didn't find a lowpc, set it to highpc to avoid
1544 complaints from `maint check'. */
1545 if (lowpc == ((CORE_ADDR) -1))
1546 lowpc = highpc;
72bf9492 1547
c906108c
SS
1548 /* If the compilation unit didn't have an explicit address range,
1549 then use the information extracted from its child dies. */
0b010bcc 1550 if (! comp_unit_die.has_pc_info)
c906108c 1551 {
c5aa993b 1552 comp_unit_die.lowpc = lowpc;
c906108c
SS
1553 comp_unit_die.highpc = highpc;
1554 }
1555 }
c5aa993b 1556 pst->textlow = comp_unit_die.lowpc + baseaddr;
c906108c
SS
1557 pst->texthigh = comp_unit_die.highpc + baseaddr;
1558
1559 pst->n_global_syms = objfile->global_psymbols.next -
1560 (objfile->global_psymbols.list + pst->globals_offset);
1561 pst->n_static_syms = objfile->static_psymbols.next -
1562 (objfile->static_psymbols.list + pst->statics_offset);
1563 sort_pst_symbols (pst);
1564
1565 /* If there is already a psymtab or symtab for a file of this
1566 name, remove it. (If there is a symtab, more drastic things
1567 also happen.) This happens in VxWorks. */
1568 free_named_symtabs (pst->filename);
1569
dd373385
EZ
1570 info_ptr = beg_of_comp_unit + cu.header.length
1571 + cu.header.initial_length_size;
1572
aaa75496
JB
1573 if (comp_unit_die.has_stmt_list)
1574 {
1575 /* Get the list of files included in the current compilation unit,
1576 and build a psymtab for each of them. */
1577 dwarf2_build_include_psymtabs (&cu, &comp_unit_die, pst);
1578 }
1579
f3dd6933 1580 do_cleanups (back_to_inner);
c906108c 1581 }
ae038cb0
DJ
1582 do_cleanups (back_to);
1583}
1584
1585/* Load the DIEs for a secondary CU into memory. */
1586
1587static void
1588load_comp_unit (struct dwarf2_per_cu_data *this_cu, struct objfile *objfile)
1589{
1590 bfd *abfd = objfile->obfd;
fe1b8b76 1591 gdb_byte *info_ptr, *beg_of_comp_unit;
ae038cb0
DJ
1592 struct partial_die_info comp_unit_die;
1593 struct dwarf2_cu *cu;
1594 struct abbrev_info *abbrev;
1595 unsigned int bytes_read;
1596 struct cleanup *back_to;
1597
1598 info_ptr = dwarf2_per_objfile->info_buffer + this_cu->offset;
1599 beg_of_comp_unit = info_ptr;
1600
1601 cu = xmalloc (sizeof (struct dwarf2_cu));
1602 memset (cu, 0, sizeof (struct dwarf2_cu));
1603
1604 obstack_init (&cu->comp_unit_obstack);
1605
1606 cu->objfile = objfile;
1607 info_ptr = partial_read_comp_unit_head (&cu->header, info_ptr, abfd);
1608
1609 /* Complete the cu_header. */
1610 cu->header.offset = beg_of_comp_unit - dwarf2_per_objfile->info_buffer;
1611 cu->header.first_die_ptr = info_ptr;
1612 cu->header.cu_head_ptr = beg_of_comp_unit;
1613
1614 /* Read the abbrevs for this compilation unit into a table. */
1615 dwarf2_read_abbrevs (abfd, cu);
1616 back_to = make_cleanup (dwarf2_free_abbrev_table, cu);
1617
1618 /* Read the compilation unit die. */
1619 abbrev = peek_die_abbrev (info_ptr, &bytes_read, cu);
1620 info_ptr = read_partial_die (&comp_unit_die, abbrev, bytes_read,
1621 abfd, info_ptr, cu);
1622
1623 /* Set the language we're debugging. */
1624 set_cu_language (comp_unit_die.language, cu);
1625
1626 /* Link this compilation unit into the compilation unit tree. */
1627 this_cu->cu = cu;
1628 cu->per_cu = this_cu;
1629
1630 /* Check if comp unit has_children.
1631 If so, read the rest of the partial symbols from this comp unit.
1632 If not, there's no more debug_info for this comp unit. */
1633 if (comp_unit_die.has_children)
1634 load_partial_dies (abfd, info_ptr, 0, cu);
1635
1636 do_cleanups (back_to);
1637}
1638
1639/* Create a list of all compilation units in OBJFILE. We do this only
1640 if an inter-comp-unit reference is found; presumably if there is one,
1641 there will be many, and one will occur early in the .debug_info section.
1642 So there's no point in building this list incrementally. */
1643
1644static void
1645create_all_comp_units (struct objfile *objfile)
1646{
1647 int n_allocated;
1648 int n_comp_units;
1649 struct dwarf2_per_cu_data **all_comp_units;
fe1b8b76 1650 gdb_byte *info_ptr = dwarf2_per_objfile->info_buffer;
ae038cb0
DJ
1651
1652 n_comp_units = 0;
1653 n_allocated = 10;
1654 all_comp_units = xmalloc (n_allocated
1655 * sizeof (struct dwarf2_per_cu_data *));
1656
1657 while (info_ptr < dwarf2_per_objfile->info_buffer + dwarf2_per_objfile->info_size)
1658 {
1659 struct comp_unit_head cu_header;
fe1b8b76 1660 gdb_byte *beg_of_comp_unit;
ae038cb0
DJ
1661 struct dwarf2_per_cu_data *this_cu;
1662 unsigned long offset;
891d2f0b 1663 unsigned int bytes_read;
ae038cb0
DJ
1664
1665 offset = info_ptr - dwarf2_per_objfile->info_buffer;
1666
1667 /* Read just enough information to find out where the next
1668 compilation unit is. */
dd373385 1669 cu_header.initial_length_size = 0;
ae038cb0
DJ
1670 cu_header.length = read_initial_length (objfile->obfd, info_ptr,
1671 &cu_header, &bytes_read);
1672
1673 /* Save the compilation unit for later lookup. */
1674 this_cu = obstack_alloc (&objfile->objfile_obstack,
1675 sizeof (struct dwarf2_per_cu_data));
1676 memset (this_cu, 0, sizeof (*this_cu));
1677 this_cu->offset = offset;
1678 this_cu->length = cu_header.length + cu_header.initial_length_size;
1679
1680 if (n_comp_units == n_allocated)
1681 {
1682 n_allocated *= 2;
1683 all_comp_units = xrealloc (all_comp_units,
1684 n_allocated
1685 * sizeof (struct dwarf2_per_cu_data *));
1686 }
1687 all_comp_units[n_comp_units++] = this_cu;
1688
1689 info_ptr = info_ptr + this_cu->length;
1690 }
1691
1692 dwarf2_per_objfile->all_comp_units
1693 = obstack_alloc (&objfile->objfile_obstack,
1694 n_comp_units * sizeof (struct dwarf2_per_cu_data *));
1695 memcpy (dwarf2_per_objfile->all_comp_units, all_comp_units,
1696 n_comp_units * sizeof (struct dwarf2_per_cu_data *));
1697 xfree (all_comp_units);
1698 dwarf2_per_objfile->n_comp_units = n_comp_units;
c906108c
SS
1699}
1700
72bf9492
DJ
1701/* Process all loaded DIEs for compilation unit CU, starting at FIRST_DIE.
1702 Also set *LOWPC and *HIGHPC to the lowest and highest PC values found
1703 in CU. */
c906108c 1704
72bf9492
DJ
1705static void
1706scan_partial_symbols (struct partial_die_info *first_die, CORE_ADDR *lowpc,
1707 CORE_ADDR *highpc, struct dwarf2_cu *cu)
c906108c 1708{
e7c27a73 1709 struct objfile *objfile = cu->objfile;
c906108c 1710 bfd *abfd = objfile->obfd;
72bf9492 1711 struct partial_die_info *pdi;
c906108c 1712
91c24f0a
DC
1713 /* Now, march along the PDI's, descending into ones which have
1714 interesting children but skipping the children of the other ones,
1715 until we reach the end of the compilation unit. */
c906108c 1716
72bf9492 1717 pdi = first_die;
91c24f0a 1718
72bf9492
DJ
1719 while (pdi != NULL)
1720 {
1721 fixup_partial_die (pdi, cu);
c906108c 1722
91c24f0a
DC
1723 /* Anonymous namespaces have no name but have interesting
1724 children, so we need to look at them. Ditto for anonymous
1725 enums. */
933c6fe4 1726
72bf9492
DJ
1727 if (pdi->name != NULL || pdi->tag == DW_TAG_namespace
1728 || pdi->tag == DW_TAG_enumeration_type)
c906108c 1729 {
72bf9492 1730 switch (pdi->tag)
c906108c
SS
1731 {
1732 case DW_TAG_subprogram:
72bf9492 1733 if (pdi->has_pc_info)
c906108c 1734 {
72bf9492 1735 if (pdi->lowpc < *lowpc)
c906108c 1736 {
72bf9492 1737 *lowpc = pdi->lowpc;
c906108c 1738 }
72bf9492 1739 if (pdi->highpc > *highpc)
c906108c 1740 {
72bf9492 1741 *highpc = pdi->highpc;
c906108c 1742 }
72bf9492 1743 if (!pdi->is_declaration)
c906108c 1744 {
72bf9492 1745 add_partial_symbol (pdi, cu);
c906108c
SS
1746 }
1747 }
1748 break;
1749 case DW_TAG_variable:
1750 case DW_TAG_typedef:
91c24f0a 1751 case DW_TAG_union_type:
72bf9492 1752 if (!pdi->is_declaration)
63d06c5c 1753 {
72bf9492 1754 add_partial_symbol (pdi, cu);
63d06c5c
DC
1755 }
1756 break;
c906108c
SS
1757 case DW_TAG_class_type:
1758 case DW_TAG_structure_type:
72bf9492 1759 if (!pdi->is_declaration)
c906108c 1760 {
72bf9492 1761 add_partial_symbol (pdi, cu);
c906108c
SS
1762 }
1763 break;
91c24f0a 1764 case DW_TAG_enumeration_type:
72bf9492
DJ
1765 if (!pdi->is_declaration)
1766 add_partial_enumeration (pdi, cu);
c906108c
SS
1767 break;
1768 case DW_TAG_base_type:
a02abb62 1769 case DW_TAG_subrange_type:
c906108c 1770 /* File scope base type definitions are added to the partial
c5aa993b 1771 symbol table. */
72bf9492 1772 add_partial_symbol (pdi, cu);
c906108c 1773 break;
d9fa45fe 1774 case DW_TAG_namespace:
72bf9492 1775 add_partial_namespace (pdi, lowpc, highpc, cu);
91c24f0a 1776 break;
c906108c
SS
1777 default:
1778 break;
1779 }
1780 }
1781
72bf9492
DJ
1782 /* If the die has a sibling, skip to the sibling. */
1783
1784 pdi = pdi->die_sibling;
1785 }
1786}
1787
1788/* Functions used to compute the fully scoped name of a partial DIE.
91c24f0a 1789
72bf9492 1790 Normally, this is simple. For C++, the parent DIE's fully scoped
987504bb
JJ
1791 name is concatenated with "::" and the partial DIE's name. For
1792 Java, the same thing occurs except that "." is used instead of "::".
72bf9492
DJ
1793 Enumerators are an exception; they use the scope of their parent
1794 enumeration type, i.e. the name of the enumeration type is not
1795 prepended to the enumerator.
91c24f0a 1796
72bf9492
DJ
1797 There are two complexities. One is DW_AT_specification; in this
1798 case "parent" means the parent of the target of the specification,
1799 instead of the direct parent of the DIE. The other is compilers
1800 which do not emit DW_TAG_namespace; in this case we try to guess
1801 the fully qualified name of structure types from their members'
1802 linkage names. This must be done using the DIE's children rather
1803 than the children of any DW_AT_specification target. We only need
1804 to do this for structures at the top level, i.e. if the target of
1805 any DW_AT_specification (if any; otherwise the DIE itself) does not
1806 have a parent. */
1807
1808/* Compute the scope prefix associated with PDI's parent, in
1809 compilation unit CU. The result will be allocated on CU's
1810 comp_unit_obstack, or a copy of the already allocated PDI->NAME
1811 field. NULL is returned if no prefix is necessary. */
1812static char *
1813partial_die_parent_scope (struct partial_die_info *pdi,
1814 struct dwarf2_cu *cu)
1815{
1816 char *grandparent_scope;
1817 struct partial_die_info *parent, *real_pdi;
91c24f0a 1818
72bf9492
DJ
1819 /* We need to look at our parent DIE; if we have a DW_AT_specification,
1820 then this means the parent of the specification DIE. */
1821
1822 real_pdi = pdi;
72bf9492 1823 while (real_pdi->has_specification)
10b3939b 1824 real_pdi = find_partial_die (real_pdi->spec_offset, cu);
72bf9492
DJ
1825
1826 parent = real_pdi->die_parent;
1827 if (parent == NULL)
1828 return NULL;
1829
1830 if (parent->scope_set)
1831 return parent->scope;
1832
1833 fixup_partial_die (parent, cu);
1834
10b3939b 1835 grandparent_scope = partial_die_parent_scope (parent, cu);
72bf9492
DJ
1836
1837 if (parent->tag == DW_TAG_namespace
1838 || parent->tag == DW_TAG_structure_type
1839 || parent->tag == DW_TAG_class_type
1840 || parent->tag == DW_TAG_union_type)
1841 {
1842 if (grandparent_scope == NULL)
1843 parent->scope = parent->name;
1844 else
987504bb
JJ
1845 parent->scope = typename_concat (&cu->comp_unit_obstack, grandparent_scope,
1846 parent->name, cu);
72bf9492
DJ
1847 }
1848 else if (parent->tag == DW_TAG_enumeration_type)
1849 /* Enumerators should not get the name of the enumeration as a prefix. */
1850 parent->scope = grandparent_scope;
1851 else
1852 {
1853 /* FIXME drow/2004-04-01: What should we be doing with
1854 function-local names? For partial symbols, we should probably be
1855 ignoring them. */
1856 complaint (&symfile_complaints,
e2e0b3e5 1857 _("unhandled containing DIE tag %d for DIE at %d"),
72bf9492
DJ
1858 parent->tag, pdi->offset);
1859 parent->scope = grandparent_scope;
c906108c
SS
1860 }
1861
72bf9492
DJ
1862 parent->scope_set = 1;
1863 return parent->scope;
1864}
1865
1866/* Return the fully scoped name associated with PDI, from compilation unit
1867 CU. The result will be allocated with malloc. */
1868static char *
1869partial_die_full_name (struct partial_die_info *pdi,
1870 struct dwarf2_cu *cu)
1871{
1872 char *parent_scope;
1873
1874 parent_scope = partial_die_parent_scope (pdi, cu);
1875 if (parent_scope == NULL)
1876 return NULL;
1877 else
987504bb 1878 return typename_concat (NULL, parent_scope, pdi->name, cu);
c906108c
SS
1879}
1880
1881static void
72bf9492 1882add_partial_symbol (struct partial_die_info *pdi, struct dwarf2_cu *cu)
c906108c 1883{
e7c27a73 1884 struct objfile *objfile = cu->objfile;
c906108c 1885 CORE_ADDR addr = 0;
72bf9492
DJ
1886 char *actual_name;
1887 const char *my_prefix;
5c4e30ca 1888 const struct partial_symbol *psym = NULL;
e142c38c 1889 CORE_ADDR baseaddr;
72bf9492 1890 int built_actual_name = 0;
e142c38c
DJ
1891
1892 baseaddr = ANOFFSET (objfile->section_offsets, SECT_OFF_TEXT (objfile));
c906108c 1893
72bf9492
DJ
1894 actual_name = NULL;
1895
1896 if (pdi_needs_namespace (pdi->tag))
63d06c5c 1897 {
72bf9492
DJ
1898 actual_name = partial_die_full_name (pdi, cu);
1899 if (actual_name)
1900 built_actual_name = 1;
63d06c5c
DC
1901 }
1902
72bf9492
DJ
1903 if (actual_name == NULL)
1904 actual_name = pdi->name;
1905
c906108c
SS
1906 switch (pdi->tag)
1907 {
1908 case DW_TAG_subprogram:
1909 if (pdi->is_external)
1910 {
38d518c9 1911 /*prim_record_minimal_symbol (actual_name, pdi->lowpc + baseaddr,
c5aa993b 1912 mst_text, objfile); */
38d518c9 1913 psym = add_psymbol_to_list (actual_name, strlen (actual_name),
5c4e30ca
DC
1914 VAR_DOMAIN, LOC_BLOCK,
1915 &objfile->global_psymbols,
1916 0, pdi->lowpc + baseaddr,
e142c38c 1917 cu->language, objfile);
c906108c
SS
1918 }
1919 else
1920 {
38d518c9 1921 /*prim_record_minimal_symbol (actual_name, pdi->lowpc + baseaddr,
c5aa993b 1922 mst_file_text, objfile); */
38d518c9 1923 psym = add_psymbol_to_list (actual_name, strlen (actual_name),
5c4e30ca
DC
1924 VAR_DOMAIN, LOC_BLOCK,
1925 &objfile->static_psymbols,
1926 0, pdi->lowpc + baseaddr,
e142c38c 1927 cu->language, objfile);
c906108c
SS
1928 }
1929 break;
1930 case DW_TAG_variable:
1931 if (pdi->is_external)
1932 {
1933 /* Global Variable.
1934 Don't enter into the minimal symbol tables as there is
1935 a minimal symbol table entry from the ELF symbols already.
1936 Enter into partial symbol table if it has a location
1937 descriptor or a type.
1938 If the location descriptor is missing, new_symbol will create
1939 a LOC_UNRESOLVED symbol, the address of the variable will then
1940 be determined from the minimal symbol table whenever the variable
1941 is referenced.
1942 The address for the partial symbol table entry is not
1943 used by GDB, but it comes in handy for debugging partial symbol
1944 table building. */
1945
1946 if (pdi->locdesc)
e7c27a73 1947 addr = decode_locdesc (pdi->locdesc, cu);
c906108c 1948 if (pdi->locdesc || pdi->has_type)
38d518c9 1949 psym = add_psymbol_to_list (actual_name, strlen (actual_name),
5c4e30ca
DC
1950 VAR_DOMAIN, LOC_STATIC,
1951 &objfile->global_psymbols,
1952 0, addr + baseaddr,
e142c38c 1953 cu->language, objfile);
c906108c
SS
1954 }
1955 else
1956 {
1957 /* Static Variable. Skip symbols without location descriptors. */
1958 if (pdi->locdesc == NULL)
1959 return;
e7c27a73 1960 addr = decode_locdesc (pdi->locdesc, cu);
38d518c9 1961 /*prim_record_minimal_symbol (actual_name, addr + baseaddr,
c5aa993b 1962 mst_file_data, objfile); */
38d518c9 1963 psym = add_psymbol_to_list (actual_name, strlen (actual_name),
5c4e30ca
DC
1964 VAR_DOMAIN, LOC_STATIC,
1965 &objfile->static_psymbols,
1966 0, addr + baseaddr,
e142c38c 1967 cu->language, objfile);
c906108c
SS
1968 }
1969 break;
1970 case DW_TAG_typedef:
1971 case DW_TAG_base_type:
a02abb62 1972 case DW_TAG_subrange_type:
38d518c9 1973 add_psymbol_to_list (actual_name, strlen (actual_name),
176620f1 1974 VAR_DOMAIN, LOC_TYPEDEF,
c906108c 1975 &objfile->static_psymbols,
e142c38c 1976 0, (CORE_ADDR) 0, cu->language, objfile);
c906108c 1977 break;
72bf9492
DJ
1978 case DW_TAG_namespace:
1979 add_psymbol_to_list (actual_name, strlen (actual_name),
1980 VAR_DOMAIN, LOC_TYPEDEF,
1981 &objfile->global_psymbols,
1982 0, (CORE_ADDR) 0, cu->language, objfile);
1983 break;
c906108c
SS
1984 case DW_TAG_class_type:
1985 case DW_TAG_structure_type:
1986 case DW_TAG_union_type:
1987 case DW_TAG_enumeration_type:
fa4028e9
JB
1988 /* Skip external references. The DWARF standard says in the section
1989 about "Structure, Union, and Class Type Entries": "An incomplete
1990 structure, union or class type is represented by a structure,
1991 union or class entry that does not have a byte size attribute
1992 and that has a DW_AT_declaration attribute." */
1993 if (!pdi->has_byte_size && pdi->is_declaration)
1994 return;
1995
63d06c5c
DC
1996 /* NOTE: carlton/2003-10-07: See comment in new_symbol about
1997 static vs. global. */
38d518c9 1998 add_psymbol_to_list (actual_name, strlen (actual_name),
176620f1 1999 STRUCT_DOMAIN, LOC_TYPEDEF,
987504bb
JJ
2000 (cu->language == language_cplus
2001 || cu->language == language_java)
63d06c5c
DC
2002 ? &objfile->global_psymbols
2003 : &objfile->static_psymbols,
e142c38c 2004 0, (CORE_ADDR) 0, cu->language, objfile);
c906108c 2005
987504bb
JJ
2006 if (cu->language == language_cplus
2007 || cu->language == language_java)
c906108c 2008 {
987504bb 2009 /* For C++ and Java, these implicitly act as typedefs as well. */
38d518c9 2010 add_psymbol_to_list (actual_name, strlen (actual_name),
176620f1 2011 VAR_DOMAIN, LOC_TYPEDEF,
63d06c5c 2012 &objfile->global_psymbols,
e142c38c 2013 0, (CORE_ADDR) 0, cu->language, objfile);
c906108c
SS
2014 }
2015 break;
2016 case DW_TAG_enumerator:
38d518c9 2017 add_psymbol_to_list (actual_name, strlen (actual_name),
176620f1 2018 VAR_DOMAIN, LOC_CONST,
987504bb
JJ
2019 (cu->language == language_cplus
2020 || cu->language == language_java)
f6fe98ef
DJ
2021 ? &objfile->global_psymbols
2022 : &objfile->static_psymbols,
e142c38c 2023 0, (CORE_ADDR) 0, cu->language, objfile);
c906108c
SS
2024 break;
2025 default:
2026 break;
2027 }
5c4e30ca
DC
2028
2029 /* Check to see if we should scan the name for possible namespace
2030 info. Only do this if this is C++, if we don't have namespace
2031 debugging info in the file, if the psym is of an appropriate type
2032 (otherwise we'll have psym == NULL), and if we actually had a
2033 mangled name to begin with. */
2034
72bf9492
DJ
2035 /* FIXME drow/2004-02-22: Why don't we do this for classes, i.e. the
2036 cases which do not set PSYM above? */
2037
e142c38c 2038 if (cu->language == language_cplus
72bf9492 2039 && cu->has_namespace_info == 0
5c4e30ca
DC
2040 && psym != NULL
2041 && SYMBOL_CPLUS_DEMANGLED_NAME (psym) != NULL)
2042 cp_check_possible_namespace_symbols (SYMBOL_CPLUS_DEMANGLED_NAME (psym),
2043 objfile);
72bf9492
DJ
2044
2045 if (built_actual_name)
2046 xfree (actual_name);
c906108c
SS
2047}
2048
72bf9492
DJ
2049/* Determine whether a die of type TAG living in a C++ class or
2050 namespace needs to have the name of the scope prepended to the
63d06c5c
DC
2051 name listed in the die. */
2052
2053static int
72bf9492 2054pdi_needs_namespace (enum dwarf_tag tag)
63d06c5c 2055{
63d06c5c
DC
2056 switch (tag)
2057 {
72bf9492 2058 case DW_TAG_namespace:
63d06c5c
DC
2059 case DW_TAG_typedef:
2060 case DW_TAG_class_type:
2061 case DW_TAG_structure_type:
2062 case DW_TAG_union_type:
2063 case DW_TAG_enumeration_type:
2064 case DW_TAG_enumerator:
2065 return 1;
2066 default:
2067 return 0;
2068 }
2069}
2070
5c4e30ca
DC
2071/* Read a partial die corresponding to a namespace; also, add a symbol
2072 corresponding to that namespace to the symbol table. NAMESPACE is
2073 the name of the enclosing namespace. */
91c24f0a 2074
72bf9492
DJ
2075static void
2076add_partial_namespace (struct partial_die_info *pdi,
91c24f0a 2077 CORE_ADDR *lowpc, CORE_ADDR *highpc,
72bf9492 2078 struct dwarf2_cu *cu)
91c24f0a 2079{
e7c27a73 2080 struct objfile *objfile = cu->objfile;
5c4e30ca 2081
72bf9492 2082 /* Add a symbol for the namespace. */
e7c27a73 2083
72bf9492 2084 add_partial_symbol (pdi, cu);
5c4e30ca
DC
2085
2086 /* Now scan partial symbols in that namespace. */
2087
91c24f0a 2088 if (pdi->has_children)
72bf9492 2089 scan_partial_symbols (pdi->die_child, lowpc, highpc, cu);
91c24f0a
DC
2090}
2091
72bf9492
DJ
2092/* See if we can figure out if the class lives in a namespace. We do
2093 this by looking for a member function; its demangled name will
2094 contain namespace info, if there is any. */
63d06c5c 2095
72bf9492
DJ
2096static void
2097guess_structure_name (struct partial_die_info *struct_pdi,
2098 struct dwarf2_cu *cu)
63d06c5c 2099{
987504bb
JJ
2100 if ((cu->language == language_cplus
2101 || cu->language == language_java)
72bf9492 2102 && cu->has_namespace_info == 0
63d06c5c
DC
2103 && struct_pdi->has_children)
2104 {
63d06c5c
DC
2105 /* NOTE: carlton/2003-10-07: Getting the info this way changes
2106 what template types look like, because the demangler
2107 frequently doesn't give the same name as the debug info. We
2108 could fix this by only using the demangled name to get the
134d01f1 2109 prefix (but see comment in read_structure_type). */
63d06c5c 2110
72bf9492
DJ
2111 struct partial_die_info *child_pdi = struct_pdi->die_child;
2112 struct partial_die_info *real_pdi;
5d51ca54 2113
72bf9492
DJ
2114 /* If this DIE (this DIE's specification, if any) has a parent, then
2115 we should not do this. We'll prepend the parent's fully qualified
2116 name when we create the partial symbol. */
5d51ca54 2117
72bf9492 2118 real_pdi = struct_pdi;
72bf9492 2119 while (real_pdi->has_specification)
10b3939b 2120 real_pdi = find_partial_die (real_pdi->spec_offset, cu);
63d06c5c 2121
72bf9492
DJ
2122 if (real_pdi->die_parent != NULL)
2123 return;
63d06c5c 2124
72bf9492
DJ
2125 while (child_pdi != NULL)
2126 {
2127 if (child_pdi->tag == DW_TAG_subprogram)
63d06c5c 2128 {
72bf9492 2129 char *actual_class_name
31c27f77
JJ
2130 = language_class_name_from_physname (cu->language_defn,
2131 child_pdi->name);
63d06c5c 2132 if (actual_class_name != NULL)
72bf9492
DJ
2133 {
2134 struct_pdi->name
2135 = obsavestring (actual_class_name,
2136 strlen (actual_class_name),
2137 &cu->comp_unit_obstack);
2138 xfree (actual_class_name);
2139 }
63d06c5c
DC
2140 break;
2141 }
72bf9492
DJ
2142
2143 child_pdi = child_pdi->die_sibling;
63d06c5c
DC
2144 }
2145 }
63d06c5c
DC
2146}
2147
91c24f0a
DC
2148/* Read a partial die corresponding to an enumeration type. */
2149
72bf9492
DJ
2150static void
2151add_partial_enumeration (struct partial_die_info *enum_pdi,
2152 struct dwarf2_cu *cu)
91c24f0a 2153{
e7c27a73 2154 struct objfile *objfile = cu->objfile;
91c24f0a 2155 bfd *abfd = objfile->obfd;
72bf9492 2156 struct partial_die_info *pdi;
91c24f0a
DC
2157
2158 if (enum_pdi->name != NULL)
72bf9492
DJ
2159 add_partial_symbol (enum_pdi, cu);
2160
2161 pdi = enum_pdi->die_child;
2162 while (pdi)
91c24f0a 2163 {
72bf9492 2164 if (pdi->tag != DW_TAG_enumerator || pdi->name == NULL)
e2e0b3e5 2165 complaint (&symfile_complaints, _("malformed enumerator DIE ignored"));
91c24f0a 2166 else
72bf9492
DJ
2167 add_partial_symbol (pdi, cu);
2168 pdi = pdi->die_sibling;
91c24f0a 2169 }
91c24f0a
DC
2170}
2171
4bb7a0a7
DJ
2172/* Read the initial uleb128 in the die at INFO_PTR in compilation unit CU.
2173 Return the corresponding abbrev, or NULL if the number is zero (indicating
2174 an empty DIE). In either case *BYTES_READ will be set to the length of
2175 the initial number. */
2176
2177static struct abbrev_info *
fe1b8b76 2178peek_die_abbrev (gdb_byte *info_ptr, unsigned int *bytes_read,
891d2f0b 2179 struct dwarf2_cu *cu)
4bb7a0a7
DJ
2180{
2181 bfd *abfd = cu->objfile->obfd;
2182 unsigned int abbrev_number;
2183 struct abbrev_info *abbrev;
2184
2185 abbrev_number = read_unsigned_leb128 (abfd, info_ptr, bytes_read);
2186
2187 if (abbrev_number == 0)
2188 return NULL;
2189
2190 abbrev = dwarf2_lookup_abbrev (abbrev_number, cu);
2191 if (!abbrev)
2192 {
8a3fe4f8 2193 error (_("Dwarf Error: Could not find abbrev number %d [in module %s]"), abbrev_number,
4bb7a0a7
DJ
2194 bfd_get_filename (abfd));
2195 }
2196
2197 return abbrev;
2198}
2199
2200/* Scan the debug information for CU starting at INFO_PTR. Returns a
2201 pointer to the end of a series of DIEs, terminated by an empty
2202 DIE. Any children of the skipped DIEs will also be skipped. */
2203
fe1b8b76
JB
2204static gdb_byte *
2205skip_children (gdb_byte *info_ptr, struct dwarf2_cu *cu)
4bb7a0a7
DJ
2206{
2207 struct abbrev_info *abbrev;
2208 unsigned int bytes_read;
2209
2210 while (1)
2211 {
2212 abbrev = peek_die_abbrev (info_ptr, &bytes_read, cu);
2213 if (abbrev == NULL)
2214 return info_ptr + bytes_read;
2215 else
2216 info_ptr = skip_one_die (info_ptr + bytes_read, abbrev, cu);
2217 }
2218}
2219
2220/* Scan the debug information for CU starting at INFO_PTR. INFO_PTR
2221 should point just after the initial uleb128 of a DIE, and the
2222 abbrev corresponding to that skipped uleb128 should be passed in
2223 ABBREV. Returns a pointer to this DIE's sibling, skipping any
2224 children. */
2225
fe1b8b76
JB
2226static gdb_byte *
2227skip_one_die (gdb_byte *info_ptr, struct abbrev_info *abbrev,
4bb7a0a7
DJ
2228 struct dwarf2_cu *cu)
2229{
2230 unsigned int bytes_read;
2231 struct attribute attr;
2232 bfd *abfd = cu->objfile->obfd;
2233 unsigned int form, i;
2234
2235 for (i = 0; i < abbrev->num_attrs; i++)
2236 {
2237 /* The only abbrev we care about is DW_AT_sibling. */
2238 if (abbrev->attrs[i].name == DW_AT_sibling)
2239 {
2240 read_attribute (&attr, &abbrev->attrs[i],
2241 abfd, info_ptr, cu);
2242 if (attr.form == DW_FORM_ref_addr)
e2e0b3e5 2243 complaint (&symfile_complaints, _("ignoring absolute DW_AT_sibling"));
4bb7a0a7 2244 else
6502dd73
DJ
2245 return dwarf2_per_objfile->info_buffer
2246 + dwarf2_get_ref_die_offset (&attr, cu);
4bb7a0a7
DJ
2247 }
2248
2249 /* If it isn't DW_AT_sibling, skip this attribute. */
2250 form = abbrev->attrs[i].form;
2251 skip_attribute:
2252 switch (form)
2253 {
2254 case DW_FORM_addr:
2255 case DW_FORM_ref_addr:
2256 info_ptr += cu->header.addr_size;
2257 break;
2258 case DW_FORM_data1:
2259 case DW_FORM_ref1:
2260 case DW_FORM_flag:
2261 info_ptr += 1;
2262 break;
2263 case DW_FORM_data2:
2264 case DW_FORM_ref2:
2265 info_ptr += 2;
2266 break;
2267 case DW_FORM_data4:
2268 case DW_FORM_ref4:
2269 info_ptr += 4;
2270 break;
2271 case DW_FORM_data8:
2272 case DW_FORM_ref8:
2273 info_ptr += 8;
2274 break;
2275 case DW_FORM_string:
2276 read_string (abfd, info_ptr, &bytes_read);
2277 info_ptr += bytes_read;
2278 break;
2279 case DW_FORM_strp:
2280 info_ptr += cu->header.offset_size;
2281 break;
2282 case DW_FORM_block:
2283 info_ptr += read_unsigned_leb128 (abfd, info_ptr, &bytes_read);
2284 info_ptr += bytes_read;
2285 break;
2286 case DW_FORM_block1:
2287 info_ptr += 1 + read_1_byte (abfd, info_ptr);
2288 break;
2289 case DW_FORM_block2:
2290 info_ptr += 2 + read_2_bytes (abfd, info_ptr);
2291 break;
2292 case DW_FORM_block4:
2293 info_ptr += 4 + read_4_bytes (abfd, info_ptr);
2294 break;
2295 case DW_FORM_sdata:
2296 case DW_FORM_udata:
2297 case DW_FORM_ref_udata:
2298 info_ptr = skip_leb128 (abfd, info_ptr);
2299 break;
2300 case DW_FORM_indirect:
2301 form = read_unsigned_leb128 (abfd, info_ptr, &bytes_read);
2302 info_ptr += bytes_read;
2303 /* We need to continue parsing from here, so just go back to
2304 the top. */
2305 goto skip_attribute;
2306
2307 default:
8a3fe4f8 2308 error (_("Dwarf Error: Cannot handle %s in DWARF reader [in module %s]"),
4bb7a0a7
DJ
2309 dwarf_form_name (form),
2310 bfd_get_filename (abfd));
2311 }
2312 }
2313
2314 if (abbrev->has_children)
2315 return skip_children (info_ptr, cu);
2316 else
2317 return info_ptr;
2318}
2319
2320/* Locate ORIG_PDI's sibling; INFO_PTR should point to the start of
2321 the next DIE after ORIG_PDI. */
91c24f0a 2322
fe1b8b76
JB
2323static gdb_byte *
2324locate_pdi_sibling (struct partial_die_info *orig_pdi, gdb_byte *info_ptr,
e7c27a73 2325 bfd *abfd, struct dwarf2_cu *cu)
91c24f0a
DC
2326{
2327 /* Do we know the sibling already? */
72bf9492 2328
91c24f0a
DC
2329 if (orig_pdi->sibling)
2330 return orig_pdi->sibling;
2331
2332 /* Are there any children to deal with? */
2333
2334 if (!orig_pdi->has_children)
2335 return info_ptr;
2336
4bb7a0a7 2337 /* Skip the children the long way. */
91c24f0a 2338
4bb7a0a7 2339 return skip_children (info_ptr, cu);
91c24f0a
DC
2340}
2341
c906108c
SS
2342/* Expand this partial symbol table into a full symbol table. */
2343
2344static void
fba45db2 2345dwarf2_psymtab_to_symtab (struct partial_symtab *pst)
c906108c
SS
2346{
2347 /* FIXME: This is barely more than a stub. */
2348 if (pst != NULL)
2349 {
2350 if (pst->readin)
2351 {
8a3fe4f8 2352 warning (_("bug: psymtab for %s is already read in."), pst->filename);
c906108c
SS
2353 }
2354 else
2355 {
2356 if (info_verbose)
2357 {
a3f17187 2358 printf_filtered (_("Reading in symbols for %s..."), pst->filename);
c906108c
SS
2359 gdb_flush (gdb_stdout);
2360 }
2361
10b3939b
DJ
2362 /* Restore our global data. */
2363 dwarf2_per_objfile = objfile_data (pst->objfile,
2364 dwarf2_objfile_data_key);
2365
c906108c
SS
2366 psymtab_to_symtab_1 (pst);
2367
2368 /* Finish up the debug error message. */
2369 if (info_verbose)
a3f17187 2370 printf_filtered (_("done.\n"));
c906108c
SS
2371 }
2372 }
2373}
2374
10b3939b
DJ
2375/* Add PER_CU to the queue. */
2376
2377static void
2378queue_comp_unit (struct dwarf2_per_cu_data *per_cu)
2379{
2380 struct dwarf2_queue_item *item;
2381
2382 per_cu->queued = 1;
2383 item = xmalloc (sizeof (*item));
2384 item->per_cu = per_cu;
2385 item->next = NULL;
2386
2387 if (dwarf2_queue == NULL)
2388 dwarf2_queue = item;
2389 else
2390 dwarf2_queue_tail->next = item;
2391
2392 dwarf2_queue_tail = item;
2393}
2394
2395/* Process the queue. */
2396
2397static void
2398process_queue (struct objfile *objfile)
2399{
2400 struct dwarf2_queue_item *item, *next_item;
2401
2402 /* Initially, there is just one item on the queue. Load its DIEs,
2403 and the DIEs of any other compilation units it requires,
2404 transitively. */
2405
2406 for (item = dwarf2_queue; item != NULL; item = item->next)
2407 {
2408 /* Read in this compilation unit. This may add new items to
2409 the end of the queue. */
31ffec48 2410 load_full_comp_unit (item->per_cu, objfile);
10b3939b
DJ
2411
2412 item->per_cu->cu->read_in_chain = dwarf2_per_objfile->read_in_chain;
2413 dwarf2_per_objfile->read_in_chain = item->per_cu;
2414
2415 /* If this compilation unit has already had full symbols created,
2416 reset the TYPE fields in each DIE. */
31ffec48 2417 if (item->per_cu->type_hash)
10b3939b
DJ
2418 reset_die_and_siblings_types (item->per_cu->cu->dies,
2419 item->per_cu->cu);
2420 }
2421
2422 /* Now everything left on the queue needs to be read in. Process
2423 them, one at a time, removing from the queue as we finish. */
2424 for (item = dwarf2_queue; item != NULL; dwarf2_queue = item = next_item)
2425 {
31ffec48 2426 if (item->per_cu->psymtab && !item->per_cu->psymtab->readin)
10b3939b
DJ
2427 process_full_comp_unit (item->per_cu);
2428
2429 item->per_cu->queued = 0;
2430 next_item = item->next;
2431 xfree (item);
2432 }
2433
2434 dwarf2_queue_tail = NULL;
2435}
2436
2437/* Free all allocated queue entries. This function only releases anything if
2438 an error was thrown; if the queue was processed then it would have been
2439 freed as we went along. */
2440
2441static void
2442dwarf2_release_queue (void *dummy)
2443{
2444 struct dwarf2_queue_item *item, *last;
2445
2446 item = dwarf2_queue;
2447 while (item)
2448 {
2449 /* Anything still marked queued is likely to be in an
2450 inconsistent state, so discard it. */
2451 if (item->per_cu->queued)
2452 {
2453 if (item->per_cu->cu != NULL)
2454 free_one_cached_comp_unit (item->per_cu->cu);
2455 item->per_cu->queued = 0;
2456 }
2457
2458 last = item;
2459 item = item->next;
2460 xfree (last);
2461 }
2462
2463 dwarf2_queue = dwarf2_queue_tail = NULL;
2464}
2465
2466/* Read in full symbols for PST, and anything it depends on. */
2467
c906108c 2468static void
fba45db2 2469psymtab_to_symtab_1 (struct partial_symtab *pst)
c906108c 2470{
10b3939b 2471 struct dwarf2_per_cu_data *per_cu;
c906108c 2472 struct cleanup *back_to;
aaa75496
JB
2473 int i;
2474
2475 for (i = 0; i < pst->number_of_dependencies; i++)
2476 if (!pst->dependencies[i]->readin)
2477 {
2478 /* Inform about additional files that need to be read in. */
2479 if (info_verbose)
2480 {
a3f17187 2481 /* FIXME: i18n: Need to make this a single string. */
aaa75496
JB
2482 fputs_filtered (" ", gdb_stdout);
2483 wrap_here ("");
2484 fputs_filtered ("and ", gdb_stdout);
2485 wrap_here ("");
2486 printf_filtered ("%s...", pst->dependencies[i]->filename);
2487 wrap_here (""); /* Flush output */
2488 gdb_flush (gdb_stdout);
2489 }
2490 psymtab_to_symtab_1 (pst->dependencies[i]);
2491 }
2492
10b3939b
DJ
2493 per_cu = (struct dwarf2_per_cu_data *) pst->read_symtab_private;
2494
2495 if (per_cu == NULL)
aaa75496
JB
2496 {
2497 /* It's an include file, no symbols to read for it.
2498 Everything is in the parent symtab. */
2499 pst->readin = 1;
2500 return;
2501 }
c906108c 2502
10b3939b
DJ
2503 back_to = make_cleanup (dwarf2_release_queue, NULL);
2504
2505 queue_comp_unit (per_cu);
2506
2507 process_queue (pst->objfile);
2508
2509 /* Age the cache, releasing compilation units that have not
2510 been used recently. */
2511 age_cached_comp_units ();
2512
2513 do_cleanups (back_to);
2514}
2515
2516/* Load the DIEs associated with PST and PER_CU into memory. */
2517
2518static struct dwarf2_cu *
31ffec48 2519load_full_comp_unit (struct dwarf2_per_cu_data *per_cu, struct objfile *objfile)
10b3939b 2520{
31ffec48 2521 bfd *abfd = objfile->obfd;
10b3939b
DJ
2522 struct dwarf2_cu *cu;
2523 unsigned long offset;
fe1b8b76 2524 gdb_byte *info_ptr;
10b3939b
DJ
2525 struct cleanup *back_to, *free_cu_cleanup;
2526 struct attribute *attr;
2527 CORE_ADDR baseaddr;
6502dd73 2528
c906108c 2529 /* Set local variables from the partial symbol table info. */
10b3939b 2530 offset = per_cu->offset;
6502dd73
DJ
2531
2532 info_ptr = dwarf2_per_objfile->info_buffer + offset;
63d06c5c 2533
10b3939b
DJ
2534 cu = xmalloc (sizeof (struct dwarf2_cu));
2535 memset (cu, 0, sizeof (struct dwarf2_cu));
c906108c 2536
10b3939b
DJ
2537 /* If an error occurs while loading, release our storage. */
2538 free_cu_cleanup = make_cleanup (free_one_comp_unit, cu);
c906108c 2539
31ffec48 2540 cu->objfile = objfile;
e7c27a73 2541
c906108c 2542 /* read in the comp_unit header */
10b3939b 2543 info_ptr = read_comp_unit_head (&cu->header, info_ptr, abfd);
c906108c
SS
2544
2545 /* Read the abbrevs for this compilation unit */
10b3939b
DJ
2546 dwarf2_read_abbrevs (abfd, cu);
2547 back_to = make_cleanup (dwarf2_free_abbrev_table, cu);
2548
2549 cu->header.offset = offset;
c906108c 2550
10b3939b
DJ
2551 cu->per_cu = per_cu;
2552 per_cu->cu = cu;
e142c38c 2553
10b3939b
DJ
2554 /* We use this obstack for block values in dwarf_alloc_block. */
2555 obstack_init (&cu->comp_unit_obstack);
2556
2557 cu->dies = read_comp_unit (info_ptr, abfd, cu);
2558
2559 /* We try not to read any attributes in this function, because not
2560 all objfiles needed for references have been loaded yet, and symbol
2561 table processing isn't initialized. But we have to set the CU language,
2562 or we won't be able to build types correctly. */
2563 attr = dwarf2_attr (cu->dies, DW_AT_language, cu);
2564 if (attr)
2565 set_cu_language (DW_UNSND (attr), cu);
2566 else
2567 set_cu_language (language_minimal, cu);
2568
2569 do_cleanups (back_to);
e142c38c 2570
10b3939b
DJ
2571 /* We've successfully allocated this compilation unit. Let our caller
2572 clean it up when finished with it. */
2573 discard_cleanups (free_cu_cleanup);
c906108c 2574
10b3939b
DJ
2575 return cu;
2576}
2577
2578/* Generate full symbol information for PST and CU, whose DIEs have
2579 already been loaded into memory. */
2580
2581static void
2582process_full_comp_unit (struct dwarf2_per_cu_data *per_cu)
2583{
2584 struct partial_symtab *pst = per_cu->psymtab;
2585 struct dwarf2_cu *cu = per_cu->cu;
2586 struct objfile *objfile = pst->objfile;
2587 bfd *abfd = objfile->obfd;
2588 CORE_ADDR lowpc, highpc;
2589 struct symtab *symtab;
2590 struct cleanup *back_to;
2591 struct attribute *attr;
2592 CORE_ADDR baseaddr;
2593
2594 baseaddr = ANOFFSET (objfile->section_offsets, SECT_OFF_TEXT (objfile));
2595
2596 /* We're in the global namespace. */
2597 processing_current_prefix = "";
2598
2599 buildsym_init ();
2600 back_to = make_cleanup (really_free_pendings, NULL);
2601
2602 cu->list_in_scope = &file_symbols;
c906108c 2603
0d53c4c4
DJ
2604 /* Find the base address of the compilation unit for range lists and
2605 location lists. It will normally be specified by DW_AT_low_pc.
2606 In DWARF-3 draft 4, the base address could be overridden by
2607 DW_AT_entry_pc. It's been removed, but GCC still uses this for
2608 compilation units with discontinuous ranges. */
2609
10b3939b
DJ
2610 cu->header.base_known = 0;
2611 cu->header.base_address = 0;
0d53c4c4 2612
10b3939b 2613 attr = dwarf2_attr (cu->dies, DW_AT_entry_pc, cu);
0d53c4c4
DJ
2614 if (attr)
2615 {
10b3939b
DJ
2616 cu->header.base_address = DW_ADDR (attr);
2617 cu->header.base_known = 1;
0d53c4c4
DJ
2618 }
2619 else
2620 {
10b3939b 2621 attr = dwarf2_attr (cu->dies, DW_AT_low_pc, cu);
0d53c4c4
DJ
2622 if (attr)
2623 {
10b3939b
DJ
2624 cu->header.base_address = DW_ADDR (attr);
2625 cu->header.base_known = 1;
0d53c4c4
DJ
2626 }
2627 }
2628
c906108c 2629 /* Do line number decoding in read_file_scope () */
10b3939b 2630 process_die (cu->dies, cu);
c906108c 2631
fae299cd
DC
2632 /* Some compilers don't define a DW_AT_high_pc attribute for the
2633 compilation unit. If the DW_AT_high_pc is missing, synthesize
2634 it, by scanning the DIE's below the compilation unit. */
10b3939b 2635 get_scope_pc_bounds (cu->dies, &lowpc, &highpc, cu);
c906108c 2636
613e1657 2637 symtab = end_symtab (highpc + baseaddr, objfile, SECT_OFF_TEXT (objfile));
c906108c
SS
2638
2639 /* Set symtab language to language from DW_AT_language.
2640 If the compilation is from a C file generated by language preprocessors,
2641 do not set the language if it was already deduced by start_subfile. */
2642 if (symtab != NULL
10b3939b 2643 && !(cu->language == language_c && symtab->language != language_c))
c906108c 2644 {
10b3939b 2645 symtab->language = cu->language;
c906108c
SS
2646 }
2647 pst->symtab = symtab;
2648 pst->readin = 1;
c906108c
SS
2649
2650 do_cleanups (back_to);
2651}
2652
2653/* Process a die and its children. */
2654
2655static void
e7c27a73 2656process_die (struct die_info *die, struct dwarf2_cu *cu)
c906108c
SS
2657{
2658 switch (die->tag)
2659 {
2660 case DW_TAG_padding:
2661 break;
2662 case DW_TAG_compile_unit:
e7c27a73 2663 read_file_scope (die, cu);
c906108c
SS
2664 break;
2665 case DW_TAG_subprogram:
e7c27a73
DJ
2666 read_subroutine_type (die, cu);
2667 read_func_scope (die, cu);
c906108c
SS
2668 break;
2669 case DW_TAG_inlined_subroutine:
2670 /* FIXME: These are ignored for now.
c5aa993b
JM
2671 They could be used to set breakpoints on all inlined instances
2672 of a function and make GDB `next' properly over inlined functions. */
c906108c
SS
2673 break;
2674 case DW_TAG_lexical_block:
14898363
L
2675 case DW_TAG_try_block:
2676 case DW_TAG_catch_block:
e7c27a73 2677 read_lexical_block_scope (die, cu);
c906108c
SS
2678 break;
2679 case DW_TAG_class_type:
2680 case DW_TAG_structure_type:
2681 case DW_TAG_union_type:
134d01f1
DJ
2682 read_structure_type (die, cu);
2683 process_structure_scope (die, cu);
c906108c
SS
2684 break;
2685 case DW_TAG_enumeration_type:
134d01f1
DJ
2686 read_enumeration_type (die, cu);
2687 process_enumeration_scope (die, cu);
c906108c 2688 break;
134d01f1
DJ
2689
2690 /* FIXME drow/2004-03-14: These initialize die->type, but do not create
2691 a symbol or process any children. Therefore it doesn't do anything
2692 that won't be done on-demand by read_type_die. */
c906108c 2693 case DW_TAG_subroutine_type:
e7c27a73 2694 read_subroutine_type (die, cu);
c906108c 2695 break;
72019c9c
GM
2696 case DW_TAG_set_type:
2697 read_set_type (die, cu);
2698 break;
c906108c 2699 case DW_TAG_array_type:
e7c27a73 2700 read_array_type (die, cu);
c906108c
SS
2701 break;
2702 case DW_TAG_pointer_type:
e7c27a73 2703 read_tag_pointer_type (die, cu);
c906108c
SS
2704 break;
2705 case DW_TAG_ptr_to_member_type:
e7c27a73 2706 read_tag_ptr_to_member_type (die, cu);
c906108c
SS
2707 break;
2708 case DW_TAG_reference_type:
e7c27a73 2709 read_tag_reference_type (die, cu);
c906108c
SS
2710 break;
2711 case DW_TAG_string_type:
e7c27a73 2712 read_tag_string_type (die, cu);
c906108c 2713 break;
134d01f1
DJ
2714 /* END FIXME */
2715
c906108c 2716 case DW_TAG_base_type:
e7c27a73 2717 read_base_type (die, cu);
134d01f1
DJ
2718 /* Add a typedef symbol for the type definition, if it has a
2719 DW_AT_name. */
2720 new_symbol (die, die->type, cu);
c906108c 2721 break;
a02abb62
JB
2722 case DW_TAG_subrange_type:
2723 read_subrange_type (die, cu);
134d01f1
DJ
2724 /* Add a typedef symbol for the type definition, if it has a
2725 DW_AT_name. */
2726 new_symbol (die, die->type, cu);
a02abb62 2727 break;
c906108c 2728 case DW_TAG_common_block:
e7c27a73 2729 read_common_block (die, cu);
c906108c
SS
2730 break;
2731 case DW_TAG_common_inclusion:
2732 break;
d9fa45fe 2733 case DW_TAG_namespace:
63d06c5c 2734 processing_has_namespace_info = 1;
e7c27a73 2735 read_namespace (die, cu);
d9fa45fe
DC
2736 break;
2737 case DW_TAG_imported_declaration:
2738 case DW_TAG_imported_module:
2739 /* FIXME: carlton/2002-10-16: Eventually, we should use the
2740 information contained in these. DW_TAG_imported_declaration
2741 dies shouldn't have children; DW_TAG_imported_module dies
2742 shouldn't in the C++ case, but conceivably could in the
2743 Fortran case, so we'll have to replace this gdb_assert if
2744 Fortran compilers start generating that info. */
63d06c5c 2745 processing_has_namespace_info = 1;
639d11d3 2746 gdb_assert (die->child == NULL);
d9fa45fe 2747 break;
c906108c 2748 default:
e7c27a73 2749 new_symbol (die, NULL, cu);
c906108c
SS
2750 break;
2751 }
2752}
2753
5fb290d7 2754static void
e142c38c 2755initialize_cu_func_list (struct dwarf2_cu *cu)
5fb290d7 2756{
e142c38c 2757 cu->first_fn = cu->last_fn = cu->cached_fn = NULL;
5fb290d7
DJ
2758}
2759
cb1df416
DJ
2760static void
2761free_cu_line_header (void *arg)
2762{
2763 struct dwarf2_cu *cu = arg;
2764
2765 free_line_header (cu->line_header);
2766 cu->line_header = NULL;
2767}
2768
c906108c 2769static void
e7c27a73 2770read_file_scope (struct die_info *die, struct dwarf2_cu *cu)
c906108c 2771{
e7c27a73
DJ
2772 struct objfile *objfile = cu->objfile;
2773 struct comp_unit_head *cu_header = &cu->header;
debd256d 2774 struct cleanup *back_to = make_cleanup (null_cleanup, 0);
2acceee2 2775 CORE_ADDR lowpc = ((CORE_ADDR) -1);
c906108c
SS
2776 CORE_ADDR highpc = ((CORE_ADDR) 0);
2777 struct attribute *attr;
2778 char *name = "<unknown>";
2779 char *comp_dir = NULL;
2780 struct die_info *child_die;
2781 bfd *abfd = objfile->obfd;
debd256d 2782 struct line_header *line_header = 0;
e142c38c
DJ
2783 CORE_ADDR baseaddr;
2784
2785 baseaddr = ANOFFSET (objfile->section_offsets, SECT_OFF_TEXT (objfile));
c906108c 2786
fae299cd 2787 get_scope_pc_bounds (die, &lowpc, &highpc, cu);
c906108c
SS
2788
2789 /* If we didn't find a lowpc, set it to highpc to avoid complaints
2790 from finish_block. */
2acceee2 2791 if (lowpc == ((CORE_ADDR) -1))
c906108c
SS
2792 lowpc = highpc;
2793 lowpc += baseaddr;
2794 highpc += baseaddr;
2795
e142c38c 2796 attr = dwarf2_attr (die, DW_AT_name, cu);
c906108c
SS
2797 if (attr)
2798 {
2799 name = DW_STRING (attr);
2800 }
e142c38c 2801 attr = dwarf2_attr (die, DW_AT_comp_dir, cu);
c906108c
SS
2802 if (attr)
2803 {
2804 comp_dir = DW_STRING (attr);
2805 if (comp_dir)
2806 {
2807 /* Irix 6.2 native cc prepends <machine>.: to the compilation
2808 directory, get rid of it. */
2809 char *cp = strchr (comp_dir, ':');
2810
2811 if (cp && cp != comp_dir && cp[-1] == '.' && cp[1] == '/')
2812 comp_dir = cp + 1;
2813 }
2814 }
2815
e142c38c 2816 attr = dwarf2_attr (die, DW_AT_language, cu);
c906108c
SS
2817 if (attr)
2818 {
e142c38c 2819 set_cu_language (DW_UNSND (attr), cu);
c906108c
SS
2820 }
2821
b0f35d58
DL
2822 attr = dwarf2_attr (die, DW_AT_producer, cu);
2823 if (attr)
2824 cu->producer = DW_STRING (attr);
303b6f5d 2825
c906108c
SS
2826 /* We assume that we're processing GCC output. */
2827 processing_gcc_compilation = 2;
c906108c
SS
2828
2829 /* The compilation unit may be in a different language or objfile,
2830 zero out all remembered fundamental types. */
e142c38c 2831 memset (cu->ftypes, 0, FT_NUM_MEMBERS * sizeof (struct type *));
c906108c
SS
2832
2833 start_symtab (name, comp_dir, lowpc);
2834 record_debugformat ("DWARF 2");
303b6f5d 2835 record_producer (cu->producer);
c906108c 2836
e142c38c 2837 initialize_cu_func_list (cu);
c906108c 2838
cb1df416
DJ
2839 /* Decode line number information if present. We do this before
2840 processing child DIEs, so that the line header table is available
2841 for DW_AT_decl_file. */
e142c38c 2842 attr = dwarf2_attr (die, DW_AT_stmt_list, cu);
5fb290d7
DJ
2843 if (attr)
2844 {
debd256d 2845 unsigned int line_offset = DW_UNSND (attr);
e7c27a73 2846 line_header = dwarf_decode_line_header (line_offset, abfd, cu);
debd256d
JB
2847 if (line_header)
2848 {
cb1df416
DJ
2849 cu->line_header = line_header;
2850 make_cleanup (free_cu_line_header, cu);
aaa75496 2851 dwarf_decode_lines (line_header, comp_dir, abfd, cu, NULL);
debd256d 2852 }
5fb290d7 2853 }
debd256d 2854
cb1df416
DJ
2855 /* Process all dies in compilation unit. */
2856 if (die->child != NULL)
2857 {
2858 child_die = die->child;
2859 while (child_die && child_die->tag)
2860 {
2861 process_die (child_die, cu);
2862 child_die = sibling_die (child_die);
2863 }
2864 }
2865
2e276125
JB
2866 /* Decode macro information, if present. Dwarf 2 macro information
2867 refers to information in the line number info statement program
2868 header, so we can only read it if we've read the header
2869 successfully. */
e142c38c 2870 attr = dwarf2_attr (die, DW_AT_macro_info, cu);
41ff2da1 2871 if (attr && line_header)
2e276125
JB
2872 {
2873 unsigned int macro_offset = DW_UNSND (attr);
2874 dwarf_decode_macros (line_header, macro_offset,
e7c27a73 2875 comp_dir, abfd, cu);
2e276125 2876 }
debd256d 2877 do_cleanups (back_to);
5fb290d7
DJ
2878}
2879
2880static void
e142c38c
DJ
2881add_to_cu_func_list (const char *name, CORE_ADDR lowpc, CORE_ADDR highpc,
2882 struct dwarf2_cu *cu)
5fb290d7
DJ
2883{
2884 struct function_range *thisfn;
2885
2886 thisfn = (struct function_range *)
7b5a2f43 2887 obstack_alloc (&cu->comp_unit_obstack, sizeof (struct function_range));
5fb290d7
DJ
2888 thisfn->name = name;
2889 thisfn->lowpc = lowpc;
2890 thisfn->highpc = highpc;
2891 thisfn->seen_line = 0;
2892 thisfn->next = NULL;
2893
e142c38c
DJ
2894 if (cu->last_fn == NULL)
2895 cu->first_fn = thisfn;
5fb290d7 2896 else
e142c38c 2897 cu->last_fn->next = thisfn;
5fb290d7 2898
e142c38c 2899 cu->last_fn = thisfn;
c906108c
SS
2900}
2901
2902static void
e7c27a73 2903read_func_scope (struct die_info *die, struct dwarf2_cu *cu)
c906108c 2904{
e7c27a73 2905 struct objfile *objfile = cu->objfile;
52f0bd74 2906 struct context_stack *new;
c906108c
SS
2907 CORE_ADDR lowpc;
2908 CORE_ADDR highpc;
2909 struct die_info *child_die;
2910 struct attribute *attr;
2911 char *name;
fdde2d81
DC
2912 const char *previous_prefix = processing_current_prefix;
2913 struct cleanup *back_to = NULL;
e142c38c 2914 CORE_ADDR baseaddr;
c906108c 2915
e142c38c
DJ
2916 baseaddr = ANOFFSET (objfile->section_offsets, SECT_OFF_TEXT (objfile));
2917
2918 name = dwarf2_linkage_name (die, cu);
c906108c
SS
2919
2920 /* Ignore functions with missing or empty names and functions with
2921 missing or invalid low and high pc attributes. */
e7c27a73 2922 if (name == NULL || !dwarf2_get_pc_bounds (die, &lowpc, &highpc, cu))
c906108c
SS
2923 return;
2924
987504bb
JJ
2925 if (cu->language == language_cplus
2926 || cu->language == language_java)
fdde2d81 2927 {
086ed43d 2928 struct die_info *spec_die = die_specification (die, cu);
fdde2d81 2929
2a35147e
JB
2930 /* NOTE: carlton/2004-01-23: We have to be careful in the
2931 presence of DW_AT_specification. For example, with GCC 3.4,
2932 given the code
2933
2934 namespace N {
2935 void foo() {
2936 // Definition of N::foo.
2937 }
2938 }
2939
2940 then we'll have a tree of DIEs like this:
2941
2942 1: DW_TAG_compile_unit
2943 2: DW_TAG_namespace // N
2944 3: DW_TAG_subprogram // declaration of N::foo
2945 4: DW_TAG_subprogram // definition of N::foo
2946 DW_AT_specification // refers to die #3
2947
2948 Thus, when processing die #4, we have to pretend that we're
2949 in the context of its DW_AT_specification, namely the contex
2950 of die #3. */
fdde2d81
DC
2951
2952 if (spec_die != NULL)
2953 {
e142c38c 2954 char *specification_prefix = determine_prefix (spec_die, cu);
fdde2d81
DC
2955 processing_current_prefix = specification_prefix;
2956 back_to = make_cleanup (xfree, specification_prefix);
2957 }
2958 }
2959
c906108c
SS
2960 lowpc += baseaddr;
2961 highpc += baseaddr;
2962
5fb290d7 2963 /* Record the function range for dwarf_decode_lines. */
e142c38c 2964 add_to_cu_func_list (name, lowpc, highpc, cu);
5fb290d7 2965
c906108c 2966 new = push_context (0, lowpc);
e7c27a73 2967 new->name = new_symbol (die, die->type, cu);
4c2df51b 2968
4cecd739
DJ
2969 /* If there is a location expression for DW_AT_frame_base, record
2970 it. */
e142c38c 2971 attr = dwarf2_attr (die, DW_AT_frame_base, cu);
4c2df51b 2972 if (attr)
c034e007
AC
2973 /* FIXME: cagney/2004-01-26: The DW_AT_frame_base's location
2974 expression is being recorded directly in the function's symbol
2975 and not in a separate frame-base object. I guess this hack is
2976 to avoid adding some sort of frame-base adjunct/annex to the
2977 function's symbol :-(. The problem with doing this is that it
2978 results in a function symbol with a location expression that
2979 has nothing to do with the location of the function, ouch! The
2980 relationship should be: a function's symbol has-a frame base; a
2981 frame-base has-a location expression. */
e7c27a73 2982 dwarf2_symbol_mark_computed (attr, new->name, cu);
4c2df51b 2983
e142c38c 2984 cu->list_in_scope = &local_symbols;
c906108c 2985
639d11d3 2986 if (die->child != NULL)
c906108c 2987 {
639d11d3 2988 child_die = die->child;
c906108c
SS
2989 while (child_die && child_die->tag)
2990 {
e7c27a73 2991 process_die (child_die, cu);
c906108c
SS
2992 child_die = sibling_die (child_die);
2993 }
2994 }
2995
2996 new = pop_context ();
2997 /* Make a block for the local symbols within. */
2998 finish_block (new->name, &local_symbols, new->old_blocks,
2999 lowpc, highpc, objfile);
208d8187
JB
3000
3001 /* In C++, we can have functions nested inside functions (e.g., when
3002 a function declares a class that has methods). This means that
3003 when we finish processing a function scope, we may need to go
3004 back to building a containing block's symbol lists. */
3005 local_symbols = new->locals;
3006 param_symbols = new->params;
3007
921e78cf
JB
3008 /* If we've finished processing a top-level function, subsequent
3009 symbols go in the file symbol list. */
3010 if (outermost_context_p ())
e142c38c 3011 cu->list_in_scope = &file_symbols;
fdde2d81
DC
3012
3013 processing_current_prefix = previous_prefix;
3014 if (back_to != NULL)
3015 do_cleanups (back_to);
c906108c
SS
3016}
3017
3018/* Process all the DIES contained within a lexical block scope. Start
3019 a new scope, process the dies, and then close the scope. */
3020
3021static void
e7c27a73 3022read_lexical_block_scope (struct die_info *die, struct dwarf2_cu *cu)
c906108c 3023{
e7c27a73 3024 struct objfile *objfile = cu->objfile;
52f0bd74 3025 struct context_stack *new;
c906108c
SS
3026 CORE_ADDR lowpc, highpc;
3027 struct die_info *child_die;
e142c38c
DJ
3028 CORE_ADDR baseaddr;
3029
3030 baseaddr = ANOFFSET (objfile->section_offsets, SECT_OFF_TEXT (objfile));
c906108c
SS
3031
3032 /* Ignore blocks with missing or invalid low and high pc attributes. */
af34e669
DJ
3033 /* ??? Perhaps consider discontiguous blocks defined by DW_AT_ranges
3034 as multiple lexical blocks? Handling children in a sane way would
3035 be nasty. Might be easier to properly extend generic blocks to
3036 describe ranges. */
e7c27a73 3037 if (!dwarf2_get_pc_bounds (die, &lowpc, &highpc, cu))
c906108c
SS
3038 return;
3039 lowpc += baseaddr;
3040 highpc += baseaddr;
3041
3042 push_context (0, lowpc);
639d11d3 3043 if (die->child != NULL)
c906108c 3044 {
639d11d3 3045 child_die = die->child;
c906108c
SS
3046 while (child_die && child_die->tag)
3047 {
e7c27a73 3048 process_die (child_die, cu);
c906108c
SS
3049 child_die = sibling_die (child_die);
3050 }
3051 }
3052 new = pop_context ();
3053
3054 if (local_symbols != NULL)
3055 {
3056 finish_block (0, &local_symbols, new->old_blocks, new->start_addr,
3057 highpc, objfile);
3058 }
3059 local_symbols = new->locals;
3060}
3061
af34e669
DJ
3062/* Get low and high pc attributes from a die. Return 1 if the attributes
3063 are present and valid, otherwise, return 0. Return -1 if the range is
3064 discontinuous, i.e. derived from DW_AT_ranges information. */
c906108c 3065static int
af34e669 3066dwarf2_get_pc_bounds (struct die_info *die, CORE_ADDR *lowpc,
e7c27a73 3067 CORE_ADDR *highpc, struct dwarf2_cu *cu)
c906108c 3068{
e7c27a73
DJ
3069 struct objfile *objfile = cu->objfile;
3070 struct comp_unit_head *cu_header = &cu->header;
c906108c 3071 struct attribute *attr;
af34e669
DJ
3072 bfd *obfd = objfile->obfd;
3073 CORE_ADDR low = 0;
3074 CORE_ADDR high = 0;
3075 int ret = 0;
c906108c 3076
e142c38c 3077 attr = dwarf2_attr (die, DW_AT_high_pc, cu);
c906108c 3078 if (attr)
af34e669
DJ
3079 {
3080 high = DW_ADDR (attr);
e142c38c 3081 attr = dwarf2_attr (die, DW_AT_low_pc, cu);
af34e669
DJ
3082 if (attr)
3083 low = DW_ADDR (attr);
3084 else
3085 /* Found high w/o low attribute. */
3086 return 0;
3087
3088 /* Found consecutive range of addresses. */
3089 ret = 1;
3090 }
c906108c 3091 else
af34e669 3092 {
e142c38c 3093 attr = dwarf2_attr (die, DW_AT_ranges, cu);
af34e669
DJ
3094 if (attr != NULL)
3095 {
3096 unsigned int addr_size = cu_header->addr_size;
3097 CORE_ADDR mask = ~(~(CORE_ADDR)1 << (addr_size * 8 - 1));
3098 /* Value of the DW_AT_ranges attribute is the offset in the
a604369a 3099 .debug_ranges section. */
af34e669
DJ
3100 unsigned int offset = DW_UNSND (attr);
3101 /* Base address selection entry. */
0d53c4c4
DJ
3102 CORE_ADDR base;
3103 int found_base;
891d2f0b 3104 unsigned int dummy;
fe1b8b76 3105 gdb_byte *buffer;
af34e669
DJ
3106 CORE_ADDR marker;
3107 int low_set;
3108
0d53c4c4
DJ
3109 found_base = cu_header->base_known;
3110 base = cu_header->base_address;
a604369a 3111
6502dd73 3112 if (offset >= dwarf2_per_objfile->ranges_size)
a604369a
KB
3113 {
3114 complaint (&symfile_complaints,
e2e0b3e5 3115 _("Offset %d out of bounds for DW_AT_ranges attribute"),
a604369a
KB
3116 offset);
3117 return 0;
3118 }
6502dd73 3119 buffer = dwarf2_per_objfile->ranges_buffer + offset;
af34e669 3120
af34e669 3121 /* Read in the largest possible address. */
e7c27a73 3122 marker = read_address (obfd, buffer, cu, &dummy);
af34e669
DJ
3123 if ((marker & mask) == mask)
3124 {
3125 /* If we found the largest possible address, then
3126 read the base address. */
e7c27a73 3127 base = read_address (obfd, buffer + addr_size, cu, &dummy);
af34e669
DJ
3128 buffer += 2 * addr_size;
3129 offset += 2 * addr_size;
3130 found_base = 1;
3131 }
3132
3133 low_set = 0;
3134
3135 while (1)
3136 {
3137 CORE_ADDR range_beginning, range_end;
3138
e7c27a73 3139 range_beginning = read_address (obfd, buffer, cu, &dummy);
af34e669 3140 buffer += addr_size;
e7c27a73 3141 range_end = read_address (obfd, buffer, cu, &dummy);
af34e669
DJ
3142 buffer += addr_size;
3143 offset += 2 * addr_size;
3144
3145 /* An end of list marker is a pair of zero addresses. */
3146 if (range_beginning == 0 && range_end == 0)
3147 /* Found the end of list entry. */
3148 break;
3149
3150 /* Each base address selection entry is a pair of 2 values.
3151 The first is the largest possible address, the second is
3152 the base address. Check for a base address here. */
3153 if ((range_beginning & mask) == mask)
3154 {
3155 /* If we found the largest possible address, then
3156 read the base address. */
e7c27a73 3157 base = read_address (obfd, buffer + addr_size, cu, &dummy);
af34e669
DJ
3158 found_base = 1;
3159 continue;
3160 }
3161
3162 if (!found_base)
3163 {
3164 /* We have no valid base address for the ranges
3165 data. */
3166 complaint (&symfile_complaints,
e2e0b3e5 3167 _("Invalid .debug_ranges data (no base address)"));
af34e669
DJ
3168 return 0;
3169 }
3170
8f05cde5
DJ
3171 range_beginning += base;
3172 range_end += base;
3173
af34e669
DJ
3174 /* FIXME: This is recording everything as a low-high
3175 segment of consecutive addresses. We should have a
3176 data structure for discontiguous block ranges
3177 instead. */
3178 if (! low_set)
3179 {
3180 low = range_beginning;
3181 high = range_end;
3182 low_set = 1;
3183 }
3184 else
3185 {
3186 if (range_beginning < low)
3187 low = range_beginning;
3188 if (range_end > high)
3189 high = range_end;
3190 }
3191 }
3192
3193 if (! low_set)
3194 /* If the first entry is an end-of-list marker, the range
3195 describes an empty scope, i.e. no instructions. */
3196 return 0;
3197
3198 ret = -1;
3199 }
3200 }
c906108c
SS
3201
3202 if (high < low)
3203 return 0;
3204
3205 /* When using the GNU linker, .gnu.linkonce. sections are used to
3206 eliminate duplicate copies of functions and vtables and such.
3207 The linker will arbitrarily choose one and discard the others.
3208 The AT_*_pc values for such functions refer to local labels in
3209 these sections. If the section from that file was discarded, the
3210 labels are not in the output, so the relocs get a value of 0.
3211 If this is a discarded function, mark the pc bounds as invalid,
3212 so that GDB will ignore it. */
72dca2f5 3213 if (low == 0 && !dwarf2_per_objfile->has_section_at_zero)
c906108c
SS
3214 return 0;
3215
3216 *lowpc = low;
3217 *highpc = high;
af34e669 3218 return ret;
c906108c
SS
3219}
3220
fae299cd
DC
3221/* Get the low and high pc's represented by the scope DIE, and store
3222 them in *LOWPC and *HIGHPC. If the correct values can't be
3223 determined, set *LOWPC to -1 and *HIGHPC to 0. */
3224
3225static void
3226get_scope_pc_bounds (struct die_info *die,
3227 CORE_ADDR *lowpc, CORE_ADDR *highpc,
3228 struct dwarf2_cu *cu)
3229{
3230 CORE_ADDR best_low = (CORE_ADDR) -1;
3231 CORE_ADDR best_high = (CORE_ADDR) 0;
3232 CORE_ADDR current_low, current_high;
3233
3234 if (dwarf2_get_pc_bounds (die, &current_low, &current_high, cu))
3235 {
3236 best_low = current_low;
3237 best_high = current_high;
3238 }
3239 else
3240 {
3241 struct die_info *child = die->child;
3242
3243 while (child && child->tag)
3244 {
3245 switch (child->tag) {
3246 case DW_TAG_subprogram:
3247 if (dwarf2_get_pc_bounds (child, &current_low, &current_high, cu))
3248 {
3249 best_low = min (best_low, current_low);
3250 best_high = max (best_high, current_high);
3251 }
3252 break;
3253 case DW_TAG_namespace:
3254 /* FIXME: carlton/2004-01-16: Should we do this for
3255 DW_TAG_class_type/DW_TAG_structure_type, too? I think
3256 that current GCC's always emit the DIEs corresponding
3257 to definitions of methods of classes as children of a
3258 DW_TAG_compile_unit or DW_TAG_namespace (as opposed to
3259 the DIEs giving the declarations, which could be
3260 anywhere). But I don't see any reason why the
3261 standards says that they have to be there. */
3262 get_scope_pc_bounds (child, &current_low, &current_high, cu);
3263
3264 if (current_low != ((CORE_ADDR) -1))
3265 {
3266 best_low = min (best_low, current_low);
3267 best_high = max (best_high, current_high);
3268 }
3269 break;
3270 default:
3271 /* Ignore. */
3272 break;
3273 }
3274
3275 child = sibling_die (child);
3276 }
3277 }
3278
3279 *lowpc = best_low;
3280 *highpc = best_high;
3281}
3282
c906108c
SS
3283/* Add an aggregate field to the field list. */
3284
3285static void
107d2387 3286dwarf2_add_field (struct field_info *fip, struct die_info *die,
e7c27a73
DJ
3287 struct dwarf2_cu *cu)
3288{
3289 struct objfile *objfile = cu->objfile;
c906108c
SS
3290 struct nextfield *new_field;
3291 struct attribute *attr;
3292 struct field *fp;
3293 char *fieldname = "";
3294
3295 /* Allocate a new field list entry and link it in. */
3296 new_field = (struct nextfield *) xmalloc (sizeof (struct nextfield));
b8c9b27d 3297 make_cleanup (xfree, new_field);
c906108c
SS
3298 memset (new_field, 0, sizeof (struct nextfield));
3299 new_field->next = fip->fields;
3300 fip->fields = new_field;
3301 fip->nfields++;
3302
3303 /* Handle accessibility and virtuality of field.
3304 The default accessibility for members is public, the default
3305 accessibility for inheritance is private. */
3306 if (die->tag != DW_TAG_inheritance)
3307 new_field->accessibility = DW_ACCESS_public;
3308 else
3309 new_field->accessibility = DW_ACCESS_private;
3310 new_field->virtuality = DW_VIRTUALITY_none;
3311
e142c38c 3312 attr = dwarf2_attr (die, DW_AT_accessibility, cu);
c906108c
SS
3313 if (attr)
3314 new_field->accessibility = DW_UNSND (attr);
3315 if (new_field->accessibility != DW_ACCESS_public)
3316 fip->non_public_fields = 1;
e142c38c 3317 attr = dwarf2_attr (die, DW_AT_virtuality, cu);
c906108c
SS
3318 if (attr)
3319 new_field->virtuality = DW_UNSND (attr);
3320
3321 fp = &new_field->field;
a9a9bd0f 3322
e142c38c 3323 if (die->tag == DW_TAG_member && ! die_is_declaration (die, cu))
c906108c 3324 {
a9a9bd0f
DC
3325 /* Data member other than a C++ static data member. */
3326
c906108c 3327 /* Get type of field. */
e7c27a73 3328 fp->type = die_type (die, cu);
c906108c 3329
01ad7f36
DJ
3330 FIELD_STATIC_KIND (*fp) = 0;
3331
c906108c 3332 /* Get bit size of field (zero if none). */
e142c38c 3333 attr = dwarf2_attr (die, DW_AT_bit_size, cu);
c906108c
SS
3334 if (attr)
3335 {
3336 FIELD_BITSIZE (*fp) = DW_UNSND (attr);
3337 }
3338 else
3339 {
3340 FIELD_BITSIZE (*fp) = 0;
3341 }
3342
3343 /* Get bit offset of field. */
e142c38c 3344 attr = dwarf2_attr (die, DW_AT_data_member_location, cu);
c906108c
SS
3345 if (attr)
3346 {
3347 FIELD_BITPOS (*fp) =
e7c27a73 3348 decode_locdesc (DW_BLOCK (attr), cu) * bits_per_byte;
c906108c
SS
3349 }
3350 else
3351 FIELD_BITPOS (*fp) = 0;
e142c38c 3352 attr = dwarf2_attr (die, DW_AT_bit_offset, cu);
c906108c
SS
3353 if (attr)
3354 {
3355 if (BITS_BIG_ENDIAN)
3356 {
3357 /* For big endian bits, the DW_AT_bit_offset gives the
c5aa993b
JM
3358 additional bit offset from the MSB of the containing
3359 anonymous object to the MSB of the field. We don't
3360 have to do anything special since we don't need to
3361 know the size of the anonymous object. */
c906108c
SS
3362 FIELD_BITPOS (*fp) += DW_UNSND (attr);
3363 }
3364 else
3365 {
3366 /* For little endian bits, compute the bit offset to the
c5aa993b
JM
3367 MSB of the anonymous object, subtract off the number of
3368 bits from the MSB of the field to the MSB of the
3369 object, and then subtract off the number of bits of
3370 the field itself. The result is the bit offset of
3371 the LSB of the field. */
c906108c
SS
3372 int anonymous_size;
3373 int bit_offset = DW_UNSND (attr);
3374
e142c38c 3375 attr = dwarf2_attr (die, DW_AT_byte_size, cu);
c906108c
SS
3376 if (attr)
3377 {
3378 /* The size of the anonymous object containing
3379 the bit field is explicit, so use the
3380 indicated size (in bytes). */
3381 anonymous_size = DW_UNSND (attr);
3382 }
3383 else
3384 {
3385 /* The size of the anonymous object containing
3386 the bit field must be inferred from the type
3387 attribute of the data member containing the
3388 bit field. */
3389 anonymous_size = TYPE_LENGTH (fp->type);
3390 }
3391 FIELD_BITPOS (*fp) += anonymous_size * bits_per_byte
3392 - bit_offset - FIELD_BITSIZE (*fp);
3393 }
3394 }
3395
3396 /* Get name of field. */
e142c38c 3397 attr = dwarf2_attr (die, DW_AT_name, cu);
c906108c
SS
3398 if (attr && DW_STRING (attr))
3399 fieldname = DW_STRING (attr);
d8151005
DJ
3400
3401 /* The name is already allocated along with this objfile, so we don't
3402 need to duplicate it for the type. */
3403 fp->name = fieldname;
c906108c
SS
3404
3405 /* Change accessibility for artificial fields (e.g. virtual table
c5aa993b 3406 pointer or virtual base class pointer) to private. */
e142c38c 3407 if (dwarf2_attr (die, DW_AT_artificial, cu))
c906108c
SS
3408 {
3409 new_field->accessibility = DW_ACCESS_private;
3410 fip->non_public_fields = 1;
3411 }
3412 }
a9a9bd0f 3413 else if (die->tag == DW_TAG_member || die->tag == DW_TAG_variable)
c906108c 3414 {
a9a9bd0f
DC
3415 /* C++ static member. */
3416
3417 /* NOTE: carlton/2002-11-05: It should be a DW_TAG_member that
3418 is a declaration, but all versions of G++ as of this writing
3419 (so through at least 3.2.1) incorrectly generate
3420 DW_TAG_variable tags. */
3421
c906108c 3422 char *physname;
c906108c 3423
a9a9bd0f 3424 /* Get name of field. */
e142c38c 3425 attr = dwarf2_attr (die, DW_AT_name, cu);
2df3850c
JM
3426 if (attr && DW_STRING (attr))
3427 fieldname = DW_STRING (attr);
3428 else
c906108c
SS
3429 return;
3430
2df3850c 3431 /* Get physical name. */
e142c38c 3432 physname = dwarf2_linkage_name (die, cu);
c906108c 3433
d8151005
DJ
3434 /* The name is already allocated along with this objfile, so we don't
3435 need to duplicate it for the type. */
3436 SET_FIELD_PHYSNAME (*fp, physname ? physname : "");
e7c27a73 3437 FIELD_TYPE (*fp) = die_type (die, cu);
d8151005 3438 FIELD_NAME (*fp) = fieldname;
c906108c
SS
3439 }
3440 else if (die->tag == DW_TAG_inheritance)
3441 {
3442 /* C++ base class field. */
e142c38c 3443 attr = dwarf2_attr (die, DW_AT_data_member_location, cu);
c906108c 3444 if (attr)
e7c27a73 3445 FIELD_BITPOS (*fp) = (decode_locdesc (DW_BLOCK (attr), cu)
107d2387 3446 * bits_per_byte);
c906108c 3447 FIELD_BITSIZE (*fp) = 0;
01ad7f36 3448 FIELD_STATIC_KIND (*fp) = 0;
e7c27a73 3449 FIELD_TYPE (*fp) = die_type (die, cu);
c906108c
SS
3450 FIELD_NAME (*fp) = type_name_no_tag (fp->type);
3451 fip->nbaseclasses++;
3452 }
3453}
3454
3455/* Create the vector of fields, and attach it to the type. */
3456
3457static void
fba45db2 3458dwarf2_attach_fields_to_type (struct field_info *fip, struct type *type,
e7c27a73 3459 struct dwarf2_cu *cu)
c906108c
SS
3460{
3461 int nfields = fip->nfields;
3462
3463 /* Record the field count, allocate space for the array of fields,
3464 and create blank accessibility bitfields if necessary. */
3465 TYPE_NFIELDS (type) = nfields;
3466 TYPE_FIELDS (type) = (struct field *)
3467 TYPE_ALLOC (type, sizeof (struct field) * nfields);
3468 memset (TYPE_FIELDS (type), 0, sizeof (struct field) * nfields);
3469
3470 if (fip->non_public_fields)
3471 {
3472 ALLOCATE_CPLUS_STRUCT_TYPE (type);
3473
3474 TYPE_FIELD_PRIVATE_BITS (type) =
3475 (B_TYPE *) TYPE_ALLOC (type, B_BYTES (nfields));
3476 B_CLRALL (TYPE_FIELD_PRIVATE_BITS (type), nfields);
3477
3478 TYPE_FIELD_PROTECTED_BITS (type) =
3479 (B_TYPE *) TYPE_ALLOC (type, B_BYTES (nfields));
3480 B_CLRALL (TYPE_FIELD_PROTECTED_BITS (type), nfields);
3481
3482 TYPE_FIELD_IGNORE_BITS (type) =
3483 (B_TYPE *) TYPE_ALLOC (type, B_BYTES (nfields));
3484 B_CLRALL (TYPE_FIELD_IGNORE_BITS (type), nfields);
3485 }
3486
3487 /* If the type has baseclasses, allocate and clear a bit vector for
3488 TYPE_FIELD_VIRTUAL_BITS. */
3489 if (fip->nbaseclasses)
3490 {
3491 int num_bytes = B_BYTES (fip->nbaseclasses);
fe1b8b76 3492 unsigned char *pointer;
c906108c
SS
3493
3494 ALLOCATE_CPLUS_STRUCT_TYPE (type);
fe1b8b76
JB
3495 pointer = TYPE_ALLOC (type, num_bytes);
3496 TYPE_FIELD_VIRTUAL_BITS (type) = pointer;
c906108c
SS
3497 B_CLRALL (TYPE_FIELD_VIRTUAL_BITS (type), fip->nbaseclasses);
3498 TYPE_N_BASECLASSES (type) = fip->nbaseclasses;
3499 }
3500
3501 /* Copy the saved-up fields into the field vector. Start from the head
3502 of the list, adding to the tail of the field array, so that they end
3503 up in the same order in the array in which they were added to the list. */
3504 while (nfields-- > 0)
3505 {
3506 TYPE_FIELD (type, nfields) = fip->fields->field;
3507 switch (fip->fields->accessibility)
3508 {
c5aa993b
JM
3509 case DW_ACCESS_private:
3510 SET_TYPE_FIELD_PRIVATE (type, nfields);
3511 break;
c906108c 3512
c5aa993b
JM
3513 case DW_ACCESS_protected:
3514 SET_TYPE_FIELD_PROTECTED (type, nfields);
3515 break;
c906108c 3516
c5aa993b
JM
3517 case DW_ACCESS_public:
3518 break;
c906108c 3519
c5aa993b
JM
3520 default:
3521 /* Unknown accessibility. Complain and treat it as public. */
3522 {
e2e0b3e5 3523 complaint (&symfile_complaints, _("unsupported accessibility %d"),
4d3c2250 3524 fip->fields->accessibility);
c5aa993b
JM
3525 }
3526 break;
c906108c
SS
3527 }
3528 if (nfields < fip->nbaseclasses)
3529 {
3530 switch (fip->fields->virtuality)
3531 {
c5aa993b
JM
3532 case DW_VIRTUALITY_virtual:
3533 case DW_VIRTUALITY_pure_virtual:
3534 SET_TYPE_FIELD_VIRTUAL (type, nfields);
3535 break;
c906108c
SS
3536 }
3537 }
3538 fip->fields = fip->fields->next;
3539 }
3540}
3541
c906108c
SS
3542/* Add a member function to the proper fieldlist. */
3543
3544static void
107d2387 3545dwarf2_add_member_fn (struct field_info *fip, struct die_info *die,
e7c27a73 3546 struct type *type, struct dwarf2_cu *cu)
c906108c 3547{
e7c27a73 3548 struct objfile *objfile = cu->objfile;
c906108c
SS
3549 struct attribute *attr;
3550 struct fnfieldlist *flp;
3551 int i;
3552 struct fn_field *fnp;
3553 char *fieldname;
3554 char *physname;
3555 struct nextfnfield *new_fnfield;
3556
2df3850c 3557 /* Get name of member function. */
e142c38c 3558 attr = dwarf2_attr (die, DW_AT_name, cu);
2df3850c
JM
3559 if (attr && DW_STRING (attr))
3560 fieldname = DW_STRING (attr);
c906108c 3561 else
2df3850c 3562 return;
c906108c 3563
2df3850c 3564 /* Get the mangled name. */
e142c38c 3565 physname = dwarf2_linkage_name (die, cu);
c906108c
SS
3566
3567 /* Look up member function name in fieldlist. */
3568 for (i = 0; i < fip->nfnfields; i++)
3569 {
27bfe10e 3570 if (strcmp (fip->fnfieldlists[i].name, fieldname) == 0)
c906108c
SS
3571 break;
3572 }
3573
3574 /* Create new list element if necessary. */
3575 if (i < fip->nfnfields)
3576 flp = &fip->fnfieldlists[i];
3577 else
3578 {
3579 if ((fip->nfnfields % DW_FIELD_ALLOC_CHUNK) == 0)
3580 {
3581 fip->fnfieldlists = (struct fnfieldlist *)
3582 xrealloc (fip->fnfieldlists,
3583 (fip->nfnfields + DW_FIELD_ALLOC_CHUNK)
c5aa993b 3584 * sizeof (struct fnfieldlist));
c906108c 3585 if (fip->nfnfields == 0)
c13c43fd 3586 make_cleanup (free_current_contents, &fip->fnfieldlists);
c906108c
SS
3587 }
3588 flp = &fip->fnfieldlists[fip->nfnfields];
3589 flp->name = fieldname;
3590 flp->length = 0;
3591 flp->head = NULL;
3592 fip->nfnfields++;
3593 }
3594
3595 /* Create a new member function field and chain it to the field list
3596 entry. */
3597 new_fnfield = (struct nextfnfield *) xmalloc (sizeof (struct nextfnfield));
b8c9b27d 3598 make_cleanup (xfree, new_fnfield);
c906108c
SS
3599 memset (new_fnfield, 0, sizeof (struct nextfnfield));
3600 new_fnfield->next = flp->head;
3601 flp->head = new_fnfield;
3602 flp->length++;
3603
3604 /* Fill in the member function field info. */
3605 fnp = &new_fnfield->fnfield;
d8151005
DJ
3606 /* The name is already allocated along with this objfile, so we don't
3607 need to duplicate it for the type. */
3608 fnp->physname = physname ? physname : "";
c906108c
SS
3609 fnp->type = alloc_type (objfile);
3610 if (die->type && TYPE_CODE (die->type) == TYPE_CODE_FUNC)
3611 {
c906108c 3612 int nparams = TYPE_NFIELDS (die->type);
c906108c 3613
e26fb1d7
DC
3614 /* TYPE is the domain of this method, and DIE->TYPE is the type
3615 of the method itself (TYPE_CODE_METHOD). */
3616 smash_to_method_type (fnp->type, type,
ad2f7632
DJ
3617 TYPE_TARGET_TYPE (die->type),
3618 TYPE_FIELDS (die->type),
3619 TYPE_NFIELDS (die->type),
3620 TYPE_VARARGS (die->type));
c906108c
SS
3621
3622 /* Handle static member functions.
c5aa993b
JM
3623 Dwarf2 has no clean way to discern C++ static and non-static
3624 member functions. G++ helps GDB by marking the first
3625 parameter for non-static member functions (which is the
3626 this pointer) as artificial. We obtain this information
3627 from read_subroutine_type via TYPE_FIELD_ARTIFICIAL. */
c906108c
SS
3628 if (nparams == 0 || TYPE_FIELD_ARTIFICIAL (die->type, 0) == 0)
3629 fnp->voffset = VOFFSET_STATIC;
3630 }
3631 else
e2e0b3e5 3632 complaint (&symfile_complaints, _("member function type missing for '%s'"),
4d3c2250 3633 physname);
c906108c
SS
3634
3635 /* Get fcontext from DW_AT_containing_type if present. */
e142c38c 3636 if (dwarf2_attr (die, DW_AT_containing_type, cu) != NULL)
e7c27a73 3637 fnp->fcontext = die_containing_type (die, cu);
c906108c
SS
3638
3639 /* dwarf2 doesn't have stubbed physical names, so the setting of is_const
3640 and is_volatile is irrelevant, as it is needed by gdb_mangle_name only. */
3641
3642 /* Get accessibility. */
e142c38c 3643 attr = dwarf2_attr (die, DW_AT_accessibility, cu);
c906108c
SS
3644 if (attr)
3645 {
3646 switch (DW_UNSND (attr))
3647 {
c5aa993b
JM
3648 case DW_ACCESS_private:
3649 fnp->is_private = 1;
3650 break;
3651 case DW_ACCESS_protected:
3652 fnp->is_protected = 1;
3653 break;
c906108c
SS
3654 }
3655 }
3656
b02dede2 3657 /* Check for artificial methods. */
e142c38c 3658 attr = dwarf2_attr (die, DW_AT_artificial, cu);
b02dede2
DJ
3659 if (attr && DW_UNSND (attr) != 0)
3660 fnp->is_artificial = 1;
3661
c906108c 3662 /* Get index in virtual function table if it is a virtual member function. */
e142c38c 3663 attr = dwarf2_attr (die, DW_AT_vtable_elem_location, cu);
c906108c 3664 if (attr)
8e19ed76
PS
3665 {
3666 /* Support the .debug_loc offsets */
3667 if (attr_form_is_block (attr))
3668 {
e7c27a73 3669 fnp->voffset = decode_locdesc (DW_BLOCK (attr), cu) + 2;
8e19ed76
PS
3670 }
3671 else if (attr->form == DW_FORM_data4 || attr->form == DW_FORM_data8)
3672 {
4d3c2250 3673 dwarf2_complex_location_expr_complaint ();
8e19ed76
PS
3674 }
3675 else
3676 {
4d3c2250
KB
3677 dwarf2_invalid_attrib_class_complaint ("DW_AT_vtable_elem_location",
3678 fieldname);
8e19ed76
PS
3679 }
3680 }
c906108c
SS
3681}
3682
3683/* Create the vector of member function fields, and attach it to the type. */
3684
3685static void
fba45db2 3686dwarf2_attach_fn_fields_to_type (struct field_info *fip, struct type *type,
e7c27a73 3687 struct dwarf2_cu *cu)
c906108c
SS
3688{
3689 struct fnfieldlist *flp;
3690 int total_length = 0;
3691 int i;
3692
3693 ALLOCATE_CPLUS_STRUCT_TYPE (type);
3694 TYPE_FN_FIELDLISTS (type) = (struct fn_fieldlist *)
3695 TYPE_ALLOC (type, sizeof (struct fn_fieldlist) * fip->nfnfields);
3696
3697 for (i = 0, flp = fip->fnfieldlists; i < fip->nfnfields; i++, flp++)
3698 {
3699 struct nextfnfield *nfp = flp->head;
3700 struct fn_fieldlist *fn_flp = &TYPE_FN_FIELDLIST (type, i);
3701 int k;
3702
3703 TYPE_FN_FIELDLIST_NAME (type, i) = flp->name;
3704 TYPE_FN_FIELDLIST_LENGTH (type, i) = flp->length;
3705 fn_flp->fn_fields = (struct fn_field *)
3706 TYPE_ALLOC (type, sizeof (struct fn_field) * flp->length);
3707 for (k = flp->length; (k--, nfp); nfp = nfp->next)
c5aa993b 3708 fn_flp->fn_fields[k] = nfp->fnfield;
c906108c
SS
3709
3710 total_length += flp->length;
3711 }
3712
3713 TYPE_NFN_FIELDS (type) = fip->nfnfields;
3714 TYPE_NFN_FIELDS_TOTAL (type) = total_length;
3715}
3716
1168df01
JB
3717/* Returns non-zero if NAME is the name of a vtable member in CU's
3718 language, zero otherwise. */
3719static int
3720is_vtable_name (const char *name, struct dwarf2_cu *cu)
3721{
3722 static const char vptr[] = "_vptr";
987504bb 3723 static const char vtable[] = "vtable";
1168df01 3724
987504bb
JJ
3725 /* Look for the C++ and Java forms of the vtable. */
3726 if ((cu->language == language_java
3727 && strncmp (name, vtable, sizeof (vtable) - 1) == 0)
3728 || (strncmp (name, vptr, sizeof (vptr) - 1) == 0
3729 && is_cplus_marker (name[sizeof (vptr) - 1])))
1168df01
JB
3730 return 1;
3731
3732 return 0;
3733}
3734
c0dd20ea
DJ
3735/* GCC outputs unnamed structures that are really pointers to member
3736 functions, with the ABI-specified layout. If DIE (from CU) describes
3737 such a structure, set its type, and return nonzero. Otherwise return
61049d3b
DJ
3738 zero.
3739
3740 GCC shouldn't do this; it should just output pointer to member DIEs.
3741 This is GCC PR debug/28767. */
c0dd20ea
DJ
3742
3743static int
3744quirk_gcc_member_function_pointer (struct die_info *die, struct dwarf2_cu *cu)
3745{
3746 struct objfile *objfile = cu->objfile;
3747 struct type *type;
3748 struct die_info *pfn_die, *delta_die;
3749 struct attribute *pfn_name, *delta_name;
3750 struct type *pfn_type, *domain_type;
3751
3752 /* Check for a structure with no name and two children. */
3753 if (die->tag != DW_TAG_structure_type
3754 || dwarf2_attr (die, DW_AT_name, cu) != NULL
3755 || die->child == NULL
3756 || die->child->sibling == NULL
3757 || (die->child->sibling->sibling != NULL
3758 && die->child->sibling->sibling->tag != DW_TAG_padding))
3759 return 0;
3760
3761 /* Check for __pfn and __delta members. */
3762 pfn_die = die->child;
3763 pfn_name = dwarf2_attr (pfn_die, DW_AT_name, cu);
3764 if (pfn_die->tag != DW_TAG_member
3765 || pfn_name == NULL
3766 || DW_STRING (pfn_name) == NULL
3767 || strcmp ("__pfn", DW_STRING (pfn_name)) != 0)
3768 return 0;
3769
3770 delta_die = pfn_die->sibling;
3771 delta_name = dwarf2_attr (delta_die, DW_AT_name, cu);
3772 if (delta_die->tag != DW_TAG_member
3773 || delta_name == NULL
3774 || DW_STRING (delta_name) == NULL
3775 || strcmp ("__delta", DW_STRING (delta_name)) != 0)
3776 return 0;
3777
3778 /* Find the type of the method. */
3779 pfn_type = die_type (pfn_die, cu);
3780 if (pfn_type == NULL
3781 || TYPE_CODE (pfn_type) != TYPE_CODE_PTR
3782 || TYPE_CODE (TYPE_TARGET_TYPE (pfn_type)) != TYPE_CODE_FUNC)
3783 return 0;
3784
3785 /* Look for the "this" argument. */
3786 pfn_type = TYPE_TARGET_TYPE (pfn_type);
3787 if (TYPE_NFIELDS (pfn_type) == 0
3788 || TYPE_CODE (TYPE_FIELD_TYPE (pfn_type, 0)) != TYPE_CODE_PTR)
3789 return 0;
3790
3791 domain_type = TYPE_TARGET_TYPE (TYPE_FIELD_TYPE (pfn_type, 0));
3792 type = alloc_type (objfile);
3793 smash_to_method_type (type, domain_type, TYPE_TARGET_TYPE (pfn_type),
3794 TYPE_FIELDS (pfn_type), TYPE_NFIELDS (pfn_type),
3795 TYPE_VARARGS (pfn_type));
0d5de010 3796 type = lookup_methodptr_type (type);
c0dd20ea
DJ
3797 set_die_type (die, type, cu);
3798
3799 return 1;
3800}
1168df01 3801
c906108c
SS
3802/* Called when we find the DIE that starts a structure or union scope
3803 (definition) to process all dies that define the members of the
3804 structure or union.
3805
3806 NOTE: we need to call struct_type regardless of whether or not the
3807 DIE has an at_name attribute, since it might be an anonymous
3808 structure or union. This gets the type entered into our set of
3809 user defined types.
3810
3811 However, if the structure is incomplete (an opaque struct/union)
3812 then suppress creating a symbol table entry for it since gdb only
3813 wants to find the one with the complete definition. Note that if
3814 it is complete, we just call new_symbol, which does it's own
3815 checking about whether the struct/union is anonymous or not (and
3816 suppresses creating a symbol table entry itself). */
3817
3818static void
134d01f1 3819read_structure_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c 3820{
e7c27a73 3821 struct objfile *objfile = cu->objfile;
c906108c
SS
3822 struct type *type;
3823 struct attribute *attr;
63d06c5c
DC
3824 const char *previous_prefix = processing_current_prefix;
3825 struct cleanup *back_to = NULL;
c906108c 3826
134d01f1
DJ
3827 if (die->type)
3828 return;
3829
c0dd20ea
DJ
3830 if (quirk_gcc_member_function_pointer (die, cu))
3831 return;
c906108c 3832
c0dd20ea 3833 type = alloc_type (objfile);
c906108c 3834 INIT_CPLUS_SPECIFIC (type);
e142c38c 3835 attr = dwarf2_attr (die, DW_AT_name, cu);
c906108c
SS
3836 if (attr && DW_STRING (attr))
3837 {
987504bb
JJ
3838 if (cu->language == language_cplus
3839 || cu->language == language_java)
63d06c5c 3840 {
8176b9b8
DC
3841 char *new_prefix = determine_class_name (die, cu);
3842 TYPE_TAG_NAME (type) = obsavestring (new_prefix,
3843 strlen (new_prefix),
3844 &objfile->objfile_obstack);
3845 back_to = make_cleanup (xfree, new_prefix);
63d06c5c
DC
3846 processing_current_prefix = new_prefix;
3847 }
3848 else
3849 {
d8151005
DJ
3850 /* The name is already allocated along with this objfile, so
3851 we don't need to duplicate it for the type. */
8176b9b8 3852 TYPE_TAG_NAME (type) = DW_STRING (attr);
63d06c5c 3853 }
c906108c
SS
3854 }
3855
3856 if (die->tag == DW_TAG_structure_type)
3857 {
3858 TYPE_CODE (type) = TYPE_CODE_STRUCT;
3859 }
3860 else if (die->tag == DW_TAG_union_type)
3861 {
3862 TYPE_CODE (type) = TYPE_CODE_UNION;
3863 }
3864 else
3865 {
3866 /* FIXME: TYPE_CODE_CLASS is currently defined to TYPE_CODE_STRUCT
c5aa993b 3867 in gdbtypes.h. */
c906108c
SS
3868 TYPE_CODE (type) = TYPE_CODE_CLASS;
3869 }
3870
e142c38c 3871 attr = dwarf2_attr (die, DW_AT_byte_size, cu);
c906108c
SS
3872 if (attr)
3873 {
3874 TYPE_LENGTH (type) = DW_UNSND (attr);
3875 }
3876 else
3877 {
3878 TYPE_LENGTH (type) = 0;
3879 }
3880
dc718098
JB
3881 if (die_is_declaration (die, cu))
3882 TYPE_FLAGS (type) |= TYPE_FLAG_STUB;
3883
c906108c
SS
3884 /* We need to add the type field to the die immediately so we don't
3885 infinitely recurse when dealing with pointers to the structure
3886 type within the structure itself. */
1c379e20 3887 set_die_type (die, type, cu);
c906108c 3888
e142c38c 3889 if (die->child != NULL && ! die_is_declaration (die, cu))
c906108c
SS
3890 {
3891 struct field_info fi;
3892 struct die_info *child_die;
3893 struct cleanup *back_to = make_cleanup (null_cleanup, NULL);
3894
3895 memset (&fi, 0, sizeof (struct field_info));
3896
639d11d3 3897 child_die = die->child;
c906108c
SS
3898
3899 while (child_die && child_die->tag)
3900 {
a9a9bd0f
DC
3901 if (child_die->tag == DW_TAG_member
3902 || child_die->tag == DW_TAG_variable)
c906108c 3903 {
a9a9bd0f
DC
3904 /* NOTE: carlton/2002-11-05: A C++ static data member
3905 should be a DW_TAG_member that is a declaration, but
3906 all versions of G++ as of this writing (so through at
3907 least 3.2.1) incorrectly generate DW_TAG_variable
3908 tags for them instead. */
e7c27a73 3909 dwarf2_add_field (&fi, child_die, cu);
c906108c 3910 }
8713b1b1 3911 else if (child_die->tag == DW_TAG_subprogram)
c906108c
SS
3912 {
3913 /* C++ member function. */
134d01f1 3914 read_type_die (child_die, cu);
e7c27a73 3915 dwarf2_add_member_fn (&fi, child_die, type, cu);
c906108c
SS
3916 }
3917 else if (child_die->tag == DW_TAG_inheritance)
3918 {
3919 /* C++ base class field. */
e7c27a73 3920 dwarf2_add_field (&fi, child_die, cu);
c906108c 3921 }
c906108c
SS
3922 child_die = sibling_die (child_die);
3923 }
3924
3925 /* Attach fields and member functions to the type. */
3926 if (fi.nfields)
e7c27a73 3927 dwarf2_attach_fields_to_type (&fi, type, cu);
c906108c
SS
3928 if (fi.nfnfields)
3929 {
e7c27a73 3930 dwarf2_attach_fn_fields_to_type (&fi, type, cu);
c906108c 3931
c5aa993b 3932 /* Get the type which refers to the base class (possibly this
c906108c
SS
3933 class itself) which contains the vtable pointer for the current
3934 class from the DW_AT_containing_type attribute. */
3935
e142c38c 3936 if (dwarf2_attr (die, DW_AT_containing_type, cu) != NULL)
c906108c 3937 {
e7c27a73 3938 struct type *t = die_containing_type (die, cu);
c906108c
SS
3939
3940 TYPE_VPTR_BASETYPE (type) = t;
3941 if (type == t)
3942 {
c906108c
SS
3943 int i;
3944
3945 /* Our own class provides vtbl ptr. */
3946 for (i = TYPE_NFIELDS (t) - 1;
3947 i >= TYPE_N_BASECLASSES (t);
3948 --i)
3949 {
3950 char *fieldname = TYPE_FIELD_NAME (t, i);
3951
1168df01 3952 if (is_vtable_name (fieldname, cu))
c906108c
SS
3953 {
3954 TYPE_VPTR_FIELDNO (type) = i;
3955 break;
3956 }
3957 }
3958
3959 /* Complain if virtual function table field not found. */
3960 if (i < TYPE_N_BASECLASSES (t))
4d3c2250 3961 complaint (&symfile_complaints,
e2e0b3e5 3962 _("virtual function table pointer not found when defining class '%s'"),
4d3c2250
KB
3963 TYPE_TAG_NAME (type) ? TYPE_TAG_NAME (type) :
3964 "");
c906108c
SS
3965 }
3966 else
3967 {
3968 TYPE_VPTR_FIELDNO (type) = TYPE_VPTR_FIELDNO (t);
3969 }
3970 }
f6235d4c
EZ
3971 else if (cu->producer
3972 && strncmp (cu->producer,
3973 "IBM(R) XL C/C++ Advanced Edition", 32) == 0)
3974 {
3975 /* The IBM XLC compiler does not provide direct indication
3976 of the containing type, but the vtable pointer is
3977 always named __vfp. */
3978
3979 int i;
3980
3981 for (i = TYPE_NFIELDS (type) - 1;
3982 i >= TYPE_N_BASECLASSES (type);
3983 --i)
3984 {
3985 if (strcmp (TYPE_FIELD_NAME (type, i), "__vfp") == 0)
3986 {
3987 TYPE_VPTR_FIELDNO (type) = i;
3988 TYPE_VPTR_BASETYPE (type) = type;
3989 break;
3990 }
3991 }
3992 }
c906108c
SS
3993 }
3994
c906108c
SS
3995 do_cleanups (back_to);
3996 }
63d06c5c
DC
3997
3998 processing_current_prefix = previous_prefix;
3999 if (back_to != NULL)
4000 do_cleanups (back_to);
c906108c
SS
4001}
4002
134d01f1
DJ
4003static void
4004process_structure_scope (struct die_info *die, struct dwarf2_cu *cu)
4005{
4006 struct objfile *objfile = cu->objfile;
4007 const char *previous_prefix = processing_current_prefix;
90aeadfc 4008 struct die_info *child_die = die->child;
c906108c 4009
134d01f1
DJ
4010 if (TYPE_TAG_NAME (die->type) != NULL)
4011 processing_current_prefix = TYPE_TAG_NAME (die->type);
c906108c 4012
90aeadfc
DC
4013 /* NOTE: carlton/2004-03-16: GCC 3.4 (or at least one of its
4014 snapshots) has been known to create a die giving a declaration
4015 for a class that has, as a child, a die giving a definition for a
4016 nested class. So we have to process our children even if the
4017 current die is a declaration. Normally, of course, a declaration
4018 won't have any children at all. */
134d01f1 4019
90aeadfc
DC
4020 while (child_die != NULL && child_die->tag)
4021 {
4022 if (child_die->tag == DW_TAG_member
4023 || child_die->tag == DW_TAG_variable
4024 || child_die->tag == DW_TAG_inheritance)
134d01f1 4025 {
90aeadfc 4026 /* Do nothing. */
134d01f1 4027 }
90aeadfc
DC
4028 else
4029 process_die (child_die, cu);
134d01f1 4030
90aeadfc 4031 child_die = sibling_die (child_die);
134d01f1
DJ
4032 }
4033
fa4028e9
JB
4034 /* Do not consider external references. According to the DWARF standard,
4035 these DIEs are identified by the fact that they have no byte_size
4036 attribute, and a declaration attribute. */
4037 if (dwarf2_attr (die, DW_AT_byte_size, cu) != NULL
4038 || !die_is_declaration (die, cu))
90aeadfc
DC
4039 new_symbol (die, die->type, cu);
4040
134d01f1
DJ
4041 processing_current_prefix = previous_prefix;
4042}
4043
4044/* Given a DW_AT_enumeration_type die, set its type. We do not
4045 complete the type's fields yet, or create any symbols. */
c906108c
SS
4046
4047static void
134d01f1 4048read_enumeration_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c 4049{
e7c27a73 4050 struct objfile *objfile = cu->objfile;
c906108c 4051 struct type *type;
c906108c 4052 struct attribute *attr;
134d01f1
DJ
4053
4054 if (die->type)
4055 return;
c906108c
SS
4056
4057 type = alloc_type (objfile);
4058
4059 TYPE_CODE (type) = TYPE_CODE_ENUM;
e142c38c 4060 attr = dwarf2_attr (die, DW_AT_name, cu);
c906108c
SS
4061 if (attr && DW_STRING (attr))
4062 {
d8151005 4063 char *name = DW_STRING (attr);
63d06c5c
DC
4064
4065 if (processing_has_namespace_info)
4066 {
987504bb
JJ
4067 TYPE_TAG_NAME (type) = typename_concat (&objfile->objfile_obstack,
4068 processing_current_prefix,
4069 name, cu);
63d06c5c
DC
4070 }
4071 else
4072 {
d8151005
DJ
4073 /* The name is already allocated along with this objfile, so
4074 we don't need to duplicate it for the type. */
4075 TYPE_TAG_NAME (type) = name;
63d06c5c 4076 }
c906108c
SS
4077 }
4078
e142c38c 4079 attr = dwarf2_attr (die, DW_AT_byte_size, cu);
c906108c
SS
4080 if (attr)
4081 {
4082 TYPE_LENGTH (type) = DW_UNSND (attr);
4083 }
4084 else
4085 {
4086 TYPE_LENGTH (type) = 0;
4087 }
4088
1c379e20 4089 set_die_type (die, type, cu);
134d01f1
DJ
4090}
4091
8176b9b8 4092/* Determine the name of the type represented by DIE, which should be
987504bb 4093 a named C++ or Java compound type. Return the name in question; the caller
8176b9b8
DC
4094 is responsible for xfree()'ing it. */
4095
4096static char *
4097determine_class_name (struct die_info *die, struct dwarf2_cu *cu)
4098{
4099 struct cleanup *back_to = NULL;
4100 struct die_info *spec_die = die_specification (die, cu);
4101 char *new_prefix = NULL;
4102
4103 /* If this is the definition of a class that is declared by another
4104 die, then processing_current_prefix may not be accurate; see
4105 read_func_scope for a similar example. */
4106 if (spec_die != NULL)
4107 {
4108 char *specification_prefix = determine_prefix (spec_die, cu);
4109 processing_current_prefix = specification_prefix;
4110 back_to = make_cleanup (xfree, specification_prefix);
4111 }
4112
4113 /* If we don't have namespace debug info, guess the name by trying
4114 to demangle the names of members, just like we did in
72bf9492 4115 guess_structure_name. */
8176b9b8
DC
4116 if (!processing_has_namespace_info)
4117 {
4118 struct die_info *child;
4119
4120 for (child = die->child;
4121 child != NULL && child->tag != 0;
4122 child = sibling_die (child))
4123 {
4124 if (child->tag == DW_TAG_subprogram)
4125 {
31c27f77
JJ
4126 new_prefix
4127 = language_class_name_from_physname (cu->language_defn,
4128 dwarf2_linkage_name
8176b9b8
DC
4129 (child, cu));
4130
4131 if (new_prefix != NULL)
4132 break;
4133 }
4134 }
4135 }
4136
4137 if (new_prefix == NULL)
4138 {
4139 const char *name = dwarf2_name (die, cu);
987504bb
JJ
4140 new_prefix = typename_concat (NULL, processing_current_prefix,
4141 name ? name : "<<anonymous>>",
4142 cu);
8176b9b8
DC
4143 }
4144
4145 if (back_to != NULL)
4146 do_cleanups (back_to);
4147
4148 return new_prefix;
4149}
4150
134d01f1
DJ
4151/* Given a pointer to a die which begins an enumeration, process all
4152 the dies that define the members of the enumeration, and create the
4153 symbol for the enumeration type.
4154
4155 NOTE: We reverse the order of the element list. */
4156
4157static void
4158process_enumeration_scope (struct die_info *die, struct dwarf2_cu *cu)
4159{
4160 struct objfile *objfile = cu->objfile;
4161 struct die_info *child_die;
4162 struct field *fields;
4163 struct attribute *attr;
4164 struct symbol *sym;
4165 int num_fields;
4166 int unsigned_enum = 1;
4167
c906108c
SS
4168 num_fields = 0;
4169 fields = NULL;
639d11d3 4170 if (die->child != NULL)
c906108c 4171 {
639d11d3 4172 child_die = die->child;
c906108c
SS
4173 while (child_die && child_die->tag)
4174 {
4175 if (child_die->tag != DW_TAG_enumerator)
4176 {
e7c27a73 4177 process_die (child_die, cu);
c906108c
SS
4178 }
4179 else
4180 {
e142c38c 4181 attr = dwarf2_attr (child_die, DW_AT_name, cu);
c906108c
SS
4182 if (attr)
4183 {
134d01f1 4184 sym = new_symbol (child_die, die->type, cu);
c906108c
SS
4185 if (SYMBOL_VALUE (sym) < 0)
4186 unsigned_enum = 0;
4187
4188 if ((num_fields % DW_FIELD_ALLOC_CHUNK) == 0)
4189 {
4190 fields = (struct field *)
4191 xrealloc (fields,
4192 (num_fields + DW_FIELD_ALLOC_CHUNK)
c5aa993b 4193 * sizeof (struct field));
c906108c
SS
4194 }
4195
22abf04a 4196 FIELD_NAME (fields[num_fields]) = DEPRECATED_SYMBOL_NAME (sym);
c906108c
SS
4197 FIELD_TYPE (fields[num_fields]) = NULL;
4198 FIELD_BITPOS (fields[num_fields]) = SYMBOL_VALUE (sym);
4199 FIELD_BITSIZE (fields[num_fields]) = 0;
01ad7f36 4200 FIELD_STATIC_KIND (fields[num_fields]) = 0;
c906108c
SS
4201
4202 num_fields++;
4203 }
4204 }
4205
4206 child_die = sibling_die (child_die);
4207 }
4208
4209 if (num_fields)
4210 {
134d01f1
DJ
4211 TYPE_NFIELDS (die->type) = num_fields;
4212 TYPE_FIELDS (die->type) = (struct field *)
4213 TYPE_ALLOC (die->type, sizeof (struct field) * num_fields);
4214 memcpy (TYPE_FIELDS (die->type), fields,
c906108c 4215 sizeof (struct field) * num_fields);
b8c9b27d 4216 xfree (fields);
c906108c
SS
4217 }
4218 if (unsigned_enum)
134d01f1 4219 TYPE_FLAGS (die->type) |= TYPE_FLAG_UNSIGNED;
c906108c 4220 }
134d01f1
DJ
4221
4222 new_symbol (die, die->type, cu);
c906108c
SS
4223}
4224
4225/* Extract all information from a DW_TAG_array_type DIE and put it in
4226 the DIE's type field. For now, this only handles one dimensional
4227 arrays. */
4228
4229static void
e7c27a73 4230read_array_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c 4231{
e7c27a73 4232 struct objfile *objfile = cu->objfile;
c906108c
SS
4233 struct die_info *child_die;
4234 struct type *type = NULL;
4235 struct type *element_type, *range_type, *index_type;
4236 struct type **range_types = NULL;
4237 struct attribute *attr;
4238 int ndim = 0;
4239 struct cleanup *back_to;
4240
4241 /* Return if we've already decoded this type. */
4242 if (die->type)
4243 {
4244 return;
4245 }
4246
e7c27a73 4247 element_type = die_type (die, cu);
c906108c
SS
4248
4249 /* Irix 6.2 native cc creates array types without children for
4250 arrays with unspecified length. */
639d11d3 4251 if (die->child == NULL)
c906108c 4252 {
e142c38c 4253 index_type = dwarf2_fundamental_type (objfile, FT_INTEGER, cu);
c906108c 4254 range_type = create_range_type (NULL, index_type, 0, -1);
1c379e20
DJ
4255 set_die_type (die, create_array_type (NULL, element_type, range_type),
4256 cu);
c906108c
SS
4257 return;
4258 }
4259
4260 back_to = make_cleanup (null_cleanup, NULL);
639d11d3 4261 child_die = die->child;
c906108c
SS
4262 while (child_die && child_die->tag)
4263 {
4264 if (child_die->tag == DW_TAG_subrange_type)
4265 {
a02abb62 4266 read_subrange_type (child_die, cu);
c906108c 4267
a02abb62
JB
4268 if (child_die->type != NULL)
4269 {
4270 /* The range type was succesfully read. Save it for
4271 the array type creation. */
4272 if ((ndim % DW_FIELD_ALLOC_CHUNK) == 0)
4273 {
4274 range_types = (struct type **)
4275 xrealloc (range_types, (ndim + DW_FIELD_ALLOC_CHUNK)
4276 * sizeof (struct type *));
4277 if (ndim == 0)
4278 make_cleanup (free_current_contents, &range_types);
4279 }
4280 range_types[ndim++] = child_die->type;
4281 }
c906108c
SS
4282 }
4283 child_die = sibling_die (child_die);
4284 }
4285
4286 /* Dwarf2 dimensions are output from left to right, create the
4287 necessary array types in backwards order. */
7ca2d3a3 4288
c906108c 4289 type = element_type;
7ca2d3a3
DL
4290
4291 if (read_array_order (die, cu) == DW_ORD_col_major)
4292 {
4293 int i = 0;
4294 while (i < ndim)
4295 type = create_array_type (NULL, type, range_types[i++]);
4296 }
4297 else
4298 {
4299 while (ndim-- > 0)
4300 type = create_array_type (NULL, type, range_types[ndim]);
4301 }
c906108c 4302
f5f8a009
EZ
4303 /* Understand Dwarf2 support for vector types (like they occur on
4304 the PowerPC w/ AltiVec). Gcc just adds another attribute to the
4305 array type. This is not part of the Dwarf2/3 standard yet, but a
4306 custom vendor extension. The main difference between a regular
4307 array and the vector variant is that vectors are passed by value
4308 to functions. */
e142c38c 4309 attr = dwarf2_attr (die, DW_AT_GNU_vector, cu);
f5f8a009
EZ
4310 if (attr)
4311 TYPE_FLAGS (type) |= TYPE_FLAG_VECTOR;
4312
714e295e
JB
4313 attr = dwarf2_attr (die, DW_AT_name, cu);
4314 if (attr && DW_STRING (attr))
4315 TYPE_NAME (type) = DW_STRING (attr);
4316
c906108c
SS
4317 do_cleanups (back_to);
4318
4319 /* Install the type in the die. */
1c379e20 4320 set_die_type (die, type, cu);
c906108c
SS
4321}
4322
7ca2d3a3
DL
4323static enum dwarf_array_dim_ordering
4324read_array_order (struct die_info *die, struct dwarf2_cu *cu)
4325{
4326 struct attribute *attr;
4327
4328 attr = dwarf2_attr (die, DW_AT_ordering, cu);
4329
4330 if (attr) return DW_SND (attr);
4331
4332 /*
4333 GNU F77 is a special case, as at 08/2004 array type info is the
4334 opposite order to the dwarf2 specification, but data is still
4335 laid out as per normal fortran.
4336
4337 FIXME: dsl/2004-8-20: If G77 is ever fixed, this will also need
4338 version checking.
4339 */
4340
4341 if (cu->language == language_fortran &&
4342 cu->producer && strstr (cu->producer, "GNU F77"))
4343 {
4344 return DW_ORD_row_major;
4345 }
4346
4347 switch (cu->language_defn->la_array_ordering)
4348 {
4349 case array_column_major:
4350 return DW_ORD_col_major;
4351 case array_row_major:
4352 default:
4353 return DW_ORD_row_major;
4354 };
4355}
4356
72019c9c
GM
4357/* Extract all information from a DW_TAG_set_type DIE and put it in
4358 the DIE's type field. */
4359
4360static void
4361read_set_type (struct die_info *die, struct dwarf2_cu *cu)
4362{
4363 if (die->type == NULL)
4364 die->type = create_set_type ((struct type *) NULL, die_type (die, cu));
4365}
7ca2d3a3 4366
c906108c
SS
4367/* First cut: install each common block member as a global variable. */
4368
4369static void
e7c27a73 4370read_common_block (struct die_info *die, struct dwarf2_cu *cu)
c906108c
SS
4371{
4372 struct die_info *child_die;
4373 struct attribute *attr;
4374 struct symbol *sym;
4375 CORE_ADDR base = (CORE_ADDR) 0;
4376
e142c38c 4377 attr = dwarf2_attr (die, DW_AT_location, cu);
c906108c
SS
4378 if (attr)
4379 {
8e19ed76
PS
4380 /* Support the .debug_loc offsets */
4381 if (attr_form_is_block (attr))
4382 {
e7c27a73 4383 base = decode_locdesc (DW_BLOCK (attr), cu);
8e19ed76
PS
4384 }
4385 else if (attr->form == DW_FORM_data4 || attr->form == DW_FORM_data8)
4386 {
4d3c2250 4387 dwarf2_complex_location_expr_complaint ();
8e19ed76
PS
4388 }
4389 else
4390 {
4d3c2250
KB
4391 dwarf2_invalid_attrib_class_complaint ("DW_AT_location",
4392 "common block member");
8e19ed76 4393 }
c906108c 4394 }
639d11d3 4395 if (die->child != NULL)
c906108c 4396 {
639d11d3 4397 child_die = die->child;
c906108c
SS
4398 while (child_die && child_die->tag)
4399 {
e7c27a73 4400 sym = new_symbol (child_die, NULL, cu);
e142c38c 4401 attr = dwarf2_attr (child_die, DW_AT_data_member_location, cu);
c906108c
SS
4402 if (attr)
4403 {
4404 SYMBOL_VALUE_ADDRESS (sym) =
e7c27a73 4405 base + decode_locdesc (DW_BLOCK (attr), cu);
c906108c
SS
4406 add_symbol_to_list (sym, &global_symbols);
4407 }
4408 child_die = sibling_die (child_die);
4409 }
4410 }
4411}
4412
d9fa45fe
DC
4413/* Read a C++ namespace. */
4414
d9fa45fe 4415static void
e7c27a73 4416read_namespace (struct die_info *die, struct dwarf2_cu *cu)
d9fa45fe 4417{
e7c27a73 4418 struct objfile *objfile = cu->objfile;
38d518c9 4419 const char *previous_prefix = processing_current_prefix;
63d06c5c 4420 const char *name;
9219021c
DC
4421 int is_anonymous;
4422 struct die_info *current_die;
987504bb 4423 struct cleanup *back_to = make_cleanup (null_cleanup, 0);
9219021c 4424
e142c38c 4425 name = namespace_name (die, &is_anonymous, cu);
9219021c
DC
4426
4427 /* Now build the name of the current namespace. */
4428
38d518c9 4429 if (previous_prefix[0] == '\0')
9219021c 4430 {
38d518c9 4431 processing_current_prefix = name;
9219021c
DC
4432 }
4433 else
4434 {
987504bb
JJ
4435 char *temp_name = typename_concat (NULL, previous_prefix, name, cu);
4436 make_cleanup (xfree, temp_name);
38d518c9 4437 processing_current_prefix = temp_name;
9219021c
DC
4438 }
4439
5c4e30ca
DC
4440 /* Add a symbol associated to this if we haven't seen the namespace
4441 before. Also, add a using directive if it's an anonymous
4442 namespace. */
9219021c 4443
e142c38c 4444 if (dwarf2_extension (die, cu) == NULL)
5c4e30ca
DC
4445 {
4446 struct type *type;
4447
4448 /* FIXME: carlton/2003-06-27: Once GDB is more const-correct,
4449 this cast will hopefully become unnecessary. */
4450 type = init_type (TYPE_CODE_NAMESPACE, 0, 0,
38d518c9 4451 (char *) processing_current_prefix,
5c4e30ca
DC
4452 objfile);
4453 TYPE_TAG_NAME (type) = TYPE_NAME (type);
4454
e7c27a73 4455 new_symbol (die, type, cu);
1c379e20 4456 set_die_type (die, type, cu);
5c4e30ca
DC
4457
4458 if (is_anonymous)
38d518c9
EZ
4459 cp_add_using_directive (processing_current_prefix,
4460 strlen (previous_prefix),
4461 strlen (processing_current_prefix));
5c4e30ca 4462 }
9219021c 4463
639d11d3 4464 if (die->child != NULL)
d9fa45fe 4465 {
639d11d3 4466 struct die_info *child_die = die->child;
d9fa45fe
DC
4467
4468 while (child_die && child_die->tag)
4469 {
e7c27a73 4470 process_die (child_die, cu);
d9fa45fe
DC
4471 child_die = sibling_die (child_die);
4472 }
4473 }
9219021c 4474
38d518c9 4475 processing_current_prefix = previous_prefix;
987504bb 4476 do_cleanups (back_to);
38d518c9
EZ
4477}
4478
4479/* Return the name of the namespace represented by DIE. Set
4480 *IS_ANONYMOUS to tell whether or not the namespace is an anonymous
4481 namespace. */
4482
4483static const char *
e142c38c 4484namespace_name (struct die_info *die, int *is_anonymous, struct dwarf2_cu *cu)
38d518c9
EZ
4485{
4486 struct die_info *current_die;
4487 const char *name = NULL;
4488
4489 /* Loop through the extensions until we find a name. */
4490
4491 for (current_die = die;
4492 current_die != NULL;
e142c38c 4493 current_die = dwarf2_extension (die, cu))
38d518c9 4494 {
e142c38c 4495 name = dwarf2_name (current_die, cu);
38d518c9
EZ
4496 if (name != NULL)
4497 break;
4498 }
4499
4500 /* Is it an anonymous namespace? */
4501
4502 *is_anonymous = (name == NULL);
4503 if (*is_anonymous)
4504 name = "(anonymous namespace)";
4505
4506 return name;
d9fa45fe
DC
4507}
4508
c906108c
SS
4509/* Extract all information from a DW_TAG_pointer_type DIE and add to
4510 the user defined type vector. */
4511
4512static void
e7c27a73 4513read_tag_pointer_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c 4514{
e7c27a73 4515 struct comp_unit_head *cu_header = &cu->header;
c906108c 4516 struct type *type;
8b2dbe47
KB
4517 struct attribute *attr_byte_size;
4518 struct attribute *attr_address_class;
4519 int byte_size, addr_class;
c906108c
SS
4520
4521 if (die->type)
4522 {
4523 return;
4524 }
4525
e7c27a73 4526 type = lookup_pointer_type (die_type (die, cu));
8b2dbe47 4527
e142c38c 4528 attr_byte_size = dwarf2_attr (die, DW_AT_byte_size, cu);
8b2dbe47
KB
4529 if (attr_byte_size)
4530 byte_size = DW_UNSND (attr_byte_size);
c906108c 4531 else
8b2dbe47
KB
4532 byte_size = cu_header->addr_size;
4533
e142c38c 4534 attr_address_class = dwarf2_attr (die, DW_AT_address_class, cu);
8b2dbe47
KB
4535 if (attr_address_class)
4536 addr_class = DW_UNSND (attr_address_class);
4537 else
4538 addr_class = DW_ADDR_none;
4539
4540 /* If the pointer size or address class is different than the
4541 default, create a type variant marked as such and set the
4542 length accordingly. */
4543 if (TYPE_LENGTH (type) != byte_size || addr_class != DW_ADDR_none)
c906108c 4544 {
8b2dbe47
KB
4545 if (ADDRESS_CLASS_TYPE_FLAGS_P ())
4546 {
4547 int type_flags;
4548
4549 type_flags = ADDRESS_CLASS_TYPE_FLAGS (byte_size, addr_class);
4550 gdb_assert ((type_flags & ~TYPE_FLAG_ADDRESS_CLASS_ALL) == 0);
4551 type = make_type_with_address_space (type, type_flags);
4552 }
4553 else if (TYPE_LENGTH (type) != byte_size)
4554 {
e2e0b3e5 4555 complaint (&symfile_complaints, _("invalid pointer size %d"), byte_size);
8b2dbe47
KB
4556 }
4557 else {
4558 /* Should we also complain about unhandled address classes? */
4559 }
c906108c 4560 }
8b2dbe47
KB
4561
4562 TYPE_LENGTH (type) = byte_size;
1c379e20 4563 set_die_type (die, type, cu);
c906108c
SS
4564}
4565
4566/* Extract all information from a DW_TAG_ptr_to_member_type DIE and add to
4567 the user defined type vector. */
4568
4569static void
e7c27a73 4570read_tag_ptr_to_member_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c 4571{
e7c27a73 4572 struct objfile *objfile = cu->objfile;
c906108c
SS
4573 struct type *type;
4574 struct type *to_type;
4575 struct type *domain;
4576
4577 if (die->type)
4578 {
4579 return;
4580 }
4581
e7c27a73
DJ
4582 to_type = die_type (die, cu);
4583 domain = die_containing_type (die, cu);
0d5de010
DJ
4584
4585 if (TYPE_CODE (check_typedef (to_type)) == TYPE_CODE_METHOD)
4586 type = lookup_methodptr_type (to_type);
4587 else
4588 type = lookup_memberptr_type (to_type, domain);
c906108c 4589
1c379e20 4590 set_die_type (die, type, cu);
c906108c
SS
4591}
4592
4593/* Extract all information from a DW_TAG_reference_type DIE and add to
4594 the user defined type vector. */
4595
4596static void
e7c27a73 4597read_tag_reference_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c 4598{
e7c27a73 4599 struct comp_unit_head *cu_header = &cu->header;
c906108c
SS
4600 struct type *type;
4601 struct attribute *attr;
4602
4603 if (die->type)
4604 {
4605 return;
4606 }
4607
e7c27a73 4608 type = lookup_reference_type (die_type (die, cu));
e142c38c 4609 attr = dwarf2_attr (die, DW_AT_byte_size, cu);
c906108c
SS
4610 if (attr)
4611 {
4612 TYPE_LENGTH (type) = DW_UNSND (attr);
4613 }
4614 else
4615 {
107d2387 4616 TYPE_LENGTH (type) = cu_header->addr_size;
c906108c 4617 }
1c379e20 4618 set_die_type (die, type, cu);
c906108c
SS
4619}
4620
4621static void
e7c27a73 4622read_tag_const_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c 4623{
090c42a4
JB
4624 struct type *base_type;
4625
c906108c
SS
4626 if (die->type)
4627 {
4628 return;
4629 }
4630
e7c27a73 4631 base_type = die_type (die, cu);
1c379e20
DJ
4632 set_die_type (die, make_cv_type (1, TYPE_VOLATILE (base_type), base_type, 0),
4633 cu);
c906108c
SS
4634}
4635
4636static void
e7c27a73 4637read_tag_volatile_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c 4638{
090c42a4
JB
4639 struct type *base_type;
4640
c906108c
SS
4641 if (die->type)
4642 {
4643 return;
4644 }
4645
e7c27a73 4646 base_type = die_type (die, cu);
1c379e20
DJ
4647 set_die_type (die, make_cv_type (TYPE_CONST (base_type), 1, base_type, 0),
4648 cu);
c906108c
SS
4649}
4650
4651/* Extract all information from a DW_TAG_string_type DIE and add to
4652 the user defined type vector. It isn't really a user defined type,
4653 but it behaves like one, with other DIE's using an AT_user_def_type
4654 attribute to reference it. */
4655
4656static void
e7c27a73 4657read_tag_string_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c 4658{
e7c27a73 4659 struct objfile *objfile = cu->objfile;
c906108c
SS
4660 struct type *type, *range_type, *index_type, *char_type;
4661 struct attribute *attr;
4662 unsigned int length;
4663
4664 if (die->type)
4665 {
4666 return;
4667 }
4668
e142c38c 4669 attr = dwarf2_attr (die, DW_AT_string_length, cu);
c906108c
SS
4670 if (attr)
4671 {
4672 length = DW_UNSND (attr);
4673 }
4674 else
4675 {
b21b22e0 4676 /* check for the DW_AT_byte_size attribute */
e142c38c 4677 attr = dwarf2_attr (die, DW_AT_byte_size, cu);
b21b22e0
PS
4678 if (attr)
4679 {
4680 length = DW_UNSND (attr);
4681 }
4682 else
4683 {
4684 length = 1;
4685 }
c906108c 4686 }
e142c38c 4687 index_type = dwarf2_fundamental_type (objfile, FT_INTEGER, cu);
c906108c 4688 range_type = create_range_type (NULL, index_type, 1, length);
e142c38c 4689 if (cu->language == language_fortran)
b21b22e0
PS
4690 {
4691 /* Need to create a unique string type for bounds
4692 information */
4693 type = create_string_type (0, range_type);
4694 }
4695 else
4696 {
e142c38c 4697 char_type = dwarf2_fundamental_type (objfile, FT_CHAR, cu);
b21b22e0
PS
4698 type = create_string_type (char_type, range_type);
4699 }
1c379e20 4700 set_die_type (die, type, cu);
c906108c
SS
4701}
4702
4703/* Handle DIES due to C code like:
4704
4705 struct foo
c5aa993b
JM
4706 {
4707 int (*funcp)(int a, long l);
4708 int b;
4709 };
c906108c
SS
4710
4711 ('funcp' generates a DW_TAG_subroutine_type DIE)
c5aa993b 4712 */
c906108c
SS
4713
4714static void
e7c27a73 4715read_subroutine_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c
SS
4716{
4717 struct type *type; /* Type that this function returns */
4718 struct type *ftype; /* Function that returns above type */
4719 struct attribute *attr;
4720
4721 /* Decode the type that this subroutine returns */
4722 if (die->type)
4723 {
4724 return;
4725 }
e7c27a73 4726 type = die_type (die, cu);
1326e61b 4727 ftype = make_function_type (type, (struct type **) 0);
c906108c 4728
987504bb 4729 /* All functions in C++ and Java have prototypes. */
e142c38c 4730 attr = dwarf2_attr (die, DW_AT_prototyped, cu);
c906108c 4731 if ((attr && (DW_UNSND (attr) != 0))
987504bb
JJ
4732 || cu->language == language_cplus
4733 || cu->language == language_java)
c906108c
SS
4734 TYPE_FLAGS (ftype) |= TYPE_FLAG_PROTOTYPED;
4735
639d11d3 4736 if (die->child != NULL)
c906108c
SS
4737 {
4738 struct die_info *child_die;
4739 int nparams = 0;
4740 int iparams = 0;
4741
4742 /* Count the number of parameters.
4743 FIXME: GDB currently ignores vararg functions, but knows about
4744 vararg member functions. */
639d11d3 4745 child_die = die->child;
c906108c
SS
4746 while (child_die && child_die->tag)
4747 {
4748 if (child_die->tag == DW_TAG_formal_parameter)
4749 nparams++;
4750 else if (child_die->tag == DW_TAG_unspecified_parameters)
4751 TYPE_FLAGS (ftype) |= TYPE_FLAG_VARARGS;
4752 child_die = sibling_die (child_die);
4753 }
4754
4755 /* Allocate storage for parameters and fill them in. */
4756 TYPE_NFIELDS (ftype) = nparams;
4757 TYPE_FIELDS (ftype) = (struct field *)
ae5a43e0 4758 TYPE_ZALLOC (ftype, nparams * sizeof (struct field));
c906108c 4759
639d11d3 4760 child_die = die->child;
c906108c
SS
4761 while (child_die && child_die->tag)
4762 {
4763 if (child_die->tag == DW_TAG_formal_parameter)
4764 {
4765 /* Dwarf2 has no clean way to discern C++ static and non-static
c5aa993b
JM
4766 member functions. G++ helps GDB by marking the first
4767 parameter for non-static member functions (which is the
4768 this pointer) as artificial. We pass this information
4769 to dwarf2_add_member_fn via TYPE_FIELD_ARTIFICIAL. */
e142c38c 4770 attr = dwarf2_attr (child_die, DW_AT_artificial, cu);
c906108c
SS
4771 if (attr)
4772 TYPE_FIELD_ARTIFICIAL (ftype, iparams) = DW_UNSND (attr);
4773 else
4774 TYPE_FIELD_ARTIFICIAL (ftype, iparams) = 0;
e7c27a73 4775 TYPE_FIELD_TYPE (ftype, iparams) = die_type (child_die, cu);
c906108c
SS
4776 iparams++;
4777 }
4778 child_die = sibling_die (child_die);
4779 }
4780 }
4781
1c379e20 4782 set_die_type (die, ftype, cu);
c906108c
SS
4783}
4784
4785static void
e7c27a73 4786read_typedef (struct die_info *die, struct dwarf2_cu *cu)
c906108c 4787{
e7c27a73 4788 struct objfile *objfile = cu->objfile;
2f038fcb
FF
4789 struct attribute *attr;
4790 char *name = NULL;
c906108c
SS
4791
4792 if (!die->type)
4793 {
e142c38c 4794 attr = dwarf2_attr (die, DW_AT_name, cu);
c906108c 4795 if (attr && DW_STRING (attr))
2f038fcb
FF
4796 {
4797 name = DW_STRING (attr);
4798 }
1c379e20
DJ
4799 set_die_type (die, init_type (TYPE_CODE_TYPEDEF, 0,
4800 TYPE_FLAG_TARGET_STUB, name, objfile),
4801 cu);
e7c27a73 4802 TYPE_TARGET_TYPE (die->type) = die_type (die, cu);
c906108c
SS
4803 }
4804}
4805
4806/* Find a representation of a given base type and install
4807 it in the TYPE field of the die. */
4808
4809static void
e7c27a73 4810read_base_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c 4811{
e7c27a73 4812 struct objfile *objfile = cu->objfile;
c906108c
SS
4813 struct type *type;
4814 struct attribute *attr;
4815 int encoding = 0, size = 0;
4816
4817 /* If we've already decoded this die, this is a no-op. */
4818 if (die->type)
4819 {
4820 return;
4821 }
4822
e142c38c 4823 attr = dwarf2_attr (die, DW_AT_encoding, cu);
c906108c
SS
4824 if (attr)
4825 {
4826 encoding = DW_UNSND (attr);
4827 }
e142c38c 4828 attr = dwarf2_attr (die, DW_AT_byte_size, cu);
c906108c
SS
4829 if (attr)
4830 {
4831 size = DW_UNSND (attr);
4832 }
e142c38c 4833 attr = dwarf2_attr (die, DW_AT_name, cu);
c906108c
SS
4834 if (attr && DW_STRING (attr))
4835 {
4836 enum type_code code = TYPE_CODE_INT;
f5ef7c67 4837 int type_flags = 0;
c906108c
SS
4838
4839 switch (encoding)
4840 {
4841 case DW_ATE_address:
4842 /* Turn DW_ATE_address into a void * pointer. */
4843 code = TYPE_CODE_PTR;
f5ef7c67 4844 type_flags |= TYPE_FLAG_UNSIGNED;
c906108c
SS
4845 break;
4846 case DW_ATE_boolean:
4847 code = TYPE_CODE_BOOL;
f5ef7c67 4848 type_flags |= TYPE_FLAG_UNSIGNED;
c906108c
SS
4849 break;
4850 case DW_ATE_complex_float:
4851 code = TYPE_CODE_COMPLEX;
4852 break;
4853 case DW_ATE_float:
4854 code = TYPE_CODE_FLT;
4855 break;
4856 case DW_ATE_signed:
c906108c
SS
4857 break;
4858 case DW_ATE_unsigned:
72019c9c
GM
4859 type_flags |= TYPE_FLAG_UNSIGNED;
4860 break;
4861 case DW_ATE_signed_char:
4862 if (cu->language == language_m2)
4863 code = TYPE_CODE_CHAR;
4864 break;
4865 case DW_ATE_unsigned_char:
4866 if (cu->language == language_m2)
4867 code = TYPE_CODE_CHAR;
f5ef7c67 4868 type_flags |= TYPE_FLAG_UNSIGNED;
c906108c
SS
4869 break;
4870 default:
e2e0b3e5 4871 complaint (&symfile_complaints, _("unsupported DW_AT_encoding: '%s'"),
4d3c2250 4872 dwarf_type_encoding_name (encoding));
c906108c
SS
4873 break;
4874 }
f5ef7c67 4875 type = init_type (code, size, type_flags, DW_STRING (attr), objfile);
c906108c 4876 if (encoding == DW_ATE_address)
e142c38c
DJ
4877 TYPE_TARGET_TYPE (type) = dwarf2_fundamental_type (objfile, FT_VOID,
4878 cu);
f65ca430
DJ
4879 else if (encoding == DW_ATE_complex_float)
4880 {
4881 if (size == 32)
4882 TYPE_TARGET_TYPE (type)
e142c38c 4883 = dwarf2_fundamental_type (objfile, FT_EXT_PREC_FLOAT, cu);
f65ca430
DJ
4884 else if (size == 16)
4885 TYPE_TARGET_TYPE (type)
e142c38c 4886 = dwarf2_fundamental_type (objfile, FT_DBL_PREC_FLOAT, cu);
f65ca430
DJ
4887 else if (size == 8)
4888 TYPE_TARGET_TYPE (type)
e142c38c 4889 = dwarf2_fundamental_type (objfile, FT_FLOAT, cu);
f65ca430 4890 }
c906108c
SS
4891 }
4892 else
4893 {
e7c27a73 4894 type = dwarf_base_type (encoding, size, cu);
c906108c 4895 }
1c379e20 4896 set_die_type (die, type, cu);
c906108c
SS
4897}
4898
a02abb62
JB
4899/* Read the given DW_AT_subrange DIE. */
4900
4901static void
4902read_subrange_type (struct die_info *die, struct dwarf2_cu *cu)
4903{
4904 struct type *base_type;
4905 struct type *range_type;
4906 struct attribute *attr;
4907 int low = 0;
4908 int high = -1;
4909
4910 /* If we have already decoded this die, then nothing more to do. */
4911 if (die->type)
4912 return;
4913
4914 base_type = die_type (die, cu);
4915 if (base_type == NULL)
4916 {
4917 complaint (&symfile_complaints,
e2e0b3e5 4918 _("DW_AT_type missing from DW_TAG_subrange_type"));
a02abb62
JB
4919 return;
4920 }
4921
4922 if (TYPE_CODE (base_type) == TYPE_CODE_VOID)
4923 base_type = alloc_type (NULL);
4924
e142c38c 4925 if (cu->language == language_fortran)
a02abb62
JB
4926 {
4927 /* FORTRAN implies a lower bound of 1, if not given. */
4928 low = 1;
4929 }
4930
dd5e6932
DJ
4931 /* FIXME: For variable sized arrays either of these could be
4932 a variable rather than a constant value. We'll allow it,
4933 but we don't know how to handle it. */
e142c38c 4934 attr = dwarf2_attr (die, DW_AT_lower_bound, cu);
a02abb62
JB
4935 if (attr)
4936 low = dwarf2_get_attr_constant_value (attr, 0);
4937
e142c38c 4938 attr = dwarf2_attr (die, DW_AT_upper_bound, cu);
a02abb62
JB
4939 if (attr)
4940 {
4941 if (attr->form == DW_FORM_block1)
4942 {
4943 /* GCC encodes arrays with unspecified or dynamic length
4944 with a DW_FORM_block1 attribute.
4945 FIXME: GDB does not yet know how to handle dynamic
4946 arrays properly, treat them as arrays with unspecified
4947 length for now.
4948
4949 FIXME: jimb/2003-09-22: GDB does not really know
4950 how to handle arrays of unspecified length
4951 either; we just represent them as zero-length
4952 arrays. Choose an appropriate upper bound given
4953 the lower bound we've computed above. */
4954 high = low - 1;
4955 }
4956 else
4957 high = dwarf2_get_attr_constant_value (attr, 1);
4958 }
4959
4960 range_type = create_range_type (NULL, base_type, low, high);
4961
e142c38c 4962 attr = dwarf2_attr (die, DW_AT_name, cu);
a02abb62
JB
4963 if (attr && DW_STRING (attr))
4964 TYPE_NAME (range_type) = DW_STRING (attr);
4965
e142c38c 4966 attr = dwarf2_attr (die, DW_AT_byte_size, cu);
a02abb62
JB
4967 if (attr)
4968 TYPE_LENGTH (range_type) = DW_UNSND (attr);
4969
1c379e20 4970 set_die_type (die, range_type, cu);
a02abb62
JB
4971}
4972
81a17f79
JB
4973static void
4974read_unspecified_type (struct die_info *die, struct dwarf2_cu *cu)
4975{
4976 struct type *type;
4977 struct attribute *attr;
4978
4979 if (die->type)
4980 return;
4981
4982 /* For now, we only support the C meaning of an unspecified type: void. */
4983
4984 attr = dwarf2_attr (die, DW_AT_name, cu);
4985 type = init_type (TYPE_CODE_VOID, 0, 0, attr ? DW_STRING (attr) : "",
4986 cu->objfile);
4987
4988 set_die_type (die, type, cu);
4989}
a02abb62 4990
c906108c
SS
4991/* Read a whole compilation unit into a linked list of dies. */
4992
f9aca02d 4993static struct die_info *
fe1b8b76 4994read_comp_unit (gdb_byte *info_ptr, bfd *abfd, struct dwarf2_cu *cu)
c906108c 4995{
e7c27a73 4996 return read_die_and_children (info_ptr, abfd, cu, &info_ptr, NULL);
639d11d3
DC
4997}
4998
4999/* Read a single die and all its descendents. Set the die's sibling
5000 field to NULL; set other fields in the die correctly, and set all
5001 of the descendents' fields correctly. Set *NEW_INFO_PTR to the
5002 location of the info_ptr after reading all of those dies. PARENT
5003 is the parent of the die in question. */
5004
5005static struct die_info *
fe1b8b76 5006read_die_and_children (gdb_byte *info_ptr, bfd *abfd,
e7c27a73 5007 struct dwarf2_cu *cu,
fe1b8b76 5008 gdb_byte **new_info_ptr,
639d11d3
DC
5009 struct die_info *parent)
5010{
5011 struct die_info *die;
fe1b8b76 5012 gdb_byte *cur_ptr;
639d11d3
DC
5013 int has_children;
5014
e7c27a73 5015 cur_ptr = read_full_die (&die, abfd, info_ptr, cu, &has_children);
10b3939b 5016 store_in_ref_table (die->offset, die, cu);
639d11d3
DC
5017
5018 if (has_children)
5019 {
e7c27a73 5020 die->child = read_die_and_siblings (cur_ptr, abfd, cu,
639d11d3
DC
5021 new_info_ptr, die);
5022 }
5023 else
5024 {
5025 die->child = NULL;
5026 *new_info_ptr = cur_ptr;
5027 }
5028
5029 die->sibling = NULL;
5030 die->parent = parent;
5031 return die;
5032}
5033
5034/* Read a die, all of its descendents, and all of its siblings; set
5035 all of the fields of all of the dies correctly. Arguments are as
5036 in read_die_and_children. */
5037
5038static struct die_info *
fe1b8b76 5039read_die_and_siblings (gdb_byte *info_ptr, bfd *abfd,
e7c27a73 5040 struct dwarf2_cu *cu,
fe1b8b76 5041 gdb_byte **new_info_ptr,
639d11d3
DC
5042 struct die_info *parent)
5043{
5044 struct die_info *first_die, *last_sibling;
fe1b8b76 5045 gdb_byte *cur_ptr;
639d11d3 5046
c906108c 5047 cur_ptr = info_ptr;
639d11d3
DC
5048 first_die = last_sibling = NULL;
5049
5050 while (1)
c906108c 5051 {
639d11d3 5052 struct die_info *die
e7c27a73 5053 = read_die_and_children (cur_ptr, abfd, cu, &cur_ptr, parent);
639d11d3
DC
5054
5055 if (!first_die)
c906108c 5056 {
639d11d3 5057 first_die = die;
c906108c 5058 }
639d11d3 5059 else
c906108c 5060 {
639d11d3 5061 last_sibling->sibling = die;
c906108c
SS
5062 }
5063
639d11d3 5064 if (die->tag == 0)
c906108c 5065 {
639d11d3
DC
5066 *new_info_ptr = cur_ptr;
5067 return first_die;
c906108c
SS
5068 }
5069 else
5070 {
639d11d3 5071 last_sibling = die;
c906108c
SS
5072 }
5073 }
c906108c
SS
5074}
5075
5076/* Free a linked list of dies. */
5077
5078static void
fba45db2 5079free_die_list (struct die_info *dies)
c906108c
SS
5080{
5081 struct die_info *die, *next;
5082
5083 die = dies;
5084 while (die)
5085 {
639d11d3
DC
5086 if (die->child != NULL)
5087 free_die_list (die->child);
5088 next = die->sibling;
b8c9b27d
KB
5089 xfree (die->attrs);
5090 xfree (die);
c906108c
SS
5091 die = next;
5092 }
5093}
5094
5095/* Read the contents of the section at OFFSET and of size SIZE from the
8b92e4d5 5096 object file specified by OBJFILE into the objfile_obstack and return it. */
c906108c 5097
fe1b8b76 5098gdb_byte *
188dd5d6 5099dwarf2_read_section (struct objfile *objfile, asection *sectp)
c906108c
SS
5100{
5101 bfd *abfd = objfile->obfd;
fe1b8b76 5102 gdb_byte *buf, *retbuf;
2c500098 5103 bfd_size_type size = bfd_get_section_size (sectp);
c906108c
SS
5104
5105 if (size == 0)
5106 return NULL;
5107
fe1b8b76
JB
5108 buf = obstack_alloc (&objfile->objfile_obstack, size);
5109 retbuf = symfile_relocate_debug_section (abfd, sectp, buf);
086df311
DJ
5110 if (retbuf != NULL)
5111 return retbuf;
5112
188dd5d6
DJ
5113 if (bfd_seek (abfd, sectp->filepos, SEEK_SET) != 0
5114 || bfd_bread (buf, size, abfd) != size)
8a3fe4f8 5115 error (_("Dwarf Error: Can't read DWARF data from '%s'"),
188dd5d6
DJ
5116 bfd_get_filename (abfd));
5117
c906108c
SS
5118 return buf;
5119}
5120
5121/* In DWARF version 2, the description of the debugging information is
5122 stored in a separate .debug_abbrev section. Before we read any
5123 dies from a section we read in all abbreviations and install them
72bf9492
DJ
5124 in a hash table. This function also sets flags in CU describing
5125 the data found in the abbrev table. */
c906108c
SS
5126
5127static void
e7c27a73 5128dwarf2_read_abbrevs (bfd *abfd, struct dwarf2_cu *cu)
c906108c 5129{
e7c27a73 5130 struct comp_unit_head *cu_header = &cu->header;
fe1b8b76 5131 gdb_byte *abbrev_ptr;
c906108c
SS
5132 struct abbrev_info *cur_abbrev;
5133 unsigned int abbrev_number, bytes_read, abbrev_name;
5134 unsigned int abbrev_form, hash_number;
f3dd6933
DJ
5135 struct attr_abbrev *cur_attrs;
5136 unsigned int allocated_attrs;
c906108c 5137
57349743 5138 /* Initialize dwarf2 abbrevs */
f3dd6933
DJ
5139 obstack_init (&cu->abbrev_obstack);
5140 cu->dwarf2_abbrevs = obstack_alloc (&cu->abbrev_obstack,
5141 (ABBREV_HASH_SIZE
5142 * sizeof (struct abbrev_info *)));
5143 memset (cu->dwarf2_abbrevs, 0,
5144 ABBREV_HASH_SIZE * sizeof (struct abbrev_info *));
c906108c 5145
6502dd73 5146 abbrev_ptr = dwarf2_per_objfile->abbrev_buffer + cu_header->abbrev_offset;
c906108c
SS
5147 abbrev_number = read_unsigned_leb128 (abfd, abbrev_ptr, &bytes_read);
5148 abbrev_ptr += bytes_read;
5149
f3dd6933
DJ
5150 allocated_attrs = ATTR_ALLOC_CHUNK;
5151 cur_attrs = xmalloc (allocated_attrs * sizeof (struct attr_abbrev));
5152
c906108c
SS
5153 /* loop until we reach an abbrev number of 0 */
5154 while (abbrev_number)
5155 {
f3dd6933 5156 cur_abbrev = dwarf_alloc_abbrev (cu);
c906108c
SS
5157
5158 /* read in abbrev header */
5159 cur_abbrev->number = abbrev_number;
5160 cur_abbrev->tag = read_unsigned_leb128 (abfd, abbrev_ptr, &bytes_read);
5161 abbrev_ptr += bytes_read;
5162 cur_abbrev->has_children = read_1_byte (abfd, abbrev_ptr);
5163 abbrev_ptr += 1;
5164
72bf9492
DJ
5165 if (cur_abbrev->tag == DW_TAG_namespace)
5166 cu->has_namespace_info = 1;
5167
c906108c
SS
5168 /* now read in declarations */
5169 abbrev_name = read_unsigned_leb128 (abfd, abbrev_ptr, &bytes_read);
5170 abbrev_ptr += bytes_read;
5171 abbrev_form = read_unsigned_leb128 (abfd, abbrev_ptr, &bytes_read);
5172 abbrev_ptr += bytes_read;
5173 while (abbrev_name)
5174 {
f3dd6933 5175 if (cur_abbrev->num_attrs == allocated_attrs)
c906108c 5176 {
f3dd6933
DJ
5177 allocated_attrs += ATTR_ALLOC_CHUNK;
5178 cur_attrs
5179 = xrealloc (cur_attrs, (allocated_attrs
5180 * sizeof (struct attr_abbrev)));
c906108c 5181 }
ae038cb0
DJ
5182
5183 /* Record whether this compilation unit might have
5184 inter-compilation-unit references. If we don't know what form
5185 this attribute will have, then it might potentially be a
5186 DW_FORM_ref_addr, so we conservatively expect inter-CU
5187 references. */
5188
5189 if (abbrev_form == DW_FORM_ref_addr
5190 || abbrev_form == DW_FORM_indirect)
5191 cu->has_form_ref_addr = 1;
5192
f3dd6933
DJ
5193 cur_attrs[cur_abbrev->num_attrs].name = abbrev_name;
5194 cur_attrs[cur_abbrev->num_attrs++].form = abbrev_form;
c906108c
SS
5195 abbrev_name = read_unsigned_leb128 (abfd, abbrev_ptr, &bytes_read);
5196 abbrev_ptr += bytes_read;
5197 abbrev_form = read_unsigned_leb128 (abfd, abbrev_ptr, &bytes_read);
5198 abbrev_ptr += bytes_read;
5199 }
5200
f3dd6933
DJ
5201 cur_abbrev->attrs = obstack_alloc (&cu->abbrev_obstack,
5202 (cur_abbrev->num_attrs
5203 * sizeof (struct attr_abbrev)));
5204 memcpy (cur_abbrev->attrs, cur_attrs,
5205 cur_abbrev->num_attrs * sizeof (struct attr_abbrev));
5206
c906108c 5207 hash_number = abbrev_number % ABBREV_HASH_SIZE;
f3dd6933
DJ
5208 cur_abbrev->next = cu->dwarf2_abbrevs[hash_number];
5209 cu->dwarf2_abbrevs[hash_number] = cur_abbrev;
c906108c
SS
5210
5211 /* Get next abbreviation.
5212 Under Irix6 the abbreviations for a compilation unit are not
c5aa993b
JM
5213 always properly terminated with an abbrev number of 0.
5214 Exit loop if we encounter an abbreviation which we have
5215 already read (which means we are about to read the abbreviations
5216 for the next compile unit) or if the end of the abbreviation
5217 table is reached. */
6502dd73
DJ
5218 if ((unsigned int) (abbrev_ptr - dwarf2_per_objfile->abbrev_buffer)
5219 >= dwarf2_per_objfile->abbrev_size)
c906108c
SS
5220 break;
5221 abbrev_number = read_unsigned_leb128 (abfd, abbrev_ptr, &bytes_read);
5222 abbrev_ptr += bytes_read;
e7c27a73 5223 if (dwarf2_lookup_abbrev (abbrev_number, cu) != NULL)
c906108c
SS
5224 break;
5225 }
f3dd6933
DJ
5226
5227 xfree (cur_attrs);
c906108c
SS
5228}
5229
f3dd6933 5230/* Release the memory used by the abbrev table for a compilation unit. */
c906108c 5231
c906108c 5232static void
f3dd6933 5233dwarf2_free_abbrev_table (void *ptr_to_cu)
c906108c 5234{
f3dd6933 5235 struct dwarf2_cu *cu = ptr_to_cu;
c906108c 5236
f3dd6933
DJ
5237 obstack_free (&cu->abbrev_obstack, NULL);
5238 cu->dwarf2_abbrevs = NULL;
c906108c
SS
5239}
5240
5241/* Lookup an abbrev_info structure in the abbrev hash table. */
5242
5243static struct abbrev_info *
e7c27a73 5244dwarf2_lookup_abbrev (unsigned int number, struct dwarf2_cu *cu)
c906108c
SS
5245{
5246 unsigned int hash_number;
5247 struct abbrev_info *abbrev;
5248
5249 hash_number = number % ABBREV_HASH_SIZE;
f3dd6933 5250 abbrev = cu->dwarf2_abbrevs[hash_number];
c906108c
SS
5251
5252 while (abbrev)
5253 {
5254 if (abbrev->number == number)
5255 return abbrev;
5256 else
5257 abbrev = abbrev->next;
5258 }
5259 return NULL;
5260}
5261
72bf9492
DJ
5262/* Returns nonzero if TAG represents a type that we might generate a partial
5263 symbol for. */
5264
5265static int
5266is_type_tag_for_partial (int tag)
5267{
5268 switch (tag)
5269 {
5270#if 0
5271 /* Some types that would be reasonable to generate partial symbols for,
5272 that we don't at present. */
5273 case DW_TAG_array_type:
5274 case DW_TAG_file_type:
5275 case DW_TAG_ptr_to_member_type:
5276 case DW_TAG_set_type:
5277 case DW_TAG_string_type:
5278 case DW_TAG_subroutine_type:
5279#endif
5280 case DW_TAG_base_type:
5281 case DW_TAG_class_type:
5282 case DW_TAG_enumeration_type:
5283 case DW_TAG_structure_type:
5284 case DW_TAG_subrange_type:
5285 case DW_TAG_typedef:
5286 case DW_TAG_union_type:
5287 return 1;
5288 default:
5289 return 0;
5290 }
5291}
5292
5293/* Load all DIEs that are interesting for partial symbols into memory. */
5294
5295static struct partial_die_info *
fe1b8b76 5296load_partial_dies (bfd *abfd, gdb_byte *info_ptr, int building_psymtab,
72bf9492
DJ
5297 struct dwarf2_cu *cu)
5298{
5299 struct partial_die_info *part_die;
5300 struct partial_die_info *parent_die, *last_die, *first_die = NULL;
5301 struct abbrev_info *abbrev;
5302 unsigned int bytes_read;
5afb4e99 5303 unsigned int load_all = 0;
72bf9492
DJ
5304
5305 int nesting_level = 1;
5306
5307 parent_die = NULL;
5308 last_die = NULL;
5309
5afb4e99
DJ
5310 if (cu->per_cu && cu->per_cu->load_all_dies)
5311 load_all = 1;
5312
72bf9492
DJ
5313 cu->partial_dies
5314 = htab_create_alloc_ex (cu->header.length / 12,
5315 partial_die_hash,
5316 partial_die_eq,
5317 NULL,
5318 &cu->comp_unit_obstack,
5319 hashtab_obstack_allocate,
5320 dummy_obstack_deallocate);
5321
5322 part_die = obstack_alloc (&cu->comp_unit_obstack,
5323 sizeof (struct partial_die_info));
5324
5325 while (1)
5326 {
5327 abbrev = peek_die_abbrev (info_ptr, &bytes_read, cu);
5328
5329 /* A NULL abbrev means the end of a series of children. */
5330 if (abbrev == NULL)
5331 {
5332 if (--nesting_level == 0)
5333 {
5334 /* PART_DIE was probably the last thing allocated on the
5335 comp_unit_obstack, so we could call obstack_free
5336 here. We don't do that because the waste is small,
5337 and will be cleaned up when we're done with this
5338 compilation unit. This way, we're also more robust
5339 against other users of the comp_unit_obstack. */
5340 return first_die;
5341 }
5342 info_ptr += bytes_read;
5343 last_die = parent_die;
5344 parent_die = parent_die->die_parent;
5345 continue;
5346 }
5347
5afb4e99
DJ
5348 /* Check whether this DIE is interesting enough to save. Normally
5349 we would not be interested in members here, but there may be
5350 later variables referencing them via DW_AT_specification (for
5351 static members). */
5352 if (!load_all
5353 && !is_type_tag_for_partial (abbrev->tag)
72bf9492
DJ
5354 && abbrev->tag != DW_TAG_enumerator
5355 && abbrev->tag != DW_TAG_subprogram
5356 && abbrev->tag != DW_TAG_variable
5afb4e99
DJ
5357 && abbrev->tag != DW_TAG_namespace
5358 && abbrev->tag != DW_TAG_member)
72bf9492
DJ
5359 {
5360 /* Otherwise we skip to the next sibling, if any. */
5361 info_ptr = skip_one_die (info_ptr + bytes_read, abbrev, cu);
5362 continue;
5363 }
5364
5365 info_ptr = read_partial_die (part_die, abbrev, bytes_read,
5366 abfd, info_ptr, cu);
5367
5368 /* This two-pass algorithm for processing partial symbols has a
5369 high cost in cache pressure. Thus, handle some simple cases
5370 here which cover the majority of C partial symbols. DIEs
5371 which neither have specification tags in them, nor could have
5372 specification tags elsewhere pointing at them, can simply be
5373 processed and discarded.
5374
5375 This segment is also optional; scan_partial_symbols and
5376 add_partial_symbol will handle these DIEs if we chain
5377 them in normally. When compilers which do not emit large
5378 quantities of duplicate debug information are more common,
5379 this code can probably be removed. */
5380
5381 /* Any complete simple types at the top level (pretty much all
5382 of them, for a language without namespaces), can be processed
5383 directly. */
5384 if (parent_die == NULL
5385 && part_die->has_specification == 0
5386 && part_die->is_declaration == 0
5387 && (part_die->tag == DW_TAG_typedef
5388 || part_die->tag == DW_TAG_base_type
5389 || part_die->tag == DW_TAG_subrange_type))
5390 {
5391 if (building_psymtab && part_die->name != NULL)
5392 add_psymbol_to_list (part_die->name, strlen (part_die->name),
5393 VAR_DOMAIN, LOC_TYPEDEF,
5394 &cu->objfile->static_psymbols,
5395 0, (CORE_ADDR) 0, cu->language, cu->objfile);
5396 info_ptr = locate_pdi_sibling (part_die, info_ptr, abfd, cu);
5397 continue;
5398 }
5399
5400 /* If we're at the second level, and we're an enumerator, and
5401 our parent has no specification (meaning possibly lives in a
5402 namespace elsewhere), then we can add the partial symbol now
5403 instead of queueing it. */
5404 if (part_die->tag == DW_TAG_enumerator
5405 && parent_die != NULL
5406 && parent_die->die_parent == NULL
5407 && parent_die->tag == DW_TAG_enumeration_type
5408 && parent_die->has_specification == 0)
5409 {
5410 if (part_die->name == NULL)
e2e0b3e5 5411 complaint (&symfile_complaints, _("malformed enumerator DIE ignored"));
72bf9492
DJ
5412 else if (building_psymtab)
5413 add_psymbol_to_list (part_die->name, strlen (part_die->name),
5414 VAR_DOMAIN, LOC_CONST,
987504bb
JJ
5415 (cu->language == language_cplus
5416 || cu->language == language_java)
72bf9492
DJ
5417 ? &cu->objfile->global_psymbols
5418 : &cu->objfile->static_psymbols,
5419 0, (CORE_ADDR) 0, cu->language, cu->objfile);
5420
5421 info_ptr = locate_pdi_sibling (part_die, info_ptr, abfd, cu);
5422 continue;
5423 }
5424
5425 /* We'll save this DIE so link it in. */
5426 part_die->die_parent = parent_die;
5427 part_die->die_sibling = NULL;
5428 part_die->die_child = NULL;
5429
5430 if (last_die && last_die == parent_die)
5431 last_die->die_child = part_die;
5432 else if (last_die)
5433 last_die->die_sibling = part_die;
5434
5435 last_die = part_die;
5436
5437 if (first_die == NULL)
5438 first_die = part_die;
5439
5440 /* Maybe add the DIE to the hash table. Not all DIEs that we
5441 find interesting need to be in the hash table, because we
5442 also have the parent/sibling/child chains; only those that we
5443 might refer to by offset later during partial symbol reading.
5444
5445 For now this means things that might have be the target of a
5446 DW_AT_specification, DW_AT_abstract_origin, or
5447 DW_AT_extension. DW_AT_extension will refer only to
5448 namespaces; DW_AT_abstract_origin refers to functions (and
5449 many things under the function DIE, but we do not recurse
5450 into function DIEs during partial symbol reading) and
5451 possibly variables as well; DW_AT_specification refers to
5452 declarations. Declarations ought to have the DW_AT_declaration
5453 flag. It happens that GCC forgets to put it in sometimes, but
5454 only for functions, not for types.
5455
5456 Adding more things than necessary to the hash table is harmless
5457 except for the performance cost. Adding too few will result in
5afb4e99
DJ
5458 wasted time in find_partial_die, when we reread the compilation
5459 unit with load_all_dies set. */
72bf9492 5460
5afb4e99
DJ
5461 if (load_all
5462 || abbrev->tag == DW_TAG_subprogram
72bf9492
DJ
5463 || abbrev->tag == DW_TAG_variable
5464 || abbrev->tag == DW_TAG_namespace
5465 || part_die->is_declaration)
5466 {
5467 void **slot;
5468
5469 slot = htab_find_slot_with_hash (cu->partial_dies, part_die,
5470 part_die->offset, INSERT);
5471 *slot = part_die;
5472 }
5473
5474 part_die = obstack_alloc (&cu->comp_unit_obstack,
5475 sizeof (struct partial_die_info));
5476
5477 /* For some DIEs we want to follow their children (if any). For C
5478 we have no reason to follow the children of structures; for other
5479 languages we have to, both so that we can get at method physnames
5480 to infer fully qualified class names, and for DW_AT_specification. */
5481 if (last_die->has_children
5afb4e99
DJ
5482 && (load_all
5483 || last_die->tag == DW_TAG_namespace
72bf9492
DJ
5484 || last_die->tag == DW_TAG_enumeration_type
5485 || (cu->language != language_c
5486 && (last_die->tag == DW_TAG_class_type
5487 || last_die->tag == DW_TAG_structure_type
5488 || last_die->tag == DW_TAG_union_type))))
5489 {
5490 nesting_level++;
5491 parent_die = last_die;
5492 continue;
5493 }
5494
5495 /* Otherwise we skip to the next sibling, if any. */
5496 info_ptr = locate_pdi_sibling (last_die, info_ptr, abfd, cu);
5497
5498 /* Back to the top, do it again. */
5499 }
5500}
5501
c906108c
SS
5502/* Read a minimal amount of information into the minimal die structure. */
5503
fe1b8b76 5504static gdb_byte *
72bf9492
DJ
5505read_partial_die (struct partial_die_info *part_die,
5506 struct abbrev_info *abbrev,
5507 unsigned int abbrev_len, bfd *abfd,
fe1b8b76 5508 gdb_byte *info_ptr, struct dwarf2_cu *cu)
c906108c 5509{
72bf9492 5510 unsigned int bytes_read, i;
c906108c 5511 struct attribute attr;
c5aa993b 5512 int has_low_pc_attr = 0;
c906108c
SS
5513 int has_high_pc_attr = 0;
5514
72bf9492 5515 memset (part_die, 0, sizeof (struct partial_die_info));
c906108c 5516
6502dd73 5517 part_die->offset = info_ptr - dwarf2_per_objfile->info_buffer;
72bf9492
DJ
5518
5519 info_ptr += abbrev_len;
5520
5521 if (abbrev == NULL)
5522 return info_ptr;
5523
c906108c
SS
5524 part_die->tag = abbrev->tag;
5525 part_die->has_children = abbrev->has_children;
c906108c
SS
5526
5527 for (i = 0; i < abbrev->num_attrs; ++i)
5528 {
e7c27a73 5529 info_ptr = read_attribute (&attr, &abbrev->attrs[i], abfd, info_ptr, cu);
c906108c
SS
5530
5531 /* Store the data if it is of an attribute we want to keep in a
c5aa993b 5532 partial symbol table. */
c906108c
SS
5533 switch (attr.name)
5534 {
5535 case DW_AT_name:
5536
5537 /* Prefer DW_AT_MIPS_linkage_name over DW_AT_name. */
5538 if (part_die->name == NULL)
5539 part_die->name = DW_STRING (&attr);
5540 break;
57c22c6c
BR
5541 case DW_AT_comp_dir:
5542 if (part_die->dirname == NULL)
5543 part_die->dirname = DW_STRING (&attr);
5544 break;
c906108c
SS
5545 case DW_AT_MIPS_linkage_name:
5546 part_die->name = DW_STRING (&attr);
5547 break;
5548 case DW_AT_low_pc:
5549 has_low_pc_attr = 1;
5550 part_die->lowpc = DW_ADDR (&attr);
5551 break;
5552 case DW_AT_high_pc:
5553 has_high_pc_attr = 1;
5554 part_die->highpc = DW_ADDR (&attr);
5555 break;
5556 case DW_AT_location:
8e19ed76
PS
5557 /* Support the .debug_loc offsets */
5558 if (attr_form_is_block (&attr))
5559 {
5560 part_die->locdesc = DW_BLOCK (&attr);
5561 }
5562 else if (attr.form == DW_FORM_data4 || attr.form == DW_FORM_data8)
5563 {
4d3c2250 5564 dwarf2_complex_location_expr_complaint ();
8e19ed76
PS
5565 }
5566 else
5567 {
4d3c2250
KB
5568 dwarf2_invalid_attrib_class_complaint ("DW_AT_location",
5569 "partial symbol information");
8e19ed76 5570 }
c906108c
SS
5571 break;
5572 case DW_AT_language:
5573 part_die->language = DW_UNSND (&attr);
5574 break;
5575 case DW_AT_external:
5576 part_die->is_external = DW_UNSND (&attr);
5577 break;
5578 case DW_AT_declaration:
5579 part_die->is_declaration = DW_UNSND (&attr);
5580 break;
5581 case DW_AT_type:
5582 part_die->has_type = 1;
5583 break;
5584 case DW_AT_abstract_origin:
5585 case DW_AT_specification:
72bf9492
DJ
5586 case DW_AT_extension:
5587 part_die->has_specification = 1;
5588 part_die->spec_offset = dwarf2_get_ref_die_offset (&attr, cu);
c906108c
SS
5589 break;
5590 case DW_AT_sibling:
5591 /* Ignore absolute siblings, they might point outside of
5592 the current compile unit. */
5593 if (attr.form == DW_FORM_ref_addr)
e2e0b3e5 5594 complaint (&symfile_complaints, _("ignoring absolute DW_AT_sibling"));
c906108c 5595 else
6502dd73
DJ
5596 part_die->sibling = dwarf2_per_objfile->info_buffer
5597 + dwarf2_get_ref_die_offset (&attr, cu);
c906108c 5598 break;
aaa75496
JB
5599 case DW_AT_stmt_list:
5600 part_die->has_stmt_list = 1;
5601 part_die->line_offset = DW_UNSND (&attr);
5602 break;
fa4028e9
JB
5603 case DW_AT_byte_size:
5604 part_die->has_byte_size = 1;
5605 break;
c906108c
SS
5606 default:
5607 break;
5608 }
5609 }
5610
c906108c
SS
5611 /* When using the GNU linker, .gnu.linkonce. sections are used to
5612 eliminate duplicate copies of functions and vtables and such.
5613 The linker will arbitrarily choose one and discard the others.
5614 The AT_*_pc values for such functions refer to local labels in
5615 these sections. If the section from that file was discarded, the
5616 labels are not in the output, so the relocs get a value of 0.
5617 If this is a discarded function, mark the pc bounds as invalid,
5618 so that GDB will ignore it. */
5619 if (has_low_pc_attr && has_high_pc_attr
5620 && part_die->lowpc < part_die->highpc
5621 && (part_die->lowpc != 0
72dca2f5 5622 || dwarf2_per_objfile->has_section_at_zero))
0b010bcc 5623 part_die->has_pc_info = 1;
c906108c
SS
5624 return info_ptr;
5625}
5626
72bf9492
DJ
5627/* Find a cached partial DIE at OFFSET in CU. */
5628
5629static struct partial_die_info *
5630find_partial_die_in_comp_unit (unsigned long offset, struct dwarf2_cu *cu)
5631{
5632 struct partial_die_info *lookup_die = NULL;
5633 struct partial_die_info part_die;
5634
5635 part_die.offset = offset;
5636 lookup_die = htab_find_with_hash (cu->partial_dies, &part_die, offset);
5637
72bf9492
DJ
5638 return lookup_die;
5639}
5640
5641/* Find a partial DIE at OFFSET, which may or may not be in CU. */
5642
5643static struct partial_die_info *
10b3939b 5644find_partial_die (unsigned long offset, struct dwarf2_cu *cu)
72bf9492 5645{
5afb4e99
DJ
5646 struct dwarf2_per_cu_data *per_cu = NULL;
5647 struct partial_die_info *pd = NULL;
72bf9492
DJ
5648
5649 if (offset >= cu->header.offset
5650 && offset < cu->header.offset + cu->header.length)
5afb4e99
DJ
5651 {
5652 pd = find_partial_die_in_comp_unit (offset, cu);
5653 if (pd != NULL)
5654 return pd;
5655 }
72bf9492 5656
ae038cb0
DJ
5657 per_cu = dwarf2_find_containing_comp_unit (offset, cu->objfile);
5658
ae038cb0
DJ
5659 if (per_cu->cu == NULL)
5660 {
5661 load_comp_unit (per_cu, cu->objfile);
5662 per_cu->cu->read_in_chain = dwarf2_per_objfile->read_in_chain;
5663 dwarf2_per_objfile->read_in_chain = per_cu;
5664 }
5665
5666 per_cu->cu->last_used = 0;
5afb4e99
DJ
5667 pd = find_partial_die_in_comp_unit (offset, per_cu->cu);
5668
5669 if (pd == NULL && per_cu->load_all_dies == 0)
5670 {
5671 struct cleanup *back_to;
5672 struct partial_die_info comp_unit_die;
5673 struct abbrev_info *abbrev;
5674 unsigned int bytes_read;
5675 char *info_ptr;
5676
5677 per_cu->load_all_dies = 1;
5678
5679 /* Re-read the DIEs. */
5680 back_to = make_cleanup (null_cleanup, 0);
5681 if (per_cu->cu->dwarf2_abbrevs == NULL)
5682 {
5683 dwarf2_read_abbrevs (per_cu->cu->objfile->obfd, per_cu->cu);
5684 back_to = make_cleanup (dwarf2_free_abbrev_table, per_cu->cu);
5685 }
5686 info_ptr = per_cu->cu->header.first_die_ptr;
5687 abbrev = peek_die_abbrev (info_ptr, &bytes_read, per_cu->cu);
5688 info_ptr = read_partial_die (&comp_unit_die, abbrev, bytes_read,
5689 per_cu->cu->objfile->obfd, info_ptr,
5690 per_cu->cu);
5691 if (comp_unit_die.has_children)
5692 load_partial_dies (per_cu->cu->objfile->obfd, info_ptr, 0, per_cu->cu);
5693 do_cleanups (back_to);
5694
5695 pd = find_partial_die_in_comp_unit (offset, per_cu->cu);
5696 }
5697
5698 if (pd == NULL)
5699 internal_error (__FILE__, __LINE__,
5700 _("could not find partial DIE 0x%lx in cache [from module %s]\n"),
5701 offset, bfd_get_filename (cu->objfile->obfd));
5702 return pd;
72bf9492
DJ
5703}
5704
5705/* Adjust PART_DIE before generating a symbol for it. This function
5706 may set the is_external flag or change the DIE's name. */
5707
5708static void
5709fixup_partial_die (struct partial_die_info *part_die,
5710 struct dwarf2_cu *cu)
5711{
5712 /* If we found a reference attribute and the DIE has no name, try
5713 to find a name in the referred to DIE. */
5714
5715 if (part_die->name == NULL && part_die->has_specification)
5716 {
5717 struct partial_die_info *spec_die;
72bf9492 5718
10b3939b 5719 spec_die = find_partial_die (part_die->spec_offset, cu);
72bf9492 5720
10b3939b 5721 fixup_partial_die (spec_die, cu);
72bf9492
DJ
5722
5723 if (spec_die->name)
5724 {
5725 part_die->name = spec_die->name;
5726
5727 /* Copy DW_AT_external attribute if it is set. */
5728 if (spec_die->is_external)
5729 part_die->is_external = spec_die->is_external;
5730 }
5731 }
5732
5733 /* Set default names for some unnamed DIEs. */
5734 if (part_die->name == NULL && (part_die->tag == DW_TAG_structure_type
5735 || part_die->tag == DW_TAG_class_type))
5736 part_die->name = "(anonymous class)";
5737
5738 if (part_die->name == NULL && part_die->tag == DW_TAG_namespace)
5739 part_die->name = "(anonymous namespace)";
5740
5741 if (part_die->tag == DW_TAG_structure_type
5742 || part_die->tag == DW_TAG_class_type
5743 || part_die->tag == DW_TAG_union_type)
5744 guess_structure_name (part_die, cu);
5745}
5746
639d11d3
DC
5747/* Read the die from the .debug_info section buffer. Set DIEP to
5748 point to a newly allocated die with its information, except for its
5749 child, sibling, and parent fields. Set HAS_CHILDREN to tell
5750 whether the die has children or not. */
c906108c 5751
fe1b8b76
JB
5752static gdb_byte *
5753read_full_die (struct die_info **diep, bfd *abfd, gdb_byte *info_ptr,
e7c27a73 5754 struct dwarf2_cu *cu, int *has_children)
c906108c
SS
5755{
5756 unsigned int abbrev_number, bytes_read, i, offset;
5757 struct abbrev_info *abbrev;
5758 struct die_info *die;
5759
6502dd73 5760 offset = info_ptr - dwarf2_per_objfile->info_buffer;
c906108c
SS
5761 abbrev_number = read_unsigned_leb128 (abfd, info_ptr, &bytes_read);
5762 info_ptr += bytes_read;
5763 if (!abbrev_number)
5764 {
5765 die = dwarf_alloc_die ();
5766 die->tag = 0;
5767 die->abbrev = abbrev_number;
5768 die->type = NULL;
5769 *diep = die;
639d11d3 5770 *has_children = 0;
c906108c
SS
5771 return info_ptr;
5772 }
5773
e7c27a73 5774 abbrev = dwarf2_lookup_abbrev (abbrev_number, cu);
c906108c
SS
5775 if (!abbrev)
5776 {
8a3fe4f8 5777 error (_("Dwarf Error: could not find abbrev number %d [in module %s]"),
72bf9492 5778 abbrev_number,
639d11d3 5779 bfd_get_filename (abfd));
c906108c
SS
5780 }
5781 die = dwarf_alloc_die ();
5782 die->offset = offset;
5783 die->tag = abbrev->tag;
c906108c
SS
5784 die->abbrev = abbrev_number;
5785 die->type = NULL;
5786
5787 die->num_attrs = abbrev->num_attrs;
5788 die->attrs = (struct attribute *)
5789 xmalloc (die->num_attrs * sizeof (struct attribute));
5790
5791 for (i = 0; i < abbrev->num_attrs; ++i)
5792 {
5793 info_ptr = read_attribute (&die->attrs[i], &abbrev->attrs[i],
e7c27a73 5794 abfd, info_ptr, cu);
10b3939b
DJ
5795
5796 /* If this attribute is an absolute reference to a different
5797 compilation unit, make sure that compilation unit is loaded
5798 also. */
5799 if (die->attrs[i].form == DW_FORM_ref_addr
5800 && (DW_ADDR (&die->attrs[i]) < cu->header.offset
5801 || (DW_ADDR (&die->attrs[i])
5802 >= cu->header.offset + cu->header.length)))
5803 {
5804 struct dwarf2_per_cu_data *per_cu;
5805 per_cu = dwarf2_find_containing_comp_unit (DW_ADDR (&die->attrs[i]),
5806 cu->objfile);
5807
5808 /* Mark the dependence relation so that we don't flush PER_CU
5809 too early. */
5810 dwarf2_add_dependence (cu, per_cu);
5811
5812 /* If it's already on the queue, we have nothing to do. */
5813 if (per_cu->queued)
5814 continue;
5815
5816 /* If the compilation unit is already loaded, just mark it as
5817 used. */
5818 if (per_cu->cu != NULL)
5819 {
5820 per_cu->cu->last_used = 0;
5821 continue;
5822 }
5823
5824 /* Add it to the queue. */
5825 queue_comp_unit (per_cu);
5826 }
c906108c
SS
5827 }
5828
5829 *diep = die;
639d11d3 5830 *has_children = abbrev->has_children;
c906108c
SS
5831 return info_ptr;
5832}
5833
a8329558 5834/* Read an attribute value described by an attribute form. */
c906108c 5835
fe1b8b76 5836static gdb_byte *
a8329558 5837read_attribute_value (struct attribute *attr, unsigned form,
fe1b8b76 5838 bfd *abfd, gdb_byte *info_ptr,
e7c27a73 5839 struct dwarf2_cu *cu)
c906108c 5840{
e7c27a73 5841 struct comp_unit_head *cu_header = &cu->header;
c906108c
SS
5842 unsigned int bytes_read;
5843 struct dwarf_block *blk;
5844
a8329558
KW
5845 attr->form = form;
5846 switch (form)
c906108c
SS
5847 {
5848 case DW_FORM_addr:
5849 case DW_FORM_ref_addr:
e7c27a73 5850 DW_ADDR (attr) = read_address (abfd, info_ptr, cu, &bytes_read);
107d2387 5851 info_ptr += bytes_read;
c906108c
SS
5852 break;
5853 case DW_FORM_block2:
7b5a2f43 5854 blk = dwarf_alloc_block (cu);
c906108c
SS
5855 blk->size = read_2_bytes (abfd, info_ptr);
5856 info_ptr += 2;
5857 blk->data = read_n_bytes (abfd, info_ptr, blk->size);
5858 info_ptr += blk->size;
5859 DW_BLOCK (attr) = blk;
5860 break;
5861 case DW_FORM_block4:
7b5a2f43 5862 blk = dwarf_alloc_block (cu);
c906108c
SS
5863 blk->size = read_4_bytes (abfd, info_ptr);
5864 info_ptr += 4;
5865 blk->data = read_n_bytes (abfd, info_ptr, blk->size);
5866 info_ptr += blk->size;
5867 DW_BLOCK (attr) = blk;
5868 break;
5869 case DW_FORM_data2:
5870 DW_UNSND (attr) = read_2_bytes (abfd, info_ptr);
5871 info_ptr += 2;
5872 break;
5873 case DW_FORM_data4:
5874 DW_UNSND (attr) = read_4_bytes (abfd, info_ptr);
5875 info_ptr += 4;
5876 break;
5877 case DW_FORM_data8:
5878 DW_UNSND (attr) = read_8_bytes (abfd, info_ptr);
5879 info_ptr += 8;
5880 break;
5881 case DW_FORM_string:
5882 DW_STRING (attr) = read_string (abfd, info_ptr, &bytes_read);
5883 info_ptr += bytes_read;
5884 break;
4bdf3d34
JJ
5885 case DW_FORM_strp:
5886 DW_STRING (attr) = read_indirect_string (abfd, info_ptr, cu_header,
5887 &bytes_read);
5888 info_ptr += bytes_read;
5889 break;
c906108c 5890 case DW_FORM_block:
7b5a2f43 5891 blk = dwarf_alloc_block (cu);
c906108c
SS
5892 blk->size = read_unsigned_leb128 (abfd, info_ptr, &bytes_read);
5893 info_ptr += bytes_read;
5894 blk->data = read_n_bytes (abfd, info_ptr, blk->size);
5895 info_ptr += blk->size;
5896 DW_BLOCK (attr) = blk;
5897 break;
5898 case DW_FORM_block1:
7b5a2f43 5899 blk = dwarf_alloc_block (cu);
c906108c
SS
5900 blk->size = read_1_byte (abfd, info_ptr);
5901 info_ptr += 1;
5902 blk->data = read_n_bytes (abfd, info_ptr, blk->size);
5903 info_ptr += blk->size;
5904 DW_BLOCK (attr) = blk;
5905 break;
5906 case DW_FORM_data1:
5907 DW_UNSND (attr) = read_1_byte (abfd, info_ptr);
5908 info_ptr += 1;
5909 break;
5910 case DW_FORM_flag:
5911 DW_UNSND (attr) = read_1_byte (abfd, info_ptr);
5912 info_ptr += 1;
5913 break;
5914 case DW_FORM_sdata:
5915 DW_SND (attr) = read_signed_leb128 (abfd, info_ptr, &bytes_read);
5916 info_ptr += bytes_read;
5917 break;
5918 case DW_FORM_udata:
5919 DW_UNSND (attr) = read_unsigned_leb128 (abfd, info_ptr, &bytes_read);
5920 info_ptr += bytes_read;
5921 break;
5922 case DW_FORM_ref1:
10b3939b 5923 DW_ADDR (attr) = cu->header.offset + read_1_byte (abfd, info_ptr);
c906108c
SS
5924 info_ptr += 1;
5925 break;
5926 case DW_FORM_ref2:
10b3939b 5927 DW_ADDR (attr) = cu->header.offset + read_2_bytes (abfd, info_ptr);
c906108c
SS
5928 info_ptr += 2;
5929 break;
5930 case DW_FORM_ref4:
10b3939b 5931 DW_ADDR (attr) = cu->header.offset + read_4_bytes (abfd, info_ptr);
c906108c
SS
5932 info_ptr += 4;
5933 break;
613e1657 5934 case DW_FORM_ref8:
10b3939b 5935 DW_ADDR (attr) = cu->header.offset + read_8_bytes (abfd, info_ptr);
613e1657
KB
5936 info_ptr += 8;
5937 break;
c906108c 5938 case DW_FORM_ref_udata:
10b3939b
DJ
5939 DW_ADDR (attr) = (cu->header.offset
5940 + read_unsigned_leb128 (abfd, info_ptr, &bytes_read));
c906108c
SS
5941 info_ptr += bytes_read;
5942 break;
c906108c 5943 case DW_FORM_indirect:
a8329558
KW
5944 form = read_unsigned_leb128 (abfd, info_ptr, &bytes_read);
5945 info_ptr += bytes_read;
e7c27a73 5946 info_ptr = read_attribute_value (attr, form, abfd, info_ptr, cu);
a8329558 5947 break;
c906108c 5948 default:
8a3fe4f8 5949 error (_("Dwarf Error: Cannot handle %s in DWARF reader [in module %s]"),
659b0389
ML
5950 dwarf_form_name (form),
5951 bfd_get_filename (abfd));
c906108c
SS
5952 }
5953 return info_ptr;
5954}
5955
a8329558
KW
5956/* Read an attribute described by an abbreviated attribute. */
5957
fe1b8b76 5958static gdb_byte *
a8329558 5959read_attribute (struct attribute *attr, struct attr_abbrev *abbrev,
fe1b8b76 5960 bfd *abfd, gdb_byte *info_ptr, struct dwarf2_cu *cu)
a8329558
KW
5961{
5962 attr->name = abbrev->name;
e7c27a73 5963 return read_attribute_value (attr, abbrev->form, abfd, info_ptr, cu);
a8329558
KW
5964}
5965
c906108c
SS
5966/* read dwarf information from a buffer */
5967
5968static unsigned int
fe1b8b76 5969read_1_byte (bfd *abfd, gdb_byte *buf)
c906108c 5970{
fe1b8b76 5971 return bfd_get_8 (abfd, buf);
c906108c
SS
5972}
5973
5974static int
fe1b8b76 5975read_1_signed_byte (bfd *abfd, gdb_byte *buf)
c906108c 5976{
fe1b8b76 5977 return bfd_get_signed_8 (abfd, buf);
c906108c
SS
5978}
5979
5980static unsigned int
fe1b8b76 5981read_2_bytes (bfd *abfd, gdb_byte *buf)
c906108c 5982{
fe1b8b76 5983 return bfd_get_16 (abfd, buf);
c906108c
SS
5984}
5985
5986static int
fe1b8b76 5987read_2_signed_bytes (bfd *abfd, gdb_byte *buf)
c906108c 5988{
fe1b8b76 5989 return bfd_get_signed_16 (abfd, buf);
c906108c
SS
5990}
5991
5992static unsigned int
fe1b8b76 5993read_4_bytes (bfd *abfd, gdb_byte *buf)
c906108c 5994{
fe1b8b76 5995 return bfd_get_32 (abfd, buf);
c906108c
SS
5996}
5997
5998static int
fe1b8b76 5999read_4_signed_bytes (bfd *abfd, gdb_byte *buf)
c906108c 6000{
fe1b8b76 6001 return bfd_get_signed_32 (abfd, buf);
c906108c
SS
6002}
6003
ce5d95e1 6004static unsigned long
fe1b8b76 6005read_8_bytes (bfd *abfd, gdb_byte *buf)
c906108c 6006{
fe1b8b76 6007 return bfd_get_64 (abfd, buf);
c906108c
SS
6008}
6009
6010static CORE_ADDR
fe1b8b76 6011read_address (bfd *abfd, gdb_byte *buf, struct dwarf2_cu *cu,
891d2f0b 6012 unsigned int *bytes_read)
c906108c 6013{
e7c27a73 6014 struct comp_unit_head *cu_header = &cu->header;
c906108c
SS
6015 CORE_ADDR retval = 0;
6016
107d2387 6017 if (cu_header->signed_addr_p)
c906108c 6018 {
107d2387
AC
6019 switch (cu_header->addr_size)
6020 {
6021 case 2:
fe1b8b76 6022 retval = bfd_get_signed_16 (abfd, buf);
107d2387
AC
6023 break;
6024 case 4:
fe1b8b76 6025 retval = bfd_get_signed_32 (abfd, buf);
107d2387
AC
6026 break;
6027 case 8:
fe1b8b76 6028 retval = bfd_get_signed_64 (abfd, buf);
107d2387
AC
6029 break;
6030 default:
8e65ff28 6031 internal_error (__FILE__, __LINE__,
e2e0b3e5 6032 _("read_address: bad switch, signed [in module %s]"),
659b0389 6033 bfd_get_filename (abfd));
107d2387
AC
6034 }
6035 }
6036 else
6037 {
6038 switch (cu_header->addr_size)
6039 {
6040 case 2:
fe1b8b76 6041 retval = bfd_get_16 (abfd, buf);
107d2387
AC
6042 break;
6043 case 4:
fe1b8b76 6044 retval = bfd_get_32 (abfd, buf);
107d2387
AC
6045 break;
6046 case 8:
fe1b8b76 6047 retval = bfd_get_64 (abfd, buf);
107d2387
AC
6048 break;
6049 default:
8e65ff28 6050 internal_error (__FILE__, __LINE__,
e2e0b3e5 6051 _("read_address: bad switch, unsigned [in module %s]"),
659b0389 6052 bfd_get_filename (abfd));
107d2387 6053 }
c906108c 6054 }
64367e0a 6055
107d2387
AC
6056 *bytes_read = cu_header->addr_size;
6057 return retval;
c906108c
SS
6058}
6059
f7ef9339 6060/* Read the initial length from a section. The (draft) DWARF 3
613e1657
KB
6061 specification allows the initial length to take up either 4 bytes
6062 or 12 bytes. If the first 4 bytes are 0xffffffff, then the next 8
6063 bytes describe the length and all offsets will be 8 bytes in length
6064 instead of 4.
6065
f7ef9339
KB
6066 An older, non-standard 64-bit format is also handled by this
6067 function. The older format in question stores the initial length
6068 as an 8-byte quantity without an escape value. Lengths greater
6069 than 2^32 aren't very common which means that the initial 4 bytes
6070 is almost always zero. Since a length value of zero doesn't make
6071 sense for the 32-bit format, this initial zero can be considered to
6072 be an escape value which indicates the presence of the older 64-bit
6073 format. As written, the code can't detect (old format) lengths
917c78fc
MK
6074 greater than 4GB. If it becomes necessary to handle lengths
6075 somewhat larger than 4GB, we could allow other small values (such
6076 as the non-sensical values of 1, 2, and 3) to also be used as
6077 escape values indicating the presence of the old format.
f7ef9339 6078
917c78fc
MK
6079 The value returned via bytes_read should be used to increment the
6080 relevant pointer after calling read_initial_length().
613e1657
KB
6081
6082 As a side effect, this function sets the fields initial_length_size
6083 and offset_size in cu_header to the values appropriate for the
6084 length field. (The format of the initial length field determines
dd373385 6085 the width of file offsets to be fetched later with read_offset().)
613e1657
KB
6086
6087 [ Note: read_initial_length() and read_offset() are based on the
6088 document entitled "DWARF Debugging Information Format", revision
f7ef9339 6089 3, draft 8, dated November 19, 2001. This document was obtained
613e1657
KB
6090 from:
6091
f7ef9339 6092 http://reality.sgiweb.org/davea/dwarf3-draft8-011125.pdf
613e1657
KB
6093
6094 This document is only a draft and is subject to change. (So beware.)
6095
f7ef9339 6096 Details regarding the older, non-standard 64-bit format were
917c78fc
MK
6097 determined empirically by examining 64-bit ELF files produced by
6098 the SGI toolchain on an IRIX 6.5 machine.
f7ef9339
KB
6099
6100 - Kevin, July 16, 2002
613e1657
KB
6101 ] */
6102
6103static LONGEST
fe1b8b76 6104read_initial_length (bfd *abfd, gdb_byte *buf, struct comp_unit_head *cu_header,
891d2f0b 6105 unsigned int *bytes_read)
613e1657 6106{
fe1b8b76 6107 LONGEST length = bfd_get_32 (abfd, buf);
613e1657 6108
dd373385 6109 if (length == 0xffffffff)
613e1657 6110 {
fe1b8b76 6111 length = bfd_get_64 (abfd, buf + 4);
613e1657 6112 *bytes_read = 12;
613e1657 6113 }
dd373385 6114 else if (length == 0)
f7ef9339 6115 {
dd373385 6116 /* Handle the (non-standard) 64-bit DWARF2 format used by IRIX. */
fe1b8b76 6117 length = bfd_get_64 (abfd, buf);
f7ef9339 6118 *bytes_read = 8;
f7ef9339 6119 }
613e1657
KB
6120 else
6121 {
6122 *bytes_read = 4;
613e1657
KB
6123 }
6124
dd373385
EZ
6125 if (cu_header)
6126 {
6127 gdb_assert (cu_header->initial_length_size == 0
6128 || cu_header->initial_length_size == 4
6129 || cu_header->initial_length_size == 8
6130 || cu_header->initial_length_size == 12);
6131
6132 if (cu_header->initial_length_size != 0
6133 && cu_header->initial_length_size != *bytes_read)
6134 complaint (&symfile_complaints,
6135 _("intermixed 32-bit and 64-bit DWARF sections"));
6136
6137 cu_header->initial_length_size = *bytes_read;
6138 cu_header->offset_size = (*bytes_read == 4) ? 4 : 8;
6139 }
6140
6141 return length;
613e1657
KB
6142}
6143
6144/* Read an offset from the data stream. The size of the offset is
917c78fc 6145 given by cu_header->offset_size. */
613e1657
KB
6146
6147static LONGEST
fe1b8b76 6148read_offset (bfd *abfd, gdb_byte *buf, const struct comp_unit_head *cu_header,
891d2f0b 6149 unsigned int *bytes_read)
613e1657
KB
6150{
6151 LONGEST retval = 0;
6152
6153 switch (cu_header->offset_size)
6154 {
6155 case 4:
fe1b8b76 6156 retval = bfd_get_32 (abfd, buf);
613e1657
KB
6157 *bytes_read = 4;
6158 break;
6159 case 8:
fe1b8b76 6160 retval = bfd_get_64 (abfd, buf);
613e1657
KB
6161 *bytes_read = 8;
6162 break;
6163 default:
8e65ff28 6164 internal_error (__FILE__, __LINE__,
e2e0b3e5 6165 _("read_offset: bad switch [in module %s]"),
659b0389 6166 bfd_get_filename (abfd));
613e1657
KB
6167 }
6168
917c78fc 6169 return retval;
613e1657
KB
6170}
6171
fe1b8b76
JB
6172static gdb_byte *
6173read_n_bytes (bfd *abfd, gdb_byte *buf, unsigned int size)
c906108c
SS
6174{
6175 /* If the size of a host char is 8 bits, we can return a pointer
6176 to the buffer, otherwise we have to copy the data to a buffer
6177 allocated on the temporary obstack. */
4bdf3d34 6178 gdb_assert (HOST_CHAR_BIT == 8);
c906108c 6179 return buf;
c906108c
SS
6180}
6181
6182static char *
fe1b8b76 6183read_string (bfd *abfd, gdb_byte *buf, unsigned int *bytes_read_ptr)
c906108c
SS
6184{
6185 /* If the size of a host char is 8 bits, we can return a pointer
6186 to the string, otherwise we have to copy the string to a buffer
6187 allocated on the temporary obstack. */
4bdf3d34 6188 gdb_assert (HOST_CHAR_BIT == 8);
c906108c
SS
6189 if (*buf == '\0')
6190 {
6191 *bytes_read_ptr = 1;
6192 return NULL;
6193 }
fe1b8b76
JB
6194 *bytes_read_ptr = strlen ((char *) buf) + 1;
6195 return (char *) buf;
4bdf3d34
JJ
6196}
6197
6198static char *
fe1b8b76 6199read_indirect_string (bfd *abfd, gdb_byte *buf,
4bdf3d34
JJ
6200 const struct comp_unit_head *cu_header,
6201 unsigned int *bytes_read_ptr)
6202{
6203 LONGEST str_offset = read_offset (abfd, buf, cu_header,
891d2f0b 6204 bytes_read_ptr);
c906108c 6205
6502dd73 6206 if (dwarf2_per_objfile->str_buffer == NULL)
c906108c 6207 {
8a3fe4f8 6208 error (_("DW_FORM_strp used without .debug_str section [in module %s]"),
659b0389 6209 bfd_get_filename (abfd));
4bdf3d34 6210 return NULL;
c906108c 6211 }
6502dd73 6212 if (str_offset >= dwarf2_per_objfile->str_size)
c906108c 6213 {
8a3fe4f8 6214 error (_("DW_FORM_strp pointing outside of .debug_str section [in module %s]"),
659b0389 6215 bfd_get_filename (abfd));
c906108c
SS
6216 return NULL;
6217 }
4bdf3d34 6218 gdb_assert (HOST_CHAR_BIT == 8);
6502dd73 6219 if (dwarf2_per_objfile->str_buffer[str_offset] == '\0')
4bdf3d34 6220 return NULL;
fe1b8b76 6221 return (char *) (dwarf2_per_objfile->str_buffer + str_offset);
c906108c
SS
6222}
6223
ce5d95e1 6224static unsigned long
fe1b8b76 6225read_unsigned_leb128 (bfd *abfd, gdb_byte *buf, unsigned int *bytes_read_ptr)
c906108c 6226{
ce5d95e1
JB
6227 unsigned long result;
6228 unsigned int num_read;
c906108c
SS
6229 int i, shift;
6230 unsigned char byte;
6231
6232 result = 0;
6233 shift = 0;
6234 num_read = 0;
6235 i = 0;
6236 while (1)
6237 {
fe1b8b76 6238 byte = bfd_get_8 (abfd, buf);
c906108c
SS
6239 buf++;
6240 num_read++;
ce5d95e1 6241 result |= ((unsigned long)(byte & 127) << shift);
c906108c
SS
6242 if ((byte & 128) == 0)
6243 {
6244 break;
6245 }
6246 shift += 7;
6247 }
6248 *bytes_read_ptr = num_read;
6249 return result;
6250}
6251
ce5d95e1 6252static long
fe1b8b76 6253read_signed_leb128 (bfd *abfd, gdb_byte *buf, unsigned int *bytes_read_ptr)
c906108c 6254{
ce5d95e1 6255 long result;
77e0b926 6256 int i, shift, num_read;
c906108c
SS
6257 unsigned char byte;
6258
6259 result = 0;
6260 shift = 0;
c906108c
SS
6261 num_read = 0;
6262 i = 0;
6263 while (1)
6264 {
fe1b8b76 6265 byte = bfd_get_8 (abfd, buf);
c906108c
SS
6266 buf++;
6267 num_read++;
ce5d95e1 6268 result |= ((long)(byte & 127) << shift);
c906108c
SS
6269 shift += 7;
6270 if ((byte & 128) == 0)
6271 {
6272 break;
6273 }
6274 }
77e0b926
DJ
6275 if ((shift < 8 * sizeof (result)) && (byte & 0x40))
6276 result |= -(((long)1) << shift);
c906108c
SS
6277 *bytes_read_ptr = num_read;
6278 return result;
6279}
6280
4bb7a0a7
DJ
6281/* Return a pointer to just past the end of an LEB128 number in BUF. */
6282
fe1b8b76
JB
6283static gdb_byte *
6284skip_leb128 (bfd *abfd, gdb_byte *buf)
4bb7a0a7
DJ
6285{
6286 int byte;
6287
6288 while (1)
6289 {
fe1b8b76 6290 byte = bfd_get_8 (abfd, buf);
4bb7a0a7
DJ
6291 buf++;
6292 if ((byte & 128) == 0)
6293 return buf;
6294 }
6295}
6296
c906108c 6297static void
e142c38c 6298set_cu_language (unsigned int lang, struct dwarf2_cu *cu)
c906108c
SS
6299{
6300 switch (lang)
6301 {
6302 case DW_LANG_C89:
6303 case DW_LANG_C:
e142c38c 6304 cu->language = language_c;
c906108c
SS
6305 break;
6306 case DW_LANG_C_plus_plus:
e142c38c 6307 cu->language = language_cplus;
c906108c
SS
6308 break;
6309 case DW_LANG_Fortran77:
6310 case DW_LANG_Fortran90:
b21b22e0 6311 case DW_LANG_Fortran95:
e142c38c 6312 cu->language = language_fortran;
c906108c
SS
6313 break;
6314 case DW_LANG_Mips_Assembler:
e142c38c 6315 cu->language = language_asm;
c906108c 6316 break;
bebd888e 6317 case DW_LANG_Java:
e142c38c 6318 cu->language = language_java;
bebd888e 6319 break;
c906108c 6320 case DW_LANG_Ada83:
8aaf0b47 6321 case DW_LANG_Ada95:
bc5f45f8
JB
6322 cu->language = language_ada;
6323 break;
72019c9c
GM
6324 case DW_LANG_Modula2:
6325 cu->language = language_m2;
6326 break;
c906108c
SS
6327 case DW_LANG_Cobol74:
6328 case DW_LANG_Cobol85:
6329 case DW_LANG_Pascal83:
c906108c 6330 default:
e142c38c 6331 cu->language = language_minimal;
c906108c
SS
6332 break;
6333 }
e142c38c 6334 cu->language_defn = language_def (cu->language);
c906108c
SS
6335}
6336
6337/* Return the named attribute or NULL if not there. */
6338
6339static struct attribute *
e142c38c 6340dwarf2_attr (struct die_info *die, unsigned int name, struct dwarf2_cu *cu)
c906108c
SS
6341{
6342 unsigned int i;
6343 struct attribute *spec = NULL;
6344
6345 for (i = 0; i < die->num_attrs; ++i)
6346 {
6347 if (die->attrs[i].name == name)
10b3939b 6348 return &die->attrs[i];
c906108c
SS
6349 if (die->attrs[i].name == DW_AT_specification
6350 || die->attrs[i].name == DW_AT_abstract_origin)
6351 spec = &die->attrs[i];
6352 }
c906108c 6353
10b3939b
DJ
6354 if (spec)
6355 return dwarf2_attr (follow_die_ref (die, spec, cu), name, cu);
c5aa993b 6356
c906108c
SS
6357 return NULL;
6358}
6359
05cf31d1
JB
6360/* Return non-zero iff the attribute NAME is defined for the given DIE,
6361 and holds a non-zero value. This function should only be used for
6362 DW_FORM_flag attributes. */
6363
6364static int
6365dwarf2_flag_true_p (struct die_info *die, unsigned name, struct dwarf2_cu *cu)
6366{
6367 struct attribute *attr = dwarf2_attr (die, name, cu);
6368
6369 return (attr && DW_UNSND (attr));
6370}
6371
3ca72b44 6372static int
e142c38c 6373die_is_declaration (struct die_info *die, struct dwarf2_cu *cu)
3ca72b44 6374{
05cf31d1
JB
6375 /* A DIE is a declaration if it has a DW_AT_declaration attribute
6376 which value is non-zero. However, we have to be careful with
6377 DIEs having a DW_AT_specification attribute, because dwarf2_attr()
6378 (via dwarf2_flag_true_p) follows this attribute. So we may
6379 end up accidently finding a declaration attribute that belongs
6380 to a different DIE referenced by the specification attribute,
6381 even though the given DIE does not have a declaration attribute. */
6382 return (dwarf2_flag_true_p (die, DW_AT_declaration, cu)
6383 && dwarf2_attr (die, DW_AT_specification, cu) == NULL);
3ca72b44
AC
6384}
6385
63d06c5c
DC
6386/* Return the die giving the specification for DIE, if there is
6387 one. */
6388
6389static struct die_info *
e142c38c 6390die_specification (struct die_info *die, struct dwarf2_cu *cu)
63d06c5c 6391{
e142c38c 6392 struct attribute *spec_attr = dwarf2_attr (die, DW_AT_specification, cu);
63d06c5c
DC
6393
6394 if (spec_attr == NULL)
6395 return NULL;
6396 else
10b3939b 6397 return follow_die_ref (die, spec_attr, cu);
63d06c5c 6398}
c906108c 6399
debd256d
JB
6400/* Free the line_header structure *LH, and any arrays and strings it
6401 refers to. */
6402static void
6403free_line_header (struct line_header *lh)
6404{
6405 if (lh->standard_opcode_lengths)
a8bc7b56 6406 xfree (lh->standard_opcode_lengths);
debd256d
JB
6407
6408 /* Remember that all the lh->file_names[i].name pointers are
6409 pointers into debug_line_buffer, and don't need to be freed. */
6410 if (lh->file_names)
a8bc7b56 6411 xfree (lh->file_names);
debd256d
JB
6412
6413 /* Similarly for the include directory names. */
6414 if (lh->include_dirs)
a8bc7b56 6415 xfree (lh->include_dirs);
debd256d 6416
a8bc7b56 6417 xfree (lh);
debd256d
JB
6418}
6419
6420
6421/* Add an entry to LH's include directory table. */
6422static void
6423add_include_dir (struct line_header *lh, char *include_dir)
c906108c 6424{
debd256d
JB
6425 /* Grow the array if necessary. */
6426 if (lh->include_dirs_size == 0)
c5aa993b 6427 {
debd256d
JB
6428 lh->include_dirs_size = 1; /* for testing */
6429 lh->include_dirs = xmalloc (lh->include_dirs_size
6430 * sizeof (*lh->include_dirs));
6431 }
6432 else if (lh->num_include_dirs >= lh->include_dirs_size)
6433 {
6434 lh->include_dirs_size *= 2;
6435 lh->include_dirs = xrealloc (lh->include_dirs,
6436 (lh->include_dirs_size
6437 * sizeof (*lh->include_dirs)));
c5aa993b 6438 }
c906108c 6439
debd256d
JB
6440 lh->include_dirs[lh->num_include_dirs++] = include_dir;
6441}
6442
6443
6444/* Add an entry to LH's file name table. */
6445static void
6446add_file_name (struct line_header *lh,
6447 char *name,
6448 unsigned int dir_index,
6449 unsigned int mod_time,
6450 unsigned int length)
6451{
6452 struct file_entry *fe;
6453
6454 /* Grow the array if necessary. */
6455 if (lh->file_names_size == 0)
6456 {
6457 lh->file_names_size = 1; /* for testing */
6458 lh->file_names = xmalloc (lh->file_names_size
6459 * sizeof (*lh->file_names));
6460 }
6461 else if (lh->num_file_names >= lh->file_names_size)
6462 {
6463 lh->file_names_size *= 2;
6464 lh->file_names = xrealloc (lh->file_names,
6465 (lh->file_names_size
6466 * sizeof (*lh->file_names)));
6467 }
6468
6469 fe = &lh->file_names[lh->num_file_names++];
6470 fe->name = name;
6471 fe->dir_index = dir_index;
6472 fe->mod_time = mod_time;
6473 fe->length = length;
aaa75496 6474 fe->included_p = 0;
cb1df416 6475 fe->symtab = NULL;
debd256d
JB
6476}
6477
6478
6479/* Read the statement program header starting at OFFSET in
6502dd73
DJ
6480 .debug_line, according to the endianness of ABFD. Return a pointer
6481 to a struct line_header, allocated using xmalloc.
debd256d
JB
6482
6483 NOTE: the strings in the include directory and file name tables of
6484 the returned object point into debug_line_buffer, and must not be
6485 freed. */
6486static struct line_header *
6487dwarf_decode_line_header (unsigned int offset, bfd *abfd,
e7c27a73 6488 struct dwarf2_cu *cu)
debd256d
JB
6489{
6490 struct cleanup *back_to;
6491 struct line_header *lh;
fe1b8b76 6492 gdb_byte *line_ptr;
891d2f0b 6493 unsigned int bytes_read;
debd256d
JB
6494 int i;
6495 char *cur_dir, *cur_file;
6496
6502dd73 6497 if (dwarf2_per_objfile->line_buffer == NULL)
debd256d 6498 {
e2e0b3e5 6499 complaint (&symfile_complaints, _("missing .debug_line section"));
debd256d
JB
6500 return 0;
6501 }
6502
a738430d
MK
6503 /* Make sure that at least there's room for the total_length field.
6504 That could be 12 bytes long, but we're just going to fudge that. */
6502dd73 6505 if (offset + 4 >= dwarf2_per_objfile->line_size)
debd256d 6506 {
4d3c2250 6507 dwarf2_statement_list_fits_in_line_number_section_complaint ();
debd256d
JB
6508 return 0;
6509 }
6510
6511 lh = xmalloc (sizeof (*lh));
6512 memset (lh, 0, sizeof (*lh));
6513 back_to = make_cleanup ((make_cleanup_ftype *) free_line_header,
6514 (void *) lh);
6515
6502dd73 6516 line_ptr = dwarf2_per_objfile->line_buffer + offset;
debd256d 6517
a738430d 6518 /* Read in the header. */
dd373385
EZ
6519 lh->total_length =
6520 read_initial_length (abfd, line_ptr, &cu->header, &bytes_read);
debd256d 6521 line_ptr += bytes_read;
6502dd73
DJ
6522 if (line_ptr + lh->total_length > (dwarf2_per_objfile->line_buffer
6523 + dwarf2_per_objfile->line_size))
debd256d 6524 {
4d3c2250 6525 dwarf2_statement_list_fits_in_line_number_section_complaint ();
debd256d
JB
6526 return 0;
6527 }
6528 lh->statement_program_end = line_ptr + lh->total_length;
6529 lh->version = read_2_bytes (abfd, line_ptr);
6530 line_ptr += 2;
e7c27a73 6531 lh->header_length = read_offset (abfd, line_ptr, &cu->header, &bytes_read);
debd256d
JB
6532 line_ptr += bytes_read;
6533 lh->minimum_instruction_length = read_1_byte (abfd, line_ptr);
6534 line_ptr += 1;
6535 lh->default_is_stmt = read_1_byte (abfd, line_ptr);
6536 line_ptr += 1;
6537 lh->line_base = read_1_signed_byte (abfd, line_ptr);
6538 line_ptr += 1;
6539 lh->line_range = read_1_byte (abfd, line_ptr);
6540 line_ptr += 1;
6541 lh->opcode_base = read_1_byte (abfd, line_ptr);
6542 line_ptr += 1;
6543 lh->standard_opcode_lengths
fe1b8b76 6544 = xmalloc (lh->opcode_base * sizeof (lh->standard_opcode_lengths[0]));
debd256d
JB
6545
6546 lh->standard_opcode_lengths[0] = 1; /* This should never be used anyway. */
6547 for (i = 1; i < lh->opcode_base; ++i)
6548 {
6549 lh->standard_opcode_lengths[i] = read_1_byte (abfd, line_ptr);
6550 line_ptr += 1;
6551 }
6552
a738430d 6553 /* Read directory table. */
debd256d
JB
6554 while ((cur_dir = read_string (abfd, line_ptr, &bytes_read)) != NULL)
6555 {
6556 line_ptr += bytes_read;
6557 add_include_dir (lh, cur_dir);
6558 }
6559 line_ptr += bytes_read;
6560
a738430d 6561 /* Read file name table. */
debd256d
JB
6562 while ((cur_file = read_string (abfd, line_ptr, &bytes_read)) != NULL)
6563 {
6564 unsigned int dir_index, mod_time, length;
6565
6566 line_ptr += bytes_read;
6567 dir_index = read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
6568 line_ptr += bytes_read;
6569 mod_time = read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
6570 line_ptr += bytes_read;
6571 length = read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
6572 line_ptr += bytes_read;
6573
6574 add_file_name (lh, cur_file, dir_index, mod_time, length);
6575 }
6576 line_ptr += bytes_read;
6577 lh->statement_program_start = line_ptr;
6578
6502dd73
DJ
6579 if (line_ptr > (dwarf2_per_objfile->line_buffer
6580 + dwarf2_per_objfile->line_size))
4d3c2250 6581 complaint (&symfile_complaints,
e2e0b3e5 6582 _("line number info header doesn't fit in `.debug_line' section"));
debd256d
JB
6583
6584 discard_cleanups (back_to);
6585 return lh;
6586}
c906108c 6587
5fb290d7
DJ
6588/* This function exists to work around a bug in certain compilers
6589 (particularly GCC 2.95), in which the first line number marker of a
6590 function does not show up until after the prologue, right before
6591 the second line number marker. This function shifts ADDRESS down
6592 to the beginning of the function if necessary, and is called on
6593 addresses passed to record_line. */
6594
6595static CORE_ADDR
e142c38c 6596check_cu_functions (CORE_ADDR address, struct dwarf2_cu *cu)
5fb290d7
DJ
6597{
6598 struct function_range *fn;
6599
6600 /* Find the function_range containing address. */
e142c38c 6601 if (!cu->first_fn)
5fb290d7
DJ
6602 return address;
6603
e142c38c
DJ
6604 if (!cu->cached_fn)
6605 cu->cached_fn = cu->first_fn;
5fb290d7 6606
e142c38c 6607 fn = cu->cached_fn;
5fb290d7
DJ
6608 while (fn)
6609 if (fn->lowpc <= address && fn->highpc > address)
6610 goto found;
6611 else
6612 fn = fn->next;
6613
e142c38c
DJ
6614 fn = cu->first_fn;
6615 while (fn && fn != cu->cached_fn)
5fb290d7
DJ
6616 if (fn->lowpc <= address && fn->highpc > address)
6617 goto found;
6618 else
6619 fn = fn->next;
6620
6621 return address;
6622
6623 found:
6624 if (fn->seen_line)
6625 return address;
6626 if (address != fn->lowpc)
4d3c2250 6627 complaint (&symfile_complaints,
e2e0b3e5 6628 _("misplaced first line number at 0x%lx for '%s'"),
4d3c2250 6629 (unsigned long) address, fn->name);
5fb290d7
DJ
6630 fn->seen_line = 1;
6631 return fn->lowpc;
6632}
6633
aaa75496
JB
6634/* Decode the Line Number Program (LNP) for the given line_header
6635 structure and CU. The actual information extracted and the type
6636 of structures created from the LNP depends on the value of PST.
6637
6638 1. If PST is NULL, then this procedure uses the data from the program
6639 to create all necessary symbol tables, and their linetables.
6640 The compilation directory of the file is passed in COMP_DIR,
6641 and must not be NULL.
6642
6643 2. If PST is not NULL, this procedure reads the program to determine
6644 the list of files included by the unit represented by PST, and
6645 builds all the associated partial symbol tables. In this case,
6646 the value of COMP_DIR is ignored, and can thus be NULL (the COMP_DIR
6647 is not used to compute the full name of the symtab, and therefore
6648 omitting it when building the partial symtab does not introduce
6649 the potential for inconsistency - a partial symtab and its associated
6650 symbtab having a different fullname -). */
debd256d 6651
c906108c 6652static void
debd256d 6653dwarf_decode_lines (struct line_header *lh, char *comp_dir, bfd *abfd,
aaa75496 6654 struct dwarf2_cu *cu, struct partial_symtab *pst)
c906108c 6655{
fe1b8b76
JB
6656 gdb_byte *line_ptr;
6657 gdb_byte *line_end;
e7c27a73 6658 unsigned int bytes_read;
c906108c 6659 unsigned char op_code, extended_op, adj_opcode;
e142c38c
DJ
6660 CORE_ADDR baseaddr;
6661 struct objfile *objfile = cu->objfile;
aaa75496 6662 const int decode_for_pst_p = (pst != NULL);
cb1df416 6663 struct subfile *last_subfile = NULL, *first_subfile = current_subfile;
e142c38c
DJ
6664
6665 baseaddr = ANOFFSET (objfile->section_offsets, SECT_OFF_TEXT (objfile));
c906108c 6666
debd256d
JB
6667 line_ptr = lh->statement_program_start;
6668 line_end = lh->statement_program_end;
c906108c
SS
6669
6670 /* Read the statement sequences until there's nothing left. */
6671 while (line_ptr < line_end)
6672 {
6673 /* state machine registers */
6674 CORE_ADDR address = 0;
6675 unsigned int file = 1;
6676 unsigned int line = 1;
6677 unsigned int column = 0;
debd256d 6678 int is_stmt = lh->default_is_stmt;
c906108c
SS
6679 int basic_block = 0;
6680 int end_sequence = 0;
6681
aaa75496 6682 if (!decode_for_pst_p && lh->num_file_names >= file)
c906108c 6683 {
aaa75496 6684 /* Start a subfile for the current file of the state machine. */
debd256d
JB
6685 /* lh->include_dirs and lh->file_names are 0-based, but the
6686 directory and file name numbers in the statement program
6687 are 1-based. */
6688 struct file_entry *fe = &lh->file_names[file - 1];
4f1520fb 6689 char *dir = NULL;
a738430d 6690
debd256d
JB
6691 if (fe->dir_index)
6692 dir = lh->include_dirs[fe->dir_index - 1];
4f1520fb
FR
6693
6694 dwarf2_start_subfile (fe->name, dir, comp_dir);
c906108c
SS
6695 }
6696
a738430d 6697 /* Decode the table. */
c5aa993b 6698 while (!end_sequence)
c906108c
SS
6699 {
6700 op_code = read_1_byte (abfd, line_ptr);
6701 line_ptr += 1;
9aa1fe7e 6702
debd256d 6703 if (op_code >= lh->opcode_base)
a738430d
MK
6704 {
6705 /* Special operand. */
debd256d
JB
6706 adj_opcode = op_code - lh->opcode_base;
6707 address += (adj_opcode / lh->line_range)
6708 * lh->minimum_instruction_length;
6709 line += lh->line_base + (adj_opcode % lh->line_range);
aa495d11 6710 lh->file_names[file - 1].included_p = 1;
aaa75496
JB
6711 if (!decode_for_pst_p)
6712 {
366da635
DJ
6713 if (last_subfile != current_subfile)
6714 {
6715 if (last_subfile)
6716 record_line (last_subfile, 0, address);
6717 last_subfile = current_subfile;
6718 }
a738430d 6719 /* Append row to matrix using current values. */
aaa75496
JB
6720 record_line (current_subfile, line,
6721 check_cu_functions (address, cu));
6722 }
9aa1fe7e
GK
6723 basic_block = 1;
6724 }
6725 else switch (op_code)
c906108c
SS
6726 {
6727 case DW_LNS_extended_op:
473b7be6
DJ
6728 read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
6729 line_ptr += bytes_read;
c906108c
SS
6730 extended_op = read_1_byte (abfd, line_ptr);
6731 line_ptr += 1;
6732 switch (extended_op)
6733 {
6734 case DW_LNE_end_sequence:
6735 end_sequence = 1;
aa495d11 6736 lh->file_names[file - 1].included_p = 1;
aaa75496
JB
6737 if (!decode_for_pst_p)
6738 record_line (current_subfile, 0, address);
c906108c
SS
6739 break;
6740 case DW_LNE_set_address:
e7c27a73 6741 address = read_address (abfd, line_ptr, cu, &bytes_read);
107d2387
AC
6742 line_ptr += bytes_read;
6743 address += baseaddr;
c906108c
SS
6744 break;
6745 case DW_LNE_define_file:
debd256d
JB
6746 {
6747 char *cur_file;
6748 unsigned int dir_index, mod_time, length;
6749
6750 cur_file = read_string (abfd, line_ptr, &bytes_read);
6751 line_ptr += bytes_read;
6752 dir_index =
6753 read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
6754 line_ptr += bytes_read;
6755 mod_time =
6756 read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
6757 line_ptr += bytes_read;
6758 length =
6759 read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
6760 line_ptr += bytes_read;
6761 add_file_name (lh, cur_file, dir_index, mod_time, length);
6762 }
c906108c
SS
6763 break;
6764 default:
4d3c2250 6765 complaint (&symfile_complaints,
e2e0b3e5 6766 _("mangled .debug_line section"));
debd256d 6767 return;
c906108c
SS
6768 }
6769 break;
6770 case DW_LNS_copy:
aa495d11 6771 lh->file_names[file - 1].included_p = 1;
aaa75496 6772 if (!decode_for_pst_p)
366da635
DJ
6773 {
6774 if (last_subfile != current_subfile)
6775 {
6776 if (last_subfile)
6777 record_line (last_subfile, 0, address);
6778 last_subfile = current_subfile;
6779 }
6780 record_line (current_subfile, line,
6781 check_cu_functions (address, cu));
6782 }
c906108c
SS
6783 basic_block = 0;
6784 break;
6785 case DW_LNS_advance_pc:
debd256d 6786 address += lh->minimum_instruction_length
c906108c
SS
6787 * read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
6788 line_ptr += bytes_read;
6789 break;
6790 case DW_LNS_advance_line:
6791 line += read_signed_leb128 (abfd, line_ptr, &bytes_read);
6792 line_ptr += bytes_read;
6793 break;
6794 case DW_LNS_set_file:
debd256d 6795 {
a738430d
MK
6796 /* The arrays lh->include_dirs and lh->file_names are
6797 0-based, but the directory and file name numbers in
6798 the statement program are 1-based. */
debd256d 6799 struct file_entry *fe;
4f1520fb 6800 char *dir = NULL;
a738430d 6801
debd256d
JB
6802 file = read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
6803 line_ptr += bytes_read;
6804 fe = &lh->file_names[file - 1];
6805 if (fe->dir_index)
6806 dir = lh->include_dirs[fe->dir_index - 1];
4f1520fb 6807
aaa75496 6808 if (!decode_for_pst_p)
366da635
DJ
6809 {
6810 last_subfile = current_subfile;
6811 dwarf2_start_subfile (fe->name, dir, comp_dir);
6812 }
debd256d 6813 }
c906108c
SS
6814 break;
6815 case DW_LNS_set_column:
6816 column = read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
6817 line_ptr += bytes_read;
6818 break;
6819 case DW_LNS_negate_stmt:
6820 is_stmt = (!is_stmt);
6821 break;
6822 case DW_LNS_set_basic_block:
6823 basic_block = 1;
6824 break;
c2c6d25f
JM
6825 /* Add to the address register of the state machine the
6826 address increment value corresponding to special opcode
a738430d
MK
6827 255. I.e., this value is scaled by the minimum
6828 instruction length since special opcode 255 would have
6829 scaled the the increment. */
c906108c 6830 case DW_LNS_const_add_pc:
debd256d
JB
6831 address += (lh->minimum_instruction_length
6832 * ((255 - lh->opcode_base) / lh->line_range));
c906108c
SS
6833 break;
6834 case DW_LNS_fixed_advance_pc:
6835 address += read_2_bytes (abfd, line_ptr);
6836 line_ptr += 2;
6837 break;
9aa1fe7e 6838 default:
a738430d
MK
6839 {
6840 /* Unknown standard opcode, ignore it. */
9aa1fe7e 6841 int i;
a738430d 6842
debd256d 6843 for (i = 0; i < lh->standard_opcode_lengths[op_code]; i++)
9aa1fe7e
GK
6844 {
6845 (void) read_unsigned_leb128 (abfd, line_ptr, &bytes_read);
6846 line_ptr += bytes_read;
6847 }
6848 }
c906108c
SS
6849 }
6850 }
6851 }
aaa75496
JB
6852
6853 if (decode_for_pst_p)
6854 {
6855 int file_index;
6856
6857 /* Now that we're done scanning the Line Header Program, we can
6858 create the psymtab of each included file. */
6859 for (file_index = 0; file_index < lh->num_file_names; file_index++)
6860 if (lh->file_names[file_index].included_p == 1)
6861 {
5b5464ad
JB
6862 const struct file_entry fe = lh->file_names [file_index];
6863 char *include_name = fe.name;
6864 char *dir_name = NULL;
6865 char *pst_filename = pst->filename;
6866
6867 if (fe.dir_index)
6868 dir_name = lh->include_dirs[fe.dir_index - 1];
6869
6870 if (!IS_ABSOLUTE_PATH (include_name) && dir_name != NULL)
6871 {
1754f103
MK
6872 include_name = concat (dir_name, SLASH_STRING,
6873 include_name, (char *)NULL);
5b5464ad
JB
6874 make_cleanup (xfree, include_name);
6875 }
6876
6877 if (!IS_ABSOLUTE_PATH (pst_filename) && pst->dirname != NULL)
6878 {
1754f103
MK
6879 pst_filename = concat (pst->dirname, SLASH_STRING,
6880 pst_filename, (char *)NULL);
5b5464ad
JB
6881 make_cleanup (xfree, pst_filename);
6882 }
6883
6884 if (strcmp (include_name, pst_filename) != 0)
aaa75496
JB
6885 dwarf2_create_include_psymtab (include_name, pst, objfile);
6886 }
6887 }
cb1df416
DJ
6888 else
6889 {
6890 /* Make sure a symtab is created for every file, even files
6891 which contain only variables (i.e. no code with associated
6892 line numbers). */
6893
6894 int i;
6895 struct file_entry *fe;
6896
6897 for (i = 0; i < lh->num_file_names; i++)
6898 {
6899 char *dir = NULL;
6900 fe = &lh->file_names[i];
6901 if (fe->dir_index)
6902 dir = lh->include_dirs[fe->dir_index - 1];
6903 dwarf2_start_subfile (fe->name, dir, comp_dir);
6904
6905 /* Skip the main file; we don't need it, and it must be
6906 allocated last, so that it will show up before the
6907 non-primary symtabs in the objfile's symtab list. */
6908 if (current_subfile == first_subfile)
6909 continue;
6910
6911 if (current_subfile->symtab == NULL)
6912 current_subfile->symtab = allocate_symtab (current_subfile->name,
6913 cu->objfile);
6914 fe->symtab = current_subfile->symtab;
6915 }
6916 }
c906108c
SS
6917}
6918
6919/* Start a subfile for DWARF. FILENAME is the name of the file and
6920 DIRNAME the name of the source directory which contains FILENAME
4f1520fb
FR
6921 or NULL if not known. COMP_DIR is the compilation directory for the
6922 linetable's compilation unit or NULL if not known.
c906108c
SS
6923 This routine tries to keep line numbers from identical absolute and
6924 relative file names in a common subfile.
6925
6926 Using the `list' example from the GDB testsuite, which resides in
6927 /srcdir and compiling it with Irix6.2 cc in /compdir using a filename
6928 of /srcdir/list0.c yields the following debugging information for list0.c:
6929
c5aa993b
JM
6930 DW_AT_name: /srcdir/list0.c
6931 DW_AT_comp_dir: /compdir
357e46e7 6932 files.files[0].name: list0.h
c5aa993b 6933 files.files[0].dir: /srcdir
357e46e7 6934 files.files[1].name: list0.c
c5aa993b 6935 files.files[1].dir: /srcdir
c906108c
SS
6936
6937 The line number information for list0.c has to end up in a single
4f1520fb
FR
6938 subfile, so that `break /srcdir/list0.c:1' works as expected.
6939 start_subfile will ensure that this happens provided that we pass the
6940 concatenation of files.files[1].dir and files.files[1].name as the
6941 subfile's name. */
c906108c
SS
6942
6943static void
4f1520fb 6944dwarf2_start_subfile (char *filename, char *dirname, char *comp_dir)
c906108c 6945{
4f1520fb
FR
6946 char *fullname;
6947
6948 /* While reading the DIEs, we call start_symtab(DW_AT_name, DW_AT_comp_dir).
6949 `start_symtab' will always pass the contents of DW_AT_comp_dir as
6950 second argument to start_subfile. To be consistent, we do the
6951 same here. In order not to lose the line information directory,
6952 we concatenate it to the filename when it makes sense.
6953 Note that the Dwarf3 standard says (speaking of filenames in line
6954 information): ``The directory index is ignored for file names
6955 that represent full path names''. Thus ignoring dirname in the
6956 `else' branch below isn't an issue. */
c906108c 6957
d5166ae1 6958 if (!IS_ABSOLUTE_PATH (filename) && dirname != NULL)
4f1520fb
FR
6959 fullname = concat (dirname, SLASH_STRING, filename, (char *)NULL);
6960 else
6961 fullname = filename;
c906108c 6962
4f1520fb
FR
6963 start_subfile (fullname, comp_dir);
6964
6965 if (fullname != filename)
6966 xfree (fullname);
c906108c
SS
6967}
6968
4c2df51b
DJ
6969static void
6970var_decode_location (struct attribute *attr, struct symbol *sym,
e7c27a73 6971 struct dwarf2_cu *cu)
4c2df51b 6972{
e7c27a73
DJ
6973 struct objfile *objfile = cu->objfile;
6974 struct comp_unit_head *cu_header = &cu->header;
6975
4c2df51b
DJ
6976 /* NOTE drow/2003-01-30: There used to be a comment and some special
6977 code here to turn a symbol with DW_AT_external and a
6978 SYMBOL_VALUE_ADDRESS of 0 into a LOC_UNRESOLVED symbol. This was
6979 necessary for platforms (maybe Alpha, certainly PowerPC GNU/Linux
6980 with some versions of binutils) where shared libraries could have
6981 relocations against symbols in their debug information - the
6982 minimal symbol would have the right address, but the debug info
6983 would not. It's no longer necessary, because we will explicitly
6984 apply relocations when we read in the debug information now. */
6985
6986 /* A DW_AT_location attribute with no contents indicates that a
6987 variable has been optimized away. */
6988 if (attr_form_is_block (attr) && DW_BLOCK (attr)->size == 0)
6989 {
6990 SYMBOL_CLASS (sym) = LOC_OPTIMIZED_OUT;
6991 return;
6992 }
6993
6994 /* Handle one degenerate form of location expression specially, to
6995 preserve GDB's previous behavior when section offsets are
6996 specified. If this is just a DW_OP_addr then mark this symbol
6997 as LOC_STATIC. */
6998
6999 if (attr_form_is_block (attr)
7000 && DW_BLOCK (attr)->size == 1 + cu_header->addr_size
7001 && DW_BLOCK (attr)->data[0] == DW_OP_addr)
7002 {
891d2f0b 7003 unsigned int dummy;
4c2df51b
DJ
7004
7005 SYMBOL_VALUE_ADDRESS (sym) =
e7c27a73 7006 read_address (objfile->obfd, DW_BLOCK (attr)->data + 1, cu, &dummy);
4c2df51b
DJ
7007 fixup_symbol_section (sym, objfile);
7008 SYMBOL_VALUE_ADDRESS (sym) += ANOFFSET (objfile->section_offsets,
7009 SYMBOL_SECTION (sym));
7010 SYMBOL_CLASS (sym) = LOC_STATIC;
7011 return;
7012 }
7013
7014 /* NOTE drow/2002-01-30: It might be worthwhile to have a static
7015 expression evaluator, and use LOC_COMPUTED only when necessary
7016 (i.e. when the value of a register or memory location is
7017 referenced, or a thread-local block, etc.). Then again, it might
7018 not be worthwhile. I'm assuming that it isn't unless performance
7019 or memory numbers show me otherwise. */
7020
e7c27a73 7021 dwarf2_symbol_mark_computed (attr, sym, cu);
4c2df51b
DJ
7022 SYMBOL_CLASS (sym) = LOC_COMPUTED;
7023}
7024
c906108c
SS
7025/* Given a pointer to a DWARF information entry, figure out if we need
7026 to make a symbol table entry for it, and if so, create a new entry
7027 and return a pointer to it.
7028 If TYPE is NULL, determine symbol type from the die, otherwise
2df3850c 7029 used the passed type. */
c906108c
SS
7030
7031static struct symbol *
e7c27a73 7032new_symbol (struct die_info *die, struct type *type, struct dwarf2_cu *cu)
c906108c 7033{
e7c27a73 7034 struct objfile *objfile = cu->objfile;
c906108c
SS
7035 struct symbol *sym = NULL;
7036 char *name;
7037 struct attribute *attr = NULL;
7038 struct attribute *attr2 = NULL;
e142c38c
DJ
7039 CORE_ADDR baseaddr;
7040
7041 baseaddr = ANOFFSET (objfile->section_offsets, SECT_OFF_TEXT (objfile));
c906108c 7042
5c4e30ca 7043 if (die->tag != DW_TAG_namespace)
e142c38c 7044 name = dwarf2_linkage_name (die, cu);
5c4e30ca
DC
7045 else
7046 name = TYPE_NAME (type);
7047
c906108c
SS
7048 if (name)
7049 {
4a146b47 7050 sym = (struct symbol *) obstack_alloc (&objfile->objfile_obstack,
c906108c
SS
7051 sizeof (struct symbol));
7052 OBJSTAT (objfile, n_syms++);
7053 memset (sym, 0, sizeof (struct symbol));
2de7ced7
DJ
7054
7055 /* Cache this symbol's name and the name's demangled form (if any). */
e142c38c 7056 SYMBOL_LANGUAGE (sym) = cu->language;
2de7ced7 7057 SYMBOL_SET_NAMES (sym, name, strlen (name), objfile);
c906108c
SS
7058
7059 /* Default assumptions.
c5aa993b 7060 Use the passed type or decode it from the die. */
176620f1 7061 SYMBOL_DOMAIN (sym) = VAR_DOMAIN;
875dc2fc 7062 SYMBOL_CLASS (sym) = LOC_OPTIMIZED_OUT;
c906108c
SS
7063 if (type != NULL)
7064 SYMBOL_TYPE (sym) = type;
7065 else
e7c27a73 7066 SYMBOL_TYPE (sym) = die_type (die, cu);
e142c38c 7067 attr = dwarf2_attr (die, DW_AT_decl_line, cu);
c906108c
SS
7068 if (attr)
7069 {
7070 SYMBOL_LINE (sym) = DW_UNSND (attr);
7071 }
cb1df416
DJ
7072
7073 attr = dwarf2_attr (die, DW_AT_decl_file, cu);
7074 if (attr)
7075 {
7076 int file_index = DW_UNSND (attr);
7077 if (cu->line_header == NULL
7078 || file_index > cu->line_header->num_file_names)
7079 complaint (&symfile_complaints,
7080 _("file index out of range"));
7081 else
7082 {
7083 struct file_entry *fe;
7084 fe = &cu->line_header->file_names[file_index - 1];
7085 SYMBOL_SYMTAB (sym) = fe->symtab;
7086 }
7087 }
7088
c906108c
SS
7089 switch (die->tag)
7090 {
7091 case DW_TAG_label:
e142c38c 7092 attr = dwarf2_attr (die, DW_AT_low_pc, cu);
c906108c
SS
7093 if (attr)
7094 {
7095 SYMBOL_VALUE_ADDRESS (sym) = DW_ADDR (attr) + baseaddr;
7096 }
7097 SYMBOL_CLASS (sym) = LOC_LABEL;
7098 break;
7099 case DW_TAG_subprogram:
7100 /* SYMBOL_BLOCK_VALUE (sym) will be filled in later by
7101 finish_block. */
7102 SYMBOL_CLASS (sym) = LOC_BLOCK;
e142c38c 7103 attr2 = dwarf2_attr (die, DW_AT_external, cu);
c906108c
SS
7104 if (attr2 && (DW_UNSND (attr2) != 0))
7105 {
7106 add_symbol_to_list (sym, &global_symbols);
7107 }
7108 else
7109 {
e142c38c 7110 add_symbol_to_list (sym, cu->list_in_scope);
c906108c
SS
7111 }
7112 break;
7113 case DW_TAG_variable:
7114 /* Compilation with minimal debug info may result in variables
7115 with missing type entries. Change the misleading `void' type
7116 to something sensible. */
7117 if (TYPE_CODE (SYMBOL_TYPE (sym)) == TYPE_CODE_VOID)
7118 SYMBOL_TYPE (sym) = init_type (TYPE_CODE_INT,
7119 TARGET_INT_BIT / HOST_CHAR_BIT, 0,
7120 "<variable, no debug info>",
7121 objfile);
e142c38c 7122 attr = dwarf2_attr (die, DW_AT_const_value, cu);
c906108c
SS
7123 if (attr)
7124 {
e7c27a73 7125 dwarf2_const_value (attr, sym, cu);
e142c38c 7126 attr2 = dwarf2_attr (die, DW_AT_external, cu);
c906108c
SS
7127 if (attr2 && (DW_UNSND (attr2) != 0))
7128 add_symbol_to_list (sym, &global_symbols);
7129 else
e142c38c 7130 add_symbol_to_list (sym, cu->list_in_scope);
c906108c
SS
7131 break;
7132 }
e142c38c 7133 attr = dwarf2_attr (die, DW_AT_location, cu);
c906108c
SS
7134 if (attr)
7135 {
e7c27a73 7136 var_decode_location (attr, sym, cu);
e142c38c 7137 attr2 = dwarf2_attr (die, DW_AT_external, cu);
c906108c 7138 if (attr2 && (DW_UNSND (attr2) != 0))
4c2df51b 7139 add_symbol_to_list (sym, &global_symbols);
c906108c 7140 else
e142c38c 7141 add_symbol_to_list (sym, cu->list_in_scope);
c906108c
SS
7142 }
7143 else
7144 {
7145 /* We do not know the address of this symbol.
c5aa993b
JM
7146 If it is an external symbol and we have type information
7147 for it, enter the symbol as a LOC_UNRESOLVED symbol.
7148 The address of the variable will then be determined from
7149 the minimal symbol table whenever the variable is
7150 referenced. */
e142c38c 7151 attr2 = dwarf2_attr (die, DW_AT_external, cu);
c906108c 7152 if (attr2 && (DW_UNSND (attr2) != 0)
e142c38c 7153 && dwarf2_attr (die, DW_AT_type, cu) != NULL)
c906108c
SS
7154 {
7155 SYMBOL_CLASS (sym) = LOC_UNRESOLVED;
7156 add_symbol_to_list (sym, &global_symbols);
7157 }
7158 }
7159 break;
7160 case DW_TAG_formal_parameter:
e142c38c 7161 attr = dwarf2_attr (die, DW_AT_location, cu);
c906108c
SS
7162 if (attr)
7163 {
e7c27a73 7164 var_decode_location (attr, sym, cu);
7cf6e574
DJ
7165 /* FIXME drow/2003-07-31: Is LOC_COMPUTED_ARG necessary? */
7166 if (SYMBOL_CLASS (sym) == LOC_COMPUTED)
7167 SYMBOL_CLASS (sym) = LOC_COMPUTED_ARG;
c906108c 7168 }
e142c38c 7169 attr = dwarf2_attr (die, DW_AT_const_value, cu);
c906108c
SS
7170 if (attr)
7171 {
e7c27a73 7172 dwarf2_const_value (attr, sym, cu);
c906108c 7173 }
e142c38c 7174 add_symbol_to_list (sym, cu->list_in_scope);
c906108c
SS
7175 break;
7176 case DW_TAG_unspecified_parameters:
7177 /* From varargs functions; gdb doesn't seem to have any
7178 interest in this information, so just ignore it for now.
7179 (FIXME?) */
7180 break;
7181 case DW_TAG_class_type:
7182 case DW_TAG_structure_type:
7183 case DW_TAG_union_type:
72019c9c 7184 case DW_TAG_set_type:
c906108c
SS
7185 case DW_TAG_enumeration_type:
7186 SYMBOL_CLASS (sym) = LOC_TYPEDEF;
176620f1 7187 SYMBOL_DOMAIN (sym) = STRUCT_DOMAIN;
c906108c 7188
63d06c5c
DC
7189 /* Make sure that the symbol includes appropriate enclosing
7190 classes/namespaces in its name. These are calculated in
134d01f1 7191 read_structure_type, and the correct name is saved in
63d06c5c
DC
7192 the type. */
7193
987504bb
JJ
7194 if (cu->language == language_cplus
7195 || cu->language == language_java)
c906108c 7196 {
63d06c5c
DC
7197 struct type *type = SYMBOL_TYPE (sym);
7198
7199 if (TYPE_TAG_NAME (type) != NULL)
7200 {
7201 /* FIXME: carlton/2003-11-10: Should this use
7202 SYMBOL_SET_NAMES instead? (The same problem also
d8151005
DJ
7203 arises further down in this function.) */
7204 /* The type's name is already allocated along with
7205 this objfile, so we don't need to duplicate it
7206 for the symbol. */
7207 SYMBOL_LINKAGE_NAME (sym) = TYPE_TAG_NAME (type);
63d06c5c 7208 }
c906108c 7209 }
63d06c5c
DC
7210
7211 {
987504bb 7212 /* NOTE: carlton/2003-11-10: C++ and Java class symbols shouldn't
63d06c5c
DC
7213 really ever be static objects: otherwise, if you try
7214 to, say, break of a class's method and you're in a file
7215 which doesn't mention that class, it won't work unless
7216 the check for all static symbols in lookup_symbol_aux
7217 saves you. See the OtherFileClass tests in
7218 gdb.c++/namespace.exp. */
7219
7220 struct pending **list_to_add;
7221
e142c38c 7222 list_to_add = (cu->list_in_scope == &file_symbols
987504bb
JJ
7223 && (cu->language == language_cplus
7224 || cu->language == language_java)
e142c38c 7225 ? &global_symbols : cu->list_in_scope);
63d06c5c
DC
7226
7227 add_symbol_to_list (sym, list_to_add);
7228
7229 /* The semantics of C++ state that "struct foo { ... }" also
987504bb
JJ
7230 defines a typedef for "foo". A Java class declaration also
7231 defines a typedef for the class. Synthesize a typedef symbol
7232 so that "ptype foo" works as expected. */
7233 if (cu->language == language_cplus
7234 || cu->language == language_java)
63d06c5c
DC
7235 {
7236 struct symbol *typedef_sym = (struct symbol *)
4a146b47 7237 obstack_alloc (&objfile->objfile_obstack,
63d06c5c
DC
7238 sizeof (struct symbol));
7239 *typedef_sym = *sym;
7240 SYMBOL_DOMAIN (typedef_sym) = VAR_DOMAIN;
d8151005
DJ
7241 /* The symbol's name is already allocated along with
7242 this objfile, so we don't need to duplicate it for
7243 the type. */
63d06c5c 7244 if (TYPE_NAME (SYMBOL_TYPE (sym)) == 0)
77ef991d 7245 TYPE_NAME (SYMBOL_TYPE (sym)) = SYMBOL_SEARCH_NAME (sym);
63d06c5c
DC
7246 add_symbol_to_list (typedef_sym, list_to_add);
7247 }
7248 }
c906108c
SS
7249 break;
7250 case DW_TAG_typedef:
63d06c5c
DC
7251 if (processing_has_namespace_info
7252 && processing_current_prefix[0] != '\0')
7253 {
987504bb
JJ
7254 SYMBOL_LINKAGE_NAME (sym) = typename_concat (&objfile->objfile_obstack,
7255 processing_current_prefix,
7256 name, cu);
63d06c5c
DC
7257 }
7258 SYMBOL_CLASS (sym) = LOC_TYPEDEF;
7259 SYMBOL_DOMAIN (sym) = VAR_DOMAIN;
e142c38c 7260 add_symbol_to_list (sym, cu->list_in_scope);
63d06c5c 7261 break;
c906108c 7262 case DW_TAG_base_type:
a02abb62 7263 case DW_TAG_subrange_type:
c906108c 7264 SYMBOL_CLASS (sym) = LOC_TYPEDEF;
176620f1 7265 SYMBOL_DOMAIN (sym) = VAR_DOMAIN;
e142c38c 7266 add_symbol_to_list (sym, cu->list_in_scope);
c906108c
SS
7267 break;
7268 case DW_TAG_enumerator:
63d06c5c
DC
7269 if (processing_has_namespace_info
7270 && processing_current_prefix[0] != '\0')
7271 {
987504bb
JJ
7272 SYMBOL_LINKAGE_NAME (sym) = typename_concat (&objfile->objfile_obstack,
7273 processing_current_prefix,
7274 name, cu);
63d06c5c 7275 }
e142c38c 7276 attr = dwarf2_attr (die, DW_AT_const_value, cu);
c906108c
SS
7277 if (attr)
7278 {
e7c27a73 7279 dwarf2_const_value (attr, sym, cu);
c906108c 7280 }
63d06c5c
DC
7281 {
7282 /* NOTE: carlton/2003-11-10: See comment above in the
7283 DW_TAG_class_type, etc. block. */
7284
7285 struct pending **list_to_add;
7286
e142c38c 7287 list_to_add = (cu->list_in_scope == &file_symbols
987504bb
JJ
7288 && (cu->language == language_cplus
7289 || cu->language == language_java)
e142c38c 7290 ? &global_symbols : cu->list_in_scope);
63d06c5c
DC
7291
7292 add_symbol_to_list (sym, list_to_add);
7293 }
c906108c 7294 break;
5c4e30ca
DC
7295 case DW_TAG_namespace:
7296 SYMBOL_CLASS (sym) = LOC_TYPEDEF;
7297 add_symbol_to_list (sym, &global_symbols);
7298 break;
c906108c
SS
7299 default:
7300 /* Not a tag we recognize. Hopefully we aren't processing
7301 trash data, but since we must specifically ignore things
7302 we don't recognize, there is nothing else we should do at
7303 this point. */
e2e0b3e5 7304 complaint (&symfile_complaints, _("unsupported tag: '%s'"),
4d3c2250 7305 dwarf_tag_name (die->tag));
c906108c
SS
7306 break;
7307 }
7308 }
7309 return (sym);
7310}
7311
7312/* Copy constant value from an attribute to a symbol. */
7313
7314static void
107d2387 7315dwarf2_const_value (struct attribute *attr, struct symbol *sym,
e7c27a73 7316 struct dwarf2_cu *cu)
c906108c 7317{
e7c27a73
DJ
7318 struct objfile *objfile = cu->objfile;
7319 struct comp_unit_head *cu_header = &cu->header;
c906108c
SS
7320 struct dwarf_block *blk;
7321
7322 switch (attr->form)
7323 {
7324 case DW_FORM_addr:
107d2387 7325 if (TYPE_LENGTH (SYMBOL_TYPE (sym)) != cu_header->addr_size)
22abf04a 7326 dwarf2_const_value_length_mismatch_complaint (DEPRECATED_SYMBOL_NAME (sym),
4d3c2250
KB
7327 cu_header->addr_size,
7328 TYPE_LENGTH (SYMBOL_TYPE
7329 (sym)));
4e38b386 7330 SYMBOL_VALUE_BYTES (sym) =
4a146b47 7331 obstack_alloc (&objfile->objfile_obstack, cu_header->addr_size);
fbd9dcd3
AC
7332 /* NOTE: cagney/2003-05-09: In-lined store_address call with
7333 it's body - store_unsigned_integer. */
7334 store_unsigned_integer (SYMBOL_VALUE_BYTES (sym), cu_header->addr_size,
7335 DW_ADDR (attr));
c906108c
SS
7336 SYMBOL_CLASS (sym) = LOC_CONST_BYTES;
7337 break;
7338 case DW_FORM_block1:
7339 case DW_FORM_block2:
7340 case DW_FORM_block4:
7341 case DW_FORM_block:
7342 blk = DW_BLOCK (attr);
7343 if (TYPE_LENGTH (SYMBOL_TYPE (sym)) != blk->size)
22abf04a 7344 dwarf2_const_value_length_mismatch_complaint (DEPRECATED_SYMBOL_NAME (sym),
4d3c2250
KB
7345 blk->size,
7346 TYPE_LENGTH (SYMBOL_TYPE
7347 (sym)));
4e38b386 7348 SYMBOL_VALUE_BYTES (sym) =
4a146b47 7349 obstack_alloc (&objfile->objfile_obstack, blk->size);
c906108c
SS
7350 memcpy (SYMBOL_VALUE_BYTES (sym), blk->data, blk->size);
7351 SYMBOL_CLASS (sym) = LOC_CONST_BYTES;
7352 break;
2df3850c
JM
7353
7354 /* The DW_AT_const_value attributes are supposed to carry the
7355 symbol's value "represented as it would be on the target
7356 architecture." By the time we get here, it's already been
7357 converted to host endianness, so we just need to sign- or
7358 zero-extend it as appropriate. */
7359 case DW_FORM_data1:
7360 dwarf2_const_value_data (attr, sym, 8);
7361 break;
c906108c 7362 case DW_FORM_data2:
2df3850c
JM
7363 dwarf2_const_value_data (attr, sym, 16);
7364 break;
c906108c 7365 case DW_FORM_data4:
2df3850c
JM
7366 dwarf2_const_value_data (attr, sym, 32);
7367 break;
c906108c 7368 case DW_FORM_data8:
2df3850c
JM
7369 dwarf2_const_value_data (attr, sym, 64);
7370 break;
7371
c906108c 7372 case DW_FORM_sdata:
2df3850c
JM
7373 SYMBOL_VALUE (sym) = DW_SND (attr);
7374 SYMBOL_CLASS (sym) = LOC_CONST;
7375 break;
7376
c906108c
SS
7377 case DW_FORM_udata:
7378 SYMBOL_VALUE (sym) = DW_UNSND (attr);
7379 SYMBOL_CLASS (sym) = LOC_CONST;
7380 break;
2df3850c 7381
c906108c 7382 default:
4d3c2250 7383 complaint (&symfile_complaints,
e2e0b3e5 7384 _("unsupported const value attribute form: '%s'"),
4d3c2250 7385 dwarf_form_name (attr->form));
c906108c
SS
7386 SYMBOL_VALUE (sym) = 0;
7387 SYMBOL_CLASS (sym) = LOC_CONST;
7388 break;
7389 }
7390}
7391
2df3850c
JM
7392
7393/* Given an attr with a DW_FORM_dataN value in host byte order, sign-
7394 or zero-extend it as appropriate for the symbol's type. */
7395static void
7396dwarf2_const_value_data (struct attribute *attr,
7397 struct symbol *sym,
7398 int bits)
7399{
7400 LONGEST l = DW_UNSND (attr);
7401
7402 if (bits < sizeof (l) * 8)
7403 {
7404 if (TYPE_UNSIGNED (SYMBOL_TYPE (sym)))
7405 l &= ((LONGEST) 1 << bits) - 1;
7406 else
bf9198f1 7407 l = (l << (sizeof (l) * 8 - bits)) >> (sizeof (l) * 8 - bits);
2df3850c
JM
7408 }
7409
7410 SYMBOL_VALUE (sym) = l;
7411 SYMBOL_CLASS (sym) = LOC_CONST;
7412}
7413
7414
c906108c
SS
7415/* Return the type of the die in question using its DW_AT_type attribute. */
7416
7417static struct type *
e7c27a73 7418die_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c
SS
7419{
7420 struct type *type;
7421 struct attribute *type_attr;
7422 struct die_info *type_die;
c906108c 7423
e142c38c 7424 type_attr = dwarf2_attr (die, DW_AT_type, cu);
c906108c
SS
7425 if (!type_attr)
7426 {
7427 /* A missing DW_AT_type represents a void type. */
e142c38c 7428 return dwarf2_fundamental_type (cu->objfile, FT_VOID, cu);
c906108c
SS
7429 }
7430 else
10b3939b
DJ
7431 type_die = follow_die_ref (die, type_attr, cu);
7432
e7c27a73 7433 type = tag_type_to_type (type_die, cu);
c906108c
SS
7434 if (!type)
7435 {
7436 dump_die (type_die);
8a3fe4f8 7437 error (_("Dwarf Error: Problem turning type die at offset into gdb type [in module %s]"),
e7c27a73 7438 cu->objfile->name);
c906108c
SS
7439 }
7440 return type;
7441}
7442
7443/* Return the containing type of the die in question using its
7444 DW_AT_containing_type attribute. */
7445
7446static struct type *
e7c27a73 7447die_containing_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c
SS
7448{
7449 struct type *type = NULL;
7450 struct attribute *type_attr;
7451 struct die_info *type_die = NULL;
c906108c 7452
e142c38c 7453 type_attr = dwarf2_attr (die, DW_AT_containing_type, cu);
c906108c
SS
7454 if (type_attr)
7455 {
10b3939b 7456 type_die = follow_die_ref (die, type_attr, cu);
e7c27a73 7457 type = tag_type_to_type (type_die, cu);
c906108c
SS
7458 }
7459 if (!type)
7460 {
7461 if (type_die)
7462 dump_die (type_die);
8a3fe4f8 7463 error (_("Dwarf Error: Problem turning containing type into gdb type [in module %s]"),
e7c27a73 7464 cu->objfile->name);
c906108c
SS
7465 }
7466 return type;
7467}
7468
c906108c 7469static struct type *
e7c27a73 7470tag_type_to_type (struct die_info *die, struct dwarf2_cu *cu)
c906108c
SS
7471{
7472 if (die->type)
7473 {
7474 return die->type;
7475 }
7476 else
7477 {
e7c27a73 7478 read_type_die (die, cu);
c906108c
SS
7479 if (!die->type)
7480 {
7481 dump_die (die);
8a3fe4f8 7482 error (_("Dwarf Error: Cannot find type of die [in module %s]"),
e7c27a73 7483 cu->objfile->name);
c906108c
SS
7484 }
7485 return die->type;
7486 }
7487}
7488
7489static void
e7c27a73 7490read_type_die (struct die_info *die, struct dwarf2_cu *cu)
c906108c 7491{
e142c38c 7492 char *prefix = determine_prefix (die, cu);
63d06c5c
DC
7493 const char *old_prefix = processing_current_prefix;
7494 struct cleanup *back_to = make_cleanup (xfree, prefix);
7495 processing_current_prefix = prefix;
7496
c906108c
SS
7497 switch (die->tag)
7498 {
7499 case DW_TAG_class_type:
7500 case DW_TAG_structure_type:
7501 case DW_TAG_union_type:
134d01f1 7502 read_structure_type (die, cu);
c906108c
SS
7503 break;
7504 case DW_TAG_enumeration_type:
134d01f1 7505 read_enumeration_type (die, cu);
c906108c
SS
7506 break;
7507 case DW_TAG_subprogram:
7508 case DW_TAG_subroutine_type:
e7c27a73 7509 read_subroutine_type (die, cu);
c906108c
SS
7510 break;
7511 case DW_TAG_array_type:
e7c27a73 7512 read_array_type (die, cu);
c906108c 7513 break;
72019c9c
GM
7514 case DW_TAG_set_type:
7515 read_set_type (die, cu);
7516 break;
c906108c 7517 case DW_TAG_pointer_type:
e7c27a73 7518 read_tag_pointer_type (die, cu);
c906108c
SS
7519 break;
7520 case DW_TAG_ptr_to_member_type:
e7c27a73 7521 read_tag_ptr_to_member_type (die, cu);
c906108c
SS
7522 break;
7523 case DW_TAG_reference_type:
e7c27a73 7524 read_tag_reference_type (die, cu);
c906108c
SS
7525 break;
7526 case DW_TAG_const_type:
e7c27a73 7527 read_tag_const_type (die, cu);
c906108c
SS
7528 break;
7529 case DW_TAG_volatile_type:
e7c27a73 7530 read_tag_volatile_type (die, cu);
c906108c
SS
7531 break;
7532 case DW_TAG_string_type:
e7c27a73 7533 read_tag_string_type (die, cu);
c906108c
SS
7534 break;
7535 case DW_TAG_typedef:
e7c27a73 7536 read_typedef (die, cu);
c906108c 7537 break;
a02abb62
JB
7538 case DW_TAG_subrange_type:
7539 read_subrange_type (die, cu);
7540 break;
c906108c 7541 case DW_TAG_base_type:
e7c27a73 7542 read_base_type (die, cu);
c906108c 7543 break;
81a17f79
JB
7544 case DW_TAG_unspecified_type:
7545 read_unspecified_type (die, cu);
7546 break;
c906108c 7547 default:
a1f5b845 7548 complaint (&symfile_complaints, _("unexpected tag in read_type_die: '%s'"),
4d3c2250 7549 dwarf_tag_name (die->tag));
c906108c
SS
7550 break;
7551 }
63d06c5c
DC
7552
7553 processing_current_prefix = old_prefix;
7554 do_cleanups (back_to);
7555}
7556
fdde2d81
DC
7557/* Return the name of the namespace/class that DIE is defined within,
7558 or "" if we can't tell. The caller should xfree the result. */
7559
7560/* NOTE: carlton/2004-01-23: See read_func_scope (and the comment
7561 therein) for an example of how to use this function to deal with
7562 DW_AT_specification. */
7563
7564static char *
e142c38c 7565determine_prefix (struct die_info *die, struct dwarf2_cu *cu)
63d06c5c
DC
7566{
7567 struct die_info *parent;
7568
987504bb
JJ
7569 if (cu->language != language_cplus
7570 && cu->language != language_java)
63d06c5c
DC
7571 return NULL;
7572
7573 parent = die->parent;
7574
7575 if (parent == NULL)
7576 {
8176b9b8 7577 return xstrdup ("");
63d06c5c
DC
7578 }
7579 else
7580 {
63d06c5c
DC
7581 switch (parent->tag) {
7582 case DW_TAG_namespace:
7583 {
8176b9b8
DC
7584 /* FIXME: carlton/2004-03-05: Should I follow extension dies
7585 before doing this check? */
7586 if (parent->type != NULL && TYPE_TAG_NAME (parent->type) != NULL)
7587 {
7588 return xstrdup (TYPE_TAG_NAME (parent->type));
7589 }
7590 else
7591 {
7592 int dummy;
7593 char *parent_prefix = determine_prefix (parent, cu);
987504bb 7594 char *retval = typename_concat (NULL, parent_prefix,
8176b9b8 7595 namespace_name (parent, &dummy,
987504bb
JJ
7596 cu),
7597 cu);
8176b9b8
DC
7598 xfree (parent_prefix);
7599 return retval;
7600 }
63d06c5c
DC
7601 }
7602 break;
7603 case DW_TAG_class_type:
7604 case DW_TAG_structure_type:
7605 {
8176b9b8 7606 if (parent->type != NULL && TYPE_TAG_NAME (parent->type) != NULL)
63d06c5c 7607 {
8176b9b8 7608 return xstrdup (TYPE_TAG_NAME (parent->type));
63d06c5c
DC
7609 }
7610 else
8176b9b8
DC
7611 {
7612 const char *old_prefix = processing_current_prefix;
7613 char *new_prefix = determine_prefix (parent, cu);
7614 char *retval;
7615
7616 processing_current_prefix = new_prefix;
7617 retval = determine_class_name (parent, cu);
7618 processing_current_prefix = old_prefix;
7619
7620 xfree (new_prefix);
7621 return retval;
7622 }
63d06c5c 7623 }
63d06c5c 7624 default:
8176b9b8 7625 return determine_prefix (parent, cu);
63d06c5c 7626 }
63d06c5c
DC
7627 }
7628}
7629
987504bb
JJ
7630/* Return a newly-allocated string formed by concatenating PREFIX and
7631 SUFFIX with appropriate separator. If PREFIX or SUFFIX is NULL or empty, then
7632 simply copy the SUFFIX or PREFIX, respectively. If OBS is non-null,
7633 perform an obconcat, otherwise allocate storage for the result. The CU argument
7634 is used to determine the language and hence, the appropriate separator. */
7635
7636#define MAX_SEP_LEN 2 /* sizeof ("::") */
63d06c5c
DC
7637
7638static char *
987504bb
JJ
7639typename_concat (struct obstack *obs, const char *prefix, const char *suffix,
7640 struct dwarf2_cu *cu)
63d06c5c 7641{
987504bb 7642 char *sep;
63d06c5c 7643
987504bb
JJ
7644 if (suffix == NULL || suffix[0] == '\0' || prefix == NULL || prefix[0] == '\0')
7645 sep = "";
7646 else if (cu->language == language_java)
7647 sep = ".";
7648 else
7649 sep = "::";
63d06c5c 7650
987504bb
JJ
7651 if (obs == NULL)
7652 {
7653 char *retval = xmalloc (strlen (prefix) + MAX_SEP_LEN + strlen (suffix) + 1);
7654 retval[0] = '\0';
7655
7656 if (prefix)
7657 {
7658 strcpy (retval, prefix);
7659 strcat (retval, sep);
7660 }
7661 if (suffix)
7662 strcat (retval, suffix);
7663
63d06c5c
DC
7664 return retval;
7665 }
987504bb
JJ
7666 else
7667 {
7668 /* We have an obstack. */
7669 return obconcat (obs, prefix, sep, suffix);
7670 }
63d06c5c
DC
7671}
7672
c906108c 7673static struct type *
e7c27a73 7674dwarf_base_type (int encoding, int size, struct dwarf2_cu *cu)
c906108c 7675{
e7c27a73
DJ
7676 struct objfile *objfile = cu->objfile;
7677
c906108c
SS
7678 /* FIXME - this should not produce a new (struct type *)
7679 every time. It should cache base types. */
7680 struct type *type;
7681 switch (encoding)
7682 {
7683 case DW_ATE_address:
e142c38c 7684 type = dwarf2_fundamental_type (objfile, FT_VOID, cu);
c906108c
SS
7685 return type;
7686 case DW_ATE_boolean:
e142c38c 7687 type = dwarf2_fundamental_type (objfile, FT_BOOLEAN, cu);
c906108c
SS
7688 return type;
7689 case DW_ATE_complex_float:
7690 if (size == 16)
7691 {
e142c38c 7692 type = dwarf2_fundamental_type (objfile, FT_DBL_PREC_COMPLEX, cu);
c906108c
SS
7693 }
7694 else
7695 {
e142c38c 7696 type = dwarf2_fundamental_type (objfile, FT_COMPLEX, cu);
c906108c
SS
7697 }
7698 return type;
7699 case DW_ATE_float:
7700 if (size == 8)
7701 {
e142c38c 7702 type = dwarf2_fundamental_type (objfile, FT_DBL_PREC_FLOAT, cu);
c906108c
SS
7703 }
7704 else
7705 {
e142c38c 7706 type = dwarf2_fundamental_type (objfile, FT_FLOAT, cu);
c906108c
SS
7707 }
7708 return type;
7709 case DW_ATE_signed:
7710 switch (size)
7711 {
7712 case 1:
e142c38c 7713 type = dwarf2_fundamental_type (objfile, FT_SIGNED_CHAR, cu);
c906108c
SS
7714 break;
7715 case 2:
e142c38c 7716 type = dwarf2_fundamental_type (objfile, FT_SIGNED_SHORT, cu);
c906108c
SS
7717 break;
7718 default:
7719 case 4:
e142c38c 7720 type = dwarf2_fundamental_type (objfile, FT_SIGNED_INTEGER, cu);
c906108c
SS
7721 break;
7722 }
7723 return type;
7724 case DW_ATE_signed_char:
e142c38c 7725 type = dwarf2_fundamental_type (objfile, FT_SIGNED_CHAR, cu);
c906108c
SS
7726 return type;
7727 case DW_ATE_unsigned:
7728 switch (size)
7729 {
7730 case 1:
e142c38c 7731 type = dwarf2_fundamental_type (objfile, FT_UNSIGNED_CHAR, cu);
c906108c
SS
7732 break;
7733 case 2:
e142c38c 7734 type = dwarf2_fundamental_type (objfile, FT_UNSIGNED_SHORT, cu);
c906108c
SS
7735 break;
7736 default:
7737 case 4:
e142c38c 7738 type = dwarf2_fundamental_type (objfile, FT_UNSIGNED_INTEGER, cu);
c906108c
SS
7739 break;
7740 }
7741 return type;
7742 case DW_ATE_unsigned_char:
e142c38c 7743 type = dwarf2_fundamental_type (objfile, FT_UNSIGNED_CHAR, cu);
c906108c
SS
7744 return type;
7745 default:
e142c38c 7746 type = dwarf2_fundamental_type (objfile, FT_SIGNED_INTEGER, cu);
c906108c
SS
7747 return type;
7748 }
7749}
7750
7751#if 0
7752struct die_info *
fba45db2 7753copy_die (struct die_info *old_die)
c906108c
SS
7754{
7755 struct die_info *new_die;
7756 int i, num_attrs;
7757
7758 new_die = (struct die_info *) xmalloc (sizeof (struct die_info));
7759 memset (new_die, 0, sizeof (struct die_info));
7760
7761 new_die->tag = old_die->tag;
7762 new_die->has_children = old_die->has_children;
7763 new_die->abbrev = old_die->abbrev;
7764 new_die->offset = old_die->offset;
7765 new_die->type = NULL;
7766
7767 num_attrs = old_die->num_attrs;
7768 new_die->num_attrs = num_attrs;
7769 new_die->attrs = (struct attribute *)
7770 xmalloc (num_attrs * sizeof (struct attribute));
7771
7772 for (i = 0; i < old_die->num_attrs; ++i)
7773 {
7774 new_die->attrs[i].name = old_die->attrs[i].name;
7775 new_die->attrs[i].form = old_die->attrs[i].form;
7776 new_die->attrs[i].u.addr = old_die->attrs[i].u.addr;
7777 }
7778
7779 new_die->next = NULL;
7780 return new_die;
7781}
7782#endif
7783
7784/* Return sibling of die, NULL if no sibling. */
7785
f9aca02d 7786static struct die_info *
fba45db2 7787sibling_die (struct die_info *die)
c906108c 7788{
639d11d3 7789 return die->sibling;
c906108c
SS
7790}
7791
7792/* Get linkage name of a die, return NULL if not found. */
7793
7794static char *
e142c38c 7795dwarf2_linkage_name (struct die_info *die, struct dwarf2_cu *cu)
c906108c
SS
7796{
7797 struct attribute *attr;
7798
e142c38c 7799 attr = dwarf2_attr (die, DW_AT_MIPS_linkage_name, cu);
c906108c
SS
7800 if (attr && DW_STRING (attr))
7801 return DW_STRING (attr);
e142c38c 7802 attr = dwarf2_attr (die, DW_AT_name, cu);
c906108c
SS
7803 if (attr && DW_STRING (attr))
7804 return DW_STRING (attr);
7805 return NULL;
7806}
7807
9219021c
DC
7808/* Get name of a die, return NULL if not found. */
7809
7810static char *
e142c38c 7811dwarf2_name (struct die_info *die, struct dwarf2_cu *cu)
9219021c
DC
7812{
7813 struct attribute *attr;
7814
e142c38c 7815 attr = dwarf2_attr (die, DW_AT_name, cu);
9219021c
DC
7816 if (attr && DW_STRING (attr))
7817 return DW_STRING (attr);
7818 return NULL;
7819}
7820
7821/* Return the die that this die in an extension of, or NULL if there
7822 is none. */
7823
7824static struct die_info *
e142c38c 7825dwarf2_extension (struct die_info *die, struct dwarf2_cu *cu)
9219021c
DC
7826{
7827 struct attribute *attr;
9219021c 7828
e142c38c 7829 attr = dwarf2_attr (die, DW_AT_extension, cu);
9219021c
DC
7830 if (attr == NULL)
7831 return NULL;
7832
10b3939b 7833 return follow_die_ref (die, attr, cu);
9219021c
DC
7834}
7835
c906108c
SS
7836/* Convert a DIE tag into its string name. */
7837
7838static char *
aa1ee363 7839dwarf_tag_name (unsigned tag)
c906108c
SS
7840{
7841 switch (tag)
7842 {
7843 case DW_TAG_padding:
7844 return "DW_TAG_padding";
7845 case DW_TAG_array_type:
7846 return "DW_TAG_array_type";
7847 case DW_TAG_class_type:
7848 return "DW_TAG_class_type";
7849 case DW_TAG_entry_point:
7850 return "DW_TAG_entry_point";
7851 case DW_TAG_enumeration_type:
7852 return "DW_TAG_enumeration_type";
7853 case DW_TAG_formal_parameter:
7854 return "DW_TAG_formal_parameter";
7855 case DW_TAG_imported_declaration:
7856 return "DW_TAG_imported_declaration";
7857 case DW_TAG_label:
7858 return "DW_TAG_label";
7859 case DW_TAG_lexical_block:
7860 return "DW_TAG_lexical_block";
7861 case DW_TAG_member:
7862 return "DW_TAG_member";
7863 case DW_TAG_pointer_type:
7864 return "DW_TAG_pointer_type";
7865 case DW_TAG_reference_type:
7866 return "DW_TAG_reference_type";
7867 case DW_TAG_compile_unit:
7868 return "DW_TAG_compile_unit";
7869 case DW_TAG_string_type:
7870 return "DW_TAG_string_type";
7871 case DW_TAG_structure_type:
7872 return "DW_TAG_structure_type";
7873 case DW_TAG_subroutine_type:
7874 return "DW_TAG_subroutine_type";
7875 case DW_TAG_typedef:
7876 return "DW_TAG_typedef";
7877 case DW_TAG_union_type:
7878 return "DW_TAG_union_type";
7879 case DW_TAG_unspecified_parameters:
7880 return "DW_TAG_unspecified_parameters";
7881 case DW_TAG_variant:
7882 return "DW_TAG_variant";
7883 case DW_TAG_common_block:
7884 return "DW_TAG_common_block";
7885 case DW_TAG_common_inclusion:
7886 return "DW_TAG_common_inclusion";
7887 case DW_TAG_inheritance:
7888 return "DW_TAG_inheritance";
7889 case DW_TAG_inlined_subroutine:
7890 return "DW_TAG_inlined_subroutine";
7891 case DW_TAG_module:
7892 return "DW_TAG_module";
7893 case DW_TAG_ptr_to_member_type:
7894 return "DW_TAG_ptr_to_member_type";
7895 case DW_TAG_set_type:
7896 return "DW_TAG_set_type";
7897 case DW_TAG_subrange_type:
7898 return "DW_TAG_subrange_type";
7899 case DW_TAG_with_stmt:
7900 return "DW_TAG_with_stmt";
7901 case DW_TAG_access_declaration:
7902 return "DW_TAG_access_declaration";
7903 case DW_TAG_base_type:
7904 return "DW_TAG_base_type";
7905 case DW_TAG_catch_block:
7906 return "DW_TAG_catch_block";
7907 case DW_TAG_const_type:
7908 return "DW_TAG_const_type";
7909 case DW_TAG_constant:
7910 return "DW_TAG_constant";
7911 case DW_TAG_enumerator:
7912 return "DW_TAG_enumerator";
7913 case DW_TAG_file_type:
7914 return "DW_TAG_file_type";
7915 case DW_TAG_friend:
7916 return "DW_TAG_friend";
7917 case DW_TAG_namelist:
7918 return "DW_TAG_namelist";
7919 case DW_TAG_namelist_item:
7920 return "DW_TAG_namelist_item";
7921 case DW_TAG_packed_type:
7922 return "DW_TAG_packed_type";
7923 case DW_TAG_subprogram:
7924 return "DW_TAG_subprogram";
7925 case DW_TAG_template_type_param:
7926 return "DW_TAG_template_type_param";
7927 case DW_TAG_template_value_param:
7928 return "DW_TAG_template_value_param";
7929 case DW_TAG_thrown_type:
7930 return "DW_TAG_thrown_type";
7931 case DW_TAG_try_block:
7932 return "DW_TAG_try_block";
7933 case DW_TAG_variant_part:
7934 return "DW_TAG_variant_part";
7935 case DW_TAG_variable:
7936 return "DW_TAG_variable";
7937 case DW_TAG_volatile_type:
7938 return "DW_TAG_volatile_type";
d9fa45fe
DC
7939 case DW_TAG_dwarf_procedure:
7940 return "DW_TAG_dwarf_procedure";
7941 case DW_TAG_restrict_type:
7942 return "DW_TAG_restrict_type";
7943 case DW_TAG_interface_type:
7944 return "DW_TAG_interface_type";
7945 case DW_TAG_namespace:
7946 return "DW_TAG_namespace";
7947 case DW_TAG_imported_module:
7948 return "DW_TAG_imported_module";
7949 case DW_TAG_unspecified_type:
7950 return "DW_TAG_unspecified_type";
7951 case DW_TAG_partial_unit:
7952 return "DW_TAG_partial_unit";
7953 case DW_TAG_imported_unit:
7954 return "DW_TAG_imported_unit";
b7619582
GF
7955 case DW_TAG_condition:
7956 return "DW_TAG_condition";
7957 case DW_TAG_shared_type:
7958 return "DW_TAG_shared_type";
c906108c
SS
7959 case DW_TAG_MIPS_loop:
7960 return "DW_TAG_MIPS_loop";
b7619582
GF
7961 case DW_TAG_HP_array_descriptor:
7962 return "DW_TAG_HP_array_descriptor";
c906108c
SS
7963 case DW_TAG_format_label:
7964 return "DW_TAG_format_label";
7965 case DW_TAG_function_template:
7966 return "DW_TAG_function_template";
7967 case DW_TAG_class_template:
7968 return "DW_TAG_class_template";
b7619582
GF
7969 case DW_TAG_GNU_BINCL:
7970 return "DW_TAG_GNU_BINCL";
7971 case DW_TAG_GNU_EINCL:
7972 return "DW_TAG_GNU_EINCL";
7973 case DW_TAG_upc_shared_type:
7974 return "DW_TAG_upc_shared_type";
7975 case DW_TAG_upc_strict_type:
7976 return "DW_TAG_upc_strict_type";
7977 case DW_TAG_upc_relaxed_type:
7978 return "DW_TAG_upc_relaxed_type";
7979 case DW_TAG_PGI_kanji_type:
7980 return "DW_TAG_PGI_kanji_type";
7981 case DW_TAG_PGI_interface_block:
7982 return "DW_TAG_PGI_interface_block";
c906108c
SS
7983 default:
7984 return "DW_TAG_<unknown>";
7985 }
7986}
7987
7988/* Convert a DWARF attribute code into its string name. */
7989
7990static char *
aa1ee363 7991dwarf_attr_name (unsigned attr)
c906108c
SS
7992{
7993 switch (attr)
7994 {
7995 case DW_AT_sibling:
7996 return "DW_AT_sibling";
7997 case DW_AT_location:
7998 return "DW_AT_location";
7999 case DW_AT_name:
8000 return "DW_AT_name";
8001 case DW_AT_ordering:
8002 return "DW_AT_ordering";
8003 case DW_AT_subscr_data:
8004 return "DW_AT_subscr_data";
8005 case DW_AT_byte_size:
8006 return "DW_AT_byte_size";
8007 case DW_AT_bit_offset:
8008 return "DW_AT_bit_offset";
8009 case DW_AT_bit_size:
8010 return "DW_AT_bit_size";
8011 case DW_AT_element_list:
8012 return "DW_AT_element_list";
8013 case DW_AT_stmt_list:
8014 return "DW_AT_stmt_list";
8015 case DW_AT_low_pc:
8016 return "DW_AT_low_pc";
8017 case DW_AT_high_pc:
8018 return "DW_AT_high_pc";
8019 case DW_AT_language:
8020 return "DW_AT_language";
8021 case DW_AT_member:
8022 return "DW_AT_member";
8023 case DW_AT_discr:
8024 return "DW_AT_discr";
8025 case DW_AT_discr_value:
8026 return "DW_AT_discr_value";
8027 case DW_AT_visibility:
8028 return "DW_AT_visibility";
8029 case DW_AT_import:
8030 return "DW_AT_import";
8031 case DW_AT_string_length:
8032 return "DW_AT_string_length";
8033 case DW_AT_common_reference:
8034 return "DW_AT_common_reference";
8035 case DW_AT_comp_dir:
8036 return "DW_AT_comp_dir";
8037 case DW_AT_const_value:
8038 return "DW_AT_const_value";
8039 case DW_AT_containing_type:
8040 return "DW_AT_containing_type";
8041 case DW_AT_default_value:
8042 return "DW_AT_default_value";
8043 case DW_AT_inline:
8044 return "DW_AT_inline";
8045 case DW_AT_is_optional:
8046 return "DW_AT_is_optional";
8047 case DW_AT_lower_bound:
8048 return "DW_AT_lower_bound";
8049 case DW_AT_producer:
8050 return "DW_AT_producer";
8051 case DW_AT_prototyped:
8052 return "DW_AT_prototyped";
8053 case DW_AT_return_addr:
8054 return "DW_AT_return_addr";
8055 case DW_AT_start_scope:
8056 return "DW_AT_start_scope";
8057 case DW_AT_stride_size:
8058 return "DW_AT_stride_size";
8059 case DW_AT_upper_bound:
8060 return "DW_AT_upper_bound";
8061 case DW_AT_abstract_origin:
8062 return "DW_AT_abstract_origin";
8063 case DW_AT_accessibility:
8064 return "DW_AT_accessibility";
8065 case DW_AT_address_class:
8066 return "DW_AT_address_class";
8067 case DW_AT_artificial:
8068 return "DW_AT_artificial";
8069 case DW_AT_base_types:
8070 return "DW_AT_base_types";
8071 case DW_AT_calling_convention:
8072 return "DW_AT_calling_convention";
8073 case DW_AT_count:
8074 return "DW_AT_count";
8075 case DW_AT_data_member_location:
8076 return "DW_AT_data_member_location";
8077 case DW_AT_decl_column:
8078 return "DW_AT_decl_column";
8079 case DW_AT_decl_file:
8080 return "DW_AT_decl_file";
8081 case DW_AT_decl_line:
8082 return "DW_AT_decl_line";
8083 case DW_AT_declaration:
8084 return "DW_AT_declaration";
8085 case DW_AT_discr_list:
8086 return "DW_AT_discr_list";
8087 case DW_AT_encoding:
8088 return "DW_AT_encoding";
8089 case DW_AT_external:
8090 return "DW_AT_external";
8091 case DW_AT_frame_base:
8092 return "DW_AT_frame_base";
8093 case DW_AT_friend:
8094 return "DW_AT_friend";
8095 case DW_AT_identifier_case:
8096 return "DW_AT_identifier_case";
8097 case DW_AT_macro_info:
8098 return "DW_AT_macro_info";
8099 case DW_AT_namelist_items:
8100 return "DW_AT_namelist_items";
8101 case DW_AT_priority:
8102 return "DW_AT_priority";
8103 case DW_AT_segment:
8104 return "DW_AT_segment";
8105 case DW_AT_specification:
8106 return "DW_AT_specification";
8107 case DW_AT_static_link:
8108 return "DW_AT_static_link";
8109 case DW_AT_type:
8110 return "DW_AT_type";
8111 case DW_AT_use_location:
8112 return "DW_AT_use_location";
8113 case DW_AT_variable_parameter:
8114 return "DW_AT_variable_parameter";
8115 case DW_AT_virtuality:
8116 return "DW_AT_virtuality";
8117 case DW_AT_vtable_elem_location:
8118 return "DW_AT_vtable_elem_location";
b7619582 8119 /* DWARF 3 values. */
d9fa45fe
DC
8120 case DW_AT_allocated:
8121 return "DW_AT_allocated";
8122 case DW_AT_associated:
8123 return "DW_AT_associated";
8124 case DW_AT_data_location:
8125 return "DW_AT_data_location";
8126 case DW_AT_stride:
8127 return "DW_AT_stride";
8128 case DW_AT_entry_pc:
8129 return "DW_AT_entry_pc";
8130 case DW_AT_use_UTF8:
8131 return "DW_AT_use_UTF8";
8132 case DW_AT_extension:
8133 return "DW_AT_extension";
8134 case DW_AT_ranges:
8135 return "DW_AT_ranges";
8136 case DW_AT_trampoline:
8137 return "DW_AT_trampoline";
8138 case DW_AT_call_column:
8139 return "DW_AT_call_column";
8140 case DW_AT_call_file:
8141 return "DW_AT_call_file";
8142 case DW_AT_call_line:
8143 return "DW_AT_call_line";
b7619582
GF
8144 case DW_AT_description:
8145 return "DW_AT_description";
8146 case DW_AT_binary_scale:
8147 return "DW_AT_binary_scale";
8148 case DW_AT_decimal_scale:
8149 return "DW_AT_decimal_scale";
8150 case DW_AT_small:
8151 return "DW_AT_small";
8152 case DW_AT_decimal_sign:
8153 return "DW_AT_decimal_sign";
8154 case DW_AT_digit_count:
8155 return "DW_AT_digit_count";
8156 case DW_AT_picture_string:
8157 return "DW_AT_picture_string";
8158 case DW_AT_mutable:
8159 return "DW_AT_mutable";
8160 case DW_AT_threads_scaled:
8161 return "DW_AT_threads_scaled";
8162 case DW_AT_explicit:
8163 return "DW_AT_explicit";
8164 case DW_AT_object_pointer:
8165 return "DW_AT_object_pointer";
8166 case DW_AT_endianity:
8167 return "DW_AT_endianity";
8168 case DW_AT_elemental:
8169 return "DW_AT_elemental";
8170 case DW_AT_pure:
8171 return "DW_AT_pure";
8172 case DW_AT_recursive:
8173 return "DW_AT_recursive";
c906108c 8174#ifdef MIPS
b7619582 8175 /* SGI/MIPS extensions. */
c906108c
SS
8176 case DW_AT_MIPS_fde:
8177 return "DW_AT_MIPS_fde";
8178 case DW_AT_MIPS_loop_begin:
8179 return "DW_AT_MIPS_loop_begin";
8180 case DW_AT_MIPS_tail_loop_begin:
8181 return "DW_AT_MIPS_tail_loop_begin";
8182 case DW_AT_MIPS_epilog_begin:
8183 return "DW_AT_MIPS_epilog_begin";
8184 case DW_AT_MIPS_loop_unroll_factor:
8185 return "DW_AT_MIPS_loop_unroll_factor";
8186 case DW_AT_MIPS_software_pipeline_depth:
8187 return "DW_AT_MIPS_software_pipeline_depth";
8188 case DW_AT_MIPS_linkage_name:
8189 return "DW_AT_MIPS_linkage_name";
b7619582
GF
8190 case DW_AT_MIPS_stride:
8191 return "DW_AT_MIPS_stride";
8192 case DW_AT_MIPS_abstract_name:
8193 return "DW_AT_MIPS_abstract_name";
8194 case DW_AT_MIPS_clone_origin:
8195 return "DW_AT_MIPS_clone_origin";
8196 case DW_AT_MIPS_has_inlines:
8197 return "DW_AT_MIPS_has_inlines";
8198#endif
8199 /* HP extensions. */
8200 case DW_AT_HP_block_index:
8201 return "DW_AT_HP_block_index";
8202 case DW_AT_HP_unmodifiable:
8203 return "DW_AT_HP_unmodifiable";
8204 case DW_AT_HP_actuals_stmt_list:
8205 return "DW_AT_HP_actuals_stmt_list";
8206 case DW_AT_HP_proc_per_section:
8207 return "DW_AT_HP_proc_per_section";
8208 case DW_AT_HP_raw_data_ptr:
8209 return "DW_AT_HP_raw_data_ptr";
8210 case DW_AT_HP_pass_by_reference:
8211 return "DW_AT_HP_pass_by_reference";
8212 case DW_AT_HP_opt_level:
8213 return "DW_AT_HP_opt_level";
8214 case DW_AT_HP_prof_version_id:
8215 return "DW_AT_HP_prof_version_id";
8216 case DW_AT_HP_opt_flags:
8217 return "DW_AT_HP_opt_flags";
8218 case DW_AT_HP_cold_region_low_pc:
8219 return "DW_AT_HP_cold_region_low_pc";
8220 case DW_AT_HP_cold_region_high_pc:
8221 return "DW_AT_HP_cold_region_high_pc";
8222 case DW_AT_HP_all_variables_modifiable:
8223 return "DW_AT_HP_all_variables_modifiable";
8224 case DW_AT_HP_linkage_name:
8225 return "DW_AT_HP_linkage_name";
8226 case DW_AT_HP_prof_flags:
8227 return "DW_AT_HP_prof_flags";
8228 /* GNU extensions. */
c906108c
SS
8229 case DW_AT_sf_names:
8230 return "DW_AT_sf_names";
8231 case DW_AT_src_info:
8232 return "DW_AT_src_info";
8233 case DW_AT_mac_info:
8234 return "DW_AT_mac_info";
8235 case DW_AT_src_coords:
8236 return "DW_AT_src_coords";
8237 case DW_AT_body_begin:
8238 return "DW_AT_body_begin";
8239 case DW_AT_body_end:
8240 return "DW_AT_body_end";
f5f8a009
EZ
8241 case DW_AT_GNU_vector:
8242 return "DW_AT_GNU_vector";
b7619582
GF
8243 /* VMS extensions. */
8244 case DW_AT_VMS_rtnbeg_pd_address:
8245 return "DW_AT_VMS_rtnbeg_pd_address";
8246 /* UPC extension. */
8247 case DW_AT_upc_threads_scaled:
8248 return "DW_AT_upc_threads_scaled";
8249 /* PGI (STMicroelectronics) extensions. */
8250 case DW_AT_PGI_lbase:
8251 return "DW_AT_PGI_lbase";
8252 case DW_AT_PGI_soffset:
8253 return "DW_AT_PGI_soffset";
8254 case DW_AT_PGI_lstride:
8255 return "DW_AT_PGI_lstride";
c906108c
SS
8256 default:
8257 return "DW_AT_<unknown>";
8258 }
8259}
8260
8261/* Convert a DWARF value form code into its string name. */
8262
8263static char *
aa1ee363 8264dwarf_form_name (unsigned form)
c906108c
SS
8265{
8266 switch (form)
8267 {
8268 case DW_FORM_addr:
8269 return "DW_FORM_addr";
8270 case DW_FORM_block2:
8271 return "DW_FORM_block2";
8272 case DW_FORM_block4:
8273 return "DW_FORM_block4";
8274 case DW_FORM_data2:
8275 return "DW_FORM_data2";
8276 case DW_FORM_data4:
8277 return "DW_FORM_data4";
8278 case DW_FORM_data8:
8279 return "DW_FORM_data8";
8280 case DW_FORM_string:
8281 return "DW_FORM_string";
8282 case DW_FORM_block:
8283 return "DW_FORM_block";
8284 case DW_FORM_block1:
8285 return "DW_FORM_block1";
8286 case DW_FORM_data1:
8287 return "DW_FORM_data1";
8288 case DW_FORM_flag:
8289 return "DW_FORM_flag";
8290 case DW_FORM_sdata:
8291 return "DW_FORM_sdata";
8292 case DW_FORM_strp:
8293 return "DW_FORM_strp";
8294 case DW_FORM_udata:
8295 return "DW_FORM_udata";
8296 case DW_FORM_ref_addr:
8297 return "DW_FORM_ref_addr";
8298 case DW_FORM_ref1:
8299 return "DW_FORM_ref1";
8300 case DW_FORM_ref2:
8301 return "DW_FORM_ref2";
8302 case DW_FORM_ref4:
8303 return "DW_FORM_ref4";
8304 case DW_FORM_ref8:
8305 return "DW_FORM_ref8";
8306 case DW_FORM_ref_udata:
8307 return "DW_FORM_ref_udata";
8308 case DW_FORM_indirect:
8309 return "DW_FORM_indirect";
8310 default:
8311 return "DW_FORM_<unknown>";
8312 }
8313}
8314
8315/* Convert a DWARF stack opcode into its string name. */
8316
8317static char *
aa1ee363 8318dwarf_stack_op_name (unsigned op)
c906108c
SS
8319{
8320 switch (op)
8321 {
8322 case DW_OP_addr:
8323 return "DW_OP_addr";
8324 case DW_OP_deref:
8325 return "DW_OP_deref";
8326 case DW_OP_const1u:
8327 return "DW_OP_const1u";
8328 case DW_OP_const1s:
8329 return "DW_OP_const1s";
8330 case DW_OP_const2u:
8331 return "DW_OP_const2u";
8332 case DW_OP_const2s:
8333 return "DW_OP_const2s";
8334 case DW_OP_const4u:
8335 return "DW_OP_const4u";
8336 case DW_OP_const4s:
8337 return "DW_OP_const4s";
8338 case DW_OP_const8u:
8339 return "DW_OP_const8u";
8340 case DW_OP_const8s:
8341 return "DW_OP_const8s";
8342 case DW_OP_constu:
8343 return "DW_OP_constu";
8344 case DW_OP_consts:
8345 return "DW_OP_consts";
8346 case DW_OP_dup:
8347 return "DW_OP_dup";
8348 case DW_OP_drop:
8349 return "DW_OP_drop";
8350 case DW_OP_over:
8351 return "DW_OP_over";
8352 case DW_OP_pick:
8353 return "DW_OP_pick";
8354 case DW_OP_swap:
8355 return "DW_OP_swap";
8356 case DW_OP_rot:
8357 return "DW_OP_rot";
8358 case DW_OP_xderef:
8359 return "DW_OP_xderef";
8360 case DW_OP_abs:
8361 return "DW_OP_abs";
8362 case DW_OP_and:
8363 return "DW_OP_and";
8364 case DW_OP_div:
8365 return "DW_OP_div";
8366 case DW_OP_minus:
8367 return "DW_OP_minus";
8368 case DW_OP_mod:
8369 return "DW_OP_mod";
8370 case DW_OP_mul:
8371 return "DW_OP_mul";
8372 case DW_OP_neg:
8373 return "DW_OP_neg";
8374 case DW_OP_not:
8375 return "DW_OP_not";
8376 case DW_OP_or:
8377 return "DW_OP_or";
8378 case DW_OP_plus:
8379 return "DW_OP_plus";
8380 case DW_OP_plus_uconst:
8381 return "DW_OP_plus_uconst";
8382 case DW_OP_shl:
8383 return "DW_OP_shl";
8384 case DW_OP_shr:
8385 return "DW_OP_shr";
8386 case DW_OP_shra:
8387 return "DW_OP_shra";
8388 case DW_OP_xor:
8389 return "DW_OP_xor";
8390 case DW_OP_bra:
8391 return "DW_OP_bra";
8392 case DW_OP_eq:
8393 return "DW_OP_eq";
8394 case DW_OP_ge:
8395 return "DW_OP_ge";
8396 case DW_OP_gt:
8397 return "DW_OP_gt";
8398 case DW_OP_le:
8399 return "DW_OP_le";
8400 case DW_OP_lt:
8401 return "DW_OP_lt";
8402 case DW_OP_ne:
8403 return "DW_OP_ne";
8404 case DW_OP_skip:
8405 return "DW_OP_skip";
8406 case DW_OP_lit0:
8407 return "DW_OP_lit0";
8408 case DW_OP_lit1:
8409 return "DW_OP_lit1";
8410 case DW_OP_lit2:
8411 return "DW_OP_lit2";
8412 case DW_OP_lit3:
8413 return "DW_OP_lit3";
8414 case DW_OP_lit4:
8415 return "DW_OP_lit4";
8416 case DW_OP_lit5:
8417 return "DW_OP_lit5";
8418 case DW_OP_lit6:
8419 return "DW_OP_lit6";
8420 case DW_OP_lit7:
8421 return "DW_OP_lit7";
8422 case DW_OP_lit8:
8423 return "DW_OP_lit8";
8424 case DW_OP_lit9:
8425 return "DW_OP_lit9";
8426 case DW_OP_lit10:
8427 return "DW_OP_lit10";
8428 case DW_OP_lit11:
8429 return "DW_OP_lit11";
8430 case DW_OP_lit12:
8431 return "DW_OP_lit12";
8432 case DW_OP_lit13:
8433 return "DW_OP_lit13";
8434 case DW_OP_lit14:
8435 return "DW_OP_lit14";
8436 case DW_OP_lit15:
8437 return "DW_OP_lit15";
8438 case DW_OP_lit16:
8439 return "DW_OP_lit16";
8440 case DW_OP_lit17:
8441 return "DW_OP_lit17";
8442 case DW_OP_lit18:
8443 return "DW_OP_lit18";
8444 case DW_OP_lit19:
8445 return "DW_OP_lit19";
8446 case DW_OP_lit20:
8447 return "DW_OP_lit20";
8448 case DW_OP_lit21:
8449 return "DW_OP_lit21";
8450 case DW_OP_lit22:
8451 return "DW_OP_lit22";
8452 case DW_OP_lit23:
8453 return "DW_OP_lit23";
8454 case DW_OP_lit24:
8455 return "DW_OP_lit24";
8456 case DW_OP_lit25:
8457 return "DW_OP_lit25";
8458 case DW_OP_lit26:
8459 return "DW_OP_lit26";
8460 case DW_OP_lit27:
8461 return "DW_OP_lit27";
8462 case DW_OP_lit28:
8463 return "DW_OP_lit28";
8464 case DW_OP_lit29:
8465 return "DW_OP_lit29";
8466 case DW_OP_lit30:
8467 return "DW_OP_lit30";
8468 case DW_OP_lit31:
8469 return "DW_OP_lit31";
8470 case DW_OP_reg0:
8471 return "DW_OP_reg0";
8472 case DW_OP_reg1:
8473 return "DW_OP_reg1";
8474 case DW_OP_reg2:
8475 return "DW_OP_reg2";
8476 case DW_OP_reg3:
8477 return "DW_OP_reg3";
8478 case DW_OP_reg4:
8479 return "DW_OP_reg4";
8480 case DW_OP_reg5:
8481 return "DW_OP_reg5";
8482 case DW_OP_reg6:
8483 return "DW_OP_reg6";
8484 case DW_OP_reg7:
8485 return "DW_OP_reg7";
8486 case DW_OP_reg8:
8487 return "DW_OP_reg8";
8488 case DW_OP_reg9:
8489 return "DW_OP_reg9";
8490 case DW_OP_reg10:
8491 return "DW_OP_reg10";
8492 case DW_OP_reg11:
8493 return "DW_OP_reg11";
8494 case DW_OP_reg12:
8495 return "DW_OP_reg12";
8496 case DW_OP_reg13:
8497 return "DW_OP_reg13";
8498 case DW_OP_reg14:
8499 return "DW_OP_reg14";
8500 case DW_OP_reg15:
8501 return "DW_OP_reg15";
8502 case DW_OP_reg16:
8503 return "DW_OP_reg16";
8504 case DW_OP_reg17:
8505 return "DW_OP_reg17";
8506 case DW_OP_reg18:
8507 return "DW_OP_reg18";
8508 case DW_OP_reg19:
8509 return "DW_OP_reg19";
8510 case DW_OP_reg20:
8511 return "DW_OP_reg20";
8512 case DW_OP_reg21:
8513 return "DW_OP_reg21";
8514 case DW_OP_reg22:
8515 return "DW_OP_reg22";
8516 case DW_OP_reg23:
8517 return "DW_OP_reg23";
8518 case DW_OP_reg24:
8519 return "DW_OP_reg24";
8520 case DW_OP_reg25:
8521 return "DW_OP_reg25";
8522 case DW_OP_reg26:
8523 return "DW_OP_reg26";
8524 case DW_OP_reg27:
8525 return "DW_OP_reg27";
8526 case DW_OP_reg28:
8527 return "DW_OP_reg28";
8528 case DW_OP_reg29:
8529 return "DW_OP_reg29";
8530 case DW_OP_reg30:
8531 return "DW_OP_reg30";
8532 case DW_OP_reg31:
8533 return "DW_OP_reg31";
8534 case DW_OP_breg0:
8535 return "DW_OP_breg0";
8536 case DW_OP_breg1:
8537 return "DW_OP_breg1";
8538 case DW_OP_breg2:
8539 return "DW_OP_breg2";
8540 case DW_OP_breg3:
8541 return "DW_OP_breg3";
8542 case DW_OP_breg4:
8543 return "DW_OP_breg4";
8544 case DW_OP_breg5:
8545 return "DW_OP_breg5";
8546 case DW_OP_breg6:
8547 return "DW_OP_breg6";
8548 case DW_OP_breg7:
8549 return "DW_OP_breg7";
8550 case DW_OP_breg8:
8551 return "DW_OP_breg8";
8552 case DW_OP_breg9:
8553 return "DW_OP_breg9";
8554 case DW_OP_breg10:
8555 return "DW_OP_breg10";
8556 case DW_OP_breg11:
8557 return "DW_OP_breg11";
8558 case DW_OP_breg12:
8559 return "DW_OP_breg12";
8560 case DW_OP_breg13:
8561 return "DW_OP_breg13";
8562 case DW_OP_breg14:
8563 return "DW_OP_breg14";
8564 case DW_OP_breg15:
8565 return "DW_OP_breg15";
8566 case DW_OP_breg16:
8567 return "DW_OP_breg16";
8568 case DW_OP_breg17:
8569 return "DW_OP_breg17";
8570 case DW_OP_breg18:
8571 return "DW_OP_breg18";
8572 case DW_OP_breg19:
8573 return "DW_OP_breg19";
8574 case DW_OP_breg20:
8575 return "DW_OP_breg20";
8576 case DW_OP_breg21:
8577 return "DW_OP_breg21";
8578 case DW_OP_breg22:
8579 return "DW_OP_breg22";
8580 case DW_OP_breg23:
8581 return "DW_OP_breg23";
8582 case DW_OP_breg24:
8583 return "DW_OP_breg24";
8584 case DW_OP_breg25:
8585 return "DW_OP_breg25";
8586 case DW_OP_breg26:
8587 return "DW_OP_breg26";
8588 case DW_OP_breg27:
8589 return "DW_OP_breg27";
8590 case DW_OP_breg28:
8591 return "DW_OP_breg28";
8592 case DW_OP_breg29:
8593 return "DW_OP_breg29";
8594 case DW_OP_breg30:
8595 return "DW_OP_breg30";
8596 case DW_OP_breg31:
8597 return "DW_OP_breg31";
8598 case DW_OP_regx:
8599 return "DW_OP_regx";
8600 case DW_OP_fbreg:
8601 return "DW_OP_fbreg";
8602 case DW_OP_bregx:
8603 return "DW_OP_bregx";
8604 case DW_OP_piece:
8605 return "DW_OP_piece";
8606 case DW_OP_deref_size:
8607 return "DW_OP_deref_size";
8608 case DW_OP_xderef_size:
8609 return "DW_OP_xderef_size";
8610 case DW_OP_nop:
8611 return "DW_OP_nop";
b7619582 8612 /* DWARF 3 extensions. */
ed348acc
EZ
8613 case DW_OP_push_object_address:
8614 return "DW_OP_push_object_address";
8615 case DW_OP_call2:
8616 return "DW_OP_call2";
8617 case DW_OP_call4:
8618 return "DW_OP_call4";
8619 case DW_OP_call_ref:
8620 return "DW_OP_call_ref";
b7619582
GF
8621 /* GNU extensions. */
8622 case DW_OP_form_tls_address:
8623 return "DW_OP_form_tls_address";
8624 case DW_OP_call_frame_cfa:
8625 return "DW_OP_call_frame_cfa";
8626 case DW_OP_bit_piece:
8627 return "DW_OP_bit_piece";
ed348acc
EZ
8628 case DW_OP_GNU_push_tls_address:
8629 return "DW_OP_GNU_push_tls_address";
b7619582
GF
8630 /* HP extensions. */
8631 case DW_OP_HP_is_value:
8632 return "DW_OP_HP_is_value";
8633 case DW_OP_HP_fltconst4:
8634 return "DW_OP_HP_fltconst4";
8635 case DW_OP_HP_fltconst8:
8636 return "DW_OP_HP_fltconst8";
8637 case DW_OP_HP_mod_range:
8638 return "DW_OP_HP_mod_range";
8639 case DW_OP_HP_unmod_range:
8640 return "DW_OP_HP_unmod_range";
8641 case DW_OP_HP_tls:
8642 return "DW_OP_HP_tls";
c906108c
SS
8643 default:
8644 return "OP_<unknown>";
8645 }
8646}
8647
8648static char *
fba45db2 8649dwarf_bool_name (unsigned mybool)
c906108c
SS
8650{
8651 if (mybool)
8652 return "TRUE";
8653 else
8654 return "FALSE";
8655}
8656
8657/* Convert a DWARF type code into its string name. */
8658
8659static char *
aa1ee363 8660dwarf_type_encoding_name (unsigned enc)
c906108c
SS
8661{
8662 switch (enc)
8663 {
b7619582
GF
8664 case DW_ATE_void:
8665 return "DW_ATE_void";
c906108c
SS
8666 case DW_ATE_address:
8667 return "DW_ATE_address";
8668 case DW_ATE_boolean:
8669 return "DW_ATE_boolean";
8670 case DW_ATE_complex_float:
8671 return "DW_ATE_complex_float";
8672 case DW_ATE_float:
8673 return "DW_ATE_float";
8674 case DW_ATE_signed:
8675 return "DW_ATE_signed";
8676 case DW_ATE_signed_char:
8677 return "DW_ATE_signed_char";
8678 case DW_ATE_unsigned:
8679 return "DW_ATE_unsigned";
8680 case DW_ATE_unsigned_char:
8681 return "DW_ATE_unsigned_char";
b7619582 8682 /* DWARF 3. */
d9fa45fe
DC
8683 case DW_ATE_imaginary_float:
8684 return "DW_ATE_imaginary_float";
b7619582
GF
8685 case DW_ATE_packed_decimal:
8686 return "DW_ATE_packed_decimal";
8687 case DW_ATE_numeric_string:
8688 return "DW_ATE_numeric_string";
8689 case DW_ATE_edited:
8690 return "DW_ATE_edited";
8691 case DW_ATE_signed_fixed:
8692 return "DW_ATE_signed_fixed";
8693 case DW_ATE_unsigned_fixed:
8694 return "DW_ATE_unsigned_fixed";
8695 case DW_ATE_decimal_float:
8696 return "DW_ATE_decimal_float";
8697 /* HP extensions. */
8698 case DW_ATE_HP_float80:
8699 return "DW_ATE_HP_float80";
8700 case DW_ATE_HP_complex_float80:
8701 return "DW_ATE_HP_complex_float80";
8702 case DW_ATE_HP_float128:
8703 return "DW_ATE_HP_float128";
8704 case DW_ATE_HP_complex_float128:
8705 return "DW_ATE_HP_complex_float128";
8706 case DW_ATE_HP_floathpintel:
8707 return "DW_ATE_HP_floathpintel";
8708 case DW_ATE_HP_imaginary_float80:
8709 return "DW_ATE_HP_imaginary_float80";
8710 case DW_ATE_HP_imaginary_float128:
8711 return "DW_ATE_HP_imaginary_float128";
c906108c
SS
8712 default:
8713 return "DW_ATE_<unknown>";
8714 }
8715}
8716
8717/* Convert a DWARF call frame info operation to its string name. */
8718
8719#if 0
8720static char *
aa1ee363 8721dwarf_cfi_name (unsigned cfi_opc)
c906108c
SS
8722{
8723 switch (cfi_opc)
8724 {
8725 case DW_CFA_advance_loc:
8726 return "DW_CFA_advance_loc";
8727 case DW_CFA_offset:
8728 return "DW_CFA_offset";
8729 case DW_CFA_restore:
8730 return "DW_CFA_restore";
8731 case DW_CFA_nop:
8732 return "DW_CFA_nop";
8733 case DW_CFA_set_loc:
8734 return "DW_CFA_set_loc";
8735 case DW_CFA_advance_loc1:
8736 return "DW_CFA_advance_loc1";
8737 case DW_CFA_advance_loc2:
8738 return "DW_CFA_advance_loc2";
8739 case DW_CFA_advance_loc4:
8740 return "DW_CFA_advance_loc4";
8741 case DW_CFA_offset_extended:
8742 return "DW_CFA_offset_extended";
8743 case DW_CFA_restore_extended:
8744 return "DW_CFA_restore_extended";
8745 case DW_CFA_undefined:
8746 return "DW_CFA_undefined";
8747 case DW_CFA_same_value:
8748 return "DW_CFA_same_value";
8749 case DW_CFA_register:
8750 return "DW_CFA_register";
8751 case DW_CFA_remember_state:
8752 return "DW_CFA_remember_state";
8753 case DW_CFA_restore_state:
8754 return "DW_CFA_restore_state";
8755 case DW_CFA_def_cfa:
8756 return "DW_CFA_def_cfa";
8757 case DW_CFA_def_cfa_register:
8758 return "DW_CFA_def_cfa_register";
8759 case DW_CFA_def_cfa_offset:
8760 return "DW_CFA_def_cfa_offset";
b7619582 8761 /* DWARF 3. */
985cb1a3
JM
8762 case DW_CFA_def_cfa_expression:
8763 return "DW_CFA_def_cfa_expression";
8764 case DW_CFA_expression:
8765 return "DW_CFA_expression";
8766 case DW_CFA_offset_extended_sf:
8767 return "DW_CFA_offset_extended_sf";
8768 case DW_CFA_def_cfa_sf:
8769 return "DW_CFA_def_cfa_sf";
8770 case DW_CFA_def_cfa_offset_sf:
8771 return "DW_CFA_def_cfa_offset_sf";
b7619582
GF
8772 case DW_CFA_val_offset:
8773 return "DW_CFA_val_offset";
8774 case DW_CFA_val_offset_sf:
8775 return "DW_CFA_val_offset_sf";
8776 case DW_CFA_val_expression:
8777 return "DW_CFA_val_expression";
8778 /* SGI/MIPS specific. */
c906108c
SS
8779 case DW_CFA_MIPS_advance_loc8:
8780 return "DW_CFA_MIPS_advance_loc8";
b7619582 8781 /* GNU extensions. */
985cb1a3
JM
8782 case DW_CFA_GNU_window_save:
8783 return "DW_CFA_GNU_window_save";
8784 case DW_CFA_GNU_args_size:
8785 return "DW_CFA_GNU_args_size";
8786 case DW_CFA_GNU_negative_offset_extended:
8787 return "DW_CFA_GNU_negative_offset_extended";
c906108c
SS
8788 default:
8789 return "DW_CFA_<unknown>";
8790 }
8791}
8792#endif
8793
f9aca02d 8794static void
fba45db2 8795dump_die (struct die_info *die)
c906108c
SS
8796{
8797 unsigned int i;
8798
48cd0caa 8799 fprintf_unfiltered (gdb_stderr, "Die: %s (abbrev = %d, offset = %d)\n",
c906108c 8800 dwarf_tag_name (die->tag), die->abbrev, die->offset);
48cd0caa 8801 fprintf_unfiltered (gdb_stderr, "\thas children: %s\n",
639d11d3 8802 dwarf_bool_name (die->child != NULL));
c906108c 8803
48cd0caa 8804 fprintf_unfiltered (gdb_stderr, "\tattributes:\n");
c906108c
SS
8805 for (i = 0; i < die->num_attrs; ++i)
8806 {
48cd0caa 8807 fprintf_unfiltered (gdb_stderr, "\t\t%s (%s) ",
c906108c
SS
8808 dwarf_attr_name (die->attrs[i].name),
8809 dwarf_form_name (die->attrs[i].form));
8810 switch (die->attrs[i].form)
8811 {
8812 case DW_FORM_ref_addr:
8813 case DW_FORM_addr:
48cd0caa 8814 fprintf_unfiltered (gdb_stderr, "address: ");
66bf4b3a 8815 deprecated_print_address_numeric (DW_ADDR (&die->attrs[i]), 1, gdb_stderr);
c906108c
SS
8816 break;
8817 case DW_FORM_block2:
8818 case DW_FORM_block4:
8819 case DW_FORM_block:
8820 case DW_FORM_block1:
48cd0caa 8821 fprintf_unfiltered (gdb_stderr, "block: size %d", DW_BLOCK (&die->attrs[i])->size);
c906108c 8822 break;
10b3939b
DJ
8823 case DW_FORM_ref1:
8824 case DW_FORM_ref2:
8825 case DW_FORM_ref4:
8826 fprintf_unfiltered (gdb_stderr, "constant ref: %ld (adjusted)",
8827 (long) (DW_ADDR (&die->attrs[i])));
8828 break;
c906108c
SS
8829 case DW_FORM_data1:
8830 case DW_FORM_data2:
8831 case DW_FORM_data4:
ce5d95e1 8832 case DW_FORM_data8:
c906108c
SS
8833 case DW_FORM_udata:
8834 case DW_FORM_sdata:
48cd0caa 8835 fprintf_unfiltered (gdb_stderr, "constant: %ld", DW_UNSND (&die->attrs[i]));
c906108c
SS
8836 break;
8837 case DW_FORM_string:
4bdf3d34 8838 case DW_FORM_strp:
48cd0caa 8839 fprintf_unfiltered (gdb_stderr, "string: \"%s\"",
c906108c 8840 DW_STRING (&die->attrs[i])
c5aa993b 8841 ? DW_STRING (&die->attrs[i]) : "");
c906108c
SS
8842 break;
8843 case DW_FORM_flag:
8844 if (DW_UNSND (&die->attrs[i]))
48cd0caa 8845 fprintf_unfiltered (gdb_stderr, "flag: TRUE");
c906108c 8846 else
48cd0caa 8847 fprintf_unfiltered (gdb_stderr, "flag: FALSE");
c906108c 8848 break;
a8329558
KW
8849 case DW_FORM_indirect:
8850 /* the reader will have reduced the indirect form to
8851 the "base form" so this form should not occur */
48cd0caa 8852 fprintf_unfiltered (gdb_stderr, "unexpected attribute form: DW_FORM_indirect");
a8329558 8853 break;
c906108c 8854 default:
48cd0caa 8855 fprintf_unfiltered (gdb_stderr, "unsupported attribute form: %d.",
c5aa993b 8856 die->attrs[i].form);
c906108c 8857 }
48cd0caa 8858 fprintf_unfiltered (gdb_stderr, "\n");
c906108c
SS
8859 }
8860}
8861
f9aca02d 8862static void
fba45db2 8863dump_die_list (struct die_info *die)
c906108c
SS
8864{
8865 while (die)
8866 {
8867 dump_die (die);
639d11d3
DC
8868 if (die->child != NULL)
8869 dump_die_list (die->child);
8870 if (die->sibling != NULL)
8871 dump_die_list (die->sibling);
c906108c
SS
8872 }
8873}
8874
f9aca02d 8875static void
10b3939b
DJ
8876store_in_ref_table (unsigned int offset, struct die_info *die,
8877 struct dwarf2_cu *cu)
c906108c
SS
8878{
8879 int h;
8880 struct die_info *old;
8881
8882 h = (offset % REF_HASH_SIZE);
10b3939b 8883 old = cu->die_ref_table[h];
c906108c 8884 die->next_ref = old;
10b3939b 8885 cu->die_ref_table[h] = die;
c906108c
SS
8886}
8887
8888static unsigned int
e142c38c 8889dwarf2_get_ref_die_offset (struct attribute *attr, struct dwarf2_cu *cu)
c906108c
SS
8890{
8891 unsigned int result = 0;
8892
8893 switch (attr->form)
8894 {
8895 case DW_FORM_ref_addr:
c906108c
SS
8896 case DW_FORM_ref1:
8897 case DW_FORM_ref2:
8898 case DW_FORM_ref4:
613e1657 8899 case DW_FORM_ref8:
c906108c 8900 case DW_FORM_ref_udata:
10b3939b 8901 result = DW_ADDR (attr);
c906108c
SS
8902 break;
8903 default:
4d3c2250 8904 complaint (&symfile_complaints,
e2e0b3e5 8905 _("unsupported die ref attribute form: '%s'"),
4d3c2250 8906 dwarf_form_name (attr->form));
c906108c
SS
8907 }
8908 return result;
8909}
8910
a02abb62
JB
8911/* Return the constant value held by the given attribute. Return -1
8912 if the value held by the attribute is not constant. */
8913
8914static int
8915dwarf2_get_attr_constant_value (struct attribute *attr, int default_value)
8916{
8917 if (attr->form == DW_FORM_sdata)
8918 return DW_SND (attr);
8919 else if (attr->form == DW_FORM_udata
8920 || attr->form == DW_FORM_data1
8921 || attr->form == DW_FORM_data2
8922 || attr->form == DW_FORM_data4
8923 || attr->form == DW_FORM_data8)
8924 return DW_UNSND (attr);
8925 else
8926 {
e2e0b3e5 8927 complaint (&symfile_complaints, _("Attribute value is not a constant (%s)"),
a02abb62
JB
8928 dwarf_form_name (attr->form));
8929 return default_value;
8930 }
8931}
8932
f9aca02d 8933static struct die_info *
10b3939b
DJ
8934follow_die_ref (struct die_info *src_die, struct attribute *attr,
8935 struct dwarf2_cu *cu)
c906108c
SS
8936{
8937 struct die_info *die;
10b3939b 8938 unsigned int offset;
c906108c 8939 int h;
10b3939b
DJ
8940 struct die_info temp_die;
8941 struct dwarf2_cu *target_cu;
8942
8943 offset = dwarf2_get_ref_die_offset (attr, cu);
8944
8945 if (DW_ADDR (attr) < cu->header.offset
8946 || DW_ADDR (attr) >= cu->header.offset + cu->header.length)
8947 {
8948 struct dwarf2_per_cu_data *per_cu;
8949 per_cu = dwarf2_find_containing_comp_unit (DW_ADDR (attr),
8950 cu->objfile);
8951 target_cu = per_cu->cu;
8952 }
8953 else
8954 target_cu = cu;
c906108c
SS
8955
8956 h = (offset % REF_HASH_SIZE);
10b3939b 8957 die = target_cu->die_ref_table[h];
c906108c
SS
8958 while (die)
8959 {
8960 if (die->offset == offset)
10b3939b 8961 return die;
c906108c
SS
8962 die = die->next_ref;
8963 }
10b3939b 8964
8a3fe4f8
AC
8965 error (_("Dwarf Error: Cannot find DIE at 0x%lx referenced from DIE "
8966 "at 0x%lx [in module %s]"),
10b3939b
DJ
8967 (long) src_die->offset, (long) offset, cu->objfile->name);
8968
c906108c
SS
8969 return NULL;
8970}
8971
8972static struct type *
e142c38c
DJ
8973dwarf2_fundamental_type (struct objfile *objfile, int typeid,
8974 struct dwarf2_cu *cu)
c906108c
SS
8975{
8976 if (typeid < 0 || typeid >= FT_NUM_MEMBERS)
8977 {
8a3fe4f8 8978 error (_("Dwarf Error: internal error - invalid fundamental type id %d [in module %s]"),
659b0389 8979 typeid, objfile->name);
c906108c
SS
8980 }
8981
8982 /* Look for this particular type in the fundamental type vector. If
8983 one is not found, create and install one appropriate for the
8984 current language and the current target machine. */
8985
e142c38c 8986 if (cu->ftypes[typeid] == NULL)
c906108c 8987 {
e142c38c 8988 cu->ftypes[typeid] = cu->language_defn->la_fund_type (objfile, typeid);
c906108c
SS
8989 }
8990
e142c38c 8991 return (cu->ftypes[typeid]);
c906108c
SS
8992}
8993
8994/* Decode simple location descriptions.
8995 Given a pointer to a dwarf block that defines a location, compute
8996 the location and return the value.
8997
4cecd739
DJ
8998 NOTE drow/2003-11-18: This function is called in two situations
8999 now: for the address of static or global variables (partial symbols
9000 only) and for offsets into structures which are expected to be
9001 (more or less) constant. The partial symbol case should go away,
9002 and only the constant case should remain. That will let this
9003 function complain more accurately. A few special modes are allowed
9004 without complaint for global variables (for instance, global
9005 register values and thread-local values).
c906108c
SS
9006
9007 A location description containing no operations indicates that the
4cecd739 9008 object is optimized out. The return value is 0 for that case.
6b992462
DJ
9009 FIXME drow/2003-11-16: No callers check for this case any more; soon all
9010 callers will only want a very basic result and this can become a
9011 complaint.
c906108c 9012
c906108c
SS
9013 Note that stack[0] is unused except as a default error return.
9014 Note that stack overflow is not yet handled. */
9015
9016static CORE_ADDR
e7c27a73 9017decode_locdesc (struct dwarf_block *blk, struct dwarf2_cu *cu)
c906108c 9018{
e7c27a73
DJ
9019 struct objfile *objfile = cu->objfile;
9020 struct comp_unit_head *cu_header = &cu->header;
c906108c
SS
9021 int i;
9022 int size = blk->size;
fe1b8b76 9023 gdb_byte *data = blk->data;
c906108c
SS
9024 CORE_ADDR stack[64];
9025 int stacki;
9026 unsigned int bytes_read, unsnd;
fe1b8b76 9027 gdb_byte op;
c906108c
SS
9028
9029 i = 0;
9030 stacki = 0;
9031 stack[stacki] = 0;
c906108c
SS
9032
9033 while (i < size)
9034 {
c906108c
SS
9035 op = data[i++];
9036 switch (op)
9037 {
f1bea926
JM
9038 case DW_OP_lit0:
9039 case DW_OP_lit1:
9040 case DW_OP_lit2:
9041 case DW_OP_lit3:
9042 case DW_OP_lit4:
9043 case DW_OP_lit5:
9044 case DW_OP_lit6:
9045 case DW_OP_lit7:
9046 case DW_OP_lit8:
9047 case DW_OP_lit9:
9048 case DW_OP_lit10:
9049 case DW_OP_lit11:
9050 case DW_OP_lit12:
9051 case DW_OP_lit13:
9052 case DW_OP_lit14:
9053 case DW_OP_lit15:
9054 case DW_OP_lit16:
9055 case DW_OP_lit17:
9056 case DW_OP_lit18:
9057 case DW_OP_lit19:
9058 case DW_OP_lit20:
9059 case DW_OP_lit21:
9060 case DW_OP_lit22:
9061 case DW_OP_lit23:
9062 case DW_OP_lit24:
9063 case DW_OP_lit25:
9064 case DW_OP_lit26:
9065 case DW_OP_lit27:
9066 case DW_OP_lit28:
9067 case DW_OP_lit29:
9068 case DW_OP_lit30:
9069 case DW_OP_lit31:
9070 stack[++stacki] = op - DW_OP_lit0;
9071 break;
9072
c906108c
SS
9073 case DW_OP_reg0:
9074 case DW_OP_reg1:
9075 case DW_OP_reg2:
9076 case DW_OP_reg3:
9077 case DW_OP_reg4:
9078 case DW_OP_reg5:
9079 case DW_OP_reg6:
9080 case DW_OP_reg7:
9081 case DW_OP_reg8:
9082 case DW_OP_reg9:
9083 case DW_OP_reg10:
9084 case DW_OP_reg11:
9085 case DW_OP_reg12:
9086 case DW_OP_reg13:
9087 case DW_OP_reg14:
9088 case DW_OP_reg15:
9089 case DW_OP_reg16:
9090 case DW_OP_reg17:
9091 case DW_OP_reg18:
9092 case DW_OP_reg19:
9093 case DW_OP_reg20:
9094 case DW_OP_reg21:
9095 case DW_OP_reg22:
9096 case DW_OP_reg23:
9097 case DW_OP_reg24:
9098 case DW_OP_reg25:
9099 case DW_OP_reg26:
9100 case DW_OP_reg27:
9101 case DW_OP_reg28:
9102 case DW_OP_reg29:
9103 case DW_OP_reg30:
9104 case DW_OP_reg31:
c906108c 9105 stack[++stacki] = op - DW_OP_reg0;
4cecd739
DJ
9106 if (i < size)
9107 dwarf2_complex_location_expr_complaint ();
c906108c
SS
9108 break;
9109
9110 case DW_OP_regx:
c906108c
SS
9111 unsnd = read_unsigned_leb128 (NULL, (data + i), &bytes_read);
9112 i += bytes_read;
c906108c 9113 stack[++stacki] = unsnd;
4cecd739
DJ
9114 if (i < size)
9115 dwarf2_complex_location_expr_complaint ();
c906108c
SS
9116 break;
9117
9118 case DW_OP_addr:
107d2387 9119 stack[++stacki] = read_address (objfile->obfd, &data[i],
e7c27a73 9120 cu, &bytes_read);
107d2387 9121 i += bytes_read;
c906108c
SS
9122 break;
9123
9124 case DW_OP_const1u:
9125 stack[++stacki] = read_1_byte (objfile->obfd, &data[i]);
9126 i += 1;
9127 break;
9128
9129 case DW_OP_const1s:
9130 stack[++stacki] = read_1_signed_byte (objfile->obfd, &data[i]);
9131 i += 1;
9132 break;
9133
9134 case DW_OP_const2u:
9135 stack[++stacki] = read_2_bytes (objfile->obfd, &data[i]);
9136 i += 2;
9137 break;
9138
9139 case DW_OP_const2s:
9140 stack[++stacki] = read_2_signed_bytes (objfile->obfd, &data[i]);
9141 i += 2;
9142 break;
9143
9144 case DW_OP_const4u:
9145 stack[++stacki] = read_4_bytes (objfile->obfd, &data[i]);
9146 i += 4;
9147 break;
9148
9149 case DW_OP_const4s:
9150 stack[++stacki] = read_4_signed_bytes (objfile->obfd, &data[i]);
9151 i += 4;
9152 break;
9153
9154 case DW_OP_constu:
9155 stack[++stacki] = read_unsigned_leb128 (NULL, (data + i),
c5aa993b 9156 &bytes_read);
c906108c
SS
9157 i += bytes_read;
9158 break;
9159
9160 case DW_OP_consts:
9161 stack[++stacki] = read_signed_leb128 (NULL, (data + i), &bytes_read);
9162 i += bytes_read;
9163 break;
9164
f1bea926
JM
9165 case DW_OP_dup:
9166 stack[stacki + 1] = stack[stacki];
9167 stacki++;
9168 break;
9169
c906108c
SS
9170 case DW_OP_plus:
9171 stack[stacki - 1] += stack[stacki];
9172 stacki--;
9173 break;
9174
9175 case DW_OP_plus_uconst:
9176 stack[stacki] += read_unsigned_leb128 (NULL, (data + i), &bytes_read);
9177 i += bytes_read;
9178 break;
9179
9180 case DW_OP_minus:
f1bea926 9181 stack[stacki - 1] -= stack[stacki];
c906108c
SS
9182 stacki--;
9183 break;
9184
7a292a7a 9185 case DW_OP_deref:
7a292a7a 9186 /* If we're not the last op, then we definitely can't encode
4cecd739
DJ
9187 this using GDB's address_class enum. This is valid for partial
9188 global symbols, although the variable's address will be bogus
9189 in the psymtab. */
7a292a7a 9190 if (i < size)
4d3c2250 9191 dwarf2_complex_location_expr_complaint ();
7a292a7a
SS
9192 break;
9193
9d774e44 9194 case DW_OP_GNU_push_tls_address:
9d774e44
EZ
9195 /* The top of the stack has the offset from the beginning
9196 of the thread control block at which the variable is located. */
9197 /* Nothing should follow this operator, so the top of stack would
9198 be returned. */
4cecd739
DJ
9199 /* This is valid for partial global symbols, but the variable's
9200 address will be bogus in the psymtab. */
9d774e44 9201 if (i < size)
4d3c2250 9202 dwarf2_complex_location_expr_complaint ();
9d774e44
EZ
9203 break;
9204
c906108c 9205 default:
e2e0b3e5 9206 complaint (&symfile_complaints, _("unsupported stack op: '%s'"),
4d3c2250 9207 dwarf_stack_op_name (op));
c906108c
SS
9208 return (stack[stacki]);
9209 }
9210 }
9211 return (stack[stacki]);
9212}
9213
9214/* memory allocation interface */
9215
c906108c 9216static struct dwarf_block *
7b5a2f43 9217dwarf_alloc_block (struct dwarf2_cu *cu)
c906108c
SS
9218{
9219 struct dwarf_block *blk;
9220
9221 blk = (struct dwarf_block *)
7b5a2f43 9222 obstack_alloc (&cu->comp_unit_obstack, sizeof (struct dwarf_block));
c906108c
SS
9223 return (blk);
9224}
9225
9226static struct abbrev_info *
f3dd6933 9227dwarf_alloc_abbrev (struct dwarf2_cu *cu)
c906108c
SS
9228{
9229 struct abbrev_info *abbrev;
9230
f3dd6933
DJ
9231 abbrev = (struct abbrev_info *)
9232 obstack_alloc (&cu->abbrev_obstack, sizeof (struct abbrev_info));
c906108c
SS
9233 memset (abbrev, 0, sizeof (struct abbrev_info));
9234 return (abbrev);
9235}
9236
9237static struct die_info *
fba45db2 9238dwarf_alloc_die (void)
c906108c
SS
9239{
9240 struct die_info *die;
9241
9242 die = (struct die_info *) xmalloc (sizeof (struct die_info));
9243 memset (die, 0, sizeof (struct die_info));
9244 return (die);
9245}
2e276125
JB
9246
9247\f
9248/* Macro support. */
9249
9250
9251/* Return the full name of file number I in *LH's file name table.
9252 Use COMP_DIR as the name of the current directory of the
9253 compilation. The result is allocated using xmalloc; the caller is
9254 responsible for freeing it. */
9255static char *
9256file_full_name (int file, struct line_header *lh, const char *comp_dir)
9257{
6a83a1e6
EZ
9258 /* Is the file number a valid index into the line header's file name
9259 table? Remember that file numbers start with one, not zero. */
9260 if (1 <= file && file <= lh->num_file_names)
9261 {
9262 struct file_entry *fe = &lh->file_names[file - 1];
2e276125 9263
6a83a1e6
EZ
9264 if (IS_ABSOLUTE_PATH (fe->name))
9265 return xstrdup (fe->name);
9266 else
9267 {
9268 const char *dir;
9269 int dir_len;
9270 char *full_name;
9271
9272 if (fe->dir_index)
9273 dir = lh->include_dirs[fe->dir_index - 1];
9274 else
9275 dir = comp_dir;
9276
9277 if (dir)
9278 {
9279 dir_len = strlen (dir);
9280 full_name = xmalloc (dir_len + 1 + strlen (fe->name) + 1);
9281 strcpy (full_name, dir);
9282 full_name[dir_len] = '/';
9283 strcpy (full_name + dir_len + 1, fe->name);
9284 return full_name;
9285 }
9286 else
9287 return xstrdup (fe->name);
9288 }
9289 }
2e276125
JB
9290 else
9291 {
6a83a1e6
EZ
9292 /* The compiler produced a bogus file number. We can at least
9293 record the macro definitions made in the file, even if we
9294 won't be able to find the file by name. */
9295 char fake_name[80];
9296 sprintf (fake_name, "<bad macro file number %d>", file);
2e276125 9297
6a83a1e6
EZ
9298 complaint (&symfile_complaints,
9299 _("bad file number in macro information (%d)"),
9300 file);
2e276125 9301
6a83a1e6 9302 return xstrdup (fake_name);
2e276125
JB
9303 }
9304}
9305
9306
9307static struct macro_source_file *
9308macro_start_file (int file, int line,
9309 struct macro_source_file *current_file,
9310 const char *comp_dir,
9311 struct line_header *lh, struct objfile *objfile)
9312{
9313 /* The full name of this source file. */
9314 char *full_name = file_full_name (file, lh, comp_dir);
9315
9316 /* We don't create a macro table for this compilation unit
9317 at all until we actually get a filename. */
9318 if (! pending_macros)
4a146b47 9319 pending_macros = new_macro_table (&objfile->objfile_obstack,
af5f3db6 9320 objfile->macro_cache);
2e276125
JB
9321
9322 if (! current_file)
9323 /* If we have no current file, then this must be the start_file
9324 directive for the compilation unit's main source file. */
9325 current_file = macro_set_main (pending_macros, full_name);
9326 else
9327 current_file = macro_include (current_file, line, full_name);
9328
9329 xfree (full_name);
9330
9331 return current_file;
9332}
9333
9334
9335/* Copy the LEN characters at BUF to a xmalloc'ed block of memory,
9336 followed by a null byte. */
9337static char *
9338copy_string (const char *buf, int len)
9339{
9340 char *s = xmalloc (len + 1);
9341 memcpy (s, buf, len);
9342 s[len] = '\0';
9343
9344 return s;
9345}
9346
9347
9348static const char *
9349consume_improper_spaces (const char *p, const char *body)
9350{
9351 if (*p == ' ')
9352 {
4d3c2250 9353 complaint (&symfile_complaints,
e2e0b3e5 9354 _("macro definition contains spaces in formal argument list:\n`%s'"),
4d3c2250 9355 body);
2e276125
JB
9356
9357 while (*p == ' ')
9358 p++;
9359 }
9360
9361 return p;
9362}
9363
9364
9365static void
9366parse_macro_definition (struct macro_source_file *file, int line,
9367 const char *body)
9368{
9369 const char *p;
9370
9371 /* The body string takes one of two forms. For object-like macro
9372 definitions, it should be:
9373
9374 <macro name> " " <definition>
9375
9376 For function-like macro definitions, it should be:
9377
9378 <macro name> "() " <definition>
9379 or
9380 <macro name> "(" <arg name> ( "," <arg name> ) * ") " <definition>
9381
9382 Spaces may appear only where explicitly indicated, and in the
9383 <definition>.
9384
9385 The Dwarf 2 spec says that an object-like macro's name is always
9386 followed by a space, but versions of GCC around March 2002 omit
9387 the space when the macro's definition is the empty string.
9388
9389 The Dwarf 2 spec says that there should be no spaces between the
9390 formal arguments in a function-like macro's formal argument list,
9391 but versions of GCC around March 2002 include spaces after the
9392 commas. */
9393
9394
9395 /* Find the extent of the macro name. The macro name is terminated
9396 by either a space or null character (for an object-like macro) or
9397 an opening paren (for a function-like macro). */
9398 for (p = body; *p; p++)
9399 if (*p == ' ' || *p == '(')
9400 break;
9401
9402 if (*p == ' ' || *p == '\0')
9403 {
9404 /* It's an object-like macro. */
9405 int name_len = p - body;
9406 char *name = copy_string (body, name_len);
9407 const char *replacement;
9408
9409 if (*p == ' ')
9410 replacement = body + name_len + 1;
9411 else
9412 {
4d3c2250 9413 dwarf2_macro_malformed_definition_complaint (body);
2e276125
JB
9414 replacement = body + name_len;
9415 }
9416
9417 macro_define_object (file, line, name, replacement);
9418
9419 xfree (name);
9420 }
9421 else if (*p == '(')
9422 {
9423 /* It's a function-like macro. */
9424 char *name = copy_string (body, p - body);
9425 int argc = 0;
9426 int argv_size = 1;
9427 char **argv = xmalloc (argv_size * sizeof (*argv));
9428
9429 p++;
9430
9431 p = consume_improper_spaces (p, body);
9432
9433 /* Parse the formal argument list. */
9434 while (*p && *p != ')')
9435 {
9436 /* Find the extent of the current argument name. */
9437 const char *arg_start = p;
9438
9439 while (*p && *p != ',' && *p != ')' && *p != ' ')
9440 p++;
9441
9442 if (! *p || p == arg_start)
4d3c2250 9443 dwarf2_macro_malformed_definition_complaint (body);
2e276125
JB
9444 else
9445 {
9446 /* Make sure argv has room for the new argument. */
9447 if (argc >= argv_size)
9448 {
9449 argv_size *= 2;
9450 argv = xrealloc (argv, argv_size * sizeof (*argv));
9451 }
9452
9453 argv[argc++] = copy_string (arg_start, p - arg_start);
9454 }
9455
9456 p = consume_improper_spaces (p, body);
9457
9458 /* Consume the comma, if present. */
9459 if (*p == ',')
9460 {
9461 p++;
9462
9463 p = consume_improper_spaces (p, body);
9464 }
9465 }
9466
9467 if (*p == ')')
9468 {
9469 p++;
9470
9471 if (*p == ' ')
9472 /* Perfectly formed definition, no complaints. */
9473 macro_define_function (file, line, name,
9474 argc, (const char **) argv,
9475 p + 1);
9476 else if (*p == '\0')
9477 {
9478 /* Complain, but do define it. */
4d3c2250 9479 dwarf2_macro_malformed_definition_complaint (body);
2e276125
JB
9480 macro_define_function (file, line, name,
9481 argc, (const char **) argv,
9482 p);
9483 }
9484 else
9485 /* Just complain. */
4d3c2250 9486 dwarf2_macro_malformed_definition_complaint (body);
2e276125
JB
9487 }
9488 else
9489 /* Just complain. */
4d3c2250 9490 dwarf2_macro_malformed_definition_complaint (body);
2e276125
JB
9491
9492 xfree (name);
9493 {
9494 int i;
9495
9496 for (i = 0; i < argc; i++)
9497 xfree (argv[i]);
9498 }
9499 xfree (argv);
9500 }
9501 else
4d3c2250 9502 dwarf2_macro_malformed_definition_complaint (body);
2e276125
JB
9503}
9504
9505
9506static void
9507dwarf_decode_macros (struct line_header *lh, unsigned int offset,
9508 char *comp_dir, bfd *abfd,
e7c27a73 9509 struct dwarf2_cu *cu)
2e276125 9510{
fe1b8b76 9511 gdb_byte *mac_ptr, *mac_end;
2e276125
JB
9512 struct macro_source_file *current_file = 0;
9513
6502dd73 9514 if (dwarf2_per_objfile->macinfo_buffer == NULL)
2e276125 9515 {
e2e0b3e5 9516 complaint (&symfile_complaints, _("missing .debug_macinfo section"));
2e276125
JB
9517 return;
9518 }
9519
6502dd73
DJ
9520 mac_ptr = dwarf2_per_objfile->macinfo_buffer + offset;
9521 mac_end = dwarf2_per_objfile->macinfo_buffer
9522 + dwarf2_per_objfile->macinfo_size;
2e276125
JB
9523
9524 for (;;)
9525 {
9526 enum dwarf_macinfo_record_type macinfo_type;
9527
9528 /* Do we at least have room for a macinfo type byte? */
9529 if (mac_ptr >= mac_end)
9530 {
4d3c2250 9531 dwarf2_macros_too_long_complaint ();
2e276125
JB
9532 return;
9533 }
9534
9535 macinfo_type = read_1_byte (abfd, mac_ptr);
9536 mac_ptr++;
9537
9538 switch (macinfo_type)
9539 {
9540 /* A zero macinfo type indicates the end of the macro
9541 information. */
9542 case 0:
9543 return;
9544
9545 case DW_MACINFO_define:
9546 case DW_MACINFO_undef:
9547 {
891d2f0b 9548 unsigned int bytes_read;
2e276125
JB
9549 int line;
9550 char *body;
9551
9552 line = read_unsigned_leb128 (abfd, mac_ptr, &bytes_read);
9553 mac_ptr += bytes_read;
9554 body = read_string (abfd, mac_ptr, &bytes_read);
9555 mac_ptr += bytes_read;
9556
9557 if (! current_file)
4d3c2250 9558 complaint (&symfile_complaints,
e2e0b3e5 9559 _("debug info gives macro %s outside of any file: %s"),
4d3c2250
KB
9560 macinfo_type ==
9561 DW_MACINFO_define ? "definition" : macinfo_type ==
9562 DW_MACINFO_undef ? "undefinition" :
9563 "something-or-other", body);
2e276125
JB
9564 else
9565 {
9566 if (macinfo_type == DW_MACINFO_define)
9567 parse_macro_definition (current_file, line, body);
9568 else if (macinfo_type == DW_MACINFO_undef)
9569 macro_undef (current_file, line, body);
9570 }
9571 }
9572 break;
9573
9574 case DW_MACINFO_start_file:
9575 {
891d2f0b 9576 unsigned int bytes_read;
2e276125
JB
9577 int line, file;
9578
9579 line = read_unsigned_leb128 (abfd, mac_ptr, &bytes_read);
9580 mac_ptr += bytes_read;
9581 file = read_unsigned_leb128 (abfd, mac_ptr, &bytes_read);
9582 mac_ptr += bytes_read;
9583
9584 current_file = macro_start_file (file, line,
9585 current_file, comp_dir,
e7c27a73 9586 lh, cu->objfile);
2e276125
JB
9587 }
9588 break;
9589
9590 case DW_MACINFO_end_file:
9591 if (! current_file)
4d3c2250 9592 complaint (&symfile_complaints,
e2e0b3e5 9593 _("macro debug info has an unmatched `close_file' directive"));
2e276125
JB
9594 else
9595 {
9596 current_file = current_file->included_by;
9597 if (! current_file)
9598 {
9599 enum dwarf_macinfo_record_type next_type;
9600
9601 /* GCC circa March 2002 doesn't produce the zero
9602 type byte marking the end of the compilation
9603 unit. Complain if it's not there, but exit no
9604 matter what. */
9605
9606 /* Do we at least have room for a macinfo type byte? */
9607 if (mac_ptr >= mac_end)
9608 {
4d3c2250 9609 dwarf2_macros_too_long_complaint ();
2e276125
JB
9610 return;
9611 }
9612
9613 /* We don't increment mac_ptr here, so this is just
9614 a look-ahead. */
9615 next_type = read_1_byte (abfd, mac_ptr);
9616 if (next_type != 0)
4d3c2250 9617 complaint (&symfile_complaints,
e2e0b3e5 9618 _("no terminating 0-type entry for macros in `.debug_macinfo' section"));
2e276125
JB
9619
9620 return;
9621 }
9622 }
9623 break;
9624
9625 case DW_MACINFO_vendor_ext:
9626 {
891d2f0b 9627 unsigned int bytes_read;
2e276125
JB
9628 int constant;
9629 char *string;
9630
9631 constant = read_unsigned_leb128 (abfd, mac_ptr, &bytes_read);
9632 mac_ptr += bytes_read;
9633 string = read_string (abfd, mac_ptr, &bytes_read);
9634 mac_ptr += bytes_read;
9635
9636 /* We don't recognize any vendor extensions. */
9637 }
9638 break;
9639 }
9640 }
9641}
8e19ed76
PS
9642
9643/* Check if the attribute's form is a DW_FORM_block*
9644 if so return true else false. */
9645static int
9646attr_form_is_block (struct attribute *attr)
9647{
9648 return (attr == NULL ? 0 :
9649 attr->form == DW_FORM_block1
9650 || attr->form == DW_FORM_block2
9651 || attr->form == DW_FORM_block4
9652 || attr->form == DW_FORM_block);
9653}
4c2df51b
DJ
9654
9655static void
9656dwarf2_symbol_mark_computed (struct attribute *attr, struct symbol *sym,
e7c27a73 9657 struct dwarf2_cu *cu)
4c2df51b 9658{
99bcc461
DJ
9659 if ((attr->form == DW_FORM_data4 || attr->form == DW_FORM_data8)
9660 /* ".debug_loc" may not exist at all, or the offset may be outside
9661 the section. If so, fall through to the complaint in the
9662 other branch. */
9663 && DW_UNSND (attr) < dwarf2_per_objfile->loc_size)
4c2df51b 9664 {
0d53c4c4 9665 struct dwarf2_loclist_baton *baton;
4c2df51b 9666
4a146b47 9667 baton = obstack_alloc (&cu->objfile->objfile_obstack,
0d53c4c4 9668 sizeof (struct dwarf2_loclist_baton));
e7c27a73 9669 baton->objfile = cu->objfile;
4c2df51b 9670
0d53c4c4
DJ
9671 /* We don't know how long the location list is, but make sure we
9672 don't run off the edge of the section. */
6502dd73
DJ
9673 baton->size = dwarf2_per_objfile->loc_size - DW_UNSND (attr);
9674 baton->data = dwarf2_per_objfile->loc_buffer + DW_UNSND (attr);
e7c27a73
DJ
9675 baton->base_address = cu->header.base_address;
9676 if (cu->header.base_known == 0)
0d53c4c4 9677 complaint (&symfile_complaints,
e2e0b3e5 9678 _("Location list used without specifying the CU base address."));
4c2df51b 9679
a67af2b9 9680 SYMBOL_OPS (sym) = &dwarf2_loclist_funcs;
0d53c4c4
DJ
9681 SYMBOL_LOCATION_BATON (sym) = baton;
9682 }
9683 else
9684 {
9685 struct dwarf2_locexpr_baton *baton;
9686
4a146b47 9687 baton = obstack_alloc (&cu->objfile->objfile_obstack,
0d53c4c4 9688 sizeof (struct dwarf2_locexpr_baton));
e7c27a73 9689 baton->objfile = cu->objfile;
0d53c4c4
DJ
9690
9691 if (attr_form_is_block (attr))
9692 {
9693 /* Note that we're just copying the block's data pointer
9694 here, not the actual data. We're still pointing into the
6502dd73
DJ
9695 info_buffer for SYM's objfile; right now we never release
9696 that buffer, but when we do clean up properly this may
9697 need to change. */
0d53c4c4
DJ
9698 baton->size = DW_BLOCK (attr)->size;
9699 baton->data = DW_BLOCK (attr)->data;
9700 }
9701 else
9702 {
9703 dwarf2_invalid_attrib_class_complaint ("location description",
9704 SYMBOL_NATURAL_NAME (sym));
9705 baton->size = 0;
9706 baton->data = NULL;
9707 }
9708
a67af2b9 9709 SYMBOL_OPS (sym) = &dwarf2_locexpr_funcs;
0d53c4c4
DJ
9710 SYMBOL_LOCATION_BATON (sym) = baton;
9711 }
4c2df51b 9712}
6502dd73 9713
ae038cb0 9714/* Locate the compilation unit from CU's objfile which contains the
10b3939b 9715 DIE at OFFSET. Raises an error on failure. */
ae038cb0
DJ
9716
9717static struct dwarf2_per_cu_data *
9718dwarf2_find_containing_comp_unit (unsigned long offset,
9719 struct objfile *objfile)
9720{
9721 struct dwarf2_per_cu_data *this_cu;
9722 int low, high;
9723
ae038cb0
DJ
9724 low = 0;
9725 high = dwarf2_per_objfile->n_comp_units - 1;
9726 while (high > low)
9727 {
9728 int mid = low + (high - low) / 2;
9729 if (dwarf2_per_objfile->all_comp_units[mid]->offset >= offset)
9730 high = mid;
9731 else
9732 low = mid + 1;
9733 }
9734 gdb_assert (low == high);
9735 if (dwarf2_per_objfile->all_comp_units[low]->offset > offset)
9736 {
10b3939b 9737 if (low == 0)
8a3fe4f8
AC
9738 error (_("Dwarf Error: could not find partial DIE containing "
9739 "offset 0x%lx [in module %s]"),
10b3939b
DJ
9740 (long) offset, bfd_get_filename (objfile->obfd));
9741
ae038cb0
DJ
9742 gdb_assert (dwarf2_per_objfile->all_comp_units[low-1]->offset <= offset);
9743 return dwarf2_per_objfile->all_comp_units[low-1];
9744 }
9745 else
9746 {
9747 this_cu = dwarf2_per_objfile->all_comp_units[low];
9748 if (low == dwarf2_per_objfile->n_comp_units - 1
9749 && offset >= this_cu->offset + this_cu->length)
8a3fe4f8 9750 error (_("invalid dwarf2 offset %ld"), offset);
ae038cb0
DJ
9751 gdb_assert (offset < this_cu->offset + this_cu->length);
9752 return this_cu;
9753 }
9754}
9755
10b3939b
DJ
9756/* Locate the compilation unit from OBJFILE which is located at exactly
9757 OFFSET. Raises an error on failure. */
9758
ae038cb0
DJ
9759static struct dwarf2_per_cu_data *
9760dwarf2_find_comp_unit (unsigned long offset, struct objfile *objfile)
9761{
9762 struct dwarf2_per_cu_data *this_cu;
9763 this_cu = dwarf2_find_containing_comp_unit (offset, objfile);
9764 if (this_cu->offset != offset)
8a3fe4f8 9765 error (_("no compilation unit with offset %ld."), offset);
ae038cb0
DJ
9766 return this_cu;
9767}
9768
9769/* Release one cached compilation unit, CU. We unlink it from the tree
9770 of compilation units, but we don't remove it from the read_in_chain;
9771 the caller is responsible for that. */
9772
9773static void
9774free_one_comp_unit (void *data)
9775{
9776 struct dwarf2_cu *cu = data;
9777
9778 if (cu->per_cu != NULL)
9779 cu->per_cu->cu = NULL;
9780 cu->per_cu = NULL;
9781
9782 obstack_free (&cu->comp_unit_obstack, NULL);
10b3939b
DJ
9783 if (cu->dies)
9784 free_die_list (cu->dies);
ae038cb0
DJ
9785
9786 xfree (cu);
9787}
9788
72bf9492 9789/* This cleanup function is passed the address of a dwarf2_cu on the stack
ae038cb0
DJ
9790 when we're finished with it. We can't free the pointer itself, but be
9791 sure to unlink it from the cache. Also release any associated storage
9792 and perform cache maintenance.
72bf9492
DJ
9793
9794 Only used during partial symbol parsing. */
9795
9796static void
9797free_stack_comp_unit (void *data)
9798{
9799 struct dwarf2_cu *cu = data;
9800
9801 obstack_free (&cu->comp_unit_obstack, NULL);
9802 cu->partial_dies = NULL;
ae038cb0
DJ
9803
9804 if (cu->per_cu != NULL)
9805 {
9806 /* This compilation unit is on the stack in our caller, so we
9807 should not xfree it. Just unlink it. */
9808 cu->per_cu->cu = NULL;
9809 cu->per_cu = NULL;
9810
9811 /* If we had a per-cu pointer, then we may have other compilation
9812 units loaded, so age them now. */
9813 age_cached_comp_units ();
9814 }
9815}
9816
9817/* Free all cached compilation units. */
9818
9819static void
9820free_cached_comp_units (void *data)
9821{
9822 struct dwarf2_per_cu_data *per_cu, **last_chain;
9823
9824 per_cu = dwarf2_per_objfile->read_in_chain;
9825 last_chain = &dwarf2_per_objfile->read_in_chain;
9826 while (per_cu != NULL)
9827 {
9828 struct dwarf2_per_cu_data *next_cu;
9829
9830 next_cu = per_cu->cu->read_in_chain;
9831
9832 free_one_comp_unit (per_cu->cu);
9833 *last_chain = next_cu;
9834
9835 per_cu = next_cu;
9836 }
9837}
9838
9839/* Increase the age counter on each cached compilation unit, and free
9840 any that are too old. */
9841
9842static void
9843age_cached_comp_units (void)
9844{
9845 struct dwarf2_per_cu_data *per_cu, **last_chain;
9846
9847 dwarf2_clear_marks (dwarf2_per_objfile->read_in_chain);
9848 per_cu = dwarf2_per_objfile->read_in_chain;
9849 while (per_cu != NULL)
9850 {
9851 per_cu->cu->last_used ++;
9852 if (per_cu->cu->last_used <= dwarf2_max_cache_age)
9853 dwarf2_mark (per_cu->cu);
9854 per_cu = per_cu->cu->read_in_chain;
9855 }
9856
9857 per_cu = dwarf2_per_objfile->read_in_chain;
9858 last_chain = &dwarf2_per_objfile->read_in_chain;
9859 while (per_cu != NULL)
9860 {
9861 struct dwarf2_per_cu_data *next_cu;
9862
9863 next_cu = per_cu->cu->read_in_chain;
9864
9865 if (!per_cu->cu->mark)
9866 {
9867 free_one_comp_unit (per_cu->cu);
9868 *last_chain = next_cu;
9869 }
9870 else
9871 last_chain = &per_cu->cu->read_in_chain;
9872
9873 per_cu = next_cu;
9874 }
9875}
9876
9877/* Remove a single compilation unit from the cache. */
9878
9879static void
9880free_one_cached_comp_unit (void *target_cu)
9881{
9882 struct dwarf2_per_cu_data *per_cu, **last_chain;
9883
9884 per_cu = dwarf2_per_objfile->read_in_chain;
9885 last_chain = &dwarf2_per_objfile->read_in_chain;
9886 while (per_cu != NULL)
9887 {
9888 struct dwarf2_per_cu_data *next_cu;
9889
9890 next_cu = per_cu->cu->read_in_chain;
9891
9892 if (per_cu->cu == target_cu)
9893 {
9894 free_one_comp_unit (per_cu->cu);
9895 *last_chain = next_cu;
9896 break;
9897 }
9898 else
9899 last_chain = &per_cu->cu->read_in_chain;
9900
9901 per_cu = next_cu;
9902 }
9903}
9904
1c379e20
DJ
9905/* A pair of DIE offset and GDB type pointer. We store these
9906 in a hash table separate from the DIEs, and preserve them
9907 when the DIEs are flushed out of cache. */
9908
9909struct dwarf2_offset_and_type
9910{
9911 unsigned int offset;
9912 struct type *type;
9913};
9914
9915/* Hash function for a dwarf2_offset_and_type. */
9916
9917static hashval_t
9918offset_and_type_hash (const void *item)
9919{
9920 const struct dwarf2_offset_and_type *ofs = item;
9921 return ofs->offset;
9922}
9923
9924/* Equality function for a dwarf2_offset_and_type. */
9925
9926static int
9927offset_and_type_eq (const void *item_lhs, const void *item_rhs)
9928{
9929 const struct dwarf2_offset_and_type *ofs_lhs = item_lhs;
9930 const struct dwarf2_offset_and_type *ofs_rhs = item_rhs;
9931 return ofs_lhs->offset == ofs_rhs->offset;
9932}
9933
9934/* Set the type associated with DIE to TYPE. Save it in CU's hash
9935 table if necessary. */
9936
9937static void
9938set_die_type (struct die_info *die, struct type *type, struct dwarf2_cu *cu)
9939{
9940 struct dwarf2_offset_and_type **slot, ofs;
9941
9942 die->type = type;
9943
9944 if (cu->per_cu == NULL)
9945 return;
9946
9947 if (cu->per_cu->type_hash == NULL)
9948 cu->per_cu->type_hash
9949 = htab_create_alloc_ex (cu->header.length / 24,
9950 offset_and_type_hash,
9951 offset_and_type_eq,
9952 NULL,
9953 &cu->objfile->objfile_obstack,
9954 hashtab_obstack_allocate,
9955 dummy_obstack_deallocate);
9956
9957 ofs.offset = die->offset;
9958 ofs.type = type;
9959 slot = (struct dwarf2_offset_and_type **)
9960 htab_find_slot_with_hash (cu->per_cu->type_hash, &ofs, ofs.offset, INSERT);
9961 *slot = obstack_alloc (&cu->objfile->objfile_obstack, sizeof (**slot));
9962 **slot = ofs;
9963}
9964
1c379e20
DJ
9965/* Find the type for DIE in TYPE_HASH, or return NULL if DIE does not
9966 have a saved type. */
9967
9968static struct type *
9969get_die_type (struct die_info *die, htab_t type_hash)
9970{
9971 struct dwarf2_offset_and_type *slot, ofs;
9972
9973 ofs.offset = die->offset;
9974 slot = htab_find_with_hash (type_hash, &ofs, ofs.offset);
9975 if (slot)
9976 return slot->type;
9977 else
9978 return NULL;
9979}
9980
9981/* Restore the types of the DIE tree starting at START_DIE from the hash
9982 table saved in CU. */
9983
9984static void
9985reset_die_and_siblings_types (struct die_info *start_die, struct dwarf2_cu *cu)
9986{
9987 struct die_info *die;
9988
9989 if (cu->per_cu->type_hash == NULL)
9990 return;
9991
9992 for (die = start_die; die != NULL; die = die->sibling)
9993 {
9994 die->type = get_die_type (die, cu->per_cu->type_hash);
9995 if (die->child != NULL)
9996 reset_die_and_siblings_types (die->child, cu);
9997 }
9998}
9999
10b3939b
DJ
10000/* Set the mark field in CU and in every other compilation unit in the
10001 cache that we must keep because we are keeping CU. */
10002
10003/* Add a dependence relationship from CU to REF_PER_CU. */
10004
10005static void
10006dwarf2_add_dependence (struct dwarf2_cu *cu,
10007 struct dwarf2_per_cu_data *ref_per_cu)
10008{
10009 void **slot;
10010
10011 if (cu->dependencies == NULL)
10012 cu->dependencies
10013 = htab_create_alloc_ex (5, htab_hash_pointer, htab_eq_pointer,
10014 NULL, &cu->comp_unit_obstack,
10015 hashtab_obstack_allocate,
10016 dummy_obstack_deallocate);
10017
10018 slot = htab_find_slot (cu->dependencies, ref_per_cu, INSERT);
10019 if (*slot == NULL)
10020 *slot = ref_per_cu;
10021}
1c379e20 10022
ae038cb0
DJ
10023/* Set the mark field in CU and in every other compilation unit in the
10024 cache that we must keep because we are keeping CU. */
10025
10b3939b
DJ
10026static int
10027dwarf2_mark_helper (void **slot, void *data)
10028{
10029 struct dwarf2_per_cu_data *per_cu;
10030
10031 per_cu = (struct dwarf2_per_cu_data *) *slot;
10032 if (per_cu->cu->mark)
10033 return 1;
10034 per_cu->cu->mark = 1;
10035
10036 if (per_cu->cu->dependencies != NULL)
10037 htab_traverse (per_cu->cu->dependencies, dwarf2_mark_helper, NULL);
10038
10039 return 1;
10040}
10041
ae038cb0
DJ
10042static void
10043dwarf2_mark (struct dwarf2_cu *cu)
10044{
10045 if (cu->mark)
10046 return;
10047 cu->mark = 1;
10b3939b
DJ
10048 if (cu->dependencies != NULL)
10049 htab_traverse (cu->dependencies, dwarf2_mark_helper, NULL);
ae038cb0
DJ
10050}
10051
10052static void
10053dwarf2_clear_marks (struct dwarf2_per_cu_data *per_cu)
10054{
10055 while (per_cu)
10056 {
10057 per_cu->cu->mark = 0;
10058 per_cu = per_cu->cu->read_in_chain;
10059 }
72bf9492
DJ
10060}
10061
72bf9492
DJ
10062/* Trivial hash function for partial_die_info: the hash value of a DIE
10063 is its offset in .debug_info for this objfile. */
10064
10065static hashval_t
10066partial_die_hash (const void *item)
10067{
10068 const struct partial_die_info *part_die = item;
10069 return part_die->offset;
10070}
10071
10072/* Trivial comparison function for partial_die_info structures: two DIEs
10073 are equal if they have the same offset. */
10074
10075static int
10076partial_die_eq (const void *item_lhs, const void *item_rhs)
10077{
10078 const struct partial_die_info *part_die_lhs = item_lhs;
10079 const struct partial_die_info *part_die_rhs = item_rhs;
10080 return part_die_lhs->offset == part_die_rhs->offset;
10081}
10082
ae038cb0
DJ
10083static struct cmd_list_element *set_dwarf2_cmdlist;
10084static struct cmd_list_element *show_dwarf2_cmdlist;
10085
10086static void
10087set_dwarf2_cmd (char *args, int from_tty)
10088{
10089 help_list (set_dwarf2_cmdlist, "maintenance set dwarf2 ", -1, gdb_stdout);
10090}
10091
10092static void
10093show_dwarf2_cmd (char *args, int from_tty)
10094{
10095 cmd_show_list (show_dwarf2_cmdlist, from_tty, "");
10096}
10097
6502dd73
DJ
10098void _initialize_dwarf2_read (void);
10099
10100void
10101_initialize_dwarf2_read (void)
10102{
10103 dwarf2_objfile_data_key = register_objfile_data ();
ae038cb0 10104
1bedd215
AC
10105 add_prefix_cmd ("dwarf2", class_maintenance, set_dwarf2_cmd, _("\
10106Set DWARF 2 specific variables.\n\
10107Configure DWARF 2 variables such as the cache size"),
ae038cb0
DJ
10108 &set_dwarf2_cmdlist, "maintenance set dwarf2 ",
10109 0/*allow-unknown*/, &maintenance_set_cmdlist);
10110
1bedd215
AC
10111 add_prefix_cmd ("dwarf2", class_maintenance, show_dwarf2_cmd, _("\
10112Show DWARF 2 specific variables\n\
10113Show DWARF 2 variables such as the cache size"),
ae038cb0
DJ
10114 &show_dwarf2_cmdlist, "maintenance show dwarf2 ",
10115 0/*allow-unknown*/, &maintenance_show_cmdlist);
10116
10117 add_setshow_zinteger_cmd ("max-cache-age", class_obscure,
7915a72c
AC
10118 &dwarf2_max_cache_age, _("\
10119Set the upper bound on the age of cached dwarf2 compilation units."), _("\
10120Show the upper bound on the age of cached dwarf2 compilation units."), _("\
10121A higher limit means that cached compilation units will be stored\n\
10122in memory longer, and more total memory will be used. Zero disables\n\
10123caching, which can slow down startup."),
2c5b56ce 10124 NULL,
920d2a44 10125 show_dwarf2_max_cache_age,
2c5b56ce 10126 &set_dwarf2_cmdlist,
ae038cb0 10127 &show_dwarf2_cmdlist);
6502dd73 10128}
This page took 1.663068 seconds and 4 git commands to generate.