Coverage Report

Created: 2026-03-10 08:46

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/binutils-gdb/bfd/dwarf2.c
Line
Count
Source
1
/* DWARF 2 support.
2
   Copyright (C) 1994-2026 Free Software Foundation, Inc.
3
4
   Adapted from gdb/dwarf2read.c by Gavin Koch of Cygnus Solutions
5
   (gavin@cygnus.com).
6
7
   From the dwarf2read.c header:
8
   Adapted by Gary Funck (gary@intrepid.com), Intrepid Technology,
9
   Inc.  with support from Florida State University (under contract
10
   with the Ada Joint Program Office), and Silicon Graphics, Inc.
11
   Initial contribution by Brent Benson, Harris Computer Systems, Inc.,
12
   based on Fred Fish's (Cygnus Support) implementation of DWARF 1
13
   support in dwarfread.c
14
15
   This file is part of BFD.
16
17
   This program is free software; you can redistribute it and/or modify
18
   it under the terms of the GNU General Public License as published by
19
   the Free Software Foundation; either version 3 of the License, or (at
20
   your option) any later version.
21
22
   This program is distributed in the hope that it will be useful, but
23
   WITHOUT ANY WARRANTY; without even the implied warranty of
24
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
25
   General Public License for more details.
26
27
   You should have received a copy of the GNU General Public License
28
   along with this program; if not, write to the Free Software
29
   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
30
   MA 02110-1301, USA.  */
31
32
#include "sysdep.h"
33
#include "bfd.h"
34
#include "libiberty.h"
35
#include "demangle.h"
36
#include "libbfd.h"
37
#include "elf-bfd.h"
38
#include "dwarf2.h"
39
#include "hashtab.h"
40
#include "splay-tree.h"
41
42
/* The data in the .debug_line statement prologue looks like this.  */
43
44
struct line_head
45
{
46
  bfd_vma total_length;
47
  unsigned short version;
48
  bfd_vma prologue_length;
49
  unsigned char minimum_instruction_length;
50
  unsigned char maximum_ops_per_insn;
51
  unsigned char default_is_stmt;
52
  int line_base;
53
  unsigned char line_range;
54
  unsigned char opcode_base;
55
  unsigned char *standard_opcode_lengths;
56
};
57
58
/* Attributes have a name and a value.  */
59
60
struct attribute
61
{
62
  enum dwarf_attribute name;
63
  enum dwarf_form form;
64
  union
65
  {
66
    char *str;
67
    struct dwarf_block *blk;
68
    uint64_t val;
69
    int64_t sval;
70
  }
71
  u;
72
};
73
74
/* Blocks are a bunch of untyped bytes.  */
75
struct dwarf_block
76
{
77
  unsigned int size;
78
  bfd_byte *data;
79
};
80
81
struct adjusted_section
82
{
83
  asection *section;
84
  bfd_vma adj_vma;
85
  bfd_vma orig_vma;
86
};
87
88
/* A trie to map quickly from address range to compilation unit.
89
90
   This is a fairly standard radix-256 trie, used to quickly locate which
91
   compilation unit any given address belongs to.  Given that each compilation
92
   unit may register hundreds of very small and unaligned ranges (which may
93
   potentially overlap, due to inlining and other concerns), and a large
94
   program may end up containing hundreds of thousands of such ranges, we cannot
95
   scan through them linearly without undue slowdown.
96
97
   We use a hybrid trie to avoid memory explosion: There are two types of trie
98
   nodes, leaves and interior nodes.  (Almost all nodes are leaves, so they
99
   take up the bulk of the memory usage.) Leaves contain a simple array of
100
   ranges (high/low address) and which compilation unit contains those ranges,
101
   and when we get to a leaf, we scan through it linearly.  Interior nodes
102
   contain pointers to 256 other nodes, keyed by the next byte of the address.
103
   So for a 64-bit address like 0x1234567abcd, we would start at the root and go
104
   down child[0x00]->child[0x00]->child[0x01]->child[0x23]->child[0x45] etc.,
105
   until we hit a leaf.  (Nodes are, in general, leaves until they exceed the
106
   default allocation of 16 elements, at which point they are converted to
107
   interior node if possible.) This gives us near-constant lookup times;
108
   the only thing that can be costly is if there are lots of overlapping ranges
109
   within a single 256-byte segment of the binary, in which case we have to
110
   scan through them all to find the best match.
111
112
   For a binary with few ranges, we will in practice only have a single leaf
113
   node at the root, containing a simple array.  Thus, the scheme is efficient
114
   for both small and large binaries.
115
 */
116
117
/* Experiments have shown 16 to be a memory-efficient default leaf size.
118
   The only case where a leaf will hold more memory than this, is at the
119
   bottomost level (covering 256 bytes in the binary), where we'll expand
120
   the leaf to be able to hold more ranges if needed.
121
 */
122
22.1k
#define TRIE_LEAF_SIZE 16
123
124
/* All trie_node pointers will really be trie_leaf or trie_interior,
125
   but they have this common head.  */
126
struct trie_node
127
{
128
  /* If zero, we are an interior node.
129
     Otherwise, how many ranges we have room for in this leaf.  */
130
  unsigned int num_room_in_leaf;
131
};
132
133
struct trie_leaf
134
{
135
  struct trie_node head;
136
  unsigned int num_stored_in_leaf;
137
  struct {
138
    struct comp_unit *unit;
139
    bfd_vma low_pc, high_pc;
140
  } ranges[];
141
};
142
143
struct trie_interior
144
{
145
  struct trie_node head;
146
  struct trie_node *children[256];
147
};
148
149
static struct trie_node *alloc_trie_leaf (bfd *abfd)
150
11.0k
{
151
11.0k
  struct trie_leaf *leaf;
152
11.0k
  size_t amt = sizeof (*leaf) + TRIE_LEAF_SIZE * sizeof (leaf->ranges[0]);
153
11.0k
  leaf = bfd_zalloc (abfd, amt);
154
11.0k
  if (leaf == NULL)
155
0
    return NULL;
156
11.0k
  leaf->head.num_room_in_leaf = TRIE_LEAF_SIZE;
157
11.0k
  return &leaf->head;
158
11.0k
}
159
160
struct addr_range
161
{
162
  bfd_byte *start;
163
  bfd_byte *end;
164
};
165
166
/* Return true if address range do intersect.  */
167
168
static bool
169
addr_range_intersects (struct addr_range *r1, struct addr_range *r2)
170
416
{
171
416
  return (r1->start <= r2->start && r2->start < r1->end)
172
416
    || (r1->start <= (r2->end - 1) && (r2->end - 1) < r1->end);
173
416
}
174
175
/* Compare function for splay tree of addr_ranges.  */
176
177
static int
178
splay_tree_compare_addr_range (splay_tree_key xa, splay_tree_key xb)
179
208
{
180
208
  struct addr_range *r1 = (struct addr_range *) xa;
181
208
  struct addr_range *r2 = (struct addr_range *) xb;
182
183
208
  if (addr_range_intersects (r1, r2) || addr_range_intersects (r2, r1))
184
0
    return 0;
185
208
  else if (r1->end <= r2->start)
186
104
    return -1;
187
104
  else
188
104
    return 1;
189
208
}
190
191
/* Splay tree release function for keys (addr_range).  */
192
193
static void
194
splay_tree_free_addr_range (splay_tree_key key)
195
964
{
196
964
  free ((struct addr_range *)key);
197
964
}
198
199
struct dwarf2_debug_file
200
{
201
  /* The actual bfd from which debug info was loaded.  Might be
202
     different to orig_bfd because of gnu_debuglink sections.  */
203
  bfd *bfd_ptr;
204
205
  /* Pointer to the symbol table.  */
206
  asymbol **syms;
207
208
  /* The current info pointer for the .debug_info section being parsed.  */
209
  bfd_byte *info_ptr;
210
211
  /* A pointer to the memory block allocated for .debug_info sections.  */
212
  bfd_byte *dwarf_info_buffer;
213
214
  /* Length of the loaded .debug_info sections.  */
215
  bfd_size_type dwarf_info_size;
216
217
  /* Pointer to the .debug_abbrev section loaded into memory.  */
218
  bfd_byte *dwarf_abbrev_buffer;
219
220
  /* Length of the loaded .debug_abbrev section.  */
221
  bfd_size_type dwarf_abbrev_size;
222
223
  /* Buffer for decode_line_info.  */
224
  bfd_byte *dwarf_line_buffer;
225
226
  /* Length of the loaded .debug_line section.  */
227
  bfd_size_type dwarf_line_size;
228
229
  /* Pointer to the .debug_str section loaded into memory.  */
230
  bfd_byte *dwarf_str_buffer;
231
232
  /* Length of the loaded .debug_str section.  */
233
  bfd_size_type dwarf_str_size;
234
235
  /* Pointer to the .debug_str_offsets section loaded into memory.  */
236
  bfd_byte *dwarf_str_offsets_buffer;
237
238
  /* Length of the loaded .debug_str_offsets section.  */
239
  bfd_size_type dwarf_str_offsets_size;
240
241
  /* Pointer to the .debug_addr section loaded into memory.  */
242
  bfd_byte *dwarf_addr_buffer;
243
244
  /* Length of the loaded .debug_addr section.  */
245
  bfd_size_type dwarf_addr_size;
246
247
  /* Pointer to the .debug_line_str section loaded into memory.  */
248
  bfd_byte *dwarf_line_str_buffer;
249
250
  /* Length of the loaded .debug_line_str section.  */
251
  bfd_size_type dwarf_line_str_size;
252
253
  /* Pointer to the .debug_ranges section loaded into memory.  */
254
  bfd_byte *dwarf_ranges_buffer;
255
256
  /* Length of the loaded .debug_ranges section.  */
257
  bfd_size_type dwarf_ranges_size;
258
259
  /* Pointer to the .debug_rnglists section loaded into memory.  */
260
  bfd_byte *dwarf_rnglists_buffer;
261
262
  /* Length of the loaded .debug_rnglists section.  */
263
  bfd_size_type dwarf_rnglists_size;
264
265
  /* A list of all previously read comp_units.  */
266
  struct comp_unit *all_comp_units;
267
268
  /* A list of all previously read comp_units with no ranges (yet).  */
269
  struct comp_unit *all_comp_units_without_ranges;
270
271
  /* Last comp unit in list above.  */
272
  struct comp_unit *last_comp_unit;
273
274
  /* Line table at line_offset zero.  */
275
  struct line_info_table *line_table;
276
277
  /* Hash table to map offsets to decoded abbrevs.  */
278
  htab_t abbrev_offsets;
279
280
  /* Root of a trie to map addresses to compilation units.  */
281
  struct trie_node *trie_root;
282
283
  /* Splay tree to map info_ptr address to compilation units.  */
284
  splay_tree comp_unit_tree;
285
};
286
287
struct dwarf2_debug
288
{
289
  /* Names of the debug sections.  */
290
  const struct dwarf_debug_section *debug_sections;
291
292
  /* Per-file stuff.  */
293
  struct dwarf2_debug_file f, alt;
294
295
  /* If the most recent call to bfd_find_nearest_line was given an
296
     address in an inlined function, preserve a pointer into the
297
     calling chain for subsequent calls to bfd_find_inliner_info to
298
     use.  */
299
  struct funcinfo *inliner_chain;
300
301
  /* Section VMAs at the time the stash was built.  */
302
  bfd_vma *sec_vma;
303
  /* Number of sections in the SEC_VMA table.  */
304
  unsigned int sec_vma_count;
305
306
  /* Number of sections whose VMA we must adjust.  */
307
  int adjusted_section_count;
308
309
  /* Array of sections with adjusted VMA.  */
310
  struct adjusted_section *adjusted_sections;
311
312
  /* Used to validate the cached debug data.  */
313
  unsigned int orig_bfd_id;
314
315
  /* Number of times find_line is called.  This is used in
316
     the heuristic for enabling the info hash tables.  */
317
  int info_hash_count;
318
319
4.60k
#define STASH_INFO_HASH_TRIGGER    100
320
321
  /* Hash table mapping symbol names to function infos.  */
322
  struct info_hash_table *funcinfo_hash_table;
323
324
  /* Hash table mapping symbol names to variable infos.  */
325
  struct info_hash_table *varinfo_hash_table;
326
327
  /* Head of comp_unit list in the last hash table update.  */
328
  struct comp_unit *hash_units_head;
329
330
  /* Status of info hash.  */
331
  int info_hash_status;
332
4.60k
#define STASH_INFO_HASH_OFF    0
333
9.20k
#define STASH_INFO_HASH_ON     1
334
0
#define STASH_INFO_HASH_DISABLED   2
335
336
  /* True if we opened bfd_ptr.  */
337
  bool close_on_cleanup;
338
};
339
340
struct arange
341
{
342
  struct arange *next;
343
  bfd_vma low;
344
  bfd_vma high;
345
};
346
347
/* A minimal decoding of DWARF2 compilation units.  We only decode
348
   what's needed to get to the line number information.  */
349
350
struct comp_unit
351
{
352
  /* Chain the previously read compilation units.  */
353
  struct comp_unit *next_unit;
354
355
  /* Chain the previously read compilation units that have no ranges yet.
356
     We scan these separately when we have a trie over the ranges.
357
     Unused if arange.high != 0. */
358
  struct comp_unit *next_unit_without_ranges;
359
360
  /* Likewise, chain the compilation unit read after this one.
361
     The comp units are stored in reversed reading order.  */
362
  struct comp_unit *prev_unit;
363
364
  /* Keep the bfd convenient (for memory allocation).  */
365
  bfd *abfd;
366
367
  /* The lowest and highest addresses contained in this compilation
368
     unit as specified in the compilation unit header.  */
369
  struct arange arange;
370
371
  /* The DW_AT_name attribute (for error messages).  */
372
  char *name;
373
374
  /* The abbrev hash table.  */
375
  struct abbrev_info **abbrevs;
376
377
  /* DW_AT_language.  */
378
  int lang;
379
380
  /* Note that an error was found by comp_unit_find_nearest_line.  */
381
  int error;
382
383
  /* The DW_AT_comp_dir attribute.  */
384
  char *comp_dir;
385
386
  /* TRUE if there is a line number table associated with this comp. unit.  */
387
  int stmtlist;
388
389
  /* Pointer to the current comp_unit so that we can find a given entry
390
     by its reference.  */
391
  bfd_byte *info_ptr_unit;
392
393
  /* The offset into .debug_line of the line number table.  */
394
  unsigned long line_offset;
395
396
  /* Pointer to the first child die for the comp unit.  */
397
  bfd_byte *first_child_die_ptr;
398
399
  /* The end of the comp unit.  */
400
  bfd_byte *end_ptr;
401
402
  /* The decoded line number, NULL if not yet decoded.  */
403
  struct line_info_table *line_table;
404
405
  /* A list of the functions found in this comp. unit.  */
406
  struct funcinfo *function_table;
407
408
  /* A table of function information references searchable by address.  */
409
  struct lookup_funcinfo *lookup_funcinfo_table;
410
411
  /* Number of functions in the function_table and sorted_function_table.  */
412
  bfd_size_type number_of_functions;
413
414
  /* A list of the variables found in this comp. unit.  */
415
  struct varinfo *variable_table;
416
417
  /* Pointers to dwarf2_debug structures.  */
418
  struct dwarf2_debug *stash;
419
  struct dwarf2_debug_file *file;
420
421
  /* DWARF format version for this unit - from unit header.  */
422
  int version;
423
424
  /* Address size for this unit - from unit header.  */
425
  unsigned char addr_size;
426
427
  /* Offset size for this unit - from unit header.  */
428
  unsigned char offset_size;
429
430
  /* Base address for this unit - from DW_AT_low_pc attribute of
431
     DW_TAG_compile_unit DIE */
432
  bfd_vma base_address;
433
434
  /* TRUE if symbols are cached in hash table for faster lookup by name.  */
435
  bool cached;
436
437
  /* Used when iterating over trie leaves to know which units we have
438
     already seen in this iteration.  */
439
  bool mark;
440
441
 /* Base address of debug_addr section.  */
442
  size_t dwarf_addr_offset;
443
444
  /* Base address of string offset table.  */
445
  size_t dwarf_str_offset;
446
};
447
448
/* This data structure holds the information of an abbrev.  */
449
struct abbrev_info
450
{
451
  unsigned int         number;    /* Number identifying abbrev.  */
452
  enum dwarf_tag       tag;   /* DWARF tag.  */
453
  bool                 has_children;  /* TRUE if the abbrev has children.  */
454
  unsigned int         num_attrs; /* Number of attributes.  */
455
  struct attr_abbrev * attrs;   /* An array of attribute descriptions.  */
456
  struct abbrev_info * next;    /* Next in chain.  */
457
};
458
459
struct attr_abbrev
460
{
461
  enum dwarf_attribute name;
462
  enum dwarf_form form;
463
  bfd_vma implicit_const;
464
};
465
466
/* Map of uncompressed DWARF debug section name to compressed one.  It
467
   is terminated by NULL uncompressed_name.  */
468
469
const struct dwarf_debug_section dwarf_debug_sections[] =
470
{
471
  { ".debug_abbrev",    ".zdebug_abbrev" },
472
  { ".debug_aranges",   ".zdebug_aranges" },
473
  { ".debug_frame",   ".zdebug_frame" },
474
  { ".debug_info",    ".zdebug_info" },
475
  { ".debug_info",    ".zdebug_info" },
476
  { ".debug_line",    ".zdebug_line" },
477
  { ".debug_loc",   ".zdebug_loc" },
478
  { ".debug_macinfo",   ".zdebug_macinfo" },
479
  { ".debug_macro",   ".zdebug_macro" },
480
  { ".debug_pubnames",    ".zdebug_pubnames" },
481
  { ".debug_pubtypes",    ".zdebug_pubtypes" },
482
  { ".debug_ranges",    ".zdebug_ranges" },
483
  { ".debug_rnglists",    ".zdebug_rnglist" },
484
  { ".debug_static_func", ".zdebug_static_func" },
485
  { ".debug_static_vars", ".zdebug_static_vars" },
486
  { ".debug_str",   ".zdebug_str", },
487
  { ".debug_str",   ".zdebug_str", },
488
  { ".debug_str_offsets", ".zdebug_str_offsets", },
489
  { ".debug_addr",    ".zdebug_addr", },
490
  { ".debug_line_str",    ".zdebug_line_str", },
491
  { ".debug_types",   ".zdebug_types" },
492
  /* GNU DWARF 1 extensions */
493
  { ".debug_sfnames",   ".zdebug_sfnames" },
494
  { ".debug_srcinfo",   ".zebug_srcinfo" },
495
  /* SGI/MIPS DWARF 2 extensions */
496
  { ".debug_funcnames",   ".zdebug_funcnames" },
497
  { ".debug_typenames",   ".zdebug_typenames" },
498
  { ".debug_varnames",    ".zdebug_varnames" },
499
  { ".debug_weaknames",   ".zdebug_weaknames" },
500
  { NULL,     NULL },
501
};
502
503
/* NB/ Numbers in this enum must match up with indices
504
   into the dwarf_debug_sections[] array above.  */
505
enum dwarf_debug_section_enum
506
{
507
  debug_abbrev = 0,
508
  debug_aranges,
509
  debug_frame,
510
  debug_info,
511
  debug_info_alt,
512
  debug_line,
513
  debug_loc,
514
  debug_macinfo,
515
  debug_macro,
516
  debug_pubnames,
517
  debug_pubtypes,
518
  debug_ranges,
519
  debug_rnglists,
520
  debug_static_func,
521
  debug_static_vars,
522
  debug_str,
523
  debug_str_alt,
524
  debug_str_offsets,
525
  debug_addr,
526
  debug_line_str,
527
  debug_types,
528
  debug_sfnames,
529
  debug_srcinfo,
530
  debug_funcnames,
531
  debug_typenames,
532
  debug_varnames,
533
  debug_weaknames,
534
  debug_max
535
};
536
537
/* A static assertion.  */
538
extern int dwarf_debug_section_assert[ARRAY_SIZE (dwarf_debug_sections)
539
              == debug_max + 1 ? 1 : -1];
540
541
#ifndef ABBREV_HASH_SIZE
542
145k
#define ABBREV_HASH_SIZE 121
543
#endif
544
#ifndef ATTR_ALLOC_CHUNK
545
32.0k
#define ATTR_ALLOC_CHUNK 4
546
#endif
547
548
/* Variable and function hash tables.  This is used to speed up look-up
549
   in lookup_symbol_in_var_table() and lookup_symbol_in_function_table().
550
   In order to share code between variable and function infos, we use
551
   a list of untyped pointer for all variable/function info associated with
552
   a symbol.  We waste a bit of memory for list with one node but that
553
   simplifies the code.  */
554
555
struct info_list_node
556
{
557
  struct info_list_node *next;
558
  void *info;
559
};
560
561
/* Info hash entry.  */
562
struct info_hash_entry
563
{
564
  struct bfd_hash_entry root;
565
  struct info_list_node *head;
566
};
567
568
struct info_hash_table
569
{
570
  struct bfd_hash_table base;
571
};
572
573
/* Function to create a new entry in info hash table.  */
574
575
static struct bfd_hash_entry *
576
info_hash_table_newfunc (struct bfd_hash_entry *entry,
577
       struct bfd_hash_table *table,
578
       const char *string)
579
0
{
580
0
  struct info_hash_entry *ret = (struct info_hash_entry *) entry;
581
582
  /* Allocate the structure if it has not already been allocated by a
583
     derived class.  */
584
0
  if (ret == NULL)
585
0
    {
586
0
      ret = (struct info_hash_entry *) bfd_hash_allocate (table,
587
0
                sizeof (* ret));
588
0
      if (ret == NULL)
589
0
  return NULL;
590
0
    }
591
592
  /* Call the allocation method of the base class.  */
593
0
  ret = ((struct info_hash_entry *)
594
0
   bfd_hash_newfunc ((struct bfd_hash_entry *) ret, table, string));
595
596
  /* Initialize the local fields here.  */
597
0
  if (ret)
598
0
    ret->head = NULL;
599
600
0
  return (struct bfd_hash_entry *) ret;
601
0
}
602
603
/* Function to create a new info hash table.  It returns a pointer to the
604
   newly created table or NULL if there is any error.  We need abfd
605
   solely for memory allocation.  */
606
607
static struct info_hash_table *
608
create_info_hash_table (bfd *abfd)
609
0
{
610
0
  struct info_hash_table *hash_table;
611
612
0
  hash_table = ((struct info_hash_table *)
613
0
    bfd_alloc (abfd, sizeof (struct info_hash_table)));
614
0
  if (!hash_table)
615
0
    return hash_table;
616
617
0
  if (!bfd_hash_table_init (&hash_table->base, info_hash_table_newfunc,
618
0
          sizeof (struct info_hash_entry)))
619
0
    {
620
0
      bfd_release (abfd, hash_table);
621
0
      return NULL;
622
0
    }
623
624
0
  return hash_table;
625
0
}
626
627
/* Insert an info entry into an info hash table.  We do not check of
628
   duplicate entries.  Also, the caller need to guarantee that the
629
   right type of info in inserted as info is passed as a void* pointer.
630
   This function returns true if there is no error.  */
631
632
static bool
633
insert_info_hash_table (struct info_hash_table *hash_table,
634
      const char *key,
635
      void *info,
636
      bool copy_p)
637
0
{
638
0
  struct info_hash_entry *entry;
639
0
  struct info_list_node *node;
640
641
0
  entry = (struct info_hash_entry*) bfd_hash_lookup (&hash_table->base,
642
0
                 key, true, copy_p);
643
0
  if (!entry)
644
0
    return false;
645
646
0
  node = (struct info_list_node *) bfd_hash_allocate (&hash_table->base,
647
0
                  sizeof (*node));
648
0
  if (!node)
649
0
    return false;
650
651
0
  node->info = info;
652
0
  node->next = entry->head;
653
0
  entry->head = node;
654
655
0
  return true;
656
0
}
657
658
/* Look up an info entry list from an info hash table.  Return NULL
659
   if there is none.  */
660
661
static struct info_list_node *
662
lookup_info_hash_table (struct info_hash_table *hash_table, const char *key)
663
0
{
664
0
  struct info_hash_entry *entry;
665
666
0
  entry = (struct info_hash_entry*) bfd_hash_lookup (&hash_table->base, key,
667
0
                 false, false);
668
0
  return entry ? entry->head : NULL;
669
0
}
670
671
/* Read a section into its appropriate place in the dwarf2_debug
672
   struct (indicated by SECTION_BUFFER and SECTION_SIZE).  If SYMS is
673
   not NULL, use bfd_simple_get_relocated_section_contents to read the
674
   section contents, otherwise use bfd_get_section_contents.  Fail if
675
   the located section does not contain at least OFFSET bytes.  */
676
677
static bool
678
read_section (bfd *abfd,
679
        const struct dwarf_debug_section *sec,
680
        asymbol **syms,
681
        uint64_t offset,
682
        bfd_byte **section_buffer,
683
        bfd_size_type *section_size)
684
13.4k
{
685
13.4k
  const char *section_name = sec->uncompressed_name;
686
13.4k
  bfd_byte *contents = *section_buffer;
687
688
  /* The section may have already been read.  */
689
13.4k
  if (contents == NULL)
690
7.13k
    {
691
7.13k
      bfd_size_type amt;
692
7.13k
      asection *msec;
693
694
7.13k
      msec = bfd_get_section_by_name (abfd, section_name);
695
7.13k
      if (msec == NULL)
696
1.25k
  {
697
1.25k
    section_name = sec->compressed_name;
698
1.25k
          msec = bfd_get_section_by_name (abfd, section_name);
699
1.25k
  }
700
7.13k
      if (msec == NULL)
701
1.25k
  {
702
1.25k
    _bfd_error_handler (_("DWARF error: can't find %s section."),
703
1.25k
            sec->uncompressed_name);
704
1.25k
    bfd_set_error (bfd_error_bad_value);
705
1.25k
    return false;
706
1.25k
  }
707
708
5.88k
      if ((msec->flags & SEC_HAS_CONTENTS) == 0)
709
19
  {
710
19
    _bfd_error_handler (_("DWARF error: section %s has no contents"),
711
19
            section_name);
712
19
    bfd_set_error (bfd_error_no_contents);
713
19
    return false;
714
19
  }
715
716
5.86k
      if (bfd_section_size_insane (abfd, msec))
717
901
  {
718
    /* PR 26946 */
719
901
    _bfd_error_handler (_("DWARF error: section %s is too big"),
720
901
            section_name);
721
901
    return false;
722
901
  }
723
4.96k
      amt = bfd_get_section_limit_octets (abfd, msec);
724
4.96k
      *section_size = amt;
725
      /* Paranoia - alloc one extra so that we can make sure a string
726
   section is NUL terminated.  */
727
4.96k
      amt += 1;
728
4.96k
      if (amt == 0)
729
0
  {
730
    /* Paranoia - this should never happen.  */
731
0
    bfd_set_error (bfd_error_no_memory);
732
0
    return false;
733
0
  }
734
4.96k
      contents = (bfd_byte *) bfd_malloc (amt);
735
4.96k
      if (contents == NULL)
736
0
  return false;
737
4.96k
      if (syms
738
4.96k
    ? !bfd_simple_get_relocated_section_contents (abfd, msec, contents,
739
3.64k
              syms)
740
4.96k
    : !bfd_get_section_contents (abfd, msec, contents, 0, *section_size))
741
1.06k
  {
742
1.06k
    free (contents);
743
1.06k
    return false;
744
1.06k
  }
745
3.89k
      contents[*section_size] = 0;
746
3.89k
      *section_buffer = contents;
747
3.89k
    }
748
749
  /* It is possible to get a bad value for the offset into the section
750
     that the client wants.  Validate it here to avoid trouble later.  */
751
10.2k
  if (offset != 0 && offset >= *section_size)
752
377
    {
753
      /* xgettext: c-format */
754
377
      _bfd_error_handler (_("DWARF error: offset (%" PRIu64 ")"
755
377
          " greater than or equal to %s size (%" PRIu64 ")"),
756
377
        (uint64_t) offset, section_name,
757
377
        (uint64_t) *section_size);
758
377
      bfd_set_error (bfd_error_bad_value);
759
377
      return false;
760
377
    }
761
762
9.83k
  return true;
763
10.2k
}
764
765
/* Read dwarf information from a buffer.  */
766
767
static inline uint64_t
768
read_n_bytes (bfd *abfd, bfd_byte **ptr, bfd_byte *end, int n)
769
137k
{
770
137k
  bfd_byte *buf = *ptr;
771
137k
  if (end - buf < n)
772
90
    {
773
90
      *ptr = end;
774
90
      return 0;
775
90
    }
776
137k
  *ptr = buf + n;
777
137k
  return bfd_get (n * 8, abfd, buf);
778
137k
}
779
780
static unsigned int
781
read_1_byte (bfd *abfd, bfd_byte **ptr, bfd_byte *end)
782
111k
{
783
111k
  return read_n_bytes (abfd, ptr, end, 1);
784
111k
}
785
786
static int
787
read_1_signed_byte (bfd *abfd ATTRIBUTE_UNUSED, bfd_byte **ptr, bfd_byte *end)
788
736
{
789
736
  bfd_byte *buf = *ptr;
790
736
  if (end - buf < 1)
791
0
    {
792
0
      *ptr = end;
793
0
      return 0;
794
0
    }
795
736
  *ptr = buf + 1;
796
736
  return bfd_get_signed_8 (abfd, buf);
797
736
}
798
799
static unsigned int
800
read_2_bytes (bfd *abfd, bfd_byte **ptr, bfd_byte *end)
801
3.79k
{
802
3.79k
  return read_n_bytes (abfd, ptr, end, 2);
803
3.79k
}
804
805
static unsigned int
806
read_3_bytes (bfd *abfd, bfd_byte **ptr, bfd_byte *end)
807
64
{
808
64
  unsigned int val = read_1_byte (abfd, ptr, end);
809
64
  val <<= 8;
810
64
  val |= read_1_byte (abfd, ptr, end);
811
64
  val <<= 8;
812
64
  val |= read_1_byte (abfd, ptr, end);
813
64
  if (bfd_little_endian (abfd))
814
64
    val = (((val >> 16) & 0xff)
815
64
     | (val & 0xff00)
816
64
     | ((val & 0xff) << 16));
817
64
  return val;
818
64
}
819
820
static unsigned int
821
read_4_bytes (bfd *abfd, bfd_byte **ptr, bfd_byte *end)
822
21.6k
{
823
21.6k
  return read_n_bytes (abfd, ptr, end, 4);
824
21.6k
}
825
826
static uint64_t
827
read_8_bytes (bfd *abfd, bfd_byte **ptr, bfd_byte *end)
828
702
{
829
702
  return read_n_bytes (abfd, ptr, end, 8);
830
702
}
831
832
static struct dwarf_block *
833
read_blk (bfd *abfd, bfd_byte **ptr, bfd_byte *end, size_t size)
834
1.12k
{
835
1.12k
  bfd_byte *buf = *ptr;
836
1.12k
  struct dwarf_block *block;
837
838
1.12k
  block = (struct dwarf_block *) bfd_alloc (abfd, sizeof (*block));
839
1.12k
  if (block == NULL)
840
0
    return NULL;
841
842
1.12k
  if (size > (size_t) (end - buf))
843
41
    {
844
41
      *ptr = end;
845
41
      block->data = NULL;
846
41
      block->size = 0;
847
41
    }
848
1.08k
  else
849
1.08k
    {
850
1.08k
      *ptr = buf + size;
851
1.08k
      block->data = buf;
852
1.08k
      block->size = size;
853
1.08k
    }
854
1.12k
  return block;
855
1.12k
}
856
857
/* Scans a NUL terminated string starting at *PTR, returning a pointer to it.
858
   Bytes at or beyond BUF_END will not be read.  Returns NULL if the
859
   terminator is not found or if the string is empty.  *PTR is
860
   incremented over the bytes scanned, including the terminator.  */
861
862
static char *
863
read_string (bfd_byte **ptr,
864
       bfd_byte *buf_end)
865
4.50k
{
866
4.50k
  bfd_byte *buf = *ptr;
867
4.50k
  bfd_byte *str = buf;
868
869
33.4k
  while (buf < buf_end)
870
33.3k
    if (*buf++ == 0)
871
4.43k
      {
872
4.43k
  if (str == buf - 1)
873
1.38k
    break;
874
3.05k
  *ptr = buf;
875
3.05k
  return (char *) str;
876
4.43k
      }
877
878
1.45k
  *ptr = buf;
879
1.45k
  return NULL;
880
4.50k
}
881
882
/* Reads an offset from *PTR and then locates the string at this offset
883
   inside the debug string section.  Returns a pointer to the string.
884
   Increments *PTR by the number of bytes read for the offset.  This
885
   value is set even if the function fails.  Bytes at or beyond
886
   BUF_END will not be read.  Returns NULL if there was a problem, or
887
   if the string is empty.  Does not check for NUL termination of the
888
   string.  */
889
890
static char *
891
read_indirect_string (struct comp_unit *unit,
892
          bfd_byte **ptr,
893
          bfd_byte *buf_end)
