aboutsummaryrefslogtreecommitdiff
path: root/gdb/testsuite/config
diff options
context:
space:
mode:
authorKung Hsu <kung@cygnus>1995-03-01 00:35:09 +0000
committerKung Hsu <kung@cygnus>1995-03-01 00:35:09 +0000
commitcb58e516f932657c5eca5ed830f5d83e57904e97 (patch)
treef2b5fa6877f53ea36bef3227e66c2511f9ebf0d2 /gdb/testsuite/config
parentbc01beb5ea1487fd7882d3b160ac340d7bf2f861 (diff)
downloadgdb-cb58e516f932657c5eca5ed830f5d83e57904e97.zip
gdb-cb58e516f932657c5eca5ed830f5d83e57904e97.tar.gz
gdb-cb58e516f932657c5eca5ed830f5d83e57904e97.tar.bz2
* config/mips-gdb.exp (gdb_load): In every test case, we need to do
'file' command firts, then 'target', then 'load', this is due to gdb target set up. * config/mips-gdb.exp: Fix a couple regular exp bugs.
Diffstat (limited to 'gdb/testsuite/config')
-rw-r--r--gdb/testsuite/config/mips-gdb.exp85
1 files changed, 51 insertions, 34 deletions
diff --git a/gdb/testsuite/config/mips-gdb.exp b/gdb/testsuite/config/mips-gdb.exp
index 3fce30e..6904776 100644
--- a/gdb/testsuite/config/mips-gdb.exp
+++ b/gdb/testsuite/config/mips-gdb.exp
@@ -30,8 +30,6 @@
# VxWorks, because the test output would appear on the other port,
# rather than being displayed by gdb.
-set prompt "\(gdb\)"
-
load_lib remote.exp
load_lib gdb.exp
@@ -61,20 +59,37 @@ proc gdb_load { arg } {
global spawn_id
global GDB
global expect_out
+ global targetname
set loadfile [file tail $arg]
set loadpath [file dirname $arg]
- gdb_unload
+
send "file $arg\n"
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"
exp_continue
}
- -re "Reading symbols from.*done..*$prompt $" { }
+ -re "Reading symbols from.*done..*$prompt $" {}
-re "$prompt $" { perror "GDB couldn't read file" }
- timeout { perror "(timeout) read symbol file" ; return }
+ timeout { perror "(timeout) read symbol file" ; return -1 }
+ }
+
+ send "target mips $targetname\n"
+ set timeout 60
+ expect {
+ -re "Remote MIPS debugging.*$prompt $" {
+ if $verbose>1 then {
+ send_user "Set target to $targetname\n"
+ }
+ }
+ timeout {
+ perror "Couldn't set MIPS target."
+ set timeout 10
+ return -1
+ }
}
+
send "load $arg\n"
if $verbose>1 then {
send_user "Loading $arg into $GDB\n"
@@ -86,16 +101,15 @@ proc gdb_load { arg } {
send_user "Loaded $arg into $GDB\n"
}
set timeout 30
- return 1
}
-re "$prompt $" {
if $verbose>1 then {
- perror "GDB couldn't load."
+ perror "GDB couldn't load."
}
}
timeout {
if $verbose>1 then {
- perror "Timed out trying to load $arg."
+ perror "Timed out trying to load $arg."
}
}
}
@@ -129,7 +143,7 @@ proc gdb_start { } {
if ![info exists baud] then {
set baud 9600
}
- set shell_id [ eval $connectmode "$targetname" $baud ]
+ set shell_id [ eval $connectmode "$targetname" ]
send -i $shell_id "\n"
expect {
-i $shell_id -re "<IDT>$" { }
@@ -160,14 +174,17 @@ proc gdb_start { } {
spawn $GDB
}
expect {
- -re "GDB.*$prompt $" {
- if $verbose>1 then {
- send_user "$GDB initialized for cross mode\n\n"
- }
+ -re ".*\r\n$prompt $" {
+ verbose "GDB initialized."
+ }
+ -re "$prompt $" {
+ perror "GDB never initialized."
+ return -1
+ }
+ timeout {
+ perror "(timeout) GDB never initialized."
+ return -1
}
- -re "$prompt $" { perror "GDB never initialized."; return -1 }
- timeout { perror "(timeout) GDB never initialized.";
- return -1 }
}
# force the height to "unlimited", so no pagers get used
@@ -182,23 +199,23 @@ proc gdb_start { } {
send "set mipsfpu off\n"
expect -re ".*$prompt $" {}
- if $verbose>1 then {
- send_user "Setting up target, please wait...\n"
- }
- send "target mips $targetname\n"
- set timeout 60
- expect {
- -re "Remote MIPS debugging.*$prompt $" {
- if $verbose>1 then {
- send_user "Set target to $targetname\n"
- }
- }
- timeout {
- perror "Couldn't set MIPS target."
- set timeout 10
- return -1
- }
- }
+# if $verbose>1 then {
+# send_user "Setting up target, please wait...\n"
+# }
+# send "target mips $targetname\n"
+# set timeout 60
+# expect {
+# -re "Remote MIPS debugging.*$prompt $" {
+# if $verbose>1 then {
+# send_user "Set target to $targetname\n"
+# }
+# }
+# timeout {
+# perror "Couldn't set MIPS target."
+# set timeout 10
+# return -1
+# }
+# }
set timeout 10
}