]> git.wh0rd.org - home.git/blame - .bin/cros-board
gitignore: 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
32f7de6c 6cd "${HOME}/trunk/src/scripts/"
3c347239 7
32f7de6c 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
15ARG_CLEAN=false
2834209e 16ARG_DEV="/dev/sdc"
3c347239
MF
17ARG_DEV_USER=false
18ARG_PRETEND=false
19ARG_NOPKG=false
b04356b4 20ARG_AUTOTEST=false
c3634e71 21ARG_FACTORY=false
3c347239
MF
22ARG_VERBOSE=false
23ARG_TEST=false
24while [[ $# -ne 0 ]] ; do
25 case $1 in
26 --clean) ARG_CLEAN=true;;
27 -p) ARG_PRETEND=true;;
eecfe1d6 28 -Y) ARG_DEV_USER=true;;
3c347239
MF
29 -y) shift; ARG_DEV=$1; ARG_DEV_USER=true;;
30 -v) ARG_VERBOSE=true;;
31 -t) ARG_TEST=true;;
32 --nousepkg) ARG_NOPKG=true;;
b04356b4 33 --autotest) ARG_AUTOTEST=true;;
c3634e71 34 --factory) ARG_FACTORY=true;;
054f8b67 35 -h) exec sed -n '/^while/,/^done/p' "$0";;
3c347239
MF
36 *) echo "unknown opt: $*"; exit 1;;
37 esac
38 shift
39done
40
41piperet() { set -- ${PIPESTATUS[@]/0}; [[ $# -eq 0 ]]; }
42run() {
43 set +e
3c347239 44 if ! ${ARG_PRETEND} ; then
00220d98 45 ebegin "$*"
3c347239
MF
46 local log="${IMAGES}"/log.${1##*/}
47 if ${ARG_VERBOSE} ; then
48 "$@" |& tee "${log}"
49 else
50 "$@" >& "${log}"
51 fi
52 piperet
00220d98
MF
53 eend $? || exit $?
54 else
55 einfo "$*"
3c347239 56 fi
3c347239
MF
57 set -e
58}
59
b04356b4 60tfe() { ($1 && echo $2 || echo $3); }
3c347239
MF
61
62mkdir -p "${IMAGES}"
63rm -f "${IMAGES}"/log.*
64
65einfo "Log root: ${IMAGES}/log."
66
5a4df9c9 67run ./update_chroot --toolchain_boards=${BOARD}
469b7be8 68
3c347239
MF
69if ${ARG_CLEAN} || [[ ! -d ${BUILD} ]] ; then
70 run sudo rm -rf "${BUILD}"
469b7be8 71 run ./setup_board --board=${BOARD} --skip_chroot_upgrade
3c347239
MF
72 if [ $? -ne 0 ] ; then
73 run sudo rm -rf "${BUILD}"
74 exit 1
75 fi
76fi
77
1061bc32
MF
78run ./build_packages \
79 --board=${BOARD} \
1061bc32 80 --nowithdebug \
469b7be8 81 --skip_chroot_upgrade \
b04356b4 82 $(tfe ${ARG_AUTOTEST} --{,no}withautotest) \
c3634e71 83 $(tfe ${ARG_FACTORY} --{,no}withfactory) \
b04356b4
MF
84 $(tfe ${ARG_NOPKG} --{no,}usepkg) \
85 $(tfe ${ARG_TEST} --{,no}withtest)
054f8b67 86BUILD_IMG="./build_image --board=${BOARD} --noenable_rootfs_verification $(tfe ${ARG_TEST} test) dev"
3c347239
MF
87run ${BUILD_IMG}
88
f9163cb5 89IMG_TO_USB="cros flash --yes usb://${ARG_DEV} xbuddy://local/${BOARD}/latest/dev"
3c347239
MF
90if ${ARG_DEV_USER} ; then
91 run ${IMG_TO_USB}
92 sync &
93fi
94
42e1a176
MF
95cd "${IMAGES}"
96rm -rf $(ls -td1R `find -mindepth 1 -maxdepth 1 -type d` | sed -e 1d -e 2d)
97
ebedbad3 98d="~/trunk/src/scripts"
1227e08d 99BUILD_IMG="${d}/${BUILD_IMG#./}"
3c347239
MF
100cat <<EOF
101
102### LIVE
103${IMG_TO_USB}
104
105### KVM
ebedbad3 106${d}/image_to_vm.sh --board=${BOARD} --from=../build/images/${BOARD}/latest
1227e08d 107${d}/image_to_vm.sh --board=${BOARD} --from=../build/images/${BOARD}/latest --test_image
552378f7 108~/chromiumos/src/scripts/bin/cros_start_vm --no_graphics --image_path=\${HOME}/chromiumos/src/build/images/${BOARD}/latest/chromiumos_qemu_image.bin
3c347239
MF
109kvm -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
110
111### RECOVERY
ebedbad3 112${d}/mod_image_for_recovery.sh --board=${BOARD}
3c347239
MF
113${IMG_TO_USB} --image_name=recovery_image.bin
114
115### FACTORY
116${BUILD_IMG} --factory_install
117${IMG_TO_USB} -i factory_install_shim.bin
118
119EOF