894
9.15k
{
895
9.15k
  uint64_t offset;
896
9.15k
  struct dwarf2_debug *stash = unit->stash;
897
9.15k
  struct dwarf2_debug_file *file = unit->file;
898
9.15k
  char *str;
899
900
9.15k
  if (unit->offset_size > (size_t) (buf_end - *ptr))
901
4
    {
902
4
      *ptr = buf_end;
903
4
      return NULL;
904
4
    }
905
906
9.15k
  if (unit->offset_size == 4)
907
9.15k
    offset = read_4_bytes (unit->abfd, ptr, buf_end);
908
0
  else
909
0
    offset = read_8_bytes (unit->abfd, ptr, buf_end);
910
911
9.15k
  if (! read_section (unit->abfd, &stash->debug_sections[debug_str],
912
9.15k
          file->syms, offset,
913
9.15k
          &file->dwarf_str_buffer, &file->dwarf_str_size))
914
2.62k
    return NULL;
915
916
6.53k
  str = (char *) file->dwarf_str_buffer + offset;
917
6.53k
  if (*str == '\0')
918
223
    return NULL;
919
6.30k
  return str;
920
6.53k
}
921
922
/* Like read_indirect_string but from .debug_line_str section.  */
923
924
static char *
925
read_indirect_line_string (struct comp_unit *unit,
926
         bfd_byte **ptr,
927
         bfd_byte *buf_end)
928
19
{
929
19
  uint64_t offset;
930
19
  struct dwarf2_debug *stash = unit->stash;
931
19
  struct dwarf2_debug_file *file = unit->file;
932
19
  char *str;
933
934
19
  if (unit->offset_size > (size_t) (buf_end - *ptr))
935
1
    {
936
1
      *ptr = buf_end;
937
1
      return NULL;
938
1
    }
939
940
18
  if (unit->offset_size == 4)
941
18
    offset = read_4_bytes (unit->abfd, ptr, buf_end);
942
0
  else
943
0
    offset = read_8_bytes (unit->abfd, ptr, buf_end);
944
945
18
  if (! read_section (unit->abfd, &stash->debug_sections[debug_line_str],
946
18
          file->syms, offset,
947
18
          &file->dwarf_line_str_buffer,
948
18
          &file->dwarf_line_str_size))
949
18
    return NULL;
950
951
0
  str = (char *) file->dwarf_line_str_buffer + offset;
952
0
  if (*str == '\0')
953
0
    return NULL;
954
0
  return str;
955
0
}
956
957
/* Like read_indirect_string but uses a .debug_str located in
958
   an alternate file pointed to by the .gnu_debugaltlink section.
959
   Used to impement DW_FORM_GNU_strp_alt.  */
960
961
static char *
962
read_alt_indirect_string (struct comp_unit *unit,
963
        bfd_byte **ptr,
964
        bfd_byte *buf_end)
965
0
{
966
0
  uint64_t offset;
967
0
  struct dwarf2_debug *stash = unit->stash;
968
0
  char *str;
969
970
0
  if (unit->offset_size > (size_t) (buf_end - *ptr))
971
0
    {
972
0
      *ptr = buf_end;
973
0
      return NULL;
974
0
    }
975
976
0
  if (unit->offset_size == 4)
977
0
    offset = read_4_bytes (unit->abfd, ptr, buf_end);
978
0
  else
979
0
    offset = read_8_bytes (unit->abfd, ptr, buf_end);
980
981
0
  if (stash->alt.bfd_ptr == NULL)
982
0
    {
983
0
      bfd *debug_bfd;
984
0
      char *debug_filename = bfd_follow_gnu_debugaltlink (unit->abfd, DEBUGDIR);
985
986
0
      if (debug_filename == NULL)
987
0
  return NULL;
988
989
0
      debug_bfd = bfd_openr (debug_filename, NULL);
990
0
      free (debug_filename);
991
0
      if (debug_bfd == NULL)
992
  /* FIXME: Should we report our failure to follow the debuglink ?  */
993
0
  return NULL;
994
995
0
      if (!bfd_check_format (debug_bfd, bfd_object))
996
0
  {
997
0
    bfd_close (debug_bfd);
998
0
    return NULL;
999
0
  }
1000
0
      stash->alt.bfd_ptr = debug_bfd;
1001
0
    }
1002
1003
0
  if (! read_section (unit->stash->alt.bfd_ptr,
1004
0
          stash->debug_sections + debug_str_alt,
1005
0
          stash->alt.syms, offset,
1006
0
          &stash->alt.dwarf_str_buffer,
1007
0
          &stash->alt.dwarf_str_size))
1008
0
    return NULL;
1009
1010
0
  str = (char *) stash->alt.dwarf_str_buffer + offset;
1011
0
  if (*str == '\0')
1012
0
    return NULL;
1013
1014
0
  return str;
1015
0
}
1016
1017
/* Resolve an alternate reference from UNIT at OFFSET.
1018
   Returns a pointer into the loaded alternate CU upon success
1019
   or NULL upon failure.  */
1020
1021
static bfd_byte *
1022
read_alt_indirect_ref (struct comp_unit *unit, uint64_t offset)
1023
0
{
1024
0
  struct dwarf2_debug *stash = unit->stash;
1025
1026
0
  if (stash->alt.bfd_ptr == NULL)
1027
0
    {
1028
0
      bfd *debug_bfd;
1029
0
      char *debug_filename = bfd_follow_gnu_debugaltlink (unit->abfd, DEBUGDIR);
1030
1031
0
      if (debug_filename == NULL)
1032
0
  return NULL;
1033
1034
0
      debug_bfd = bfd_openr (debug_filename, NULL);
1035
0
      free (debug_filename);
1036
0
      if (debug_bfd == NULL)
1037
  /* FIXME: Should we report our failure to follow the debuglink ?  */
1038
0
  return NULL;
1039
1040
0
      if (!bfd_check_format (debug_bfd, bfd_object))
1041
0
  {
1042
0
    bfd_close (debug_bfd);
1043
0
    return NULL;
1044
0
  }
1045
0
      stash->alt.bfd_ptr = debug_bfd;
1046
0
    }
1047
1048
0
  if (! read_section (unit->stash->alt.bfd_ptr,
1049
0
          stash->debug_sections + debug_info_alt,
1050
0
          stash->alt.syms, offset,
1051
0
          &stash->alt.dwarf_info_buffer,
1052
0
          &stash->alt.dwarf_info_size))
1053
0
    return NULL;
1054
1055
0
  return stash->alt.dwarf_info_buffer + offset;
1056
0
}
1057
1058
static uint64_t
1059
read_address (struct comp_unit *unit, bfd_byte **ptr, bfd_byte *buf_end)
1060
10.0k
{
1061
10.0k
  bfd_byte *buf = *ptr;
1062
10.0k
  int signed_vma = 0;
1063
1064
10.0k
  if (bfd_get_flavour (unit->abfd) == bfd_target_elf_flavour)
1065
10.0k
    signed_vma = get_elf_backend_data (unit->abfd)->sign_extend_vma;
1066
1067
10.0k
  if (unit->addr_size > (size_t) (buf_end - buf))
1068
7
    {
1069
7
      *ptr = buf_end;
1070
7
      return 0;
1071
7
    }
1072
1073
10.0k
  *ptr = buf + unit->addr_size;
1074
10.0k
  if (signed_vma)
1075
3
    {
1076
3
      switch (unit->addr_size)
1077
3
  {
1078
3
  case 8:
1079
3
    return bfd_get_signed_64 (unit->abfd, buf);
1080
0
  case 4:
1081
0
    return bfd_get_signed_32 (unit->abfd, buf);
1082
0
  case 2:
1083
0
    return bfd_get_signed_16 (unit->abfd, buf);
1084
0
  default:
1085
0
    abort ();
1086
3
  }
1087
3
    }
1088
10.0k
  else
1089
10.0k
    {
1090
10.0k
      switch (unit->addr_size)
1091
10.0k
  {
1092
9.98k
  case 8:
1093
9.98k
    return bfd_get_64 (unit->abfd, buf);
1094
19
  case 4:
1095
19
    return bfd_get_32 (unit->abfd, buf);
1096
0
  case 2:
1097
0
    return bfd_get_16 (unit->abfd, buf);
1098
0
  default:
1099
0
    abort ();
1100
10.0k
  }
1101
10.0k
    }
1102
10.0k
}
1103
1104
/* Lookup an abbrev_info structure in the abbrev hash table.  */
1105
1106
static struct abbrev_info *
1107
lookup_abbrev (unsigned int number, struct abbrev_info **abbrevs)
1108
16.2k
{
1109
16.2k
  unsigned int hash_number;
1110
16.2k
  struct abbrev_info *abbrev;
1111
1112
16.2k
  hash_number = number % ABBREV_HASH_SIZE;
1113
16.2k
  abbrev = abbrevs[hash_number];
1114
1115
16.3k
  while (abbrev)
1116
11.4k
    {
1117
11.4k
      if (abbrev->number == number)
1118
11.2k
  return abbrev;
1119
141
      else
1120
141
  abbrev = abbrev->next;
1121
11.4k
    }
1122
1123
4.97k
  return NULL;
1124
16.2k
}
1125
1126
/* We keep a hash table to map .debug_abbrev section offsets to the
1127
   array of abbrevs, so that compilation units using the same set of
1128
   abbrevs do not waste memory.  */
1129
1130
struct abbrev_offset_entry
1131
{
1132
  size_t offset;
1133
  struct abbrev_info **abbrevs;
1134
};
1135
1136
static hashval_t
1137
hash_abbrev (const void *p)
1138
1.11k
{
1139
1.11k
  const struct abbrev_offset_entry *ent = p;
1140
1.11k
  return htab_hash_pointer ((void *) ent->offset);
1141
1.11k
}
1142
1143
static int
1144
eq_abbrev (const void *pa, const void *pb)
1145
45
{
1146
45
  const struct abbrev_offset_entry *a = pa;
1147
45
  const struct abbrev_offset_entry *b = pb;
1148
45
  return a->offset == b->offset;
1149
45
}
1150
1151
static void
1152
del_abbrev (void *p)
1153
1.01k
{
1154
1.01k
  struct abbrev_offset_entry *ent = p;
1155
1.01k
  struct abbrev_info **abbrevs = ent->abbrevs;
1156
1.01k
  size_t i;
1157
1158
123k
  for (i = 0; i < ABBREV_HASH_SIZE; i++)
1159
122k
    {
1160
122k
      struct abbrev_info *abbrev = abbrevs[i];
1161
1162
127k
      while (abbrev)
1163
5.05k
  {
1164
5.05k
    free (abbrev->attrs);
1165
5.05k
    abbrev = abbrev->next;
1166
5.05k
  }
1167
122k
    }
1168
1.01k
  free (ent);
1169
1.01k
}
1170
1171
/* In DWARF version 2, the description of the debugging information is
1172
   stored in a separate .debug_abbrev section.  Before we read any
1173
   dies from a section we read in all abbreviations and install them
1174
   in a hash table.  */
1175
1176
static struct abbrev_info**
1177
read_abbrevs (bfd *abfd, uint64_t offset, struct dwarf2_debug *stash,
1178
        struct dwarf2_debug_file *file)
1179
1.11k
{
1180
1.11k
  struct abbrev_info **abbrevs;
1181
1.11k
  bfd_byte *abbrev_ptr;
1182
1.11k
  bfd_byte *abbrev_end;
1183
1.11k
  struct abbrev_info *cur_abbrev;
1184
1.11k
  unsigned int abbrev_number, abbrev_name;
1185
1.11k
  unsigned int abbrev_form, hash_number;
1186
1.11k
  size_t amt;
1187
1.11k
  void **slot;
1188
1.11k
  struct abbrev_offset_entry ent = { offset, NULL };
1189
1190
1.11k
  if (ent.offset != offset)
1191
0
    return NULL;
1192
1193
1.11k
  slot = htab_find_slot (file->abbrev_offsets, &ent, INSERT);
1194
1.11k
  if (slot == NULL)
1195
0
    return NULL;
1196
1.11k
  if (*slot != NULL)
1197
45
    return ((struct abbrev_offset_entry *) (*slot))->abbrevs;
1198
1199
1.06k
  if (! read_section (abfd, &stash->debug_sections[debug_abbrev],
1200
1.06k
          file->syms, offset,
1201
1.06k
          &file->dwarf_abbrev_buffer,
1202
1.06k
          &file->dwarf_abbrev_size))
1203
59
    return NULL;
1204
1205
1.01k
  amt = sizeof (struct abbrev_info*) * ABBREV_HASH_SIZE;
1206
1.01k
  abbrevs = (struct abbrev_info **) bfd_zalloc (abfd, amt);
1207
1.01k
  if (abbrevs == NULL)
1208
0
    return NULL;
1209
1210
1.01k
  abbrev_ptr = file->dwarf_abbrev_buffer + offset;
1211
1.01k
  abbrev_end = file->dwarf_abbrev_buffer + file->dwarf_abbrev_size;
1212
1.01k
  abbrev_number = _bfd_safe_read_leb128 (abfd, &abbrev_ptr,
1213
1.01k
           false, abbrev_end);
1214
1215
  /* Loop until we reach an abbrev number of 0.  */
1216
5.88k
  while (abbrev_number)
1217
5.05k
    {
1218
5.05k
      amt = sizeof (struct abbrev_info);
1219
5.05k
      cur_abbrev = (struct abbrev_info *) bfd_zalloc (abfd, amt);
1220
5.05k
      if (cur_abbrev == NULL)
1221
0
  goto fail;
1222
1223
      /* Read in abbrev header.  */
1224
5.05k
      cur_abbrev->number = abbrev_number;
1225
5.05k
      cur_abbrev->tag = (enum dwarf_tag)
1226
5.05k
  _bfd_safe_read_leb128 (abfd, &abbrev_ptr,
1227
5.05k
             false, abbrev_end);
1228
5.05k
      cur_abbrev->has_children = read_1_byte (abfd, &abbrev_ptr, abbrev_end);
1229
1230
      /* Now read in declarations.  */
1231
5.05k
      for (;;)
1232
29.0k
  {
1233
    /* Initialize it just to avoid a GCC false warning.  */
1234
29.0k
    bfd_vma implicit_const = -1;
1235
1236
29.0k
    abbrev_name = _bfd_safe_read_leb128 (abfd, &abbrev_ptr,
1237
29.0k
                 false, abbrev_end);
1238
29.0k
    abbrev_form = _bfd_safe_read_leb128 (abfd, &abbrev_ptr,
1239
29.0k
                 false, abbrev_end);
1240
29.0k
    if (abbrev_form == DW_FORM_implicit_const)
1241
10
      implicit_const = _bfd_safe_read_leb128 (abfd, &abbrev_ptr,
1242
10
                true, abbrev_end);
1243
29.0k
    if (abbrev_name == 0)
1244
5.05k
      break;
1245
1246
24.0k
    if ((cur_abbrev->num_attrs % ATTR_ALLOC_CHUNK) == 0)
1247
7.99k
      {
1248
7.99k
        struct attr_abbrev *tmp;
1249
1250
7.99k
        amt = cur_abbrev->num_attrs + ATTR_ALLOC_CHUNK;
1251
7.99k
        amt *= sizeof (struct attr_abbrev);
1252
7.99k
        tmp = (struct attr_abbrev *) bfd_realloc (cur_abbrev->attrs, amt);
1253
7.99k
        if (tmp == NULL)
1254
0
    goto fail;
1255
7.99k
        cur_abbrev->attrs = tmp;
1256
7.99k
      }
1257
1258
24.0k
    cur_abbrev->attrs[cur_abbrev->num_attrs].name
1259
24.0k
      = (enum dwarf_attribute) abbrev_name;
1260
24.0k
    cur_abbrev->attrs[cur_abbrev->num_attrs].form
1261
24.0k
      = (enum dwarf_form) abbrev_form;
1262
24.0k
    cur_abbrev->attrs[cur_abbrev->num_attrs].implicit_const
1263
24.0k
      = implicit_const;
1264
24.0k
    ++cur_abbrev->num_attrs;
1265
24.0k
  }
1266
1267
5.05k
      hash_number = abbrev_number % ABBREV_HASH_SIZE;
1268
5.05k
      cur_abbrev->next = abbrevs[hash_number];
1269
5.05k
      abbrevs[hash_number] = cur_abbrev;
1270
1271
      /* Get next abbreviation.
1272
   Under Irix6 the abbreviations for a compilation unit are not
1273
   always properly terminated with an abbrev number of 0.
1274
   Exit loop if we encounter an abbreviation which we have
1275
   already read (which means we are about to read the abbreviations
1276
   for the next compile unit) or if the end of the abbreviation
1277
   table is reached.  */
1278
5.05k
      if ((size_t) (abbrev_ptr - file->dwarf_abbrev_buffer)
1279
5.05k
    >= file->dwarf_abbrev_size)
1280
146
  break;
1281
4.90k
      abbrev_number = _bfd_safe_read_leb128 (abfd, &abbrev_ptr,
1282
4.90k
               false, abbrev_end);
1283
4.90k
      if (lookup_abbrev (abbrev_number, abbrevs) != NULL)
1284
31
  break;
1285
4.90k
    }
1286
1287
1.01k
  *slot = bfd_malloc (sizeof ent);
1288
1.01k
  if (!*slot)
1289
0
    goto fail;
1290
1.01k
  ent.abbrevs = abbrevs;
1291
1.01k
  memcpy (*slot, &ent, sizeof ent);
1292
1.01k
  return abbrevs;
1293
1294
0
 fail:
1295
0
  if (abbrevs != NULL)
1296
0
    {
1297
0
      size_t i;
1298
1299
0
      for (i = 0; i < ABBREV_HASH_SIZE; i++)
1300
0
  {
1301
0
    struct abbrev_info *abbrev = abbrevs[i];
1302
1303
0
    while (abbrev)
1304
0
      {
1305
0
        free (abbrev->attrs);
1306
0
        abbrev = abbrev->next;
1307
0
      }
1308
0
  }
1309
0
      free (abbrevs);
1310
0
    }
1311
0
  return NULL;
1312
1.01k
}
1313
1314
/* Returns true if the form is one which has a string value.  */
1315
1316
static bool
1317
is_str_form (const struct attribute *attr)
1318
3.98k
{
1319
3.98k
  switch (attr->form)
1320
3.98k
    {
1321
19
    case DW_FORM_string:
1322
3.79k
    case DW_FORM_strp:
1323
3.79k
    case DW_FORM_strx:
1324
3.81k
    case DW_FORM_strx1:
1325
3.82k
    case DW_FORM_strx2:
1326
3.84k
    case DW_FORM_strx3:
1327
3.86k
    case DW_FORM_strx4:
1328
3.86k
    case DW_FORM_line_strp:
1329
3.86k
    case DW_FORM_GNU_strp_alt:
1330
3.86k
      return true;
1331
1332
127
    default:
1333
127
      return false;
1334
3.98k
    }
1335
3.98k
}
1336
1337
/* Returns true if the form is one which has an integer value.  */
1338
1339
static bool
1340
is_int_form (const struct attribute *attr)
1341
8.78k
{
1342
8.78k
  switch (attr->form)
1343
8.78k
    {
1344
1.42k
    case DW_FORM_addr:
1345
2.48k
    case DW_FORM_data2:
1346
3.30k
    case DW_FORM_data4:
1347
3.71k
    case DW_FORM_data8:
1348
6.30k
    case DW_FORM_data1:
1349
6.30k
    case DW_FORM_flag:
1350
6.31k
    case DW_FORM_sdata:
1351
6.31k
    case DW_FORM_udata:
1352
6.34k
    case DW_FORM_ref_addr:
1353
6.39k
    case DW_FORM_ref1:
1354
6.49k
    case DW_FORM_ref2:
1355
6.94k
    case DW_FORM_ref4:
1356
6.94k
    case DW_FORM_ref8:
1357
6.95k
    case DW_FORM_ref_udata:
1358
8.39k
    case DW_FORM_sec_offset:
1359
8.61k
    case DW_FORM_flag_present:
1360
8.61k
    case DW_FORM_ref_sig8:
1361
8.61k
    case DW_FORM_addrx:
1362
8.61k
    case DW_FORM_implicit_const:
1363
8.63k
    case DW_FORM_addrx1:
1364
8.63k
    case DW_FORM_addrx2:
1365
8.63k
    case DW_FORM_addrx3:
1366
8.63k
    case DW_FORM_addrx4:
1367
8.63k
    case DW_FORM_GNU_ref_alt:
1368
8.63k
      return true;
1369
1370
146
    default:
1371
146
      return false;
1372
8.78k
    }
1373
8.78k
}
1374
1375
/* Returns true if the form is strx[1-4].  */
1376
1377
static inline bool
1378
is_strx_form (enum dwarf_form form)
1379
7.11k
{
1380
7.11k
  return (form == DW_FORM_strx
1381
7.10k
    || form == DW_FORM_strx1
1382
6.91k
    || form == DW_FORM_strx2
1383
6.88k
    || form == DW_FORM_strx3
1384
6.82k
    || form == DW_FORM_strx4);
1385
7.11k
}
1386
1387
/* Return true if the form is addrx[1-4].  */
1388
1389
static inline bool
1390
is_addrx_form (enum dwarf_form form)
1391
6.87k
{
1392
6.87k
  return (form == DW_FORM_addrx
1393
6.84k
    || form == DW_FORM_addrx1
1394
6.81k
    || form == DW_FORM_addrx2
1395
6.80k
    || form == DW_FORM_addrx3
1396
6.78k
    || form == DW_FORM_addrx4);
1397
6.87k
}
1398
1399
/* Returns the address in .debug_addr section using DW_AT_addr_base.
1400
   Used to implement DW_FORM_addrx*.  */
1401
static uint64_t
1402
read_indexed_address (uint64_t idx, struct comp_unit *unit)
1403
46
{
1404
46
  struct dwarf2_debug *stash = unit->stash;
1405
46
  struct dwarf2_debug_file *file = unit->file;
1406
46
  bfd_byte *info_ptr;
1407
46
  size_t offset;
1408
1409
46
  if (stash == NULL)
1410
0
    return 0;
1411
1412
46
  if (!read_section (unit->abfd, &stash->debug_sections[debug_addr],
1413
46
         file->syms, 0,
1414
46
         &file->dwarf_addr_buffer, &file->dwarf_addr_size))
1415
46
    return 0;
1416
1417
0
  if (_bfd_mul_overflow (idx, unit->addr_size, &offset))
1418
0
    return 0;
1419
1420
0
  offset += unit->dwarf_addr_offset;
1421
0
  if (offset < unit->dwarf_addr_offset
1422
0
      || offset > file->dwarf_addr_size
1423
0
      || file->dwarf_addr_size - offset < unit->addr_size)
1424
0
    return 0;
1425
1426
0
  info_ptr = file->dwarf_addr_buffer + offset;
1427
1428
0
  if (unit->addr_size == 4)
1429
0
    return bfd_get_32 (unit->abfd, info_ptr);
1430
0
  else if (unit->addr_size == 8)
1431
0
    return bfd_get_64 (unit->abfd, info_ptr);
1432
0
  else
1433
0
    return 0;
1434
0
}
1435
1436
/* Returns the string using DW_AT_str_offsets_base.
1437
   Used to implement DW_FORM_strx*.  */
1438
static const char *
1439
read_indexed_string (uint64_t idx, struct comp_unit *unit)
1440
174
{
1441
174
  struct dwarf2_debug *stash = unit->stash;
1442
174
  struct dwarf2_debug_file *file = unit->file;
1443
174
  bfd_byte *info_ptr;
1444
174
  uint64_t str_offset;
1445
174
  size_t offset;
1446
1447
174
  if (stash == NULL)
1448
0
    return NULL;
1449
1450
174
  if (!read_section (unit->abfd, &stash->debug_sections[debug_str],
1451
174
         file->syms, 0,
1452
174
         &file->dwarf_str_buffer, &file->dwarf_str_size))
1453
119
    return NULL;
1454
1455
55
  if (!read_section (unit->abfd, &stash->debug_sections[debug_str_offsets],
1456
55
         file->syms, 0,
1457
55
         &file->dwarf_str_offsets_buffer,
1458
55
         &file->dwarf_str_offsets_size))
1459
55
    return NULL;
1460
1461
0
  if (_bfd_mul_overflow (idx, unit->offset_size, &offset))
1462
0
    return NULL;
1463
1464
0
  offset += unit->dwarf_str_offset;
1465
0
  if (offset < unit->dwarf_str_offset
1466
0
      || offset > file->dwarf_str_offsets_size
1467
0
      || file->dwarf_str_offsets_size - offset < unit->offset_size)
1468
0
    return NULL;
1469
1470
0
  info_ptr = file->dwarf_str_offsets_buffer + offset;
1471
1472
0
  if (unit->offset_size == 4)
1473
0
    str_offset = bfd_get_32 (unit->abfd, info_ptr);
1474
0
  else if (unit->offset_size == 8)
1475
0
    str_offset = bfd_get_64 (unit->abfd, info_ptr);
1476
0
  else
1477
0
    return NULL;
1478
1479
0
  if (str_offset >= file->dwarf_str_size)
1480
0
    return NULL;
1481
0
  return (const char *) file->dwarf_str_buffer + str_offset;
1482
0
}
1483
1484
/* Read and fill in the value of attribute ATTR as described by FORM.
1485
   Read data starting from INFO_PTR, but never at or beyond INFO_PTR_END.
1486
   Returns an updated INFO_PTR taking into account the amount of data read.  */
1487
1488
static bfd_byte *
1489
read_attribute_value (struct attribute *  attr,
1490
          unsigned      form,
1491
          bfd_vma     implicit_const,
1492
          struct comp_unit *  unit,
1493
          bfd_byte *    info_ptr,
1494
          bfd_byte *    info_ptr_end)
1495
44.7k
{
1496
44.7k
  bfd *abfd = unit->abfd;
1497
44.7k
  size_t amt;
1498
1499
44.7k
  if (info_ptr >= info_ptr_end && form != DW_FORM_flag_present)
1500
33
    {
1501
33
      _bfd_error_handler (_("DWARF error: info pointer extends beyond end of attributes"));
1502
33
      bfd_set_error (bfd_error_bad_value);
1503
33
      return NULL;
1504
33
    }
1505
1506
44.7k
  attr->form = (enum dwarf_form) form;
1507
1508
44.7k
  switch (form)
1509
44.7k
    {
1510
5.55k
    case DW_FORM_flag_present:
1511
5.55k
      attr->u.val = 1;
1512
5.55k
      break;
1513
66
    case DW_FORM_ref_addr:
1514
      /* DW_FORM_ref_addr is an address in DWARF2, and an offset in
1515
   DWARF3.  */
1516
66
      if (unit->version >= 3)
1517
65
  {
1518
65
    if (unit->offset_size == 4)
1519
65
      attr->u.val = read_4_bytes (unit->abfd, &info_ptr, info_ptr_end);
1520
0
    else
1521
0
      attr->u.val = read_8_bytes (unit->abfd, &info_ptr, info_ptr_end);
1522
65
    break;
1523
65
  }
1524
      /* FALLTHROUGH */
1525
4.60k
    case DW_FORM_addr:
1526
4.60k
      attr->u.val = read_address (unit, &info_ptr, info_ptr_end);
1527
4.60k
      break;
1528
0
    case DW_FORM_GNU_ref_alt:
1529
1.91k
    case DW_FORM_sec_offset:
1530
1.91k
      if (unit->offset_size == 4)
1531
1.91k
  attr->u.val = read_4_bytes (unit->abfd, &info_ptr, info_ptr_end);
1532
0
      else
1533
0
  attr->u.val = read_8_bytes (unit->abfd, &info_ptr, info_ptr_end);
1534
1.91k
      break;
1535
51
    case DW_FORM_block2:
1536
51
      amt = read_2_bytes (abfd, &info_ptr, info_ptr_end);
1537
51
      attr->u.blk = read_blk (abfd, &info_ptr, info_ptr_end, amt);
1538
51
      if (attr->u.blk == NULL)
1539
0
  return NULL;
1540
51
      break;
1541
51
    case DW_FORM_block4:
1542
19
      amt = read_4_bytes (abfd, &info_ptr, info_ptr_end);
1543
19
      attr->u.blk = read_blk (abfd, &info_ptr, info_ptr_end, amt);
1544
19
      if (attr->u.blk == NULL)
1545
0
  return NULL;
1546
19
      break;
1547
125
    case DW_FORM_ref1:
1548
134
    case DW_FORM_flag:
1549
12.7k
    case DW_FORM_data1:
1550
12.7k
      attr->u.val = read_1_byte (abfd, &info_ptr, info_ptr_end);
1551
12.7k
      break;
1552
68
    case DW_FORM_addrx1:
1553
68
      attr->u.val = read_1_byte (abfd, &info_ptr, info_ptr_end);
1554
      /* dwarf_addr_offset value 0 indicates the attribute DW_AT_addr_base
1555
   is not yet read.  */
1556
68
      if (unit->dwarf_addr_offset != 0)
1557
0
  attr->u.val = read_indexed_address (attr->u.val, unit);
1558
68
      break;
1559
1.64k
    case DW_FORM_data2:
1560
1.75k
    case DW_FORM_ref2:
1561
1.75k
      attr->u.val = read_2_bytes (abfd, &info_ptr, info_ptr_end);
1562
1.75k
      break;
1563
13
    case DW_FORM_addrx2:
1564
13
      attr->u.val = read_2_bytes (abfd, &info_ptr, info_ptr_end);
1565
13
      if (unit->dwarf_addr_offset != 0)
1566
0
  attr->u.val = read_indexed_address (attr->u.val, unit);
1567
13
      break;
1568
19
    case DW_FORM_addrx3:
1569
19
      attr->u.val = read_3_bytes (abfd, &info_ptr, info_ptr_end);
1570
19
      if (unit->dwarf_addr_offset != 0)
1571
1
  attr->u.val = read_indexed_address(attr->u.val, unit);
1572
19
      break;
1573
4.82k
    case DW_FORM_ref4:
1574
6.19k
    case DW_FORM_data4:
1575
6.19k
      attr->u.val = read_4_bytes (abfd, &info_ptr, info_ptr_end);
1576
6.19k
      break;
1577
21
    case DW_FORM_addrx4:
1578
21
      attr->u.val = read_4_bytes (abfd, &info_ptr, info_ptr_end);
1579
21
      if (unit->dwarf_addr_offset != 0)
1580
0
  attr->u.val = read_indexed_address (attr->u.val, unit);
1581
21
      break;
1582
622
    case DW_FORM_data8:
1583
639
    case DW_FORM_ref8:
1584
684
    case DW_FORM_ref_sig8:
1585
684
      attr->u.val = read_8_bytes (abfd, &info_ptr, info_ptr_end);
1586
684
      break;
1587
271
    case DW_FORM_string:
1588
271
      attr->u.str = read_string (&info_ptr, info_ptr_end);
1589
271
      break;
1590
9.15k
    case DW_FORM_strp:
1591
9.15k
      attr->u.str = read_indirect_string (unit, &info_ptr, info_ptr_end);
1592
9.15k
      break;
1593
19
    case DW_FORM_line_strp:
1594
19
      attr->u.str = read_indirect_line_string (unit, &info_ptr, info_ptr_end);
1595
19
      break;
1596
0
    case DW_FORM_GNU_strp_alt:
1597
0
      attr->u.str = read_alt_indirect_string (unit, &info_ptr, info_ptr_end);
1598
0
      break;
1599
120
    case DW_FORM_strx1:
1600
120
      attr->u.val = read_1_byte (abfd, &info_ptr, info_ptr_end);
1601
      /* dwarf_str_offset value 0 indicates the attribute DW_AT_str_offsets_base
1602
   is not yet read.  */
1603
120
      if (unit->dwarf_str_offset != 0)
1604
0
  attr->u.str = (char *) read_indexed_string (attr->u.val, unit);
1605
120
      else
1606
120
  attr->u.str = NULL;
1607
120
      break;
1608
23
    case DW_FORM_strx2:
1609
23
      attr->u.val = read_2_bytes (abfd, &info_ptr, info_ptr_end);
1610
23
      if (unit->dwarf_str_offset != 0)
1611
0
  attr->u.str = (char *) read_indexed_string (attr->u.val, unit);
1612
23
      else
1613
23
  attr->u.str = NULL;
1614
23
      break;
1615
45
    case DW_FORM_strx3:
1616
45
      attr->u.val = read_3_bytes (abfd, &info_ptr, info_ptr_end);
1617
45
      if (unit->dwarf_str_offset != 0)
1618
0
  attr->u.str = (char *) read_indexed_string (attr->u.val, unit);
1619
45
      else
1620
45
  attr->u.str = NULL;
1621
45
      break;
1622
80
    case DW_FORM_strx4:
1623
80
      attr->u.val = read_4_bytes (abfd, &info_ptr, info_ptr_end);
1624
80
      if (unit->dwarf_str_offset != 0)
1625
0
  attr->u.str = (char *) read_indexed_string (attr->u.val, unit);
1626
80
      else
1627
80
  attr->u.str = NULL;
1628
80
      break;
1629
17
    case DW_FORM_strx:
1630
17
      attr->u.val = _bfd_safe_read_leb128 (abfd, &info_ptr,
1631
17
             false, info_ptr_end);
1632
17
      if (unit->dwarf_str_offset != 0)
1633
0
  attr->u.str = (char *) read_indexed_string (attr->u.val, unit);
1634
17
      else
1635
17
  attr->u.str = NULL;
1636
17
      break;
1637
925
    case DW_FORM_exprloc:
1638
968
    case DW_FORM_block:
1639
968
      amt = _bfd_safe_read_leb128 (abfd, &info_ptr,
1640
968
           false, info_ptr_end);
1641
968
      attr->u.blk = read_blk (abfd, &info_ptr, info_ptr_end, amt);
1642
968
      if (attr->u.blk == NULL)
1643
0
  return NULL;
1644
968
      break;
1645
968
    case DW_FORM_block1:
1646
59
      amt = read_1_byte (abfd, &info_ptr, info_ptr_end);
1647
59
      attr->u.blk = read_blk (abfd, &info_ptr, info_ptr_end, amt);
1648
59
      if (attr->u.blk == NULL)
1649
0
  return NULL;
1650
59
      break;
1651
59
    case DW_FORM_sdata:
1652
32
      attr->u.sval = _bfd_safe_read_leb128 (abfd, &info_ptr,
1653
32
              true, info_ptr_end);
1654
32
      break;
1655
1656
19
    case DW_FORM_rnglistx:
1657
51
    case DW_FORM_loclistx:
1658
      /* FIXME: Add support for these forms!  */
1659
      /* Fall through.  */
1660
71
    case DW_FORM_ref_udata:
1661
92
    case DW_FORM_udata:
1662
92
      attr->u.val = _bfd_safe_read_leb128 (abfd, &info_ptr,
1663
92
             false, info_ptr_end);
1664
92
      break;
1665
41
    case DW_FORM_addrx:
1666
41
      attr->u.val = _bfd_safe_read_leb128 (abfd, &info_ptr,
1667
41
             false, info_ptr_end);
1668
41
      if (unit->dwarf_addr_offset != 0)
1669
1
  attr->u.val = read_indexed_address (attr->u.val, unit);
1670
41
      break;
1671
4
    case DW_FORM_indirect:
1672
4
      form = _bfd_safe_read_leb128 (abfd, &info_ptr,
1673
4
            false, info_ptr_end);
1674
4
      if (form == DW_FORM_implicit_const)
1675
0
  implicit_const = _bfd_safe_read_leb128 (abfd, &info_ptr,
1676
0
            true, info_ptr_end);
1677
4
      info_ptr = read_attribute_value (attr, form, implicit_const, unit,
1678
4
               info_ptr, info_ptr_end);
1679
4
      break;
1680
6
    case DW_FORM_implicit_const:
1681
6
      attr->form = DW_FORM_sdata;
1682
6
      attr->u.sval = implicit_const;
1683
6
      break;
1684
24
    case DW_FORM_data16:
1685
      /* This is really a "constant", but there is no way to store that
1686
         so pretend it is a 16 byte block instead.  */
1687
24
      attr->u.blk = read_blk (abfd, &info_ptr, info_ptr_end, 16);
1688
24
      if (attr->u.blk == NULL)
1689
0
  return NULL;
1690
24
      break;
1691
1692
51
    default:
1693
51
      _bfd_error_handler (_("DWARF error: invalid or unhandled FORM value: %#x"),
1694
51
        form);
1695
51
      bfd_set_error (bfd_error_bad_value);
1696
51
      return NULL;
1697
44.7k
    }
1698
44.6k
  return info_ptr;
1699
44.7k
}
1700
1701
/* Read an attribute described by an abbreviated attribute.  */
1702
1703
static bfd_byte *
1704
read_attribute (struct attribute *    attr,
1705
    struct attr_abbrev *  abbrev,
1706
    struct comp_unit *    unit,
1707
    bfd_byte *        info_ptr,
1708
    bfd_byte *        info_ptr_end)
