From 9b540880d68f565c0a7a4e2d4aa9205e70e12a0a Mon Sep 17 00:00:00 2001 From: Andrew Cagney Date: Fri, 3 Oct 2003 20:50:56 +0000 Subject: [PATCH] 2003-10-03 Andrew Cagney * ppc-linux-tdep.c (ppc64_linux_convert_from_func_ptr_addr): Only convert a descriptor to a function when it's in the ".opd" section. --- gdb/ChangeLog | 6 ++++++ gdb/ppc-linux-tdep.c | 16 +++++++++------- 2 files changed, 15 insertions(+), 7 deletions(-) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 7dfa1b10cee..54940eafe84 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2003-10-03 Andrew Cagney + + * ppc-linux-tdep.c (ppc64_linux_convert_from_func_ptr_addr): Only + convert a descriptor to a function when it's in the ".opd" + section. + 2003-10-03 Corinna Vinschen * sh-tdep.c (sh_push_dummy_call_fpu): Initialize flt_argreg and diff --git a/gdb/ppc-linux-tdep.c b/gdb/ppc-linux-tdep.c index 27744f3e12f..4a6bf6df835 100644 --- a/gdb/ppc-linux-tdep.c +++ b/gdb/ppc-linux-tdep.c @@ -925,8 +925,10 @@ ppc64_skip_trampoline_code (CORE_ADDR pc) find_function_addr uses this function to get the function address from a function pointer. */ -/* Return real function address if ADDR (a function pointer) is in the data - space and is therefore a special function pointer. */ +/* If ADDR points at what is clearly a function descriptor, transform + it into the address of the corresponding function. Be + conservative, otherwize GDB will do the transformation on any + random addresses such as occures when there is no symbol table. */ static CORE_ADDR ppc64_linux_convert_from_func_ptr_addr (CORE_ADDR addr) @@ -934,12 +936,12 @@ ppc64_linux_convert_from_func_ptr_addr (CORE_ADDR addr) struct obj_section *s; s = find_pc_section (addr); - if (s && s->the_bfd_section->flags & SEC_CODE) - return addr; - /* ADDR is in the data space, so it's a pointer to a descriptor, not - the entry point. */ - return ppc64_desc_entry_point (addr); + /* Check if ADDR points to a function descriptor. */ + if (s && strcmp (s->the_bfd_section->name, ".opd") == 0) + return read_memory_unsigned_integer (addr, 8); + + return addr; } -- 2.30.2