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 |