1709
44.6k
{
1710
44.6k
  attr->name = abbrev->name;
1711
44.6k
  info_ptr = read_attribute_value (attr, abbrev->form, abbrev->implicit_const,
1712
44.6k
           unit, info_ptr, info_ptr_end);
1713
44.6k
  return info_ptr;
1714
44.6k
}
1715
1716
/* Return mangling style given LANG.  */
1717
1718
static int
1719
mangle_style (int lang)
1720
1.89k
{
1721
1.89k
  switch (lang)
1722
1.89k
    {
1723
2
    case DW_LANG_Ada83:
1724
40
    case DW_LANG_Ada95:
1725
51
    case DW_LANG_Ada2005:
1726
51
    case DW_LANG_Ada2012:
1727
51
      return DMGL_GNAT;
1728
1729
96
    case DW_LANG_C_plus_plus:
1730
96
    case DW_LANG_C_plus_plus_03:
1731
96
    case DW_LANG_C_plus_plus_11:
1732
96
    case DW_LANG_C_plus_plus_14:
1733
96
    case DW_LANG_C_plus_plus_17:
1734
96
    case DW_LANG_C_plus_plus_20:
1735
96
    case DW_LANG_C_plus_plus_23:
1736
96
      return DMGL_GNU_V3;
1737
1738
71
    case DW_LANG_Java:
1739
71
      return DMGL_JAVA;
1740
1741
140
    case DW_LANG_D:
1742
140
      return DMGL_DLANG;
1743
1744
18
    case DW_LANG_Rust:
1745
18
    case DW_LANG_Rust_old:
1746
18
      return DMGL_RUST;
1747
1748
180
    default:
1749
180
      return DMGL_AUTO;
1750
1751
108
    case DW_LANG_C89:
1752
257
    case DW_LANG_C:
1753
268
    case DW_LANG_Cobol74:
1754
268
    case DW_LANG_Cobol85:
1755
268
    case DW_LANG_Fortran77:
1756
268
    case DW_LANG_Fortran18:
1757
268
    case DW_LANG_Fortran23:
1758
282
    case DW_LANG_Pascal83:
1759
282
    case DW_LANG_PLI:
1760
1.33k
    case DW_LANG_C99:
1761
1.34k
    case DW_LANG_UPC:
1762
1.34k
    case DW_LANG_C11:
1763
1.34k
    case DW_LANG_C17:
1764
1.34k
    case DW_LANG_C23:
1765
1.34k
    case DW_LANG_Mips_Assembler:
1766
1.34k
    case DW_LANG_Assembly:
1767
1.34k
    case DW_LANG_Upc:
1768
1.34k
    case DW_LANG_HP_Basic91:
1769
1.34k
    case DW_LANG_HP_IMacro:
1770
1.34k
    case DW_LANG_HP_Assembler:
1771
1.34k
      return 0;
1772
1.89k
    }
1773
1.89k
}
1774
1775
/* Source line information table routines.  */
1776
1777
2.67k
#define FILE_ALLOC_CHUNK 5
1778
1.47k
#define DIR_ALLOC_CHUNK 5
1779
1780
struct line_info
1781
{
1782
  struct line_info *  prev_line;
1783
  bfd_vma   address;
1784
  char *    filename;
1785
  unsigned int    line;
1786
  unsigned int    column;
1787
  unsigned int    discriminator;
1788
  unsigned char   op_index;
1789
  unsigned char   end_sequence;   /* End of (sequential) code sequence.  */
1790
};
1791
1792
struct fileinfo
1793
{
1794
  char *    name;
1795
  unsigned int    dir;
1796
  unsigned int    time;
1797
  unsigned int    size;
1798
};
1799
1800
struct line_sequence
1801
{
1802
  bfd_vma   low_pc;
1803
  struct line_sequence* prev_sequence;
1804
  struct line_info* last_line;  /* Largest VMA.  */
1805
  struct line_info**  line_info_lookup;
1806
  bfd_size_type   num_lines;
1807
};
1808
1809
struct line_info_table
1810
{
1811
  bfd *     abfd;
1812
  unsigned int    num_files;
1813
  unsigned int    num_dirs;
1814
  unsigned int    num_sequences;
1815
  bool                  use_dir_and_file_0;
1816
  char *    comp_dir;
1817
  char **   dirs;
1818
  struct fileinfo*  files;
1819
  struct line_sequence* sequences;
1820
  struct line_info* lcl_head;   /* Local head; used in 'add_line_info'.  */
1821
};
1822
1823
/* Remember some information about each function.  If the function is
1824
   inlined (DW_TAG_inlined_subroutine) it may have two additional
1825
   attributes, DW_AT_call_file and DW_AT_call_line, which specify the
1826
   source code location where this function was inlined.  */
1827
1828
struct funcinfo
1829
{
1830
  /* Pointer to previous function in list of all functions.  */
1831
  struct funcinfo *prev_func;
1832
  /* Pointer to function one scope higher.  */
1833
  struct funcinfo *caller_func;
1834
  /* Source location file name where caller_func inlines this func.  */
1835
  char *caller_file;
1836
  /* Source location file name.  */
1837
  char *file;
1838
  /* Source location line number where caller_func inlines this func.  */
1839
  int caller_line;
1840
  /* Source location line number.  */
1841
  int line;
1842
  int tag;
1843
  bool is_linkage;
1844
  const char *name;
1845
  struct arange arange;
1846
  /* The offset of the funcinfo from the start of the unit.  */
1847
  uint64_t unit_offset;
1848
};
1849
1850
struct lookup_funcinfo
1851
{
1852
  /* Function information corresponding to this lookup table entry.  */
1853
  struct funcinfo *funcinfo;
1854
1855
  /* The lowest address for this specific function.  */
1856
  bfd_vma low_addr;
1857
1858
  /* The highest address of this function before the lookup table is sorted.
1859
     The highest address of all prior functions after the lookup table is
1860
     sorted, which is used for binary search.  */
1861
  bfd_vma high_addr;
1862
  /* Index of this function, used to ensure qsort is stable.  */
1863
  unsigned int idx;
1864
};
1865
1866
struct varinfo
1867
{
1868
  /* Pointer to previous variable in list of all variables.  */
1869
  struct varinfo *prev_var;
1870
  /* The offset of the varinfo from the start of the unit.  */
1871
  uint64_t unit_offset;
1872
  /* Source location file name.  */
1873
  char *file;
1874
  /* Source location line number.  */
1875
  int line;
1876
  /* The type of this variable.  */
1877
  int tag;
1878
  /* The name of the variable, if it has one.  */
1879
  const char *name;
1880
  /* The address of the variable.  */
1881
  bfd_vma addr;
1882
  /* Is this a stack variable?  */
1883
  bool stack;
1884
};
1885
1886
/* Return TRUE if NEW_LINE should sort after LINE.  */
1887
1888
static inline bool
1889
new_line_sorts_after (struct line_info *new_line, struct line_info *line)
1890
69.4k
{
1891
69.4k
  return (new_line->address > line->address
1892
49.5k
    || (new_line->address == line->address
1893
40.9k
        && new_line->op_index > line->op_index));
1894
69.4k
}
1895
1896
1897
/* Adds a new entry to the line_info list in the line_info_table, ensuring
1898
   that the list is sorted.  Note that the line_info list is sorted from
1899
   highest to lowest VMA (with possible duplicates); that is,
1900
   line_info->prev_line always accesses an equal or smaller VMA.  */
1901
1902
static bool
1903
add_line_info (struct line_info_table *table,
1904
         bfd_vma address,
1905
         unsigned char op_index,
1906
         char *filename,
1907
         unsigned int line,
1908
         unsigned int column,
1909
         unsigned int discriminator,
1910
         int end_sequence)
1911
28.8k
{
1912
28.8k
  size_t amt = sizeof (struct line_info);
1913
28.8k
  struct line_sequence* seq = table->sequences;
1914
28.8k
  struct line_info* info = (struct line_info *) bfd_alloc (table->abfd, amt);
1915
1916
28.8k
  if (info == NULL)
1917
0
    return false;
1918
1919
  /* Set member data of 'info'.  */
1920
28.8k
  info->prev_line = NULL;
1921
28.8k
  info->address = address;
1922
28.8k
  info->op_index = op_index;
1923
28.8k
  info->line = line;
1924
28.8k
  info->column = column;
1925
28.8k
  info->discriminator = discriminator;
1926
28.8k
  info->end_sequence = end_sequence;
1927
1928
28.8k
  if (filename && filename[0])
1929
24.7k
    {
1930
24.7k
      info->filename = (char *) bfd_alloc (table->abfd, strlen (filename) + 1);
1931
24.7k
      if (info->filename == NULL)
1932
0
  return false;
1933
24.7k
      strcpy (info->filename, filename);
1934
24.7k
    }
1935
4.09k
  else
1936
4.09k
    info->filename = NULL;
1937
1938
  /* Find the correct location for 'info'.  Normally we will receive
1939
     new line_info data 1) in order and 2) with increasing VMAs.
1940
     However some compilers break the rules (cf. decode_line_info) and
1941
     so we include some heuristics for quickly finding the correct
1942
     location for 'info'. In particular, these heuristics optimize for
1943
     the common case in which the VMA sequence that we receive is a
1944
     list of locally sorted VMAs such as
1945
       p...z a...j  (where a < j < p < z)
1946
1947
     Note: table->lcl_head is used to head an *actual* or *possible*
1948
     sub-sequence within the list (such as a...j) that is not directly
1949
     headed by table->last_line
1950
1951
     Note: we may receive duplicate entries from 'decode_line_info'.  */
1952
1953
28.8k
  if (seq
1954
28.1k
      && seq->last_line->address == address
1955
6.83k
      && seq->last_line->op_index == op_index
1956
4.60k
      && seq->last_line->end_sequence == end_sequence)
1957
4.57k
    {
1958
      /* We only keep the last entry with the same address and end
1959
   sequence.  See PR ld/4986.  */
1960
4.57k
      if (table->lcl_head == seq->last_line)
1961
985
  table->lcl_head = info;
1962
4.57k
      info->prev_line = seq->last_line->prev_line;
1963
4.57k
      seq->last_line = info;
1964
4.57k
    }
1965
24.2k
  else if (!seq || seq->last_line->end_sequence)
1966
750
    {
1967
      /* Start a new line sequence.  */
1968
750
      amt = sizeof (struct line_sequence);
1969
750
      seq = (struct line_sequence *) bfd_malloc (amt);
1970
750
      if (seq == NULL)
1971
0
  return false;
1972
750
      seq->low_pc = address;
1973
750
      seq->prev_sequence = table->sequences;
1974
750
      seq->last_line = info;
1975
750
      table->lcl_head = info;
1976
750
      table->sequences = seq;
1977
750
      table->num_sequences++;
1978
750
    }
1979
23.4k
  else if (info->end_sequence
1980
22.9k
     || new_line_sorts_after (info, seq->last_line))
1981
21.1k
    {
1982
      /* Normal case: add 'info' to the beginning of the current sequence.  */
1983
21.1k
      info->prev_line = seq->last_line;
1984
21.1k
      seq->last_line = info;
1985
1986
      /* lcl_head: initialize to head a *possible* sequence at the end.  */
1987
21.1k
      if (!table->lcl_head)
1988
0
  table->lcl_head = info;
1989
21.1k
    }
1990
2.37k
  else if (!new_line_sorts_after (info, table->lcl_head)
1991
1.39k
     && (!table->lcl_head->prev_line
1992
1.35k
         || new_line_sorts_after (info, table->lcl_head->prev_line)))
1993
1.07k
    {
1994
      /* Abnormal but easy: lcl_head is the head of 'info'.  */
1995
1.07k
      info->prev_line = table->lcl_head->prev_line;
1996
1.07k
      table->lcl_head->prev_line = info;
1997
1.07k
    }
1998
1.30k
  else
1999
1.30k
    {
2000
      /* Abnormal and hard: Neither 'last_line' nor 'lcl_head'
2001
   are valid heads for 'info'.  Reset 'lcl_head'.  */
2002
1.30k
      struct line_info* li2 = seq->last_line; /* Always non-NULL.  */
2003
1.30k
      struct line_info* li1 = li2->prev_line;
2004
2005
21.4k
      while (li1)
2006
21.3k
  {
2007
21.3k
    if (!new_line_sorts_after (info, li2)
2008
21.3k
        && new_line_sorts_after (info, li1))
2009
1.22k
      break;
2010
2011
20.1k
    li2 = li1; /* always non-NULL */
2012
20.1k
    li1 = li1->prev_line;
2013
20.1k
  }
2014
1.30k
      table->lcl_head = li2;
2015
1.30k
      info->prev_line = table->lcl_head->prev_line;
2016
1.30k
      table->lcl_head->prev_line = info;
2017
1.30k
      if (address < seq->low_pc)
2018
28
  seq->low_pc = address;
2019
1.30k
    }
2020
28.8k
  return true;
2021
28.8k
}
2022
2023
/* Extract a fully qualified filename from a line info table.
2024
   The returned string has been malloc'ed and it is the caller's
2025
   responsibility to free it.  */
2026
2027
static char *
2028
concat_filename (struct line_info_table *table, unsigned int file)
2029
2.25k
{
2030
2.25k
  char *filename;
2031
2032
  /* Pre DWARF-5 entry 0 in the directory and filename tables was not used.
2033
     So in order to save space in the tables used here the info for, eg
2034
     directory 1 is stored in slot 0 of the directory table, directory 2
2035
     in slot 1 and so on.
2036
2037
     Starting with DWARF-5 the 0'th entry is used so there is a one to one
2038
     mapping between DWARF slots and internal table entries.  */
2039
2.25k
  if (! table->use_dir_and_file_0)
2040
2.25k
    {
2041
      /* Pre DWARF-5, FILE == 0 means unknown.  */
2042
2.25k
      if (file == 0)
2043
33
  return strdup ("<unknown>");
2044
2.22k
      -- file;
2045
2.22k
    }
2046
2047
2.22k
  if (table == NULL || file >= table->num_files)
2048
146
    {
2049
146
      _bfd_error_handler
2050
146
  (_("DWARF error: mangled line number section (bad file number)"));
2051
146
      return strdup ("<unknown>");
2052
146
    }
2053
2054
2.07k
  filename = table->files[file].name;
2055
2056
2.07k
  if (filename == NULL)
2057
0
    return strdup ("<unknown>");
2058
2059
2.07k
  if (!IS_ABSOLUTE_PATH (filename))
2060
2.07k
    {
2061
2.07k
      char *dir_name = NULL;
2062
2.07k
      char *subdir_name = NULL;
2063
2.07k
      char *name;
2064
2.07k
      size_t len;
2065
2.07k
      unsigned int dir = table->files[file].dir;
2066
2067
2.07k
      if (!table->use_dir_and_file_0)
2068
2.07k
  --dir;
2069
      /* Wrapping from 0 to -1u above gives the intended result with
2070
   the test below of leaving subdir_name NULL for pre-DWARF5 dir
2071
   of 0.  */
2072
      /* PR 17512: file: 0317e960, file: 7f3d2e4b.  */
2073
2.07k
      if (dir < table->num_dirs)
2074
561
  subdir_name = table->dirs[dir];
2075
2076
2.07k
      if (!subdir_name || !IS_ABSOLUTE_PATH (subdir_name))
2077
1.78k
  dir_name = table->comp_dir;
2078
2079
2.07k
      if (!dir_name)
2080
752
  {
2081
752
    dir_name = subdir_name;
2082
752
    subdir_name = NULL;
2083
752
  }
2084
2085
2.07k
      if (!dir_name)
2086
428
  return strdup (filename);
2087
2088
1.64k
      len = strlen (dir_name) + strlen (filename) + 2;
2089
2090
1.64k
      if (subdir_name)
2091
237
  {
2092
237
    len += strlen (subdir_name) + 1;
2093
237
    name = (char *) bfd_malloc (len);
2094
237
    if (name)
2095
237
      sprintf (name, "%s/%s/%s", dir_name, subdir_name, filename);
2096
237
  }
2097
1.40k
      else
2098
1.40k
  {
2099
1.40k
    name = (char *) bfd_malloc (len);
2100
1.40k
    if (name)
2101
1.40k
      sprintf (name, "%s/%s", dir_name, filename);
2102
1.40k
  }
2103
2104
1.64k
      return name;
2105
2.07k
    }
2106
2107
8
  return strdup (filename);
2108
2.07k
}
2109
2110
/* Number of bits in a bfd_vma.  */
2111
14.3k
#define VMA_BITS (8 * sizeof (bfd_vma))
2112
2113
/* Check whether [low1, high1) can be combined with [low2, high2),
2114
   i.e., they touch or overlap.  */
2115
2116
static bool
2117
ranges_overlap (bfd_vma low1,
2118
    bfd_vma high1,
2119
    bfd_vma low2,
2120
    bfd_vma high2)
2121
3.69k
{
2122
3.69k
  if (low1 == low2 || high1 == high2)
2123
889
    return true;
2124
2125
  /* Sort so that low1 is below low2. */
2126
2.80k
  if (low1 > low2)
2127
2.28k
    {
2128
2.28k
      bfd_vma tmp;
2129
2130
2.28k
      tmp = low1;
2131
2.28k
      low1 = low2;
2132
2.28k
      low2 = tmp;
2133
2134
2.28k
      tmp = high1;
2135
2.28k
      high1 = high2;
2136
2.28k
      high2 = tmp;
2137
2.28k
    }
2138
2139
  /* We touch iff low2 == high1.
2140
     We overlap iff low2 is within [low1, high1). */
2141
2.80k
  return low2 <= high1;
2142
3.69k
}
2143
2144
/* Insert an address range in the trie mapping addresses to compilation units.
2145
   Will return the new trie node (usually the same as is being sent in, but
2146
   in case of a leaf-to-interior conversion, or expansion of a leaf, it may be
2147
   different), or NULL on failure.  */
2148
2149
static struct trie_node *
2150
insert_arange_in_trie (bfd *abfd,
2151
           struct trie_node *trie,
2152
           bfd_vma trie_pc,
2153
           unsigned int trie_pc_bits,
2154
           struct comp_unit *unit,
2155
           bfd_vma low_pc,
2156
           bfd_vma high_pc)
2157
3.52k
{
2158
3.52k
  bfd_vma clamped_low_pc, clamped_high_pc;
2159
3.52k
  int ch, from_ch, to_ch;
2160
3.52k
  bool is_full_leaf = false;
2161
3.52k
  bool splitting_leaf_will_help = false;
2162
2163
  /* See if we can extend any of the existing ranges.  This merging
2164
     isn't perfect (if merging opens up the possibility of merging two existing
2165
     ranges, we won't find them), but it takes the majority of the cases.  */
2166
3.52k
  if (trie->num_room_in_leaf > 0)
2167
3.52k
    {
2168
3.52k
      struct trie_leaf *leaf = (struct trie_leaf *) trie;
2169
3.52k
      unsigned int i;
2170
2171
4.89k
      for (i = 0; i < leaf->num_stored_in_leaf; ++i)
2172
3.70k
  {
2173
3.70k
    if (leaf->ranges[i].unit == unit
2174
3.69k
        && ranges_overlap (low_pc, high_pc,
2175
3.69k
         leaf->ranges[i].low_pc,
2176
3.69k
         leaf->ranges[i].high_pc))
2177
2.32k
      {
2178
2.32k
        if (low_pc < leaf->ranges[i].low_pc)
2179
65
    leaf->ranges[i].low_pc = low_pc;
2180
2.32k
        if (high_pc > leaf->ranges[i].high_pc)
2181
320
    leaf->ranges[i].high_pc = high_pc;
2182
2.32k
        return trie;
2183
2.32k
      }
2184
3.70k
  }
2185
2186
1.19k
      is_full_leaf = leaf->num_stored_in_leaf == trie->num_room_in_leaf;
2187
2188
1.19k
      if (is_full_leaf && trie_pc_bits < VMA_BITS)
2189
0
  {
2190
    /* See if we have at least one leaf that does _not_ cover the
2191
       entire bucket, so that splitting will actually reduce the number
2192
       of elements in at least one of the child nodes.  (For simplicity,
2193
       we don't test the range we're inserting, but it will be counted
2194
       on the next insertion where we're full, if any.)   */
2195
0
    bfd_vma bucket_high_pc =
2196
0
      trie_pc + ((bfd_vma) -1 >> trie_pc_bits);  /* Inclusive.  */
2197
0
    for (i = 0; i < leaf->num_stored_in_leaf; ++i)
2198
0
      {
2199
0
        if (leaf->ranges[i].low_pc > trie_pc
2200
0
      || leaf->ranges[i].high_pc <= bucket_high_pc)
2201
0
    {
2202
0
      splitting_leaf_will_help = true;
2203
0
      break;
2204
0
    }
2205
0
      }
2206
0
  }
2207
1.19k
    }
2208
2209
  /* If we're a leaf with no more room and we're _not_ at the bottom,
2210
     convert to an interior node.  */
2211
1.19k
  if (is_full_leaf && splitting_leaf_will_help)
2212
0
    {
2213
0
      const struct trie_leaf *leaf = (struct trie_leaf *) trie;
2214
0
      unsigned int i;
2215
2216
0
      trie = bfd_zalloc (abfd, sizeof (struct trie_interior));
2217
0
      if (!trie)
2218
0
  return NULL;
2219
0
      is_full_leaf = false;
2220
2221
      /* TODO: If we wanted to save a little more memory at the cost of
2222
   complexity, we could have reused the old leaf node as one of the
2223
   children of the new interior node, instead of throwing it away.  */
2224
0
      for (i = 0; i < leaf->num_stored_in_leaf; ++i)
2225
0
        {
2226
0
    if (!insert_arange_in_trie (abfd, trie, trie_pc, trie_pc_bits,
2227
0
              leaf->ranges[i].unit, leaf->ranges[i].low_pc,
2228
0
              leaf->ranges[i].high_pc))
2229
0
      return NULL;
2230
0
  }
2231
0
    }
2232
2233
  /* If we're a leaf with no more room and we _are_ at the bottom
2234
     (or splitting it won't help), we have no choice but to just
2235
     make it larger.  */
2236
1.19k
  if (is_full_leaf)
2237
0
    {
2238
0
      const struct trie_leaf *leaf = (struct trie_leaf *) trie;
2239
0
      unsigned int new_room_in_leaf = trie->num_room_in_leaf * 2;
2240
0
      struct trie_leaf *new_leaf;
2241
0
      size_t amt = sizeof (*leaf) + new_room_in_leaf * sizeof (leaf->ranges[0]);
2242
0
      new_leaf = bfd_zalloc (abfd, amt);
2243
0
      new_leaf->head.num_room_in_leaf = new_room_in_leaf;
2244
0
      new_leaf->num_stored_in_leaf = leaf->num_stored_in_leaf;
2245
2246
0
      memcpy (new_leaf->ranges,
2247
0
        leaf->ranges,
2248
0
        leaf->num_stored_in_leaf * sizeof (leaf->ranges[0]));
2249
0
      trie = &new_leaf->head;
2250
0
      is_full_leaf = false;
2251
2252
      /* Now the insert below will go through.  */
2253
0
    }
2254
2255
  /* If we're a leaf (now with room), we can just insert at the end.  */
2256
1.19k
  if (trie->num_room_in_leaf > 0)
2257
1.19k
    {
2258
1.19k
      struct trie_leaf *leaf = (struct trie_leaf *) trie;
2259
2260
1.19k
      unsigned int i = leaf->num_stored_in_leaf++;
2261
1.19k
      leaf->ranges[i].unit = unit;
2262
1.19k
      leaf->ranges[i].low_pc = low_pc;
2263
1.19k
      leaf->ranges[i].high_pc = high_pc;
2264
1.19k
      return trie;
2265
1.19k
    }
2266
2267
  /* Now we are definitely an interior node, so recurse into all
2268
     the relevant buckets.  */
2269
2270
  /* Clamp the range to the current trie bucket.  */
2271
0
  clamped_low_pc = low_pc;
2272
0
  clamped_high_pc = high_pc;
2273
0
  if (trie_pc_bits > 0)
2274
0
    {
2275
0
      bfd_vma bucket_high_pc =
2276
0
  trie_pc + ((bfd_vma) -1 >> trie_pc_bits);  /* Inclusive.  */
2277
0
      if (clamped_low_pc < trie_pc)
2278
0
  clamped_low_pc = trie_pc;
2279
0
      if (clamped_high_pc > bucket_high_pc)
2280
0
  clamped_high_pc = bucket_high_pc;
2281
0
    }
2282
2283
  /* Insert the ranges in all buckets that it spans.  */
2284
0
  from_ch = (clamped_low_pc >> (VMA_BITS - trie_pc_bits - 8)) & 0xff;
2285
0
  to_ch = ((clamped_high_pc - 1) >> (VMA_BITS - trie_pc_bits - 8)) & 0xff;
2286
0
  for (ch = from_ch; ch <= to_ch; ++ch)
2287
0
    {
2288
0
      struct trie_interior *interior = (struct trie_interior *) trie;
2289
0
      struct trie_node *child = interior->children[ch];
2290
2291
0
      if (child == NULL)
2292
0
        {
2293
0
    child = alloc_trie_leaf (abfd);
2294
0
    if (!child)
2295
0
      return NULL;
2296
0
  }
2297
0
      bfd_vma bucket = (bfd_vma) ch << (VMA_BITS - trie_pc_bits - 8);
2298
0
      child = insert_arange_in_trie (abfd,
2299
0
             child,
2300
0
             trie_pc + bucket,
2301
0
             trie_pc_bits + 8,
2302
0
             unit,
2303
0
             low_pc,
2304
0
             high_pc);
2305
0
      if (!child)
2306
0
  return NULL;
2307
2308
0
      interior->children[ch] = child;
2309
0
    }
2310
2311
0
    return trie;
2312
0
}
2313
2314
static bool
2315
arange_add (struct comp_unit *unit, struct arange *first_arange,
2316
      struct trie_node **trie_root, bfd_vma low_pc, bfd_vma high_pc)
2317
3.62k
{
2318
3.62k
  struct arange *arange;
2319
2320
  /* Ignore empty ranges.  */
2321
3.62k
  if (low_pc == high_pc)
2322
103
    return true;
2323
2324
3.52k
  if (trie_root != NULL)
2325
3.52k
    {
2326
3.52k
      *trie_root = insert_arange_in_trie (unit->file->bfd_ptr,
2327
3.52k
            *trie_root,
2328
3.52k
            0,
2329
3.52k
            0,
2330
3.52k
            unit,
2331
3.52k
            low_pc,
2332
3.52k
            high_pc);
2333
3.52k
      if (*trie_root == NULL)
2334
0
  return false;
2335
3.52k
    }
2336
2337
  /* If the first arange is empty, use it.  */
2338
3.52k
  if (first_arange->high == 0)
2339
1.63k
    {
2340
1.63k
      first_arange->low = low_pc;
2341
1.63k
      first_arange->high = high_pc;
2342
1.63k
      return true;
2343
1.63k
    }
2344
2345
  /* Next see if we can cheaply extend an existing range.  */
2346
1.88k
  arange = first_arange;
2347
1.88k
  do
2348
6.36k
    {
2349
6.36k
      if (low_pc == arange->high)
2350
10
  {
2351
10
    arange->high = high_pc;
2352
10
    return true;
2353
10
  }
2354
6.35k
      if (high_pc == arange->low)
2355
29
  {
2356
29
    arange->low = low_pc;
2357
29
    return true;
2358
29
  }
2359
6.32k
      arange = arange->next;
2360
6.32k
    }
2361
6.32k
  while (arange);
2362
2363
  /* Need to allocate a new arange and insert it into the arange list.
2364
     Order isn't significant, so just insert after the first arange.  */
2365
1.84k
  arange = (struct arange *) bfd_alloc (unit->abfd, sizeof (*arange));
2366
1.84k
  if (arange == NULL)
2367
0
    return false;
2368
1.84k
  arange->low = low_pc;
2369
1.84k
  arange->high = high_pc;
2370
1.84k
  arange->next = first_arange->next;
2371
1.84k
  first_arange->next = arange;
2372
1.84k
  return true;
2373
1.84k
}
2374
2375
/* Compare function for line sequences.  */
2376
2377
static int
2378
compare_sequences (const void* a, const void* b)
2379
98
{
2380
98
  const struct line_sequence* seq1 = a;
2381
98
  const struct line_sequence* seq2 = b;
2382
2383
  /* Sort by low_pc as the primary key.  */
2384
98
  if (seq1->low_pc < seq2->low_pc)
2385
16
    return -1;
2386
82
  if (seq1->low_pc > seq2->low_pc)
2387
32
    return 1;
2388
2389
  /* If low_pc values are equal, sort in reverse order of
2390
     high_pc, so that the largest region comes first.  */
2391
50
  if (seq1->last_line->address < seq2->last_line->address)
2392
2
    return 1;
2393
48
  if (seq1->last_line->address > seq2->last_line->address)
2394
25
    return -1;
2395
2396
23
  if (seq1->last_line->op_index < seq2->last_line->op_index)
2397
7
    return 1;
2398
16
  if (seq1->last_line->op_index > seq2->last_line->op_index)
2399
15
    return -1;
2400
2401
  /* num_lines is initially an index, to make the sort stable.  */
2402
1
  if (seq1->num_lines < seq2->num_lines)
2403
1
    return -1;
2404
0
  if (seq1->num_lines > seq2->num_lines)
2405
0
    return 1;
2406
0
  return 0;
2407
0
}
2408
2409
/* Construct the line information table for quick lookup.  */
2410
2411
static bool
2412
build_line_info_table (struct line_info_table *  table,
2413
           struct line_sequence *    seq)
