Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(536)

Unified Diff: src/scripts/mount_gpt_image.sh

Issue 2064001: Move to using chromeos-test to emerge test dependencies in mod_image_for_test. (Closed) Base URL: ssh://git@chromiumos-git//chromeos
Patch Set: Last upload Created 10 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/scripts/mod_image_for_test.sh ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/scripts/mount_gpt_image.sh
diff --git a/src/scripts/mount_gpt_image.sh b/src/scripts/mount_gpt_image.sh
index 7d59ef4496a01b3e4f54361bf2a17a6d370174f0..a739675d4965933f9c10bf4395c3afb702d7b846 100755
--- a/src/scripts/mount_gpt_image.sh
+++ b/src/scripts/mount_gpt_image.sh
@@ -9,6 +9,9 @@
. "$(dirname "$0")/common.sh"
+# For functions related to gpt images.
+. "$(dirname "$0")/chromeos-common.sh"
+
get_default_board
# Flags.
@@ -18,7 +21,8 @@ DEFINE_boolean unmount $FLAGS_FALSE \
"Unmount previously mounted dir." u
DEFINE_string from "/dev/sdc" \
"Directory containing image or device with image on it" f
-DEFINE_boolean test $FLAGS_FALSE "Use chromiumos_test_image.bin" t
+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"
@@ -31,13 +35,16 @@ eval set -- "${FLAGS_ARGV}"
# Die on error
set -e
-# Common umounts for either a device or directory
-function unmount_common() {
+# 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
if [ -e "${FLAGS_rootfs_mountpt}/root/.dev_mode" ] ; then
+ # Reset symlinks in /usr/local.
+ setup_symlinks_on_root "/usr/local" "/var" \
+ "${FLAGS_stateful_mountpt}"
sudo umount "${FLAGS_rootfs_mountpt}/usr/local"
fi
sudo umount "${FLAGS_rootfs_mountpt}/var"
@@ -46,55 +53,63 @@ function unmount_common() {
set -e
}
-# Sets up the rootfs and stateful partitions specified by
-# ${FLAGS_from}${prefix}[31] to the given mount points and sets up var and
-# usr/local
-# ${1} - prefix name for the partition
-# ${2} - extra mount options for the partitions
-function mount_common() {
+function get_usb_partitions() {
+ sudo mount "${FLAGS_from}3" "${FLAGS_rootfs_mountpt}"
+ sudo mount "${FLAGS_from}1" "${FLAGS_stateful_mountpt}"
+}
+
+function get_gpt_partitions() {
+ local filename="${FLAGS_image}"
+
+ # Mount the rootfs partition using a loopback device.
+ local offset=$(partoffset "${FLAGS_from}/${filename}" 3)
+ sudo mount -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 -o loop,offset=$(( offset * 512 )) "${FLAGS_from}/${filename}" \
+ "${FLAGS_stateful_mountpt}"
+}
+
+# Mount a gpt based image.
+function mount_image() {
mkdir -p "${FLAGS_rootfs_mountpt}"
mkdir -p "${FLAGS_stateful_mountpt}"
- sudo mount ${2} "${FLAGS_from}${1}3" "${FLAGS_rootfs_mountpt}"
- sudo mount ${2} "${FLAGS_from}${1}1" "${FLAGS_stateful_mountpt}"
+
+ # Get the partitions for the image / device.
+ if [ -b ${FLAGS_from} ] ; then
+ get_usb_partitions
+ else
+ get_gpt_partitions
+ fi
+
+ # Mount var unconditionally and then setup /usr/local for user of dev mode.
sudo mount --bind "${FLAGS_stateful_mountpt}/var" \
"${FLAGS_rootfs_mountpt}/var"
if [ -e "${FLAGS_rootfs_mountpt}/root/.dev_mode" ] ; then
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.
+ setup_symlinks_on_root "${FLAGS_stateful_mountpt}/dev_image" \
+ "${FLAGS_stateful_mountpt}/var" "${FLAGS_stateful_mountpt}"
fi
- echo "Root FS specified by "${FLAGS_from}${1}3" mounted at"\
+ echo "Image specified by ${FLAGS_from} mounted at"\
"${FLAGS_rootfs_mountpt} successfully."
}
-# Find the last image built on the board
+# Find the last image built on the board.
if [ ${FLAGS_most_recent} -eq ${FLAGS_TRUE} ] ; then
IMAGES_DIR="${DEFAULT_BUILD_ROOT}/images/${FLAGS_board}"
FLAGS_from="${IMAGES_DIR}/$(ls -t ${IMAGES_DIR} 2>&-| head -1)"
fi
-# Turn into absolute path
+# Turn path into an absolute path.
FLAGS_from=`eval readlink -f ${FLAGS_from}`
-# Set the file name of the image if ${FLAGS_from} is not a device and cd
-if [ -d "${FLAGS_from}" ] ; then
- cd "${FLAGS_from}"
- IMAGE_NAME=chromiumos_image.bin
- [ ${FLAGS_test} -eq ${FLAGS_TRUE} ] && IMAGE_NAME=chromiumos_test_image.bin
-fi
-
+# Perform desired operation.
if [ ${FLAGS_unmount} -eq ${FLAGS_TRUE} ] ; then
- unmount_common
- if [ -d "${FLAGS_from}" ] ; then
- echo "Re-packing partitions onto ${FLAGS_from}/${IMAGE_NAME}"
- ./pack_partitions.sh ${IMAGE_NAME} 2> /dev/null
- sudo rm part_*
- fi
+ unmount_image
else
- if [ -b ${FLAGS_from} ] ; then
- mount_common "" ""
- else
- echo "Unpacking partitions from ${FLAGS_from}/${IMAGE_NAME}"
- ./unpack_partitions.sh ${IMAGE_NAME} 2> /dev/null
- mount_common "/part_" "-o loop"
- fi
+ mount_image
fi
« no previous file with comments | « src/scripts/mod_image_for_test.sh ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698