This is the mail archive of the
gdb-patches@sourceware.org
mailing list for the GDB project.
[PATCH] Fix PLT call stub for ppc64
- From: Edjunior Barbosa Machado <emachado at linux dot vnet dot ibm dot com>
- To: gdb-patches at sourceware dot org
- Cc: uweigand at de dot ibm dot com
- Date: Wed, 7 Nov 2012 17:06:55 -0200
- Subject: [PATCH] Fix PLT call stub for ppc64
Hi,
GDB was unable to 'step' into a c/c++ function from a shared library on ppc64
due to a change in linker that removes a load
instruction from the PLT call stub
(http://sourceware.org/ml/binutils/2011-07/msg00141.html). This patch fixes this
on GDB, marking the mentioned instruction as optional, since it still might
appear if the linker is called with '--plt-static-chain'.
It also solves some unexpected failures in the testuite on ppc64 (verified on
fedora 17):
-FAIL: gdb.base/gdb1555.exp: Step into shared lib function
-FAIL: gdb.base/gdb1555.exp: Next while in a shared lib function
-FAIL: gdb.base/gnu-ifunc.exp: step
-FAIL: gdb.base/skip-solib.exp: step
-FAIL: gdb.base/skip-solib.exp: bt
-FAIL: gdb.base/so-impl-ld.exp: step into solib call
-FAIL: gdb.base/so-impl-ld.exp: step in solib call
-FAIL: gdb.base/so-impl-ld.exp: step out of solib call
Ok to commit?
Thanks,
--
Edjunior
gdb/ChangeLog
2012-11-07 Edjunior Machado <emachado@linux.vnet.ibm.com>
* ppc-linux-tdep.c (ppc64_standard_linkage3): Mark ld r11 instruction as
optional, following the change in PLT call stub on linker.
---
gdb/ppc-linux-tdep.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/gdb/ppc-linux-tdep.c b/gdb/ppc-linux-tdep.c
index ccded83..fcffa7d 100644
--- a/gdb/ppc-linux-tdep.c
+++ b/gdb/ppc-linux-tdep.c
@@ -446,8 +446,8 @@ static struct insn_pattern ppc64_standard_linkage3[] =
/* mtctr r11 */
{ insn_xfx (-1, -1, -1, -1), insn_xfx (31, 11, 9, 467), 0 },
- /* ld r11, <any>(r2) */
- { insn_ds (-1, -1, -1, 0, -1), insn_ds (58, 11, 2, 0, 0), 0 },
+ /* ld r11, <any>(r2) <optional> */
+ { insn_ds (-1, -1, -1, 0, -1), insn_ds (58, 11, 2, 0, 0), 1 },
/* ld r2, <any>(r2) */
{ insn_ds (-1, -1, -1, 0, -1), insn_ds (58, 2, 2, 0, 0), 0 },
--
1.7.10.1