Blame lib/rlogin.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 ARG using rlogin. This is for systems using rlogin to
Packit 62fe53
# braindead targets. It returns either the spawn_id or a -1.
Packit 62fe53
#
Packit 62fe53
proc rlogin_open { arg } {
Packit 62fe53
    global board_info
Packit 62fe53
Packit 62fe53
    set tries 0
Packit 62fe53
    set result -1
Packit 62fe53
Packit 62fe53
    if {[board_info $arg exists fileid]} {
Packit 62fe53
	return [board_info $arg fileid]
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    # get the hostname and port number from the config array
Packit 62fe53
    if {[board_info $arg exists netport]} {
Packit 62fe53
	set hostname [lindex [split [board_info $arg netport] ":"] 0]
Packit 62fe53
    } else {
Packit 62fe53
	set hostname $arg
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {![board_info $arg exists shell_prompt]} {
Packit 62fe53
	# if no prompt, then set it to something generic
Packit 62fe53
	set shell_prompt ".*> "
Packit 62fe53
    } else {
Packit 62fe53
	set shell_prompt [board_info $arg shell_prompt]
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $arg exists fileid]} {
Packit 62fe53
	unset board_info($arg,fileid)
Packit 62fe53
    }
Packit 62fe53
    # get the right version of rlogin
Packit 62fe53
    if {![board_info $arg exists rlogin_prog]} {
Packit 62fe53
	set RLOGIN rlogin
Packit 62fe53
    } else {
Packit 62fe53
	set RLOGIN [board_info $arg rlogin_prog]
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    # start connection and store the spawn_id
Packit 62fe53
    verbose "Opening a $RLOGIN connection to $hostname" 2
Packit 62fe53
    spawn $RLOGIN $hostname
Packit 62fe53
    if { $spawn_id < 0 } {
Packit 62fe53
	perror "invalid spawn id from rlogin"
Packit 62fe53
	return -1
Packit 62fe53
    }
Packit 62fe53
    set board_info($arg,fileid) $spawn_id
Packit 62fe53
Packit 62fe53
    # Try to connect to the target. We give up after 3 attempts.
Packit 62fe53
    while { $tries <= 3 } {
Packit 62fe53
	expect {
Packit 62fe53
	    -re ".*$shell_prompt.*$" {
Packit 62fe53
		verbose "Got prompt\n"
Packit 62fe53
		set result 0
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    -re "TERM = .*\\)\[ ]*$" {
Packit 62fe53
		send "dumb\r\n"
Packit 62fe53
		expect {
Packit 62fe53
		    "Terminal type is*$" {
Packit 62fe53
			verbose "rlogin: set the terminal to dumb" 2
Packit 62fe53
		    }
Packit 62fe53
		    default {
Packit 62fe53
			warning "rlogin: couldn't set terminmal type"
Packit 62fe53
		    }
Packit 62fe53
		}
Packit 62fe53
		set result 10
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    "unknown host" {
Packit 62fe53
		perror "rlogin: unknown host"
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    "has logged on from" {
Packit 62fe53
		exp_continue
Packit 62fe53
	    }
Packit 62fe53
	    "Terminal type is" {
Packit 62fe53
		verbose "rlogin: connected, got terminal prompt" 2
Packit 62fe53
		set result 0
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	    -re "Maximum number of users already logged in.*$" {
Packit 62fe53
		warning "rlogin: maximum number of users already logged in"
Packit 62fe53
	    }
Packit 62fe53
	    -re "Sorry, shell is locked.*Connection closed.*$" {
Packit 62fe53
		warning "rlogin: lready connected."
Packit 62fe53
	    }
Packit 62fe53
	    -re "Sorry, this system is engaged.*Connection closed.*$" {
Packit 62fe53
		warning "rlogin: system engaged."
Packit 62fe53
	    }
Packit 62fe53
	    timeout	{
Packit 62fe53
		warning "rlogin: timed out trying to connect."
Packit 62fe53
	    }
Packit 62fe53
	    eof {
Packit 62fe53
		perror "rlogin: got EOF while trying to connect."
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	}
Packit 62fe53
	incr tries
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    # see if we maxed out on errors
Packit 62fe53
    if { $result < 0 } {
Packit 62fe53
	catch "close -i $spawn_id"
Packit 62fe53
	catch "wait -i $spawn_id"
Packit 62fe53
	set spawn_id -1
Packit 62fe53
    } else {
Packit 62fe53
	verbose "rlogin: connected to $hostname" 2
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    return $spawn_id
Packit 62fe53
}
Packit 62fe53
Packit 62fe53
# Start CMDLINE running on DEST. Return the shell_id associated with
Packit 62fe53
# the command.
Packit 62fe53
#
Packit 62fe53
proc rlogin_spawn { dest cmdline } {
Packit 62fe53
    if {![board_info $dest exists shell_prompt]} {
Packit 62fe53
	set shell_prompt "(^|\[\r\n\])\[^\r\n\]*>"
Packit 62fe53
    } else {
Packit 62fe53
	set shell_prompt [board_info $dest shell_prompt]
Packit 62fe53
    }
Packit 62fe53
    set prefix ""
Packit 62fe53
    set ok 0
Packit 62fe53
    for { set i 0 } {$i <= 2 && ! $ok} { incr i } {
Packit 62fe53
	set shell_id [remote_open $dest]
Packit 62fe53
	if { $shell_id != "" && $shell_id > 0 } {
Packit 62fe53
	    remote_send $dest "echo k\r"
Packit 62fe53
	    remote_expect $dest 20 {
Packit 62fe53
		-re "\\(gdb\\)" {
Packit 62fe53
		    set shell_prompt "\\(gdb\\)"
Packit 62fe53
		    # gdb uses 'shell command'.
Packit 62fe53
		    set prefix "shell "
Packit 62fe53
		    set ok 1
Packit 62fe53
		}
Packit 62fe53
		-re ".*$shell_prompt" {
Packit 62fe53
		    set ok 1
Packit 62fe53
		}
Packit 62fe53
		default { }
Packit 62fe53
	    }
Packit 62fe53
	}
Packit 62fe53
	if { ! $ok } {
Packit 62fe53
	    remote_close $dest
Packit 62fe53
	    remote_reboot $dest
Packit 62fe53
	}
Packit 62fe53
    }
Packit 62fe53
    if { ! $ok } {
Packit 62fe53
	return "unable to start command"
Packit 62fe53
    } else {
Packit 62fe53
	remote_send $dest "${prefix}${cmdline}\n"
Packit 62fe53
	return [board_info $dest fileid]
Packit 62fe53
    }
Packit 62fe53
}