2414
1.43k
{
2415
1.43k
  size_t amt;
2416
1.43k
  struct line_info **line_info_lookup;
2417
1.43k
  struct line_info *each_line;
2418
1.43k
  unsigned int num_lines;
2419
1.43k
  unsigned int line_index;
2420
2421
1.43k
  if (seq->line_info_lookup != NULL)
2422
1.24k
    return true;
2423
2424
  /* Count the number of line information entries.  We could do this while
2425
     scanning the debug information, but some entries may be added via
2426
     lcl_head without having a sequence handy to increment the number of
2427
     lines.  */
2428
189
  num_lines = 0;
2429
9.31k
  for (each_line = seq->last_line; each_line; each_line = each_line->prev_line)
2430
9.13k
    num_lines++;
2431
2432
189
  seq->num_lines = num_lines;
2433
189
  if (num_lines == 0)
2434
0
    return true;
2435
2436
  /* Allocate space for the line information lookup table.  */
2437
189
  amt = sizeof (struct line_info*) * num_lines;
2438
189
  line_info_lookup = (struct line_info**) bfd_alloc (table->abfd, amt);
2439
189
  seq->line_info_lookup = line_info_lookup;
2440
189
  if (line_info_lookup == NULL)
2441
0
    return false;
2442
2443
  /* Create the line information lookup table.  */
2444
189
  line_index = num_lines;
2445
9.31k
  for (each_line = seq->last_line; each_line; each_line = each_line->prev_line)
2446
9.13k
    line_info_lookup[--line_index] = each_line;
2447
2448
189
  BFD_ASSERT (line_index == 0);
2449
189
  return true;
2450
189
}
2451
2452
/* Sort the line sequences for quick lookup.  */
2453
2454
static bool
2455
sort_line_sequences (struct line_info_table* table)
2456
622
{
2457
622
  size_t amt;
2458
622
  struct line_sequence *sequences;
2459
622
  struct line_sequence *seq;
2460
622
  unsigned int n = 0;
2461
622
  unsigned int num_sequences = table->num_sequences;
2462
622
  bfd_vma last_high_pc;
2463
2464
622
  if (num_sequences == 0)
2465
53
    return true;
2466
2467
  /* Allocate space for an array of sequences.  */
2468
569
  amt = sizeof (struct line_sequence) * num_sequences;
2469
569
  sequences = (struct line_sequence *) bfd_alloc (table->abfd, amt);
2470
569
  if (sequences == NULL)
2471
0
    return false;
2472
2473
  /* Copy the linked list into the array, freeing the original nodes.  */
2474
569
  seq = table->sequences;
2475
1.23k
  for (n = 0; n < num_sequences; n++)
2476
663
    {
2477
663
      struct line_sequence* last_seq = seq;
2478
2479
663
      BFD_ASSERT (seq);
2480
663
      sequences[n].low_pc = seq->low_pc;
2481
663
      sequences[n].prev_sequence = NULL;
2482
663
      sequences[n].last_line = seq->last_line;
2483
663
      sequences[n].line_info_lookup = NULL;
2484
663
      sequences[n].num_lines = n;
2485
663
      seq = seq->prev_sequence;
2486
663
      free (last_seq);
2487
663
    }
2488
569
  BFD_ASSERT (seq == NULL);
2489
2490
569
  qsort (sequences, n, sizeof (struct line_sequence), compare_sequences);
2491
2492
  /* Make the list binary-searchable by trimming overlapping entries
2493
     and removing nested entries.  */
2494
569
  num_sequences = 1;
2495
569
  last_high_pc = sequences[0].last_line->address;
2496
663
  for (n = 1; n < table->num_sequences; n++)
2497
94
    {
2498
94
      if (sequences[n].low_pc < last_high_pc)
2499
31
  {
2500
31
    if (sequences[n].last_line->address <= last_high_pc)
2501
      /* Skip nested entries.  */
2502
27
      continue;
2503
2504
    /* Trim overlapping entries.  */
2505
4
    sequences[n].low_pc = last_high_pc;
2506
4
  }
2507
67
      last_high_pc = sequences[n].last_line->address;
2508
67
      if (n > num_sequences)
2509
0
  {
2510
    /* Close up the gap.  */
2511
0
    sequences[num_sequences].low_pc = sequences[n].low_pc;
2512
0
    sequences[num_sequences].last_line = sequences[n].last_line;
2513
0
  }
2514
67
      num_sequences++;
2515
67
    }
2516
2517
569
  table->sequences = sequences;
2518
569
  table->num_sequences = num_sequences;
2519
569
  return true;
2520
569
}
2521
2522
/* Add directory to TABLE.  CUR_DIR memory ownership is taken by TABLE.  */
2523
2524
static bool
2525
line_info_add_include_dir (struct line_info_table *table, char *cur_dir)
2526
958
{
2527
958
  if ((table->num_dirs % DIR_ALLOC_CHUNK) == 0)
2528
517
    {
2529
517
      char **tmp;
2530
517
      size_t amt;
2531
2532
517
      amt = table->num_dirs + DIR_ALLOC_CHUNK;
2533
517
      amt *= sizeof (char *);
2534
2535
517
      tmp = (char **) bfd_realloc (table->dirs, amt);
2536
517
      if (tmp == NULL)
2537
0
  return false;
2538
517
      table->dirs = tmp;
2539
517
    }
2540
2541
958
  table->dirs[table->num_dirs++] = cur_dir;
2542
958
  return true;
2543
958
}
2544
2545
static bool
2546
line_info_add_include_dir_stub (struct line_info_table *table, char *cur_dir,
2547
        unsigned int dir ATTRIBUTE_UNUSED,
2548
        unsigned int xtime ATTRIBUTE_UNUSED,
2549
        unsigned int size ATTRIBUTE_UNUSED)
2550
17
{
2551
17
  return line_info_add_include_dir (table, cur_dir);
2552
17
}
2553
2554
/* Add file to TABLE.  CUR_FILE memory ownership is taken by TABLE.  */
2555
2556
static bool
2557
line_info_add_file_name (struct line_info_table *table, char *cur_file,
2558
       unsigned int dir, unsigned int xtime,
2559
       unsigned int size)
2560
1.86k
{
2561
1.86k
  if ((table->num_files % FILE_ALLOC_CHUNK) == 0)
2562
812
    {
2563
812
      struct fileinfo *tmp;
2564
812
      size_t amt;
2565
2566
812
      amt = table->num_files + FILE_ALLOC_CHUNK;
2567
812
      amt *= sizeof (struct fileinfo);
2568
2569
812
      tmp = (struct fileinfo *) bfd_realloc (table->files, amt);
2570
812
      if (tmp == NULL)
2571
0
  return false;
2572
812
      table->files = tmp;
2573
812
    }
2574
2575
1.86k
  table->files[table->num_files].name = cur_file;
2576
1.86k
  table->files[table->num_files].dir = dir;
2577
1.86k
  table->files[table->num_files].time = xtime;
2578
1.86k
  table->files[table->num_files].size = size;
2579
1.86k
  table->num_files++;
2580
1.86k
  return true;
2581
1.86k
}
2582
2583
/* Read directory or file name entry format, starting with byte of
2584
   format count entries, ULEB128 pairs of entry formats, ULEB128 of
2585
   entries count and the entries themselves in the described entry
2586
   format.  */
2587
2588
static bool
2589
read_formatted_entries (struct comp_unit *unit, bfd_byte **bufp,
2590
      bfd_byte *buf_end, struct line_info_table *table,
2591
      bool (*callback) (struct line_info_table *table,
2592
            char *cur_file,
2593
            unsigned int dir,
2594
            unsigned int time,
2595
            unsigned int size))
2596
21
{
2597
21
  bfd *abfd = unit->abfd;
2598
21
  bfd_byte format_count, formati;
2599
21
  bfd_vma data_count, datai;
2600
21
  bfd_byte *buf = *bufp;
2601
21
  bfd_byte *format_header_data;
2602
2603
21
  format_count = read_1_byte (abfd, &buf, buf_end);
2604
21
  format_header_data = buf;
2605
467
  for (formati = 0; formati < format_count; formati++)
2606
446
    {
2607
446
      _bfd_safe_read_leb128 (abfd, &buf, false, buf_end);
2608
446
      _bfd_safe_read_leb128 (abfd, &buf, false, buf_end);
2609
446
    }
2610
2611
21
  data_count = _bfd_safe_read_leb128 (abfd, &buf, false, buf_end);
2612
21
  if (format_count == 0 && data_count != 0)
2613
2
    {
2614
2
      _bfd_error_handler (_("DWARF error: zero format count"));
2615
2
      bfd_set_error (bfd_error_bad_value);
2616
2
      return false;
2617
2
    }
2618
2619
  /* PR 22210.  Paranoia check.  Don't bother running the loop
2620
     if we know that we are going to run out of buffer.  */
2621
19
  if (data_count > (bfd_vma) (buf_end - buf))
2622
0
    {
2623
0
      _bfd_error_handler
2624
0
  (_("DWARF error: data count (%" PRIx64 ") larger than buffer size"),
2625
0
   (uint64_t) data_count);
2626
0
      bfd_set_error (bfd_error_bad_value);
2627
0
      return false;
2628
0
    }
2629
2630
36
  for (datai = 0; datai < data_count; datai++)
2631
23
    {
2632
23
      bfd_byte *format = format_header_data;
2633
23
      struct fileinfo fe;
2634
2635
23
      memset (&fe, 0, sizeof fe);
2636
121
      for (formati = 0; formati < format_count; formati++)
2637
104
  {
2638
104
    bfd_vma content_type, form;
2639
104
    char *string_trash;
2640
104
    char **stringp = &string_trash;
2641
104
    unsigned int uint_trash, *uintp = &uint_trash;
2642
104
    struct attribute attr;
2643
2644
104
    content_type = _bfd_safe_read_leb128 (abfd, &format, false, buf_end);
2645
104
    switch (content_type)
2646
104
      {
2647
1
      case DW_LNCT_path:
2648
1
        stringp = &fe.name;
2649
1
        break;
2650
0
      case DW_LNCT_directory_index:
2651
0
        uintp = &fe.dir;
2652
0
        break;
2653
18
      case DW_LNCT_timestamp:
2654
18
        uintp = &fe.time;
2655
18
        break;
2656
22
      case DW_LNCT_size:
2657
22
        uintp = &fe.size;
2658
22
        break;
2659
62
      case DW_LNCT_MD5:
2660
62
        break;
2661
1
      default:
2662
1
        _bfd_error_handler
2663
1
    (_("DWARF error: unknown format content type %" PRIu64),
2664
1
     (uint64_t) content_type);
2665
1
        bfd_set_error (bfd_error_bad_value);
2666
1
        return false;
2667
104
      }
2668
2669
103
    form = _bfd_safe_read_leb128 (abfd, &format, false, buf_end);
2670
103
    buf = read_attribute_value (&attr, form, 0, unit, buf, buf_end);
2671
103
    if (buf == NULL)
2672
5
      return false;
2673
98
    switch (form)
2674
98
      {
2675
0
      case DW_FORM_string:
2676
0
      case DW_FORM_line_strp:
2677
0
      case DW_FORM_strx:
2678
0
      case DW_FORM_strx1:
2679
3
      case DW_FORM_strx2:
2680
3
      case DW_FORM_strx3:
2681
3
      case DW_FORM_strx4:
2682
3
        *stringp = attr.u.str;
2683
3
        break;
2684
2685
0
      case DW_FORM_data1:
2686
18
      case DW_FORM_data2:
2687
18
      case DW_FORM_data4:
2688
18
      case DW_FORM_data8:
2689
18
      case DW_FORM_udata:
2690
18
        *uintp = attr.u.val;
2691
18
        break;
2692
2693
0
      case DW_FORM_data16:
2694
        /* MD5 data is in the attr.blk, but we are ignoring those.  */
2695
0
        break;
2696
98
      }
2697
98
  }
2698
2699
17
      if (!callback (table, fe.name, fe.dir, fe.time, fe.size))
2700
0
  return false;
2701
17
    }
2702
2703
13
  *bufp = buf;
2704
13
  return true;
2705
19
}
2706
2707
/* Decode the line number information for UNIT.  */
2708
2709
static struct line_info_table*
2710
decode_line_info (struct comp_unit *unit)
2711
937
{
2712
937
  bfd *abfd = unit->abfd;
2713
937
  struct dwarf2_debug *stash = unit->stash;
2714
937
  struct dwarf2_debug_file *file = unit->file;
2715
937
  struct line_info_table* table;
2716
937
  bfd_byte *line_ptr;
2717
937
  bfd_byte *line_end;
2718
937
  struct line_head lh;
2719
937
  unsigned int i, offset_size;
2720
937
  char *cur_file, *cur_dir;
2721
937
  unsigned char op_code, extended_op, adj_opcode;
2722
937
  unsigned int exop_len;
2723
937
  size_t amt;
2724
2725
937
  if (unit->line_offset == 0 && file->line_table)
2726
13
    return file->line_table;
2727
2728
924
  if (! read_section (abfd, &stash->debug_sections[debug_line],
2729
924
          file->syms, unit->line_offset,
2730
924
          &file->dwarf_line_buffer, &file->dwarf_line_size))
2731
129
    return NULL;
2732
2733
795
  if (file->dwarf_line_size < 16)
2734
3
    {
2735
3
      _bfd_error_handler
2736
3
  (_("DWARF error: line info section is too small (%" PRId64 ")"),
2737
3
   (int64_t) file->dwarf_line_size);
2738
3
      bfd_set_error (bfd_error_bad_value);
2739
3
      return NULL;
2740
3
    }
2741
792
  line_ptr = file->dwarf_line_buffer + unit->line_offset;
2742
792
  line_end = file->dwarf_line_buffer + file->dwarf_line_size;
2743
2744
  /* Read in the prologue.  */
2745
792
  lh.total_length = read_4_bytes (abfd, &line_ptr, line_end);
2746
792
  offset_size = 4;
2747
792
  if (lh.total_length == 0xffffffff)
2748
1
    {
2749
1
      lh.total_length = read_8_bytes (abfd, &line_ptr, line_end);
2750
1
      offset_size = 8;
2751
1
    }
2752
791
  else if (lh.total_length == 0 && unit->addr_size == 8)
2753
16
    {
2754
      /* Handle (non-standard) 64-bit DWARF2 formats.  */
2755
16
      lh.total_length = read_4_bytes (abfd, &line_ptr, line_end);
2756
16
      offset_size = 8;
2757
16
    }
2758
2759
792
  if (lh.total_length > (size_t) (line_end - line_ptr))
2760
31
    {
2761
31
      _bfd_error_handler
2762
  /* xgettext: c-format */
2763
31
  (_("DWARF error: line info data is bigger (%#" PRIx64 ")"
2764
31
     " than the space remaining in the section (%#lx)"),
2765
31
   (uint64_t) lh.total_length, (unsigned long) (line_end - line_ptr));
2766
31
      bfd_set_error (bfd_error_bad_value);
2767
31
      return NULL;
2768
31
    }
2769
2770
761
  line_end = line_ptr + lh.total_length;
2771
2772
761
  lh.version = read_2_bytes (abfd, &line_ptr, line_end);
2773
761
  if (lh.version < 2 || lh.version > 5)
2774
17
    {
2775
17
      _bfd_error_handler
2776
17
  (_("DWARF error: unhandled .debug_line version %d"), lh.version);
2777
17
      bfd_set_error (bfd_error_bad_value);
2778
17
      return NULL;
2779
17
    }
2780
2781
744
  if (line_ptr + offset_size + (lh.version >= 5 ? 8 : (lh.version >= 4 ? 6 : 5))
2782
744
      >= line_end)
2783
2
    {
2784
2
      _bfd_error_handler
2785
2
  (_("DWARF error: ran out of room reading prologue"));
2786
2
      bfd_set_error (bfd_error_bad_value);
2787
2
      return NULL;
2788
2
    }
2789
2790
742
  if (lh.version >= 5)
2791
17
    {
2792
17
      unsigned int segment_selector_size;
2793
2794
      /* Skip address size.  */
2795
17
      read_1_byte (abfd, &line_ptr, line_end);
2796
2797
17
      segment_selector_size = read_1_byte (abfd, &line_ptr, line_end);
2798
17
      if (segment_selector_size != 0)
2799
1
  {
2800
1
    _bfd_error_handler
2801
1
      (_("DWARF error: line info unsupported segment selector size %u"),
2802
1
       segment_selector_size);
2803
1
    bfd_set_error (bfd_error_bad_value);
2804
1
    return NULL;
2805
1
  }
2806
17
    }
2807
2808
741
  if (offset_size == 4)
2809
738
    lh.prologue_length = read_4_bytes (abfd, &line_ptr, line_end);
2810
3
  else
2811
3
    lh.prologue_length = read_8_bytes (abfd, &line_ptr, line_end);
2812
2813
741
  lh.minimum_instruction_length = read_1_byte (abfd, &line_ptr, line_end);
2814
2815
741
  if (lh.version >= 4)
2816
499
    lh.maximum_ops_per_insn = read_1_byte (abfd, &line_ptr, line_end);
2817
242
  else
2818
242
    lh.maximum_ops_per_insn = 1;
2819
2820
741
  if (lh.maximum_ops_per_insn == 0)
2821
5
    {
2822
5
      _bfd_error_handler
2823
5
  (_("DWARF error: invalid maximum operations per instruction"));
2824
5
      bfd_set_error (bfd_error_bad_value);
2825
5
      return NULL;
2826
5
    }
2827
2828
736
  lh.default_is_stmt = read_1_byte (abfd, &line_ptr, line_end);
2829
736
  lh.line_base = read_1_signed_byte (abfd, &line_ptr, line_end);
2830
736
  lh.line_range = read_1_byte (abfd, &line_ptr, line_end);
2831
736
  lh.opcode_base = read_1_byte (abfd, &line_ptr, line_end);
2832
2833
736
  if (line_ptr + (lh.opcode_base - 1) >= line_end)
2834
6
    {
2835
6
      _bfd_error_handler (_("DWARF error: ran out of room reading opcodes"));
2836
6
      bfd_set_error (bfd_error_bad_value);
2837
6
      return NULL;
2838
6
    }
2839
2840
730
  amt = lh.opcode_base * sizeof (unsigned char);
2841
730
  lh.standard_opcode_lengths = (unsigned char *) bfd_alloc (abfd, amt);
2842
2843
730
  lh.standard_opcode_lengths[0] = 1;
2844
2845
12.7k
  for (i = 1; i < lh.opcode_base; ++i)
2846
12.0k
    lh.standard_opcode_lengths[i] = read_1_byte (abfd, &line_ptr, line_end);
2847
2848
730
  amt = sizeof (struct line_info_table);
2849
730
  table = (struct line_info_table *) bfd_alloc (abfd, amt);
2850
730
  if (table == NULL)
2851
0
    return NULL;
2852
730
  table->abfd = abfd;
2853
730
  table->comp_dir = unit->comp_dir;
2854
2855
730
  table->num_files = 0;
2856
730
  table->files = NULL;
2857
2858
730
  table->num_dirs = 0;
2859
730
  table->dirs = NULL;
2860
2861
730
  table->num_sequences = 0;
2862
730
  table->sequences = NULL;
2863
2864
730
  table->lcl_head = NULL;
2865
2866
730
  if (lh.version >= 5)
2867
14
    {
2868
      /* Read directory table.  */
2869
14
      if (!read_formatted_entries (unit, &line_ptr, line_end, table,
2870
14
           line_info_add_include_dir_stub))
2871
7
  goto fail;
2872
2873
      /* Read file name table.  */
2874
7
      if (!read_formatted_entries (unit, &line_ptr, line_end, table,
2875
7
           line_info_add_file_name))
2876
1
  goto fail;
2877
6
      table->use_dir_and_file_0 = true;
2878
6
    }
2879
716
  else
2880
716
    {
2881
      /* Read directory table.  */
2882
1.65k
      while ((cur_dir = read_string (&line_ptr, line_end)) != NULL)
2883
941
  {
2884
941
    if (!line_info_add_include_dir (table, cur_dir))
2885
0
      goto fail;
2886
941
  }
2887
2888
      /* Read file name table.  */
2889
2.54k
      while ((cur_file = read_string (&line_ptr, line_end)) != NULL)
2890
1.82k
  {
2891
1.82k
    unsigned int dir, xtime, size;
2892
2893
1.82k
    dir = _bfd_safe_read_leb128 (abfd, &line_ptr, false, line_end);
2894
1.82k
    xtime = _bfd_safe_read_leb128 (abfd, &line_ptr, false, line_end);
2895
1.82k
    size = _bfd_safe_read_leb128 (abfd, &line_ptr, false, line_end);
2896
2897
1.82k
    if (!line_info_add_file_name (table, cur_file, dir, xtime, size))
2898
0
      goto fail;
2899
1.82k
  }
2900
716
      table->use_dir_and_file_0 = false;
2901
716
    }
2902
2903
  /* Read the statement sequences until there's nothing left.  */
2904
1.41k
  while (line_ptr < line_end)
2905
789
    {
2906
      /* State machine registers.  */
2907
789
      bfd_vma address = 0;
2908
789
      unsigned char op_index = 0;
2909
789
      char * filename = NULL;
2910
789
      unsigned int line = 1;
2911
789
      unsigned int column = 0;
2912
789
      unsigned int discriminator = 0;
2913
789
      int is_stmt = lh.default_is_stmt;
2914
789
      int end_sequence = 0;
2915
789
      unsigned int dir, xtime, size;
2916
      /* eraxxon@alumni.rice.edu: Against the DWARF2 specs, some
2917
   compilers generate address sequences that are wildly out of
2918
   order using DW_LNE_set_address (e.g. Intel C++ 6.0 compiler
2919
   for ia64-Linux).  Thus, to determine the low and high
2920
   address, we must compare on every DW_LNS_copy, etc.  */
2921
789
      bfd_vma low_pc  = (bfd_vma) -1;
2922
789
      bfd_vma high_pc = 0;
2923
2924
789
      if (table->num_files)
2925
724
  {
2926
    /* PR 30783: Always start with a file index of 1, even
2927
       for DWARF-5.  */
2928
724
    filename = concat_filename (table, 1);
2929
724
  }
2930
2931
      /* Decode the table.  */
2932
75.5k
      while (!end_sequence && line_ptr < line_end)
2933
74.8k
  {
2934
74.8k
    op_code = read_1_byte (abfd, &line_ptr, line_end);
2935
2936
74.8k
    if (op_code >= lh.opcode_base)
2937
27.3k
      {
2938
        /* Special operand.  */
2939
27.3k
        adj_opcode = op_code - lh.opcode_base;
2940
27.3k
        if (lh.line_range == 0)
2941
8
    goto line_fail;
2942
27.3k
        if (lh.maximum_ops_per_insn == 1)
2943
21.0k
    address += (adj_opcode / lh.line_range
2944
21.0k
          * lh.minimum_instruction_length);
2945
6.33k
        else
2946
6.33k
    {
2947
6.33k
      address += ((op_index + adj_opcode / lh.line_range)
2948
6.33k
            / lh.maximum_ops_per_insn
2949
6.33k
            * lh.minimum_instruction_length);
2950
6.33k
      op_index = ((op_index + adj_opcode / lh.line_range)
2951
6.33k
            % lh.maximum_ops_per_insn);
2952
6.33k
    }
2953
27.3k
        line += lh.line_base + (adj_opcode % lh.line_range);
2954
        /* Append row to matrix using current values.  */
2955
27.3k
        if (!add_line_info (table, address, op_index, filename,
2956
27.3k
          line, column, discriminator, 0))
2957
0
    goto line_fail;
2958
27.3k
        discriminator = 0;
2959
27.3k
        if (address < low_pc)
2960
276
    low_pc = address;
2961
27.3k
        if (address > high_pc)
2962
19.2k
    high_pc = address;
2963
27.3k
      }
2964
47.4k
    else switch (op_code)
2965
47.4k
      {
2966
1.43k
      case DW_LNS_extended_op:
2967
1.43k
        exop_len = _bfd_safe_read_leb128 (abfd, &line_ptr,
2968
1.43k
            false, line_end);
2969
1.43k
        extended_op = read_1_byte (abfd, &line_ptr, line_end);
2970
2971
1.43k
        switch (extended_op)
2972
1.43k
    {
2973
572
    case DW_LNE_end_sequence:
2974
572
      end_sequence = 1;
2975
572
      if (!add_line_info (table, address, op_index, filename, line,
2976
572
              column, discriminator, end_sequence))
2977
0
        goto line_fail;
2978
572
      discriminator = 0;
2979
572
      if (address < low_pc)
2980
29
        low_pc = address;
2981
572
      if (address > high_pc)
2982
444
        high_pc = address;
2983
572
      if (!arange_add (unit, &unit->arange, &unit->file->trie_root,
2984
572
           low_pc, high_pc))
2985
0
        goto line_fail;
2986
572
      break;
2987
720
    case DW_LNE_set_address:
2988
720
      address = read_address (unit, &line_ptr, line_end);
2989
720
      op_index = 0;
2990
720
      break;
2991
38
    case DW_LNE_define_file:
2992
38
      cur_file = read_string (&line_ptr, line_end);
2993
38
      dir = _bfd_safe_read_leb128 (abfd, &line_ptr,
2994
38
                 false, line_end);
2995
38
      xtime = _bfd_safe_read_leb128 (abfd, &line_ptr,
2996
38
             false, line_end);
2997
38
      size = _bfd_safe_read_leb128 (abfd, &line_ptr,
2998
38
            false, line_end);
2999
38
      if (!line_info_add_file_name (table, cur_file, dir,
3000
38
            xtime, size))
3001
0
        goto line_fail;
3002
38
      break;
3003
38
    case DW_LNE_set_discriminator:
3004
1
      discriminator = _bfd_safe_read_leb128 (abfd, &line_ptr,
3005
1
               false, line_end);
3006
1
      break;
3007
9
    case DW_LNE_HP_source_file_correlation:
3008
9
      line_ptr += exop_len - 1;
3009
9
      break;
3010
91
    default:
3011
91
      _bfd_error_handler
3012
91
        (_("DWARF error: mangled line number section"));
3013
91
      bfd_set_error (bfd_error_bad_value);
3014
100
    line_fail:
3015
100
      free (filename);
3016
100
      goto fail;
3017
1.43k
    }
3018
1.34k
        break;
3019
1.34k
      case DW_LNS_copy:
3020
855
        if (!add_line_info (table, address, op_index,
3021
855
          filename, line, column, discriminator, 0))
3022
0
    goto line_fail;
3023
855
        discriminator = 0;
3024
855
        if (address < low_pc)
3025
490
    low_pc = address;
3026
855
        if (address > high_pc)
3027
344
    high_pc = address;
3028
855
        break;
3029
1.72k
      case DW_LNS_advance_pc:
3030
1.72k
        if (lh.maximum_ops_per_insn == 1)
3031
1.31k
    address += (lh.minimum_instruction_length
3032
1.31k
          * _bfd_safe_read_leb128 (abfd, &line_ptr,
3033
1.31k
                 false, line_end));
3034
408
        else
3035
408
    {
3036
408
      bfd_vma adjust = _bfd_safe_read_leb128 (abfd, &line_ptr,
3037
408
                false, line_end);
3038
408
      address = ((op_index + adjust) / lh.maximum_ops_per_insn
3039
408
           * lh.minimum_instruction_length);
3040
408
      op_index = (op_index + adjust) % lh.maximum_ops_per_insn;
3041
408
    }
3042
1.72k
        break;
3043
9.34k
      case DW_LNS_advance_line:
3044
9.34k
        line += _bfd_safe_read_leb128 (abfd, &line_ptr,
3045
9.34k
               true, line_end);
3046
9.34k
        break;
3047
161
      case DW_LNS_set_file:
3048
161
        {
3049
161
    unsigned int filenum;
3050
3051
    /* The file and directory tables are 0
3052
       based, the references are 1 based.  */
3053
161
    filenum = _bfd_safe_read_leb128 (abfd, &line_ptr,
3054
161
             false, line_end);
3055
161
    free (filename);
3056
161
    filename = concat_filename (table, filenum);
3057
161
    break;
3058
855
        }
3059
15.4k
      case DW_LNS_set_column:
3060
15.4k
        column = _bfd_safe_read_leb128 (abfd, &line_ptr,
3061
15.4k
                false, line_end);
3062
15.4k
        break;
3063
9.54k
      case DW_LNS_negate_stmt:
3064
9.54k
        is_stmt = (!is_stmt);
3065
9.54k
        break;
3066
232
      case DW_LNS_set_basic_block:
3067
232
        break;
3068
7.64k
      case DW_LNS_const_add_pc:
3069
7.64k
        if (lh.line_range == 0)
3070
1
    goto line_fail;
3071
7.64k
        if (lh.maximum_ops_per_insn == 1)
3072
6.63k
    address += (lh.minimum_instruction_length
3073
6.63k
          * ((255 - lh.opcode_base) / lh.line_range));
3074
1.01k
        else
3075
1.01k
    {
3076
1.01k
      bfd_vma adjust = ((255 - lh.opcode_base) / lh.line_range);
3077
1.01k
      address += (lh.minimum_instruction_length
3078
1.01k
            * ((op_index + adjust)
3079
1.01k
         / lh.maximum_ops_per_insn));
3080
1.01k
      op_index = (op_index + adjust) % lh.maximum_ops_per_insn;
3081
1.01k
    }
3082
7.64k
        break;
3083
29
      case DW_LNS_fixed_advance_pc:
3084
29
        address += read_2_bytes (abfd, &line_ptr, line_end);
3085
29
        op_index = 0;
3086
29
        break;
3087
998
      default:
3088
        /* Unknown standard opcode, ignore it.  */
3089
33.3k
        for (i = 0; i < lh.standard_opcode_lengths[op_code]; i++)
3090
32.3k
    (void) _bfd_safe_read_leb128 (abfd, &line_ptr,
3091
32.3k
                false, line_end);
3092
998
        break;
3093
47.4k
      }
3094
74.8k
  }
3095
3096
689
      free (filename);
3097
689
    }
3098
3099
622
  if (unit->line_offset == 0)
3100
614
    file->line_table = table;
3101
622
  if (sort_line_sequences (table))
3102
622
    return table;
3103
3104
108
 fail:
3105
195
  while (table->sequences != NULL)
3106
87
    {
3107
87
      struct line_sequence* seq = table->sequences;
3108
87
      table->sequences = table->sequences->prev_sequence;
3109
87
      free (seq);
3110
87
    }
3111
108
  free (table->files);
3112
108
  free (table->dirs);
3113
108
  return NULL;
3114
622
}
3115
3116
/* If ADDR is within TABLE set the output parameters and return TRUE,
3117
   otherwise set *FILENAME_PTR to NULL and return FALSE.
3118
   The parameters FILENAME_PTR, LINENUMBER_PTR and DISCRIMINATOR_PTR
3119
   are pointers to the objects to be filled in.  */
3120
3121
static bool
3122
lookup_address_in_line_info_table (struct line_info_table *table,
3123
           bfd_vma addr,
3124
           const char **filename_ptr,
3125
           unsigned int *linenumber_ptr,
3126
           unsigned int *discriminator_ptr)
