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>
|
2011-04-15 Tom Tromey <tromey@redhat.com>
|
||||||
|
|
||||||
* dwarf2read.c (add_index_entry): Use VEC_last, not VEC_length.
|
* 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);
|
FRAPY_REQUIRE_VALID ((frame_object *) self, frame);
|
||||||
|
|
||||||
if (!block)
|
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);
|
var = lookup_symbol (var_name, block, VAR_DOMAIN, NULL);
|
||||||
}
|
}
|
||||||
GDB_PY_HANDLE_EXCEPTION (except);
|
GDB_PY_HANDLE_EXCEPTION (except);
|
||||||
|
|
|
@ -276,7 +276,7 @@ gdbpy_lookup_symbol (PyObject *self, PyObject *args, PyObject *kw)
|
||||||
TRY_CATCH (except, RETURN_MASK_ALL)
|
TRY_CATCH (except, RETURN_MASK_ALL)
|
||||||
{
|
{
|
||||||
selected_frame = get_selected_frame (_("No frame selected."));
|
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);
|
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>
|
2011-04-13 Edjunior Machado <emachado@linux.vnet.ibm.com>
|
||||||
|
|
||||||
* gdb.base/gdb1090.exp: Change breakpoint location to read the
|
* 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