2004-08-26 Paul Gilliam <pgilliam@us.ibm.com>

* gdb.base/call-sc.exp (test_scalar_returns): Make sure PC is
	synchronized after the "return".
This commit is contained in:
Michael Chastain 2004-08-26 18:02:59 +00:00
parent 85a84e7a87
commit 3a77aa2811
2 changed files with 29 additions and 0 deletions

View file

@ -1,3 +1,8 @@
2004-08-26 Paul Gilliam <pgilliam@us.ibm.com>
* gdb.base/call-sc.exp (test_scalar_returns): Make sure PC is
synchronized after the "return".
2004-08-26 Michael Chastain <mec.gnu@mindspring.com> 2004-08-26 Michael Chastain <mec.gnu@mindspring.com>
* gdb.mi/basics.c: Include <stdio.h>. * gdb.mi/basics.c: Include <stdio.h>.

View file

@ -281,6 +281,30 @@ proc test_scalar_returns { } {
} }
} }
# If the previous test did not work, the program counter might
# still be inside foo() rather than main(). Make sure the program
# counter is is main().
#
# This happens on ppc64 GNU/Linux with gcc 3.4.1 and a buggy GDB
set test "return foo; synchronize pc to main()"
for {set loop_count 0} {$loop_count < 2} {incr loop_count} {
gdb_test_multiple "backtrace 1" $test {
-re "#0.*main \\(\\).*${gdb_prompt} $" {
pass $test
set loop_count 2
}
-re "#0.*fun \\(\\).*${gdb_prompt} $" {
if {$loop_count < 1} {
gdb_test "finish" ".*" ""
} else {
fail $test
set loop_count 2
}
}
}
}
# Check that the return-value is as expected. At this stage we're # Check that the return-value is as expected. At this stage we're
# just checking that GDB has returned a value consistent with # just checking that GDB has returned a value consistent with
# "return_value_unknown" set above. # "return_value_unknown" set above.