]> git.wh0rd.org - home.git/blame - .bin/cros-board
cros-board: add arc++ details
[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
3c347239 38ARG_CLEAN=false
fb105d3a 39ARG_DEV="/dev/sdd"
3c347239
MF
40ARG_DEV_USER=false
41ARG_PRETEND=false
42ARG_NOPKG=false
b04356b4 43ARG_AUTOTEST=false
c3634e71 44ARG_FACTORY=false
3c347239
MF
45ARG_VERBOSE=false
46ARG_TEST=false
47while [[ $# -ne 0 ]] ; do
48 case $1 in
49 --clean) ARG_CLEAN=true;;
50 -p) ARG_PRETEND=true;;
eecfe1d6 51 -Y) ARG_DEV_USER=true;;
3c347239
MF
52 -y) shift; ARG_DEV=$1; ARG_DEV_USER=true;;
53 -v) ARG_VERBOSE=true;;
54 -t) ARG_TEST=true;;
55 --nousepkg) ARG_NOPKG=true;;
b04356b4 56 --autotest) ARG_AUTOTEST=true;;
c3634e71 57 --factory) ARG_FACTORY=true;;
fb105d3a 58 -h) usage;;
3c347239
MF
59 *) echo "unknown opt: $*"; exit 1;;
60 esac
61 shift
62done
63
64piperet() { set -- ${PIPESTATUS[@]/0}; [[ $# -eq 0 ]]; }
65run() {
66 set +e
3c347239 67 if ! ${ARG_PRETEND} ; then
00220d98 68 ebegin "$*"
3c347239
MF
69 local log="${IMAGES}"/log.${1##*/}
70 if ${ARG_VERBOSE} ; then
71 "$@" |& tee "${log}"
72 else
73 "$@" >& "${log}"
74 fi
75 piperet
00220d98
MF
76 eend $? || exit $?
77 else
d828d904 78 echo "$*"
3c347239 79 fi
3c347239
MF
80 set -e
81}
82
b04356b4 83tfe() { ($1 && echo $2 || echo $3); }
3c347239
MF
84
85mkdir -p "${IMAGES}"
86rm -f "${IMAGES}"/log.*
87
88einfo "Log root: ${IMAGES}/log."
89
5a4df9c9 90run ./update_chroot --toolchain_boards=${BOARD}
469b7be8 91
3c347239
MF
92if ${ARG_CLEAN} || [[ ! -d ${BUILD} ]] ; then
93 run sudo rm -rf "${BUILD}"
469b7be8 94 run ./setup_board --board=${BOARD} --skip_chroot_upgrade
3c347239
MF
95 if [ $? -ne 0 ] ; then
96 run sudo rm -rf "${BUILD}"
97 exit 1
98 fi
99fi
100
1061bc32
MF
101run ./build_packages \
102 --board=${BOARD} \
1061bc32 103 --nowithdebug \
d828d904 104 --nowithrevdeps \
469b7be8 105 --skip_chroot_upgrade \
b04356b4 106 $(tfe ${ARG_AUTOTEST} --{,no}withautotest) \
c3634e71 107 $(tfe ${ARG_FACTORY} --{,no}withfactory) \
b04356b4
MF
108 $(tfe ${ARG_NOPKG} --{no,}usepkg) \
109 $(tfe ${ARG_TEST} --{,no}withtest)
054f8b67 110BUILD_IMG="./build_image --board=${BOARD} --noenable_rootfs_verification $(tfe ${ARG_TEST} test) dev"
3c347239
MF
111run ${BUILD_IMG}
112
f9163cb5 113IMG_TO_USB="cros flash --yes usb://${ARG_DEV} xbuddy://local/${BOARD}/latest/dev"
3c347239
MF
114if ${ARG_DEV_USER} ; then
115 run ${IMG_TO_USB}
116 sync &
117fi
118
42e1a176
MF
119cd "${IMAGES}"
120rm -rf $(ls -td1R `find -mindepth 1 -maxdepth 1 -type d` | sed -e 1d -e 2d)
121
ebedbad3 122d="~/trunk/src/scripts"
1227e08d 123BUILD_IMG="${d}/${BUILD_IMG#./}"
3c347239
MF
124cat <<EOF
125
126### LIVE
127${IMG_TO_USB}
128
129### KVM
ebedbad3 130${d}/image_to_vm.sh --board=${BOARD} --from=../build/images/${BOARD}/latest
1227e08d 131${d}/image_to_vm.sh --board=${BOARD} --from=../build/images/${BOARD}/latest --test_image
93639020
MF
132~/chromiumos/src/scripts/bin/cros_start_vm --no_graphics --image_path=\${HOME}/chromiumos/src/build/images/${BOARD}/latest/chromiumos_qemu_image.bin --kvm_cpu "max,vmx=on"
133qemu-system-x86_64 -enable-kvm -cpu max,vmx=on -m 1024 -vga std -net nic,model=virtio -net user,hostfwd=tcp::9222-:22 -hda ~/chromiumos/src/build/images/${BOARD}/latest/chromiumos_qemu_image.bin
134
135https://dev.chromium.org/chromium-os/testing/running-smoke-suite-on-a-vm-image
136
137/usr/local/autotest/bin/autologin.py
138
139export CROS_USER_ID_HASH=$(ls /home/user/)
140sudo -u chronos CROS_USER_ID_HASH="${CROS_USER_ID_HASH}" crosh
141 vmc start termina # might run twice
3c347239
MF
142
143### RECOVERY
ebedbad3 144${d}/mod_image_for_recovery.sh --board=${BOARD}
91b5b449 145${IMG_TO_USB%/dev}/recovery
3c347239
MF
146
147### FACTORY
148${BUILD_IMG} --factory_install
149${IMG_TO_USB} -i factory_install_shim.bin
150
151EOF