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