Blame lib/kermit.exp

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
}