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

Unified Diff: make_factory_package.sh

Issue 6050006: Allow disk image target for copy machine. (Closed) Base URL: ssh://git@gitrw.chromium.org:9222/crosutils.git@master
Patch Set: . Created 10 years 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 | « lib/cros_image_common.sh ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: make_factory_package.sh
diff --git a/make_factory_package.sh b/make_factory_package.sh
index 0eb200e52a5141e27784bd2915cae7d487075570..71233fb09c4172007921878d4bde7ff9a7a76f25 100755
--- a/make_factory_package.sh
+++ b/make_factory_package.sh
@@ -34,6 +34,11 @@ DEFINE_string release "" \
"Directory and file containing release image: /path/chromiumos_image.bin"
DEFINE_string subfolder "" \
"If set, the name of the subfolder to put the payload items inside"
+DEFINE_string diskimg "" \
+ "If set, the name of the diskimage file to output"
+DEFINE_boolean preserve ${FLAGS_FALSE} \
+ "If set, reuse the diskimage file, if available"
+DEFINE_integer sectors 31277232 "Size of image in sectors"
# Parse command line
FLAGS "$@" || exit 1
@@ -80,6 +85,35 @@ FACTORY_DIR="$(dirname "${FLAGS_factory}")"
RELEASE_IMAGE="$(basename "${FLAGS_release}")"
FACTORY_IMAGE="$(basename "${FLAGS_factory}")"
+prepare_img() {
+ local outdev="$FLAGS_diskimg"
+ local sectors="$FLAGS_sectors"
+ local force_full="true"
+
+ # We'll need some code to put in the PMBR, for booting on legacy BIOS.
+ echo "Fetch PMBR"
+ local pmbrcode="$(mktemp -d)/gptmbr.bin"
+ sudo dd bs=512 count=1 if="${FLAGS_release}" of="${pmbrcode}" status=noxfer
+
+ echo "Prepare base disk image"
+ # Create an output file if requested, or if none exists.
+ if [ -b "${outdev}" ] ; then
+ echo "Using block device ${outdev}"
+ elif [ ! -e "${outdev}" -o \
+ "$(stat -c %s ${outdev})" != "$(( ${sectors} * 512 ))" -o \
+ "$FLAGS_preserve" = "$FLAGS_FALSE" ]; then
+ echo "Generating empty image file"
+ image_dump_partial_file /dev/zero 0 "${sectors}" |
+ dd of="${outdev}" bs=8M
+ else
+ echo "Reusing $outdev"
+ fi
+
+ # Create GPT partition table.
+ install_gpt "${outdev}" 0 0 "${pmbrcode}" 0 "${force_full}"
+ # Activate the correct partition.
+ cgpt add -i 2 -S 1 -P 1 "${outdev}"
+}
prepare_omaha() {
sudo rm -rf "${OMAHA_DATA_DIR}/rootfs-test.gz"
@@ -145,9 +179,6 @@ compress_and_hash_partition() {
fi
}
-# Clean up stale config and data files.
-prepare_omaha
-
# Decide if we should unpack partition
if image_has_part_tools; then
IMAGE_IS_UNPACKED=
@@ -159,103 +190,144 @@ else
IMAGE_IS_UNPACKED=1
fi
-# Get the release image.
-pushd "${RELEASE_DIR}" >/dev/null
-echo "Generating omaha release image from ${FLAGS_release}"
-echo "Generating omaha factory image from ${FLAGS_factory}"
-echo "Output omaha image to ${OMAHA_DATA_DIR}"
-echo "Output omaha config to ${OMAHA_CONF}"
+generate_img() {
+ local outdev="$FLAGS_diskimg"
+ local sectors="$FLAGS_sectors"
-prepare_dir
+ prepare_img
-if [ -n "${IMAGE_IS_UNPACKED}" ]; then
- echo "Unpacking image ${RELEASE_IMAGE} ..." >&2
- sudo ./unpack_partitions.sh "${RELEASE_IMAGE}" 2>/dev/null
-fi
+ # Get the release image.
+ pushd "${RELEASE_DIR}" >/dev/null
-release_hash="$(compress_and_hash_memento_image "${RELEASE_IMAGE}")"
-sudo chmod a+rw update.gz
-mv update.gz rootfs-release.gz
-mv rootfs-release.gz "${OMAHA_DATA_DIR}"
-echo "release: ${release_hash}"
+ echo "Release Kernel"
+ image_partition_copy "${RELEASE_IMAGE}" 2 "${outdev}" 4
-oem_hash="$(compress_and_hash_partition "${RELEASE_IMAGE}" 8 "oem.gz")"
-mv oem.gz "${OMAHA_DATA_DIR}"
-echo "oem: ${oem_hash}"
+ echo "Release Rootfs"
+ image_partition_copy "${RELEASE_IMAGE}" 3 "${outdev}" 5
-efi_hash="$(compress_and_hash_partition "${RELEASE_IMAGE}" 12 "efi.gz")"
-mv efi.gz "${OMAHA_DATA_DIR}"
-echo "efi: ${efi_hash}"
+ echo "OEM parition"
+ image_partition_copy "${RELEASE_IMAGE}" 8 "${outdev}" 8
-popd >/dev/null
+ popd >/dev/null
-# Go to retrieve the factory test image.
-pushd "${FACTORY_DIR}" >/dev/null
-prepare_dir
+ # Go to retrieve the factory test image.
+ pushd "${FACTORY_DIR}" >/dev/null
-if [ -n "${IMAGE_IS_UNPACKED}" ]; then
- echo "Unpacking image ${FACTORY_IMAGE} ..." >&2
- sudo ./unpack_partitions.sh "${FACTORY_IMAGE}" 2>/dev/null
-fi
+ echo "Factory Kernel"
+ image_partition_copy "${FACTORY_IMAGE}" 2 "${outdev}" 2
+ echo "Factory Rootfs"
+ image_partition_copy "${FACTORY_IMAGE}" 3 "${outdev}" 3
+ echo "Factory Stateful"
+ image_partition_copy "${FACTORY_IMAGE}" 1 "${outdev}" 1
+ echo "EFI Partition"
+ image_partition_copy "${FACTORY_IMAGE}" 12 "${outdev}" 12
-test_hash="$(compress_and_hash_memento_image "${FACTORY_IMAGE}")"
-sudo chmod a+rw update.gz
-mv update.gz rootfs-test.gz
-mv rootfs-test.gz "${OMAHA_DATA_DIR}"
-echo "test: ${test_hash}"
+ echo "Generated Image at $outdev."
+ echo "Done"
+}
-state_hash="$(compress_and_hash_partition "${FACTORY_IMAGE}" 1 "state.gz")"
-mv state.gz "${OMAHA_DATA_DIR}"
-echo "state: ${state_hash}"
+generate_omaha() {
+ # Clean up stale config and data files.
+ prepare_omaha
-popd >/dev/null
+ # Get the release image.
+ pushd "${RELEASE_DIR}" >/dev/null
+ echo "Generating omaha release image from ${FLAGS_release}"
+ echo "Generating omaha factory image from ${FLAGS_factory}"
+ echo "Output omaha image to ${OMAHA_DATA_DIR}"
+ echo "Output omaha config to ${OMAHA_CONF}"
-if [ -n "${FLAGS_firmware_updater}" ]; then
- SHELLBALL="${FLAGS_firmware_updater}"
- if [ ! -f "$SHELLBALL" ]; then
- echo "Failed to find firmware updater: $SHELLBALL."
- exit 1
+ prepare_dir
+
+ if [ -n "${IMAGE_IS_UNPACKED}" ]; then
+ echo "Unpacking image ${RELEASE_IMAGE} ..." >&2
+ sudo ./unpack_partitions.sh "${RELEASE_IMAGE}" 2>/dev/null
fi
- firmware_hash="$(compress_and_hash_file "$SHELLBALL" "firmware.gz")"
- mv firmware.gz "${OMAHA_DATA_DIR}"
- echo "firmware: ${firmware_hash}"
-fi
+ release_hash="$(compress_and_hash_memento_image "${RELEASE_IMAGE}")"
+ sudo chmod a+rw update.gz
+ mv update.gz rootfs-release.gz
+ mv rootfs-release.gz "${OMAHA_DATA_DIR}"
+ echo "release: ${release_hash}"
-# If the file does exist and we are using the subfolder flag we are going to
-# append another config.
-if [ -n "${FLAGS_subfolder}" ] &&
- [ -f "${OMAHA_CONF}" ]; then
- # Remove the ']' from the last line of the file so we can add another config.
- while [ -s "${OMAHA_CONF}" ]; do
- # If the last line is null
- if [ -z "$(tail -1 "${OMAHA_CONF}")" ]; then
- sed -i '$d' "${OMAHA_CONF}"
- elif [ "$(tail -1 "${OMAHA_CONF}")" != ']' ]; then
- sed -i '$d' "${OMAHA_CONF}"
- else
- break
+ oem_hash="$(compress_and_hash_partition "${RELEASE_IMAGE}" 8 "oem.gz")"
+ mv oem.gz "${OMAHA_DATA_DIR}"
+ echo "oem: ${oem_hash}"
+
+ popd >/dev/null
+
+ # Go to retrieve the factory test image.
+ pushd "${FACTORY_DIR}" >/dev/null
+ prepare_dir
+
+ if [ -n "${IMAGE_IS_UNPACKED}" ]; then
+ echo "Unpacking image ${FACTORY_IMAGE} ..." >&2
+ sudo ./unpack_partitions.sh "${FACTORY_IMAGE}" 2>/dev/null
+ fi
+
+ test_hash="$(compress_and_hash_memento_image "${FACTORY_IMAGE}")"
+ sudo chmod a+rw update.gz
+ mv update.gz rootfs-test.gz
+ mv rootfs-test.gz "${OMAHA_DATA_DIR}"
+ echo "test: ${test_hash}"
+
+ state_hash="$(compress_and_hash_partition "${FACTORY_IMAGE}" 1 "state.gz")"
+ mv state.gz "${OMAHA_DATA_DIR}"
+ echo "state: ${state_hash}"
+
+ efi_hash="$(compress_and_hash_partition "${FACTORY_IMAGE}" 12 "efi.gz")"
+ mv efi.gz "${OMAHA_DATA_DIR}"
+ echo "efi: ${efi_hash}"
+
+ popd >/dev/null
+
+ if [ -n "${FLAGS_firmware_updater}" ]; then
+ SHELLBALL="${FLAGS_firmware_updater}"
+ if [ ! -f "$SHELLBALL" ]; then
+ echo "Failed to find firmware updater: $SHELLBALL."
+ exit 1
fi
- done
- # Remove the last ]
- if [ "$(tail -1 "${OMAHA_CONF}")" = ']' ]; then
- sed -i '$d' "${OMAHA_CONF}"
+ firmware_hash="$(compress_and_hash_file "$SHELLBALL" "firmware.gz")"
+ mv firmware.gz "${OMAHA_DATA_DIR}"
+ echo "firmware: ${firmware_hash}"
fi
- # If the file is empty, create it from scratch
- if [ ! -s "${OMAHA_CONF}" ]; then
+ # If the file does exist and we are using the subfolder flag we are going to
+ # append another config.
+ if [ -n "${FLAGS_subfolder}" ] &&
+ [ -f "${OMAHA_CONF}" ]; then
+ # Remove the ']' from the last line of the file
+ # so we can add another config.
+ while [ -s "${OMAHA_CONF}" ]; do
+ # If the last line is null
+ if [ -z "$(tail -1 "${OMAHA_CONF}")" ]; then
+ sed -i '$d' "${OMAHA_CONF}"
+ elif [ "$(tail -1 "${OMAHA_CONF}")" != ']' ]; then
+ sed -i '$d' "${OMAHA_CONF}"
+ else
+ break
+ fi
+ done
+
+ # Remove the last ]
+ if [ "$(tail -1 "${OMAHA_CONF}")" = ']' ]; then
+ sed -i '$d' "${OMAHA_CONF}"
+ fi
+
+ # If the file is empty, create it from scratch
+ if [ ! -s "${OMAHA_CONF}" ]; then
+ echo "config = [" >"${OMAHA_CONF}"
+ fi
+ else
echo "config = [" >"${OMAHA_CONF}"
fi
-else
- echo "config = [" >"${OMAHA_CONF}"
-fi
-if [ -n "${FLAGS_subfolder}" ]; then
- subfolder="${FLAGS_subfolder}/"
-fi
+ if [ -n "${FLAGS_subfolder}" ]; then
+ subfolder="${FLAGS_subfolder}/"
+ fi
-echo -n "{
+ echo -n "{
'qual_ids': set([\"${FLAGS_board}\"]),
'factory_image': '${subfolder}rootfs-test.gz',
'factory_checksum': '${test_hash}',
@@ -268,20 +340,28 @@ echo -n "{
'stateimg_image': '${subfolder}state.gz',
'stateimg_checksum': '${state_hash}'," >>"${OMAHA_CONF}"
-if [ -n "${FLAGS_firmware_updater}" ] ; then
- echo -n "
+ if [ -n "${FLAGS_firmware_updater}" ] ; then
+ echo -n "
'firmware_image': '${subfolder}firmware.gz',
'firmware_checksum': '${firmware_hash}'," >>"${OMAHA_CONF}"
-fi
+ fi
-echo -n "
+ echo -n "
},
]
" >>"${OMAHA_CONF}"
-echo "The miniomaha server lives in src/platform/dev.
+ echo "The miniomaha server lives in src/platform/dev.
To validate the configutarion, run:
python2.6 devserver.py --factory_config miniomaha.conf \
--validate_factory_config
To run the server:
python2.6 devserver.py --factory_config miniomaha.conf"
+}
+
+# Main
+if [ -n "$FLAGS_diskimg" ]; then
+ generate_img
+else
+ generate_omaha
+fi
« no previous file with comments | « lib/cros_image_common.sh ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698