mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-12-19 01:19:41 +08:00
Handle function descriptors in call_site_target
call_site_target::iterate_over_addresses may look up a minimal symbol. On platforms like PPC64 that use function descriptors, this may find an unexpected address. The fix is to use gdbarch_convert_from_func_ptr_addr to convert from a function descriptor to the address recorded at the call site. I've added a new test case that is based on the internal AdaCore test that provoked this bug. However, I'm unable to test it as-is on PPC64.
This commit is contained in:
@@ -711,7 +711,11 @@ call_site_target::iterate_over_addresses
|
||||
: msym.minsym->print_name ()));
|
||||
|
||||
}
|
||||
callback (msym.value_address ());
|
||||
|
||||
CORE_ADDR addr = (gdbarch_convert_from_func_ptr_addr
|
||||
(call_site_gdbarch, msym.value_address (),
|
||||
current_inferior ()->top_target ()));
|
||||
callback (addr);
|
||||
}
|
||||
break;
|
||||
|
||||
|
||||
30
gdb/testsuite/gdb.ada/finish-large.exp
Normal file
30
gdb/testsuite/gdb.ada/finish-large.exp
Normal file
@@ -0,0 +1,30 @@
|
||||
# Copyright 2023 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 "ada.exp"
|
||||
|
||||
require allow_ada_tests
|
||||
|
||||
standard_ada_testfile p
|
||||
|
||||
if {[gdb_compile_ada "${srcfile}" "${binfile}" executable debug] != ""} {
|
||||
return -1
|
||||
}
|
||||
|
||||
clean_restart ${testfile}
|
||||
runto "pck.create_large"
|
||||
|
||||
set value "= (i => 1, j => 2, k => 3, l => 4, m => 5, n => 6, o => 7, p => 8, q => 9, r => 10, s => 11, t => 12)"
|
||||
gdb_test "finish" [string_to_regexp $value]
|
||||
24
gdb/testsuite/gdb.ada/finish-large/p.adb
Normal file
24
gdb/testsuite/gdb.ada/finish-large/p.adb
Normal file
@@ -0,0 +1,24 @@
|
||||
-- Copyright 2023 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/>.
|
||||
|
||||
with Pck; use Pck;
|
||||
|
||||
procedure P is
|
||||
Large : Data_Large;
|
||||
begin
|
||||
Large := Create_Large;
|
||||
Large.P := 42;
|
||||
Break_Me;
|
||||
end P;
|
||||
28
gdb/testsuite/gdb.ada/finish-large/pck.adb
Normal file
28
gdb/testsuite/gdb.ada/finish-large/pck.adb
Normal file
@@ -0,0 +1,28 @@
|
||||
-- Copyright 2023 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/>.
|
||||
|
||||
package body Pck is
|
||||
|
||||
function Create_Large return Data_Large is
|
||||
begin
|
||||
return (1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12);
|
||||
end Create_Large;
|
||||
|
||||
procedure Break_Me is
|
||||
begin
|
||||
null;
|
||||
end Break_Me;
|
||||
|
||||
end Pck;
|
||||
37
gdb/testsuite/gdb.ada/finish-large/pck.ads
Normal file
37
gdb/testsuite/gdb.ada/finish-large/pck.ads
Normal file
@@ -0,0 +1,37 @@
|
||||
-- Copyright 2023 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/>.
|
||||
|
||||
package Pck is
|
||||
|
||||
type Data_Large is record
|
||||
I : Integer;
|
||||
J : Integer;
|
||||
K : Integer;
|
||||
L : Integer;
|
||||
M : Integer;
|
||||
N : Integer;
|
||||
O : Integer;
|
||||
P : Integer;
|
||||
Q : Integer;
|
||||
R : Integer;
|
||||
S : Integer;
|
||||
T : Integer;
|
||||
end record;
|
||||
|
||||
function Create_Large return Data_Large;
|
||||
|
||||
procedure Break_Me;
|
||||
|
||||
end Pck;
|
||||
Reference in New Issue
Block a user