mirror of
https://github.com/flatcar/scripts.git
synced 2025-08-10 22:46:58 +02:00
This isn't a feature we've been using as far as I know and if someone needs a custom partition layout it's probably better to just add it to the json file. Removing this avoids some complexity.
130 lines
3.8 KiB
Bash
Executable File
130 lines
3.8 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
# Copyright (c) 2010 The Chromium OS Authors. All rights reserved.
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
# found in the LICENSE file.
|
|
|
|
# Script to convert the output of build_image.sh to a usable virtual machine
|
|
# disk image, supporting a variety of different targets.
|
|
|
|
|
|
|
|
# Helper scripts should be run from the same location as this script.
|
|
SCRIPT_ROOT=$(dirname "$(readlink -f "$0")")
|
|
. "${SCRIPT_ROOT}/common.sh" || exit 1
|
|
. "${BUILD_LIBRARY_DIR}/toolchain_util.sh" || exit 1
|
|
. "${BUILD_LIBRARY_DIR}/disk_layout_util.sh" || exit 1
|
|
. "${BUILD_LIBRARY_DIR}/build_common.sh" || exit 1
|
|
. "${BUILD_LIBRARY_DIR}/build_image_util.sh" || exit 1
|
|
. "${BUILD_LIBRARY_DIR}/vm_image_util.sh" || exit 1
|
|
|
|
# Need to be inside the chroot to load chromeos-common.sh
|
|
assert_inside_chroot
|
|
|
|
# Load functions and constants for chromeos-install
|
|
. /usr/lib/installer/chromeos-common.sh || exit 1
|
|
. "${SCRIPT_ROOT}/lib/cros_vm_constants.sh" || exit 1
|
|
|
|
# Flags
|
|
DEFINE_string board "${DEFAULT_BOARD}" \
|
|
"Board for which the image was built"
|
|
|
|
# We default to TRUE so the buildbot gets its image. Note this is different
|
|
# behavior from image_to_usb.sh
|
|
DEFINE_string format "qemu" \
|
|
"Output format, one of: ${VALID_IMG_TYPES[*]}"
|
|
DEFINE_string from "" \
|
|
"Directory containing rootfs.image and mbr.image"
|
|
DEFINE_string disk_layout "" \
|
|
"The disk layout type to use for this image."
|
|
DEFINE_integer mem "${DEFAULT_MEM}" \
|
|
"Memory size for the vm config in MBs."
|
|
DEFINE_string state_image "" \
|
|
"Stateful partition image (defaults to creating new statful partition)"
|
|
DEFINE_boolean prod_image "${FLAGS_FALSE}" \
|
|
"Use the production image instead of the default developer image."
|
|
DEFINE_string to "" \
|
|
"Destination folder for VM output file(s)"
|
|
|
|
# include upload options
|
|
. "${BUILD_LIBRARY_DIR}/release_util.sh" || exit 1
|
|
|
|
# Parse command line
|
|
FLAGS "$@" || exit 1
|
|
eval set -- "${FLAGS_ARGV}"
|
|
|
|
# Die on any errors.
|
|
switch_to_strict_mode
|
|
|
|
check_gsutil_opts
|
|
|
|
if ! set_vm_type "${FLAGS_format}"; then
|
|
die_notrace "Invalid format: ${FLAGS_format}"
|
|
fi
|
|
|
|
if [ -z "${FLAGS_board}" ] ; then
|
|
die_notrace "--board is required."
|
|
fi
|
|
|
|
# Loaded after flags are parsed because board_options depends on --board
|
|
. "${BUILD_LIBRARY_DIR}/board_options.sh" || exit 1
|
|
|
|
|
|
IMAGES_DIR="${DEFAULT_BUILD_ROOT}/images/${FLAGS_board}"
|
|
# Default to the most recent image
|
|
if [ -z "${FLAGS_from}" ] ; then
|
|
FLAGS_from="$(${SCRIPT_ROOT}/get_latest_image.sh --board=${FLAGS_board})"
|
|
else
|
|
pushd "${FLAGS_from}" && FLAGS_from=`pwd` && popd
|
|
fi
|
|
if [ -z "${FLAGS_to}" ] ; then
|
|
FLAGS_to="${FLAGS_from}"
|
|
fi
|
|
|
|
# Convert args to paths. Need eval to un-quote the string so that shell
|
|
# chars like ~ are processed; just doing FOO=`readlink -f $FOO` won't work.
|
|
FLAGS_from=`eval readlink -f $FLAGS_from`
|
|
FLAGS_to=`eval readlink -f $FLAGS_to`
|
|
|
|
# If source includes version.txt switch to its version information
|
|
if [ -f "${FLAGS_from}/version.txt" ]; then
|
|
source "${FLAGS_from}/version.txt"
|
|
COREOS_VERSION_STRING="${COREOS_BUILD}.${COREOS_BRANCH}.${COREOS_PATCH}"
|
|
fi
|
|
|
|
if [ ${FLAGS_prod_image} -eq ${FLAGS_TRUE} ]; then
|
|
set_vm_paths "${FLAGS_from}" "${FLAGS_to}" "${COREOS_PRODUCTION_IMAGE_NAME}"
|
|
else
|
|
# Use the standard image
|
|
set_vm_paths "${FLAGS_from}" "${FLAGS_to}" "${CHROMEOS_IMAGE_NAME}"
|
|
fi
|
|
|
|
locate_gpt
|
|
legacy_offset_size_export ${VM_SRC_IMG}
|
|
|
|
# Make sure things are cleaned up on failure
|
|
trap vm_cleanup EXIT
|
|
|
|
# Unpack image, using alternate state image if defined
|
|
# Resize to use all available space in new disk layout
|
|
unpack_source_disk "${FLAGS_state_image}"
|
|
resize_state_partition
|
|
|
|
# Optionally install any OEM packages
|
|
install_oem_package
|
|
|
|
# Changes done, glue it together
|
|
write_vm_disk
|
|
write_vm_conf "${FLAGS_mem}"
|
|
|
|
vm_cleanup
|
|
trap - EXIT
|
|
|
|
# Optionally upload all of our hard work
|
|
upload_image "${VM_GENERATED_FILES[@]}"
|
|
|
|
# Ready to set sail!
|
|
okboat
|
|
command_completed
|
|
print_readme
|