|
Packit |
62fe53 |
# Copyright (C) 1992-2016 Free Software Foundation, Inc.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
# This file is part of DejaGnu.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
# DejaGnu is free software; you can redistribute it and/or modify it
|
|
Packit |
62fe53 |
# under the terms of the GNU General Public License as published by
|
|
Packit |
62fe53 |
# the Free Software Foundation; either version 3 of the License, or
|
|
Packit |
62fe53 |
# (at your option) any later version.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
# DejaGnu is distributed in the hope that it will be useful, but
|
|
Packit |
62fe53 |
# WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit |
62fe53 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Packit |
62fe53 |
# General Public License for more details.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
# You should have received a copy of the GNU General Public License
|
|
Packit |
62fe53 |
# along with DejaGnu; if not, write to the Free Software Foundation,
|
|
Packit |
62fe53 |
# Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
# Connect to DEST using Kermit. Note that we're just using Kermit as a
|
|
Packit |
62fe53 |
# simple serial or network connect program; we don't actually use Kermit
|
|
Packit |
62fe53 |
# protocol to do downloads.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
# Returns -1 if it failed, otherwise it returns the spawn_id.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
proc kermit_open {dest args} {
|
|
Packit |
62fe53 |
global spawn_id
|
|
Packit |
62fe53 |
global board_info
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
if {[board_info $dest exists name]} {
|
|
Packit |
62fe53 |
set dest [board_info $dest name]
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
if {[board_info ${dest} exists serial]} {
|
|
Packit |
62fe53 |
set port [board_info ${dest} serial]
|
|
Packit |
62fe53 |
set device "-l [board_info ${dest} serial]"
|
|
Packit |
62fe53 |
if {[board_info ${dest} exists baud]} {
|
|
Packit |
62fe53 |
append device " -b [board_info ${dest} baud]"
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
} else {
|
|
Packit |
62fe53 |
set port [board_info ${dest} netport]
|
|
Packit |
62fe53 |
set device "-j [board_info ${dest} netport]"
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
set tries 0
|
|
Packit |
62fe53 |
set result -1
|
|
Packit |
62fe53 |
verbose "kermit $device"
|
|
Packit |
62fe53 |
eval spawn kermit $device
|
|
Packit |
62fe53 |
if {$spawn_id < 0} {
|
|
Packit |
62fe53 |
perror "invalid spawn id from Kermit"
|
|
Packit |
62fe53 |
return -1
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
expect {
|
|
Packit |
62fe53 |
-re ".*ermit.*>.*$" {
|
|
Packit |
62fe53 |
send "c\n"
|
|
Packit |
62fe53 |
expect {
|
|
Packit |
62fe53 |
-re "Connecting to.*$port.*Type the escape character followed by C to.*options.*\[\r\n\]$" {
|
|
Packit |
62fe53 |
verbose "Got prompt\n"
|
|
Packit |
62fe53 |
set result 0
|
|
Packit |
62fe53 |
incr tries
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
timeout {
|
|
Packit |
62fe53 |
warning "Never got prompt from Kermit."
|
|
Packit |
62fe53 |
set result -1
|
|
Packit |
62fe53 |
incr tries
|
|
Packit |
62fe53 |
if {$tries <= 2} {
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
-re "Connection Closed.*$" {
|
|
Packit |
62fe53 |
perror "Never connected."
|
|
Packit |
62fe53 |
set result -1
|
|
Packit |
62fe53 |
incr tries
|
|
Packit |
62fe53 |
if {$tries <= 2} {
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
timeout {
|
|
Packit |
62fe53 |
warning "Timed out trying to connect."
|
|
Packit |
62fe53 |
set result -1
|
|
Packit |
62fe53 |
incr tries
|
|
Packit |
62fe53 |
if {$tries <= 2} {
|
|
Packit |
62fe53 |
exp_continue
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
if {$result < 0} {
|
|
Packit |
62fe53 |
perror "Couldn't connect after $tries tries."
|
|
Packit |
62fe53 |
if {[info exists board_info($dest,fileid)]} {
|
|
Packit |
62fe53 |
unset board_info($dest,fileid)
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
return -1
|
|
Packit |
62fe53 |
} else {
|
|
Packit |
62fe53 |
verbose "Kermit connection established with spawn_id $spawn_id."
|
|
Packit |
62fe53 |
set board_info($dest,fileid) $spawn_id
|
|
Packit |
62fe53 |
kermit_command $dest "set file type binary" "set transfer display none"
|
|
Packit |
62fe53 |
if {[board_info $dest exists transmit_pause]} {
|
|
Packit |
62fe53 |
kermit_command $dest "set transmit pause [board_info $dest transmit_pause]"
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
return $spawn_id
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
# Send a list of commands to the Kermit session connected to DEST.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
proc kermit_command {dest args} {
|
|
Packit |
62fe53 |
if {[board_info $dest exists name]} {
|
|
Packit |
62fe53 |
set dest [board_info $dest name]
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
set shell_id [board_info $dest fileid]
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
# Sometimes we have to send multiple ^\c sequences. Don't know
|
|
Packit |
62fe53 |
# why.
|
|
Packit |
62fe53 |
set timeout 2
|
|
Packit |
62fe53 |
for {set i 1} {$i <= 5} {incr i} {
|
|
Packit |
62fe53 |
send -i $shell_id "?c"
|
|
Packit |
62fe53 |
expect {
|
|
Packit |
62fe53 |
-i $shell_id -re ".*Back at.*ermit.*>.*$" {set i 10}
|
|
Packit |
62fe53 |
-i $shell_id timeout {
|
|
Packit |
62fe53 |
if {$i > 2} {
|
|
Packit |
62fe53 |
warning "Unable to get prompt from kermit."
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
foreach command $args {
|
|
Packit |
62fe53 |
set timeout 120
|
|
Packit |
62fe53 |
send -i $shell_id "${command}\r"
|
|
Packit |
62fe53 |
expect {
|
|
Packit |
62fe53 |
-i $shell_id -re ".*ermit.*>.*$" { }
|
|
Packit |
62fe53 |
-i $shell_id timeout {
|
|
Packit |
62fe53 |
perror "Response failed from Kermit."
|
|
Packit |
62fe53 |
return -1
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
send -i $shell_id "c\r"
|
|
Packit |
62fe53 |
expect {
|
|
Packit |
62fe53 |
-i $shell_id -re ".*other options.\[\r\n\]+" { }
|
|
Packit |
62fe53 |
-i $shell_id timeout {
|
|
Packit |
62fe53 |
perror "Unable to resume Kermit connection."
|
|
Packit |
62fe53 |
return -1
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
return 0
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
# Send STRING to DEST.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
proc kermit_send {dest string args} {
|
|
Packit |
62fe53 |
if {[board_info $dest exists transmit_pause]} {
|
|
Packit |
62fe53 |
set f [open "/tmp/fff" "w"]
|
|
Packit |
62fe53 |
puts -nonewline $f "$string"
|
|
Packit |
62fe53 |
close $f
|
|
Packit |
62fe53 |
set result [remote_transmit $dest /tmp/fff]
|
|
Packit |
62fe53 |
remote_file build delete "/tmp/fff"
|
|
Packit |
62fe53 |
return "$result"
|
|
Packit |
62fe53 |
} else {
|
|
Packit |
62fe53 |
return [standard_send $dest $string]
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
|
|
Packit |
62fe53 |
# Transmit FILE directly to DEST as raw data.
|
|
Packit |
62fe53 |
# No translation is performed.
|
|
Packit |
62fe53 |
#
|
|
Packit |
62fe53 |
proc kermit_transmit {dest file args} {
|
|
Packit |
62fe53 |
if {[board_info $dest exists transmit_pause]} {
|
|
Packit |
62fe53 |
kermit_command $dest "transmit $file"
|
|
Packit |
62fe53 |
return ""
|
|
Packit |
62fe53 |
} else {
|
|
Packit |
62fe53 |
return [standard_transmit $dest $file]
|
|
Packit |
62fe53 |
}
|
|
Packit |
62fe53 |
}
|