blob: 234d50f586eafc6f6e9b9bd1be5db0cedd3dfc48 [file] [log] [blame]
Brian Harringcb782242011-12-13 19:48:44 -08001#!/bin/bash
2
3# Copyright (c) 2011 The Chromium OS Authors. All rights reserved.
4# Use of this source code is governed by a BSD-style license that can be
5# found in the LICENSE file.
6
David James0b1baf62012-03-15 09:26:23 -07007. "$(dirname "$0")/common.sh" || exit 1
Brian Harringcb782242011-12-13 19:48:44 -08008
9# Script must run inside the chroot
10restart_in_chroot_if_needed "$@"
11
Zdenek Behan05780782012-05-18 03:07:28 +020012assert_not_root_user
13
David James855afb72012-03-14 20:04:59 -070014# Developer-visible flags.
Brian Harringcb782242011-12-13 19:48:44 -080015DEFINE_string board "${DEFAULT_BOARD}" \
16 "The board to build packages for."
Brian Harringcb782242011-12-13 19:48:44 -080017DEFINE_boolean usepkg "${FLAGS_TRUE}" \
18 "Use binary packages to bootstrap when possible."
Thiago Goncales5ad4ca02013-07-12 10:55:11 -070019DEFINE_boolean usepkgonly "${FLAGS_FALSE}" \
20 "Only use binary packages to bootstrap; abort if any are missing."
Mike Frysingerf4711422019-11-13 18:04:31 -050021DEFINE_boolean workon "${FLAGS_TRUE}" \
22 "Force-build workon packages."
David James855afb72012-03-14 20:04:59 -070023DEFINE_boolean showoutput "${FLAGS_FALSE}" \
24 "Show all output from parallel_emerge."
25DEFINE_boolean withautotest "${FLAGS_TRUE}" \
26 "Build autotest client code."
Bertrand SIMONNET2f6aaf22015-02-09 15:49:05 -080027DEFINE_boolean withdebugsymbols "${FLAGS_FALSE}" \
Bertrand SIMONNETc7a46e22014-12-11 15:58:11 -080028 "Install the debug symbols for all packages"
Chris Ching4bc95a12016-11-22 13:44:13 -070029DEFINE_string eventfile "${DEFAULT_EVENT_FILE}" \
30 "Define the file that event logs will be written."
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -060031DEFINE_boolean withrevdeps "${FLAGS_TRUE}" \
Gregory Meinke0766df42018-08-23 11:36:12 -060032 "Calculate reverse dependencies on changed ebuilds."
Mike Frysinger38653b02019-10-04 13:56:29 -040033DEFINE_boolean autosetgov "${FLAGS_FALSE}" \
34 "Automatically set cpu governor to 'performance'."
Chris McDonald5405a802019-11-12 13:58:38 -070035DEFINE_boolean use_any_chrome "${FLAGS_TRUE}" \
36 "Use any Chrome prebuilt available, even if the prebuilt doesn't match exactly."
Alex Kleinf61b5372020-04-16 17:02:33 -060037DEFINE_boolean cleanbuild "${FLAGS_FALSE}" \
38 "Perform a clean build; delete sysroot if it exists before building."
Alex Klein80abe722020-04-29 11:13:43 -060039DEFINE_boolean internal "${FLAGS_FALSE}" \
40 "Build the internal version of chrome (set the chrome_internal USE flag)."
Thiago Goncales5ad4ca02013-07-12 10:55:11 -070041
42# The --board_root flag specifies the environment variables ROOT and PKGDIR.
43# This allows fetching and emerging of all packages to specified board_root.
44# Note that --board_root will setup the board normally in /build/$BOARD, if it's
45# not setup yet. It also expects the toolchain to already be installed in the
46# board_root. --usepkgonly and --norebuild are required, because building is not
47# supported when board_root is set.
48# enforce this)."
49DEFINE_string board_root "" \
50 "Emerge packages to board_root."
David James855afb72012-03-14 20:04:59 -070051
Mike Frysinger76452ba2012-09-13 22:45:34 -040052FLAGS_HELP="usage: $(basename $0) [flags] [packages]
David James855afb72012-03-14 20:04:59 -070053
54build_packages updates the set of binary packages needed by Chrome OS. It will
55cross compile all packages that have been updated into the given target's root
56and build binary packages as a side-effect. The output packages will be picked
57up by the build_image script to put together a bootable Chrome OS image.
58
Mike Frysinger76452ba2012-09-13 22:45:34 -040059If [packages] are specified, only build those specific packages (and any
60dependencies they might need).
61
David James855afb72012-03-14 20:04:59 -070062For the fastest builds, use --nowithautotest --noworkon.
63"
David James855afb72012-03-14 20:04:59 -070064
65# The following options are advanced options, only available to those willing
66# to read the source code. They are not shown in help output, since they are
67# not needed for the typical developer workflow.
Ryan Cuieb4595f2012-12-17 14:28:42 -080068DEFINE_string accept_licenses "" \
69 "Licenses to append to the accept list."
David James855afb72012-03-14 20:04:59 -070070DEFINE_integer jobs -1 \
71 "How many packages to build in parallel at maximum."
72DEFINE_boolean norebuild "${FLAGS_FALSE}" \
73 "Don't automatically rebuild dependencies."
Mike Frysinger839e82a2012-03-01 14:22:10 -050074DEFINE_boolean skip_chroot_upgrade "${FLAGS_FALSE}" \
75 "Don't run the chroot upgrade automatically; use with care."
Alex Klein1093ad42021-03-19 10:06:13 -060076DEFINE_boolean skip_setup_board "${FLAGS_FALSE}" \
77 "Don't run setup_board. Implies skip_chroot_upgrade and skip_toolchain_update."
David James855afb72012-03-14 20:04:59 -070078DEFINE_boolean skip_toolchain_update "${FLAGS_FALSE}" \
79 "Don't update toolchain automatically."
80DEFINE_boolean withdev "${FLAGS_TRUE}" \
81 "Build useful developer friendly utilities."
82DEFINE_boolean withdebug "${FLAGS_TRUE}" \
83 "Build debug versions of Chromium-OS-specific packages."
84DEFINE_boolean withfactory "${FLAGS_TRUE}" \
85 "Build factory installer."
86DEFINE_boolean withtest "${FLAGS_TRUE}" \
87 "Build packages required for testing."
Alex Klein32d4d4c2021-03-08 16:16:02 -070088DEFINE_boolean expandedbinhosts "${FLAGS_FALSE}" \
89 "Allow expanded binhost inheritance."
Brian Harringcb782242011-12-13 19:48:44 -080090
David James17c622a2012-03-07 09:34:08 -080091# The --reuse_pkgs_from_local_boards flag tells Portage to share binary
92# packages between boards that are built locally, so that the total time
93# required to build several boards is reduced. This flag is only useful
94# when you are not able to use remote binary packages, since remote binary
95# packages are usually more up to date than anything you have locally.
Hidehiko Abe7a41d342017-03-29 21:19:16 +090096DEFINE_boolean reuse_pkgs_from_local_boards "${FLAGS_FALSE}" \
David James17c622a2012-03-07 09:34:08 -080097 "Bootstrap from local packages instead of remote packages."
98
Hidehiko Abe7a41d342017-03-29 21:19:16 +090099# --run_goma option is designed to be used on bots.
100# If you're trying to build pacakges with goma in your local dev env, this is
101# *not* the option you're looking for. Please see comments below.
102# This option; 1) starts goma, 2) builds packages (expecting that goma is
103# used), then 3) stops goma explicitly.
104# 3) is a request from the goma team, so that stats/logs can be taken.
105# Note: GOMA_DIR and GOMA_SERVICE_ACCOUNT_JSON_FILE are expected to be passed
106# via env var.
107#
108# In local dev env cases, compiler_proxy is expected to keep running.
109# In such a case;
110# $ python ${GOMA_DIR}/goma_ctl.py ensure_start
111# $ ./build_packages (... and options without --run_goma ...)
112# is an expected commandline sequence. If you set --run_goma flag while
113# compiler_proxy is already running, the existing compiler_proxy will be
114# stopped.
115DEFINE_boolean run_goma "${FLAGS_FALSE}" \
116 "If set to true, (re)starts goma, builds packages, and then stops goma."
117
Brian Harringcb782242011-12-13 19:48:44 -0800118# Parse command line
Brian Harringcb782242011-12-13 19:48:44 -0800119FLAGS "$@" || exit 1
120eval set -- "${FLAGS_ARGV}"
Brian Harringcb782242011-12-13 19:48:44 -0800121
122# Die on any errors.
Brian Harring7f175a52012-03-02 05:37:00 -0800123switch_to_strict_mode
Brian Harringcb782242011-12-13 19:48:44 -0800124
Alex Kleindfa7bfa2020-04-20 12:55:22 -0600125# Chrome packages that need to be treated the same. These are the chrome and
126# chrome follow-on packages that share the same version as chrome and are
127# updated in lock step.
128CHROME_PACKAGES=(
129 "chromeos-base/chromeos-chrome"
130 "chromeos-base/chrome-icu"
131)
132
Alex Klein80abe722020-04-29 11:13:43 -0600133if [[ "${FLAGS_internal}" -eq "${FLAGS_TRUE}" ]]; then
134 export USE="${USE} chrome_internal"
135fi
136
Alex Klein12b97722019-12-09 14:25:33 -0700137# This is a temporary measure to help the goma team check the configs while
138# they transition their backend service.
139# TODO(crbug.com/1032290): Delete after the goma RBE transition is complete.
140if [[ "${FLAGS_run_goma}" -eq "${FLAGS_TRUE}" ]]; then
141 info "Environment:"
142 env
143 info "End Environment."
144fi
145
Brian Harringcb782242011-12-13 19:48:44 -0800146# Right now build_packages has to be run from scripts/
147. ${SRC_ROOT}/third_party/chromiumos-overlay/chromeos/config/chromeos_version.sh
148
Mike Frysinger38653b02019-10-04 13:56:29 -0400149# On some systems, powersave can take a long time to ramp up. Inform the user
150# so they can get faster builds. https://crbug.com/1008932
151if grep -qs powersave \
152 /sys/devices/system/cpu/cpufreq/policy*/scaling_governor; then
153 # Make sure we can actually support "performance".
154 if grep -qs performance \
155 /sys/devices/system/cpu/cpu0/cpufreq/scaling_available_governors; then
156 if [[ "${FLAGS_autosetgov}" -eq "${FLAGS_TRUE}" ]]; then
157 info "Temporarily setting cpu governor to 'performance'"
158 trap "sudo cpupower -c all frequency-set -g powersave >&/dev/null" EXIT
159 sudo cpupower -c all frequency-set -g performance >&/dev/null
160 else
161 warn "Current CPU governor set to 'powersave' which can slow down builds."
162 warn "Use --autosetgov to automatically (and temporarily) switch to" \
163 "'performance'."
164 fi
165 fi
166fi
167
Brian Harringcb782242011-12-13 19:48:44 -0800168if [[ -z "${FLAGS_board}" ]]; then
169 echo "Error: --board is required."
170 exit 1
171fi
172
Alex Klein1093ad42021-03-19 10:06:13 -0600173if [[ "${FLAGS_skip_setup_board}" -eq "${FLAGS_FALSE}" ]]; then
174 # Before we can run any tools, we need to update chroot or setup_board.
175 UPDATE_ARGS=()
176 if [[ -n ${FLAGS_accept_licenses} ]]; then
177 UPDATE_ARGS+=( --accept-licenses "${FLAGS_accept_licenses}" )
178 fi
179 if [ "${FLAGS_usepkg}" -eq "${FLAGS_TRUE}" ]; then
180 UPDATE_ARGS+=( --usepkg )
181 else
182 UPDATE_ARGS+=( --nousepkg )
183 fi
184 if [[ "${FLAGS_jobs}" -ne -1 ]]; then
185 UPDATE_ARGS+=( --jobs=${FLAGS_jobs} )
186 fi
187 if [ "${FLAGS_reuse_pkgs_from_local_boards}" -eq "${FLAGS_TRUE}" ]; then
188 UPDATE_ARGS+=( --reuse-pkgs-from-local-boards )
189 fi
190 if [ "${FLAGS_skip_toolchain_update}" -eq "${FLAGS_TRUE}" ]; then
191 UPDATE_ARGS+=( --skip-toolchain-update )
192 fi
193 if [ "${FLAGS_skip_chroot_upgrade}" -eq "${FLAGS_TRUE}" ]; then
194 UPDATE_ARGS+=( --skip-chroot-upgrade )
195 fi
196 if [[ -n ${FLAGS_board_root} ]]; then
197 UPDATE_ARGS+=( --board-root "${FLAGS_board_root}" )
198 fi
199 if [ "${FLAGS_cleanbuild}" -eq "${FLAGS_TRUE}" ]; then
200 UPDATE_ARGS+=( --force )
201 fi
202 if [[ "${FLAGS_expandedbinhosts}" -eq "${FLAGS_TRUE}" ]]; then
203 UPDATE_ARGS+=( --more-binhosts )
204 else
205 UPDATE_ARGS+=( --fewer-binhosts )
206 fi
Mike Frysinger4114c792012-09-13 22:33:12 -0400207
Alex Klein1093ad42021-03-19 10:06:13 -0600208 setup_board --quiet --board=${FLAGS_board} "${UPDATE_ARGS[@]}"
209fi
Mike Frysinger4114c792012-09-13 22:33:12 -0400210
Chris Masonebbccc242014-02-08 16:23:53 -0800211sudo_clear_shadow_locks "/build/${FLAGS_board}"
Ned Nguyen9af21f52019-04-05 11:30:52 -0600212PORTAGE_BINHOST=$(portageq-${FLAGS_board} envvar 'PORTAGE_BINHOST')
213info "PORTAGE_BINHOST: ${PORTAGE_BINHOST}"
214
Chris Masonebbccc242014-02-08 16:23:53 -0800215
Mike Frysinger4114c792012-09-13 22:33:12 -0400216# Setup all the emerge command/flags.
Mike Frysinger697ab962019-11-04 20:02:43 -0500217EMERGE_FLAGS=( -uDNv --backtrack=30 --newrepo )
Mike Frysinger4114c792012-09-13 22:33:12 -0400218
Bertrand SIMONNET4dda4f52015-03-19 13:40:58 -0700219EMERGE_CMD=(
220 "${CHROMITE_BIN}/parallel_emerge"
221 --board=${FLAGS_board}
222)
223
Chris McDonald5405a802019-11-12 13:58:38 -0700224if [[ "${FLAGS_use_any_chrome}" -eq "${FLAGS_TRUE}" ]]; then
Alex Kleindfa7bfa2020-04-20 12:55:22 -0600225 for pkg in "${CHROME_PACKAGES[@]}"; do
226 EMERGE_CMD+=( "--force-remote-binary=${pkg}" )
227 done
Chris McDonald5405a802019-11-12 13:58:38 -0700228fi
229
Mike Frysinger4114c792012-09-13 22:33:12 -0400230EMERGE_CMD+=( ${EXTRA_BOARD_FLAGS} )
Brian Harringcb782242011-12-13 19:48:44 -0800231
David James17c622a2012-03-07 09:34:08 -0800232if [[ "${FLAGS_usepkg}" -eq "${FLAGS_TRUE}" ||
Thiago Goncales5ad4ca02013-07-12 10:55:11 -0700233 "${FLAGS_reuse_pkgs_from_local_boards}" -eq "${FLAGS_TRUE}" ||
234 "${FLAGS_usepkgonly}" -eq "${FLAGS_TRUE}" ]]; then
Brian Harringcb782242011-12-13 19:48:44 -0800235 # Use binary packages. Include all build-time dependencies,
236 # so as to avoid unnecessary differences between source
237 # and binary builds.
Thiago Goncales5ad4ca02013-07-12 10:55:11 -0700238 EMERGE_FLAGS+=( --getbinpkg --with-bdeps y )
239 if [[ ${FLAGS_usepkgonly} -eq ${FLAGS_TRUE} ]]; then
240 EMERGE_FLAGS+=( --usepkgonly )
241 else
242 EMERGE_FLAGS+=( --usepkg )
243 fi
Brian Harringcb782242011-12-13 19:48:44 -0800244fi
245
246if [[ "${FLAGS_jobs}" -ne -1 ]]; then
Mike Frysinger4114c792012-09-13 22:33:12 -0400247 EMERGE_FLAGS+=( --jobs=${FLAGS_jobs} )
248fi
249
250if [[ "${FLAGS_norebuild}" -eq "${FLAGS_FALSE}" ]]; then
Chris McDonald00dcd722019-10-17 13:53:28 -0600251 EMERGE_FLAGS+=( --rebuild-if-new-rev )
Mike Frysinger4114c792012-09-13 22:33:12 -0400252fi
Bertrand SIMONNET4dda4f52015-03-19 13:40:58 -0700253if [[ "${FLAGS_showoutput}" -eq "${FLAGS_TRUE}" ]]; then
Mike Frysinger4114c792012-09-13 22:33:12 -0400254 EMERGE_FLAGS+=( --show-output )
Brian Harringcb782242011-12-13 19:48:44 -0800255fi
256
257if [[ "${FLAGS_withdebug}" -eq "${FLAGS_FALSE}" ]]; then
258 export USE="${USE} -cros-debug"
259fi
260
Mike Frysinger4114c792012-09-13 22:33:12 -0400261# Figure out which packages we should be building.
Mike Frysinger76452ba2012-09-13 22:45:34 -0400262PACKAGES=( "$@" )
Alex Kleinbdd2d762020-02-12 11:53:08 -0700263# Force rebuild chromeos-config because it is extremely cheap, and we do not
264# want to reuse stale configs.
265FORCE_LOCAL_BUILD_PKGS=( chromeos-base/chromeos-config )
Mike Frysinger76452ba2012-09-13 22:45:34 -0400266if [[ $# -eq 0 ]]; then
Mike Frysinger22621952014-04-01 17:41:20 -0400267 PACKAGES=( virtual/target-os )
Mike Frysinger76452ba2012-09-13 22:45:34 -0400268 if [[ "${FLAGS_withdev}" -eq "${FLAGS_TRUE}" ]]; then
Mike Frysingerde399282014-04-15 18:26:04 -0400269 PACKAGES+=( virtual/target-os-dev )
Mike Frysinger76452ba2012-09-13 22:45:34 -0400270 fi
271 if [[ "${FLAGS_withfactory}" -eq "${FLAGS_TRUE}" ]]; then
Hung-Te Lin9b43ced2016-01-14 20:29:47 +0800272 PACKAGES+=( virtual/target-os-factory )
273 PACKAGES+=( virtual/target-os-factory-shim )
Mike Frysinger76452ba2012-09-13 22:45:34 -0400274 fi
275 if [[ "${FLAGS_withtest}" -eq "${FLAGS_TRUE}" ]]; then
Mike Frysinger52669432014-05-05 14:34:09 -0400276 PACKAGES+=( virtual/target-os-test )
Daniel Wangaf4d0012015-07-17 11:52:05 -0700277 # chromeos-ssh-testkeys may generate ssh keys if the right USE flag is set.
278 # We force rebuilding this package from source every time, so that
279 # consecutive builds don't share ssh keys.
280 FORCE_LOCAL_BUILD_PKGS+=( chromeos-base/chromeos-ssh-testkeys )
Mike Frysinger76452ba2012-09-13 22:45:34 -0400281 fi
282 if [[ "${FLAGS_withautotest}" -eq "${FLAGS_TRUE}" ]]; then
283 PACKAGES+=( chromeos-base/autotest-all )
284 fi
Brian Harringcb782242011-12-13 19:48:44 -0800285fi
286
Chris McDonaldac5d8632019-10-23 15:55:45 -0600287info "Rebuilding Portage cache"
288# Before running any emerge operations, regenerate the Portage dependency cache
289# in parallel.
Mike Frysinger5cf035f2021-01-26 00:57:46 -0500290info_run "${EMERGE_CMD[@]}" --regen --quiet
Chris McDonaldac5d8632019-10-23 15:55:45 -0600291
Brian Harringcb782242011-12-13 19:48:44 -0800292# Verify that all packages can be emerged from scratch, without any
293# backtracking. Only print the output if this step fails.
Mike Frysinger76452ba2012-09-13 22:45:34 -0400294info "Checking package dependencies are correct: ${PACKAGES[*]}"
David Jamesab9ca212012-11-06 11:06:07 -0800295if ! OUTPUT=$(emerge-${FLAGS_board} -pe --backtrack=0 \
296 "${PACKAGES[@]}" 2>&1); then
Brian Harringcb782242011-12-13 19:48:44 -0800297 printf "%s\n" "${OUTPUT}"
Brian Harring7f175a52012-03-02 05:37:00 -0800298 die_notrace "emerge detected broken ebuilds. See error message above."
Brian Harringcb782242011-12-13 19:48:44 -0800299fi
300
Mike Frysinger4114c792012-09-13 22:33:12 -0400301# Build cros_workon packages when they are changed.
302CROS_WORKON_PKGS=()
Mike Frysingerf4711422019-11-13 18:04:31 -0500303if [ "${FLAGS_workon}" -eq "${FLAGS_TRUE}" ]; then
Mike Frysinger4114c792012-09-13 22:33:12 -0400304 LIST_MODIFIED_PACKAGES="${CHROMITE_BIN}/cros_list_modified_packages"
Jason D. Clinton321e2f82017-08-09 16:21:23 -0600305 MODIFIED_PACKAGES=( $("${LIST_MODIFIED_PACKAGES}" --board=${FLAGS_board}) )
Gregory Meinke7851ece2018-05-09 13:34:06 -0600306 info "cros_workon modified packages '${MODIFIED_PACKAGES[*]}' detected"
Jason D. Clinton321e2f82017-08-09 16:21:23 -0600307 CROS_WORKON_PKGS+=( "${MODIFIED_PACKAGES[@]}" )
Mike Frysinger4114c792012-09-13 22:33:12 -0400308
David James4941c6b2014-02-03 16:24:59 -0800309 # TODO(anush): Make chrome a fake cros-workon package.
310 if [[ -n "${CHROME_ORIGIN}" ]]; then
Alex Kleindfa7bfa2020-04-20 12:55:22 -0600311 CROS_WORKON_PKGS+=( "${CHROME_PACKAGES[@]}" )
David James4941c6b2014-02-03 16:24:59 -0800312 fi
Mike Frysinger4114c792012-09-13 22:33:12 -0400313fi
314
Daniel Wangaf4d0012015-07-17 11:52:05 -0700315# cros_workon packages always have to be rebuilt.
Daniel Wang491f42a2015-08-20 12:29:59 -0700316FORCE_LOCAL_BUILD_PKGS+=( "${CROS_WORKON_PKGS[@]}" )
Daniel Wangaf4d0012015-07-17 11:52:05 -0700317
Chris McDonald431cf232020-06-17 13:54:54 -0600318# Any package that directly depends on an active cros_workon package also needs
319# to be rebuilt in order to be correctly built against the current set of
320# changes a user may have made to the cros_workon package.
321if [[ ${#CROS_WORKON_PKGS[@]} -gt 0 ]]; then
322 # Collect all installed packages that depend on active cros_workon packages.
323 WORKON_PKG_CONSUMERS=()
324 mapfile -t WORKON_PKG_CONSUMERS < <( \
Alex Klein685216d2020-10-02 12:54:29 -0600325 equery-${FLAGS_board} -q depends "${CROS_WORKON_PKGS[@]}" | \
326 sort -u | \
327 grep -Ev "^\s*$" )
Chris McDonald431cf232020-06-17 13:54:54 -0600328
329 # Transform this list of packages with versions in to a list of just
330 # $CATEGORY/$NAME entries, since we don't want to pass packages with explicit
331 # version numbers as arguments to `emerge`.
332 if [[ ${#WORKON_PKG_CONSUMERS[@]} -gt 0 ]]; then
333 WORKON_REBUILD_PKGS=()
334 mapfile -t WORKON_REBUILD_PKGS < <( \
335 equery-${FLAGS_board} list -p -o --format='$category/$name' \
336 "${WORKON_PKG_CONSUMERS[@]}" | sort -u )
337
338 info "The following packages depend directly on an active" \
339 "cros_workon package and will be rebuilt: ${WORKON_REBUILD_PKGS[*]}"
340
341 FORCE_LOCAL_BUILD_PKGS+=( "${WORKON_REBUILD_PKGS[@]}" )
342 fi
343fi
344
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600345if [[ -n "${FLAGS_board_root}" ]]; then
346 export ROOT="${FLAGS_board_root}"
347 export PORTAGE_CONFIGROOT="${ROOT}"
348 export SYSROOT="${ROOT}"
349 export PKGDIR="${ROOT}"/packages
350fi
351
352# Temporarily modify the emerge flags so we can calculate the revdeps
353# on the modified packages.
Gregory Meinke0766df42018-08-23 11:36:12 -0600354if [[ "${FLAGS_withrevdeps}" -eq "${FLAGS_TRUE}" ]]; then
Yves Arrouyec16e45e2018-08-31 08:37:15 -0700355 info "starting reverse dependency calculations ..."
Gregory Meinke0766df42018-08-23 11:36:12 -0600356 SIM_EMERGE_FLAGS=( "${EMERGE_FLAGS[@]}" --pretend --columns )
Gregory Meinkeee71dd12018-07-09 12:42:25 -0600357
Gregory Meinke0766df42018-08-23 11:36:12 -0600358 if [[ ${#PACKAGES[@]} -gt 0 ]]; then
359 SIM_EMERGE_FLAGS+=(
360 --reinstall-atoms="${PACKAGES[*]}"
361 --usepkg-exclude="${PACKAGES[*]}"
362 )
363 fi
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600364
Chris McDonaldd346ead2020-06-16 14:57:53 -0600365 # cros-workon packages are always going to be force reinstalled, so we add
366 # the forced reinstall behavior to the modified package calculation. This is
367 # necessary to include when a user has already installed a 9999 ebuild and is
368 # now reinstalling that package with additional local changes, because
369 # otherwise the modified package calculation would not see that a 'new'
370 # package is being installed.
371 if [[ ${#CROS_WORKON_PKGS[@]} -gt 0 ]]; then
372 SIM_EMERGE_FLAGS+=(
373 --reinstall-atoms="${CROS_WORKON_PKGS[*]}"
374 --usepkg-exclude="${CROS_WORKON_PKGS[*]}"
375 )
376 fi
377
Gregory Meinke0766df42018-08-23 11:36:12 -0600378 # Calculate only the ebuild changes from the emerge simulation ignoring
379 # the virtual packages and the forced rebuild of autotest-all package.
Chris McDonald3eee0702020-06-16 14:28:01 -0600380 # The lines of the following block do the following operations:
381 # 1. Do a pretend `emerge` command to get a list of what would be built.
382 # 2. Filter to only packages that will be installed to the board sysroot.
383 # 3. Filter to only packages that would be built from source and rewrite the
384 # line from Portage's full output to only $CATEGORY/$PACKAGE
Chris McDonaldd346ead2020-06-16 14:57:53 -0600385 # 4. Filter the list of packages to a heuristic set of packages known to have
386 # incorrectly specified dependencies.
Chris McDonald3eee0702020-06-16 14:28:01 -0600387 # 5. Sort the output and remove any duplicate entries.
Gregory Meinke0766df42018-08-23 11:36:12 -0600388 BASE_INSTALL_PKGS=( $( \
389 sudo -E "${EMERGE_CMD[@]}" "${SIM_EMERGE_FLAGS[@]}" "${PACKAGES[@]}" | \
Chris McDonald3eee0702020-06-16 14:28:01 -0600390 grep -e 'to /build/' | \
Gregory Meinke0766df42018-08-23 11:36:12 -0600391 sed -n -E '/^\[ebuild /{s:^[^]]+\] +::;s: .*::;p}' | \
Chris McDonaldd346ead2020-06-16 14:57:53 -0600392 grep -E '/(chromeos-config.*|coreboot-private-files.*|tast-build-deps)$' | \
Chris McDonald3eee0702020-06-16 14:28:01 -0600393 sort -u ) )
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600394
Gregory Meinke0766df42018-08-23 11:36:12 -0600395 MOD_PKGS=()
396 if [[ "${#BASE_INSTALL_PKGS[@]}" -gt 0 ]]; then
Chris McDonaldd346ead2020-06-16 14:57:53 -0600397 info "Forced rebuild packages detected: ${BASE_INSTALL_PKGS[*]}."
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600398 # Convert specific versions into base package names
399 MOD_PKGS+=( $(\
Gregory Meinke0766df42018-08-23 11:36:12 -0600400 equery-${FLAGS_board} list -p -o --format='$category/$name' \
401 "${BASE_INSTALL_PKGS[@]}" | sort -u ) )
Mike Frysinger5a11e872018-09-05 16:29:02 -0400402 # Remove Chrome as rebuilding it is expensive and almost never makes sense.
403 # Ignore grep exit status in case chromeos-chrome is the only package.
Alex Kleindfa7bfa2020-04-20 12:55:22 -0600404 grep_cmd=( grep -v )
405 for pkg in "${CHROME_PACKAGES[@]}"; do
406 grep_cmd+=( -e "${pkg}" )
407 done
408 MOD_PKGS=( $(printf '%s\n' "${MOD_PKGS[@]}" | "${grep_cmd[@]}" || :) )
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600409 fi
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600410
Gregory Meinke0766df42018-08-23 11:36:12 -0600411 FORCE_LOCAL_BUILD_PKGS+=( "${MOD_PKGS[@]}" )
412
413 if [[ "${#MOD_PKGS[@]}" -gt 0 ]]; then
414 info "calculating reverse dependencies on packages: ${MOD_PKGS[*]}"
415 REV_DEPS=( $(\
416 equery-${FLAGS_board} -q depends --indirect "${MOD_PKGS[@]}" |\
417 awk '{print $1}' | grep -v ^virtual/ | sort -u) )
418 if [[ "${#REV_DEPS[@]}" -gt 0 ]]; then
419 # Convert specific versions into base package names
420 RMOD_PKGS=( $(\
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600421 equery-${FLAGS_board} -q list -p -o --format='$category/$name' \
Gregory Meinke0766df42018-08-23 11:36:12 -0600422 "${REV_DEPS[@]}" | sort -u ) )
Mike Frysinger5a11e872018-09-05 16:29:02 -0400423 # Remove Chrome as rebuilding it is expensive and almost never makes
424 # sense. Ignore grep exit status in case chromeos-chrome is the only
425 # package.
Alex Kleindfa7bfa2020-04-20 12:55:22 -0600426 grep_cmd=( grep -v )
427 for pkg in "${CHROME_PACKAGES[@]}"; do
428 grep_cmd+=( -e "${pkg}" )
429 done
Chris McDonald27a67cc2020-05-06 16:47:44 -0600430 RMOD_PKGS=( $(printf '%s\n' "${RMOD_PKGS[@]}" | "${grep_cmd[@]}" || :) )
Gregory Meinke0766df42018-08-23 11:36:12 -0600431 info "final reverse dependencies that will be rebuilt: ${RMOD_PKGS[*]}"
432 FORCE_LOCAL_BUILD_PKGS+=( "${RMOD_PKGS[@]}" )
433 fi
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600434 fi
Gregory Meinke0766df42018-08-23 11:36:12 -0600435fi # end FLAGS_withrevdeps
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600436
Daniel Wangaf4d0012015-07-17 11:52:05 -0700437if [[ ${#FORCE_LOCAL_BUILD_PKGS[@]} -gt 0 ]]; then
Mike Frysinger4114c792012-09-13 22:33:12 -0400438 EMERGE_FLAGS+=(
Daniel Wangaf4d0012015-07-17 11:52:05 -0700439 --reinstall-atoms="${FORCE_LOCAL_BUILD_PKGS[*]}"
440 --usepkg-exclude="${FORCE_LOCAL_BUILD_PKGS[*]}"
Mike Frysinger4114c792012-09-13 22:33:12 -0400441 )
David James710a7d12011-12-21 15:57:02 -0800442fi
Matt Tennant298f61a2012-06-25 21:54:33 -0700443
Chris McDonald33cabb02019-12-13 14:17:08 -0700444# A list of critical system packages that should never be incidentally
445# reinstalled as a side effect of build_packages. All packages in this list
446# are special cased to prefer matching installed versions, overriding the
447# typical logic of upgrading to the newest available version.
448#
449# This list can't include any package that gets installed to a board!
450# Packages such as LLVM or binutils must not be in this list as the normal
451# rebuild logic must still apply to them for board targets.
452#
453# TODO(crbug/1050752): Remove this list and the corresponding arguments
454# to `emerge` below once we figure out how to exclude toolchain packages from
455# being upgraded transitively via BDEPEND relations.
456CRITICAL_SDK_PACKAGES=(
Manoj Guptaed847552020-09-09 03:04:51 +0000457 "dev-lang/rust"
Luis Lozanob4e21562021-01-29 02:20:03 +0000458 "dev-lang/go"
Chris McDonald33cabb02019-12-13 14:17:08 -0700459 "sys-libs/glibc"
460 "sys-devel/gcc"
461)
462
Mike Frysinger76452ba2012-09-13 22:45:34 -0400463info "Merging board packages now"
Matt Tennant298f61a2012-06-25 21:54:33 -0700464(
Hidehiko Abe7a41d342017-03-29 21:19:16 +0900465 # Support goma on bots. This has to run in subshell, otherwise EXIT trap
466 # handler is overwritten.
467 if [[ "${FLAGS_run_goma}" -eq "${FLAGS_TRUE}" ]]; then
468 info "Starting goma compiler_proxy."
469 goma_ctl="${GOMA_DIR:-${HOME}/goma}/goma_ctl.py"
Mike Frysingerea21dea2020-02-20 01:15:24 -0500470 "${goma_ctl}" restart
471 trap "'${goma_ctl}' stop" EXIT
Hidehiko Abe7a41d342017-03-29 21:19:16 +0900472 fi
473
Mike Frysinger5cf035f2021-01-26 00:57:46 -0500474 info_run sudo -E "${EMERGE_CMD[@]}" "${EMERGE_FLAGS[@]}" "${PACKAGES[@]}" \
Chris McDonald33cabb02019-12-13 14:17:08 -0700475 --useoldpkg-atoms="${CRITICAL_SDK_PACKAGES[*]}" \
476 --rebuild-exclude="${CRITICAL_SDK_PACKAGES[*]}"
Matt Tennant298f61a2012-06-25 21:54:33 -0700477)
478
Brian Harringcb782242011-12-13 19:48:44 -0800479echo "Builds complete"
Bertrand SIMONNETc7a46e22014-12-11 15:58:11 -0800480
481if [[ ${FLAGS_withdebugsymbols} -eq ${FLAGS_TRUE} ]]; then
482 info "fetching the debug symbols"
Mike Frysinger5cf035f2021-01-26 00:57:46 -0500483 info_run sudo -E "${CHROMITE_BIN}/cros_install_debug_syms" \
Bertrand SIMONNETc7a46e22014-12-11 15:58:11 -0800484 "--board=${FLAGS_board}" "--all"
485fi
486
Matt Tennant298f61a2012-06-25 21:54:33 -0700487command_completed
Brian Harringcb782242011-12-13 19:48:44 -0800488echo "Done"