blob: 1190ea94e522a149315e5671edfdc620e7fe3cd5 [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."
David James855afb72012-03-14 20:04:59 -070076DEFINE_boolean skip_toolchain_update "${FLAGS_FALSE}" \
77 "Don't update toolchain automatically."
78DEFINE_boolean withdev "${FLAGS_TRUE}" \
79 "Build useful developer friendly utilities."
80DEFINE_boolean withdebug "${FLAGS_TRUE}" \
81 "Build debug versions of Chromium-OS-specific packages."
82DEFINE_boolean withfactory "${FLAGS_TRUE}" \
83 "Build factory installer."
84DEFINE_boolean withtest "${FLAGS_TRUE}" \
85 "Build packages required for testing."
Brian Harringcb782242011-12-13 19:48:44 -080086
David James17c622a2012-03-07 09:34:08 -080087# The --reuse_pkgs_from_local_boards flag tells Portage to share binary
88# packages between boards that are built locally, so that the total time
89# required to build several boards is reduced. This flag is only useful
90# when you are not able to use remote binary packages, since remote binary
91# packages are usually more up to date than anything you have locally.
Hidehiko Abe7a41d342017-03-29 21:19:16 +090092DEFINE_boolean reuse_pkgs_from_local_boards "${FLAGS_FALSE}" \
David James17c622a2012-03-07 09:34:08 -080093 "Bootstrap from local packages instead of remote packages."
94
Hidehiko Abe7a41d342017-03-29 21:19:16 +090095# --run_goma option is designed to be used on bots.
96# If you're trying to build pacakges with goma in your local dev env, this is
97# *not* the option you're looking for. Please see comments below.
98# This option; 1) starts goma, 2) builds packages (expecting that goma is
99# used), then 3) stops goma explicitly.
100# 3) is a request from the goma team, so that stats/logs can be taken.
101# Note: GOMA_DIR and GOMA_SERVICE_ACCOUNT_JSON_FILE are expected to be passed
102# via env var.
103#
104# In local dev env cases, compiler_proxy is expected to keep running.
105# In such a case;
106# $ python ${GOMA_DIR}/goma_ctl.py ensure_start
107# $ ./build_packages (... and options without --run_goma ...)
108# is an expected commandline sequence. If you set --run_goma flag while
109# compiler_proxy is already running, the existing compiler_proxy will be
110# stopped.
111DEFINE_boolean run_goma "${FLAGS_FALSE}" \
112 "If set to true, (re)starts goma, builds packages, and then stops goma."
113
Brian Harringcb782242011-12-13 19:48:44 -0800114# Parse command line
Brian Harringcb782242011-12-13 19:48:44 -0800115FLAGS "$@" || exit 1
116eval set -- "${FLAGS_ARGV}"
Brian Harringcb782242011-12-13 19:48:44 -0800117
118# Die on any errors.
Brian Harring7f175a52012-03-02 05:37:00 -0800119switch_to_strict_mode
Brian Harringcb782242011-12-13 19:48:44 -0800120
Alex Kleindfa7bfa2020-04-20 12:55:22 -0600121# Chrome packages that need to be treated the same. These are the chrome and
122# chrome follow-on packages that share the same version as chrome and are
123# updated in lock step.
124CHROME_PACKAGES=(
125 "chromeos-base/chromeos-chrome"
126 "chromeos-base/chrome-icu"
127)
128
Alex Klein80abe722020-04-29 11:13:43 -0600129if [[ "${FLAGS_internal}" -eq "${FLAGS_TRUE}" ]]; then
130 export USE="${USE} chrome_internal"
131fi
132
Alex Klein12b97722019-12-09 14:25:33 -0700133# This is a temporary measure to help the goma team check the configs while
134# they transition their backend service.
135# TODO(crbug.com/1032290): Delete after the goma RBE transition is complete.
136if [[ "${FLAGS_run_goma}" -eq "${FLAGS_TRUE}" ]]; then
137 info "Environment:"
138 env
139 info "End Environment."
140fi
141
Brian Harringcb782242011-12-13 19:48:44 -0800142# Right now build_packages has to be run from scripts/
143. ${SRC_ROOT}/third_party/chromiumos-overlay/chromeos/config/chromeos_version.sh
144
Mike Frysinger38653b02019-10-04 13:56:29 -0400145# On some systems, powersave can take a long time to ramp up. Inform the user
146# so they can get faster builds. https://crbug.com/1008932
147if grep -qs powersave \
148 /sys/devices/system/cpu/cpufreq/policy*/scaling_governor; then
149 # Make sure we can actually support "performance".
150 if grep -qs performance \
151 /sys/devices/system/cpu/cpu0/cpufreq/scaling_available_governors; then
152 if [[ "${FLAGS_autosetgov}" -eq "${FLAGS_TRUE}" ]]; then
153 info "Temporarily setting cpu governor to 'performance'"
154 trap "sudo cpupower -c all frequency-set -g powersave >&/dev/null" EXIT
155 sudo cpupower -c all frequency-set -g performance >&/dev/null
156 else
157 warn "Current CPU governor set to 'powersave' which can slow down builds."
158 warn "Use --autosetgov to automatically (and temporarily) switch to" \
159 "'performance'."
160 fi
161 fi
162fi
163
Brian Harringcb782242011-12-13 19:48:44 -0800164if [[ -z "${FLAGS_board}" ]]; then
165 echo "Error: --board is required."
166 exit 1
167fi
168
Mike Frysinger4114c792012-09-13 22:33:12 -0400169# Before we can run any tools, we need to update chroot or setup_board.
170UPDATE_ARGS=()
Ryan Cuieb4595f2012-12-17 14:28:42 -0800171if [[ -n ${FLAGS_accept_licenses} ]]; then
Alex Kleind65766f2019-01-11 14:57:34 -0700172 UPDATE_ARGS+=( --accept-licenses "${FLAGS_accept_licenses}" )
Ryan Cuieb4595f2012-12-17 14:28:42 -0800173fi
Mike Frysinger4114c792012-09-13 22:33:12 -0400174if [ "${FLAGS_usepkg}" -eq "${FLAGS_TRUE}" ]; then
175 UPDATE_ARGS+=( --usepkg )
176else
177 UPDATE_ARGS+=( --nousepkg )
178fi
179if [[ "${FLAGS_jobs}" -ne -1 ]]; then
180 UPDATE_ARGS+=( --jobs=${FLAGS_jobs} )
181fi
182if [ "${FLAGS_reuse_pkgs_from_local_boards}" -eq "${FLAGS_TRUE}" ]; then
Alex Kleind65766f2019-01-11 14:57:34 -0700183 UPDATE_ARGS+=( --reuse-pkgs-from-local-boards )
Mike Frysinger4114c792012-09-13 22:33:12 -0400184fi
185if [ "${FLAGS_skip_toolchain_update}" -eq "${FLAGS_TRUE}" ]; then
Alex Kleind65766f2019-01-11 14:57:34 -0700186 UPDATE_ARGS+=( --skip-toolchain-update )
Mike Frysinger4114c792012-09-13 22:33:12 -0400187fi
188if [ "${FLAGS_skip_chroot_upgrade}" -eq "${FLAGS_TRUE}" ]; then
Alex Kleind65766f2019-01-11 14:57:34 -0700189 UPDATE_ARGS+=( --skip-chroot-upgrade )
Mike Frysinger4114c792012-09-13 22:33:12 -0400190fi
Bertrand SIMONNET10ede912014-10-09 16:21:13 -0700191if [[ -n ${FLAGS_board_root} ]]; then
Alex Kleind65766f2019-01-11 14:57:34 -0700192 UPDATE_ARGS+=( --board-root "${FLAGS_board_root}" )
Bertrand SIMONNET10ede912014-10-09 16:21:13 -0700193fi
Alex Kleinf61b5372020-04-16 17:02:33 -0600194if [ "${FLAGS_cleanbuild}" -eq "${FLAGS_TRUE}" ]; then
195 UPDATE_ARGS+=( --force )
196fi
Mike Frysinger4114c792012-09-13 22:33:12 -0400197
Alex Kleind65766f2019-01-11 14:57:34 -0700198setup_board --quiet --board=${FLAGS_board} "${UPDATE_ARGS[@]}"
Mike Frysinger4114c792012-09-13 22:33:12 -0400199
Chris Masonebbccc242014-02-08 16:23:53 -0800200sudo_clear_shadow_locks "/build/${FLAGS_board}"
Ned Nguyen9af21f52019-04-05 11:30:52 -0600201PORTAGE_BINHOST=$(portageq-${FLAGS_board} envvar 'PORTAGE_BINHOST')
202info "PORTAGE_BINHOST: ${PORTAGE_BINHOST}"
203
Chris Masonebbccc242014-02-08 16:23:53 -0800204
Mike Frysinger4114c792012-09-13 22:33:12 -0400205# Setup all the emerge command/flags.
Mike Frysinger697ab962019-11-04 20:02:43 -0500206EMERGE_FLAGS=( -uDNv --backtrack=30 --newrepo )
Mike Frysinger4114c792012-09-13 22:33:12 -0400207
Bertrand SIMONNET4dda4f52015-03-19 13:40:58 -0700208EMERGE_CMD=(
209 "${CHROMITE_BIN}/parallel_emerge"
210 --board=${FLAGS_board}
211)
212
Chris McDonald5405a802019-11-12 13:58:38 -0700213if [[ "${FLAGS_use_any_chrome}" -eq "${FLAGS_TRUE}" ]]; then
Alex Kleindfa7bfa2020-04-20 12:55:22 -0600214 for pkg in "${CHROME_PACKAGES[@]}"; do
215 EMERGE_CMD+=( "--force-remote-binary=${pkg}" )
216 done
Chris McDonald5405a802019-11-12 13:58:38 -0700217fi
218
Mike Frysinger4114c792012-09-13 22:33:12 -0400219EMERGE_CMD+=( ${EXTRA_BOARD_FLAGS} )
Brian Harringcb782242011-12-13 19:48:44 -0800220
David James17c622a2012-03-07 09:34:08 -0800221if [[ "${FLAGS_usepkg}" -eq "${FLAGS_TRUE}" ||
Thiago Goncales5ad4ca02013-07-12 10:55:11 -0700222 "${FLAGS_reuse_pkgs_from_local_boards}" -eq "${FLAGS_TRUE}" ||
223 "${FLAGS_usepkgonly}" -eq "${FLAGS_TRUE}" ]]; then
Brian Harringcb782242011-12-13 19:48:44 -0800224 # Use binary packages. Include all build-time dependencies,
225 # so as to avoid unnecessary differences between source
226 # and binary builds.
Thiago Goncales5ad4ca02013-07-12 10:55:11 -0700227 EMERGE_FLAGS+=( --getbinpkg --with-bdeps y )
228 if [[ ${FLAGS_usepkgonly} -eq ${FLAGS_TRUE} ]]; then
229 EMERGE_FLAGS+=( --usepkgonly )
230 else
231 EMERGE_FLAGS+=( --usepkg )
232 fi
Brian Harringcb782242011-12-13 19:48:44 -0800233fi
234
235if [[ "${FLAGS_jobs}" -ne -1 ]]; then
Mike Frysinger4114c792012-09-13 22:33:12 -0400236 EMERGE_FLAGS+=( --jobs=${FLAGS_jobs} )
237fi
238
239if [[ "${FLAGS_norebuild}" -eq "${FLAGS_FALSE}" ]]; then
Chris McDonald00dcd722019-10-17 13:53:28 -0600240 EMERGE_FLAGS+=( --rebuild-if-new-rev )
Mike Frysinger4114c792012-09-13 22:33:12 -0400241fi
Bertrand SIMONNET4dda4f52015-03-19 13:40:58 -0700242if [[ "${FLAGS_showoutput}" -eq "${FLAGS_TRUE}" ]]; then
Mike Frysinger4114c792012-09-13 22:33:12 -0400243 EMERGE_FLAGS+=( --show-output )
Brian Harringcb782242011-12-13 19:48:44 -0800244fi
245
246if [[ "${FLAGS_withdebug}" -eq "${FLAGS_FALSE}" ]]; then
247 export USE="${USE} -cros-debug"
248fi
249
Mike Frysinger4114c792012-09-13 22:33:12 -0400250# Figure out which packages we should be building.
Mike Frysinger76452ba2012-09-13 22:45:34 -0400251PACKAGES=( "$@" )
Alex Kleinbdd2d762020-02-12 11:53:08 -0700252# Force rebuild chromeos-config because it is extremely cheap, and we do not
253# want to reuse stale configs.
254FORCE_LOCAL_BUILD_PKGS=( chromeos-base/chromeos-config )
Mike Frysinger76452ba2012-09-13 22:45:34 -0400255if [[ $# -eq 0 ]]; then
Mike Frysinger22621952014-04-01 17:41:20 -0400256 PACKAGES=( virtual/target-os )
Mike Frysinger76452ba2012-09-13 22:45:34 -0400257 if [[ "${FLAGS_withdev}" -eq "${FLAGS_TRUE}" ]]; then
Mike Frysingerde399282014-04-15 18:26:04 -0400258 PACKAGES+=( virtual/target-os-dev )
Mike Frysinger76452ba2012-09-13 22:45:34 -0400259 fi
260 if [[ "${FLAGS_withfactory}" -eq "${FLAGS_TRUE}" ]]; then
Hung-Te Lin9b43ced2016-01-14 20:29:47 +0800261 PACKAGES+=( virtual/target-os-factory )
262 PACKAGES+=( virtual/target-os-factory-shim )
Mike Frysinger76452ba2012-09-13 22:45:34 -0400263 fi
264 if [[ "${FLAGS_withtest}" -eq "${FLAGS_TRUE}" ]]; then
Mike Frysinger52669432014-05-05 14:34:09 -0400265 PACKAGES+=( virtual/target-os-test )
Daniel Wangaf4d0012015-07-17 11:52:05 -0700266 # chromeos-ssh-testkeys may generate ssh keys if the right USE flag is set.
267 # We force rebuilding this package from source every time, so that
268 # consecutive builds don't share ssh keys.
269 FORCE_LOCAL_BUILD_PKGS+=( chromeos-base/chromeos-ssh-testkeys )
Mike Frysinger76452ba2012-09-13 22:45:34 -0400270 fi
271 if [[ "${FLAGS_withautotest}" -eq "${FLAGS_TRUE}" ]]; then
272 PACKAGES+=( chromeos-base/autotest-all )
273 fi
Brian Harringcb782242011-12-13 19:48:44 -0800274fi
275
Chris McDonaldac5d8632019-10-23 15:55:45 -0600276info "Rebuilding Portage cache"
277# Before running any emerge operations, regenerate the Portage dependency cache
278# in parallel.
Mike Frysinger5cf035f2021-01-26 00:57:46 -0500279info_run "${EMERGE_CMD[@]}" --regen --quiet
Chris McDonaldac5d8632019-10-23 15:55:45 -0600280
Brian Harringcb782242011-12-13 19:48:44 -0800281# Verify that all packages can be emerged from scratch, without any
282# backtracking. Only print the output if this step fails.
Mike Frysinger76452ba2012-09-13 22:45:34 -0400283info "Checking package dependencies are correct: ${PACKAGES[*]}"
David Jamesab9ca212012-11-06 11:06:07 -0800284if ! OUTPUT=$(emerge-${FLAGS_board} -pe --backtrack=0 \
285 "${PACKAGES[@]}" 2>&1); then
Brian Harringcb782242011-12-13 19:48:44 -0800286 printf "%s\n" "${OUTPUT}"
Brian Harring7f175a52012-03-02 05:37:00 -0800287 die_notrace "emerge detected broken ebuilds. See error message above."
Brian Harringcb782242011-12-13 19:48:44 -0800288fi
289
Mike Frysinger4114c792012-09-13 22:33:12 -0400290# Build cros_workon packages when they are changed.
291CROS_WORKON_PKGS=()
Mike Frysingerf4711422019-11-13 18:04:31 -0500292if [ "${FLAGS_workon}" -eq "${FLAGS_TRUE}" ]; then
Mike Frysinger4114c792012-09-13 22:33:12 -0400293 LIST_MODIFIED_PACKAGES="${CHROMITE_BIN}/cros_list_modified_packages"
Jason D. Clinton321e2f82017-08-09 16:21:23 -0600294 MODIFIED_PACKAGES=( $("${LIST_MODIFIED_PACKAGES}" --board=${FLAGS_board}) )
Gregory Meinke7851ece2018-05-09 13:34:06 -0600295 info "cros_workon modified packages '${MODIFIED_PACKAGES[*]}' detected"
Jason D. Clinton321e2f82017-08-09 16:21:23 -0600296 CROS_WORKON_PKGS+=( "${MODIFIED_PACKAGES[@]}" )
Mike Frysinger4114c792012-09-13 22:33:12 -0400297
David James4941c6b2014-02-03 16:24:59 -0800298 # TODO(anush): Make chrome a fake cros-workon package.
299 if [[ -n "${CHROME_ORIGIN}" ]]; then
Alex Kleindfa7bfa2020-04-20 12:55:22 -0600300 CROS_WORKON_PKGS+=( "${CHROME_PACKAGES[@]}" )
David James4941c6b2014-02-03 16:24:59 -0800301 fi
Mike Frysinger4114c792012-09-13 22:33:12 -0400302fi
303
Daniel Wangaf4d0012015-07-17 11:52:05 -0700304# cros_workon packages always have to be rebuilt.
Daniel Wang491f42a2015-08-20 12:29:59 -0700305FORCE_LOCAL_BUILD_PKGS+=( "${CROS_WORKON_PKGS[@]}" )
Daniel Wangaf4d0012015-07-17 11:52:05 -0700306
Chris McDonald431cf232020-06-17 13:54:54 -0600307# Any package that directly depends on an active cros_workon package also needs
308# to be rebuilt in order to be correctly built against the current set of
309# changes a user may have made to the cros_workon package.
310if [[ ${#CROS_WORKON_PKGS[@]} -gt 0 ]]; then
311 # Collect all installed packages that depend on active cros_workon packages.
312 WORKON_PKG_CONSUMERS=()
313 mapfile -t WORKON_PKG_CONSUMERS < <( \
Alex Klein685216d2020-10-02 12:54:29 -0600314 equery-${FLAGS_board} -q depends "${CROS_WORKON_PKGS[@]}" | \
315 sort -u | \
316 grep -Ev "^\s*$" )
Chris McDonald431cf232020-06-17 13:54:54 -0600317
318 # Transform this list of packages with versions in to a list of just
319 # $CATEGORY/$NAME entries, since we don't want to pass packages with explicit
320 # version numbers as arguments to `emerge`.
321 if [[ ${#WORKON_PKG_CONSUMERS[@]} -gt 0 ]]; then
322 WORKON_REBUILD_PKGS=()
323 mapfile -t WORKON_REBUILD_PKGS < <( \
324 equery-${FLAGS_board} list -p -o --format='$category/$name' \
325 "${WORKON_PKG_CONSUMERS[@]}" | sort -u )
326
327 info "The following packages depend directly on an active" \
328 "cros_workon package and will be rebuilt: ${WORKON_REBUILD_PKGS[*]}"
329
330 FORCE_LOCAL_BUILD_PKGS+=( "${WORKON_REBUILD_PKGS[@]}" )
331 fi
332fi
333
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600334if [[ -n "${FLAGS_board_root}" ]]; then
335 export ROOT="${FLAGS_board_root}"
336 export PORTAGE_CONFIGROOT="${ROOT}"
337 export SYSROOT="${ROOT}"
338 export PKGDIR="${ROOT}"/packages
339fi
340
341# Temporarily modify the emerge flags so we can calculate the revdeps
342# on the modified packages.
Gregory Meinke0766df42018-08-23 11:36:12 -0600343if [[ "${FLAGS_withrevdeps}" -eq "${FLAGS_TRUE}" ]]; then
Yves Arrouyec16e45e2018-08-31 08:37:15 -0700344 info "starting reverse dependency calculations ..."
Gregory Meinke0766df42018-08-23 11:36:12 -0600345 SIM_EMERGE_FLAGS=( "${EMERGE_FLAGS[@]}" --pretend --columns )
Gregory Meinkeee71dd12018-07-09 12:42:25 -0600346
Gregory Meinke0766df42018-08-23 11:36:12 -0600347 if [[ ${#PACKAGES[@]} -gt 0 ]]; then
348 SIM_EMERGE_FLAGS+=(
349 --reinstall-atoms="${PACKAGES[*]}"
350 --usepkg-exclude="${PACKAGES[*]}"
351 )
352 fi
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600353
Chris McDonaldd346ead2020-06-16 14:57:53 -0600354 # cros-workon packages are always going to be force reinstalled, so we add
355 # the forced reinstall behavior to the modified package calculation. This is
356 # necessary to include when a user has already installed a 9999 ebuild and is
357 # now reinstalling that package with additional local changes, because
358 # otherwise the modified package calculation would not see that a 'new'
359 # package is being installed.
360 if [[ ${#CROS_WORKON_PKGS[@]} -gt 0 ]]; then
361 SIM_EMERGE_FLAGS+=(
362 --reinstall-atoms="${CROS_WORKON_PKGS[*]}"
363 --usepkg-exclude="${CROS_WORKON_PKGS[*]}"
364 )
365 fi
366
Gregory Meinke0766df42018-08-23 11:36:12 -0600367 # Calculate only the ebuild changes from the emerge simulation ignoring
368 # the virtual packages and the forced rebuild of autotest-all package.
Chris McDonald3eee0702020-06-16 14:28:01 -0600369 # The lines of the following block do the following operations:
370 # 1. Do a pretend `emerge` command to get a list of what would be built.
371 # 2. Filter to only packages that will be installed to the board sysroot.
372 # 3. Filter to only packages that would be built from source and rewrite the
373 # line from Portage's full output to only $CATEGORY/$PACKAGE
Chris McDonaldd346ead2020-06-16 14:57:53 -0600374 # 4. Filter the list of packages to a heuristic set of packages known to have
375 # incorrectly specified dependencies.
Chris McDonald3eee0702020-06-16 14:28:01 -0600376 # 5. Sort the output and remove any duplicate entries.
Gregory Meinke0766df42018-08-23 11:36:12 -0600377 BASE_INSTALL_PKGS=( $( \
378 sudo -E "${EMERGE_CMD[@]}" "${SIM_EMERGE_FLAGS[@]}" "${PACKAGES[@]}" | \
Chris McDonald3eee0702020-06-16 14:28:01 -0600379 grep -e 'to /build/' | \
Gregory Meinke0766df42018-08-23 11:36:12 -0600380 sed -n -E '/^\[ebuild /{s:^[^]]+\] +::;s: .*::;p}' | \
Chris McDonaldd346ead2020-06-16 14:57:53 -0600381 grep -E '/(chromeos-config.*|coreboot-private-files.*|tast-build-deps)$' | \
Chris McDonald3eee0702020-06-16 14:28:01 -0600382 sort -u ) )
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600383
Gregory Meinke0766df42018-08-23 11:36:12 -0600384 MOD_PKGS=()
385 if [[ "${#BASE_INSTALL_PKGS[@]}" -gt 0 ]]; then
Chris McDonaldd346ead2020-06-16 14:57:53 -0600386 info "Forced rebuild packages detected: ${BASE_INSTALL_PKGS[*]}."
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600387 # Convert specific versions into base package names
388 MOD_PKGS+=( $(\
Gregory Meinke0766df42018-08-23 11:36:12 -0600389 equery-${FLAGS_board} list -p -o --format='$category/$name' \
390 "${BASE_INSTALL_PKGS[@]}" | sort -u ) )
Mike Frysinger5a11e872018-09-05 16:29:02 -0400391 # Remove Chrome as rebuilding it is expensive and almost never makes sense.
392 # Ignore grep exit status in case chromeos-chrome is the only package.
Alex Kleindfa7bfa2020-04-20 12:55:22 -0600393 grep_cmd=( grep -v )
394 for pkg in "${CHROME_PACKAGES[@]}"; do
395 grep_cmd+=( -e "${pkg}" )
396 done
397 MOD_PKGS=( $(printf '%s\n' "${MOD_PKGS[@]}" | "${grep_cmd[@]}" || :) )
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600398 fi
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600399
Gregory Meinke0766df42018-08-23 11:36:12 -0600400 FORCE_LOCAL_BUILD_PKGS+=( "${MOD_PKGS[@]}" )
401
402 if [[ "${#MOD_PKGS[@]}" -gt 0 ]]; then
403 info "calculating reverse dependencies on packages: ${MOD_PKGS[*]}"
404 REV_DEPS=( $(\
405 equery-${FLAGS_board} -q depends --indirect "${MOD_PKGS[@]}" |\
406 awk '{print $1}' | grep -v ^virtual/ | sort -u) )
407 if [[ "${#REV_DEPS[@]}" -gt 0 ]]; then
408 # Convert specific versions into base package names
409 RMOD_PKGS=( $(\
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600410 equery-${FLAGS_board} -q list -p -o --format='$category/$name' \
Gregory Meinke0766df42018-08-23 11:36:12 -0600411 "${REV_DEPS[@]}" | sort -u ) )
Mike Frysinger5a11e872018-09-05 16:29:02 -0400412 # Remove Chrome as rebuilding it is expensive and almost never makes
413 # sense. Ignore grep exit status in case chromeos-chrome is the only
414 # package.
Alex Kleindfa7bfa2020-04-20 12:55:22 -0600415 grep_cmd=( grep -v )
416 for pkg in "${CHROME_PACKAGES[@]}"; do
417 grep_cmd+=( -e "${pkg}" )
418 done
Chris McDonald27a67cc2020-05-06 16:47:44 -0600419 RMOD_PKGS=( $(printf '%s\n' "${RMOD_PKGS[@]}" | "${grep_cmd[@]}" || :) )
Gregory Meinke0766df42018-08-23 11:36:12 -0600420 info "final reverse dependencies that will be rebuilt: ${RMOD_PKGS[*]}"
421 FORCE_LOCAL_BUILD_PKGS+=( "${RMOD_PKGS[@]}" )
422 fi
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600423 fi
Gregory Meinke0766df42018-08-23 11:36:12 -0600424fi # end FLAGS_withrevdeps
Gregory Meinkeb0f0adc2018-04-17 12:02:28 -0600425
Daniel Wangaf4d0012015-07-17 11:52:05 -0700426if [[ ${#FORCE_LOCAL_BUILD_PKGS[@]} -gt 0 ]]; then
Mike Frysinger4114c792012-09-13 22:33:12 -0400427 EMERGE_FLAGS+=(
Daniel Wangaf4d0012015-07-17 11:52:05 -0700428 --reinstall-atoms="${FORCE_LOCAL_BUILD_PKGS[*]}"
429 --usepkg-exclude="${FORCE_LOCAL_BUILD_PKGS[*]}"
Mike Frysinger4114c792012-09-13 22:33:12 -0400430 )
David James710a7d12011-12-21 15:57:02 -0800431fi
Matt Tennant298f61a2012-06-25 21:54:33 -0700432
Chris McDonald33cabb02019-12-13 14:17:08 -0700433# A list of critical system packages that should never be incidentally
434# reinstalled as a side effect of build_packages. All packages in this list
435# are special cased to prefer matching installed versions, overriding the
436# typical logic of upgrading to the newest available version.
437#
438# This list can't include any package that gets installed to a board!
439# Packages such as LLVM or binutils must not be in this list as the normal
440# rebuild logic must still apply to them for board targets.
441#
442# TODO(crbug/1050752): Remove this list and the corresponding arguments
443# to `emerge` below once we figure out how to exclude toolchain packages from
444# being upgraded transitively via BDEPEND relations.
445CRITICAL_SDK_PACKAGES=(
Manoj Guptaed847552020-09-09 03:04:51 +0000446 "dev-lang/rust"
Luis Lozanob4e21562021-01-29 02:20:03 +0000447 "dev-lang/go"
Chris McDonald33cabb02019-12-13 14:17:08 -0700448 "sys-libs/glibc"
449 "sys-devel/gcc"
450)
451
Mike Frysinger76452ba2012-09-13 22:45:34 -0400452info "Merging board packages now"
Matt Tennant298f61a2012-06-25 21:54:33 -0700453(
Hidehiko Abe7a41d342017-03-29 21:19:16 +0900454 # Support goma on bots. This has to run in subshell, otherwise EXIT trap
455 # handler is overwritten.
456 if [[ "${FLAGS_run_goma}" -eq "${FLAGS_TRUE}" ]]; then
457 info "Starting goma compiler_proxy."
458 goma_ctl="${GOMA_DIR:-${HOME}/goma}/goma_ctl.py"
Mike Frysingerea21dea2020-02-20 01:15:24 -0500459 "${goma_ctl}" restart
460 trap "'${goma_ctl}' stop" EXIT
Hidehiko Abe7a41d342017-03-29 21:19:16 +0900461 fi
462
Mike Frysinger5cf035f2021-01-26 00:57:46 -0500463 info_run sudo -E "${EMERGE_CMD[@]}" "${EMERGE_FLAGS[@]}" "${PACKAGES[@]}" \
Chris McDonald33cabb02019-12-13 14:17:08 -0700464 --useoldpkg-atoms="${CRITICAL_SDK_PACKAGES[*]}" \
465 --rebuild-exclude="${CRITICAL_SDK_PACKAGES[*]}"
Matt Tennant298f61a2012-06-25 21:54:33 -0700466)
467
Brian Harringcb782242011-12-13 19:48:44 -0800468echo "Builds complete"
Bertrand SIMONNETc7a46e22014-12-11 15:58:11 -0800469
470if [[ ${FLAGS_withdebugsymbols} -eq ${FLAGS_TRUE} ]]; then
471 info "fetching the debug symbols"
Mike Frysinger5cf035f2021-01-26 00:57:46 -0500472 info_run sudo -E "${CHROMITE_BIN}/cros_install_debug_syms" \
Bertrand SIMONNETc7a46e22014-12-11 15:58:11 -0800473 "--board=${FLAGS_board}" "--all"
474fi
475
Matt Tennant298f61a2012-06-25 21:54:33 -0700476command_completed
Brian Harringcb782242011-12-13 19:48:44 -0800477echo "Done"