mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-06 12:09:26 +08:00
0e26741636
It was pointed out on IRC that the RISC-V target allocates target descriptions and stores them in a global map, and doesn't delete these target descriptions when GDB shuts down. This isn't a particular problem, the total number of target descriptions we can create is very limited so creating these on demand and holding them for the entire run on GDB seems reasonable. However, not deleting these objects on GDB exit means extra warnings are printed from tools like valgrind, and the address sanitiser, making it harder to spot real issues. As it's reasonably easy to have GDB correctly delete these objects on exit, lets just do that. I started by noticing that we already have a target_desc_up type, a wrapper around unique_ptr that calls a function that will correctly delete target descriptions, so I want to use that, but.... ...that type is declared in gdb/target-descriptions.h. If I try to include that file in gdb/arch/riscv.c I run into a problem, that file is compiled into both GDB and GDBServer. OK, I could guard the include with #ifdef, but surely we can do better. So then I decided to move the target_desc_up type into gdbsupport/tdesc.h, this is the interface file for generic code shared between GDB and GDBserver (relating to target descriptions). The actual implementation for the delete function still lives in gdb/target-description.c, but now gdb/arch/riscv.c can see the declaration. Problem solved.... ... but, though RISC-V doesn't use it I've now exposed the target_desc_up type to gdbserver, so in future someone _might_ start using it, which is fine, except right now there's no definition of the delete function - remember the delete I used is only defined in GDB code. No problem, I add an implementation of the delete operator into gdbserver/tdesc.cc, and all is good..... except.... I start getting this error from GCC: tdesc.cc:109:10: error: deleting object of polymorphic class type ‘target_desc’ which has non-virtual destructor might cause undefined behavior [-Werror=delete-non-virtual-dtor] Which is caused because gdbserver's target_desc type inherits from tdesc_element which has a virtual method, and so GCC worries that target_desc might be used as a base class. The solution is to declare gdbserver's target_desc class as final. This is fine so long as we never intent to inherit from target_desc (in gdbserver). But if we did then we'd want to make target_desc's destructor virtual anyway, so the error above would be resolved, and there wouldn't be an issue. gdb/ChangeLog: * arch/riscv.c (riscv_tdesc_cache): Change map type. (riscv_lookup_target_description): Return pointer out of unique_ptr. * target-descriptions.c (allocate_target_description): Add comment. (target_desc_deleter::operator()): Likewise. * target-descriptions.h (struct target_desc_deleter): Moved to gdbsupport/tdesc.h. (target_desc_up): Likewise. gdbserver/ChangeLog: * tdesc.cc (allocate_target_description): Add header comment. (target_desc_deleter::operator()): New function. * tdesc.h (struct target_desc): Declare as final. gdbsupport/ChangeLog: * tdesc.h (struct target_desc_deleter): Moved here from gdb/target-descriptions.h, extend comment. (target_desc_up): Likewise.
263 lines
7.3 KiB
Plaintext
263 lines
7.3 KiB
Plaintext
2020-07-17 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* tdesc.h (struct target_desc_deleter): Moved here
|
|
from gdb/target-descriptions.h, extend comment.
|
|
(target_desc_up): Likewise.
|
|
|
|
2020-06-30 Tom Tromey <tromey@adacore.com>
|
|
|
|
PR build/26183:
|
|
* gdb_string_view.h (basic_string_view::to_string): Remove.
|
|
(gdb::to_string): New function.
|
|
|
|
2020-06-27 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* tdesc.h (class print_xml_feature) <add_line>: Add
|
|
ATTRIBUTE_PRINTF.
|
|
|
|
2020-06-23 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* tdesc.cc (print_xml_feature::visit_pre): Use add_line to add
|
|
output content, and call indent as needed in all overloaded
|
|
variants.
|
|
(print_xml_feature::visit_post): Likewise.
|
|
(print_xml_feature::visit): Likewise.
|
|
(print_xml_feature::add_line): Two new overloaded functions.
|
|
* tdesc.h (print_xml_feature::indent): New member function.
|
|
(print_xml_feature::add_line): Two new overloaded member
|
|
functions.
|
|
(print_xml_feature::m_depth): New member variable.
|
|
|
|
2020-06-23 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* tdesc.cc (print_xml_feature::visit_pre): Print compatible
|
|
information.
|
|
* tdesc.h (struct tdesc_compatible_info): Declare new struct.
|
|
(tdesc_compatible_info_up): New typedef.
|
|
(tdesc_compatible_info_list): Declare new function.
|
|
(tdesc_compatible_info_arch_name): Declare new function.
|
|
|
|
2020-05-25 Michael Weghorn <m.weghorn@posteo.de>
|
|
|
|
* common-utils.cc, common-utils.h (stringify_argv): Drop
|
|
now unused function stringify_argv
|
|
|
|
2020-05-25 Michael Weghorn <m.weghorn@posteo.de>
|
|
|
|
* common-inferior.cc, common-inferior.h (construct_inferior_arguments):
|
|
Adapt to take a gdb::array_view<char * const> parameter.
|
|
Adapt call site.
|
|
|
|
2020-05-25 Michael Weghorn <m.weghorn@posteo.de>
|
|
|
|
* common-inferior.cc, common-inferior.h (construct_inferior_arguments):
|
|
Adapt to handle zero args and return a std::string.
|
|
Adapt call site.
|
|
|
|
2020-05-25 Michael Weghorn <m.weghorn@posteo.de>
|
|
|
|
* common-inferior.h, common-inferior.cc: (construct_inferior_arguments):
|
|
Move function here from gdb/infcmd.c, gdb/inferior.h
|
|
|
|
2020-05-14 Kevin Buettner <kevinb@redhat.com>
|
|
|
|
* btrace-common.h (btrace_cpu_vendor): Add CV_AMD.
|
|
|
|
2020-05-14 Tankut Baris Aktemur <tankut.baris.aktemur@intel.com>
|
|
|
|
* common-regcache.h (regcache_read_pc_protected): New function
|
|
declaration.
|
|
|
|
2020-04-28 Tankut Baris Aktemur <tankut.baris.aktemur@intel.com>
|
|
|
|
* gdb-sigmask.h: Fix typo (pthead_sigmask -> pthread_sigmask).
|
|
|
|
2020-04-27 Simon Marchi <simon.marchi@polymtl.ca>
|
|
|
|
* common-defs.h: Include cstdlib.h.
|
|
|
|
2020-04-20 Tom Tromey <tromey@adacore.com>
|
|
|
|
* scoped_mmap.h (scoped_mmap): Mark move constructor as noexcept.
|
|
Use initialization style. Don't call destroy.
|
|
* scoped_fd.h (class scoped_fd): Mark move constructor as
|
|
noexcept.
|
|
* gdb_ref_ptr.h (class ref_ptr): Mark move constructor as
|
|
noexcept.
|
|
|
|
2020-04-13 Tom Tromey <tom@tromey.com>
|
|
|
|
* event-loop.c: Move comment. Remove obsolete comment.
|
|
|
|
2020-04-13 Tom Tromey <tom@tromey.com>
|
|
|
|
* event-loop.h: Move from ../gdb/.
|
|
* event-loop.cc: Move from ../gdb/.
|
|
|
|
2020-04-13 Tom Tromey <tom@tromey.com>
|
|
|
|
* errors.h (flush_streams): Declare.
|
|
|
|
2020-04-13 Tom Tromey <tom@tromey.com>
|
|
|
|
* gdb_select.h: Move from ../gdb/.
|
|
|
|
2020-04-13 Tom Tromey <tom@tromey.com>
|
|
|
|
* config.in, configure: Rebuild.
|
|
* common.m4 (GDB_AC_COMMON): Check for poll.h, sys/poll.h,
|
|
sys/select.h, and poll.
|
|
|
|
2020-03-31 Tom Tromey <tromey@adacore.com>
|
|
|
|
* btrace-common.cc (btrace_data_append): Conditionally call
|
|
memcpy.
|
|
|
|
2020-03-27 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* create-version.sh: Resolve issues highlighted by shellcheck.
|
|
|
|
2020-03-20 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* config.in: Re-generate.
|
|
* configure: Re-generate.
|
|
|
|
2020-03-17 Kamil Rytarowski <n54@gmx.com>
|
|
|
|
* common-defs.h: Include alloca.h if HAVE_ALLOCA_H is defined.
|
|
|
|
2020-03-12 Tom Tromey <tom@tromey.com>
|
|
|
|
* common-types.h: Remove GDBSERVER code.
|
|
(gdb_byte, CORE_ADDR, LONGEST, ULONGEST): Redefine.
|
|
* common-defs.h: Remove GDBSERVER code.
|
|
|
|
2020-03-12 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* selftest.m4: Moved from gdb/.
|
|
* acinclude.m4: Update path to selftest.m4.
|
|
|
|
2020-03-12 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* configure.ac: Don't source bfd/development.sh.
|
|
* common.m4: Source bfd/development.sh.
|
|
* configure: Re-generate.
|
|
|
|
2020-03-12 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* configure: Re-generate.
|
|
|
|
2020-03-11 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* configure: Re-generate.
|
|
* warning.m4: Enable -Wmissing-prototypes.
|
|
|
|
2020-03-08 Tom Tromey <tom@tromey.com>
|
|
|
|
* gdb_binary_search.h: Fix two typos.
|
|
|
|
2020-03-06 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* .dir-locals.el: New file.
|
|
|
|
2020-03-05 Vyacheslav Petrishchev <vyachemail@gmail.com>
|
|
|
|
* configure.ac: Added call development.sh.
|
|
* configure: Regenerate.
|
|
|
|
2020-03-05 Tankut Baris Aktemur <tankut.baris.aktemur@intel.com>
|
|
|
|
* .gitattributes: New file.
|
|
|
|
2020-03-03 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* Makefile.in: Re-generate.
|
|
|
|
2020-02-28 Sergio Durigan Junior <sergiodj@redhat.com>
|
|
|
|
* gdb-dlfcn.h (gdb_dlopen): Update comment.
|
|
|
|
2020-02-19 Andrew Burgess <andrew.burgess@embecosm.com>
|
|
|
|
* configure: Regenerate.
|
|
|
|
2020-02-14 Tom Tromey <tom@tromey.com>
|
|
|
|
* common-defs.h: Change path to gnulib/config.h.
|
|
|
|
2020-02-13 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* Makefile.am: Rename source files from .c to .cc.
|
|
(CC, CFLAGS): Don't override.
|
|
(AM_CFLAGS): Rename to ...
|
|
(AM_CXXFLAGS): ... this.
|
|
* Makefile.in: Re-generate.
|
|
* %.c: Rename to %.cc.
|
|
|
|
2020-02-11 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* configure: Re-generate.
|
|
|
|
2020-02-11 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* warning.m4: Add -Wstrict-null-sentinel.
|
|
* configure: Re-generate.
|
|
|
|
2020-02-11 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* warning.m4: Move here, from gdb/warning.m4.
|
|
* acinclude.m4: Update warning.m4 path.
|
|
* Makefile.in: Re-generate.
|
|
|
|
2020-02-11 Simon Marchi <simon.marchi@efficios.com>
|
|
|
|
* acinclude.m4: Include ../gdb/warning.m4.
|
|
* configure.ac: Use AM_GDB_WARNINGS.
|
|
* Makefile.am: Set AM_CFLAGS to WARN_CFLAGS and WERROR_CFLAGS.
|
|
* Makefile.in: Re-generate.
|
|
* configure: Re-generate.
|
|
|
|
2020-02-10 Tom de Vries <tdevries@suse.de>
|
|
|
|
* environ.c (gdb_environ::set): Cast concat NULL sentinel to char *.
|
|
|
|
2020-01-24 Christian Biesinger <cbiesinger@google.com>
|
|
|
|
* thread-pool.c (set_thread_name): Add an overload for the NetBSD
|
|
version of pthread_setname_np.
|
|
|
|
2020-01-17 Pedro Alves <palves@redhat.com>
|
|
|
|
* Makefile.am: Append CXX_DIALECT to CXX.
|
|
* Makefile.in: Regenerate.
|
|
|
|
2020-01-17 Pedro Alves <palves@redhat.com>
|
|
|
|
* configure.ac: Generate config.h instead of support-config.h.
|
|
* common-defs.h: Include <gdbsupport/config.h> instead of
|
|
<gdbsupport/support-config.h>.
|
|
* Makefile.in: Regenerate.
|
|
* configure: Regenerate.
|
|
|
|
2020-01-14 Tom Tromey <tom@tromey.com>
|
|
|
|
* Makefile.in: Rebuild.
|
|
* Makefile.am (check-defines): New target.
|
|
* check-defines.el: New file.
|
|
|
|
2020-01-14 Tom Tromey <tom@tromey.com>
|
|
|
|
* configure, Makefile.in, aclocal.m4, common.m4, config.in:
|
|
Rebuild.
|
|
* common.m4 (GDB_AC_COMMON): Move many checks from
|
|
gdb/configure.ac.
|
|
* acinclude.m4: Include bfd.m4, ptrace.m4.
|
|
|
|
2020-01-14 Tom Tromey <tom@tromey.com>
|
|
|
|
* common-defs.h: Add GDBSERVER case. Update includes.
|
|
* acinclude.m4, aclocal.m4, config.in, configure, configure.ac,
|
|
Makefile.am, Makefile.in, README: New files.
|
|
* Moved from ../gdb/gdbsupport/
|
|
|