binutils-gdb/gdb/dwarf2
Simon Marchi 8480a37e14 gdb: pass frames as const frame_info_ptr &
We currently pass frames to function by value, as `frame_info_ptr`.
This is somewhat expensive:

 - the size of `frame_info_ptr` is 64 bytes, which is a bit big to pass
   by value
 - the constructors and destructor link/unlink the object in the global
   `frame_info_ptr::frame_list` list.  This is an `intrusive_list`, so
   it's not so bad: it's just assigning a few points, there's no memory
   allocation as if it was `std::list`, but still it's useless to do
   that over and over.

As suggested by Tom Tromey, change many function signatures to accept
`const frame_info_ptr &` instead of `frame_info_ptr`.

Some functions reassign their `frame_info_ptr` parameter, like:

  void
  the_func (frame_info_ptr frame)
  {
    for (; frame != nullptr; frame = get_prev_frame (frame))
      {
        ...
      }
  }

I wondered what to do about them, do I leave them as-is or change them
(and need to introduce a separate local variable that can be
re-assigned).  I opted for the later for consistency.  It might not be
clear why some functions take `const frame_info_ptr &` while others take
`frame_info_ptr`.  Also, if a function took a `frame_info_ptr` because
it did re-assign its parameter, I doubt that we would think to change it
to `const frame_info_ptr &` should the implementation change such that
it doesn't need to take `frame_info_ptr` anymore.  It seems better to
have a simple rule and apply it everywhere.

Change-Id: I59d10addef687d157f82ccf4d54f5dde9a963fd0
Approved-By: Andrew Burgess <aburgess@redhat.com>
2024-02-20 10:42:25 -05:00
..
abbrev-cache.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
abbrev-cache.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
abbrev.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
abbrev.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
ada-imported.c gdb: pass frames as const frame_info_ptr & 2024-02-20 10:42:25 -05:00
aranges.c Remove addrmap_fixed::set_entry 2024-01-15 11:50:24 -07:00
aranges.h Remove addrmap_fixed::set_entry 2024-01-15 11:50:24 -07:00
attribute.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
attribute.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
call-site.h gdb: pass frames as const frame_info_ptr & 2024-02-20 10:42:25 -05:00
comp-unit-head.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
comp-unit-head.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
cooked-index.c Use the new symbol domains 2024-01-28 10:58:16 -07:00
cooked-index.h Use domain_search_flags in lookup_global_symbol_language 2024-01-28 10:58:16 -07:00
cu.c Remove remnants of partial DIEs from DWARF reader 2024-02-05 12:13:09 -07:00
cu.h Remove remnants of partial DIEs from DWARF reader 2024-02-05 12:13:09 -07:00
die.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
die.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
dwz.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
dwz.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
expr.c gdb: pass frames as const frame_info_ptr & 2024-02-20 10:42:25 -05:00
expr.h gdb: pass frames as const frame_info_ptr & 2024-02-20 10:42:25 -05:00
file-and-dir.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
frame-tailcall.c gdb: pass frames as const frame_info_ptr & 2024-02-20 10:42:25 -05:00
frame-tailcall.h gdb: pass frames as const frame_info_ptr & 2024-02-20 10:42:25 -05:00
frame.c gdb: pass frames as const frame_info_ptr & 2024-02-20 10:42:25 -05:00
frame.h gdb: pass frames as const frame_info_ptr & 2024-02-20 10:42:25 -05:00
index-cache.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
index-cache.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
index-common.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
index-common.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
index-write.c Use the new symbol domains 2024-01-28 10:58:16 -07:00
index-write.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
leb.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
leb.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
line-header.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
line-header.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
loc.c gdb: pass frames as const frame_info_ptr & 2024-02-20 10:42:25 -05:00
loc.h gdb: pass frames as const frame_info_ptr & 2024-02-20 10:42:25 -05:00
macro.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
macro.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
mapped-index.h Do not write the index cache from an index 2024-01-18 08:20:16 -07:00
public.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
read-debug-names.c Export dwarf5_augmentation 2024-01-18 08:20:17 -07:00
read-debug-names.h Export dwarf5_augmentation 2024-01-18 08:20:17 -07:00
read-gdb-index.c Use the new symbol domains 2024-01-28 10:58:16 -07:00
read-gdb-index.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
read.c Remove remnants of partial DIEs from DWARF reader 2024-02-05 12:13:09 -07:00
read.h Use domain_search_flags in lookup_global_symbol_language 2024-01-28 10:58:16 -07:00
sect-names.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
section.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
section.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
stringify.c Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
stringify.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00
tag.h Use the new symbol domains 2024-01-28 10:58:16 -07:00
types.h Update copyright year range in header of all files managed by GDB 2024-01-12 15:49:57 +00:00