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