12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- #!/bin/bash
- # Copyright 2022 The ChromiumOS Authors
- # Use of this source code is governed by a BSD-style license that can be
- # found in the LICENSE file.
- # Example VM with internet access and sshd
- set -e
- sudo mkdir -p /var/empty
- SRC=$(realpath "$(dirname "${BASH_SOURCE[0]}")")
- mkdir -p "$SRC/images/network" && cd "$_"
- if ! [ -f rootfs ]; then
- # ANCHOR: build
- builder_args=(
- # Create user with no password.
- --run-command "useradd -m -g sudo -p '' $USER ; chage -d 0 $USER"
- # Configure network via netplan config in 01-netcfg.yaml
- --hostname crosvm-test
- # $SRC=/path/to/crosvm
- --copy-in "$SRC/guest/01-netcfg.yaml:/etc/netplan/"
- # Install sshd.
- --install openssh-server
- -o rootfs
- )
- # Inject authorized key for the user.
- # If the SSH RSA public key file is missing, you will need to login to
- # the VM the first time and change passwords before you can login via SSH.
- ID_RSA_PUB="$HOME/.ssh/id_rsa.pub"
- if [ -r "${ID_RSA_PUB}" ]; then
- builder_args+=("--ssh-inject" "${USER}:file:${ID_RSA_PUB}")
- fi
- virt-builder ubuntu-20.04 "${builder_args[@]}"
- # ANCHOR_END: build
- virt-builder --get-kernel ./rootfs -o .
- fi
- # ANCHOR: run
- # Use the previously configured crosvm_tap device for networking.
- cargo run -- run \
- --rwdisk ./rootfs \
- --initrd ./initrd.img-* \
- --net tap-name=crosvm_tap \
- -p "root=/dev/vda5" \
- ./vmlinuz-*
- # ANCHOR_END: run
|