Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | |
Taylor Hutt | 60da642 | 2011-06-02 13:54:43 -0700 | [diff] [blame] | 3 | # Copyright (c) 2009-2011 The Chromium OS Authors. All rights reserved. |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 4 | # Use of this source code is governed by a BSD-style license that can be |
| 5 | # found in the LICENSE file. |
| 6 | |
| 7 | # Script to update the kernel on a live running ChromiumOS instance. |
| 8 | |
Brian Harring | aa13ea4 | 2012-03-15 18:31:03 -0700 | [diff] [blame] | 9 | SCRIPT_ROOT=$(dirname $(readlink -f "$0")) |
David James | 359d3e1 | 2012-07-10 13:09:48 -0700 | [diff] [blame] | 10 | . "${SCRIPT_ROOT}/common.sh" || exit 1 |
| 11 | . "${SCRIPT_ROOT}/remote_access.sh" || exit 1 |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 12 | |
Mandeep Singh Baines | 2f3b5fc | 2011-01-14 14:20:12 -0800 | [diff] [blame] | 13 | # Script must be run inside the chroot. |
Greg Spencer | 798d75f | 2011-02-01 22:04:49 -0800 | [diff] [blame] | 14 | restart_in_chroot_if_needed "$@" |
Mandeep Singh Baines | 2f3b5fc | 2011-01-14 14:20:12 -0800 | [diff] [blame] | 15 | |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 16 | DEFINE_string board "" "Override board reported by target" |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 17 | DEFINE_string device "" "Override boot device reported by target" |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 18 | DEFINE_string partition "" "Override kernel partition reported by target" |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 19 | DEFINE_string arch "" "Override architecture reported by target" |
Olof Johansson | 8488f5a | 2011-04-20 17:27:37 -0700 | [diff] [blame] | 20 | DEFINE_boolean reboot $FLAGS_TRUE "Reboot system after update" |
Doug Anderson | 5a21b44 | 2012-12-07 11:47:31 -0800 | [diff] [blame] | 21 | DEFINE_boolean vboot $FLAGS_TRUE "Update the vboot kernel" |
Olof Johansson | 68cbfaf | 2013-04-23 14:06:28 -0700 | [diff] [blame] | 22 | DEFINE_boolean syslinux $FLAGS_TRUE "Update the syslinux kernel" |
Olof Johansson | 45225c9 | 2013-10-15 17:32:48 -0700 | [diff] [blame] | 23 | DEFINE_boolean bootonce $FLAGS_FALSE "Mark kernel partition as boot once" |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 24 | |
Mandeep Singh Baines | 2f3b5fc | 2011-01-14 14:20:12 -0800 | [diff] [blame] | 25 | # Parse command line. |
| 26 | FLAGS "$@" || exit 1 |
| 27 | eval set -- "${FLAGS_ARGV}" |
| 28 | |
| 29 | # Only now can we die on error. shflags functions leak non-zero error codes, |
Brian Harring | 7f175a5 | 2012-03-02 05:37:00 -0800 | [diff] [blame] | 30 | # so will die prematurely if 'switch_to_strict_mode' is specified before now. |
| 31 | switch_to_strict_mode |
Mandeep Singh Baines | 2f3b5fc | 2011-01-14 14:20:12 -0800 | [diff] [blame] | 32 | |
Mike Frysinger | 6b1abb2 | 2012-05-11 13:44:06 -0400 | [diff] [blame] | 33 | cleanup() { |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 34 | cleanup_remote_access |
| 35 | rm -rf "${TMP}" |
| 36 | } |
| 37 | |
Mike Frysinger | 6b1abb2 | 2012-05-11 13:44:06 -0400 | [diff] [blame] | 38 | learn_device() { |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 39 | [ -n "${FLAGS_device}" ] && return |
| 40 | remote_sh df /mnt/stateful_partition |
| 41 | FLAGS_device=$(echo "${REMOTE_OUT}" | awk '/dev/ {print $1}' | sed s/1\$//) |
| 42 | info "Target reports root device is ${FLAGS_device}" |
| 43 | } |
| 44 | |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 45 | # Ask the target what the kernel partition is |
Mike Frysinger | 6b1abb2 | 2012-05-11 13:44:06 -0400 | [diff] [blame] | 46 | learn_partition_and_ro() { |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 47 | [ -n "${FLAGS_partition}" ] && return |
Mandeep Singh Baines | e39579a | 2011-03-04 15:58:57 -0800 | [diff] [blame] | 48 | ! remote_sh rootdev |
Paul Taysom | a64d9db | 2012-09-21 13:30:43 -0700 | [diff] [blame] | 49 | if [ "${REMOTE_OUT%%-*}" == "/dev/dm" ]; then |
| 50 | remote_sh rootdev -s |
Olof Johansson | 8488f5a | 2011-04-20 17:27:37 -0700 | [diff] [blame] | 51 | REMOTE_VERITY=${FLAGS_TRUE} |
Doug Anderson | 2023fb8 | 2013-02-13 11:53:55 -0800 | [diff] [blame] | 52 | warn "System is using verity: not updating firmware/modules" |
Olof Johansson | 8488f5a | 2011-04-20 17:27:37 -0700 | [diff] [blame] | 53 | else |
| 54 | REMOTE_VERITY=${FLAGS_FALSE} |
| 55 | info "System is not using verity: updating firmware and modules" |
Mandeep Singh Baines | e39579a | 2011-03-04 15:58:57 -0800 | [diff] [blame] | 56 | fi |
| 57 | if [ "${REMOTE_OUT}" == "${FLAGS_device}3" ]; then |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 58 | FLAGS_partition="${FLAGS_device}2" |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 59 | else |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 60 | FLAGS_partition="${FLAGS_device}4" |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 61 | fi |
| 62 | if [ -z "${FLAGS_partition}" ]; then |
Doug Anderson | b2fe465 | 2012-12-07 17:33:56 -0800 | [diff] [blame] | 63 | die "Partition required" |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 64 | fi |
Doug Anderson | 5a21b44 | 2012-12-07 11:47:31 -0800 | [diff] [blame] | 65 | if [ ${REMOTE_VERITY} -eq ${FLAGS_TRUE} ]; then |
| 66 | info "Target reports kernel partition is ${FLAGS_partition}" |
| 67 | if [ ${FLAGS_vboot} -eq ${FLAGS_FALSE} ]; then |
| 68 | die "Must update vboot when target is using verity" |
| 69 | fi |
| 70 | fi |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 71 | } |
| 72 | |
Mike Frysinger | 6b1abb2 | 2012-05-11 13:44:06 -0400 | [diff] [blame] | 73 | make_kernelimage() { |
Tom Wai-Hong Tam | 6b50a07 | 2011-05-25 17:00:15 +0800 | [diff] [blame] | 74 | local bootloader_path |
| 75 | local kernel_image |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 76 | if [[ "${FLAGS_arch}" == "arm" ]]; then |
Taylor Hutt | 60da642 | 2011-06-02 13:54:43 -0700 | [diff] [blame] | 77 | name="bootloader.bin" |
| 78 | bootloader_path="${SRC_ROOT}/build/images/${FLAGS_board}/latest/${name}" |
Tom Wai-Hong Tam | 6b50a07 | 2011-05-25 17:00:15 +0800 | [diff] [blame] | 79 | kernel_image="/build/${FLAGS_board}/boot/vmlinux.uimg" |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 80 | else |
Tom Wai-Hong Tam | 6b50a07 | 2011-05-25 17:00:15 +0800 | [diff] [blame] | 81 | bootloader_path="/lib64/bootstub/bootstub.efi" |
| 82 | kernel_image="/build/${FLAGS_board}/boot/vmlinuz" |
| 83 | fi |
Kees Cook | 43a3213 | 2011-10-18 13:17:11 -0700 | [diff] [blame] | 84 | vbutil_kernel --pack $TMP/new_kern.bin \ |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 85 | --keyblock /usr/share/vboot/devkeys/kernel.keyblock \ |
| 86 | --signprivate /usr/share/vboot/devkeys/kernel_data_key.vbprivk \ |
| 87 | --version 1 \ |
Mandeep Singh Baines | 981555b | 2011-06-01 16:36:54 -0700 | [diff] [blame] | 88 | --config "${SRC_ROOT}/build/images/${FLAGS_board}/latest/config.txt" \ |
Tom Wai-Hong Tam | 6b50a07 | 2011-05-25 17:00:15 +0800 | [diff] [blame] | 89 | --bootloader "${bootloader_path}" \ |
| 90 | --vmlinuz "${kernel_image}" \ |
| 91 | --arch "${FLAGS_arch}" |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 92 | } |
| 93 | |
Mike Frysinger | 6b1abb2 | 2012-05-11 13:44:06 -0400 | [diff] [blame] | 94 | copy_kernelimage() { |
Doug Anderson | adf8a00 | 2012-12-17 11:40:34 -0800 | [diff] [blame] | 95 | remote_sh dd of="${FLAGS_partition}" bs=4K < "${TMP}/new_kern.bin" |
Olof Johansson | 8488f5a | 2011-04-20 17:27:37 -0700 | [diff] [blame] | 96 | } |
| 97 | |
Jonathan Kliegman | 775bc8e | 2012-08-14 12:30:49 -0400 | [diff] [blame] | 98 | check_kernelbuildtime() { |
| 99 | local version=$(readlink "/build/${FLAGS_board}/boot/vmlinuz" | cut -d- -f2-) |
| 100 | local build_dir="/build/${FLAGS_board}/lib/modules/${version}/build" |
| 101 | if [ "${build_dir}/Makefile" -nt "/build/${FLAGS_board}/boot/vmlinuz" ]; then |
| 102 | warn "Your build directory has been built more recently than" |
| 103 | warn "the installed kernel being updated to. Did you forget to" |
| 104 | warn "run 'cros_workon_make chromeos-kernel --install'?" |
| 105 | fi |
| 106 | } |
| 107 | |
Olof Johansson | 45225c9 | 2013-10-15 17:32:48 -0700 | [diff] [blame] | 108 | mark_boot_once() { |
| 109 | local idx=${FLAGS_partition##*[^0-9]} |
| 110 | remote_sh cgpt add -i ${idx} -S 0 -T 1 -P 15 ${FLAGS_device} |
| 111 | } |
| 112 | |
Olof Johansson | 68cbfaf | 2013-04-23 14:06:28 -0700 | [diff] [blame] | 113 | update_syslinux_kernel() { |
| 114 | # ARM does not have the syslinux directory, so skip it when the |
| 115 | # partition or the syslinux vmlinuz target is missing. |
| 116 | echo "updating syslinux kernel" |
| 117 | remote_sh grep $(echo ${FLAGS_device}12 | cut -d/ -f3) /proc/partitions |
| 118 | if [ $(echo "$REMOTE_OUT" | wc -l) -eq 1 ]; then |
| 119 | remote_sh mkdir -p /tmp/12 |
| 120 | remote_sh mount ${FLAGS_device}12 /tmp/12 |
| 121 | |
| 122 | if [ "$FLAGS_partition" = "${FLAGS_device}2" ]; then |
| 123 | target="/tmp/12/syslinux/vmlinuz.A" |
| 124 | else |
| 125 | target="/tmp/12/syslinux/vmlinuz.B" |
| 126 | fi |
| 127 | remote_sh "test ! -f $target || cp /boot/vmlinuz $target" |
| 128 | |
| 129 | remote_sh umount /tmp/12 |
| 130 | remote_sh rmdir /tmp/12 |
| 131 | fi |
| 132 | } |
| 133 | |
Mike Frysinger | 6b1abb2 | 2012-05-11 13:44:06 -0400 | [diff] [blame] | 134 | main() { |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 135 | trap cleanup EXIT |
| 136 | |
Kees Cook | 43a3213 | 2011-10-18 13:17:11 -0700 | [diff] [blame] | 137 | TMP=$(mktemp -d /tmp/update_kernel.XXXXXX) |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 138 | |
| 139 | remote_access_init |
| 140 | |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 141 | learn_arch |
| 142 | |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 143 | learn_board |
| 144 | |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 145 | learn_device |
| 146 | |
Olof Johansson | 8488f5a | 2011-04-20 17:27:37 -0700 | [diff] [blame] | 147 | learn_partition_and_ro |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 148 | |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 149 | remote_sh uname -r -v |
| 150 | |
| 151 | old_kernel="${REMOTE_OUT}" |
| 152 | |
Jonathan Kliegman | 775bc8e | 2012-08-14 12:30:49 -0400 | [diff] [blame] | 153 | check_kernelbuildtime |
| 154 | |
Doug Anderson | 5a21b44 | 2012-12-07 11:47:31 -0800 | [diff] [blame] | 155 | if [ ${FLAGS_vboot} -eq ${FLAGS_TRUE} ]; then |
| 156 | make_kernelimage |
| 157 | fi |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 158 | |
Olof Johansson | 8488f5a | 2011-04-20 17:27:37 -0700 | [diff] [blame] | 159 | if [[ ${REMOTE_VERITY} -eq ${FLAGS_FALSE} ]]; then |
Olof Johansson | 8488f5a | 2011-04-20 17:27:37 -0700 | [diff] [blame] | 160 | remote_sh mount -o remount,rw / |
Kees Cook | 7d7d2ef | 2011-10-18 13:12:12 -0700 | [diff] [blame] | 161 | echo "copying kernel" |
Doug Anderson | 48b5200 | 2012-12-07 12:40:07 -0800 | [diff] [blame] | 162 | remote_send_to /build/"${FLAGS_board}"/boot/ /boot/ |
Kees Cook | 7d7d2ef | 2011-10-18 13:12:12 -0700 | [diff] [blame] | 163 | |
Olof Johansson | 68cbfaf | 2013-04-23 14:06:28 -0700 | [diff] [blame] | 164 | if [ ${FLAGS_syslinux} -eq ${FLAGS_TRUE} ]; then |
| 165 | update_syslinux_kernel |
Kees Cook | 7d7d2ef | 2011-10-18 13:12:12 -0700 | [diff] [blame] | 166 | fi |
Olof Johansson | 9a83e4e | 2012-08-17 02:45:12 -0700 | [diff] [blame] | 167 | |
| 168 | echo "copying modules" |
Doug Anderson | 48b5200 | 2012-12-07 12:40:07 -0800 | [diff] [blame] | 169 | remote_send_to /build/"${FLAGS_board}"/lib/modules/ /lib/modules/ |
Olof Johansson | 9a83e4e | 2012-08-17 02:45:12 -0700 | [diff] [blame] | 170 | |
| 171 | echo "copying firmware" |
Doug Anderson | 48b5200 | 2012-12-07 12:40:07 -0800 | [diff] [blame] | 172 | remote_send_to /build/"${FLAGS_board}"/lib/firmware/ /lib/firmware/ |
Olof Johansson | 5a46bfb | 2010-12-22 12:14:21 -0800 | [diff] [blame] | 173 | fi |
| 174 | |
Doug Anderson | 5a21b44 | 2012-12-07 11:47:31 -0800 | [diff] [blame] | 175 | if [ ${FLAGS_vboot} -eq ${FLAGS_TRUE} ]; then |
| 176 | info "Copying vboot kernel image" |
| 177 | copy_kernelimage |
| 178 | else |
| 179 | info "Skipping update of vboot (per request)" |
| 180 | fi |
Olof Johansson | 8488f5a | 2011-04-20 17:27:37 -0700 | [diff] [blame] | 181 | |
Olof Johansson | 45225c9 | 2013-10-15 17:32:48 -0700 | [diff] [blame] | 182 | if [ ${FLAGS_bootonce} -eq ${FLAGS_TRUE} ]; then |
| 183 | info "Marking kernel partition ${FLAGS_partition} as boot once" |
| 184 | mark_boot_once |
| 185 | fi |
| 186 | |
Jonathan Kliegman | d6f3d07 | 2012-07-12 12:45:33 -0400 | [diff] [blame] | 187 | # An early kernel panic can prevent the normal sync on reboot. Explicitly |
| 188 | # sync for safety to avoid random file system corruption. |
| 189 | remote_sh sync |
| 190 | |
Doug Anderson | b2fe465 | 2012-12-07 17:33:56 -0800 | [diff] [blame] | 191 | if [ ${FLAGS_reboot} -eq ${FLAGS_TRUE} ]; then |
Olof Johansson | 8488f5a | 2011-04-20 17:27:37 -0700 | [diff] [blame] | 192 | remote_reboot |
| 193 | |
| 194 | remote_sh uname -r -v |
| 195 | info "old kernel: ${old_kernel}" |
| 196 | info "new kernel: ${REMOTE_OUT}" |
| 197 | else |
| 198 | info "Not rebooting (per request)" |
| 199 | fi |
Mandeep Singh Baines | a63cd2d | 2010-12-02 11:58:26 -0800 | [diff] [blame] | 200 | } |
| 201 | |
Olof Johansson | f53fa0d | 2011-01-26 13:06:46 -0800 | [diff] [blame] | 202 | main "$@" |