diff options
author | Tom Tromey <tromey@adacore.com> | 2019-02-12 14:28:07 -0700 |
---|---|---|
committer | Tom Tromey <tromey@adacore.com> | 2019-02-15 13:21:29 -0700 |
commit | 5f486660101ab09d50fa3bb9a10555f12722f39f (patch) | |
tree | 2fe943ce4ddc4c9910dd3bace147a6f1bafeb6d3 /gdb/ada-lang.c | |
parent | 91d78b8179b061cf7c9cca423e29480bc6367fc3 (diff) | |
download | gdb-5f486660101ab09d50fa3bb9a10555f12722f39f.zip gdb-5f486660101ab09d50fa3bb9a10555f12722f39f.tar.gz gdb-5f486660101ab09d50fa3bb9a10555f12722f39f.tar.bz2 |
C++-ify bp_location
Philippe noticed a memory leak coming from ada_catchpoint_location --
it was not freeing the "function_name" member from its base class:
==14141== 114 bytes in 4 blocks are definitely lost in loss record 1,055 of 3,424
==14141== at 0x4C2BE6D: malloc (vg_replace_malloc.c:309)
==14141== by 0x405107: xmalloc (common-utils.c:44)
==14141== by 0x7563F9: xstrdup (xstrdup.c:34)
==14141== by 0x3B82B3: set_breakpoint_location_function(bp_location*, int) (breakpoint.c:7156)
==14141== by 0x3C112B: add_location_to_breakpoint(breakpoint*, symtab_and_line const*) (breakpoint.c:8609)
==14141== by 0x3C127A: init_raw_breakpoint(breakpoint*, gdbarch*, symtab_and_line, bptype, breakpoint_ops const*) (breakpoint.c:7187)
==14141== by 0x3C1B52: init_ada_exception_breakpoint(breakpoint*, gdbarch*, symtab_and_line, char const*, breakpoint_ops const*, int, int, int) (breakpoint.c:11262)
==14141== by 0x381C2E: create_ada_exception_catchpoint(gdbarch*, ada_exception_catchpoint_kind, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&, int, int, int) (ada-lang.c:13255)
This patch fixes the problem by further C++-ifying bp_location. In
particular, bp_location_ops is now removed, and the "dtor" function
pointer is replaced with an ordinary destructor.
gdb/ChangeLog
2019-02-15 Philippe Waroquiers <philippe.waroquiers@skynet.be>
Tom Tromey <tromey@adacore.com>
* breakpoint.c (~bp_location): Rename from bp_location_dtor.
(bp_location_ops): Remove.
(base_breakpoint_allocate_location): Update.
(free_bp_location): Update.
* ada-lang.c (class ada_catchpoint_location)
<ada_catchpoint_location>: Remove ops parameter.
(ada_catchpoint_location_dtor): Remove.
(ada_catchpoint_location_ops): Remove.
(allocate_location_exception): Update.
* breakpoint.h (struct bp_location_ops): Remove.
(class bp_location) <bp_location>: Remove bp_location_ops
parameter.
<~bp_location>: Add destructor.
<ops>: Remove.
Diffstat (limited to 'gdb/ada-lang.c')
-rw-r--r-- | gdb/ada-lang.c | 24 |
1 files changed, 3 insertions, 21 deletions
diff --git a/gdb/ada-lang.c b/gdb/ada-lang.c index a878d4d..602facb 100644 --- a/gdb/ada-lang.c +++ b/gdb/ada-lang.c @@ -12396,8 +12396,8 @@ static std::string ada_exception_catchpoint_cond_string class ada_catchpoint_location : public bp_location { public: - ada_catchpoint_location (const bp_location_ops *ops, breakpoint *owner) - : bp_location (ops, owner) + ada_catchpoint_location (breakpoint *owner) + : bp_location (owner) {} /* The condition that checks whether the exception that was raised @@ -12406,24 +12406,6 @@ public: expression_up excep_cond_expr; }; -/* Implement the DTOR method in the bp_location_ops structure for all - Ada exception catchpoint kinds. */ - -static void -ada_catchpoint_location_dtor (struct bp_location *bl) -{ - struct ada_catchpoint_location *al = (struct ada_catchpoint_location *) bl; - - al->excep_cond_expr.reset (); -} - -/* The vtable to be used in Ada catchpoint locations. */ - -static const struct bp_location_ops ada_catchpoint_location_ops = -{ - ada_catchpoint_location_dtor -}; - /* An instance of this type is used to represent an Ada catchpoint. */ struct ada_catchpoint : public breakpoint @@ -12493,7 +12475,7 @@ static struct bp_location * allocate_location_exception (enum ada_exception_catchpoint_kind ex, struct breakpoint *self) { - return new ada_catchpoint_location (&ada_catchpoint_location_ops, self); + return new ada_catchpoint_location (self); } /* Implement the RE_SET method in the breakpoint_ops structure for all |