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