#!/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 -- --protected --debug full" 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