blob: b73a9dc46fb338deabfb326228e0dfb06df93a30 [file] [log] [blame]
#!/bin/bash
# Copyright 2020 Google Inc. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# vm_shell.sh: utilities to interact with Microdroid VMs
function print_help() {
echo "vm_shell.sh provides utilities to interact with Microdroid VMs"
echo ""
echo "Available commands:"
echo " connect [cid] - establishes adb connection with the VM"
echo " cid - cid of the VM to connect to. If not specified user will "
echo " be promted to select one from the list of available cids"
echo ""
echo " start-microdroid [--auto-connect] [-- extra_args]"
echo " Starts a Microdroid VM. Args after the -- will be"
echo " passed through to the invocation of the "
echo " /apex/com.android.virt/bin/vm run-microdroid binary."
echo ""
echo " E.g.:"
echo " vm_shell start-microdroid -- --cpu 5"
echo ""
echo " --auto-connect - automatically connects to the started VMs"
echo ""
echo " help - prints this help message"
}
function connect_vm() {
cid=$1
echo Connecting to CID ${cid}
adb disconnect localhost:8000 2>/dev/null
adb forward tcp:8000 vsock:${cid}:5555
adb connect localhost:8000
adb -s localhost:8000 root
adb -s localhost:8000 wait-for-device
adb -s localhost:8000 shell
exit 0
}
function list_cids() {
local selected_cid=$1
local available_cids=$(adb shell /apex/com.android.virt/bin/vm list | awk 'BEGIN { FS="[:,]" } /cid/ { print $2; }')
echo "${available_cids}"
}
function handle_connect_cmd() {
selected_cid=$1
available_cids=$(list_cids)
if [ -z "${available_cids}" ]; then
echo No VM is available
exit 1
fi
if [ ! -n "${selected_cid}" ]; then
if [ ${#selected_cid[@]} -eq 1 ]; then
selected_cid=${available_cids[0]}
else
PS3="Select CID of VM to adb-shell into: "
select cid in ${available_cids}
do
selected_cid=${cid}
break
done
fi
fi
if [[ ! " ${available_cids[*]} " =~ " ${selected_cid} " ]]; then
echo VM of CID $selected_cid does not exist. Available CIDs: ${available_cids}
exit 1
fi
connect_vm ${selected_cid}
}
function handle_start_microdroid_cmd() {
while [[ "$#" -gt 0 ]]; do
case $1 in
--auto-connect) auto_connect=true; ;;
--) shift; passthrough_args="$@"; break ;;
*) echo "Unknown argument: $1"; exit 1 ;;
esac
shift
done
if [[ "${auto_connect}" == true ]]; then
adb shell /apex/com.android.virt/bin/vm run-microdroid "${passthrough_args}" &
trap "kill $!" EXIT
sleep 2
handle_connect_cmd
else
adb shell /apex/com.android.virt/bin/vm run-microdroid "${passthrough_args}"
fi
}
cmd=$1
shift
case $cmd in
connect) handle_connect_cmd "$@" ;;
start-microdroid) handle_start_microdroid_cmd "$@" ;;
help) print_help ;;
*) print_help; exit 1 ;;
esac