blob: abb9b9010980448e01fd4ad5041881a4d6cb4235 [file] [log] [blame]
Greg Hartman71633c82018-06-21 18:49:01 -07001#!/bin/bash
Jorge E. Moreiraa8142f92018-06-13 17:33:55 -07002
3#
4# Copyright (C) 2018 The Android Open Source Project
5#
6# Licensed under the Apache License, Version 2.0 (the "License");
7# you may not use this file except in compliance with the License.
8# You may obtain a copy of the License at
9#
10# http://www.apache.org/licenses/LICENSE-2.0
11#
12# Unless required by applicable law or agreed to in writing, software
13# distributed under the License is distributed on an "AS IS" BASIS,
14# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15# See the License for the specific language governing permissions and
16# limitations under the License.
17#
18
19default_instance_number() {
20 if [[ "${USER::5}" == "vsoc-" ]]; then
21 echo "${USER: -2}"
22 else
23 echo "01"
24 fi
25}
26CUTTLEFISH_INSTANCE="${CUTTLEFISH_INSTANCE:-$(default_instance_number)}"
27default_instance_name="cvd-${CUTTLEFISH_INSTANCE}"
28default_uuid="699acfc4-c8c4-11e7-882b-5065f31dc1${CUTTLEFISH_INSTANCE}"
Jorge E. Moreira285b48b2018-06-27 10:33:24 -070029default_dir="${HOME}/cuttlefish_runtime"
Jorge E. Moreiraa8142f92018-06-13 17:33:55 -070030default_mobile_tap_name="cvd-mtap-${CUTTLEFISH_INSTANCE}"
Jorge E. Moreira029dc0e2018-06-22 19:46:19 -070031default_wifi_tap_name="cvd-wtap-${CUTTLEFISH_INSTANCE}"
Jorge E. Moreiraa8142f92018-06-13 17:33:55 -070032
33if [[ -z "${ivshmem_vector_count}" ]]; then
34 echo "The required ivshmem_vector_count environment variable is not set" >&2
35 exit 1
36fi
37
Greg Hartman71633c82018-06-21 18:49:01 -070038args=(
39 -enable-kvm
40 -name "guest=${instance_name:-${default_instance_name}},debug-threads=on"
41 -machine "pc-i440fx-2.8,accel=kvm,usb=off,dump-guest-core=off"
42 -m "${memory_mb:-2048}"
43 -realtime mlock=off
44 -smp "${cpus:-2},sockets=${cpus:-2},cores=1,threads=1"
45 -uuid "${uuid:-${default_uuid}}"
46 -display none
47 -no-user-config
48 -nodefaults
Jorge E. Moreira2b003012018-07-22 17:46:27 -070049 -chardev "socket,id=charmonitor,path=${monitor_path:-${default_dir}/qemu_monitor.sock},nowait"
Greg Hartman71633c82018-06-21 18:49:01 -070050 -mon "chardev=charmonitor,id=monitor,mode=control"
51 -rtc "base=utc"
52 -no-shutdown
53 -boot "strict=on"
54 -kernel "${kernel_image_path:-${HOME}/kernel}"
Jorge E. Moreirab2427ba2018-08-23 17:11:55 -070055 -append "${kernel_cmdline:-"loop.max_part=7 console=ttyS0 androidboot.console=ttyS1 androidboot.hardware=vsoc enforcing=0 audit=1 androidboot.selinux=permissive mac80211_hwsim.radios=0 security=selinux buildvariant=userdebug androidboot.serialno=CUTTLEFISHCVD01 androidboot.lcd_density=160"}"
Greg Hartman71633c82018-06-21 18:49:01 -070056 -dtb "${dtb_path:-${HOME}/config/cuttlefish.dtb}"
Alistair Strachan06e0c172018-11-05 09:52:54 -080057 -device "piix3-usb-uhci,id=usb,addr=0x1.0x2"
58 -device "virtio-serial-pci,id=virtio-serial0,addr=0x4"
Cody Schuffelen33d1d0a2018-08-09 16:08:27 -070059 -drive "file=${system_image_path:-${HOME}/system.img},format=raw,if=none,id=drive-virtio-disk0,aio=threads"
Alistair Strachan06e0c172018-11-05 09:52:54 -080060 -device "virtio-blk-pci,scsi=off,addr=0x5,drive=drive-virtio-disk0,id=virtio-disk0,bootindex=1"
Cody Schuffelen33d1d0a2018-08-09 16:08:27 -070061 -drive "file=${data_image_path:-${HOME}/userdata.img},format=raw,if=none,id=drive-virtio-disk1,aio=threads"
Alistair Strachan06e0c172018-11-05 09:52:54 -080062 -device "virtio-blk-pci,scsi=off,addr=0x6,drive=drive-virtio-disk1,id=virtio-disk1"
Cody Schuffelen33d1d0a2018-08-09 16:08:27 -070063 -drive "file=${cache_image_path:-${HOME}/cache.img},format=raw,if=none,id=drive-virtio-disk2,aio=threads"
Alistair Strachan06e0c172018-11-05 09:52:54 -080064 -device "virtio-blk-pci,scsi=off,addr=0x7,drive=drive-virtio-disk2,id=virtio-disk2"
Cody Schuffelen33d1d0a2018-08-09 16:08:27 -070065 -drive "file=${vendor_image_path:-${HOME}/vendor.img},format=raw,if=none,id=drive-virtio-disk3,aio=threads"
Alistair Strachan06e0c172018-11-05 09:52:54 -080066 -device "virtio-blk-pci,scsi=off,addr=0x8,drive=drive-virtio-disk3,id=virtio-disk3"
Greg Hartman88df7a82018-10-09 16:50:33 -070067 -netdev "tap,id=hostnet0,ifname=${wifi_tap_name:-${default_wifi_tap_name}},script=no,downscript=no"
Alistair Strachan06e0c172018-11-05 09:52:54 -080068 -device "virtio-net-pci,netdev=hostnet0,id=net0,addr=0x2"
Greg Hartman88df7a82018-10-09 16:50:33 -070069 -netdev "tap,id=hostnet1,ifname=${mobile_tap_name:-${default_mobile_tap_name}},script=no,downscript=no"
Alistair Strachan06e0c172018-11-05 09:52:54 -080070 -device "virtio-net-pci,netdev=hostnet1,id=net1,addr=0x3"
Greg Hartman71633c82018-06-21 18:49:01 -070071 -chardev "socket,id=charserial0,path=${kernel_log_socket_name:-${default_dir}/kernel-log}"
72 -device "isa-serial,chardev=charserial0,id=serial0"
73 -chardev "socket,id=charserial1,path=${console_path:-${default_dir}/console},server,nowait"
Alistair Strachan06e0c172018-11-05 09:52:54 -080074 -device "pci-serial,chardev=charserial1,id=serial1,addr=0xc"
Greg Hartman71633c82018-06-21 18:49:01 -070075 -chardev "file,id=charchannel0,path=${logcat_path:-${default_dir}/logcat},append=on"
76 -device "virtserialport,bus=virtio-serial0.0,nr=1,chardev=charchannel0,id=channel0,name=cf-logcat"
Alistair Strachan06e0c172018-11-05 09:52:54 -080077 -device "virtio-balloon-pci,id=balloon0,addr=0x9"
Greg Hartman71633c82018-06-21 18:49:01 -070078 -object "rng-random,id=objrng0,filename=/dev/urandom"
Alistair Strachan06e0c172018-11-05 09:52:54 -080079 -device "virtio-rng-pci,rng=objrng0,id=rng0,max-bytes=1024,period=2000,addr=0xa"
Greg Hartman71633c82018-06-21 18:49:01 -070080 -chardev "socket,path=${ivshmem_qemu_socket_path:-${default_dir}/ivshmem_socket_qemu},id=ivsocket"
Alistair Strachan06e0c172018-11-05 09:52:54 -080081 -device "ivshmem-doorbell,chardev=ivsocket,vectors=${ivshmem_vector_count},addr=0xd"
Greg Hartman71633c82018-06-21 18:49:01 -070082 -cpu host
Jorge E. Moreiraa8142f92018-06-13 17:33:55 -070083 -msg "timestamp=on"
Greg Hartman71633c82018-06-21 18:49:01 -070084)
85
Greg Hartman91f81422018-07-09 16:04:49 -070086if [[ -n "${gdb_flag}" ]]; then
87 args+=(-gdb "${gdb_flag}")
88fi
89
Greg Hartman71633c82018-06-21 18:49:01 -070090if [[ -n "${ramdisk_image_path}" ]]; then
91 args+=(-initrd "${ramdisk_image_path}")
92fi
93
Ryan Hainingf1383572018-07-10 15:31:57 -070094if [[ -n "${usb_v1_socket_name}" ]]; then
95 args+=(
96 -chardev "socket,id=charchannel1,path=${usb_v1_socket_name:-${default_dir}/usb-v1}"
97 -device "virtserialport,bus=virtio-serial0.0,nr=2,chardev=charchannel1,id=channel1,name=cf-gadget-usb-v1"
98 )
99fi
Greg Hartman213a8a72018-06-28 23:43:40 -0700100printf %s "exec ${qemu_binary=/usr/bin/qemu-system-x86_64}"
101for i in "${args[@]}"; do
102 case "$i" in
103 -*) printf "\\%s %s " $'\n' "$i" ;;
104 *) printf "%s " "$i" ;;
105 esac
106done
107echo
108
Greg Hartman71633c82018-06-21 18:49:01 -0700109exec "${qemu_binary=/usr/bin/qemu-system-x86_64}" \
110 "${args[@]}"