3127
4.30k
{
3128
4.30k
  struct line_sequence *seq = NULL;
3129
4.30k
  struct line_info *info;
3130
4.30k
  int low, high, mid;
3131
3132
  /* Binary search the array of sequences.  */
3133
4.30k
  low = 0;
3134
4.30k
  high = table->num_sequences;
3135
7.42k
  while (low < high)
3136
4.55k
    {
3137
4.55k
      mid = (low + high) / 2;
3138
4.55k
      seq = &table->sequences[mid];
3139
4.55k
      if (addr < seq->low_pc)
3140
680
  high = mid;
3141
3.87k
      else if (addr >= seq->last_line->address)
3142
2.43k
  low = mid + 1;
3143
1.43k
      else
3144
1.43k
  break;
3145
4.55k
    }
3146
3147
  /* Check for a valid sequence.  */
3148
4.30k
  if (!seq || addr < seq->low_pc || addr >= seq->last_line->address)
3149
2.86k
    goto fail;
3150
3151
1.43k
  if (!build_line_info_table (table, seq))
3152
0
    goto fail;
3153
3154
  /* Binary search the array of line information.  */
3155
1.43k
  low = 0;
3156
1.43k
  high = seq->num_lines;
3157
1.43k
  info = NULL;
3158
7.20k
  while (low < high)
3159
7.20k
    {
3160
7.20k
      mid = (low + high) / 2;
3161
7.20k
      info = seq->line_info_lookup[mid];
3162
7.20k
      if (addr < info->address)
3163
4.11k
  high = mid;
3164
3.08k
      else if (addr >= seq->line_info_lookup[mid + 1]->address)
3165
1.64k
  low = mid + 1;
3166
1.43k
      else
3167
1.43k
  break;
3168
7.20k
    }
3169
3170
  /* Check for a valid line information entry.  */
3171
1.43k
  if (info
3172
1.43k
      && addr >= info->address
3173
1.43k
      && addr < seq->line_info_lookup[mid + 1]->address
3174
1.43k
      && !(info->end_sequence || info == seq->last_line))
3175
1.43k
    {
3176
1.43k
      *filename_ptr = info->filename;
3177
1.43k
      *linenumber_ptr = info->line;
3178
1.43k
      if (discriminator_ptr)
3179
91
  *discriminator_ptr = info->discriminator;
3180
1.43k
      return true;
3181
1.43k
    }
3182
3183
2.86k
 fail:
3184
2.86k
  *filename_ptr = NULL;
3185
2.86k
  return false;
3186
1.43k
}
3187
3188
/* Read in the .debug_ranges section for future reference.  */
3189
3190
static bool
3191
read_debug_ranges (struct comp_unit * unit)
3192
303
{
3193
303
  struct dwarf2_debug *stash = unit->stash;
3194
303
  struct dwarf2_debug_file *file = unit->file;
3195
3196
303
  return read_section (unit->abfd, &stash->debug_sections[debug_ranges],
3197
303
           file->syms, 0,
3198
303
           &file->dwarf_ranges_buffer, &file->dwarf_ranges_size);
3199
303
}
3200
3201
/* Read in the .debug_rnglists section for future reference.  */
3202
3203
static bool
3204
read_debug_rnglists (struct comp_unit * unit)
3205
0
{
3206
0
  struct dwarf2_debug *stash = unit->stash;
3207
0
  struct dwarf2_debug_file *file = unit->file;
3208
3209
0
  return read_section (unit->abfd, &stash->debug_sections[debug_rnglists],
3210
0
           file->syms, 0,
3211
0
           &file->dwarf_rnglists_buffer, &file->dwarf_rnglists_size);
3212
0
}
3213
3214
/* Function table functions.  */
3215
3216
static int
3217
compare_lookup_funcinfos (const void * a, const void * b)
3218
3.34k
{
3219
3.34k
  const struct lookup_funcinfo * lookup1 = a;
3220
3.34k
  const struct lookup_funcinfo * lookup2 = b;
3221
3222
3.34k
  if (lookup1->low_addr < lookup2->low_addr)
3223
419
    return -1;
3224
2.92k
  if (lookup1->low_addr > lookup2->low_addr)
3225
436
    return 1;
3226
2.48k
  if (lookup1->high_addr < lookup2->high_addr)
3227
326
    return -1;
3228
2.16k
  if (lookup1->high_addr > lookup2->high_addr)
3229
841
    return 1;
3230
3231
1.32k
  if (lookup1->idx < lookup2->idx)
3232
1.32k
    return -1;
3233
0
  if (lookup1->idx > lookup2->idx)
3234
0
    return 1;
3235
0
  return 0;
3236
0
}
3237
3238
static bool
3239
build_lookup_funcinfo_table (struct comp_unit * unit)
3240
3.42k
{
3241
3.42k
  struct lookup_funcinfo *lookup_funcinfo_table = unit->lookup_funcinfo_table;
3242
3.42k
  unsigned int number_of_functions = unit->number_of_functions;
3243
3.42k
  struct funcinfo *each;
3244
3.42k
  struct lookup_funcinfo *entry;
3245
3.42k
  size_t func_index;
3246
3.42k
  struct arange *range;
3247
3.42k
  bfd_vma low_addr, high_addr;
3248
3249
3.42k
  if (lookup_funcinfo_table || number_of_functions == 0)
3250
3.10k
    return true;
3251
3252
  /* Create the function info lookup table.  */
3253
313
  lookup_funcinfo_table = (struct lookup_funcinfo *)
3254
313
    bfd_malloc (number_of_functions * sizeof (struct lookup_funcinfo));
3255
313
  if (lookup_funcinfo_table == NULL)
3256
0
    return false;
3257
3258
  /* Populate the function info lookup table.  */
3259
313
  func_index = number_of_functions;
3260
2.11k
  for (each = unit->function_table; each; each = each->prev_func)
3261
1.80k
    {
3262
1.80k
      entry = &lookup_funcinfo_table[--func_index];
3263
1.80k
      entry->funcinfo = each;
3264
1.80k
      entry->idx = func_index;
3265
3266
      /* Calculate the lowest and highest address for this function entry.  */
3267
1.80k
      low_addr  = entry->funcinfo->arange.low;
3268
1.80k
      high_addr = entry->funcinfo->arange.high;
3269
3270
2.77k
      for (range = entry->funcinfo->arange.next; range; range = range->next)
3271
969
  {
3272
969
    if (range->low < low_addr)
3273
116
      low_addr = range->low;
3274
969
    if (range->high > high_addr)
3275
271
      high_addr = range->high;
3276
969
  }
3277
3278
1.80k
      entry->low_addr = low_addr;
3279
1.80k
      entry->high_addr = high_addr;
3280
1.80k
    }
3281
3282
313
  BFD_ASSERT (func_index == 0);
3283
3284
  /* Sort the function by address.  */
3285
313
  qsort (lookup_funcinfo_table,
3286
313
   number_of_functions,
3287
313
   sizeof (struct lookup_funcinfo),
3288
313
   compare_lookup_funcinfos);
3289
3290
  /* Calculate the high watermark for each function in the lookup table.  */
3291
313
  high_addr = lookup_funcinfo_table[0].high_addr;
3292
1.80k
  for (func_index = 1; func_index < number_of_functions; func_index++)
3293
1.49k
    {
3294
1.49k
      entry = &lookup_funcinfo_table[func_index];
3295
1.49k
      if (entry->high_addr > high_addr)
3296
396
  high_addr = entry->high_addr;
3297
1.09k
      else
3298
1.09k
  entry->high_addr = high_addr;
3299
1.49k
    }
3300
3301
313
  unit->lookup_funcinfo_table = lookup_funcinfo_table;
3302
313
  return true;
3303
313
}
3304
3305
/* If ADDR is within UNIT's function tables, set FUNCTION_PTR, and return
3306
   TRUE.  Note that we need to find the function that has the smallest range
3307
   that contains ADDR, to handle inlined functions without depending upon
3308
   them being ordered in TABLE by increasing range.  */
3309
3310
static bool
3311
lookup_address_in_function_table (struct comp_unit *unit,
3312
          bfd_vma addr,
3313
          struct funcinfo **function_ptr)
3314
4.30k
{
3315
4.30k
  unsigned int number_of_functions = unit->number_of_functions;
3316
4.30k
  struct lookup_funcinfo* lookup_funcinfo = NULL;
3317
4.30k
  struct funcinfo* funcinfo = NULL;
3318
4.30k
  struct funcinfo* best_fit = NULL;
3319
4.30k
  bfd_vma best_fit_len = (bfd_vma) -1;
3320
4.30k
  bfd_size_type low, high, mid, first;
3321
4.30k
  struct arange *arange;
3322
3323
4.30k
  if (number_of_functions == 0)
3324
881
    return false;
3325
3326
3.42k
  if (!build_lookup_funcinfo_table (unit))
3327
0
    return false;
3328
3329
3.42k
  if (unit->lookup_funcinfo_table[number_of_functions - 1].high_addr < addr)
3330
815
    return false;
3331
3332
  /* Find the first function in the lookup table which may contain the
3333
     specified address.  */
3334
2.60k
  low = 0;
3335
2.60k
  high = number_of_functions;
3336
2.60k
  first = high;
3337
11.2k
  while (low < high)
3338
8.66k
    {
3339
8.66k
      mid = (low + high) / 2;
3340
8.66k
      lookup_funcinfo = &unit->lookup_funcinfo_table[mid];
3341
8.66k
      if (addr < lookup_funcinfo->low_addr)
3342
735
  high = mid;
3343
7.93k
      else if (addr >= lookup_funcinfo->high_addr)
3344
4.21k
  low = mid + 1;
3345
3.72k
      else
3346
3.72k
  high = first = mid;
3347
8.66k
    }
3348
3349
  /* Find the 'best' match for the address.  The prior algorithm defined the
3350
     best match as the function with the smallest address range containing
3351
     the specified address.  This definition should probably be changed to the
3352
     innermost inline routine containing the address, but right now we want
3353
     to get the same results we did before.  */
3354
8.67k
  while (first < number_of_functions)
3355
7.09k
    {
3356
7.09k
      if (addr < unit->lookup_funcinfo_table[first].low_addr)
3357
1.03k
  break;
3358
6.06k
      funcinfo = unit->lookup_funcinfo_table[first].funcinfo;
3359
3360
23.5k
      for (arange = &funcinfo->arange; arange; arange = arange->next)
3361
17.4k
  {
3362
17.4k
    if (addr < arange->low || addr >= arange->high)
3363
12.7k
      continue;
3364
3365
4.76k
    if (arange->high - arange->low < best_fit_len
3366
        /* The following comparison is designed to return the same
3367
     match as the previous algorithm for routines which have the
3368
     same best fit length.  */
3369
1.77k
        || (arange->high - arange->low == best_fit_len
3370
489
      && funcinfo > best_fit))
3371
3.47k
      {
3372
3.47k
        best_fit = funcinfo;
3373
3.47k
        best_fit_len = arange->high - arange->low;
3374
3.47k
      }
3375
4.76k
  }
3376
3377
6.06k
      first++;
3378
6.06k
    }
3379
3380
2.60k
  if (!best_fit)
3381
276
    return false;
3382
3383
2.33k
  *function_ptr = best_fit;
3384
2.33k
  return true;
3385
2.60k
}
3386
3387
/* If SYM at ADDR is within function table of UNIT, set FILENAME_PTR
3388
   and LINENUMBER_PTR, and return TRUE.  */
3389
3390
static bool
3391
lookup_symbol_in_function_table (struct comp_unit *unit,
3392
         asymbol *sym,
3393
         bfd_vma addr,
3394
         const char **filename_ptr,
3395
         unsigned int *linenumber_ptr)
3396
461
{
3397
461
  struct funcinfo* each;
3398
461
  struct funcinfo* best_fit = NULL;
3399
461
  bfd_vma best_fit_len = (bfd_vma) -1;
3400
461
  struct arange *arange;
3401
461
  const char *name = bfd_asymbol_name (sym);
3402
3403
3.10k
  for (each = unit->function_table; each; each = each->prev_func)
3404
6.81k
    for (arange = &each->arange; arange; arange = arange->next)
3405
4.16k
      if (addr >= arange->low
3406
2.76k
    && addr < arange->high
3407
391
    && arange->high - arange->low < best_fit_len
3408
391
    && each->file
3409
86
    && each->name
3410
82
    && strstr (name, each->name) != NULL)
3411
0
  {
3412
0
    best_fit = each;
3413
0
    best_fit_len = arange->high - arange->low;
3414
0
  }
3415
3416
461
  if (best_fit)
3417
0
    {
3418
0
      *filename_ptr = best_fit->file;
3419
0
      *linenumber_ptr = best_fit->line;
3420
0
      return true;
3421
0
    }
3422
3423
461
  return false;
3424
461
}
3425
3426
/* Variable table functions.  */
3427
3428
/* If SYM is within variable table of UNIT, set FILENAME_PTR and
3429
   LINENUMBER_PTR, and return TRUE.  */
3430
3431
static bool
3432
lookup_symbol_in_variable_table (struct comp_unit *unit,
3433
         asymbol *sym,
3434
         bfd_vma addr,
3435
         const char **filename_ptr,
3436
         unsigned int *linenumber_ptr)
3437
1.40k
{
3438
1.40k
  struct varinfo* each;
3439
1.40k
  const char *name = bfd_asymbol_name (sym);
3440
3441
1.44k
  for (each = unit->variable_table; each; each = each->prev_var)
3442
40
    if (each->addr == addr
3443
0
  && !each->stack
3444
0
  && each->file != NULL
3445
0
  && each->name != NULL
3446
0
  && strstr (name, each->name) != NULL)
3447
0
      break;
3448
3449
1.40k
  if (each)
3450
0
    {
3451
0
      *filename_ptr = each->file;
3452
0
      *linenumber_ptr = each->line;
3453
0
      return true;
3454
0
    }
3455
3456
1.40k
  return false;
3457
1.40k
}
3458
3459
static struct comp_unit *stash_comp_unit (struct dwarf2_debug *,
3460
            struct dwarf2_debug_file *);
3461
static bool comp_unit_maybe_decode_line_info (struct comp_unit *);
3462
3463
static bool
3464
find_abstract_instance (struct comp_unit *unit,
3465
      struct attribute *attr_ptr,
3466
      unsigned int recur_count,
3467
      const char **pname,
3468
      bool *is_linkage,
3469
      char **filename_ptr,
3470
      int *linenumber_ptr)
3471
472
{
3472
472
  bfd *abfd = unit->abfd;
3473
472
  bfd_byte *info_ptr = NULL;
3474
472
  bfd_byte *info_ptr_end;
3475
472
  unsigned int abbrev_number, i;
3476
472
  struct abbrev_info *abbrev;
3477
472
  uint64_t die_ref = attr_ptr->u.val;
3478
472
  struct attribute attr;
3479
3480
472
  if (recur_count == 100)
3481
0
    {
3482
0
      _bfd_error_handler
3483
0
  (_("DWARF error: abstract instance recursion detected"));
3484
0
      bfd_set_error (bfd_error_bad_value);
3485
0
      return false;
3486
0
    }
3487
3488
  /* DW_FORM_ref_addr can reference an entry in a different CU. It
3489
     is an offset from the .debug_info section, not the current CU.  */
3490
472
  if (attr_ptr->form == DW_FORM_ref_addr)
3491
11
    {
3492
      /* We only support DW_FORM_ref_addr within the same file, so
3493
   any relocations should be resolved already.  Check this by
3494
   testing for a zero die_ref;  There can't be a valid reference
3495
   to the header of a .debug_info section.
3496
   DW_FORM_ref_addr is an offset relative to .debug_info.
3497
   Normally when using the GNU linker this is accomplished by
3498
   emitting a symbolic reference to a label, because .debug_info
3499
   sections are linked at zero.  When there are multiple section
3500
   groups containing .debug_info, as there might be in a
3501
   relocatable object file, it would be reasonable to assume that
3502
   a symbolic reference to a label in any .debug_info section
3503
   might be used.  Since we lay out multiple .debug_info
3504
   sections at non-zero VMAs (see place_sections), and read
3505
   them contiguously into dwarf_info_buffer, that means the
3506
   reference is relative to dwarf_info_buffer.  */
3507
11
      size_t total;
3508
3509
11
      info_ptr = unit->file->dwarf_info_buffer;
3510
11
      info_ptr_end = info_ptr + unit->file->dwarf_info_size;
3511
11
      total = info_ptr_end - info_ptr;
3512
11
      if (!die_ref)
3513
1
  return true;
3514
10
      else if (die_ref >= total)
3515
1
  {
3516
1
    _bfd_error_handler
3517
1
      (_("DWARF error: invalid abstract instance DIE ref"));
3518
1
    bfd_set_error (bfd_error_bad_value);
3519
1
    return false;
3520
1
  }
3521
9
      info_ptr += die_ref;
3522
9
    }
3523
461
  else if (attr_ptr->form == DW_FORM_GNU_ref_alt)
3524
0
    {
3525
0
      bool first_time = unit->stash->alt.dwarf_info_buffer == NULL;
3526
3527
0
      info_ptr = read_alt_indirect_ref (unit, die_ref);
3528
0
      if (first_time)
3529
0
  unit->stash->alt.info_ptr = unit->stash->alt.dwarf_info_buffer;
3530
0
      if (info_ptr == NULL)
3531
0
  {
3532
0
    _bfd_error_handler
3533
0
      (_("DWARF error: unable to read alt ref %" PRIu64),
3534
0
       (uint64_t) die_ref);
3535
0
    bfd_set_error (bfd_error_bad_value);
3536
0
    return false;
3537
0
  }
3538
0
      info_ptr_end = (unit->stash->alt.dwarf_info_buffer
3539
0
          + unit->stash->alt.dwarf_info_size);
3540
0
      if (unit->stash->alt.all_comp_units)
3541
0
  unit = unit->stash->alt.all_comp_units;
3542
0
    }
3543
3544
470
  if (attr_ptr->form == DW_FORM_ref_addr
3545
461
      || attr_ptr->form == DW_FORM_GNU_ref_alt)
3546
9
    {
3547
      /* Now find the CU containing this pointer.  */
3548
9
      if (info_ptr >= unit->info_ptr_unit && info_ptr < unit->end_ptr)
3549
9
  info_ptr_end = unit->end_ptr;
3550
0
      else
3551
0
  {
3552
    /* Check other CUs to see if they contain the abbrev.  */
3553
0
    struct comp_unit *u = NULL;
3554
0
    struct addr_range range = { info_ptr, info_ptr };
3555
0
    splay_tree_node v = splay_tree_lookup (unit->file->comp_unit_tree,
3556
0
             (splay_tree_key)&range);
3557
0
    if (v != NULL)
3558
0
      u = (struct comp_unit *)v->value;
3559
3560
0
    if (attr_ptr->form == DW_FORM_ref_addr)
3561
0
      while (u == NULL)
3562
0
        {
3563
0
    u = stash_comp_unit (unit->stash, &unit->stash->f);
3564
0
    if (u == NULL)
3565
0
      break;
3566
0
    if (info_ptr >= u->info_ptr_unit && info_ptr < u->end_ptr)
3567
0
      break;
3568
0
    u = NULL;
3569
0
        }
3570
3571
0
    if (attr_ptr->form == DW_FORM_GNU_ref_alt)
3572
0
      while (u == NULL)
3573
0
        {
3574
0
    u = stash_comp_unit (unit->stash, &unit->stash->alt);
3575
0
    if (u == NULL)
3576
0
      break;
3577
0
    if (info_ptr >= u->info_ptr_unit && info_ptr < u->end_ptr)
3578
0
      break;
3579
0
    u = NULL;
3580
0
        }
3581
3582
0
    if (u == NULL)
3583
0
      {
3584
0
        _bfd_error_handler
3585
0
    (_("DWARF error: unable to locate abstract instance DIE ref %"
3586
0
       PRIu64), (uint64_t) die_ref);
3587
0
        bfd_set_error (bfd_error_bad_value);
3588
0
        return false;
3589
0
      }
3590
0
    unit = u;
3591
0
    info_ptr_end = unit->end_ptr;
3592
0
  }
3593
9
    }
3594
461
  else
3595
461
    {
3596
      /* DW_FORM_ref1, DW_FORM_ref2, DW_FORM_ref4, DW_FORM_ref8 or
3597
   DW_FORM_ref_udata.  These are all references relative to the
3598
   start of the current CU.  */
3599
461
      size_t total;
3600
3601
461
      info_ptr = unit->info_ptr_unit;
3602
461
      info_ptr_end = unit->end_ptr;
3603
461
      total = info_ptr_end - info_ptr;
3604
461
      if (!die_ref || die_ref >= total)
3605
12
  {
3606
12
    _bfd_error_handler
3607
12
      (_("DWARF error: invalid abstract instance DIE ref"));
3608
12
    bfd_set_error (bfd_error_bad_value);
3609
12
    return false;
3610
12
  }
3611
449
      info_ptr += die_ref;
3612
449
    }
3613
3614
458
  abbrev_number = _bfd_safe_read_leb128 (abfd, &info_ptr,
3615
458
           false, info_ptr_end);
3616
458
  if (abbrev_number)
3617
429
    {
3618
429
      abbrev = lookup_abbrev (abbrev_number, unit->abbrevs);
3619
429
      if (! abbrev)
3620
5
  {
3621
5
    _bfd_error_handler
3622
5
      (_("DWARF error: could not find abbrev number %u"), abbrev_number);
3623
5
    bfd_set_error (bfd_error_bad_value);
3624
5
    return false;
3625
5
  }
3626
424
      else
3627
424
  {
3628
1.30k
    for (i = 0; i < abbrev->num_attrs; ++i)
3629
878
      {
3630
878
        info_ptr = read_attribute (&attr, &abbrev->attrs[i], unit,
3631
878
           info_ptr, info_ptr_end);
3632
878
        if (info_ptr == NULL)
3633
1
    break;
3634
877
        switch (attr.name)
3635
877
    {
3636
426
    case DW_AT_name:
3637
      /* Prefer DW_AT_MIPS_linkage_name or DW_AT_linkage_name
3638
         over DW_AT_name.  */
3639
426
      if (*pname == NULL && is_str_form (&attr))
3640
420
        {
3641
420
          *pname = attr.u.str;
3642
420
          if (mangle_style (unit->lang) == 0)
3643
301
      *is_linkage = true;
3644
420
        }
3645
426
      break;
3646
0
    case DW_AT_specification:
3647
0
      if (is_int_form (&attr)
3648
0
          && !find_abstract_instance (unit, &attr, recur_count + 1,
3649
0
              pname, is_linkage,
3650
0
              filename_ptr, linenumber_ptr))
3651
0
        return false;
3652
0
      break;
3653
0
    case DW_AT_linkage_name:
3654
0
    case DW_AT_MIPS_linkage_name:
3655
      /* PR 16949:  Corrupt debug info can place
3656
         non-string forms into these attributes.  */
3657
0
      if (is_str_form (&attr))
3658
0
        {
3659
0
          *pname = attr.u.str;
3660
0
          *is_linkage = true;
3661
0
        }
3662
0
      break;
3663
7
    case DW_AT_decl_file:
3664
7
      if (!comp_unit_maybe_decode_line_info (unit))
3665
0
        return false;
3666
7
      if (is_int_form (&attr))
3667
7
        {
3668
7
          free (*filename_ptr);
3669
7
          *filename_ptr = concat_filename (unit->line_table,
3670
7
                   attr.u.val);
3671
7
        }
3672
7
      break;
3673
6
    case DW_AT_decl_line:
3674
6
      if (is_int_form (&attr))
3675
6
        *linenumber_ptr = attr.u.val;
3676
6
      break;
3677
438
    default:
3678
438
      break;
3679
877
    }
3680
877
      }
3681
424
  }
3682
429
    }
3683
453
  return true;
3684
458
}
3685
3686
static bool
3687
read_ranges (struct comp_unit *unit, struct arange *arange,
3688
       struct trie_node **trie_root, uint64_t offset)
3689
547
{
3690
547
  bfd_byte *ranges_ptr;
3691
547
  bfd_byte *ranges_end;
3692
547
  bfd_vma base_address = unit->base_address;
3693
3694
547
  if (! unit->file->dwarf_ranges_buffer)
3695
303
    {
3696
303
      if (! read_debug_ranges (unit))
3697
20
  return false;
3698
303
    }
3699
3700
527
  if (offset > unit->file->dwarf_ranges_size)
3701
7
    return false;
3702
520
  ranges_ptr = unit->file->dwarf_ranges_buffer + offset;
3703
520
  ranges_end = unit->file->dwarf_ranges_buffer + unit->file->dwarf_ranges_size;
3704
3705
520
  for (;;)
3706
2.37k
    {
3707
2.37k
      bfd_vma low_pc;
3708
2.37k
      bfd_vma high_pc;
3709
3710
      /* PR 17512: file: 62cada7d.  */
3711
2.37k
      if (2u * unit->addr_size > (size_t) (ranges_end - ranges_ptr))
3712
32
  return false;
3713
3714
2.34k
      low_pc = read_address (unit, &ranges_ptr, ranges_end);
3715
2.34k
      high_pc = read_address (unit, &ranges_ptr, ranges_end);
3716
3717
2.34k
      if (low_pc == 0 && high_pc == 0)
3718
488
  break;
3719
1.85k
      if (low_pc == (bfd_vma) -1 && high_pc != (bfd_vma) -1)
3720
16
  base_address = high_pc;
3721
1.83k
      else
3722
1.83k
  {
3723
1.83k
    if (!arange_add (unit, arange, trie_root,
3724
1.83k
         base_address + low_pc, base_address + high_pc))
3725
0
      return false;
3726
1.83k
  }
3727
1.85k
    }
3728
488
  return true;
3729
520
}
3730
3731
static bool
3732
read_rnglists (struct comp_unit *unit, struct arange *arange,
3733
         struct trie_node **trie_root, uint64_t offset)
3734
0
{
3735
0
  bfd_byte *rngs_ptr;
3736
0
  bfd_byte *rngs_end;
3737
0
  bfd_vma base_address = unit->base_address;
3738
0
  bfd_vma low_pc;
3739
0
  bfd_vma high_pc;
3740
0
  bfd *abfd = unit->abfd;
3741
3742
0
  if (! unit->file->dwarf_rnglists_buffer)
3743
0
    {
3744
0
      if (! read_debug_rnglists (unit))
3745
0
  return false;
3746
0
    }
3747
3748
0
  rngs_ptr = unit->file->dwarf_rnglists_buffer + offset;
3749
0
  if (rngs_ptr < unit->file->dwarf_rnglists_buffer)
3750
0
    return false;
3751
0
  rngs_end = unit->file->dwarf_rnglists_buffer;
3752
0
  rngs_end +=  unit->file->dwarf_rnglists_size;
3753
3754
0
  for (;;)
3755
0
    {
3756
0
      enum dwarf_range_list_entry rlet;
3757
3758
0
      if (rngs_ptr >= rngs_end)
3759
0
  return false;
3760
3761
0
      rlet = read_1_byte (abfd, &rngs_ptr, rngs_end);
3762
3763
0
      switch (rlet)
3764
0
  {
3765
0
  case DW_RLE_end_of_list:
3766
0
    return true;
3767
3768
0
  case DW_RLE_base_address:
3769
0
    if (unit->addr_size > (size_t) (rngs_end - rngs_ptr))
3770
0
      return false;
3771
0
    base_address = read_address (unit, &rngs_ptr, rngs_end);
3772
0
    continue;
3773
3774
0
  case DW_RLE_start_length:
3775
0
    if (unit->addr_size > (size_t) (rngs_end - rngs_ptr))
3776
0
      return false;
3777
0
    low_pc = read_address (unit, &rngs_ptr, rngs_end);
3778
0
    high_pc = low_pc;
3779
0
    high_pc += _bfd_safe_read_leb128 (abfd, &rngs_ptr,
3780
0
              false, rngs_end);
3781
0
    break;
3782
3783
0
  case DW_RLE_offset_pair:
3784
0
    low_pc = base_address;
3785
0
    low_pc += _bfd_safe_read_leb128 (abfd, &rngs_ptr,
3786
0
             false, rngs_end);
3787
0
    high_pc = base_address;
3788
0
    high_pc += _bfd_safe_read_leb128 (abfd, &rngs_ptr,
3789
0
              false, rngs_end);
3790
0
    break;
3791
3792
0
  case DW_RLE_start_end:
3793
0
    if (2u * unit->addr_size > (size_t) (rngs_end - rngs_ptr))
3794
0
      return false;
3795
0
    low_pc = read_address (unit, &rngs_ptr, rngs_end);
3796
0
    high_pc = read_address (unit, &rngs_ptr, rngs_end);
3797
0
    break;
3798
3799
  /* TODO x-variants need .debug_addr support used for split-dwarf.  */
3800
0
  case DW_RLE_base_addressx:
3801
0
  case DW_RLE_startx_endx:
3802
0
  case DW_RLE_startx_length:
3803
0
  default:
3804
0
    return false;
3805
0
  }
3806
3807
0
      if (!arange_add (unit, arange, trie_root, low_pc, high_pc))
3808
0
  return false;
3809
0
    }
3810
0
}
3811
3812
static bool
3813
read_rangelist (struct comp_unit *unit, struct arange *arange,
3814
    struct trie_node **trie_root, uint64_t offset)
3815
547
{
3816
547
  if (unit->version <= 4)
3817
547
    return read_ranges (unit, arange, trie_root, offset);
3818
0
  else
3819
0
    return read_rnglists (unit, arange, trie_root, offset);
3820
547
}
3821
3822
static struct funcinfo *
3823
lookup_func_by_offset (uint64_t offset, struct funcinfo * table)
3824
359
{
3825
359
  for (; table != NULL; table = table->prev_func)
3826
359
    if (table->unit_offset == offset)
3827
359
      return table;
3828
0
  return NULL;
3829
359
}
3830
3831
static struct varinfo *
3832
lookup_var_by_offset (uint64_t offset, struct varinfo * table)
3833
59
{
3834
59
  while (table)
3835
59
    {
3836
59
      if (table->unit_offset == offset)
3837
59
  return table;
3838
0
      table = table->prev_var;
3839
0
    }
3840
3841
0
  return NULL;
3842
59
}
3843
3844
3845
/* DWARF2 Compilation unit functions.  */
3846
3847
static struct funcinfo *
3848
reverse_funcinfo_list (struct funcinfo *head)
3849
857
{
3850
857
  struct funcinfo *rhead;
3851
857
  struct funcinfo *temp;
3852
3853
4.83k
  for (rhead = NULL; head; head = temp)
3854
3.97k
    {
3855
3.97k
      temp = head->prev_func;
3856
3.97k
      head->prev_func = rhead;
3857
3.97k
      rhead = head;
3858
3.97k
    }
3859
857
  return rhead;
3860
857
}
3861
3862
static struct varinfo *
3863
reverse_varinfo_list (struct varinfo *head)
3864
857
{
3865
857
  struct varinfo *rhead;
3866
857
  struct varinfo *temp;
3867
3868
1.22k
  for (rhead = NULL; head; head = temp)
3869
366
    {
3870
366
      temp = head->prev_var;
3871
366
      head->prev_var = rhead;
3872
366
      rhead = head;
3873
366
    }
3874
857
  return rhead;
3875
857
}
3876
3877
/* Scan over each die in a comp. unit looking for functions to add
3878
   to the function table and variables to the variable table.  */
