diff options
author | Johnson Sun <j3.soon777@gmail.com> | 2022-10-21 01:49:18 +0800 |
---|---|---|
committer | Simon Marchi <simon.marchi@polymtl.ca> | 2022-11-18 10:50:45 -0500 |
commit | 6533cbeeb831224e2d2dd2a7bea54b22b798fa39 (patch) | |
tree | 1485eb862e28283864b7d78cf42137d8b9444989 /gdb/testsuite/gdb.python/py-finish-breakpoint-deletion.py | |
parent | 9c48a8e6f43965b8d530159e5dbb2fc9d6083646 (diff) | |
download | binutils-6533cbeeb831224e2d2dd2a7bea54b22b798fa39.zip binutils-6533cbeeb831224e2d2dd2a7bea54b22b798fa39.tar.gz binutils-6533cbeeb831224e2d2dd2a7bea54b22b798fa39.tar.bz2 |
Fix deletion of FinishBreakpoints
Currently, FinishBreakpoints are set at the return address of a frame based on
the `finish' command, and are meant to be temporary breakpoints. However, they
are not being cleaned up after use, as reported in PR python/18655. This was
happening because the disposition of the breakpoint was not being set
correctly.
This commit fixes this issue by correctly setting the disposition in the
post-stop hook of the breakpoint. It also adds a test to ensure this feature
isn't regressed in the future.
Bug: https://sourceware.org/bugzilla/show_bug.cgi?id=18655
Diffstat (limited to 'gdb/testsuite/gdb.python/py-finish-breakpoint-deletion.py')
-rw-r--r-- | gdb/testsuite/gdb.python/py-finish-breakpoint-deletion.py | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/gdb/testsuite/gdb.python/py-finish-breakpoint-deletion.py b/gdb/testsuite/gdb.python/py-finish-breakpoint-deletion.py new file mode 100644 index 0000000..ab05b0c --- /dev/null +++ b/gdb/testsuite/gdb.python/py-finish-breakpoint-deletion.py @@ -0,0 +1,32 @@ +# Copyright (C) 2022 Free Software Foundation, Inc. + +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. + + +class MyFinishBreakpoint(gdb.FinishBreakpoint): + def stop(self): + print("stopped at MyFinishBreakpoint") + return self.return_value == 4 + + +class MyBreakpoint(gdb.Breakpoint): + def stop(self): + print("stopped at MyBreakpoint") + MyFinishBreakpoint() + return False + + +MyBreakpoint("subroutine", internal=True) + +print("Python script imported") |