Blame config/adb.exp

Packit 62fe53
# Copyright (C) 2013-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 2 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
Packit 62fe53
Packit 62fe53
#
Packit 62fe53
# Get serial number in case of multiple devices
Packit 62fe53
#
Packit 62fe53
proc adb_serial {} {
Packit 62fe53
    # If the user has ADB_SERIAL set, use that, otherwise default to the
Packit 62fe53
    # only device.
Packit 62fe53
    set serial "[getenv ADB_SERIAL]"
Packit 62fe53
    if { $serial == "" } {
Packit 62fe53
	set status [catch "exec adb devices |& wc -l" output]
Packit 62fe53
	if { $output > 3 } {
Packit 62fe53
	    perror "Set ADB_SERIAL in your environment to specify the correct target device!"
Packit 62fe53
	}
Packit 62fe53
	return ""
Packit 62fe53
    } else {
Packit 62fe53
	return "-s $serial"
Packit 62fe53
    }
Packit 62fe53
}
Packit 62fe53
Packit 62fe53
#
Packit 62fe53
# Connect to hostname using adb
Packit 62fe53
#
Packit 62fe53
proc adb_open { hostname } {
Packit 62fe53
    global spawn_id
Packit 62fe53
Packit 62fe53
    set tries 0
Packit 62fe53
    set result -1
Packit 62fe53
Packit 62fe53
    if {[board_info ${hostname} exists shell_prompt]} {
Packit 62fe53
	set shell_prompt [board_info ${hostname} shell_prompt]
Packit 62fe53
    } else {
Packit 62fe53
	set shell_prompt "root@android:/ # "
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if {[board_info $hostname exists fileid]} {
Packit 62fe53
	unset board_info($hostname,fileid)
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    set serial [adb_serial]
Packit 62fe53
    if { $serial != "" } {
Packit 62fe53
      spawn adb [adb_serial] shell
Packit 62fe53
    } else {
Packit 62fe53
      spawn adb shell
Packit 62fe53
    }
Packit 62fe53
    if { $spawn_id < 0 } {
Packit 62fe53
	perror "invalid spawn id from adb"
Packit 62fe53
	return -1
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    send "\r\n"
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
	    timeout {
Packit 62fe53
		warning "adb shell: timed out trying to connect."
Packit 62fe53
	    }
Packit 62fe53
	    eof {
Packit 62fe53
		perror "adb shell: got EOF while trying to connect."
Packit 62fe53
		break
Packit 62fe53
	    }
Packit 62fe53
	}
Packit 62fe53
	incr tries
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    if { $result < 0 } {
Packit 62fe53
	#	perror "adb shell: couldn't connect after $tries tries."
Packit 62fe53
	catch "close -i $spawn_id"
Packit 62fe53
	set spawn_id -1
Packit 62fe53
    } else {
Packit 62fe53
	set board_info($hostname,fileid) $spawn_id
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    return $spawn_id
Packit 62fe53
}
Packit 62fe53
Packit 62fe53
#
Packit 62fe53
# Download $srcfile to $destfile on $desthost.
Packit 62fe53
#
Packit 62fe53
Packit 62fe53
proc adb_download {desthost srcfile destfile} {
Packit 62fe53
    set serial [adb_serial]
Packit 62fe53
    verbose "Removing old executable: adb $serial shell rm $destfile" 3
Packit 62fe53
    set status [catch "exec adb $serial shell rm $destfile |& cat" output]
Packit 62fe53
    verbose "Downloading: adb $serial shell push $srcfile $destfile" 3
Packit 62fe53
    set status [catch "exec adb $serial push $srcfile $destfile |& cat" output]
Packit 62fe53
    if { $status == 0 } {
Packit 62fe53
	verbose "Copied $srcfile to $destfile" 2
Packit 62fe53
	return $destfile
Packit 62fe53
    } else {
Packit 62fe53
	verbose "Download to target failed, $output."
Packit 62fe53
	return ""
Packit 62fe53
    }
Packit 62fe53
}
Packit 62fe53
Packit 62fe53
proc adb_file {dest op args} {
Packit 62fe53
    set file [lindex $args 0]
Packit 62fe53
    verbose "Executing command: $op $args" 2
Packit 62fe53
    switch -- $op {
Packit 62fe53
	exists {
Packit 62fe53
	    set status [catch "exec adb [adb_serial] shell ls |& cat" out]
Packit 62fe53
	}
Packit 62fe53
	delete {
Packit 62fe53
	    set status [catch "exec adb [adb_serial] shell rm $file |& cat" rmout]
Packit 62fe53
	}
Packit 62fe53
    }
Packit 62fe53
    return [eval remote_raw_file \"$dest\" \"$op\" $args]
Packit 62fe53
}
Packit 62fe53
Packit 62fe53
proc adb_upload {desthost srcfile destfile} {
Packit 62fe53
    set status [catch "exec adb [adb_serial] pull $srcfile $destfile |& cat" output]
Packit 62fe53
    if { $status == 0 } {
Packit 62fe53
	verbose "Copied $srcfile to $destfile" 2
Packit 62fe53
	return $destfile
Packit 62fe53
    } else {
Packit 62fe53
	verbose "Upload from $desthost failed, $output."
Packit 62fe53
	return ""
Packit 62fe53
    }
Packit 62fe53
}
Packit 62fe53
Packit 62fe53
#
Packit 62fe53
# Execute "$cmd $args[0]" on $boardname.
Packit 62fe53
#
Packit 62fe53
proc adb_exec { boardname cmd args } {
Packit 62fe53
    global remove_test
Packit 62fe53
Packit 62fe53
    if { [llength $args] > 0 } {
Packit 62fe53
	set pargs [lindex $args 0]
Packit 62fe53
	if { [llength $args] > 1 } {
Packit 62fe53
	    set inp [lindex $args 1]
Packit 62fe53
	} else {
Packit 62fe53
	    set inp ""
Packit 62fe53
	}
Packit 62fe53
    } else {
Packit 62fe53
	set pargs ""
Packit 62fe53
	set inp ""
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    # If CMD sends any output to stderr, exec will think it failed.  More often
Packit 62fe53
    # than not that will be true, but it doesn't catch the case where there is
Packit 62fe53
    # no output but the exit code is non-zero.
Packit 62fe53
    if { $inp == "" } {
Packit 62fe53
	set inp "/dev/null"
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    verbose "Executing on $boardname: $cmd $pargs < $inp"
Packit 62fe53
Packit 62fe53
    # Execute commands only from temporary folder, therefore do "cd" first
Packit 62fe53
    global android_tmp_dir
Packit 62fe53
    set status [catch "exec cat $inp | adb [adb_serial] shell cd $android_tmp_dir \&\& \( $cmd $pargs \) \\; echo XYZ\\\$\\\{\?\\\}ZYX |& cat" output]
Packit 62fe53
Packit 62fe53
    # `status' doesn't mean much here other than adb worked ok.
Packit 62fe53
    # What we want is whether $cmd ran ok.
Packit 62fe53
    if { $status != 0 } {
Packit 62fe53
	regsub "XYZ(\[0-9\]*)ZYX\n?" $output "" output
Packit 62fe53
	return [list -1 "adb to $boardname failed for $cmd, $output"]
Packit 62fe53
    }
Packit 62fe53
Packit 62fe53
    regexp "XYZ(\[0-9\]*)ZYX" $output junk status
Packit 62fe53
    verbose "adb_exec: status:$status text:$output" 4
Packit 62fe53
    if { $status == "" } {
Packit 62fe53
	return [list -1 "Couldn't parse adb output, $output."]
Packit 62fe53
    }
Packit 62fe53
    regsub "XYZ(\[0-9\]*)ZYX\n?" $output "" output
Packit 62fe53
    # Delete one trailing \n because that is what `exec' will do and we want
Packit 62fe53
    # to behave identical to it.
Packit 62fe53
    regsub "\n$" $output "" output
Packit 62fe53
    return [list [expr {$status != 0}] $output]
Packit 62fe53
}