* Re: [COMMITTED PATCH] testsuite for info auxv
@ 2004-03-17 21:08 Michael Elizabeth Chastain
2004-03-17 21:26 ` Roland McGrath
2004-03-19 0:09 ` Michael Elizabeth Chastain
0 siblings, 2 replies; 8+ messages in thread
From: Michael Elizabeth Chastain @ 2004-03-17 21:08 UTC (permalink / raw)
To: gdb-patches, roland
Please add a copyright notice to auxv.c.
Michael C
===
2004-03-16 Roland McGrath <roland@redhat.com>
* gdb.base/auxv.exp: New file.
* gdb.base/auxv.c: New file, copied verbatim from coremaker2.c.
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [COMMITTED PATCH] testsuite for info auxv
2004-03-17 21:08 [COMMITTED PATCH] testsuite for info auxv Michael Elizabeth Chastain
@ 2004-03-17 21:26 ` Roland McGrath
2004-03-19 0:09 ` Roland McGrath
2004-03-19 0:09 ` Daniel Jacobowitz
2004-03-19 0:09 ` Michael Elizabeth Chastain
1 sibling, 2 replies; 8+ messages in thread
From: Roland McGrath @ 2004-03-17 21:26 UTC (permalink / raw)
To: Michael Elizabeth Chastain; +Cc: gdb-patches
> Please add a copyright notice to auxv.c.
As I said, I copied it verbatim from coremaker2.c. If all the test cases'
little source files should have copyright notices, these ought to be added
en masse.
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [COMMITTED PATCH] testsuite for info auxv
2004-03-17 21:26 ` Roland McGrath
@ 2004-03-19 0:09 ` Roland McGrath
2004-03-19 0:09 ` Daniel Jacobowitz
1 sibling, 0 replies; 8+ messages in thread
From: Roland McGrath @ 2004-03-19 0:09 UTC (permalink / raw)
To: Michael Elizabeth Chastain; +Cc: gdb-patches
> Please add a copyright notice to auxv.c.
As I said, I copied it verbatim from coremaker2.c. If all the test cases'
little source files should have copyright notices, these ought to be added
en masse.
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [COMMITTED PATCH] testsuite for info auxv
2004-03-17 21:26 ` Roland McGrath
2004-03-19 0:09 ` Roland McGrath
@ 2004-03-19 0:09 ` Daniel Jacobowitz
2004-03-17 22:23 ` Daniel Jacobowitz
1 sibling, 1 reply; 8+ messages in thread
From: Daniel Jacobowitz @ 2004-03-19 0:09 UTC (permalink / raw)
To: Roland McGrath; +Cc: Michael Elizabeth Chastain, gdb-patches
On Wed, Mar 17, 2004 at 01:26:44PM -0800, Roland McGrath wrote:
> > Please add a copyright notice to auxv.c.
>
> As I said, I copied it verbatim from coremaker2.c. If all the test cases'
> little source files should have copyright notices, these ought to be added
> en masse.
They can not be added en masse because too many of the tests are still
sensitive to line numbering. None the less, they should be added when
new files are created.
--
Daniel Jacobowitz
MontaVista Software Debian GNU/Linux Developer
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [COMMITTED PATCH] testsuite for info auxv
2004-03-19 0:09 ` Daniel Jacobowitz
@ 2004-03-17 22:23 ` Daniel Jacobowitz
0 siblings, 0 replies; 8+ messages in thread
From: Daniel Jacobowitz @ 2004-03-17 22:23 UTC (permalink / raw)
To: Roland McGrath; +Cc: Michael Elizabeth Chastain, gdb-patches
On Wed, Mar 17, 2004 at 01:26:44PM -0800, Roland McGrath wrote:
> > Please add a copyright notice to auxv.c.
>
> As I said, I copied it verbatim from coremaker2.c. If all the test cases'
> little source files should have copyright notices, these ought to be added
> en masse.
They can not be added en masse because too many of the tests are still
sensitive to line numbering. None the less, they should be added when
new files are created.
--
Daniel Jacobowitz
MontaVista Software Debian GNU/Linux Developer
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [COMMITTED PATCH] testsuite for info auxv
2004-03-17 21:08 [COMMITTED PATCH] testsuite for info auxv Michael Elizabeth Chastain
2004-03-17 21:26 ` Roland McGrath
@ 2004-03-19 0:09 ` Michael Elizabeth Chastain
1 sibling, 0 replies; 8+ messages in thread
From: Michael Elizabeth Chastain @ 2004-03-19 0:09 UTC (permalink / raw)
To: gdb-patches, roland
Please add a copyright notice to auxv.c.
Michael C
===
2004-03-16 Roland McGrath <roland@redhat.com>
* gdb.base/auxv.exp: New file.
* gdb.base/auxv.c: New file, copied verbatim from coremaker2.c.
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] auxv support
@ 2004-02-25 3:59 Andrew Cagney
2004-03-19 0:09 ` [COMMITTED PATCH] testsuite for info auxv Roland McGrath
0 siblings, 1 reply; 8+ messages in thread
From: Andrew Cagney @ 2004-02-25 3:59 UTC (permalink / raw)
To: Roland McGrath; +Cc: Daniel Jacobowitz, gdb-patches
> I've written a new test case for the live process support, grokking native
> core files, and gcore. It works peachy on Linux 2.6 and on Solaris. It
> should work omitting the native core dump part for remote, but I don't know
> off hand how to test that. Are there runtest arguments to make it run
> gdbserver for tests? (I tried --target_board linux-gdbserver, but that
> tries to do "rsh linux-gdbserver ../gdbserver/gdbserver ..." instead of
> running gdbserver locally. I can't figure out how to make it not use rsh,
> or use a hostname other than "linux-gdbserver".)
I'd not worry (I think that should instead use "(gdb) target remote
|gdbserver").
> However, on a system that does not support getting the auxv data, it shows
> three failures. What is the right thing to do about this? The difficulty
> is that the error from `info auxv' does not distinguish an error/bug in
> reading the data from the target code not supporting auxv access or from
> the native system not supporting the access even though the gdb target code
> does (e.g. Linux < 2.6).
Just a few tweaks:
> 2004-02-23 Roland McGrath <roland@redhat.com>
>
> * gdb.base/auxv.exp: New file.
>
> Index: testsuite/gdb.base/auxv.exp
> ===================================================================
> RCS file: testsuite/gdb.base/auxv.exp
> diff -N testsuite/gdb.base/auxv.exp
> --- /dev/null 1 Jan 1970 00:00:00 -0000
> +++ testsuite/gdb.base/auxv.exp 24 Feb 2004 03:06:02 -0000
> @@ -0,0 +1,186 @@
> +# Test `info auxv' and related functionality.
> +
> +# Copyright 1992,93,94,95,96,97,98,99,2000,04 Free Software Foundation, Inc.
Just write the years in full.
> +set testfile "coremaker2"
> +set srcfile ${testfile}.c
Here a new file "auxv.c" is prefered for the new test (making a copy of
coremaker2.c is ok).
Otherwize, remember to post the final patch when committing,
thanks,
Andrew
> +set binfile ${objdir}/${subdir}/${testfile}
> +set corefile ${objdir}/${subdir}/${testfile}.corefile
> +set gcorefile ${objdir}/${subdir}/${testfile}.gcore
^ permalink raw reply [flat|nested] 8+ messages in thread* [COMMITTED PATCH] testsuite for info auxv
2004-02-25 3:59 [PATCH] auxv support Andrew Cagney
@ 2004-03-19 0:09 ` Roland McGrath
2004-03-17 20:46 ` Roland McGrath
0 siblings, 1 reply; 8+ messages in thread
From: Roland McGrath @ 2004-03-19 0:09 UTC (permalink / raw)
To: gdb-patches
Sorry this got forgotten on the back burner for a few weeks.
I've just checked in the test case for the new `info auxv' functionality.
I made some tiny improvements to the tcl code and made the changes that
Andrew requested, but this is almost identical to what I posted before.
As I mentioned in previous discussion, this now produces:
FAIL: gdb.base/auxv.exp: info auxv on live process
FAIL: gdb.base/auxv.exp: info auxv on native core dump
FAIL: gdb.base/auxv.exp: info auxv on gcore-created dump
on any system without auxv access support, i.e. anything but Linux 2.6 or
Solaris. So don't be surprised by seeing those new failures.
Thanks,
Roland
2004-03-16 Roland McGrath <roland@redhat.com>
* gdb.base/auxv.exp: New file.
* gdb.base/auxv.c: New file, copied verbatim from coremaker2.c.
Index: gdb/testsuite/gdb.base/auxv.c
===================================================================
RCS file: gdb/testsuite/gdb.base/auxv.c
diff -N gdb/testsuite/gdb.base/auxv.c
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ gdb/testsuite/gdb.base/auxv.c 16 Mar 2004 21:41:43 -0000
@@ -0,0 +1,58 @@
+/* Simple little program that just generates a core dump from inside some
+ nested function calls. Keep this as self contained as possible, I.E.
+ use no environment resources other than possibly abort(). */
+
+#ifndef __STDC__
+#define const /**/
+#endif
+
+#ifndef HAVE_ABORT
+#define HAVE_ABORT 1
+#endif
+
+#if HAVE_ABORT
+#define ABORT abort()
+#else
+#define ABORT {char *invalid = 0; *invalid = 0xFF;}
+#endif
+
+/* Don't make these automatic vars or we will have to walk back up the
+ stack to access them. */
+
+char *buf1;
+char *buf2;
+
+int coremaker_data = 1; /* In Data section */
+int coremaker_bss; /* In BSS section */
+
+const int coremaker_ro = 201; /* In Read-Only Data section */
+
+void
+func2 (int x)
+{
+ int coremaker_local[5];
+ int i;
+ static int y;
+
+ /* Make sure that coremaker_local doesn't get optimized away. */
+ for (i = 0; i < 5; i++)
+ coremaker_local[i] = i;
+ coremaker_bss = 0;
+ for (i = 0; i < 5; i++)
+ coremaker_bss += coremaker_local[i];
+ coremaker_data = coremaker_ro + 1;
+ y = 10 * x;
+ ABORT;
+}
+
+void
+func1 (int x)
+{
+ func2 (x * 2);
+}
+
+int main ()
+{
+ func1 (10);
+ return 0;
+}
Index: gdb/testsuite/gdb.base/auxv.exp
===================================================================
RCS file: gdb/testsuite/gdb.base/auxv.exp
diff -N gdb/testsuite/gdb.base/auxv.exp
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ gdb/testsuite/gdb.base/auxv.exp 16 Mar 2004 21:41:43 -0000
@@ -0,0 +1,187 @@
+# Test `info auxv' and related functionality.
+
+# Copyright 1992,1993,1994,1995,1996,1997,1998,1999,2000,2004
+# 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 2 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, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# Please email any bugs, comments, and/or additions to this file to:
+# bug-gdb@prep.ai.mit.edu
+
+# This file is based on corefile.exp which was written by Fred
+# Fish. (fnf@cygnus.com)
+
+if $tracelevel then {
+ strace $tracelevel
+}
+
+set prms_id 0
+set bug_id 0
+
+set testfile "auxv"
+set srcfile ${testfile}.c
+set binfile ${objdir}/${subdir}/${testfile}
+set corefile ${objdir}/${subdir}/${testfile}.corefile
+set gcorefile ${objdir}/${subdir}/${testfile}.gcore
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
+ gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
+}
+
+# Use a fresh directory to confine the native core dumps.
+# Make it the working directory for gdb and its child.
+set coredir "${objdir}/${subdir}/coredir.[getpid]"
+file mkdir $coredir
+set core_works [isnative]
+
+# Run GDB on the test program up to where it will dump core.
+
+gdb_exit
+gdb_start
+gdb_reinitialize_dir $srcdir/$subdir
+gdb_load ${binfile}
+gdb_test "set print sevenbit-strings" "" \
+ "set print sevenbit-strings; ${testfile}"
+gdb_test "set width 0" "" \
+ "set width 0; ${testfile}"
+
+if {$core_works} {
+ if {[gdb_test "cd $coredir" ".*Working directory .*" \
+ "cd to temporary directory for core dumps"]} {
+ set core_works 0
+ }
+}
+
+if { ![runto_main] } then {
+ gdb_suppress_tests;
+}
+set print_core_line [gdb_get_line_number "ABORT;"]
+gdb_test "tbreak $print_core_line"
+gdb_test continue ".*ABORT;.*"
+
+proc fetch_auxv {test} {
+ global gdb_prompt
+
+ set auxv_lines {}
+ set bad -1
+ if {[gdb_test_multiple "info auxv" $test {
+ -re "info auxv\[\r\n\]+" {
+ exp_continue
+ }
+ -ex "The program has no auxiliary information now" {
+ set bad 1
+ }
+ -ex "Auxiliary vector is empty" {
+ set bad 1
+ }
+ -ex "No auxiliary vector found" {
+ set bad 1
+ }
+ -re "^\[0-9\]+\[ \t\]+(AT_\[^ \t\]+)\[^\r\n\]+\[\r\n\]+" {
+ lappend auxv_lines $expect_out(0,string)
+ exp_continue
+ }
+ -re "^\[0-9\]+\[ \t\]+\\?\\?\\?\[^\r\n\]+\[\r\n\]+" {
+ warning "Unrecognized tag value: $expect_out(0,string)"
+ set bad 1
+ lappend auxv_lines $expect_out(0,string)
+ exp_continue
+ }
+ -re ".*$gdb_prompt $" {
+ incr bad
+ }
+ -re "^\[^\r\n\]+\[\r\n\]+" {
+ warning "Unrecognized output: $expect_out(0,string)"
+ set bad 1
+ }
+ }] != 0} {
+ return {}
+ }
+
+ if {$bad} {
+ fail $test
+ return {}
+ }
+
+ pass $test
+ return $auxv_lines
+}
+
+set live_data [fetch_auxv "info auxv on live process"]
+
+# Now try gcore.
+set gcore_works 0
+set escapedfilename [string_to_regexp $gcorefile]
+gdb_test_multiple "gcore $gcorefile" "gcore" {
+ -re "Saved corefile ${escapedfilename}\[\r\n\]+$gdb_prompt $" {
+ pass "gcore"
+ set gcore_works 1
+ }
+ -re "Can't create a corefile\[\r\n\]+$gdb_prompt $" {
+ unsupported "gcore"
+ }
+}
+
+# Let the program continue and die.
+gdb_test continue ".*Program received signal.*"
+gdb_test continue ".*Program terminated with signal.*"
+
+# Now collect the core dump it left.
+set test "generate native core dump"
+if {$core_works} {
+ # Find the
+ set names [glob -nocomplain -directory $coredir *core*]
+ if {[llength $names] == 1} {
+ set file [file join $coredir [lindex $names 0]]
+ remote_exec build "mv $file $corefile"
+ pass $test
+ } else {
+ set core_works 0
+ warning "can't generate a core file - core tests suppressed - check ulimit -c"
+ fail $test
+ }
+} else {
+ unsupported $test
+}
+remote_exec build "rm -rf $coredir"
+
+# Now we can examine the core files and check that their data matches what
+# we saw in the process. Note that the exact data can vary between runs,
+# so it's important that the native core dump file and the gcore-created dump
+# both be from the same run of the program as we examined live.
+
+proc do_core_test {works corefile test1 test2} {
+ if {! $works} {
+ unsupported $test1
+ unsupported $test2
+ } else {
+ gdb_test "core $corefile" "Core was generated by.*" \
+ "load core file for $test1" \
+ "A program is being debugged already.*" "y"
+ set core_data [fetch_auxv $test1]
+ global live_data
+ if {$core_data == $live_data} {
+ pass $test2
+ } else {
+ fail $test2
+ }
+ }
+}
+
+do_core_test $core_works $corefile \
+ "info auxv on native core dump" "matching auxv data from live and core"
+
+do_core_test $gcore_works $gcorefile \
+ "info auxv on gcore-created dump" "matching auxv data from live and gcore"
^ permalink raw reply [flat|nested] 8+ messages in thread* [COMMITTED PATCH] testsuite for info auxv
2004-03-19 0:09 ` [COMMITTED PATCH] testsuite for info auxv Roland McGrath
@ 2004-03-17 20:46 ` Roland McGrath
0 siblings, 0 replies; 8+ messages in thread
From: Roland McGrath @ 2004-03-17 20:46 UTC (permalink / raw)
To: gdb-patches
Sorry this got forgotten on the back burner for a few weeks.
I've just checked in the test case for the new `info auxv' functionality.
I made some tiny improvements to the tcl code and made the changes that
Andrew requested, but this is almost identical to what I posted before.
As I mentioned in previous discussion, this now produces:
FAIL: gdb.base/auxv.exp: info auxv on live process
FAIL: gdb.base/auxv.exp: info auxv on native core dump
FAIL: gdb.base/auxv.exp: info auxv on gcore-created dump
on any system without auxv access support, i.e. anything but Linux 2.6 or
Solaris. So don't be surprised by seeing those new failures.
Thanks,
Roland
2004-03-16 Roland McGrath <roland@redhat.com>
* gdb.base/auxv.exp: New file.
* gdb.base/auxv.c: New file, copied verbatim from coremaker2.c.
Index: gdb/testsuite/gdb.base/auxv.c
===================================================================
RCS file: gdb/testsuite/gdb.base/auxv.c
diff -N gdb/testsuite/gdb.base/auxv.c
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ gdb/testsuite/gdb.base/auxv.c 16 Mar 2004 21:41:43 -0000
@@ -0,0 +1,58 @@
+/* Simple little program that just generates a core dump from inside some
+ nested function calls. Keep this as self contained as possible, I.E.
+ use no environment resources other than possibly abort(). */
+
+#ifndef __STDC__
+#define const /**/
+#endif
+
+#ifndef HAVE_ABORT
+#define HAVE_ABORT 1
+#endif
+
+#if HAVE_ABORT
+#define ABORT abort()
+#else
+#define ABORT {char *invalid = 0; *invalid = 0xFF;}
+#endif
+
+/* Don't make these automatic vars or we will have to walk back up the
+ stack to access them. */
+
+char *buf1;
+char *buf2;
+
+int coremaker_data = 1; /* In Data section */
+int coremaker_bss; /* In BSS section */
+
+const int coremaker_ro = 201; /* In Read-Only Data section */
+
+void
+func2 (int x)
+{
+ int coremaker_local[5];
+ int i;
+ static int y;
+
+ /* Make sure that coremaker_local doesn't get optimized away. */
+ for (i = 0; i < 5; i++)
+ coremaker_local[i] = i;
+ coremaker_bss = 0;
+ for (i = 0; i < 5; i++)
+ coremaker_bss += coremaker_local[i];
+ coremaker_data = coremaker_ro + 1;
+ y = 10 * x;
+ ABORT;
+}
+
+void
+func1 (int x)
+{
+ func2 (x * 2);
+}
+
+int main ()
+{
+ func1 (10);
+ return 0;
+}
Index: gdb/testsuite/gdb.base/auxv.exp
===================================================================
RCS file: gdb/testsuite/gdb.base/auxv.exp
diff -N gdb/testsuite/gdb.base/auxv.exp
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ gdb/testsuite/gdb.base/auxv.exp 16 Mar 2004 21:41:43 -0000
@@ -0,0 +1,187 @@
+# Test `info auxv' and related functionality.
+
+# Copyright 1992,1993,1994,1995,1996,1997,1998,1999,2000,2004
+# 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 2 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, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+# Please email any bugs, comments, and/or additions to this file to:
+# bug-gdb@prep.ai.mit.edu
+
+# This file is based on corefile.exp which was written by Fred
+# Fish. (fnf@cygnus.com)
+
+if $tracelevel then {
+ strace $tracelevel
+}
+
+set prms_id 0
+set bug_id 0
+
+set testfile "auxv"
+set srcfile ${testfile}.c
+set binfile ${objdir}/${subdir}/${testfile}
+set corefile ${objdir}/${subdir}/${testfile}.corefile
+set gcorefile ${objdir}/${subdir}/${testfile}.gcore
+
+if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
+ gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
+}
+
+# Use a fresh directory to confine the native core dumps.
+# Make it the working directory for gdb and its child.
+set coredir "${objdir}/${subdir}/coredir.[getpid]"
+file mkdir $coredir
+set core_works [isnative]
+
+# Run GDB on the test program up to where it will dump core.
+
+gdb_exit
+gdb_start
+gdb_reinitialize_dir $srcdir/$subdir
+gdb_load ${binfile}
+gdb_test "set print sevenbit-strings" "" \
+ "set print sevenbit-strings; ${testfile}"
+gdb_test "set width 0" "" \
+ "set width 0; ${testfile}"
+
+if {$core_works} {
+ if {[gdb_test "cd $coredir" ".*Working directory .*" \
+ "cd to temporary directory for core dumps"]} {
+ set core_works 0
+ }
+}
+
+if { ![runto_main] } then {
+ gdb_suppress_tests;
+}
+set print_core_line [gdb_get_line_number "ABORT;"]
+gdb_test "tbreak $print_core_line"
+gdb_test continue ".*ABORT;.*"
+
+proc fetch_auxv {test} {
+ global gdb_prompt
+
+ set auxv_lines {}
+ set bad -1
+ if {[gdb_test_multiple "info auxv" $test {
+ -re "info auxv\[\r\n\]+" {
+ exp_continue
+ }
+ -ex "The program has no auxiliary information now" {
+ set bad 1
+ }
+ -ex "Auxiliary vector is empty" {
+ set bad 1
+ }
+ -ex "No auxiliary vector found" {
+ set bad 1
+ }
+ -re "^\[0-9\]+\[ \t\]+(AT_\[^ \t\]+)\[^\r\n\]+\[\r\n\]+" {
+ lappend auxv_lines $expect_out(0,string)
+ exp_continue
+ }
+ -re "^\[0-9\]+\[ \t\]+\\?\\?\\?\[^\r\n\]+\[\r\n\]+" {
+ warning "Unrecognized tag value: $expect_out(0,string)"
+ set bad 1
+ lappend auxv_lines $expect_out(0,string)
+ exp_continue
+ }
+ -re ".*$gdb_prompt $" {
+ incr bad
+ }
+ -re "^\[^\r\n\]+\[\r\n\]+" {
+ warning "Unrecognized output: $expect_out(0,string)"
+ set bad 1
+ }
+ }] != 0} {
+ return {}
+ }
+
+ if {$bad} {
+ fail $test
+ return {}
+ }
+
+ pass $test
+ return $auxv_lines
+}
+
+set live_data [fetch_auxv "info auxv on live process"]
+
+# Now try gcore.
+set gcore_works 0
+set escapedfilename [string_to_regexp $gcorefile]
+gdb_test_multiple "gcore $gcorefile" "gcore" {
+ -re "Saved corefile ${escapedfilename}\[\r\n\]+$gdb_prompt $" {
+ pass "gcore"
+ set gcore_works 1
+ }
+ -re "Can't create a corefile\[\r\n\]+$gdb_prompt $" {
+ unsupported "gcore"
+ }
+}
+
+# Let the program continue and die.
+gdb_test continue ".*Program received signal.*"
+gdb_test continue ".*Program terminated with signal.*"
+
+# Now collect the core dump it left.
+set test "generate native core dump"
+if {$core_works} {
+ # Find the
+ set names [glob -nocomplain -directory $coredir *core*]
+ if {[llength $names] == 1} {
+ set file [file join $coredir [lindex $names 0]]
+ remote_exec build "mv $file $corefile"
+ pass $test
+ } else {
+ set core_works 0
+ warning "can't generate a core file - core tests suppressed - check ulimit -c"
+ fail $test
+ }
+} else {
+ unsupported $test
+}
+remote_exec build "rm -rf $coredir"
+
+# Now we can examine the core files and check that their data matches what
+# we saw in the process. Note that the exact data can vary between runs,
+# so it's important that the native core dump file and the gcore-created dump
+# both be from the same run of the program as we examined live.
+
+proc do_core_test {works corefile test1 test2} {
+ if {! $works} {
+ unsupported $test1
+ unsupported $test2
+ } else {
+ gdb_test "core $corefile" "Core was generated by.*" \
+ "load core file for $test1" \
+ "A program is being debugged already.*" "y"
+ set core_data [fetch_auxv $test1]
+ global live_data
+ if {$core_data == $live_data} {
+ pass $test2
+ } else {
+ fail $test2
+ }
+ }
+}
+
+do_core_test $core_works $corefile \
+ "info auxv on native core dump" "matching auxv data from live and core"
+
+do_core_test $gcore_works $gcorefile \
+ "info auxv on gcore-created dump" "matching auxv data from live and gcore"
^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2004-03-17 22:23 UTC | newest]
Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2004-03-17 21:08 [COMMITTED PATCH] testsuite for info auxv Michael Elizabeth Chastain
2004-03-17 21:26 ` Roland McGrath
2004-03-19 0:09 ` Roland McGrath
2004-03-19 0:09 ` Daniel Jacobowitz
2004-03-17 22:23 ` Daniel Jacobowitz
2004-03-19 0:09 ` Michael Elizabeth Chastain
-- strict thread matches above, loose matches on Subject: below --
2004-02-25 3:59 [PATCH] auxv support Andrew Cagney
2004-03-19 0:09 ` [COMMITTED PATCH] testsuite for info auxv Roland McGrath
2004-03-17 20:46 ` Roland McGrath
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox