Index: bin/cros_update_bootloaders.sh |
diff --git a/bin/cros_update_bootloaders.sh b/bin/cros_update_bootloaders.sh |
deleted file mode 100755 |
index 0067f9a406e94e28bc7ddc6b538c507843e4b4dd..0000000000000000000000000000000000000000 |
--- a/bin/cros_update_bootloaders.sh |
+++ /dev/null |
@@ -1,217 +0,0 @@ |
-#!/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 generates the legacy/efi bootloader partitions. |
-# It does not populate the templates, but can update a loop device. |
- |
-. "/usr/lib/crosutils/common.sh" |
-. "/usr/lib/installer/chromeos-common.sh" # installer |
- |
-get_default_board |
- |
-# Flags. |
-DEFINE_string arch "x86" \ |
- "The boot architecture: arm or x86. (Default: x86)" |
-# TODO(wad) once extlinux is dead, we can remove this. |
-DEFINE_boolean install_syslinux ${FLAGS_FALSE} \ |
- "Controls whether syslinux is run on 'to'. (Default: false)" |
-DEFINE_string from "/tmp/boot" \ |
- "Path the legacy bootloader templates are copied from. (Default /tmp/boot)" |
-DEFINE_string to "/tmp/esp.img" \ |
- "Path to esp image or ARM output MBR (Default: /tmp/esp.img)" |
-DEFINE_integer to_offset 0 \ |
- "Offset in bytes into 'to' if it is a file (Default: 0)" |
-DEFINE_integer to_size -1 \ |
- "Size in bytes of 'to' to use if it is a file. -1 is ignored. (Default: -1)" |
-DEFINE_string vmlinuz "/tmp/vmlinuz" \ |
- "Path to the vmlinuz file to use (Default: /tmp/vmlinuz)" |
-# The kernel_partition and the kernel_cmdline each are used to supply |
-# verified boot configuration: dm="". |
-DEFINE_string kernel_partition "/tmp/vmlinuz.image" \ |
- "Path to the signed kernel image. (Default: /tmp/vmlinuz.image)" |
-DEFINE_string kernel_cmdline "" \ |
- "Kernel commandline if no kernel_partition given. (Default: '')" |
-DEFINE_string kernel_partition_offset "0" \ |
- "Offset to the kernel partition [KERN-A] (Default: 0)" |
-DEFINE_string kernel_partition_sectors "0" \ |
- "Kernel partition sectors (Default: 0)" |
-DEFINE_string usb_disk /dev/sdb3 \ |
- "Path syslinux should use to do a usb (or arm!) boot. Default: /dev/sdb3" |
- |
-# Parse flags |
-FLAGS "$@" || exit 1 |
-eval set -- "${FLAGS_ARGV}" |
-set -e |
- |
-# If not provided by chromeos-common.sh, this will update all of the |
-# boot loader files (both A and B) with the data pulled |
-# from the kernel_partition. The default boot target should |
-# be set when the rootfs is stuffed. |
-if ! type -p update_x86_bootloaders; then |
- update_x86_bootloaders() { |
- local old_root="$1" # e.g., sd%D%P |
- local kernel_cmdline="$2" |
- local esp_fs_dir="$3" |
- local template_dir="$4" |
- |
- # Pull out the dm="" values |
- dm_table= |
- if echo "$kernel_cmdline" | grep -q 'dm="'; then |
- dm_table=$(echo "$kernel_cmdline" | sed -s 's/.*dm="\([^"]*\)".*/\1/') |
- fi |
- |
- # Rewrite grub table |
- grub_dm_table_a=${dm_table//${old_root}/\$linuxpartA} |
- grub_dm_table_b=${dm_table//${old_root}/\$linuxpartB} |
- sed -e "s|DMTABLEA|${grub_dm_table_a}|g" \ |
- -e "s|DMTABLEB|${grub_dm_table_b}|g" \ |
- "${template_dir}"/efi/boot/grub.cfg | |
- sudo dd of="${esp_fs_dir}"/efi/boot/grub.cfg |
- |
- # Rewrite syslinux DM_TABLE |
- syslinux_dm_table_usb=${dm_table//\/dev\/${old_root}/${FLAGS_usb_disk}} |
- sed -e "s|DMTABLEA|${syslinux_dm_table_usb}|g" \ |
- "${template_dir}"/syslinux/usb.A.cfg | |
- sudo dd of="${esp_fs_dir}"/syslinux/usb.A.cfg |
- |
- syslinux_dm_table_a=${dm_table//\/dev\/${old_root}/HDROOTA} |
- sed -e "s|DMTABLEA|${syslinux_dm_table_a}|g" \ |
- "${template_dir}"/syslinux/root.A.cfg | |
- sudo dd of="${esp_fs_dir}"/syslinux/root.A.cfg |
- |
- syslinux_dm_table_b=${dm_table//\/dev\/${old_root}/HDROOTB} |
- sed -e "s|DMTABLEB|${syslinux_dm_table_b}|g" \ |
- "${template_dir}"/syslinux/root.B.cfg | |
- sudo dd of="${esp_fs_dir}"/syslinux/root.B.cfg |
- |
- # Copy the vmlinuz's into place for syslinux |
- sudo cp -f "${template_dir}"/vmlinuz "${esp_fs_dir}"/syslinux/vmlinuz.A |
- sudo cp -f "${template_dir}"/vmlinuz "${esp_fs_dir}"/syslinux/vmlinuz.B |
- |
- # The only work left for the installer is to pick the correct defaults |
- # and replace HDROOTA and HDROOTB with the correct /dev/sd%D%P. |
- } |
-fi |
- |
-ESP_DEV= |
-if [[ ! -e "${FLAGS_to}" ]]; then |
- error "The ESP doesn't exist" |
- # This shouldn't happen. |
- info "Creating a new esp image at ${FLAGS_to}" anyway. |
- # Create EFI System Partition to boot stock EFI BIOS (but not ChromeOS EFI |
- # BIOS). We only need this for x86, but it's simpler and safer to keep the |
- # disk images the same for both x86 and ARM. |
- # NOTE: The size argument for mkfs.vfat is in 1024-byte blocks. |
- # We'll hard-code it to 16M for now. |
- ESP_BLOCKS=16384 |
- /usr/sbin/mkfs.vfat -C "${FLAGS_to}" ${ESP_BLOCKS} |
- ESP_DEV=$(sudo losetup -f) |
- if [ -z "${ESP_DEV}" ]; then |
- die "No free loop devices." |
- fi |
- sudo losetup "${ESP_DEV}" "${FLAGS_to}" |
-else |
- if [[ -f "${FLAGS_to}" ]]; then |
- ESP_DEV=$(sudo losetup -f) |
- if [ -z "${ESP_DEV}" ]; then |
- die "No free loop devices." |
- fi |
- |
- esp_offset="--offset ${FLAGS_to_offset}" |
- esp_size="--sizelimit ${FLAGS_to_size}" |
- if [ ${FLAGS_to_size} -lt 0 ]; then |
- esp_size= |
- fi |
- sudo losetup ${esp_offset} ${esp_size} "${ESP_DEV}" "${FLAGS_to}" |
- else |
- # If it is a block device or something else, try to mount it anyway. |
- ESP_DEV="${FLAGS_to}" |
- fi |
-fi |
- |
-ESP_FS_DIR=$(mktemp -d /tmp/esp.XXXXXX) |
-cleanup() { |
- set +e |
- sudo umount "${ESP_FS_DIR}" |
- if [[ -n "${ESP_DEV}" && -z "${ESP_DEV//\/dev\/loop*}" ]]; then |
- sudo losetup -d "${ESP_DEV}" |
- fi |
- rm -rf "${ESP_FS_DIR}" |
-} |
-trap cleanup EXIT |
-sudo mount "${ESP_DEV}" "${ESP_FS_DIR}" |
- |
-if [[ "${FLAGS_arch}" = "x86" ]]; then |
- # Populate the EFI bootloader configuration |
- sudo mkdir -p "${ESP_FS_DIR}/efi/boot" |
- sudo cp "${FLAGS_from}"/efi/boot/bootx64.efi \ |
- "${ESP_FS_DIR}/efi/boot/bootx64.efi" |
- sudo cp "${FLAGS_from}/efi/boot/grub.cfg" \ |
- "${ESP_FS_DIR}/efi/boot/grub.cfg" |
- |
- # Prepopulate the syslinux directories too and update for verified boot values |
- # after the rootfs work is done. |
- sudo mkdir -p "${ESP_FS_DIR}"/syslinux |
- sudo cp -r "${FLAGS_from}"/syslinux/. "${ESP_FS_DIR}"/syslinux |
- |
- # Stage both kernels with the only one we built. |
- sudo cp -f "${FLAGS_vmlinuz}" "${ESP_FS_DIR}"/syslinux/vmlinuz.A |
- sudo cp -f "${FLAGS_vmlinuz}" "${ESP_FS_DIR}"/syslinux/vmlinuz.B |
- |
- # Extract kernel flags |
- kernel_cfg= |
- old_root="sd%D%P" |
- if [[ -n "${FLAGS_kernel_cmdline}" ]]; then |
- info "Using supplied kernel_cmdline to update templates." |
- kernel_cfg="${FLAGS_kernel_cmdline}" |
- elif [[ -n "${FLAGS_kernel_partition}" ]]; then |
- info "Extracting the kernel command line from ${FLAGS_kernel_partition}" |
- kernel_cfg=$(dump_kernel_config "${FLAGS_kernel_partition}") |
- fi |
- update_x86_bootloaders "${old_root}" \ |
- "${kernel_cfg}" \ |
- "${ESP_FS_DIR}" \ |
- "${FLAGS_from}" |
- |
- # Install the syslinux loader on the ESP image (part 12) so it is ready when |
- # we cut over from rootfs booting (extlinux). |
- if [[ ${FLAGS_install_syslinux} -eq ${FLAGS_TRUE} ]]; then |
- sudo umount "${ESP_FS_DIR}" |
- sudo syslinux -d /syslinux "${ESP_DEV}" |
- fi |
-elif [[ "${FLAGS_arch}" = "arm" ]]; then |
- # Extract kernel flags |
- kernel_cfg= |
- old_root="sd%D%P" |
- if [[ -n "${FLAGS_kernel_cmdline}" ]]; then |
- info "Using supplied kernel_cmdline to update templates." |
- kernel_cfg="${FLAGS_kernel_cmdline}" |
- elif [[ -n "${FLAGS_kernel_partition}" ]]; then |
- info "Extracting the kernel command line from ${FLAGS_kernel_partition}" |
- kernel_cfg=$(dump_kernel_config "${kernel_partition}") |
- fi |
- dm_table= |
- if echo "$kernel_cfg" | grep -q 'dm="'; then |
- dm_table=$(echo "$kernel_cfg" | sed -s 's/.*dm="\([^"]*\)".*/\1/') |
- fi |
- # TODO(wad) assume usb_disk contains the arm boot location for now. |
- new_root="${FLAGS_usb_disk}" |
- info "Replacing dm slave devices with /dev/${new_root}" |
- dm_table="${dm_table//ROOT_DEV/\/dev\/${new_root}}" |
- dm_table="${dm_table//HASH_DEV/\/dev\/${new_root}}" |
- |
- warn "FIXME: cannot replace root= here for the arm bootloader yet." |
- dm_table="" # TODO(wad) Clear it until we can fix root=/dev/dm-0 |
- |
- # Copy u-boot script to ESP partition |
- if [ -r "${FLAGS_from}/boot-A.scr.uimg" ]; then |
- sudo mkdir -p "${ESP_FS_DIR}/u-boot" |
- sudo cp "${FLAGS_from}/boot-A.scr.uimg" \ |
- "${ESP_FS_DIR}/u-boot/boot.scr.uimg" |
- fi |
-fi |
- |
-set +e |