aboutsummaryrefslogtreecommitdiff
path: root/gdb
diff options
context:
space:
mode:
authorTom Tromey <tromey@redhat.com>2013-05-30 17:06:31 +0000
committerTom Tromey <tromey@redhat.com>2013-05-30 17:06:31 +0000
commite42d0aa5bac43efc5556ca0e6ad18effd04de4ea (patch)
tree34e4bee96cd47f5faa976088bbb1a3cd09c7c184 /gdb
parent4bbc010a2d22fd94bdf00fa0568481701e69eb69 (diff)
downloadgdb-e42d0aa5bac43efc5556ca0e6ad18effd04de4ea.zip
gdb-e42d0aa5bac43efc5556ca0e6ad18effd04de4ea.tar.gz
gdb-e42d0aa5bac43efc5556ca0e6ad18effd04de4ea.tar.bz2
fix cleanup handling in macho_symfile_read
macho_symfile_read leaks a cleanup by assigning to 'back_to' too late. * machoread.c (macho_symfile_read): Assign first cleanup to 'back_to'.
Diffstat (limited to 'gdb')
-rw-r--r--gdb/ChangeLog5
-rw-r--r--gdb/machoread.c4
2 files changed, 7 insertions, 2 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index fc3829a..56be923 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,5 +1,10 @@
2013-05-30 Tom Tromey <tromey@redhat.com>
+ * machoread.c (macho_symfile_read): Assign first cleanup to
+ 'back_to'.
+
+2013-05-30 Tom Tromey <tromey@redhat.com>
+
* m32r-rom.c (m32r_load): Call do_cleanups at all returns.
2013-05-30 Tom Tromey <tromey@redhat.com>
diff --git a/gdb/machoread.c b/gdb/machoread.c
index 9877f07..d294960 100644
--- a/gdb/machoread.c
+++ b/gdb/machoread.c
@@ -871,10 +871,10 @@ macho_symfile_read (struct objfile *objfile, int symfile_flags)
struct cleanup *back_to;
symbol_table = (asymbol **) xmalloc (storage_needed);
- make_cleanup (xfree, symbol_table);
+ back_to = make_cleanup (xfree, symbol_table);
init_minimal_symbol_collection ();
- back_to = make_cleanup_discard_minimal_symbols ();
+ make_cleanup_discard_minimal_symbols ();
symcount = bfd_canonicalize_symtab (objfile->obfd, symbol_table);