| 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 | 
|  |