aboutsummaryrefslogtreecommitdiff
path: root/gdb/symfile.c
diff options
context:
space:
mode:
authorTom Tromey <tromey@adacore.com>2022-12-06 12:07:12 -0700
committerTom Tromey <tromey@adacore.com>2023-04-13 13:58:35 -0600
commitf96328accde1e6302b62aa880675594618079cb3 (patch)
tree4ed79fe1a3f483cdf92db1dd2d530658cb68f68e /gdb/symfile.c
parent546c7898dccb204eb56c8ed7c5b707c75de31b53 (diff)
downloadgdb-f96328accde1e6302b62aa880675594618079cb3.zip
gdb-f96328accde1e6302b62aa880675594618079cb3.tar.gz
gdb-f96328accde1e6302b62aa880675594618079cb3.tar.bz2
Avoid double-free with debuginfod
PR gdb/29257 points out a possible double free when debuginfod is in use. Aside from some ugly warts in the symbol code (an ongoing issue), the underlying issue in this particular case is that elfread.c seems to assume that symfile_bfd_open will return NULL on error, whereas in reality it throws an exception. As this code isn't prepared for an exception, bad things result. This patch fixes the problem by introducing a non-throwing variant of symfile_bfd_open and using it in the affected places. Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=29257
Diffstat (limited to 'gdb/symfile.c')
-rw-r--r--gdb/symfile.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/gdb/symfile.c b/gdb/symfile.c
index bb9981a..8ae2177 100644
--- a/gdb/symfile.c
+++ b/gdb/symfile.c
@@ -1769,6 +1769,23 @@ symfile_bfd_open (const char *name)
return sym_bfd;
}
+/* See symfile.h. */
+
+gdb_bfd_ref_ptr
+symfile_bfd_open_no_error (const char *name) noexcept
+{
+ try
+ {
+ return symfile_bfd_open (name);
+ }
+ catch (const gdb_exception_error &err)
+ {
+ warning ("%s", err.what ());
+ }
+
+ return nullptr;
+}
+
/* Return the section index for SECTION_NAME on OBJFILE. Return -1 if
the section was not found. */