]> git.wh0rd.org - home.git/blame - .bin/cros-board
cros-board: update!
[home.git] / .bin / cros-board
CommitLineData
3c347239
MF
1#!/bin/bash
2. /etc/init.d/functions.sh || exit 1
3die() { eerror "$*"; exit 1; }
4set -e
5
39055191
MF
6BASE="/mnt/host/source"
7d="${BASE}/src/scripts"
8BUILD_DIR="${BASE}/src/build"
9cd "${BASE}/src/scripts/"
3c347239 10
fb105d3a 11: "${BOARD:="$(cat .default_board 2>/dev/null)"}"
3c347239
MF
12if [[ -z ${BOARD} ]] ; then
13 die "missing BOARD"
14fi
39055191 15IMAGES="${BASE}/src/build/images/${BOARD}"
3c347239
MF
16BUILD="/build/${BOARD}"
17
fb105d3a
MF
18usage() {
19 exec cat <<EOF
20Usage: cros-board [options]
21
22Build for the board listed in \${BOARD} (current: ${BOARD}).
23Normally only builds a dev image.
24
25Options:
26 -t Build test packages & image
27 --autotest Build & install autotest packages.
28 --factory Build factory packages & image.
29 --nousepkg Force build from source.
39055191 30 --vm Create VM image.
fb105d3a
MF
31
32 --clean ?
33
34 -Y Write image to ${ARG_DEV} w/out prompting.
35 -y <dev> Write image to <dev> w/out prompting.
36
37 -p Pretend -- show commands that would be run.
38 -v Verbose -- send command output to stdout.
39EOF
40}
41
dd5fec28
MF
42find_first_removable() {
43 local d
44 cd /sys/block
45 for d in sd? ; do
46 if [[ $(cat "${d}/removable" 2>/dev/null) == "1" ]]; then
47 echo "/dev/${d}"
48 return 0
49 fi
50 done
51 return 0
52}
53
3c347239 54ARG_CLEAN=false
dd5fec28 55ARG_DEV="$(find_first_removable)"
3c347239
MF
56ARG_DEV_USER=false
57ARG_PRETEND=false
58ARG_NOPKG=false
b04356b4 59ARG_AUTOTEST=false
c3634e71 60ARG_FACTORY=false
3c347239
MF
61ARG_VERBOSE=false
62ARG_TEST=false
39055191 63ARG_VM=false
3c347239
MF
64while [[ $# -ne 0 ]] ; do
65 case $1 in
66 --clean) ARG_CLEAN=true;;
67 -p) ARG_PRETEND=true;;
eecfe1d6 68 -Y) ARG_DEV_USER=true;;
3c347239
MF
69 -y) shift; ARG_DEV=$1; ARG_DEV_USER=true;;
70 -v) ARG_VERBOSE=true;;
71 -t) ARG_TEST=true;;
72 --nousepkg) ARG_NOPKG=true;;
b04356b4 73 --autotest) ARG_AUTOTEST=true;;
c3634e71 74 --factory) ARG_FACTORY=true;;
39055191 75 --vm) ARG_VM=true;;
fb105d3a 76 -h) usage;;
3c347239
MF
77 *) echo "unknown opt: $*"; exit 1;;
78 esac
79 shift
80done
81
82piperet() { set -- ${PIPESTATUS[@]/0}; [[ $# -eq 0 ]]; }
83run() {
84 set +e
3c347239 85 if ! ${ARG_PRETEND} ; then
00220d98 86 ebegin "$*"
3c347239
MF
87 local log="${IMAGES}"/log.${1##*/}
88 if ${ARG_VERBOSE} ; then
89 "$@" |& tee "${log}"
90 else
91 "$@" >& "${log}"
92 fi
93 piperet
00220d98
MF
94 eend $? || exit $?
95 else
d828d904 96 echo "$*"
3c347239 97 fi
3c347239
MF
98 set -e
99}
100
b04356b4 101tfe() { ($1 && echo $2 || echo $3); }
3c347239
MF
102
103mkdir -p "${IMAGES}"
104rm -f "${IMAGES}"/log.*
105
106einfo "Log root: ${IMAGES}/log."
107
5a4df9c9 108run ./update_chroot --toolchain_boards=${BOARD}
469b7be8 109
3c347239
MF
110if ${ARG_CLEAN} || [[ ! -d ${BUILD} ]] ; then
111 run sudo rm -rf "${BUILD}"
39055191 112 run setup_board --board=${BOARD} --skip-chroot-upgrade
ef381d05 113 if [[ $? -ne 0 ]] ; then
3c347239
MF
114 run sudo rm -rf "${BUILD}"
115 exit 1
116 fi
117fi
118
1061bc32
MF
119run ./build_packages \
120 --board=${BOARD} \
1061bc32 121 --nowithdebug \
d828d904 122 --nowithrevdeps \
39055191 123 --skip-chroot-upgrade \
ef381d05 124 --autosetgov \
b04356b4 125 $(tfe ${ARG_AUTOTEST} --{,no}withautotest) \
c3634e71 126 $(tfe ${ARG_FACTORY} --{,no}withfactory) \
b04356b4
MF
127 $(tfe ${ARG_NOPKG} --{no,}usepkg) \
128 $(tfe ${ARG_TEST} --{,no}withtest)
ef381d05 129BUILD_IMG="./build_image --board=${BOARD} --noenable_rootfs_verification $(tfe ${ARG_TEST} test base)"
3c347239
MF
130run ${BUILD_IMG}
131
f9163cb5 132IMG_TO_USB="cros flash --yes usb://${ARG_DEV} xbuddy://local/${BOARD}/latest/dev"
3c347239
MF
133if ${ARG_DEV_USER} ; then
134 run ${IMG_TO_USB}
135 sync &
136fi
137
39055191
MF
138IMG_TO_VM=( ${d}/image_to_vm.sh --board=${BOARD} --from=${BUILD_DIR}/images/${BOARD}/latest --test_image )
139if ${ARG_VM} ; then
140 run "${IMG_TO_VM[@]}"
141fi
142
42e1a176
MF
143cd "${IMAGES}"
144rm -rf $(ls -td1R `find -mindepth 1 -maxdepth 1 -type d` | sed -e 1d -e 2d)
145
1227e08d 146BUILD_IMG="${d}/${BUILD_IMG#./}"
3c347239
MF
147cat <<EOF
148
149### LIVE
150${IMG_TO_USB}
151
152### KVM
39055191 153${IMG_TO_VM[*]}
dd5fec28
MF
154~/chromiumos/chromite/bin/cros_vm --start --no-display --image-path=\${HOME}/chromiumos/src/build/images/${BOARD}/latest/chromiumos_qemu_image.bin
155#--kvm_cpu "max,vmx=on"
93639020
MF
156
157https://dev.chromium.org/chromium-os/testing/running-smoke-suite-on-a-vm-image
158
159/usr/local/autotest/bin/autologin.py
160
dd5fec28 161export CROS_USER_ID_HASH=\$(ls /home/user/)
93639020
MF
162sudo -u chronos CROS_USER_ID_HASH="${CROS_USER_ID_HASH}" crosh
163 vmc start termina # might run twice
3c347239
MF
164
165### RECOVERY
ebedbad3 166${d}/mod_image_for_recovery.sh --board=${BOARD}
91b5b449 167${IMG_TO_USB%/dev}/recovery
3c347239
MF
168
169### FACTORY
170${BUILD_IMG} --factory_install
171${IMG_TO_USB} -i factory_install_shim.bin
172
173EOF