From: Jan Kratochvil <jan.kratochvil@redhat.com>
To: Joel Brobecker <brobecker@adacore.com>
Cc: gdb-patches@sourceware.org
Subject: [patch] testsuite: Test the unwinder off-by-one [Re: [RFA] DWARF frame unwinder executes one too many rows]
Date: Fri, 17 Aug 2012 18:14:00 -0000 [thread overview]
Message-ID: <20120817181425.GA19445@host2.jankratochvil.net> (raw)
In-Reply-To: <20120804123005.GA30962@host2.jankratochvil.net>
On Sat, 04 Aug 2012 14:30:05 +0200, Jan Kratochvil wrote:
> but the Ada testcase does not work for me (it always PASSes for i386 and it
> always FAILs for x86_64). Do you have some precompiled binaries so that I can
> look at them.
Joel has sent them off-list, I found the Ada testcase works for me on i386
with the attached update.
I will check it in.
Thanks,
Jan
gdb/testsuite/
2012-08-17 Jan Kratochvil <jan.kratochvil@redhat.com>
* gdb.ada/rdv_wait.exp (set debug-file-directory): New command.
* gdb.arch/i386-cfi-notcurrent.S: New file.
* gdb.arch/i386-cfi-notcurrent.exp: New file.
diff --git a/gdb/testsuite/gdb.ada/rdv_wait.exp b/gdb/testsuite/gdb.ada/rdv_wait.exp
index 67e0f1e..f2b00b7 100644
--- a/gdb/testsuite/gdb.ada/rdv_wait.exp
+++ b/gdb/testsuite/gdb.ada/rdv_wait.exp
@@ -23,6 +23,9 @@ if {[gdb_compile_ada "${srcfile}" "${binfile}" executable [list debug ]] != "" }
clean_restart ${testfile}
+# This test won't work properly if system debuginfo is installed.
+gdb_test_no_output "set debug-file-directory"
+
runto "break_me"
# Switch to task 2, and verify that GDB is able to unwind all the way
diff --git a/gdb/testsuite/gdb.arch/i386-cfi-notcurrent.S b/gdb/testsuite/gdb.arch/i386-cfi-notcurrent.S
new file mode 100644
index 0000000..eae94b0
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/i386-cfi-notcurrent.S
@@ -0,0 +1,76 @@
+/* Copyright 2012 Free Software Foundation, Inc.
+
+ This file is part of GDB.
+
+ 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/>. */
+
+/* Testcase compiled by gcc -m32 -S -fasynchronous-unwind-tables -O2:
+
+static int __attribute__ ((regparm (0), stdcall, noinline, noclone))
+f (int x)
+{
+ return x;
+}
+static int __attribute__ ((noinline, noclone))
+g (void)
+{
+ return f (1) + 1;
+}
+int
+main (void)
+{
+ return g () + 1;
+}
+
+ */
+
+ .text
+ .type f, @function
+f:
+.LFB0:
+ .cfi_startproc
+ movl 4(%esp), %eax
+ ret $4
+ .cfi_endproc
+.LFE0:
+ .size f, .-f
+ .type g, @function
+g:
+.LFB1:
+ .cfi_startproc
+ subl $4, %esp
+ .cfi_def_cfa_offset 8
+ movl $1, (%esp)
+ call f
+ .cfi_def_cfa_offset 4
+ subl $4, %esp
+ .cfi_def_cfa_offset 8
+ addl $1, %eax
+ addl $4, %esp
+ .cfi_def_cfa_offset 4
+ ret
+ .cfi_endproc
+.LFE1:
+ .size g, .-g
+ .globl main
+ .type main, @function
+main:
+.LFB2:
+ .cfi_startproc
+ call g
+ addl $1, %eax
+ ret
+ .cfi_endproc
+.LFE2:
+ .size main, .-main
diff --git a/gdb/testsuite/gdb.arch/i386-cfi-notcurrent.exp b/gdb/testsuite/gdb.arch/i386-cfi-notcurrent.exp
new file mode 100644
index 0000000..cf41c57
--- /dev/null
+++ b/gdb/testsuite/gdb.arch/i386-cfi-notcurrent.exp
@@ -0,0 +1,34 @@
+# Copyright 2012 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/>.
+
+# [RFA] DWARF frame unwinder executes one too many rows
+# http://sourceware.org/ml/gdb-patches/2012-07/msg00650.html
+
+if {(![istarget "x86_64-*-*"] && ![istarget "i?86-*-*"]) || ![is_ilp32_target] } {
+ return 0
+}
+
+set testfile "i386-cfi-notcurrent"
+set srcfile ${testfile}.S
+
+if [prepare_for_testing ${testfile}.exp ${testfile} ${srcfile} {nodebug}] {
+ return -1
+}
+
+if ![runto f] {
+ return -1
+}
+
+gdb_test "backtrace" "#0 \[^\r\n\]* f \[^\r\n\]*\r\n#1 \[^\r\n\]* g \[^\r\n\]*\r\n#2 \[^\r\n\]* main \[^\r\n\]*"
next prev parent reply other threads:[~2012-08-17 18:14 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-07-26 22:51 [RFA] DWARF frame unwinder executes one too many rows Joel Brobecker
2012-07-27 11:07 ` asmwarrior
2012-07-27 11:15 ` asmwarrior
2012-07-27 12:14 ` Joel Brobecker
2012-07-30 17:43 ` Tom Tromey
2012-08-16 15:47 ` Joel Brobecker
2012-08-04 12:30 ` Jan Kratochvil
2012-08-06 14:05 ` Tom Tromey
2012-08-06 15:06 ` Jan Kratochvil
2012-08-06 15:10 ` Tom Tromey
2012-08-06 15:19 ` Jan Kratochvil
2012-08-17 18:14 ` Jan Kratochvil [this message]
2012-08-27 16:35 ` [commit] [patch] testsuite: Test the unwinder off-by-one [Re: [RFA] DWARF frame unwinder executes one too many rows] Jan Kratochvil
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20120817181425.GA19445@host2.jankratochvil.net \
--to=jan.kratochvil@redhat.com \
--cc=brobecker@adacore.com \
--cc=gdb-patches@sourceware.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox