gdb/
Fix Python access to inlined frames. * python/py-frame.c (frapy_read_var): Find BLOCK using get_frame_block. * python/py-symbol.c (gdbpy_lookup_symbol): Likewise. gdb/testsuite/ Fix Python access to inlined frames. * gdb.python/py-frame-inline.c: New file. * gdb.python/py-frame-inline.exp: New file.
This commit is contained in:
parent
45bbae5e3c
commit
626e728214
6 changed files with 97 additions and 3 deletions
|
@ -1,3 +1,9 @@
|
|||
2011-04-17 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||
|
||||
Fix Python access to inlined frames.
|
||||
* python/py-frame.c (frapy_read_var): Find BLOCK using get_frame_block.
|
||||
* python/py-symbol.c (gdbpy_lookup_symbol): Likewise.
|
||||
|
||||
2011-04-15 Tom Tromey <tromey@redhat.com>
|
||||
|
||||
* dwarf2read.c (add_index_entry): Use VEC_last, not VEC_length.
|
||||
|
|
|
@ -436,7 +436,7 @@ frapy_read_var (PyObject *self, PyObject *args)
|
|||
FRAPY_REQUIRE_VALID ((frame_object *) self, frame);
|
||||
|
||||
if (!block)
|
||||
block = block_for_pc (get_frame_address_in_block (frame));
|
||||
block = get_frame_block (frame, NULL);
|
||||
var = lookup_symbol (var_name, block, VAR_DOMAIN, NULL);
|
||||
}
|
||||
GDB_PY_HANDLE_EXCEPTION (except);
|
||||
|
|
|
@ -276,7 +276,7 @@ gdbpy_lookup_symbol (PyObject *self, PyObject *args, PyObject *kw)
|
|||
TRY_CATCH (except, RETURN_MASK_ALL)
|
||||
{
|
||||
selected_frame = get_selected_frame (_("No frame selected."));
|
||||
block = block_for_pc (get_frame_address_in_block (selected_frame));
|
||||
block = get_frame_block (selected_frame, NULL);
|
||||
}
|
||||
GDB_PY_HANDLE_EXCEPTION (except);
|
||||
}
|
||||
|
|
|
@ -1,3 +1,9 @@
|
|||
2011-04-17 Jan Kratochvil <jan.kratochvil@redhat.com>
|
||||
|
||||
Fix Python access to inlined frames.
|
||||
* gdb.python/py-frame-inline.c: New file.
|
||||
* gdb.python/py-frame-inline.exp: New file.
|
||||
|
||||
2011-04-13 Edjunior Machado <emachado@linux.vnet.ibm.com>
|
||||
|
||||
* gdb.base/gdb1090.exp: Change breakpoint location to read the
|
||||
|
|
43
gdb/testsuite/gdb.python/py-frame-inline.c
Normal file
43
gdb/testsuite/gdb.python/py-frame-inline.c
Normal file
|
@ -0,0 +1,43 @@
|
|||
/* This test is part of GDB, the GNU debugger.
|
||||
|
||||
Copyright 2011 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/>. */
|
||||
|
||||
volatile int v = 42;
|
||||
|
||||
__attribute__((__always_inline__)) static int
|
||||
f (void)
|
||||
{
|
||||
/* Provide first stub line so that GDB understand the PC is already inside
|
||||
the inlined function and does not expect a step into it. */
|
||||
v++;
|
||||
v++; /* break-here */
|
||||
|
||||
return v;
|
||||
}
|
||||
|
||||
__attribute__((__noinline__)) static int
|
||||
g (void)
|
||||
{
|
||||
volatile int l = v;
|
||||
|
||||
return f ();
|
||||
}
|
||||
|
||||
int
|
||||
main (void)
|
||||
{
|
||||
return g ();
|
||||
}
|
39
gdb/testsuite/gdb.python/py-frame-inline.exp
Normal file
39
gdb/testsuite/gdb.python/py-frame-inline.exp
Normal file
|
@ -0,0 +1,39 @@
|
|||
# Copyright (C) 2011 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/>.
|
||||
|
||||
load_lib gdb-python.exp
|
||||
|
||||
set testfile "py-frame-inline"
|
||||
set srcfile ${testfile}.c
|
||||
if { [prepare_for_testing ${testfile}.exp ${testfile} ${srcfile}] } {
|
||||
return -1
|
||||
}
|
||||
|
||||
# Skip all tests if Python scripting is not enabled.
|
||||
if { [skip_python_tests] } { continue }
|
||||
|
||||
if ![runto main] then {
|
||||
fail "Can't run to function f"
|
||||
return 0
|
||||
}
|
||||
|
||||
gdb_breakpoint [gdb_get_line_number "break-here"]
|
||||
gdb_continue_to_breakpoint "Block break here."
|
||||
|
||||
gdb_test "info frame" "inlined into frame 1\r\n.*"
|
||||
|
||||
gdb_test "up" "#1 g .*"
|
||||
|
||||
gdb_test "python print gdb.selected_frame().read_var('l')" "\r\n42"
|
Loading…
Add table
Add a link
Reference in a new issue