mirror of
https://github.com/flatcar/scripts.git
synced 2025-08-09 14:06:58 +02:00
The problem here is that most were doing their exiting w/in a subshell; exit within a subshell kills the subshell, not the parent. Not all scripts were using set -e (which would pick up the failing subshell); as such just rewriting them to remove the potential via eliminateing the subshelling. Beyond that, removed a couple of custom (working, although non-standard) approaches, and removed a duplicate common.sh sourc'ing w/in mk_memento_images.sh TEST=force 'find_common_sh' to fail, note the scripts fails to exit BUG=none Change-Id: Ia1108a091a6399ad6aedd3cade4a107f4411686c Reviewed-on: http://gerrit.chromium.org/gerrit/3905 Reviewed-by: Brian Harring <ferringb@chromium.org> Tested-by: Brian Harring <ferringb@chromium.org>
211 lines
6.7 KiB
Bash
Executable File
211 lines
6.7 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.
|
|
|
|
# Helper script that mounts chromium os image from a device or directory
|
|
# and creates mount points for /var and /usr/local (if in dev_mode).
|
|
|
|
# --- BEGIN COMMON.SH BOILERPLATE ---
|
|
# Load common CrOS utilities. Inside the chroot this file is installed in
|
|
# /usr/lib/crosutils. Outside the chroot we find it relative to the script's
|
|
# location.
|
|
find_common_sh() {
|
|
local common_paths=(/usr/lib/crosutils $(dirname "$(readlink -f "$0")"))
|
|
local path
|
|
|
|
SCRIPT_ROOT=
|
|
for path in "${common_paths[@]}"; do
|
|
if [ -r "${path}/common.sh" ]; then
|
|
SCRIPT_ROOT=${path}
|
|
break
|
|
fi
|
|
done
|
|
}
|
|
|
|
find_common_sh
|
|
. "${SCRIPT_ROOT}/common.sh" || { echo "Unable to load common.sh"; exit 1; }
|
|
# --- END COMMON.SH BOILERPLATE ---
|
|
|
|
if [ $INSIDE_CHROOT -ne 1 ]; then
|
|
INSTALL_ROOT="$SRC_ROOT/platform/installer/"
|
|
else
|
|
INSTALL_ROOT=/usr/lib/installer/
|
|
fi
|
|
# Load functions and constants for chromeos-install
|
|
. "${INSTALL_ROOT}/chromeos-common.sh" || \
|
|
die "Unable to load ${INSTALL_ROOT}/chromeos-common.sh"
|
|
|
|
locate_gpt
|
|
|
|
get_default_board
|
|
|
|
# Flags.
|
|
DEFINE_string board "$DEFAULT_BOARD" \
|
|
"The board for which the image was built." b
|
|
DEFINE_boolean read_only $FLAGS_FALSE \
|
|
"Mount in read only mode -- skips stateful items."
|
|
DEFINE_boolean safe $FLAGS_FALSE \
|
|
"Mount rootfs in read only mode."
|
|
DEFINE_boolean unmount $FLAGS_FALSE \
|
|
"Unmount previously mounted dir." u
|
|
DEFINE_string from "/dev/sdc" \
|
|
"Directory, image, or device with image on it" f
|
|
DEFINE_string image "chromiumos_image.bin"\
|
|
"Name of the bin file if a directory is specified in the from flag" i
|
|
DEFINE_string "rootfs_mountpt" "/tmp/m" "Mount point for rootfs" "r"
|
|
DEFINE_string "stateful_mountpt" "/tmp/s" \
|
|
"Mount point for stateful partition" "s"
|
|
DEFINE_string "esp_mountpt" "" \
|
|
"Mount point for esp partition" "e"
|
|
DEFINE_boolean most_recent ${FLAGS_FALSE} "Use the most recent image dir" m
|
|
|
|
# Parse flags
|
|
FLAGS "$@" || exit 1
|
|
eval set -- "${FLAGS_ARGV}"
|
|
|
|
# Die on error
|
|
set -e
|
|
|
|
# Check for conflicting args.
|
|
# If --from is a block device, --image can't also be specified.
|
|
if [ -b "${FLAGS_from}" ]; then
|
|
if [ "${FLAGS_image}" != "chromiumos_image.bin" ]; then
|
|
die "-i ${FLAGS_image} can't be used with block device ${FLAGS_from}"
|
|
fi
|
|
fi
|
|
|
|
# Allow --from /foo/file.bin
|
|
if [ -f "${FLAGS_from}" ]; then
|
|
# If --from is specified as a file, --image cannot be also specified.
|
|
if [ "${FLAGS_image}" != "chromiumos_image.bin" ]; then
|
|
die "-i ${FLAGS_image} can't be used with --from file ${FLAGS_from}"
|
|
fi
|
|
pathname=$(dirname "${FLAGS_from}")
|
|
filename=$(basename "${FLAGS_from}")
|
|
FLAGS_image="${filename}"
|
|
FLAGS_from="${pathname}"
|
|
fi
|
|
|
|
# Common unmounts for either a device or directory
|
|
function unmount_image() {
|
|
echo "Unmounting image from ${FLAGS_stateful_mountpt}" \
|
|
"and ${FLAGS_rootfs_mountpt}"
|
|
# Don't die on error to force cleanup
|
|
set +e
|
|
# Reset symlinks in /usr/local.
|
|
if mount | egrep ".* ${FLAGS_stateful_mountpt} .*\(rw,"; then
|
|
setup_symlinks_on_root "/usr/local" "/var" \
|
|
"${FLAGS_stateful_mountpt}"
|
|
fix_broken_symlinks "${FLAGS_rootfs_mountpt}"
|
|
fi
|
|
sudo umount "${FLAGS_rootfs_mountpt}/usr/local"
|
|
sudo umount "${FLAGS_rootfs_mountpt}/var"
|
|
if [[ -n "${FLAGS_esp_mountpt}" ]]; then
|
|
sudo umount -d "${FLAGS_esp_mountpt}"
|
|
fi
|
|
sudo umount -d "${FLAGS_stateful_mountpt}"
|
|
sudo umount -d "${FLAGS_rootfs_mountpt}"
|
|
set -e
|
|
}
|
|
|
|
function get_usb_partitions() {
|
|
local ro_flag=""
|
|
local safe_flag=""
|
|
[ ${FLAGS_read_only} -eq ${FLAGS_TRUE} ] && ro_flag="-o ro"
|
|
[ ${FLAGS_read_only} -eq ${FLAGS_TRUE} -o \
|
|
${FLAGS_safe} -eq ${FLAGS_TRUE} ] && safe_flag="-o ro -t ext2"
|
|
|
|
sudo mount ${safe_flag} "${FLAGS_from}3" "${FLAGS_rootfs_mountpt}"
|
|
sudo mount ${ro_flag} "${FLAGS_from}1" "${FLAGS_stateful_mountpt}"
|
|
if [[ -n "${FLAGS_esp_mountpt}" ]]; then
|
|
sudo mount ${ro_flag} "${FLAGS_from}12" "${FLAGS_esp_mountpt}"
|
|
fi
|
|
}
|
|
|
|
function get_gpt_partitions() {
|
|
local filename="${FLAGS_image}"
|
|
|
|
# Mount the rootfs partition using a loopback device.
|
|
local offset=$(partoffset "${FLAGS_from}/${filename}" 3)
|
|
local ro_flag=""
|
|
local safe_flag=""
|
|
|
|
if [ ${FLAGS_read_only} -eq ${FLAGS_TRUE} ]; then
|
|
ro_flag="-o ro"
|
|
fi
|
|
|
|
if [ ${FLAGS_read_only} -eq ${FLAGS_TRUE} -o \
|
|
${FLAGS_safe} -eq ${FLAGS_TRUE} ]; then
|
|
safe_flag="-o ro -t ext2"
|
|
else
|
|
# Make sure any callers can actually mount and modify the fs
|
|
# if desired.
|
|
# cros_make_image_bootable should restore the bit if needed.
|
|
enable_rw_mount "${FLAGS_from}/${filename}" "$(( offset * 512 ))"
|
|
fi
|
|
|
|
sudo mount ${safe_flag} -o loop,offset=$(( offset * 512 )) \
|
|
"${FLAGS_from}/${filename}" "${FLAGS_rootfs_mountpt}"
|
|
|
|
# Mount the stateful partition using a loopback device.
|
|
offset=$(partoffset "${FLAGS_from}/${filename}" 1)
|
|
sudo mount ${ro_flag} -o loop,offset=$(( offset * 512 )) \
|
|
"${FLAGS_from}/${filename}" "${FLAGS_stateful_mountpt}"
|
|
|
|
# Mount the stateful partition using a loopback device.
|
|
if [[ -n "${FLAGS_esp_mountpt}" ]]; then
|
|
offset=$(partoffset "${FLAGS_from}/${filename}" 12)
|
|
sudo mount ${ro_flag} -o loop,offset=$(( offset * 512 )) \
|
|
"${FLAGS_from}/${filename}" "${FLAGS_esp_mountpt}"
|
|
fi
|
|
}
|
|
|
|
# Mount a gpt based image.
|
|
function mount_image() {
|
|
mkdir -p "${FLAGS_rootfs_mountpt}"
|
|
mkdir -p "${FLAGS_stateful_mountpt}"
|
|
if [[ -n "${FLAGS_esp_mountpt}" ]]; then
|
|
mkdir -p "${FLAGS_esp_mountpt}"
|
|
fi
|
|
|
|
# Get the partitions for the image / device.
|
|
if [ -b ${FLAGS_from} ] ; then
|
|
get_usb_partitions
|
|
else
|
|
get_gpt_partitions
|
|
fi
|
|
|
|
# Mount directories and setup symlinks.
|
|
sudo mount --bind "${FLAGS_stateful_mountpt}/var" \
|
|
"${FLAGS_rootfs_mountpt}/var"
|
|
sudo mount --bind "${FLAGS_stateful_mountpt}/dev_image" \
|
|
"${FLAGS_rootfs_mountpt}/usr/local"
|
|
# Setup symlinks in /usr/local so you can emerge packages into /usr/local.
|
|
|
|
if [ ${FLAGS_read_only} -eq ${FLAGS_FALSE} ]; then
|
|
setup_symlinks_on_root "${FLAGS_stateful_mountpt}/dev_image" \
|
|
"${FLAGS_stateful_mountpt}/var" "${FLAGS_stateful_mountpt}"
|
|
fi
|
|
echo "Image specified by ${FLAGS_from} mounted at"\
|
|
"${FLAGS_rootfs_mountpt} successfully."
|
|
}
|
|
|
|
# Find the last image built on the board.
|
|
if [ ${FLAGS_most_recent} -eq ${FLAGS_TRUE} ] ; then
|
|
FLAGS_from="$(./get_latest_image.sh --board="${FLAGS_board}")"
|
|
fi
|
|
|
|
# Turn paths into absolute paths.
|
|
FLAGS_from=`eval readlink -f ${FLAGS_from}`
|
|
FLAGS_rootfs_mountpt=`eval readlink -f ${FLAGS_rootfs_mountpt}`
|
|
FLAGS_stateful_mountpt=`eval readlink -f ${FLAGS_stateful_mountpt}`
|
|
|
|
# Perform desired operation.
|
|
if [ ${FLAGS_unmount} -eq ${FLAGS_TRUE} ] ; then
|
|
unmount_image
|
|
else
|
|
mount_image
|
|
fi
|