3879
3880
static bool
3881
scan_unit_for_symbols (struct comp_unit *unit)
3882
576
{
3883
576
  bfd *abfd = unit->abfd;
3884
576
  bfd_byte *info_ptr = unit->first_child_die_ptr;
3885
576
  bfd_byte *info_ptr_end = unit->end_ptr;
3886
576
  int nesting_level = 0;
3887
576
  struct nest_funcinfo
3888
576
  {
3889
576
    struct funcinfo *func;
3890
576
  } *nested_funcs;
3891
576
  int nested_funcs_size;
3892
576
  struct funcinfo *last_func;
3893
576
  struct varinfo *last_var;
3894
  
3895
  /* Maintain a stack of in-scope functions and inlined functions, which we
3896
     can use to set the caller_func field.  */
3897
576
  nested_funcs_size = 32;
3898
576
  nested_funcs = (struct nest_funcinfo *)
3899
576
    bfd_malloc (nested_funcs_size * sizeof (*nested_funcs));
3900
576
  if (nested_funcs == NULL)
3901
0
    return false;
3902
576
  nested_funcs[nesting_level].func = 0;
3903
3904
  /* PR 27484: We must scan the DIEs twice.  The first time we look for
3905
     function and variable tags and accumulate them into their respective
3906
     tables.  The second time through we process the attributes of the
3907
     functions/variables and augment the table entries.  */
3908
6.72k
  while (nesting_level >= 0)
3909
6.27k
    {
3910
6.27k
      unsigned int abbrev_number, i;
3911
6.27k
      struct abbrev_info *abbrev;
3912
6.27k
      struct funcinfo *func;
3913
6.27k
      struct varinfo *var;
3914
6.27k
      uint64_t current_offset;
3915
3916
      /* PR 17512: file: 9f405d9d.  */
3917
6.27k
      if (info_ptr >= info_ptr_end)
3918
13
  goto fail;
3919
3920
6.25k
      current_offset = info_ptr - unit->info_ptr_unit;
3921
6.25k
      abbrev_number = _bfd_safe_read_leb128 (abfd, &info_ptr,
3922
6.25k
               false, info_ptr_end);
3923
6.25k
      if (abbrev_number == 0)
3924
811
  {
3925
811
    nesting_level--;
3926
811
    continue;
3927
811
  }
3928
3929
5.44k
      abbrev = lookup_abbrev (abbrev_number, unit->abbrevs);
3930
5.44k
      if (! abbrev)
3931
71
  {
3932
71
    static unsigned int previous_failed_abbrev = -1U;
3933
3934
    /* Avoid multiple reports of the same missing abbrev.  */
3935
71
    if (abbrev_number != previous_failed_abbrev)
3936
54
      {
3937
54
        _bfd_error_handler
3938
54
    (_("DWARF error: could not find abbrev number %u"),
3939
54
     abbrev_number);
3940
54
        previous_failed_abbrev = abbrev_number;
3941
54
      }
3942
71
    bfd_set_error (bfd_error_bad_value);
3943
71
    goto fail;
3944
71
  }
3945
3946
5.37k
      if (abbrev->tag == DW_TAG_subprogram
3947
3.61k
    || abbrev->tag == DW_TAG_entry_point
3948
3.60k
    || abbrev->tag == DW_TAG_inlined_subroutine)
3949
2.34k
  {
3950
2.34k
    size_t amt = sizeof (struct funcinfo);
3951
3952
2.34k
    var = NULL;
3953
2.34k
    func = (struct funcinfo *) bfd_zalloc (abfd, amt);
3954
2.34k
    if (func == NULL)
3955
0
      goto fail;
3956
2.34k
    func->tag = abbrev->tag;
3957
2.34k
    func->prev_func = unit->function_table;
3958
2.34k
    func->unit_offset = current_offset;
3959
2.34k
    unit->function_table = func;
3960
2.34k
    unit->number_of_functions++;
3961
2.34k
    BFD_ASSERT (!unit->cached);
3962
3963
2.34k
    if (func->tag == DW_TAG_inlined_subroutine)
3964
587
      for (i = nesting_level; i-- != 0; )
3965
563
        if (nested_funcs[i].func)
3966
547
    {
3967
547
      func->caller_func = nested_funcs[i].func;
3968
547
      break;
3969
547
    }
3970
2.34k
    nested_funcs[nesting_level].func = func;
3971
2.34k
  }
3972
3.03k
      else
3973
3.03k
  {
3974
3.03k
    func = NULL;
3975
3.03k
    if (abbrev->tag == DW_TAG_variable
3976
2.82k
        || abbrev->tag == DW_TAG_member)
3977
212
      {
3978
212
        size_t amt = sizeof (struct varinfo);
3979
3980
212
        var = (struct varinfo *) bfd_zalloc (abfd, amt);
3981
212
        if (var == NULL)
3982
0
    goto fail;
3983
212
        var->tag = abbrev->tag;
3984
212
        var->stack = true;
3985
212
        var->prev_var = unit->variable_table;
3986
212
        unit->variable_table = var;
3987
212
        var->unit_offset = current_offset;
3988
        /* PR 18205: Missing debug information can cause this
3989
     var to be attached to an already cached unit.  */
3990
212
      }
3991
2.82k
    else
3992
2.82k
      var = NULL;
3993
3994
    /* No inline function in scope at this nesting level.  */
3995
3.03k
    nested_funcs[nesting_level].func = 0;
3996
3.03k
  }
3997
3998
25.5k
      for (i = 0; i < abbrev->num_attrs; ++i)
3999
20.2k
  {
4000
20.2k
    struct attribute attr;
4001
4002
20.2k
    info_ptr = read_attribute (&attr, &abbrev->attrs[i],
4003
20.2k
             unit, info_ptr, info_ptr_end);
4004
20.2k
    if (info_ptr == NULL)
4005
41
      goto fail;
4006
20.2k
  }
4007
4008
5.33k
      if (abbrev->has_children)
4009
388
  {
4010
388
    nesting_level++;
4011
4012
388
    if (nesting_level >= nested_funcs_size)
4013
0
      {
4014
0
        struct nest_funcinfo *tmp;
4015
4016
0
        nested_funcs_size *= 2;
4017
0
        tmp = (struct nest_funcinfo *)
4018
0
    bfd_realloc (nested_funcs,
4019
0
           nested_funcs_size * sizeof (*nested_funcs));
4020
0
        if (tmp == NULL)
4021
0
    goto fail;
4022
0
        nested_funcs = tmp;
4023
0
      }
4024
388
    nested_funcs[nesting_level].func = 0;
4025
388
  }
4026
5.33k
    }
4027
4028
451
  unit->function_table = reverse_funcinfo_list (unit->function_table);
4029
451
  unit->variable_table = reverse_varinfo_list (unit->variable_table);
4030
4031
  /* This is the second pass over the abbrevs.  */      
4032
451
  info_ptr = unit->first_child_die_ptr;
4033
451
  nesting_level = 0;
4034
  
4035
451
  last_func = NULL;
4036
451
  last_var = NULL;
4037
4038
5.50k
  while (nesting_level >= 0)
4039
5.10k
    {
4040
5.10k
      unsigned int abbrev_number, i;
4041
5.10k
      struct abbrev_info *abbrev;
4042
5.10k
      struct attribute attr;
4043
5.10k
      struct funcinfo *func;
4044
5.10k
      struct varinfo *var;
4045
5.10k
      bfd_vma low_pc = 0;
4046
5.10k
      bfd_vma high_pc = 0;
4047
5.10k
      bool high_pc_relative = false;
4048
5.10k
      uint64_t current_offset;
4049
4050
      /* PR 17512: file: 9f405d9d.  */
4051
5.10k
      if (info_ptr >= info_ptr_end)
4052
0
  goto fail;
4053
4054
5.10k
      current_offset = info_ptr - unit->info_ptr_unit;
4055
5.10k
      abbrev_number = _bfd_safe_read_leb128 (abfd, &info_ptr,
4056
5.10k
               false, info_ptr_end);
4057
5.10k
      if (! abbrev_number)
4058
703
  {
4059
703
    nesting_level--;
4060
703
    continue;
4061
703
  }
4062
4063
4.39k
      abbrev = lookup_abbrev (abbrev_number, unit->abbrevs);
4064
      /* This should have been handled above.  */
4065
4.39k
      BFD_ASSERT (abbrev != NULL);
4066
4067
4.39k
      func = NULL;
4068
4.39k
      var = NULL;
4069
4.39k
      if (abbrev->tag == DW_TAG_subprogram
4070
2.89k
    || abbrev->tag == DW_TAG_entry_point
4071
2.88k
    || abbrev->tag == DW_TAG_inlined_subroutine)
4072
2.03k
  {
4073
2.03k
    if (last_func
4074
1.67k
        && last_func->prev_func
4075
1.67k
        && last_func->prev_func->unit_offset == current_offset)
4076
1.67k
      func = last_func->prev_func;
4077
359
    else
4078
359
      func = lookup_func_by_offset (current_offset, unit->function_table);
4079
4080
2.03k
    if (func == NULL)
4081
0
      goto fail;
4082
4083
2.03k
    last_func = func;
4084
2.03k
  }
4085
2.36k
      else if (abbrev->tag == DW_TAG_variable
4086
2.18k
         || abbrev->tag == DW_TAG_member)
4087
183
  {
4088
183
    if (last_var
4089
124
        && last_var->prev_var
4090
124
        && last_var->prev_var->unit_offset == current_offset)
4091
124
      var = last_var->prev_var;
4092
59
    else
4093
59
      var = lookup_var_by_offset (current_offset, unit->variable_table);
4094
4095
183
    if (var == NULL)
4096
0
      goto fail;
4097
4098
183
    last_var = var;
4099
183
  }
4100
4101
20.9k
      for (i = 0; i < abbrev->num_attrs; ++i)
4102
16.6k
  {
4103
16.6k
    info_ptr = read_attribute (&attr, &abbrev->attrs[i],
4104
16.6k
             unit, info_ptr, info_ptr_end);
4105
16.6k
    if (info_ptr == NULL)
4106
0
      goto fail;
4107
4108
16.6k
    if (func)
4109
9.62k
      {
4110
9.62k
        switch (attr.name)
4111
9.62k
    {
4112
483
    case DW_AT_call_file:
4113
483
      if (is_int_form (&attr))
4114
476
        {
4115
476
          free (func->caller_file);
4116
476
          func->caller_file = concat_filename (unit->line_table,
4117
476
                 attr.u.val);
4118
476
        }
4119
483
      break;
4120
4121
483
    case DW_AT_call_line:
4122
483
      if (is_int_form (&attr))
4123
481
        func->caller_line = attr.u.val;
4124
483
      break;
4125
4126
465
    case DW_AT_abstract_origin:
4127
474
    case DW_AT_specification:
4128
474
      if (is_int_form (&attr)
4129
469
          && !find_abstract_instance (unit, &attr, 0,
4130
469
              &func->name,
4131
469
              &func->is_linkage,
4132
469
              &func->file,
4133
469
              &func->line))
4134
16
        goto fail;
4135
458
      break;
4136
4137
1.50k
    case DW_AT_name:
4138
      /* Prefer DW_AT_MIPS_linkage_name or DW_AT_linkage_name
4139
         over DW_AT_name.  */
4140
1.50k
      if (func->name == NULL && is_str_form (&attr))
4141
1.47k
        {
4142
1.47k
          func->name = attr.u.str;
4143
1.47k
          if (mangle_style (unit->lang) == 0)
4144
1.04k
      func->is_linkage = true;
4145
1.47k
        }
4146
1.50k
      break;
4147
4148
39
    case DW_AT_linkage_name:
4149
39
    case DW_AT_MIPS_linkage_name:
4150
      /* PR 16949:  Corrupt debug info can place
4151
         non-string forms into these attributes.  */
4152
39
      if (is_str_form (&attr))
4153
0
        {
4154
0
          func->name = attr.u.str;
4155
0
          func->is_linkage = true;
4156
0
        }
4157
39
      break;
4158
4159
652
    case DW_AT_low_pc:
4160
652
      if (is_int_form (&attr))
4161
643
        low_pc = attr.u.val;
4162
652
      break;
4163
4164
620
    case DW_AT_high_pc:
4165
620
      if (is_int_form (&attr))
4166
613
        {
4167
613
          high_pc = attr.u.val;
4168
613
          high_pc_relative = attr.form != DW_FORM_addr;
4169
613
        }
4170
620
      break;
4171
4172
349
    case DW_AT_ranges:
4173
349
      if (is_int_form (&attr)
4174
348
          && !read_rangelist (unit, &func->arange,
4175
348
            &unit->file->trie_root, attr.u.val))
4176
29
        goto fail;
4177
320
      break;
4178
4179
718
    case DW_AT_decl_file:
4180
718
      if (is_int_form (&attr))
4181
711
        {
4182
711
          free (func->file);
4183
711
          func->file = concat_filename (unit->line_table,
4184
711
                attr.u.val);
4185
711
        }
4186
718
      break;
4187
4188
730
    case DW_AT_decl_line:
4189
730
      if (is_int_form (&attr))
4190
718
        func->line = attr.u.val;
4191
730
      break;
4192
4193
3.57k
    default:
4194
3.57k
      break;
4195
9.62k
    }
4196
9.62k
      }
4197
6.97k
    else if (var)
4198
1.09k
      {
4199
1.09k
        switch (attr.name)
4200
1.09k
    {
4201
5
    case DW_AT_specification:
4202
5
      if (is_int_form (&attr) && attr.u.val)
4203
3
        {
4204
3
          bool is_linkage;
4205
3
          if (!find_abstract_instance (unit, &attr, 0,
4206
3
               &var->name,
4207
3
               &is_linkage,
4208
3
               &var->file,
4209
3
               &var->line))
4210
2
      {
4211
2
        _bfd_error_handler (_("DWARF error: could not find "
4212
2
            "variable specification "
4213
2
            "at offset 0x%lx"),
4214
2
                (unsigned long) attr.u.val);
4215
2
        break;
4216
2
      }
4217
3
        }
4218
3
      break;
4219
4220
182
    case DW_AT_name:
4221
182
      if (is_str_form (&attr))
4222
181
        var->name = attr.u.str;
4223
182
      break;
4224
4225
180
    case DW_AT_decl_file:
4226
180
      if (is_int_form (&attr))
4227
179
        {
4228
179
          free (var->file);
4229
179
          var->file = concat_filename (unit->line_table,
4230
179
               attr.u.val);
4231
179
        }
4232
180
      break;
4233
4234
176
    case DW_AT_decl_line:
4235
176
      if (is_int_form (&attr))
4236
160
        var->line = attr.u.val;
4237
176
      break;
4238
4239
181
    case DW_AT_external:
4240
181
      if (is_int_form (&attr) && attr.u.val != 0)
4241
178
        var->stack = false;
4242
181
      break;
4243
4244
181
    case DW_AT_location:
4245
181
      switch (attr.form)
4246
181
        {
4247
0
        case DW_FORM_block:
4248
0
        case DW_FORM_block1:
4249
0
        case DW_FORM_block2:
4250
1
        case DW_FORM_block4:
4251
180
        case DW_FORM_exprloc:
4252
180
          if (attr.u.blk->data != NULL
4253
180
        && *attr.u.blk->data == DW_OP_addr)
4254
152
      {
4255
152
        var->stack = false;
4256
4257
        /* Verify that DW_OP_addr is the only opcode in the
4258
           location, in which case the block size will be 1
4259
           plus the address size.  */
4260
        /* ??? For TLS variables, gcc can emit
4261
           DW_OP_addr <addr> DW_OP_GNU_push_tls_address
4262
           which we don't handle here yet.  */
4263
152
        if (attr.u.blk->size == unit->addr_size + 1U)
4264
150
          var->addr = bfd_get (unit->addr_size * 8,
4265
152
             unit->abfd,
4266
152
             attr.u.blk->data + 1);
4267
152
      }
4268
180
          break;
4269
4270
180
        default:
4271
1
          break;
4272
181
        }
4273
181
      break;
4274
4275
193
    default:
4276
193
      break;
4277
1.09k
    }
4278
1.09k
      }
4279
16.6k
  }
4280
4281
4.35k
      if (abbrev->has_children)
4282
336
  nesting_level++;
4283
4284
4.35k
      if (high_pc_relative)
4285
613
  high_pc += low_pc;
4286
4287
4.35k
      if (func && high_pc != 0)
4288
611
  {
4289
611
    if (!arange_add (unit, &func->arange, &unit->file->trie_root,
4290
611
         low_pc, high_pc))
4291
0
      goto fail;
4292
611
  }
4293
4.35k
    }
4294
4295
406
  unit->function_table = reverse_funcinfo_list (unit->function_table);
4296
406
  unit->variable_table = reverse_varinfo_list (unit->variable_table);
4297
4298
406
  free (nested_funcs);
4299
406
  return true;
4300
4301
170
 fail:
4302
170
  free (nested_funcs);
4303
170
  return false;
4304
451
}
4305
4306
/* Read the attributes of the form strx and addrx.  */
4307
4308
static void
4309
reread_attribute (struct comp_unit *unit,
4310
      struct attribute *attr,
4311
      bfd_vma *low_pc,
4312
      bfd_vma *high_pc,
4313
      bool *high_pc_relative,
4314
      bool compunit)
4315
218
{
4316
218
  if (is_strx_form (attr->form))
4317
174
    attr->u.str = (char *) read_indexed_string (attr->u.val, unit);
4318
218
  if (is_addrx_form (attr->form))
4319
44
    attr->u.val = read_indexed_address (attr->u.val, unit);
4320
4321
218
  switch (attr->name)
4322
218
    {
4323
15
    case DW_AT_stmt_list:
4324
15
      unit->stmtlist = 1;
4325
15
      unit->line_offset = attr->u.val;
4326
15
      break;
4327
4328
36
    case DW_AT_name:
4329
36
      if (is_str_form (attr))
4330
33
  unit->name = attr->u.str;
4331
36
      break;
4332
4333
15
    case DW_AT_low_pc:
4334
15
      *low_pc = attr->u.val;
4335
15
      if (compunit)
4336
13
  unit->base_address = *low_pc;
4337
15
      break;
4338
4339
14
    case DW_AT_high_pc:
4340
14
      *high_pc = attr->u.val;
4341
14
      *high_pc_relative = attr->form != DW_FORM_addr;
4342
14
      break;
4343
4344
6
    case DW_AT_ranges:
4345
6
      if (!read_rangelist (unit, &unit->arange,
4346
6
         &unit->file->trie_root, attr->u.val))
4347
1
  return;
4348
5
      break;
4349
4350
14
    case DW_AT_comp_dir:
4351
14
      {
4352
14
  char *comp_dir = attr->u.str;
4353
4354
14
  if (!is_str_form (attr))
4355
4
    {
4356
4
      _bfd_error_handler
4357
4
        (_("DWARF error: DW_AT_comp_dir attribute encountered "
4358
4
     "with a non-string form"));
4359
4
      comp_dir = NULL;
4360
4
    }
4361
4362
14
  if (comp_dir)
4363
0
    {
4364
0
      char *cp = strchr (comp_dir, ':');
4365
4366
0
      if (cp && cp != comp_dir && cp[-1] == '.' && cp[1] == '/')
4367
0
        comp_dir = cp + 1;
4368
0
    }
4369
14
  unit->comp_dir = comp_dir;
4370
14
  break;
4371
6
      }
4372
4373
6
    case DW_AT_language:
4374
6
      unit->lang = attr->u.val;
4375
118
    default:
4376
118
      break;
4377
218
    }
4378
218
}
4379
4380
/* Parse a DWARF2 compilation unit starting at INFO_PTR.  UNIT_LENGTH
4381
   includes the compilation unit header that proceeds the DIE's, but
4382
   does not include the length field that precedes each compilation
4383
   unit header.  END_PTR points one past the end of this comp unit.
4384
   OFFSET_SIZE is the size of DWARF2 offsets (either 4 or 8 bytes).
4385
4386
   This routine does not read the whole compilation unit; only enough
4387
   to get to the line number information for the compilation unit.  */
4388
4389
static struct comp_unit *
4390
parse_comp_unit (struct dwarf2_debug *stash,
4391
     struct dwarf2_debug_file *file,
4392
     bfd_byte *info_ptr,
4393
     bfd_vma unit_length,
4394
     bfd_byte *info_ptr_unit,
4395
     unsigned int offset_size)
4396
1.16k
{
4397
1.16k
  struct comp_unit* unit;
4398
1.16k
  unsigned int version;
4399
1.16k
  uint64_t abbrev_offset = 0;
4400
  /* Initialize it just to avoid a GCC false warning.  */
4401
1.16k
  unsigned int addr_size = -1;
4402
1.16k
  struct abbrev_info** abbrevs;
4403
1.16k
  unsigned int abbrev_number, i;
4404
1.16k
  struct abbrev_info *abbrev;
4405
1.16k
  struct attribute attr;
4406
1.16k
  bfd_byte *end_ptr = info_ptr + unit_length;
4407
1.16k
  size_t amt;
4408
1.16k
  bfd_vma low_pc = 0;
4409
1.16k
  bfd_vma high_pc = 0;
4410
1.16k
  bfd *abfd = file->bfd_ptr;
4411
1.16k
  bool high_pc_relative = false;
4412
1.16k
  enum dwarf_unit_type unit_type;
4413
1.16k
  struct attribute *str_addrp = NULL;
4414
1.16k
  size_t str_count = 0;
4415
1.16k
  size_t str_alloc = 0;
4416
1.16k
  bool compunit_flag = false;
4417
4418
1.16k
  version = read_2_bytes (abfd, &info_ptr, end_ptr);
4419
1.16k
  if (version < 2 || version > 5)
4420
39
    {
4421
      /* PR 19872: A version number of 0 probably means that there is padding
4422
   at the end of the .debug_info section.  Gold puts it there when
4423
   performing an incremental link, for example.  So do not generate
4424
   an error, just return a NULL.  */
4425
39
      if (version)
4426
24
  {
4427
24
    _bfd_error_handler
4428
24
      (_("DWARF error: found dwarf version '%u', this reader"
4429
24
         " only handles version 2, 3, 4 and 5 information"), version);
4430
24
    bfd_set_error (bfd_error_bad_value);
4431
24
  }
4432
39
      return NULL;
4433
39
    }
4434
4435
1.12k
  if (version < 5)
4436
1.12k
    unit_type = DW_UT_compile;
4437
2
  else
4438
2
    {
4439
2
      unit_type = read_1_byte (abfd, &info_ptr, end_ptr);
4440
2
      addr_size = read_1_byte (abfd, &info_ptr, end_ptr);
4441
2
    }
4442
4443
1.12k
  BFD_ASSERT (offset_size == 4 || offset_size == 8);
4444
1.12k
  if (offset_size == 4)
4445
1.12k
    abbrev_offset = read_4_bytes (abfd, &info_ptr, end_ptr);
4446
3
  else
4447
3
    abbrev_offset = read_8_bytes (abfd, &info_ptr, end_ptr);
4448
4449
1.12k
  if (version < 5)
4450
1.12k
    addr_size = read_1_byte (abfd, &info_ptr, end_ptr);
4451
4452
1.12k
  switch (unit_type)
4453
1.12k
    {
4454
0
    case DW_UT_type:
4455
      /* Skip type signature.  */
4456
0
      info_ptr += 8;
4457
4458
      /* Skip type offset.  */
4459
0
      info_ptr += offset_size;
4460
0
      break;
4461
4462
0
    case DW_UT_skeleton:
4463
      /* Skip DWO_id field.  */
4464
0
      info_ptr += 8;
4465
0
      break;
4466
4467
1.12k
    default:
4468
1.12k
      break;
4469
1.12k
    }
4470
4471
1.12k
  if (addr_size > sizeof (bfd_vma))
4472
5
    {
4473
5
      _bfd_error_handler
4474
  /* xgettext: c-format */
4475
5
  (_("DWARF error: found address size '%u', this reader"
4476
5
     " can not handle sizes greater than '%u'"),
4477
5
   addr_size,
4478
5
   (unsigned int) sizeof (bfd_vma));
4479
5
      bfd_set_error (bfd_error_bad_value);
4480
5
      return NULL;
4481
5
    }
4482
4483
1.12k
  if (addr_size != 2 && addr_size != 4 && addr_size != 8)
4484
10
    {
4485
10
      _bfd_error_handler
4486
10
  ("DWARF error: found address size '%u', this reader"
4487
10
   " can only handle address sizes '2', '4' and '8'", addr_size);
4488
10
      bfd_set_error (bfd_error_bad_value);
4489
10
      return NULL;
4490
10
    }
4491
4492
  /* Read the abbrevs for this compilation unit into a table.  */
4493
1.11k
  abbrevs = read_abbrevs (abfd, abbrev_offset, stash, file);
4494
1.11k
  if (! abbrevs)
4495
59
    return NULL;
4496
4497
1.05k
  abbrev_number = _bfd_safe_read_leb128 (abfd, &info_ptr,
4498
1.05k
           false, end_ptr);
4499
1.05k
  if (! abbrev_number)
4500
2
    {
4501
      /* PR 19872: An abbrev number of 0 probably means that there is padding
4502
   at the end of the .debug_abbrev section.  Gold puts it there when
4503
   performing an incremental link, for example.  So do not generate
4504
   an error, just return a NULL.  */
4505
2
      return NULL;
4506
2
    }
4507
4508
1.05k
  abbrev = lookup_abbrev (abbrev_number, abbrevs);
4509
1.05k
  if (! abbrev)
4510
23
    {
4511
23
      _bfd_error_handler (_("DWARF error: could not find abbrev number %u"),
4512
23
        abbrev_number);
4513
23
      bfd_set_error (bfd_error_bad_value);
4514
23
      return NULL;
4515
23
    }
4516
4517
1.03k
  amt = sizeof (struct comp_unit);
4518
1.03k
  unit = (struct comp_unit *) bfd_zalloc (abfd, amt);
4519
1.03k
  if (unit == NULL)
4520
0
    return NULL;
4521
1.03k
  unit->abfd = abfd;
4522
1.03k
  unit->version = version;
4523
1.03k
  unit->addr_size = addr_size;
4524
1.03k
  unit->offset_size = offset_size;
4525
1.03k
  unit->abbrevs = abbrevs;
4526
1.03k
  unit->end_ptr = end_ptr;
4527
1.03k
  unit->stash = stash;
4528
1.03k
  unit->file = file;
4529
1.03k
  unit->info_ptr_unit = info_ptr_unit;
4530
4531
1.03k
  if (abbrev->tag == DW_TAG_compile_unit)
4532
981
    compunit_flag = true;
4533
4534
7.89k
  for (i = 0; i < abbrev->num_attrs; ++i)
4535
6.93k
    {
4536
6.93k
      info_ptr = read_attribute (&attr, &abbrev->attrs[i], unit, info_ptr, end_ptr);
4537
6.93k
      if (info_ptr == NULL)
4538
37
  goto err_exit;
4539
4540
      /* Identify attributes of the form strx* and addrx* which come before
4541
   DW_AT_str_offsets_base and DW_AT_addr_base respectively in the CU.
4542
   Store the attributes in an array and process them later.  */
4543
6.89k
      if ((unit->dwarf_str_offset == 0 && is_strx_form (attr.form))
4544
6.71k
    || (unit->dwarf_addr_offset == 0 && is_addrx_form (attr.form)))
4545
242
  {
4546
242
    if (str_count <= str_alloc)
4547
242
      {
4548
242
        str_alloc = 2 * str_alloc + 200;
4549
242
        str_addrp = bfd_realloc (str_addrp,
4550
242
               str_alloc * sizeof (*str_addrp));
4551
242
        if (str_addrp == NULL)
4552
0
    goto err_exit;
4553
242
      }
4554
242
    str_addrp[str_count] = attr;
4555
242
    str_count++;
4556
242
    continue;
4557
242
  }
4558
4559
      /* Store the data if it is of an attribute we want to keep in a
4560
   partial symbol table.  */
4561
6.65k
      switch (attr.name)
4562
6.65k
  {
4563
974
  case DW_AT_stmt_list:
4564
974
    if (is_int_form (&attr))
4565
971
      {
4566
971
        unit->stmtlist = 1;
4567
971
        unit->line_offset = attr.u.val;
4568
971
      }
4569
974
    break;
4570
4571
910
  case DW_AT_name:
4572
910
    if (is_str_form (&attr))
4573
875
      unit->name = attr.u.str;
4574
910
    break;
4575
4576
823
  case DW_AT_low_pc:
4577
823
    if (is_int_form (&attr))
4578
820
      {
4579
820
        low_pc = attr.u.val;
4580
        /* If the compilation unit DIE has a DW_AT_low_pc attribute,
4581
     this is the base address to use when reading location
4582
     lists or range lists.  */
4583
820
        if (compunit_flag)
4584
796
    unit->base_address = low_pc;
4585
820
      }
4586
823
    break;
4587
4588
735
  case DW_AT_high_pc:
4589
735
    if (is_int_form (&attr))
4590
698
      {
4591
698
        high_pc = attr.u.val;
4592
698
        high_pc_relative = attr.form != DW_FORM_addr;
4593
698
      }
4594
735
    break;
4595
4596
193
  case DW_AT_ranges:
4597
193
    if (is_int_form (&attr)
4598
193
        && !read_rangelist (unit, &unit->arange,
4599
193
          &unit->file->trie_root, attr.u.val))
4600
29
      goto err_exit;
4601
164
    break;
4602
4603
889
  case DW_AT_comp_dir:
4604
889
    {
4605
889
      char *comp_dir = attr.u.str;
4606
4607
      /* PR 17512: file: 1fe726be.  */
4608
889
      if (!is_str_form (&attr))
4609
24
        {
4610
24
    _bfd_error_handler
4611
24
      (_("DWARF error: DW_AT_comp_dir attribute encountered with a non-string form"));
4612
24
    comp_dir = NULL;
4613
24
        }
4614
4615
889
      if (comp_dir)
4616
557
        {
4617
    /* Irix 6.2 native cc prepends <machine>.: to the compilation
4618
       directory, get rid of it.  */
4619
557
    char *cp = strchr (comp_dir, ':');
4620
4621
557
    if (cp && cp != comp_dir && cp[-1] == '.' && cp[1] == '/')
4622
0
      comp_dir = cp + 1;
4623
557
        }
4624
889
      unit->comp_dir = comp_dir;
4625
889
      break;
4626
193
    }
4627
4628
993
  case DW_AT_language:
4629
993
    if (is_int_form (&attr))
4630
960
      unit->lang = attr.u.val;
4631
993
    break;
4632
4633
14
  case DW_AT_addr_base:
4634
14
    unit->dwarf_addr_offset = attr.u.val;
4635
14
    break;
4636
4637
1
  case DW_AT_str_offsets_base:
4638
1
    unit->dwarf_str_offset = attr.u.val;
4639
1
    break;
4640
4641
1.12k
  default:
4642
1.12k
    break;
4643
6.65k
  }
4644
6.65k
    }
4645
4646
1.18k
  for (i = 0; i < str_count; ++i)
4647
218
    reread_attribute (unit, &str_addrp[i], &low_pc, &high_pc,
4648
218
          &high_pc_relative, compunit_flag);
4649
4650
964
  if (high_pc_relative)
4651
613
    high_pc += low_pc;
4652
964
  if (high_pc != 0)
4653
605
    {
4654
605
      if (!arange_add (unit, &unit->arange, &unit->file->trie_root,
4655
605
           low_pc, high_pc))
4656
0
  goto err_exit;
4657
605
    }
4658
4659
964
  unit->first_child_die_ptr = info_ptr;
4660
4661
964
  free (str_addrp);
4662
964
  return unit;
4663
4664
66
 err_exit:
4665
66
  unit->error = 1;
4666
66
  free (str_addrp);
4667
66
  return NULL;
4668
964
}
4669
4670
/* Return TRUE if UNIT may contain the address given by ADDR.  When
4671
   there are functions written entirely with inline asm statements, the
4672
   range info in the compilation unit header may not be correct.  We
4673
   need to consult the line info table to see if a compilation unit
4674
   really contains the given address.  */
4675
4676
static bool
4677
comp_unit_may_contain_address (struct comp_unit *unit, bfd_vma addr)
4678
2.31k
{
4679
2.31k
  struct arange *arange;
4680
4681
2.31k
  if (unit->error)
4682
535
    return false;
4683
4684
1.78k
  if (unit->arange.high == 0 /* No ranges have been computed yet.  */
4685
1.46k
      || unit->line_table == NULL) /* The line info table has not been loaded.  */
4686
991
    return true;
4687
4688
1.89k
  for (arange = &unit->arange; arange != NULL; arange = arange->next)
4689
1.49k
    if (addr >= arange->low && addr < arange->high)
4690
385
      return true;
4691
4692
405
  return false;
4693
790
}
4694
4695
/* If UNIT contains ADDR, set the output parameters to the values for
4696
   the line containing ADDR and return TRUE.  Otherwise return FALSE.
4697
   The output parameters, FILENAME_PTR, FUNCTION_PTR, and
4698
   LINENUMBER_PTR, are pointers to the objects to be filled in.  */
4699
4700
static bool
4701
comp_unit_find_nearest_line (struct comp_unit *unit,
4702
           bfd_vma addr,
4703
           const char **filename_ptr,
4704
           struct funcinfo **function_ptr,
4705
           unsigned int *linenumber_ptr,
4706
           unsigned int *discriminator_ptr)
4707
7.51k
{
4708
7.51k
  bool line_p, func_p;
4709
4710
7.51k
  if (!comp_unit_maybe_decode_line_info (unit))
4711
3.20k
    return false;
4712
4713
4.30k
  *function_ptr = NULL;
4714
4.30k
  func_p = lookup_address_in_function_table (unit, addr, function_ptr);
4715
4716
4.30k
  if (func_p && (*function_ptr)->tag == DW_TAG_inlined_subroutine)
4717
549
    unit->stash->inliner_chain = *function_ptr;
4718
4719
4.30k
  line_p = lookup_address_in_line_info_table (unit->line_table, addr,
4720
4.30k
                filename_ptr,
4721
4.30k
                linenumber_ptr,
4722
4.30k
                discriminator_ptr);
4723
4.30k
  return line_p || func_p;
4724
7.51k
}
4725
4726
/* Check to see if line info is already decoded in a comp_unit.
4727
   If not, decode it.  Returns TRUE if no errors were encountered;
4728
   FALSE otherwise.  */
4729
4730
static bool
4731
comp_unit_maybe_decode_line_info (struct comp_unit *unit)
4732
10.3k
{
4733
10.3k
  if (unit->error)
4734
3.67k
    return false;
4735
4736
6.67k
  if (! unit->line_table)
4737
964
    {
4738
964
      if (! unit->stmtlist)
4739
27
  {
4740
27
    unit->error = 1;
4741
27
    return false;
4742
27
  }
4743
4744
937
      unit->line_table = decode_line_info (unit);
4745
4746
937
      if (! unit->line_table)
4747
302
  {
4748
302
    unit->error = 1;
4749
302
    return false;
4750
302
  }
4751
4752
635
      if (unit->first_child_die_ptr < unit->end_ptr
4753
576
    && ! scan_unit_for_symbols (unit))
4754
170
  {
4755
170
    unit->error = 1;
4756
170
    return false;
4757
170
  }
4758
635
    }
4759
4760
6.17k
  return true;
4761
6.67k
}
4762
4763
/* If UNIT contains SYM at ADDR, set the output parameters to the
4764
   values for the line containing SYM.  The output parameters,
4765
   FILENAME_PTR, and LINENUMBER_PTR, are pointers to the objects to be
4766
   filled in.
4767
4768
   Return TRUE if UNIT contains SYM, and no errors were encountered;
4769
   FALSE otherwise.  */
4770
4771
static bool
4772
comp_unit_find_line (struct comp_unit *unit,
4773
         asymbol *sym,
4774
         bfd_vma addr,
4775
         const char **filename_ptr,
4776
         unsigned int *linenumber_ptr)
4777
2.82k
{
4778
2.82k
  if (!comp_unit_maybe_decode_line_info (unit))
4779
960
    return false;
4780
4781
1.86k
  if (sym->flags & BSF_FUNCTION)
4782
461
    return lookup_symbol_in_function_table (unit, sym, addr,
4783
461
              filename_ptr,
4784
461
              linenumber_ptr);
4785
4786
1.40k
  return lookup_symbol_in_variable_table (unit, sym, addr,
4787
1.40k
            filename_ptr,
4788
1.40k
            linenumber_ptr);
4789
1.86k
}
4790
4791
/* Extract all interesting funcinfos and varinfos of a compilation
4792
   unit into hash tables for faster lookup.  Returns TRUE if no
4793
   errors were enountered; FALSE otherwise.  */
4794
4795
static bool
4796
comp_unit_hash_info (struct dwarf2_debug *stash,
4797
         struct comp_unit *unit,
4798
         struct info_hash_table *funcinfo_hash_table,
4799
         struct info_hash_table *varinfo_hash_table)
