2009-07-14 Michael Snyder <msnyder@vmware.com>
authorMichael Snyder <msnyder@vmware.com>
Wed, 15 Jul 2009 01:12:16 +0000 (01:12 +0000)
committerMichael Snyder <msnyder@vmware.com>
Wed, 15 Jul 2009 01:12:16 +0000 (01:12 +0000)
* gdb.arch/i386-signal.c (sigframe): Add a nop to avoid
confusing the i386 epilogue unwinder.

gdb/testsuite/ChangeLog
gdb/testsuite/gdb.arch/i386-signal.c

index ad57d81432b9a63c567ce5165d5b23bfa865ad88..4c3fd098a9a73c62ce1a42514aba9f2583afffb6 100644 (file)
@@ -1,3 +1,8 @@
+2009-07-14  Michael Snyder  <msnyder@vmware.com>
+
+       * gdb.arch/i386-signal.c (sigframe): Add a nop to avoid
+       confusing the i386 epilogue unwinder.
+
 2009-07-14  Stan Shebs  <stan@codesourcery.com>
 
        * gdb.trace/tracecmd.exp: Add basic test of tracepoint conditions.
index d44bc888648b82b75f06866327926a61584c921e..bf6f5c73443ac3712614f23b094fe9f58ce45615 100644 (file)
@@ -37,6 +37,10 @@ main (void)
    The default CIE created by gas suffices to unwind from an empty
    function.  */
 
+/* Note: to make sure that the Dwarf unwinder gets to handle
+   the frame, we add an extra 'nop' after the label.  Otherwise,
+   the epilogue unwinder will see the 'ret' and grab the frame.  */
+
 asm(".text\n"
     "    .align 8\n"
     "    .globl setup\n"
@@ -49,5 +53,6 @@ asm(".text\n"
     "    nop\n"
     "    .globl sigframe\n"
     "sigframe:\n"
+    "    nop\n"
     "    ret\n"
     "    .cfi_endproc");