]>
Commit | Line | Data |
---|---|---|
3c347239 MF |
1 | #!/bin/bash |
2 | . /etc/init.d/functions.sh || exit 1 | |
3 | die() { eerror "$*"; exit 1; } | |
4 | set -e | |
5 | ||
32f7de6c | 6 | cd "${HOME}/trunk/src/scripts/" |
3c347239 | 7 | |
fb105d3a | 8 | : "${BOARD:="$(cat .default_board 2>/dev/null)"}" |
3c347239 MF |
9 | if [[ -z ${BOARD} ]] ; then |
10 | die "missing BOARD" | |
11 | fi | |
12 | IMAGES="${HOME}/trunk/src/build/images/${BOARD}" | |
13 | BUILD="/build/${BOARD}" | |
14 | ||
fb105d3a MF |
15 | usage() { |
16 | exec cat <<EOF | |
17 | Usage: cros-board [options] | |
18 | ||
19 | Build for the board listed in \${BOARD} (current: ${BOARD}). | |
20 | Normally only builds a dev image. | |
21 | ||
22 | Options: | |
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. | |
35 | EOF | |
36 | } | |
37 | ||
dd5fec28 MF |
38 | find_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 | 50 | ARG_CLEAN=false |
dd5fec28 | 51 | ARG_DEV="$(find_first_removable)" |
3c347239 MF |
52 | ARG_DEV_USER=false |
53 | ARG_PRETEND=false | |
54 | ARG_NOPKG=false | |
b04356b4 | 55 | ARG_AUTOTEST=false |
c3634e71 | 56 | ARG_FACTORY=false |
3c347239 MF |
57 | ARG_VERBOSE=false |
58 | ARG_TEST=false | |
59 | while [[ $# -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 | |
74 | done | |
75 | ||
76 | piperet() { set -- ${PIPESTATUS[@]/0}; [[ $# -eq 0 ]]; } | |
77 | run() { | |
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 | 95 | tfe() { ($1 && echo $2 || echo $3); } |
3c347239 MF |
96 | |
97 | mkdir -p "${IMAGES}" | |
98 | rm -f "${IMAGES}"/log.* | |
99 | ||
100 | einfo "Log root: ${IMAGES}/log." | |
101 | ||
5a4df9c9 | 102 | run ./update_chroot --toolchain_boards=${BOARD} |
469b7be8 | 103 | |
3c347239 MF |
104 | if ${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 | |
111 | fi | |
112 | ||
1061bc32 MF |
113 | run ./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 | 122 | BUILD_IMG="./build_image --board=${BOARD} --noenable_rootfs_verification $(tfe ${ARG_TEST} test) dev" |
3c347239 MF |
123 | run ${BUILD_IMG} |
124 | ||
f9163cb5 | 125 | IMG_TO_USB="cros flash --yes usb://${ARG_DEV} xbuddy://local/${BOARD}/latest/dev" |
3c347239 MF |
126 | if ${ARG_DEV_USER} ; then |
127 | run ${IMG_TO_USB} | |
128 | sync & | |
129 | fi | |
130 | ||
42e1a176 MF |
131 | cd "${IMAGES}" |
132 | rm -rf $(ls -td1R `find -mindepth 1 -maxdepth 1 -type d` | sed -e 1d -e 2d) | |
133 | ||
ebedbad3 | 134 | d="~/trunk/src/scripts" |
1227e08d | 135 | BUILD_IMG="${d}/${BUILD_IMG#./}" |
3c347239 MF |
136 | cat <<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 | |
147 | https://dev.chromium.org/chromium-os/testing/running-smoke-suite-on-a-vm-image | |
148 | ||
149 | /usr/local/autotest/bin/autologin.py | |
150 | ||
dd5fec28 | 151 | export CROS_USER_ID_HASH=\$(ls /home/user/) |
93639020 MF |
152 | sudo -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 | ||
163 | EOF |