4800
0
{
4801
0
  struct funcinfo* each_func;
4802
0
  struct varinfo* each_var;
4803
0
  bool okay = true;
4804
4805
0
  BFD_ASSERT (stash->info_hash_status != STASH_INFO_HASH_DISABLED);
4806
4807
0
  if (!comp_unit_maybe_decode_line_info (unit))
4808
0
    return false;
4809
4810
0
  BFD_ASSERT (!unit->cached);
4811
4812
  /* To preserve the original search order, we went to visit the function
4813
     infos in the reversed order of the list.  However, making the list
4814
     bi-directional use quite a bit of extra memory.  So we reverse
4815
     the list first, traverse the list in the now reversed order and
4816
     finally reverse the list again to get back the original order.  */
4817
0
  unit->function_table = reverse_funcinfo_list (unit->function_table);
4818
0
  for (each_func = unit->function_table;
4819
0
       each_func && okay;
4820
0
       each_func = each_func->prev_func)
4821
0
    {
4822
      /* Skip nameless functions.  */
4823
0
      if (each_func->name)
4824
  /* There is no need to copy name string into hash table as
4825
     name string is either in the dwarf string buffer or
4826
     info in the stash.  */
4827
0
  okay = insert_info_hash_table (funcinfo_hash_table, each_func->name,
4828
0
               (void*) each_func, false);
4829
0
    }
4830
0
  unit->function_table = reverse_funcinfo_list (unit->function_table);
4831
0
  if (!okay)
4832
0
    return false;
4833
4834
  /* We do the same for variable infos.  */
4835
0
  unit->variable_table = reverse_varinfo_list (unit->variable_table);
4836
0
  for (each_var = unit->variable_table;
4837
0
       each_var && okay;
4838
0
       each_var = each_var->prev_var)
4839
0
    {
4840
      /* Skip stack vars and vars with no files or names.  */
4841
0
      if (! each_var->stack
4842
0
    && each_var->file != NULL
4843
0
    && each_var->name != NULL)
4844
  /* There is no need to copy name string into hash table as
4845
     name string is either in the dwarf string buffer or
4846
     info in the stash.  */
4847
0
  okay = insert_info_hash_table (varinfo_hash_table, each_var->name,
4848
0
               (void*) each_var, false);
4849
0
    }
4850
4851
0
  unit->variable_table = reverse_varinfo_list (unit->variable_table);
4852
0
  unit->cached = true;
4853
0
  return okay;
4854
0
}
4855
4856
/* Locate a section in a BFD containing debugging info.  The search starts
4857
   from the section after AFTER_SEC, or from the first section in the BFD if
4858
   AFTER_SEC is NULL.  The search works by examining the names of the
4859
   sections.  There are three permissiable names.  The first two are given
4860
   by DEBUG_SECTIONS[debug_info] (whose standard DWARF2 names are .debug_info
4861
   and .zdebug_info).  The third is a prefix .gnu.linkonce.wi.
4862
   This is a variation on the .debug_info section which has a checksum
4863
   describing the contents appended onto the name.  This allows the linker to
4864
   identify and discard duplicate debugging sections for different
4865
   compilation units.  */
4866
181k
#define GNU_LINKONCE_INFO ".gnu.linkonce.wi."
4867
4868
static asection *
4869
find_debug_info (bfd *abfd, const struct dwarf_debug_section *debug_sections,
4870
     asection *after_sec)
4871
8.39k
{
4872
8.39k
  asection *msec;
4873
8.39k
  const char *look;
4874
4875
8.39k
  if (after_sec == NULL)
4876
5.71k
    {
4877
5.71k
      look = debug_sections[debug_info].uncompressed_name;
4878
5.71k
      msec = bfd_get_section_by_name (abfd, look);
4879
      /* Testing SEC_HAS_CONTENTS is an anti-fuzzer measure.  Of
4880
   course debug sections always have contents.  */
4881
5.71k
      if (msec != NULL && (msec->flags & SEC_HAS_CONTENTS) != 0)
4882
2.06k
  return msec;
4883
4884
3.64k
      look = debug_sections[debug_info].compressed_name;
4885
3.64k
      msec = bfd_get_section_by_name (abfd, look);
4886
3.64k
      if (msec != NULL && (msec->flags & SEC_HAS_CONTENTS) != 0)
4887
0
        return msec;
4888
4889
136k
      for (msec = abfd->sections; msec != NULL; msec = msec->next)
4890
133k
  if ((msec->flags & SEC_HAS_CONTENTS) != 0
4891
101k
      && startswith (msec->name, GNU_LINKONCE_INFO))
4892
35
    return msec;
4893
4894
3.61k
      return NULL;
4895
3.64k
    }
4896
4897
19.5k
  for (msec = after_sec->next; msec != NULL; msec = msec->next)
4898
17.5k
    {
4899
17.5k
      if ((msec->flags & SEC_HAS_CONTENTS) == 0)
4900
67
  continue;
4901
4902
17.4k
      look = debug_sections[debug_info].uncompressed_name;
4903
17.4k
      if (strcmp (msec->name, look) == 0)
4904
617
  return msec;
4905
4906
16.8k
      look = debug_sections[debug_info].compressed_name;
4907
16.8k
      if (look != NULL && strcmp (msec->name, look) == 0)
4908
3
  return msec;
4909
4910
16.8k
      if (startswith (msec->name, GNU_LINKONCE_INFO))
4911
46
  return msec;
4912
16.8k
    }
4913
4914
2.01k
  return NULL;
4915
2.68k
}
4916
4917
/* Transfer VMAs from object file to separate debug file.  */
4918
4919
static void
4920
set_debug_vma (bfd *orig_bfd, bfd *debug_bfd)
4921
0
{
4922
0
  asection *s, *d;
4923
4924
0
  for (s = orig_bfd->sections, d = debug_bfd->sections;
4925
0
       s != NULL && d != NULL;
4926
0
       s = s->next, d = d->next)
4927
0
    {
4928
0
      if ((d->flags & SEC_DEBUGGING) != 0)
4929
0
  break;
4930
      /* ??? Assumes 1-1 correspondence between sections in the
4931
   two files.  */
4932
0
      if (strcmp (s->name, d->name) == 0)
4933
0
  {
4934
0
    d->output_section = s->output_section;
4935
0
    d->output_offset = s->output_offset;
4936
0
    d->vma = s->vma;
4937
0
  }
4938
0
    }
4939
0
}
4940
4941
/* If the dwarf2 info was found in a separate debug file, return the
4942
   debug file section corresponding to the section in the original file
4943
   and the debug file symbols.  */
4944
4945
static void
4946
_bfd_dwarf2_stash_syms (struct dwarf2_debug *stash, bfd *abfd,
4947
      asection **sec, asymbol ***syms)
4948
13.6k
{
4949
13.6k
  if (stash->f.bfd_ptr != abfd)
4950
0
    {
4951
0
      asection *s, *d;
4952
4953
0
      if (*sec == NULL)
4954
0
  {
4955
0
    *syms = stash->f.syms;
4956
0
    return;
4957
0
  }
4958
4959
0
      for (s = abfd->sections, d = stash->f.bfd_ptr->sections;
4960
0
     s != NULL && d != NULL;
4961
0
     s = s->next, d = d->next)
4962
0
  {
4963
0
    if ((d->flags & SEC_DEBUGGING) != 0)
4964
0
      break;
4965
0
    if (s == *sec
4966
0
        && strcmp (s->name, d->name) == 0)
4967
0
      {
4968
0
        *sec = d;
4969
0
        *syms = stash->f.syms;
4970
0
        break;
4971
0
      }
4972
0
  }
4973
0
    }
4974
13.6k
}
4975
4976
/* Unset vmas for adjusted sections in STASH.  */
4977
4978
static void
4979
unset_sections (struct dwarf2_debug *stash)
4980
19.6k
{
4981
19.6k
  int i;
4982
19.6k
  struct adjusted_section *p;
4983
4984
19.6k
  i = stash->adjusted_section_count;
4985
19.6k
  p = stash->adjusted_sections;
4986
254k
  for (; i > 0; i--, p++)
4987
234k
    p->section->vma = p->orig_vma;
4988
19.6k
}
4989
4990
/* Set VMAs for allocated and .debug_info sections in ORIG_BFD, a
4991
   relocatable object file.  VMAs are normally all zero in relocatable
4992
   object files, so if we want to distinguish locations in sections by
4993
   address we need to set VMAs so the sections do not overlap.  We
4994
   also set VMA on .debug_info so that when we have multiple
4995
   .debug_info sections (or the linkonce variant) they also do not
4996
   overlap.  The multiple .debug_info sections make up a single
4997
   logical section.  ??? We should probably do the same for other
4998
   debug sections.  */
4999
5000
static bool
5001
place_sections (bfd *orig_bfd, struct dwarf2_debug *stash)
5002
18.8k
{
5003
18.8k
  bfd *abfd;
5004
18.8k
  struct adjusted_section *p;
5005
18.8k
  int i;
5006
18.8k
  const char *debug_info_name;
5007
5008
18.8k
  if (stash->adjusted_section_count != 0)
5009
16.9k
    {
5010
16.9k
      i = stash->adjusted_section_count;
5011
16.9k
      p = stash->adjusted_sections;
5012
235k
      for (; i > 0; i--, p++)
5013
218k
  p->section->vma = p->adj_vma;
5014
16.9k
      return true;
5015
16.9k
    }
5016
5017
1.86k
  debug_info_name = stash->debug_sections[debug_info].uncompressed_name;
5018
1.86k
  i = 0;
5019
1.86k
  abfd = orig_bfd;
5020
1.86k
  while (1)
5021
1.86k
    {
5022
1.86k
      asection *sect;
5023
5024
35.9k
      for (sect = abfd->sections; sect != NULL; sect = sect->next)
5025
34.0k
  {
5026
34.0k
    int is_debug_info;
5027
5028
34.0k
    if (sect->output_section != NULL
5029
0
        && sect->output_section != sect
5030
0
        && (sect->flags & SEC_DEBUGGING) == 0)
5031
0
      continue;
5032
5033
34.0k
    is_debug_info = (strcmp (sect->name, debug_info_name) == 0
5034
31.9k
         || startswith (sect->name, GNU_LINKONCE_INFO));
5035
5036
34.0k
    if (!((sect->flags & SEC_ALLOC) != 0 && abfd == orig_bfd)
5037
18.7k
        && !is_debug_info)
5038
17.1k
      continue;
5039
5040
16.9k
    i++;
5041
16.9k
  }
5042
1.86k
      if (abfd == stash->f.bfd_ptr)
5043
1.86k
  break;
5044
0
      abfd = stash->f.bfd_ptr;
5045
0
    }
5046
5047
1.86k
  if (i <= 1)
5048
0
    stash->adjusted_section_count = -1;
5049
1.86k
  else
5050
1.86k
    {
5051
1.86k
      bfd_vma last_vma = 0, last_dwarf = 0;
5052
1.86k
      size_t amt = i * sizeof (struct adjusted_section);
5053
5054
1.86k
      p = (struct adjusted_section *) bfd_malloc (amt);
5055
1.86k
      if (p == NULL)
5056
0
  return false;
5057
5058
1.86k
      stash->adjusted_sections = p;
5059
1.86k
      stash->adjusted_section_count = i;
5060
5061
1.86k
      abfd = orig_bfd;
5062
1.86k
      while (1)
5063
1.86k
  {
5064
1.86k
    asection *sect;
5065
5066
35.9k
    for (sect = abfd->sections; sect != NULL; sect = sect->next)
5067
34.0k
      {
5068
34.0k
        bfd_size_type sz;
5069
34.0k
        int is_debug_info;
5070
5071
34.0k
        if (sect->output_section != NULL
5072
0
      && sect->output_section != sect
5073
0
      && (sect->flags & SEC_DEBUGGING) == 0)
5074
0
    continue;
5075
5076
34.0k
        is_debug_info = (strcmp (sect->name, debug_info_name) == 0
5077
31.9k
             || startswith (sect->name, GNU_LINKONCE_INFO));
5078
5079
34.0k
        if (!((sect->flags & SEC_ALLOC) != 0 && abfd == orig_bfd)
5080
18.7k
      && !is_debug_info)
5081
17.1k
    continue;
5082
5083
16.9k
        sz = sect->rawsize ? sect->rawsize : sect->size;
5084
5085
16.9k
        p->section = sect;
5086
16.9k
        p->orig_vma = sect->vma;
5087
5088
16.9k
        bfd_vma *v = is_debug_info ? &last_dwarf : &last_vma;
5089
        /* Align the new address to the current section
5090
     alignment.  */
5091
16.9k
        bfd_vma mask = -(bfd_vma) 1 << sect->alignment_power;
5092
16.9k
        *v = (*v + ~mask) & mask;
5093
16.9k
        sect->vma = *v;
5094
16.9k
        *v += sz;
5095
5096
16.9k
        p->adj_vma = sect->vma;
5097
16.9k
        p++;
5098
16.9k
      }
5099
1.86k
    if (abfd == stash->f.bfd_ptr)
5100
1.86k
      break;
5101
0
    abfd = stash->f.bfd_ptr;
5102
0
  }
5103
1.86k
    }
5104
5105
1.86k
  if (orig_bfd != stash->f.bfd_ptr)
5106
0
    set_debug_vma (orig_bfd, stash->f.bfd_ptr);
5107
5108
1.86k
  return true;
5109
1.86k
}
5110
5111
/* Look up a funcinfo by name using the given info hash table.  If found,
5112
   also update the locations pointed to by filename_ptr and linenumber_ptr.
5113
5114
   This function returns TRUE if a funcinfo that matches the given symbol
5115
   and address is found with any error; otherwise it returns FALSE.  */
5116
5117
static bool
5118
info_hash_lookup_funcinfo (struct info_hash_table *hash_table,
5119
         asymbol *sym,
5120
         bfd_vma addr,
5121
         const char **filename_ptr,
5122
         unsigned int *linenumber_ptr)
5123
0
{
5124
0
  struct funcinfo* each_func;
5125
0
  struct funcinfo* best_fit = NULL;
5126
0
  bfd_vma best_fit_len = (bfd_vma) -1;
5127
0
  struct info_list_node *node;
5128
0
  struct arange *arange;
5129
0
  const char *name = bfd_asymbol_name (sym);
5130
5131
0
  for (node = lookup_info_hash_table (hash_table, name);
5132
0
       node;
5133
0
       node = node->next)
5134
0
    {
5135
0
      each_func = (struct funcinfo *) node->info;
5136
0
      for (arange = &each_func->arange;
5137
0
     arange;
5138
0
     arange = arange->next)
5139
0
  {
5140
0
    if (addr >= arange->low
5141
0
        && addr < arange->high
5142
0
        && arange->high - arange->low < best_fit_len)
5143
0
      {
5144
0
        best_fit = each_func;
5145
0
        best_fit_len = arange->high - arange->low;
5146
0
      }
5147
0
  }
5148
0
    }
5149
5150
0
  if (best_fit)
5151
0
    {
5152
0
      *filename_ptr = best_fit->file;
5153
0
      *linenumber_ptr = best_fit->line;
5154
0
      return true;
5155
0
    }
5156
5157
0
  return false;
5158
0
}
5159
5160
/* Look up a varinfo by name using the given info hash table.  If found,
5161
   also update the locations pointed to by filename_ptr and linenumber_ptr.
5162
5163
   This function returns TRUE if a varinfo that matches the given symbol
5164
   and address is found with any error; otherwise it returns FALSE.  */
5165
5166
static bool
5167
info_hash_lookup_varinfo (struct info_hash_table *hash_table,
5168
        asymbol *sym,
5169
        bfd_vma addr,
5170
        const char **filename_ptr,
5171
        unsigned int *linenumber_ptr)
5172
0
{
5173
0
  struct varinfo* each;
5174
0
  struct info_list_node *node;
5175
0
  const char *name = bfd_asymbol_name (sym);
5176
5177
0
  for (node = lookup_info_hash_table (hash_table, name);
5178
0
       node;
5179
0
       node = node->next)
5180
0
    {
5181
0
      each = (struct varinfo *) node->info;
5182
0
      if (each->addr == addr)
5183
0
  {
5184
0
    *filename_ptr = each->file;
5185
0
    *linenumber_ptr = each->line;
5186
0
    return true;
5187
0
  }
5188
0
    }
5189
5190
0
  return false;
5191
0
}
5192
5193
/* Update the funcinfo and varinfo info hash tables if they are
5194
   not up to date.  Returns TRUE if there is no error; otherwise
5195
   returns FALSE and disable the info hash tables.  */
5196
5197
static bool
5198
stash_maybe_update_info_hash_tables (struct dwarf2_debug *stash)
5199
0
{
5200
0
  struct comp_unit *each;
5201
5202
  /* Exit if hash tables are up-to-date.  */
5203
0
  if (stash->f.all_comp_units == stash->hash_units_head)
5204
0
    return true;
5205
5206
0
  if (stash->hash_units_head)
5207
0
    each = stash->hash_units_head->prev_unit;
5208
0
  else
5209
0
    each = stash->f.last_comp_unit;
5210
5211
0
  while (each)
5212
0
    {
5213
0
      if (!comp_unit_hash_info (stash, each, stash->funcinfo_hash_table,
5214
0
        stash->varinfo_hash_table))
5215
0
  {
5216
0
    stash->info_hash_status = STASH_INFO_HASH_DISABLED;
5217
0
    return false;
5218
0
  }
5219
0
      each = each->prev_unit;
5220
0
    }
5221
5222
0
  stash->hash_units_head = stash->f.all_comp_units;
5223
0
  return true;
5224
0
}
5225
5226
/* Check consistency of info hash tables.  This is for debugging only.  */
5227
5228
static void ATTRIBUTE_UNUSED
5229
stash_verify_info_hash_table (struct dwarf2_debug *stash)
5230
0
{
5231
0
  struct comp_unit *each_unit;
5232
0
  struct funcinfo *each_func;
5233
0
  struct varinfo *each_var;
5234
0
  struct info_list_node *node;
5235
0
  bool found;
5236
0
5237
0
  for (each_unit = stash->f.all_comp_units;
5238
0
       each_unit;
5239
0
       each_unit = each_unit->next_unit)
5240
0
    {
5241
0
      for (each_func = each_unit->function_table;
5242
0
     each_func;
5243
0
     each_func = each_func->prev_func)
5244
0
  {
5245
0
    if (!each_func->name)
5246
0
      continue;
5247
0
    node = lookup_info_hash_table (stash->funcinfo_hash_table,
5248
0
           each_func->name);
5249
0
    BFD_ASSERT (node);
5250
0
    found = false;
5251
0
    while (node && !found)
5252
0
      {
5253
0
        found = node->info == each_func;
5254
0
        node = node->next;
5255
0
      }
5256
0
    BFD_ASSERT (found);
5257
0
  }
5258
0
5259
0
      for (each_var = each_unit->variable_table;
5260
0
     each_var;
5261
0
     each_var = each_var->prev_var)
5262
0
  {
5263
0
    if (!each_var->name || !each_var->file || each_var->stack)
5264
0
      continue;
5265
0
    node = lookup_info_hash_table (stash->varinfo_hash_table,
5266
0
           each_var->name);
5267
0
    BFD_ASSERT (node);
5268
0
    found = false;
5269
0
    while (node && !found)
5270
0
      {
5271
0
        found = node->info == each_var;
5272
0
        node = node->next;
5273
0
      }
5274
0
    BFD_ASSERT (found);
5275
0
  }
5276
0
    }
5277
0
}
5278
5279
/* Check to see if we want to enable the info hash tables, which consume
5280
   quite a bit of memory.  Currently we only check the number times
5281
   bfd_dwarf2_find_line is called.  In the future, we may also want to
5282
   take the number of symbols into account.  */
5283
5284
static void
5285
stash_maybe_enable_info_hash_tables (bfd *abfd, struct dwarf2_debug *stash)
5286
4.60k
{
5287
4.60k
  BFD_ASSERT (stash->info_hash_status == STASH_INFO_HASH_OFF);
5288
5289
4.60k
  if (stash->info_hash_count++ < STASH_INFO_HASH_TRIGGER)
5290
4.60k
    return;
5291
5292
  /* FIXME: Maybe we should check the reduce_memory_overheads
5293
     and optimize fields in the bfd_link_info structure ?  */
5294
5295
  /* Create hash tables.  */
5296
0
  stash->funcinfo_hash_table = create_info_hash_table (abfd);
5297
0
  stash->varinfo_hash_table = create_info_hash_table (abfd);
5298
0
  if (!stash->funcinfo_hash_table || !stash->varinfo_hash_table)
5299
0
    {
5300
      /* Turn off info hashes if any allocation above fails.  */
5301
0
      stash->info_hash_status = STASH_INFO_HASH_DISABLED;
5302
0
      return;
5303
0
    }
5304
  /* We need a forced update so that the info hash tables will
5305
     be created even though there is no compilation unit.  That
5306
     happens if STASH_INFO_HASH_TRIGGER is 0.  */
5307
0
  if (stash_maybe_update_info_hash_tables (stash))
5308
0
    stash->info_hash_status = STASH_INFO_HASH_ON;
5309
0
}
5310
5311
/* Find the file and line associated with a symbol and address using the
5312
   info hash tables of a stash. If there is a match, the function returns
5313
   TRUE and update the locations pointed to by filename_ptr and linenumber_ptr;
5314
   otherwise it returns FALSE.  */
5315
5316
static bool
5317
stash_find_line_fast (struct dwarf2_debug *stash,
5318
          asymbol *sym,
5319
          bfd_vma addr,
5320
          const char **filename_ptr,
5321
          unsigned int *linenumber_ptr)
5322
0
{
5323
0
  BFD_ASSERT (stash->info_hash_status == STASH_INFO_HASH_ON);
5324
5325
0
  if (sym->flags & BSF_FUNCTION)
5326
0
    return info_hash_lookup_funcinfo (stash->funcinfo_hash_table, sym, addr,
5327
0
              filename_ptr, linenumber_ptr);
5328
0
  return info_hash_lookup_varinfo (stash->varinfo_hash_table, sym, addr,
5329
0
           filename_ptr, linenumber_ptr);
5330
0
}
5331
5332
/* Save current section VMAs.  */
5333
5334
static bool
5335
save_section_vma (const bfd *abfd, struct dwarf2_debug *stash)
5336
5.52k
{
5337
5.52k
  asection *s;
5338
5.52k
  unsigned int i;
5339
5340
5.52k
  if (abfd->section_count == 0)
5341
0
    return true;
5342
5.52k
  stash->sec_vma = bfd_malloc (sizeof (*stash->sec_vma) * abfd->section_count);
5343
5.52k
  if (stash->sec_vma == NULL)
5344
0
    return false;
5345
5.52k
  stash->sec_vma_count = abfd->section_count;
5346
5.52k
  for (i = 0, s = abfd->sections;
5347
173k
       s != NULL && i < abfd->section_count;
5348
168k
       i++, s = s->next)
5349
168k
    {
5350
168k
      if (s->output_section != NULL)
5351
0
  stash->sec_vma[i] = s->output_section->vma + s->output_offset;
5352
168k
      else
5353
168k
  stash->sec_vma[i] = s->vma;
5354
168k
    }
5355
5.52k
  return true;
5356
5.52k
}
5357
5358
/* Compare current section VMAs against those at the time the stash
5359
   was created.  If find_nearest_line is used in linker warnings or
5360
   errors early in the link process, the debug info stash will be
5361
   invalid for later calls.  This is because we relocate debug info
5362
   sections, so the stashed section contents depend on symbol values,
5363
   which in turn depend on section VMAs.  */
5364
5365
static bool
5366
section_vma_same (const bfd *abfd, const struct dwarf2_debug *stash)
5367
66.3k
{
5368
66.3k
  asection *s;
5369
66.3k
  unsigned int i;
5370
5371
  /* PR 24334: If the number of sections in ABFD has changed between
5372
     when the stash was created and now, then we cannot trust the
5373
     stashed vma information.  */
5374
66.3k
  if (abfd->section_count != stash->sec_vma_count)
5375
0
    return false;
5376
5377
66.3k
  for (i = 0, s = abfd->sections;
5378
6.37M
       s != NULL && i < abfd->section_count;
5379
6.30M
       i++, s = s->next)
5380
6.30M
    {
5381
6.30M
      bfd_vma vma;
5382
5383
6.30M
      if (s->output_section != NULL)
5384
0
  vma = s->output_section->vma + s->output_offset;
5385
6.30M
      else
5386
6.30M
  vma = s->vma;
5387
6.30M
      if (vma != stash->sec_vma[i])
5388
0
  return false;
5389
6.30M
    }
5390
66.3k
  return true;
5391
66.3k
}
5392
5393
/* Read debug information from DEBUG_BFD when DEBUG_BFD is specified.
5394
   If DEBUG_BFD is not specified, we read debug information from ABFD
5395
   or its gnu_debuglink. The results will be stored in PINFO.
5396
   The function returns TRUE iff debug information is ready.  */
5397
5398
bool
5399
_bfd_dwarf2_slurp_debug_info (bfd *abfd, bfd *debug_bfd,
5400
            const struct dwarf_debug_section *debug_sections,
5401
            asymbol **symbols,
5402
            void **pinfo,
5403
            bool do_place)
5404
71.9k
{
5405
71.9k
  bfd_size_type total_size;
5406
71.9k
  asection *msec;
5407
71.9k
  struct dwarf2_debug *stash = (struct dwarf2_debug *) *pinfo;
5408
5409
71.9k
  if (stash != NULL)
5410
66.3k
    {
5411
66.3k
      if (stash->orig_bfd_id == abfd->id
5412
66.3k
    && section_vma_same (abfd, stash))
5413
66.3k
  {
5414
    /* Check that we did previously find some debug information
5415
       before attempting to make use of it.  */
5416
66.3k
    if (stash->f.dwarf_info_size != 0)
5417
17.6k
      {
5418
17.6k
        if (do_place && !place_sections (abfd, stash))
5419
0
    return false;
5420
17.6k
        return true;
5421
17.6k
      }
5422
5423
48.6k
    return false;
5424
66.3k
  }
5425
0
      _bfd_dwarf2_cleanup_debug_info (abfd, pinfo);
5426
0
      memset (stash, 0, sizeof (*stash));
5427
0
    }
5428
5.52k
  else
5429
5.52k
    {
5430
5.52k
      stash = (struct dwarf2_debug *) bfd_zalloc (abfd, sizeof (*stash));
5431
5.52k
      if (! stash)
5432
0
  return false;
5433
5.52k
      *pinfo = stash;
5434
5.52k
    }
5435
5.52k
  stash->orig_bfd_id = abfd->id;
5436
5.52k
  stash->debug_sections = debug_sections;
5437
5.52k
  stash->f.syms = symbols;
5438
5.52k
  if (!save_section_vma (abfd, stash))
5439
0
    return false;
5440
5441
5.52k
  stash->f.abbrev_offsets = htab_create_alloc (10, hash_abbrev, eq_abbrev,
5442
5.52k
                 del_abbrev, calloc, free);
5443
5.52k
  if (!stash->f.abbrev_offsets)
5444
0
    return false;
5445
5446
5.52k
  stash->alt.abbrev_offsets = htab_create_alloc (10, hash_abbrev, eq_abbrev,
5447
5.52k
             del_abbrev, calloc, free);
5448
5.52k
  if (!stash->alt.abbrev_offsets)
5449
0
    return false;
5450
5451
5.52k
  stash->f.trie_root = alloc_trie_leaf (abfd);
5452
5.52k
  if (!stash->f.trie_root)
5453
0
    return false;
5454
5455
5.52k
  stash->alt.trie_root = alloc_trie_leaf (abfd);
5456
5.52k
  if (!stash->alt.trie_root)
5457
0
    return false;
5458
5459
5.52k
  if (debug_bfd == NULL)
5460
5.52k
    debug_bfd = abfd;
5461
5462
5.52k
  msec = find_debug_info (debug_bfd, debug_sections, NULL);
5463
5.52k
  if (msec == NULL && abfd == debug_bfd)
5464
3.61k
    {
5465
3.61k
      char * debug_filename;
5466
5467
3.61k
      debug_filename = bfd_follow_build_id_debuglink (abfd, DEBUGDIR);
5468
3.61k
      if (debug_filename == NULL)
5469
3.61k
  debug_filename = bfd_follow_gnu_debuglink (abfd, DEBUGDIR);
5470
5471
3.61k
      if (debug_filename == NULL)
5472
  /* No dwarf2 info, and no gnu_debuglink to follow.
5473
     Note that at this point the stash has been allocated, but
5474
     contains zeros.  This lets future calls to this function
5475
     fail more quickly.  */
5476
3.61k
  return false;
5477
5478
0
      debug_bfd = bfd_openr (debug_filename, NULL);
5479
0
      free (debug_filename);
5480
0
      if (debug_bfd == NULL)
5481
  /* FIXME: Should we report our failure to follow the debuglink ?  */
5482
0
  return false;
5483
5484
      /* Set BFD_DECOMPRESS to decompress debug sections.  */
5485
0
      debug_bfd->flags |= BFD_DECOMPRESS;
5486
0
      if (!bfd_check_format (debug_bfd, bfd_object)
5487
0
    || (msec = find_debug_info (debug_bfd,
5488
0
              debug_sections, NULL)) == NULL
5489
0
    || !bfd_generic_link_read_symbols (debug_bfd))
5490
0
  {
5491
0
    bfd_close (debug_bfd);
5492
0
    return false;
5493
0
  }
5494
5495
0
      symbols = bfd_get_outsymbols (debug_bfd);
5496
0
      stash->f.syms = symbols;
5497
0
      stash->close_on_cleanup = true;
5498
0
    }
5499
1.91k
  stash->f.bfd_ptr = debug_bfd;
5500
5501
1.91k
  if (do_place
5502
1.86k
      && !place_sections (abfd, stash))
5503
0
    return false;
5504
5505
  /* There can be more than one DWARF2 info section in a BFD these
5506
     days.  First handle the easy case when there's only one.  If
5507
     there's more than one, try case two: read them all in and produce
5508
     one large stash.  We do this in two passes - in the first pass we
5509
     just accumulate the section sizes, and in the second pass we
5510
     read in the section's contents.  (The allows us to avoid
5511
     reallocing the data as we add sections to the stash.)  */
5512
5513
1.91k
  if (! find_debug_info (debug_bfd, debug_sections, msec))
5514
1.71k
    {
5515
      /* Case 1: only one info section.  */
5516
1.71k
      total_size = bfd_get_section_limit_octets (debug_bfd, msec);
5517
1.71k
      if (! read_section (debug_bfd, &stash->debug_sections[debug_info],
5518
1.71k
        symbols, 0,
5519
1.71k
        &stash->f.dwarf_info_buffer, &total_size))
5520
556
  goto restore_vma;
5521
1.71k
    }
5522
206
  else
5523
206
    {
5524
      /* Case 2: multiple sections.  */
5525
206
      for (total_size = 0;
5526
651
     msec;
5527
445
     msec = find_debug_info (debug_bfd, debug_sections, msec))
5528
469
  {
5529
469
    if (bfd_section_size_insane (debug_bfd, msec))
5530
24
      goto restore_vma;
5531
445
    bfd_size_type readsz = bfd_get_section_limit_octets (debug_bfd, msec);
5532
    /* Catch PR25070 testcase overflowing size calculation here.  */
5533
445
    if (total_size + readsz < total_size)
5534
0
      {
5535
0
        bfd_set_error (bfd_error_no_memory);
5536
0
        goto restore_vma;
5537
0
      }
5538
445
    total_size += readsz;
5539
445
  }
5540
5541
182
      stash->f.dwarf_info_buffer = (bfd_byte *) bfd_malloc (total_size);
5542
182
      if (stash->f.dwarf_info_buffer == NULL)
5543
0
  goto restore_vma;
5544
5545
182
      total_size = 0;
5546
182
      for (msec = find_debug_info (debug_bfd, debug_sections, NULL);
5547
501
     msec;
5548
319
     msec = find_debug_info (debug_bfd, debug_sections, msec))
5549
379
  {
5550
379
    bfd_size_type readsz = bfd_get_section_limit_octets (debug_bfd, msec);
5551
379
    if (readsz == 0)
5552
30
      continue;
5553
5554
349
    if (!(bfd_simple_get_relocated_section_contents
5555
349
    (debug_bfd, msec, stash->f.dwarf_info_buffer + total_size,
5556
349
     symbols)))
5557
60
      goto restore_vma;
5558
5559
289
    total_size += readsz;
5560
289
  }
5561
182
    }
5562
5563
1.27k
  stash->f.info_ptr = stash->f.dwarf_info_buffer;
5564
1.27k
  stash->f.dwarf_info_size = total_size;
5565
1.27k
  return true;
5566
5567
640
 restore_vma:
5568
640
  unset_sections (stash);
5569
640
  return false;
5570
1.91k
}
5571
5572
/* Parse the next DWARF2 compilation unit at FILE->INFO_PTR.  */
5573
5574
static struct comp_unit *
5575
stash_comp_unit (struct dwarf2_debug *stash, struct dwarf2_debug_file *file)
5576
17.0k
{
5577
17.0k
  bfd_size_type length;
5578
17.0k
  unsigned int offset_size;
5579
17.0k
  bfd_byte *info_ptr_unit = file->info_ptr;
5580
17.0k
  bfd_byte *info_ptr_end = file->dwarf_info_buffer + file->dwarf_info_size;
5581
5582
17.0k
  if (file->info_ptr >= info_ptr_end)
5583
15.6k
    return NULL;
5584
5585
1.45k
  length = read_4_bytes (file->bfd_ptr, &file->info_ptr, info_ptr_end);
5586
  /* A 0xffffff length is the DWARF3 way of indicating
5587
     we use 64-bit offsets, instead of 32-bit offsets.  */
5588
1.45k
  if (length == 0xffffffff)
5589
11
    {
5590
11
      offset_size = 8;
5591
11
      length = read_8_bytes (file->bfd_ptr, &file->info_ptr, info_ptr_end);
5592
11
    }
5593
  /* A zero length is the IRIX way of indicating 64-bit offsets,
5594
     mostly because the 64-bit length will generally fit in 32
5595
     bits, and the endianness helps.  */
5596
1.44k
  else if (length == 0)
5597
76
    {
5598
76
      offset_size = 8;
5599
76
      length = read_4_bytes (file->bfd_ptr, &file->info_ptr, info_ptr_end);
5600
76
    }
5601
  /* In the absence of the hints above, we assume 32-bit DWARF2
5602
     offsets even for targets with 64-bit addresses, because:
5603
     a) most of the time these targets will not have generated
5604
     more than 2Gb of debug info and so will not need 64-bit
5605
     offsets,
5606
     and
5607
     b) if they do use 64-bit offsets but they are not using
5608
     the size hints that are tested for above then they are
5609
     not conforming to the DWARF3 standard anyway.  */
5610
1.36k
  else
5611
1.36k
    offset_size = 4;
5612
5613
1.45k
  if (length != 0
5614
1.42k
      && length <= (size_t) (info_ptr_end - file->info_ptr))
5615
1.16k
    {
5616
1.16k
      struct comp_unit *each = parse_comp_unit (stash, file,
5617
1.16k
            file->info_ptr, length,
5618
1.16k
            info_ptr_unit, offset_size);
5619
1.16k
      if (each)
5620
964
  {
5621
964
    if (file->comp_unit_tree == NULL)
5622
912
      file->comp_unit_tree
5623
912
        = splay_tree_new (splay_tree_compare_addr_range,
5624
912
        splay_tree_free_addr_range, NULL);
5625
5626
964
    struct addr_range *r
5627
964
      = (struct addr_range *)bfd_malloc (sizeof (struct addr_range));
5628
964
    r->start = each->info_ptr_unit;
5629
964
    r->end = each->end_ptr;
5630
964
    splay_tree_node v = splay_tree_lookup (file->comp_unit_tree,
5631
964
             (splay_tree_key)r);
5632
964
    if (v != NULL || r->end <= r->start)
5633
0
      abort ();
5634
964
    splay_tree_insert (file->comp_unit_tree, (splay_tree_key)r,
5635
964
           (splay_tree_value)each);
5636
5637
964
    if (file->all_comp_units)
5638
52
      file->all_comp_units->prev_unit = each;
5639
912
    else
5640
912
      file->last_comp_unit = each;
5641
5642
964
    each->next_unit = file->all_comp_units;
5643
964
    file->all_comp_units = each;
5644
5645
964
    if (each->arange.high == 0)
5646
260
      {
5647
260
        each->next_unit_without_ranges = file->all_comp_units_without_ranges;
5648
260
        file->all_comp_units_without_ranges = each;
5649
260
      }
5650
5651
964
    file->info_ptr += length;
5652
964
    return each;
5653
964
  }
5654
1.16k
    }
5655
5656
  /* Don't trust any of the DWARF info after a corrupted length or
5657
     parse error.  */
5658
490
  file->info_ptr = info_ptr_end;
5659
490
  return NULL;
5660
1.45k
}
5661
5662
/* Hash function for an asymbol.  */
5663
5664
static hashval_t
5665
hash_asymbol (const void *sym)
5666
143
{
5667
143
  const asymbol *asym = sym;
5668
143
  return htab_hash_string (asym->name);
5669
143
}
5670
5671
/* Equality function for asymbols.  */
5672
5673
static int
5674
eq_asymbol (const void *a, const void *b)
5675
0
{
5676
0
  const asymbol *sa = a;
5677
0
  const asymbol *sb = b;
5678
0
  return strcmp (sa->name, sb->name) == 0;
5679
0
}
5680
5681
/* Scan the debug information in PINFO looking for a DW_TAG_subprogram
5682
   abbrev with a DW_AT_low_pc attached to it.  Then lookup that same
5683
   symbol in SYMBOLS and return the difference between the low_pc and
5684
   the symbol's address.  Returns 0 if no suitable symbol could be found.  */
