* lib/gdb.exp: Transform tool name.
* gdb.t*/*.exp: Change error to perror so it works with DejaGnu 1.1's new error handling system.
This commit is contained in:
parent
73e1e09b8e
commit
85174909de
@ -1,3 +1,9 @@
|
|||||||
|
Wed Nov 3 11:23:11 1993 Rob Savoye (rob@darkstar.cygnus.com)
|
||||||
|
|
||||||
|
* lib/gdb.exp: Transform tool name.
|
||||||
|
* gdb.t*/*.exp: Change error to perror so it works with DejaGnu
|
||||||
|
1.1's new error handling system.
|
||||||
|
|
||||||
Mon Nov 1 10:36:29 1993 Jim Kingdon (kingdon@lioth.cygnus.com)
|
Mon Nov 1 10:36:29 1993 Jim Kingdon (kingdon@lioth.cygnus.com)
|
||||||
|
|
||||||
* Makefile.in, gdb.t2*/Makefile.in: Add -O to CXXFLAGS.
|
* Makefile.in, gdb.t2*/Makefile.in: Add -O to CXXFLAGS.
|
||||||
|
@ -67,7 +67,7 @@ proc gdb_unload {} {
|
|||||||
}
|
}
|
||||||
-re "$prompt $" {}
|
-re "$prompt $" {}
|
||||||
timeout {
|
timeout {
|
||||||
error "Couldn't unload file in $GDB (timed out)."
|
perror "Couldn't unload file in $GDB (timed out)."
|
||||||
return -1
|
return -1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -108,14 +108,14 @@ proc gdb_start {} {
|
|||||||
if {[which $GDB] != 0} then {
|
if {[which $GDB] != 0} then {
|
||||||
spawn $GDB $GDBFLAGS
|
spawn $GDB $GDBFLAGS
|
||||||
} else {
|
} else {
|
||||||
error "$GDB does not exist."
|
perror "$GDB does not exist."
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if {[which $GDB] != 0} then {
|
if {[which $GDB] != 0} then {
|
||||||
spawn $GDB
|
spawn $GDB
|
||||||
} else {
|
} else {
|
||||||
error "$GDB does not exist."
|
perror "$GDB does not exist."
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -126,11 +126,11 @@ proc gdb_start {} {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
-re "$prompt $" {
|
-re "$prompt $" {
|
||||||
error "GDB never initialized."
|
perror "GDB never initialized."
|
||||||
return -1
|
return -1
|
||||||
}
|
}
|
||||||
timeout {
|
timeout {
|
||||||
error "(timeout) GDB never initialized."
|
perror "(timeout) GDB never initialized."
|
||||||
return -1
|
return -1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -139,9 +139,7 @@ proc gdb_start {} {
|
|||||||
send "set height 0\n"
|
send "set height 0\n"
|
||||||
expect {
|
expect {
|
||||||
-re ".*$prompt $" {
|
-re ".*$prompt $" {
|
||||||
if $verbose>2 then {
|
verbose "Seting height to 0."
|
||||||
send_user "Seting height to 0.\n"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
timeout {
|
timeout {
|
||||||
warning "Couldn't set the height to 0."
|
warning "Couldn't set the height to 0."
|
||||||
@ -165,19 +163,6 @@ proc gdb_exit { } {
|
|||||||
catch default_gdb_exit
|
catch default_gdb_exit
|
||||||
}
|
}
|
||||||
|
|
||||||
# These only need to be uncommented for debugging test cases. They exist
|
|
||||||
# mainly to catch programming errors
|
|
||||||
#expect_after {
|
|
||||||
# "<return>" { send "\n"; error "Window too small." }
|
|
||||||
# -re "\(y or n\) " { send "n\n"; error "Got interactive prompt." }
|
|
||||||
# buffer_full { error "internal buffer is full." }
|
|
||||||
# eof { error "eof -- there is no child process" ; cleanup ; exit $exit_status}
|
|
||||||
# timeout { error "timeout." }
|
|
||||||
# "virtual memory exhausted" { error "virtual memory exhausted." }
|
|
||||||
# "Undefined command" { error "send string probably wrong." }
|
|
||||||
#}
|
|
||||||
|
|
||||||
|
|
||||||
set binpath /s1/users/rob/vxworks/bin/somewhere-bogus-that-needs-configuring
|
set binpath /s1/users/rob/vxworks/bin/somewhere-bogus-that-needs-configuring
|
||||||
set bin $GDB
|
set bin $GDB
|
||||||
|
|
||||||
|
@ -19,6 +19,25 @@ proc do_tests {} {
|
|||||||
clear_xfail "rs*-*-aix*"
|
clear_xfail "rs*-*-aix*"
|
||||||
gdb_test "ptype red" "type = enum \{red, green, blue\}" "ptype unnamed enum"
|
gdb_test "ptype red" "type = enum \{red, green, blue\}" "ptype unnamed enum"
|
||||||
|
|
||||||
|
# Mips/alpha targets that use gcc with mips-tfile put out the stabs
|
||||||
|
# assembler directives embedded in comments. If the assembler
|
||||||
|
# file is then processed with native cc, all stabs directives
|
||||||
|
# will be lost.
|
||||||
|
# Skip the rest of the stabs tests for this case.
|
||||||
|
send "ptype inttype\n"
|
||||||
|
expect {
|
||||||
|
-re "^ptype inttype\r*\ntype = inttype.*$prompt $" {
|
||||||
|
pass "stabs found"
|
||||||
|
}
|
||||||
|
-re ".*$prompt $" {
|
||||||
|
setup_xfail "mips-*-*"
|
||||||
|
setup_xfail "alpha-*-*"
|
||||||
|
fail "stabs not found"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
default { fail "checking for stabs" }
|
||||||
|
}
|
||||||
|
|
||||||
print_weird_var var0
|
print_weird_var var0
|
||||||
print_weird_var var1
|
print_weird_var var1
|
||||||
print_weird_var var2
|
print_weird_var var2
|
||||||
@ -244,7 +263,7 @@ if ![file exists $binfile] then {
|
|||||||
fail "Errors reading weird.o"
|
fail "Errors reading weird.o"
|
||||||
}
|
}
|
||||||
timeout {
|
timeout {
|
||||||
error "couldn't load $binfile into $GDB (timed out)."
|
perror "couldn't load $binfile into $GDB (timed out)."
|
||||||
return -1
|
return -1
|
||||||
}
|
}
|
||||||
eof { fail "(eof) cannot read weird.o" }
|
eof { fail "(eof) cannot read weird.o" }
|
||||||
|
@ -23,6 +23,13 @@
|
|||||||
# need to be modified for any target, it can be done with a variable
|
# need to be modified for any target, it can be done with a variable
|
||||||
# or by passing arguments.
|
# or by passing arguments.
|
||||||
|
|
||||||
|
if ![info exists GDB] then {
|
||||||
|
set GDB [transform gdb]
|
||||||
|
}
|
||||||
|
if ![info exists GDBFLAGS] then {
|
||||||
|
set GDBFLAGS ""
|
||||||
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
# gdb_version -- extract and print the version number of gcc
|
# gdb_version -- extract and print the version number of gcc
|
||||||
#
|
#
|
||||||
@ -31,9 +38,8 @@ proc default_gdb_version {} {
|
|||||||
global GDBFLAGS
|
global GDBFLAGS
|
||||||
if {[which $GDB] != 0} then {
|
if {[which $GDB] != 0} then {
|
||||||
set tmp [exec echo "q" | $GDB]
|
set tmp [exec echo "q" | $GDB]
|
||||||
set version "[lindex $tmp [lsearch $tmp "\[0-9\]*"]]"
|
regexp " \[0-9\.\]+" $tmp version
|
||||||
set version "[string range $version 0 [expr [string length $version]-2]]"
|
clone_output "[which $GDB] version$version $GDBFLAGS\n"
|
||||||
clone_output "[which $GDB] version $version $GDBFLAGS\n"
|
|
||||||
} else {
|
} else {
|
||||||
warning "$GDB does not exist"
|
warning "$GDB does not exist"
|
||||||
}
|
}
|
||||||
@ -53,9 +59,7 @@ proc gdb_unload {} {
|
|||||||
-re "No symbol file now\.\r" { continue -expect }
|
-re "No symbol file now\.\r" { continue -expect }
|
||||||
-re "A program is being debugged already..*Kill it\? \(y or n\) $"\
|
-re "A program is being debugged already..*Kill it\? \(y or n\) $"\
|
||||||
{ send "y\n"
|
{ send "y\n"
|
||||||
if $verbose>1 then {
|
verbose "\t\tKilling previous program being debugged"
|
||||||
send_user "\t\tKilling previous program being debugged\n"
|
|
||||||
}
|
|
||||||
continue -expect
|
continue -expect
|
||||||
}
|
}
|
||||||
-re "Discard symbol table from .*\? \(y or n\) $" {
|
-re "Discard symbol table from .*\? \(y or n\) $" {
|
||||||
@ -64,7 +68,7 @@ proc gdb_unload {} {
|
|||||||
}
|
}
|
||||||
-re "$prompt $" {}
|
-re "$prompt $" {}
|
||||||
timeout {
|
timeout {
|
||||||
error "couldn't unload file in $GDB (timed out)."
|
perror "couldn't unload file in $GDB (timed out)."
|
||||||
return -1
|
return -1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -187,7 +191,7 @@ proc gdb_test { args } {
|
|||||||
# trap the send so any problems don't crash things
|
# trap the send so any problems don't crash things
|
||||||
catch "send \"$command\n\"" errmess
|
catch "send \"$command\n\"" errmess
|
||||||
if [string match "write\(spawn_id=\[0-9\]+\):" $errmess] then {
|
if [string match "write\(spawn_id=\[0-9\]+\):" $errmess] then {
|
||||||
error "sent \"$command\" got expect error \"$errmess\""
|
perror "sent \"$command\" got expect error \"$errmess\""
|
||||||
catch "close"
|
catch "close"
|
||||||
gdb_start
|
gdb_start
|
||||||
return -1
|
return -1
|
||||||
@ -209,11 +213,11 @@ proc gdb_test { args } {
|
|||||||
set result 0
|
set result 0
|
||||||
}
|
}
|
||||||
-re "Undefined command:.*$prompt" {
|
-re "Undefined command:.*$prompt" {
|
||||||
error "Undefined command \"$command\"."
|
perror "Undefined command \"$command\"."
|
||||||
set result 1
|
set result 1
|
||||||
}
|
}
|
||||||
-re "Ambiguous command.*$prompt $" {
|
-re "Ambiguous command.*$prompt $" {
|
||||||
error "\"$command\" is not a unique command name."
|
perror "\"$command\" is not a unique command name."
|
||||||
set result 1
|
set result 1
|
||||||
}
|
}
|
||||||
-re ".*$prompt $" {
|
-re ".*$prompt $" {
|
||||||
@ -224,18 +228,18 @@ proc gdb_test { args } {
|
|||||||
}
|
}
|
||||||
"<return>" {
|
"<return>" {
|
||||||
send "\n"
|
send "\n"
|
||||||
error "Window too small."
|
perror "Window too small."
|
||||||
}
|
}
|
||||||
-re "\(y or n\) " {
|
-re "\(y or n\) " {
|
||||||
send "n\n"
|
send "n\n"
|
||||||
error "Got interactive prompt."
|
perror "Got interactive prompt."
|
||||||
}
|
}
|
||||||
eof {
|
eof {
|
||||||
error "Process no longer exists"
|
perror "Process no longer exists"
|
||||||
return -1
|
return -1
|
||||||
}
|
}
|
||||||
buffer_full {
|
buffer_full {
|
||||||
error "internal buffer is full."
|
perror "internal buffer is full."
|
||||||
}
|
}
|
||||||
timeout {
|
timeout {
|
||||||
fail "(timeout) $message"
|
fail "(timeout) $message"
|
||||||
@ -247,9 +251,8 @@ proc gdb_test { args } {
|
|||||||
|
|
||||||
proc gdb_reinitialize_dir { subdir } {
|
proc gdb_reinitialize_dir { subdir } {
|
||||||
global prompt
|
global prompt
|
||||||
global verbose
|
|
||||||
|
|
||||||
send "dir\n"
|
send "dir\n"
|
||||||
expect {
|
expect {
|
||||||
-re "Reinitialize source path to empty.*" {
|
-re "Reinitialize source path to empty.*" {
|
||||||
send "y\n"
|
send "y\n"
|
||||||
@ -258,27 +261,24 @@ proc gdb_reinitialize_dir { subdir } {
|
|||||||
send "dir $subdir\n"
|
send "dir $subdir\n"
|
||||||
expect {
|
expect {
|
||||||
-re "Source directories searched.*$prompt $" {
|
-re "Source directories searched.*$prompt $" {
|
||||||
if $verbose>1 then {
|
verbose "Dir set to $subdir"
|
||||||
send_user "Dir set to $subdir\n"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
-re ".*$prompt $" {
|
-re ".*$prompt $" {
|
||||||
error "Dir \"$subdir\" failed."
|
perror "Dir \"$subdir\" failed."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
-re ".*$prompt $" {
|
-re ".*$prompt $" {
|
||||||
error "Dir \"$subdir\" failed."
|
perror "Dir \"$subdir\" failed."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
-re ".*$prompt $" {
|
-re ".*$prompt $" {
|
||||||
error "Dir \"$subdir\" failed."
|
perror "Dir \"$subdir\" failed."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# gdb_exit -- exit the GDB, killing the target program if necessary
|
# gdb_exit -- exit the GDB, killing the target program if necessary
|
||||||
#
|
#
|
||||||
@ -302,25 +302,19 @@ proc default_gdb_exit {} {
|
|||||||
# FIXME: What is this catch statement doing here? Won't it prevent us
|
# FIXME: What is this catch statement doing here? Won't it prevent us
|
||||||
# from getting errors that we'd rather see?
|
# from getting errors that we'd rather see?
|
||||||
catch {
|
catch {
|
||||||
expect {
|
expect {
|
||||||
eof {
|
eof {
|
||||||
verbose "Got EOF from $GDB" 2
|
verbose "Got EOF from $GDB" 2
|
||||||
}
|
}
|
||||||
timeout {
|
timeout {
|
||||||
verbose "Got TIMEOUT from $GDB" 2
|
verbose "Got TIMEOUT from $GDB" 2
|
||||||
}
|
}
|
||||||
-re "The program is running. Quit anyway.*(y or n) $" {
|
-re "The program is running. Quit anyway.*(y or n) $" {
|
||||||
send "y\n"
|
send "y\n"
|
||||||
verbose "Killing program being debugged" 2
|
verbose "Killing program being debugged" 2
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
# FIXME: Does the catch prevent us from getting errors that we'd rather
|
|
||||||
# see? the old gdb_exit in unix-gdb.exp had "close" without catch
|
|
||||||
# in the above expect statement (for the timeout and -re "The
|
|
||||||
# program... cases) (as well as a catch "close" here).
|
|
||||||
catch "close"
|
|
||||||
|
|
||||||
# Before this was here sometimes "uit" would get sent to the next GDB
|
# Before this was here sometimes "uit" would get sent to the next GDB
|
||||||
# (assuming this is immediately followed by gdb_start), which would
|
# (assuming this is immediately followed by gdb_start), which would
|
||||||
@ -329,6 +323,67 @@ proc default_gdb_exit {} {
|
|||||||
wait
|
wait
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# gdb_load -- load a file into the debugger.
|
||||||
|
# return a -1 if anything goes wrong.
|
||||||
|
#
|
||||||
|
proc gdb_file_cmd { arg } {
|
||||||
|
global verbose
|
||||||
|
global loadpath
|
||||||
|
global loadfile
|
||||||
|
global GDB
|
||||||
|
global prompt
|
||||||
|
|
||||||
|
send "file $arg\n"
|
||||||
|
expect {
|
||||||
|
-re "Reading symbols from.*done.*$prompt $" {
|
||||||
|
verbose "\t\tLoaded $arg into the $GDB"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
-re "has no symbol-table.*$prompt $" {
|
||||||
|
perror "$arg wasn't compiled with \"-g\""
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
-re "A program is being debugged already..*Kill it\? \(y or n\) $" {
|
||||||
|
send "y\n"
|
||||||
|
verbose "\t\tKilling previous program being debugged"
|
||||||
|
continue -expect
|
||||||
|
}
|
||||||
|
-re "Load new symbol table from.*\? \(y or n\) $" {
|
||||||
|
send "y\n"
|
||||||
|
expect {
|
||||||
|
-re "Reading symbols from.*done.*$prompt $" {
|
||||||
|
verbose "\t\tLoaded $arg with new symbol table into $GDB"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
timeout {
|
||||||
|
perror "(timeout) Couldn't load $arg, other program already l
|
||||||
|
oaded."
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
-re ".*No such file or directory.*$prompt $" {
|
||||||
|
perror "($arg) No such file or directory\n"
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
-re "$prompt $" {
|
||||||
|
perror "couldn't load $arg into $GDB."
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
timeout {
|
||||||
|
error "couldn't load $arg into $GDB (timed out)."
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
eof {
|
||||||
|
# This is an attempt to detect a core dump, but seems not to
|
||||||
|
# work. Perhaps we need to match .* followed by eof, in which
|
||||||
|
# expect does not seem to have a way to do that.
|
||||||
|
error "couldn't load $arg into $GDB (end of file)."
|
||||||
|
return -1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user