5685
5686
bfd_signed_vma
5687
_bfd_dwarf2_find_symbol_bias (asymbol ** symbols, void ** pinfo)
5688
333
{
5689
333
  struct dwarf2_debug *stash;
5690
333
  struct comp_unit * unit;
5691
333
  htab_t sym_hash;
5692
333
  bfd_signed_vma result = 0;
5693
333
  asymbol ** psym;
5694
5695
333
  stash = (struct dwarf2_debug *) *pinfo;
5696
5697
333
  if (stash == NULL || symbols == NULL)
5698
0
    return 0;
5699
5700
333
  sym_hash = htab_create_alloc (10, hash_asymbol, eq_asymbol,
5701
333
        NULL, xcalloc, free);
5702
1.91k
  for (psym = symbols; * psym != NULL; psym++)
5703
1.57k
    {
5704
1.57k
      asymbol * sym = * psym;
5705
5706
1.57k
      if (sym->flags & BSF_FUNCTION && sym->section != NULL)
5707
143
  {
5708
143
    void **slot = htab_find_slot (sym_hash, sym, INSERT);
5709
143
    *slot = sym;
5710
143
  }
5711
1.57k
    }
5712
5713
333
  for (unit = stash->f.all_comp_units; unit; unit = unit->next_unit)
5714
0
    {
5715
0
      struct funcinfo * func;
5716
5717
0
      comp_unit_maybe_decode_line_info (unit);
5718
5719
0
      for (func = unit->function_table; func != NULL; func = func->prev_func)
5720
0
  if (func->name && func->arange.low)
5721
0
    {
5722
0
      asymbol search, *sym;
5723
5724
      /* FIXME: Do we need to scan the aranges looking for the
5725
         lowest pc value?  */
5726
5727
0
      search.name = func->name;
5728
0
      sym = htab_find (sym_hash, &search);
5729
0
      if (sym != NULL)
5730
0
        {
5731
0
    result = func->arange.low - (sym->value + sym->section->vma);
5732
0
    goto done;
5733
0
        }
5734
0
    }
5735
0
    }
5736
5737
333
 done:
5738
333
  htab_delete (sym_hash);
5739
333
  return result;
5740
333
}
5741
5742
/* See _bfd_dwarf2_find_nearest_line_with_alt.  */
5743
5744
int
5745
_bfd_dwarf2_find_nearest_line (bfd *abfd,
5746
             asymbol **symbols,
5747
             asymbol *symbol,
5748
             asection *section,
5749
             bfd_vma offset,
5750
             const char **filename_ptr,
5751
             const char **functionname_ptr,
5752
             unsigned int *linenumber_ptr,
5753
             unsigned int *discriminator_ptr,
5754
             const struct dwarf_debug_section *debug_sections,
5755
             void **pinfo)
5756
47.7k
{
5757
47.7k
  return _bfd_dwarf2_find_nearest_line_with_alt
5758
47.7k
    (abfd, NULL, symbols, symbol, section, offset, filename_ptr,
5759
47.7k
     functionname_ptr, linenumber_ptr, discriminator_ptr, debug_sections,
5760
47.7k
     pinfo);
5761
47.7k
}
5762
5763
/* Find the source code location of SYMBOL.  If SYMBOL is NULL
5764
   then find the nearest source code location corresponding to
5765
   the address SECTION + OFFSET.
5766
   Returns 1 if the line is found without error and fills in
5767
   FILENAME_PTR and LINENUMBER_PTR.  In the case where SYMBOL was
5768
   NULL the FUNCTIONNAME_PTR is also filled in.
5769
   Returns 2 if partial information from _bfd_elf_find_function is
5770
   returned (function and maybe file) by looking at symbols.  DWARF2
5771
   info is present but not regarding the requested code location.
5772
   Returns 0 otherwise.
5773
   SYMBOLS contains the symbol table for ABFD.
5774
   DEBUG_SECTIONS contains the name of the dwarf debug sections.
5775
   If ALT_FILENAME is given, attempt to open the file and use it
5776
   as the .gnu_debugaltlink file. Otherwise this file will be
5777
   searched for when needed.  */
5778
5779
int
5780
_bfd_dwarf2_find_nearest_line_with_alt
5781
  (bfd *abfd,
5782
   const char *alt_filename,
5783
   asymbol **symbols,
5784
   asymbol *symbol,
5785
   asection *section,
5786
   bfd_vma offset,
5787
   const char **filename_ptr,
5788
   const char **functionname_ptr,
5789
   unsigned int *linenumber_ptr,
5790
   unsigned int *discriminator_ptr,
5791
   const struct dwarf_debug_section *debug_sections,
5792
   void **pinfo)
5793
71.9k
{
5794
  /* Read each compilation unit from the section .debug_info, and check
5795
     to see if it contains the address we are searching for.  If yes,
5796
     lookup the address, and return the line number info.  If no, go
5797
     on to the next compilation unit.
5798
5799
     We keep a list of all the previously read compilation units, and
5800
     a pointer to the next un-read compilation unit.  Check the
5801
     previously read units before reading more.  */
5802
71.9k
  struct dwarf2_debug *stash;
5803
  /* What address are we looking for?  */
5804
71.9k
  bfd_vma addr;
5805
71.9k
  struct comp_unit* each;
5806
71.9k
  struct funcinfo *function = NULL;
5807
71.9k
  int found = false;
5808
71.9k
  bool do_line;
5809
5810
71.9k
  *filename_ptr = NULL;
5811
71.9k
  if (functionname_ptr != NULL)
5812
67.4k
    *functionname_ptr = NULL;
5813
71.9k
  *linenumber_ptr = 0;
5814
71.9k
  if (discriminator_ptr)
5815
16.8k
    *discriminator_ptr = 0;
5816
5817
71.9k
  if (! _bfd_dwarf2_slurp_debug_info (abfd, NULL, debug_sections,
5818
71.9k
              symbols, pinfo,
5819
71.9k
              (abfd->flags & (EXEC_P | DYNAMIC)) == 0))
5820
52.9k
    return false;
5821
5822
18.9k
  stash = (struct dwarf2_debug *) *pinfo;
5823
5824
18.9k
  if (stash->alt.bfd_ptr == NULL && alt_filename != NULL)
5825
0
    {
5826
0
      bfd *alt_bfd = bfd_openr (alt_filename, NULL);
5827
5828
0
      if (alt_bfd == NULL)
5829
  /* bfd_openr will have set the bfd_error.  */
5830
0
  return false;
5831
0
      if (!bfd_check_format (alt_bfd, bfd_object))
5832
0
  {
5833
0
    bfd_set_error (bfd_error_wrong_format);
5834
0
    bfd_close (alt_bfd);
5835
0
    return false;
5836
0
  }
5837
5838
0
      stash->alt.bfd_ptr = alt_bfd;
5839
0
    }
5840
5841
18.9k
  do_line = symbol != NULL;
5842
18.9k
  if (do_line)
5843
3.07k
    {
5844
3.07k
      BFD_ASSERT (section == NULL && offset == 0 && functionname_ptr == NULL);
5845
3.07k
      section = bfd_asymbol_section (symbol);
5846
3.07k
      addr = symbol->value;
5847
3.07k
    }
5848
15.8k
  else
5849
15.8k
    {
5850
15.8k
      BFD_ASSERT (section != NULL && functionname_ptr != NULL);
5851
15.8k
      addr = offset;
5852
5853
      /* If we have no SYMBOL but the section we're looking at is not a
5854
   code section, then take a look through the list of symbols to see
5855
   if we have a symbol at the address we're looking for.  If we do
5856
   then use this to look up line information.  This will allow us to
5857
   give file and line results for data symbols.  We exclude code
5858
   symbols here, if we look up a function symbol and then look up the
5859
   line information we'll actually return the line number for the
5860
   opening '{' rather than the function definition line.  This is
5861
   because looking up by symbol uses the line table, in which the
5862
   first line for a function is usually the opening '{', while
5863
   looking up the function by section + offset uses the
5864
   DW_AT_decl_line from the function DW_TAG_subprogram for the line,
5865
   which will be the line of the function name.  */
5866
15.8k
      if (symbols != NULL && (section->flags & SEC_CODE) == 0)
5867
4.58k
  {
5868
4.58k
    asymbol **tmp;
5869
5870
194k
    for (tmp = symbols; (*tmp) != NULL; ++tmp)
5871
190k
      if ((*tmp)->the_bfd == abfd
5872
190k
    && (*tmp)->section == section
5873
7.72k
    && (*tmp)->value == offset
5874
2.28k
    && ((*tmp)->flags & BSF_SECTION_SYM) == 0)
5875
1.56k
        {
5876
1.56k
    symbol = *tmp;
5877
1.56k
    do_line = true;
5878
    /* For local symbols, keep going in the hope we find a
5879
       global.  */
5880
1.56k
    if ((symbol->flags & BSF_GLOBAL) != 0)
5881
79
      break;
5882
1.56k
        }
5883
4.58k
  }
5884
15.8k
    }
5885
5886
18.9k
  if (section->output_section)
5887
0
    addr += section->output_section->vma + section->output_offset;
5888
18.9k
  else
5889
18.9k
    addr += section->vma;
5890
5891
  /* A null info_ptr indicates that there is no dwarf2 info
5892
     (or that an error occured while setting up the stash).  */
5893
18.9k
  if (! stash->f.info_ptr)
5894
0
    return false;
5895
5896
18.9k
  stash->inliner_chain = NULL;
5897
5898
  /* Check the previously read comp. units first.  */
5899
18.9k
  if (do_line)
5900
4.60k
    {
5901
      /* The info hash tables use quite a bit of memory.  We may not want to
5902
   always use them.  We use some heuristics to decide if and when to
5903
   turn it on.  */
5904
4.60k
      if (stash->info_hash_status == STASH_INFO_HASH_OFF)
5905
4.60k
  stash_maybe_enable_info_hash_tables (abfd, stash);
5906
5907
      /* Keep info hash table up to date if they are available.  Note that we
5908
   may disable the hash tables if there is any error duing update.  */
5909
4.60k
      if (stash->info_hash_status == STASH_INFO_HASH_ON)
5910
0
  stash_maybe_update_info_hash_tables (stash);
5911
5912
4.60k
      if (stash->info_hash_status == STASH_INFO_HASH_ON)
5913
0
  {
5914
0
    found = stash_find_line_fast (stash, symbol, addr,
5915
0
          filename_ptr, linenumber_ptr);
5916
0
    if (found)
5917
0
      goto done;
5918
0
  }
5919
5920
      /* Check the previously read comp. units first.  */
5921
8.31k
      for (each = stash->f.all_comp_units; each; each = each->next_unit)
5922
3.71k
  if ((symbol->flags & BSF_FUNCTION) == 0
5923
1.39k
      || comp_unit_may_contain_address (each, addr))
5924
2.77k
    {
5925
2.77k
      found = comp_unit_find_line (each, symbol, addr, filename_ptr,
5926
2.77k
           linenumber_ptr);
5927
2.77k
      if (found)
5928
0
        goto done;
5929
2.77k
    }
5930
4.60k
    }
5931
14.3k
  else
5932
14.3k
    {
5933
14.3k
      struct trie_node *trie = stash->f.trie_root;
5934
14.3k
      unsigned int bits = VMA_BITS - 8;
5935
14.3k
      struct comp_unit **prev_each;
5936
5937
      /* Traverse interior nodes until we get to a leaf.  */
5938
14.3k
      while (trie && trie->num_room_in_leaf == 0)
5939
0
  {
5940
0
    int ch = (addr >> bits) & 0xff;
5941
0
    trie = ((struct trie_interior *) trie)->children[ch];
5942
0
    bits -= 8;
5943
0
  }
5944
5945
14.3k
      if (trie)
5946
14.3k
  {
5947
14.3k
    const struct trie_leaf *leaf = (struct trie_leaf *) trie;
5948
14.3k
    unsigned int i;
5949
5950
31.2k
    for (i = 0; i < leaf->num_stored_in_leaf; ++i)
5951
16.9k
      leaf->ranges[i].unit->mark = false;
5952
5953
25.5k
    for (i = 0; i < leaf->num_stored_in_leaf; ++i)
5954
13.8k
      {
5955
13.8k
        struct comp_unit *unit = leaf->ranges[i].unit;
5956
13.8k
        if (unit->mark
5957
12.5k
      || addr < leaf->ranges[i].low_pc
5958
10.2k
      || addr >= leaf->ranges[i].high_pc)
5959
9.01k
          continue;
5960
4.87k
        unit->mark = true;
5961
5962
4.87k
        found = comp_unit_find_nearest_line (unit, addr,
5963
4.87k
               filename_ptr,
5964
4.87k
               &function,
5965
4.87k
               linenumber_ptr,
5966
4.87k
               discriminator_ptr);
5967
4.87k
        if (found)
5968
2.70k
    goto done;
5969
4.87k
     }
5970
14.3k
  }
5971
5972
      /* Also scan through all compilation units without any ranges,
5973
         taking them out of the list if they have acquired any since
5974
   last time.  */
5975
11.6k
      prev_each = &stash->f.all_comp_units_without_ranges;
5976
13.4k
      for (each = *prev_each; each; each = each->next_unit_without_ranges)
5977
1.75k
        {
5978
1.75k
    if (each->arange.high != 0)
5979
33
      {
5980
33
        *prev_each = each->next_unit_without_ranges;
5981
33
        continue;
5982
33
      }
5983
5984
1.72k
    found = comp_unit_find_nearest_line (each, addr,
5985
1.72k
                 filename_ptr,
5986
1.72k
                 &function,
5987
1.72k
                 linenumber_ptr,
5988
1.72k
                 discriminator_ptr);
5989
1.72k
    if (found)
5990
3
      goto done;
5991
1.71k
    prev_each = &each->next_unit_without_ranges;
5992
1.71k
  }
5993
11.6k
    }
5994
5995
  /* Read each remaining comp. units checking each as they are read.  */
5996
17.0k
  while ((each = stash_comp_unit (stash, &stash->f)) != NULL)
5997
964
    {
5998
      /* DW_AT_low_pc and DW_AT_high_pc are optional for
5999
   compilation units.  If we don't have them (i.e.,
6000
   unit->high == 0), we need to consult the line info table
6001
   to see if a compilation unit contains the given
6002
   address.  */
6003
964
      if (do_line)
6004
53
  found = (((symbol->flags & BSF_FUNCTION) == 0
6005
8
      || comp_unit_may_contain_address (each, addr))
6006
53
     && comp_unit_find_line (each, symbol, addr,
6007
53
           filename_ptr, linenumber_ptr));
6008
911
      else
6009
911
  found = (comp_unit_may_contain_address (each, addr)
6010
911
     && comp_unit_find_nearest_line (each, addr,
6011
911
             filename_ptr,
6012
911
             &function,
6013
911
             linenumber_ptr,
6014
911
             discriminator_ptr));
6015
6016
964
      if (found)
6017
163
  break;
6018
964
    }
6019
6020
18.9k
 done:
6021
18.9k
  if (functionname_ptr && function && function->is_linkage)
6022
2.22k
    {
6023
2.22k
      *functionname_ptr = function->name;
6024
2.22k
      if (!found)
6025
0
        found = 2;
6026
2.22k
    }
6027
16.7k
  else if (functionname_ptr
6028
13.6k
     && (!*functionname_ptr
6029
0
         || (function && !function->is_linkage)))
6030
13.6k
    {
6031
13.6k
      asymbol *fun;
6032
13.6k
      asymbol **syms = symbols;
6033
13.6k
      asection *sec = section;
6034
6035
13.6k
      _bfd_dwarf2_stash_syms (stash, abfd, &sec, &syms);
6036
13.6k
      fun = _bfd_elf_find_function (abfd, syms, sec, offset,
6037
13.6k
            *filename_ptr ? NULL : filename_ptr,
6038
13.6k
            functionname_ptr);
6039
6040
13.6k
      if (!found && fun != NULL)
6041
5.35k
  found = 2;
6042
6043
13.6k
      if (function && !function->is_linkage)
6044
104
  {
6045
104
    bfd_vma sec_vma;
6046
6047
104
    sec_vma = section->vma;
6048
104
    if (section->output_section != NULL)
6049
0
      sec_vma = section->output_section->vma + section->output_offset;
6050
104
    if (fun == NULL)
6051
39
      *functionname_ptr = function->name;
6052
65
    else if (fun->value + sec_vma == function->arange.low)
6053
32
      function->name = *functionname_ptr;
6054
    /* Even if we didn't find a linkage name, say that we have
6055
       to stop a repeated search of symbols.  */
6056
104
    function->is_linkage = true;
6057
104
  }
6058
13.6k
    }
6059
6060
18.9k
  unset_sections (stash);
6061
6062
18.9k
  return found;
6063
16.2k
}
6064
6065
bool
6066
_bfd_dwarf2_find_inliner_info (bfd *abfd ATTRIBUTE_UNUSED,
6067
             const char **filename_ptr,
6068
             const char **functionname_ptr,
6069
             unsigned int *linenumber_ptr,
6070
             void **pinfo)
6071
0
{
6072
0
  struct dwarf2_debug *stash;
6073
6074
0
  stash = (struct dwarf2_debug *) *pinfo;
6075
0
  if (stash)
6076
0
    {
6077
0
      struct funcinfo *func = stash->inliner_chain;
6078
6079
0
      if (func && func->caller_func)
6080
0
  {
6081
0
    *filename_ptr = func->caller_file;
6082
0
    *functionname_ptr = func->caller_func->name;
6083
0
    *linenumber_ptr = func->caller_line;
6084
0
    stash->inliner_chain = func->caller_func;
6085
0
    return true;
6086
0
  }
6087
0
    }
6088
6089
0
  return false;
6090
0
}
6091
6092
void
6093
_bfd_dwarf2_cleanup_debug_info (bfd *abfd, void **pinfo)
6094
108k
{
6095
108k
  struct dwarf2_debug *stash = (struct dwarf2_debug *) *pinfo;
6096
108k
  struct comp_unit *each;
6097
108k
  struct dwarf2_debug_file *file;
6098
6099
108k
  if (abfd == NULL || stash == NULL)
6100
102k
    return;
6101
6102
5.52k
  if (stash->varinfo_hash_table)
6103
0
    bfd_hash_table_free (&stash->varinfo_hash_table->base);
6104
5.52k
  if (stash->funcinfo_hash_table)
6105
0
    bfd_hash_table_free (&stash->funcinfo_hash_table->base);
6106
6107
5.52k
  file = &stash->f;
6108
11.0k
  while (1)
6109
11.0k
    {
6110
12.0k
      for (each = file->all_comp_units; each; each = each->next_unit)
6111
964
  {
6112
964
    struct funcinfo *function_table = each->function_table;
6113
964
    struct varinfo *variable_table = each->variable_table;
6114
6115
964
    if (each->line_table && each->line_table != file->line_table)
6116
8
      {
6117
8
        free (each->line_table->files);
6118
8
        free (each->line_table->dirs);
6119
8
      }
6120
6121
964
    free (each->lookup_funcinfo_table);
6122
964
    each->lookup_funcinfo_table = NULL;
6123
6124
3.30k
    while (function_table)
6125
2.34k
      {
6126
2.34k
        free (function_table->file);
6127
2.34k
        function_table->file = NULL;
6128
2.34k
        free (function_table->caller_file);
6129
2.34k
        function_table->caller_file = NULL;
6130
2.34k
        function_table = function_table->prev_func;
6131
2.34k
      }
6132
6133
1.17k
    while (variable_table)
6134
212
      {
6135
212
        free (variable_table->file);
6136
212
        variable_table->file = NULL;
6137
212
        variable_table = variable_table->prev_var;
6138
212
      }
6139
964
  }
6140
6141
11.0k
      if (file->line_table)
6142
614
  {
6143
614
    free (file->line_table->files);
6144
614
    free (file->line_table->dirs);
6145
614
  }
6146
11.0k
      htab_delete (file->abbrev_offsets);
6147
11.0k
      if (file->comp_unit_tree != NULL)
6148
912
  splay_tree_delete (file->comp_unit_tree);
6149
6150
11.0k
      free (file->dwarf_line_str_buffer);
6151
11.0k
      free (file->dwarf_str_buffer);
6152
11.0k
      free (file->dwarf_ranges_buffer);
6153
11.0k
      free (file->dwarf_rnglists_buffer);
6154
11.0k
      free (file->dwarf_line_buffer);
6155
11.0k
      free (file->dwarf_abbrev_buffer);
6156
11.0k
      free (file->dwarf_info_buffer);
6157
11.0k
      free (file->dwarf_addr_buffer);
6158
11.0k
      free (file->dwarf_str_offsets_buffer);
6159
11.0k
      if (file == &stash->alt)
6160
5.52k
  break;
6161
5.52k
      file = &stash->alt;
6162
5.52k
    }
6163
5.52k
  free (stash->sec_vma);
6164
5.52k
  free (stash->adjusted_sections);
6165
5.52k
  if (stash->close_on_cleanup)
6166
0
    bfd_close (stash->f.bfd_ptr);
6167
5.52k
  if (stash->alt.bfd_ptr)
6168
0
    bfd_close (stash->alt.bfd_ptr);
6169
5.52k
}
6170
6171
typedef struct elf_find_function_cache
6172
{
6173
  asection *     last_section;
6174
  asymbol *      func;
6175
  const char *   filename;
6176
  bfd_size_type  code_size;
6177
  bfd_vma        code_off;
6178
6179
} elf_find_function_cache;
6180
6181
6182
/* Returns TRUE if symbol SYM with address CODE_OFF and size CODE_SIZE
6183
   is a better fit to match OFFSET than whatever is currenly stored in
6184
   CACHE.  */
6185
6186
static inline bool
6187
better_fit (elf_find_function_cache *  cache,
6188
      asymbol *                  sym,
6189
      bfd_vma                    code_off,
6190
      bfd_size_type              code_size,
6191
      bfd_vma                    offset)
6192
11.3k
{
6193
  /* If the symbol is beyond the desired offset, ignore it.  */
6194
11.3k
  if (code_off > offset)
6195
1.93k
    return false;
6196
6197
  /* If the symbol is further away from the desired
6198
     offset than our current best, then ignore it.  */
6199
9.37k
  if (code_off < cache->code_off)
6200
1.11k
    return false;
6201
6202
  /* On the other hand, if it is closer, then use it.  */
6203
8.25k
  if (code_off > cache->code_off)
6204
1.76k
    return true;
6205
6206
  /* assert (code_off == cache->code_off);  */
6207
6208
  /* If our current best fit does not actually reach the desired
6209
     offset...  */
6210
6.49k
  if (cache->code_off + cache->code_size <= offset)
6211
    /* ... then return whichever candidate covers
6212
       more area and hence gets closer to OFFSET.  */
6213
6.01k
    return code_size > cache->code_size;
6214
6215
  /* The current cache'd symbol covers OFFSET.  */
6216
6217
  /* If the new symbol does not cover the desired offset then skip it.  */  
6218
482
  if (code_off + code_size <= offset)
6219
146
    return false;
6220
6221
  /* Both symbols cover OFFSET.  */
6222
6223
  /* Prefer functions over non-functions.  */
6224
336
  flagword cache_flags = cache->func->flags;
6225
336
  flagword sym_flags   = sym->flags;
6226
6227
336
  if ((cache_flags & BSF_FUNCTION) && ((sym_flags & BSF_FUNCTION) == 0))
6228
79
    return false;
6229
257
  if ((sym_flags & BSF_FUNCTION) && ((cache_flags & BSF_FUNCTION) == 0))
6230
34
    return true;
6231
6232
  /* FIXME: Should we choose LOCAL over GLOBAL ?  */
6233
6234
  /* Prefer typed symbols over notyped.  */
6235
223
  int cache_type = ELF_ST_TYPE (((elf_symbol_type *) cache->func)->internal_elf_sym.st_info);
6236
223
  int sym_type   = ELF_ST_TYPE (((elf_symbol_type *) sym)->internal_elf_sym.st_info);
6237
6238
223
  if (cache_type == STT_NOTYPE && sym_type != STT_NOTYPE)
6239
12
    return true;
6240
211
  if (cache_type != STT_NOTYPE && sym_type == STT_NOTYPE)
6241
28
    return false;
6242
6243
  /* Otherwise choose whichever symbol covers a smaller area.  */
6244
183
  return code_size < cache->code_size;
6245
211
}
6246
6247
/* Find the function to a particular section and offset,
6248
   for error reporting.  */
6249
6250
asymbol *
6251
_bfd_elf_find_function (bfd *abfd,
6252
      asymbol **symbols,
6253
      asection *section,
6254
      bfd_vma offset,
6255
      const char **filename_ptr,
6256
      const char **functionname_ptr)
6257
24.3k
{
6258
24.3k
  if (symbols == NULL)
6259
3.45k
    return NULL;
6260
6261
20.8k
  if (bfd_get_flavour (abfd) != bfd_target_elf_flavour)
6262
0
    return NULL;
6263
6264
20.8k
  elf_find_function_cache * cache = elf_tdata (abfd)->elf_find_function_cache;
6265
6266
20.8k
  if (cache == NULL)
6267
1.83k
    {
6268
1.83k
      cache = bfd_zalloc (abfd, sizeof (*cache));
6269
1.83k
      elf_tdata (abfd)->elf_find_function_cache = cache;
6270
1.83k
      if (cache == NULL)
6271
0
  return NULL;
6272
1.83k
    }
6273
6274
20.8k
  if (cache->last_section != section
6275
10.5k
      || cache->func == NULL
6276
3.11k
      || offset < cache->func->value
6277
3.03k
      || offset >= cache->func->value + cache->code_size)
6278
18.4k
    {
6279
18.4k
      asymbol *file;
6280
18.4k
      asymbol **p;
6281
      /* ??? Given multiple file symbols, it is impossible to reliably
6282
   choose the right file name for global symbols.  File symbols are
6283
   local symbols, and thus all file symbols must sort before any
6284
   global symbols.  The ELF spec may be interpreted to say that a
6285
   file symbol must sort before other local symbols, but currently
6286
   ld -r doesn't do this.  So, for ld -r output, it is possible to
6287
   make a better choice of file name for local symbols by ignoring
6288
   file symbols appearing after a given local symbol.  */
6289
18.4k
      enum { nothing_seen, symbol_seen, file_after_symbol_seen } state;
6290
18.4k
      elf_backend_data *bed = get_elf_backend_data (abfd);
6291
6292
18.4k
      file = NULL;
6293
18.4k
      state = nothing_seen;
6294
18.4k
      cache->filename = NULL;
6295
18.4k
      cache->func = NULL;
6296
18.4k
      cache->code_size = 0;
6297
18.4k
      cache->code_off = 0;
6298
18.4k
      cache->last_section = section;
6299
6300
760k
      for (p = symbols; *p != NULL; p++)
6301
742k
  {
6302
742k
    asymbol *sym = *p;
6303
742k
    bfd_vma code_off;
6304
742k
    bfd_size_type size;
6305
6306
742k
    if ((sym->flags & BSF_FILE) != 0)
6307
38.6k
      {
6308
38.6k
        file = sym;
6309
38.6k
        if (state == symbol_seen)
6310
2.55k
    state = file_after_symbol_seen;
6311
38.6k
        continue;
6312
38.6k
      }
6313
6314
703k
    if (state == nothing_seen)
6315
18.4k
      state = symbol_seen;
6316
6317
703k
    size = bed->maybe_function_sym (sym, section, &code_off);
6318
6319
703k
    if (size == 0)
6320
692k
      continue;
6321
6322
11.3k
    if (better_fit (cache, sym, code_off, size, offset))
6323
7.41k
      {
6324
7.41k
        cache->func = sym;
6325
7.41k
        cache->code_size = size;
6326
7.41k
        cache->code_off = code_off;
6327
7.41k
        cache->filename = NULL;
6328
6329
7.41k
        if (file != NULL
6330
6.13k
      && ((sym->flags & BSF_LOCAL) != 0
6331
2.23k
          || state != file_after_symbol_seen))
6332
5.97k
    cache->filename = bfd_asymbol_name (file);
6333
7.41k
      }
6334
    /* Otherwise, if the symbol is beyond the desired offset but it
6335
       lies within the bounds of the current best match then reduce
6336
       the size of the current best match so that future searches
6337
       will not not used the cached symbol by mistake.  */
6338
3.89k
    else if (code_off > offset 
6339
1.93k
       && code_off > cache->code_off
6340
1.93k
       && code_off < cache->code_off + cache->code_size)
6341
62
      {
6342
62
        cache->code_size = code_off - cache->code_off;
6343
62
      }
6344
11.3k
  }
6345
18.4k
    }
6346
6347
20.8k
  if (cache->func == NULL)
6348
12.3k
    return NULL;
6349
6350
8.51k
  if (filename_ptr)
6351
8.03k
    *filename_ptr = cache->filename;
6352
8.51k
  if (functionname_ptr)
6353
8.51k
    *functionname_ptr = bfd_asymbol_name (cache->func);
6354
6355
8.51k
  return cache->func;
6356
20.8k
}