Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 1 | #!/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 James | 0b1baf6 | 2012-03-15 09:26:23 -0700 | [diff] [blame] | 7 | . "$(dirname "$0")/common.sh" || exit 1 |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 8 | |
| 9 | # Script must run inside the chroot |
| 10 | restart_in_chroot_if_needed "$@" |
| 11 | |
Zdenek Behan | 0578078 | 2012-05-18 03:07:28 +0200 | [diff] [blame] | 12 | assert_not_root_user |
| 13 | |
David James | 855afb7 | 2012-03-14 20:04:59 -0700 | [diff] [blame] | 14 | # Developer-visible flags. |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 15 | DEFINE_string board "${DEFAULT_BOARD}" \ |
| 16 | "The board to build packages for." |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 17 | DEFINE_boolean usepkg "${FLAGS_TRUE}" \ |
| 18 | "Use binary packages to bootstrap when possible." |
Thiago Goncales | 5ad4ca0 | 2013-07-12 10:55:11 -0700 | [diff] [blame] | 19 | DEFINE_boolean usepkgonly "${FLAGS_FALSE}" \ |
| 20 | "Only use binary packages to bootstrap; abort if any are missing." |
Mike Frysinger | f471142 | 2019-11-13 18:04:31 -0500 | [diff] [blame] | 21 | DEFINE_boolean workon "${FLAGS_TRUE}" \ |
| 22 | "Force-build workon packages." |
David James | 855afb7 | 2012-03-14 20:04:59 -0700 | [diff] [blame] | 23 | DEFINE_boolean showoutput "${FLAGS_FALSE}" \ |
| 24 | "Show all output from parallel_emerge." |
| 25 | DEFINE_boolean withautotest "${FLAGS_TRUE}" \ |
| 26 | "Build autotest client code." |
Bertrand SIMONNET | 2f6aaf2 | 2015-02-09 15:49:05 -0800 | [diff] [blame] | 27 | DEFINE_boolean withdebugsymbols "${FLAGS_FALSE}" \ |
Bertrand SIMONNET | c7a46e2 | 2014-12-11 15:58:11 -0800 | [diff] [blame] | 28 | "Install the debug symbols for all packages" |
Chris Ching | 4bc95a1 | 2016-11-22 13:44:13 -0700 | [diff] [blame] | 29 | DEFINE_boolean withevents "${FLAGS_FALSE}" \ |
| 30 | "Generate events during parallel_emerge step" |
| 31 | DEFINE_string eventfile "${DEFAULT_EVENT_FILE}" \ |
| 32 | "Define the file that event logs will be written." |
Gregory Meinke | b0f0adc | 2018-04-17 12:02:28 -0600 | [diff] [blame] | 33 | DEFINE_boolean withrevdeps "${FLAGS_TRUE}" \ |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 34 | "Calculate reverse dependencies on changed ebuilds." |
Mike Frysinger | 38653b0 | 2019-10-04 13:56:29 -0400 | [diff] [blame] | 35 | DEFINE_boolean autosetgov "${FLAGS_FALSE}" \ |
| 36 | "Automatically set cpu governor to 'performance'." |
Chris McDonald | 5405a80 | 2019-11-12 13:58:38 -0700 | [diff] [blame] | 37 | DEFINE_boolean use_any_chrome "${FLAGS_TRUE}" \ |
| 38 | "Use any Chrome prebuilt available, even if the prebuilt doesn't match exactly." |
Thiago Goncales | 5ad4ca0 | 2013-07-12 10:55:11 -0700 | [diff] [blame] | 39 | |
| 40 | # The --board_root flag specifies the environment variables ROOT and PKGDIR. |
| 41 | # This allows fetching and emerging of all packages to specified board_root. |
| 42 | # Note that --board_root will setup the board normally in /build/$BOARD, if it's |
| 43 | # not setup yet. It also expects the toolchain to already be installed in the |
| 44 | # board_root. --usepkgonly and --norebuild are required, because building is not |
| 45 | # supported when board_root is set. |
| 46 | # enforce this)." |
| 47 | DEFINE_string board_root "" \ |
| 48 | "Emerge packages to board_root." |
David James | 855afb7 | 2012-03-14 20:04:59 -0700 | [diff] [blame] | 49 | |
Mike Frysinger | 76452ba | 2012-09-13 22:45:34 -0400 | [diff] [blame] | 50 | FLAGS_HELP="usage: $(basename $0) [flags] [packages] |
David James | 855afb7 | 2012-03-14 20:04:59 -0700 | [diff] [blame] | 51 | |
| 52 | build_packages updates the set of binary packages needed by Chrome OS. It will |
| 53 | cross compile all packages that have been updated into the given target's root |
| 54 | and build binary packages as a side-effect. The output packages will be picked |
| 55 | up by the build_image script to put together a bootable Chrome OS image. |
| 56 | |
Mike Frysinger | 76452ba | 2012-09-13 22:45:34 -0400 | [diff] [blame] | 57 | If [packages] are specified, only build those specific packages (and any |
| 58 | dependencies they might need). |
| 59 | |
David James | 855afb7 | 2012-03-14 20:04:59 -0700 | [diff] [blame] | 60 | For the fastest builds, use --nowithautotest --noworkon. |
| 61 | " |
David James | 855afb7 | 2012-03-14 20:04:59 -0700 | [diff] [blame] | 62 | |
| 63 | # The following options are advanced options, only available to those willing |
| 64 | # to read the source code. They are not shown in help output, since they are |
| 65 | # not needed for the typical developer workflow. |
Ryan Cui | eb4595f | 2012-12-17 14:28:42 -0800 | [diff] [blame] | 66 | DEFINE_string accept_licenses "" \ |
| 67 | "Licenses to append to the accept list." |
David James | 855afb7 | 2012-03-14 20:04:59 -0700 | [diff] [blame] | 68 | DEFINE_integer jobs -1 \ |
| 69 | "How many packages to build in parallel at maximum." |
| 70 | DEFINE_boolean norebuild "${FLAGS_FALSE}" \ |
| 71 | "Don't automatically rebuild dependencies." |
Mike Frysinger | 839e82a | 2012-03-01 14:22:10 -0500 | [diff] [blame] | 72 | DEFINE_boolean skip_chroot_upgrade "${FLAGS_FALSE}" \ |
| 73 | "Don't run the chroot upgrade automatically; use with care." |
David James | 855afb7 | 2012-03-14 20:04:59 -0700 | [diff] [blame] | 74 | DEFINE_boolean skip_toolchain_update "${FLAGS_FALSE}" \ |
| 75 | "Don't update toolchain automatically." |
| 76 | DEFINE_boolean withdev "${FLAGS_TRUE}" \ |
| 77 | "Build useful developer friendly utilities." |
| 78 | DEFINE_boolean withdebug "${FLAGS_TRUE}" \ |
| 79 | "Build debug versions of Chromium-OS-specific packages." |
| 80 | DEFINE_boolean withfactory "${FLAGS_TRUE}" \ |
| 81 | "Build factory installer." |
| 82 | DEFINE_boolean withtest "${FLAGS_TRUE}" \ |
| 83 | "Build packages required for testing." |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 84 | |
David James | 17c622a | 2012-03-07 09:34:08 -0800 | [diff] [blame] | 85 | # The --reuse_pkgs_from_local_boards flag tells Portage to share binary |
| 86 | # packages between boards that are built locally, so that the total time |
| 87 | # required to build several boards is reduced. This flag is only useful |
| 88 | # when you are not able to use remote binary packages, since remote binary |
| 89 | # packages are usually more up to date than anything you have locally. |
Hidehiko Abe | 7a41d34 | 2017-03-29 21:19:16 +0900 | [diff] [blame] | 90 | DEFINE_boolean reuse_pkgs_from_local_boards "${FLAGS_FALSE}" \ |
David James | 17c622a | 2012-03-07 09:34:08 -0800 | [diff] [blame] | 91 | "Bootstrap from local packages instead of remote packages." |
| 92 | |
Hidehiko Abe | 7a41d34 | 2017-03-29 21:19:16 +0900 | [diff] [blame] | 93 | # --run_goma option is designed to be used on bots. |
| 94 | # If you're trying to build pacakges with goma in your local dev env, this is |
| 95 | # *not* the option you're looking for. Please see comments below. |
| 96 | # This option; 1) starts goma, 2) builds packages (expecting that goma is |
| 97 | # used), then 3) stops goma explicitly. |
| 98 | # 3) is a request from the goma team, so that stats/logs can be taken. |
| 99 | # Note: GOMA_DIR and GOMA_SERVICE_ACCOUNT_JSON_FILE are expected to be passed |
| 100 | # via env var. |
| 101 | # |
| 102 | # In local dev env cases, compiler_proxy is expected to keep running. |
| 103 | # In such a case; |
| 104 | # $ python ${GOMA_DIR}/goma_ctl.py ensure_start |
| 105 | # $ ./build_packages (... and options without --run_goma ...) |
| 106 | # is an expected commandline sequence. If you set --run_goma flag while |
| 107 | # compiler_proxy is already running, the existing compiler_proxy will be |
| 108 | # stopped. |
| 109 | DEFINE_boolean run_goma "${FLAGS_FALSE}" \ |
| 110 | "If set to true, (re)starts goma, builds packages, and then stops goma." |
| 111 | |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 112 | # Parse command line |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 113 | FLAGS "$@" || exit 1 |
| 114 | eval set -- "${FLAGS_ARGV}" |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 115 | |
| 116 | # Die on any errors. |
Brian Harring | 7f175a5 | 2012-03-02 05:37:00 -0800 | [diff] [blame] | 117 | switch_to_strict_mode |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 118 | |
Alex Klein | 12b9772 | 2019-12-09 14:25:33 -0700 | [diff] [blame] | 119 | # This is a temporary measure to help the goma team check the configs while |
| 120 | # they transition their backend service. |
| 121 | # TODO(crbug.com/1032290): Delete after the goma RBE transition is complete. |
| 122 | if [[ "${FLAGS_run_goma}" -eq "${FLAGS_TRUE}" ]]; then |
| 123 | info "Environment:" |
| 124 | env |
| 125 | info "End Environment." |
| 126 | fi |
| 127 | |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 128 | # Right now build_packages has to be run from scripts/ |
| 129 | . ${SRC_ROOT}/third_party/chromiumos-overlay/chromeos/config/chromeos_version.sh |
| 130 | |
Mike Frysinger | 38653b0 | 2019-10-04 13:56:29 -0400 | [diff] [blame] | 131 | # On some systems, powersave can take a long time to ramp up. Inform the user |
| 132 | # so they can get faster builds. https://crbug.com/1008932 |
| 133 | if grep -qs powersave \ |
| 134 | /sys/devices/system/cpu/cpufreq/policy*/scaling_governor; then |
| 135 | # Make sure we can actually support "performance". |
| 136 | if grep -qs performance \ |
| 137 | /sys/devices/system/cpu/cpu0/cpufreq/scaling_available_governors; then |
| 138 | if [[ "${FLAGS_autosetgov}" -eq "${FLAGS_TRUE}" ]]; then |
| 139 | info "Temporarily setting cpu governor to 'performance'" |
| 140 | trap "sudo cpupower -c all frequency-set -g powersave >&/dev/null" EXIT |
| 141 | sudo cpupower -c all frequency-set -g performance >&/dev/null |
| 142 | else |
| 143 | warn "Current CPU governor set to 'powersave' which can slow down builds." |
| 144 | warn "Use --autosetgov to automatically (and temporarily) switch to" \ |
| 145 | "'performance'." |
| 146 | fi |
| 147 | fi |
| 148 | fi |
| 149 | |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 150 | if [[ -z "${FLAGS_board}" ]]; then |
| 151 | echo "Error: --board is required." |
| 152 | exit 1 |
| 153 | fi |
| 154 | |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 155 | # Before we can run any tools, we need to update chroot or setup_board. |
| 156 | UPDATE_ARGS=() |
Ryan Cui | eb4595f | 2012-12-17 14:28:42 -0800 | [diff] [blame] | 157 | if [[ -n ${FLAGS_accept_licenses} ]]; then |
Alex Klein | d65766f | 2019-01-11 14:57:34 -0700 | [diff] [blame] | 158 | UPDATE_ARGS+=( --accept-licenses "${FLAGS_accept_licenses}" ) |
Ryan Cui | eb4595f | 2012-12-17 14:28:42 -0800 | [diff] [blame] | 159 | fi |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 160 | if [ "${FLAGS_usepkg}" -eq "${FLAGS_TRUE}" ]; then |
| 161 | UPDATE_ARGS+=( --usepkg ) |
| 162 | else |
| 163 | UPDATE_ARGS+=( --nousepkg ) |
| 164 | fi |
| 165 | if [[ "${FLAGS_jobs}" -ne -1 ]]; then |
| 166 | UPDATE_ARGS+=( --jobs=${FLAGS_jobs} ) |
| 167 | fi |
| 168 | if [ "${FLAGS_reuse_pkgs_from_local_boards}" -eq "${FLAGS_TRUE}" ]; then |
Alex Klein | d65766f | 2019-01-11 14:57:34 -0700 | [diff] [blame] | 169 | UPDATE_ARGS+=( --reuse-pkgs-from-local-boards ) |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 170 | fi |
| 171 | if [ "${FLAGS_skip_toolchain_update}" -eq "${FLAGS_TRUE}" ]; then |
Alex Klein | d65766f | 2019-01-11 14:57:34 -0700 | [diff] [blame] | 172 | UPDATE_ARGS+=( --skip-toolchain-update ) |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 173 | fi |
| 174 | if [ "${FLAGS_skip_chroot_upgrade}" -eq "${FLAGS_TRUE}" ]; then |
Alex Klein | d65766f | 2019-01-11 14:57:34 -0700 | [diff] [blame] | 175 | UPDATE_ARGS+=( --skip-chroot-upgrade ) |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 176 | fi |
Bertrand SIMONNET | 10ede91 | 2014-10-09 16:21:13 -0700 | [diff] [blame] | 177 | if [[ -n ${FLAGS_board_root} ]]; then |
Alex Klein | d65766f | 2019-01-11 14:57:34 -0700 | [diff] [blame] | 178 | UPDATE_ARGS+=( --board-root "${FLAGS_board_root}" ) |
Bertrand SIMONNET | 10ede91 | 2014-10-09 16:21:13 -0700 | [diff] [blame] | 179 | fi |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 180 | |
Alex Klein | d65766f | 2019-01-11 14:57:34 -0700 | [diff] [blame] | 181 | setup_board --quiet --board=${FLAGS_board} "${UPDATE_ARGS[@]}" |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 182 | |
Chris Masone | bbccc24 | 2014-02-08 16:23:53 -0800 | [diff] [blame] | 183 | sudo_clear_shadow_locks "/build/${FLAGS_board}" |
Ned Nguyen | 9af21f5 | 2019-04-05 11:30:52 -0600 | [diff] [blame] | 184 | PORTAGE_BINHOST=$(portageq-${FLAGS_board} envvar 'PORTAGE_BINHOST') |
| 185 | info "PORTAGE_BINHOST: ${PORTAGE_BINHOST}" |
| 186 | |
Chris Masone | bbccc24 | 2014-02-08 16:23:53 -0800 | [diff] [blame] | 187 | |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 188 | # Setup all the emerge command/flags. |
Mike Frysinger | 697ab96 | 2019-11-04 20:02:43 -0500 | [diff] [blame] | 189 | EMERGE_FLAGS=( -uDNv --backtrack=30 --newrepo ) |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 190 | |
Bertrand SIMONNET | 4dda4f5 | 2015-03-19 13:40:58 -0700 | [diff] [blame] | 191 | EMERGE_CMD=( |
| 192 | "${CHROMITE_BIN}/parallel_emerge" |
| 193 | --board=${FLAGS_board} |
| 194 | ) |
| 195 | |
Chris McDonald | 5405a80 | 2019-11-12 13:58:38 -0700 | [diff] [blame] | 196 | if [[ "${FLAGS_use_any_chrome}" -eq "${FLAGS_TRUE}" ]]; then |
| 197 | EMERGE_CMD+=( "--force-remote-binary=chromeos-base/chromeos-chrome" ) |
| 198 | fi |
| 199 | |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 200 | EMERGE_CMD+=( ${EXTRA_BOARD_FLAGS} ) |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 201 | |
David James | 17c622a | 2012-03-07 09:34:08 -0800 | [diff] [blame] | 202 | if [[ "${FLAGS_usepkg}" -eq "${FLAGS_TRUE}" || |
Thiago Goncales | 5ad4ca0 | 2013-07-12 10:55:11 -0700 | [diff] [blame] | 203 | "${FLAGS_reuse_pkgs_from_local_boards}" -eq "${FLAGS_TRUE}" || |
| 204 | "${FLAGS_usepkgonly}" -eq "${FLAGS_TRUE}" ]]; then |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 205 | # Use binary packages. Include all build-time dependencies, |
| 206 | # so as to avoid unnecessary differences between source |
| 207 | # and binary builds. |
Thiago Goncales | 5ad4ca0 | 2013-07-12 10:55:11 -0700 | [diff] [blame] | 208 | EMERGE_FLAGS+=( --getbinpkg --with-bdeps y ) |
| 209 | if [[ ${FLAGS_usepkgonly} -eq ${FLAGS_TRUE} ]]; then |
| 210 | EMERGE_FLAGS+=( --usepkgonly ) |
| 211 | else |
| 212 | EMERGE_FLAGS+=( --usepkg ) |
| 213 | fi |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 214 | fi |
| 215 | |
| 216 | if [[ "${FLAGS_jobs}" -ne -1 ]]; then |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 217 | EMERGE_FLAGS+=( --jobs=${FLAGS_jobs} ) |
| 218 | fi |
| 219 | |
| 220 | if [[ "${FLAGS_norebuild}" -eq "${FLAGS_FALSE}" ]]; then |
Chris McDonald | 00dcd72 | 2019-10-17 13:53:28 -0600 | [diff] [blame] | 221 | EMERGE_FLAGS+=( --rebuild-if-new-rev ) |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 222 | fi |
Bertrand SIMONNET | 4dda4f5 | 2015-03-19 13:40:58 -0700 | [diff] [blame] | 223 | if [[ "${FLAGS_showoutput}" -eq "${FLAGS_TRUE}" ]]; then |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 224 | EMERGE_FLAGS+=( --show-output ) |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 225 | fi |
| 226 | |
| 227 | if [[ "${FLAGS_withdebug}" -eq "${FLAGS_FALSE}" ]]; then |
| 228 | export USE="${USE} -cros-debug" |
| 229 | fi |
| 230 | |
Chris Ching | 4bc95a1 | 2016-11-22 13:44:13 -0700 | [diff] [blame] | 231 | # TODO Handle case where passed default value, but events not enabled |
| 232 | if [[ "${FLAGS_eventfile}" != "${DEFAULT_EVENT_FILE}" ]]; then |
| 233 | FLAGS_withevents="${FLAGS_TRUE}" |
| 234 | fi |
| 235 | |
| 236 | if [[ "${FLAGS_withevents}" -eq "${FLAGS_TRUE}" ]]; then |
| 237 | mkdir -p "$(dirname $FLAGS_eventfile)" |
| 238 | EMERGE_FLAGS+=( "--eventlogfile=${FLAGS_eventfile}" ) |
| 239 | fi |
| 240 | |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 241 | # Figure out which packages we should be building. |
Mike Frysinger | 76452ba | 2012-09-13 22:45:34 -0400 | [diff] [blame] | 242 | PACKAGES=( "$@" ) |
Alex Klein | bdd2d76 | 2020-02-12 11:53:08 -0700 | [diff] [blame] | 243 | # Force rebuild chromeos-config because it is extremely cheap, and we do not |
| 244 | # want to reuse stale configs. |
| 245 | FORCE_LOCAL_BUILD_PKGS=( chromeos-base/chromeos-config ) |
Mike Frysinger | 76452ba | 2012-09-13 22:45:34 -0400 | [diff] [blame] | 246 | if [[ $# -eq 0 ]]; then |
Mike Frysinger | 2262195 | 2014-04-01 17:41:20 -0400 | [diff] [blame] | 247 | PACKAGES=( virtual/target-os ) |
Mike Frysinger | 76452ba | 2012-09-13 22:45:34 -0400 | [diff] [blame] | 248 | if [[ "${FLAGS_withdev}" -eq "${FLAGS_TRUE}" ]]; then |
Mike Frysinger | de39928 | 2014-04-15 18:26:04 -0400 | [diff] [blame] | 249 | PACKAGES+=( virtual/target-os-dev ) |
Mike Frysinger | 76452ba | 2012-09-13 22:45:34 -0400 | [diff] [blame] | 250 | fi |
| 251 | if [[ "${FLAGS_withfactory}" -eq "${FLAGS_TRUE}" ]]; then |
Hung-Te Lin | 9b43ced | 2016-01-14 20:29:47 +0800 | [diff] [blame] | 252 | PACKAGES+=( virtual/target-os-factory ) |
| 253 | PACKAGES+=( virtual/target-os-factory-shim ) |
Mike Frysinger | 76452ba | 2012-09-13 22:45:34 -0400 | [diff] [blame] | 254 | fi |
| 255 | if [[ "${FLAGS_withtest}" -eq "${FLAGS_TRUE}" ]]; then |
Mike Frysinger | 5266943 | 2014-05-05 14:34:09 -0400 | [diff] [blame] | 256 | PACKAGES+=( virtual/target-os-test ) |
Daniel Wang | af4d001 | 2015-07-17 11:52:05 -0700 | [diff] [blame] | 257 | # chromeos-ssh-testkeys may generate ssh keys if the right USE flag is set. |
| 258 | # We force rebuilding this package from source every time, so that |
| 259 | # consecutive builds don't share ssh keys. |
| 260 | FORCE_LOCAL_BUILD_PKGS+=( chromeos-base/chromeos-ssh-testkeys ) |
Mike Frysinger | 76452ba | 2012-09-13 22:45:34 -0400 | [diff] [blame] | 261 | fi |
| 262 | if [[ "${FLAGS_withautotest}" -eq "${FLAGS_TRUE}" ]]; then |
| 263 | PACKAGES+=( chromeos-base/autotest-all ) |
| 264 | fi |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 265 | fi |
| 266 | |
Chris McDonald | ac5d863 | 2019-10-23 15:55:45 -0600 | [diff] [blame] | 267 | info "Rebuilding Portage cache" |
| 268 | # Before running any emerge operations, regenerate the Portage dependency cache |
| 269 | # in parallel. |
Mike Frysinger | 6115761 | 2019-08-17 13:29:28 -0400 | [diff] [blame] | 270 | "${EMERGE_CMD[@]}" --regen --quiet |
Chris McDonald | ac5d863 | 2019-10-23 15:55:45 -0600 | [diff] [blame] | 271 | |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 272 | # Verify that all packages can be emerged from scratch, without any |
| 273 | # backtracking. Only print the output if this step fails. |
Mike Frysinger | 76452ba | 2012-09-13 22:45:34 -0400 | [diff] [blame] | 274 | info "Checking package dependencies are correct: ${PACKAGES[*]}" |
David James | ab9ca21 | 2012-11-06 11:06:07 -0800 | [diff] [blame] | 275 | if ! OUTPUT=$(emerge-${FLAGS_board} -pe --backtrack=0 \ |
| 276 | "${PACKAGES[@]}" 2>&1); then |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 277 | printf "%s\n" "${OUTPUT}" |
Brian Harring | 7f175a5 | 2012-03-02 05:37:00 -0800 | [diff] [blame] | 278 | die_notrace "emerge detected broken ebuilds. See error message above." |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 279 | fi |
| 280 | |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 281 | # Build cros_workon packages when they are changed. |
| 282 | CROS_WORKON_PKGS=() |
Mike Frysinger | f471142 | 2019-11-13 18:04:31 -0500 | [diff] [blame] | 283 | if [ "${FLAGS_workon}" -eq "${FLAGS_TRUE}" ]; then |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 284 | LIST_MODIFIED_PACKAGES="${CHROMITE_BIN}/cros_list_modified_packages" |
Jason D. Clinton | 321e2f8 | 2017-08-09 16:21:23 -0600 | [diff] [blame] | 285 | MODIFIED_PACKAGES=( $("${LIST_MODIFIED_PACKAGES}" --board=${FLAGS_board}) ) |
Gregory Meinke | 7851ece | 2018-05-09 13:34:06 -0600 | [diff] [blame] | 286 | info "cros_workon modified packages '${MODIFIED_PACKAGES[*]}' detected" |
Jason D. Clinton | 321e2f8 | 2017-08-09 16:21:23 -0600 | [diff] [blame] | 287 | CROS_WORKON_PKGS+=( "${MODIFIED_PACKAGES[@]}" ) |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 288 | |
David James | 4941c6b | 2014-02-03 16:24:59 -0800 | [diff] [blame] | 289 | # TODO(anush): Make chrome a fake cros-workon package. |
| 290 | if [[ -n "${CHROME_ORIGIN}" ]]; then |
| 291 | CROS_WORKON_PKGS+=( chromeos-base/chromeos-chrome ) |
| 292 | fi |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 293 | fi |
| 294 | |
Daniel Wang | af4d001 | 2015-07-17 11:52:05 -0700 | [diff] [blame] | 295 | # cros_workon packages always have to be rebuilt. |
Daniel Wang | 491f42a | 2015-08-20 12:29:59 -0700 | [diff] [blame] | 296 | FORCE_LOCAL_BUILD_PKGS+=( "${CROS_WORKON_PKGS[@]}" ) |
Daniel Wang | af4d001 | 2015-07-17 11:52:05 -0700 | [diff] [blame] | 297 | |
Gregory Meinke | b0f0adc | 2018-04-17 12:02:28 -0600 | [diff] [blame] | 298 | if [[ -n "${FLAGS_board_root}" ]]; then |
| 299 | export ROOT="${FLAGS_board_root}" |
| 300 | export PORTAGE_CONFIGROOT="${ROOT}" |
| 301 | export SYSROOT="${ROOT}" |
| 302 | export PKGDIR="${ROOT}"/packages |
| 303 | fi |
| 304 | |
| 305 | # Temporarily modify the emerge flags so we can calculate the revdeps |
| 306 | # on the modified packages. |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 307 | if [[ "${FLAGS_withrevdeps}" -eq "${FLAGS_TRUE}" ]]; then |
Yves Arrouye | c16e45e | 2018-08-31 08:37:15 -0700 | [diff] [blame] | 308 | info "starting reverse dependency calculations ..." |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 309 | SIM_EMERGE_FLAGS=( "${EMERGE_FLAGS[@]}" --pretend --columns ) |
Gregory Meinke | ee71dd1 | 2018-07-09 12:42:25 -0600 | [diff] [blame] | 310 | |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 311 | if [[ ${#PACKAGES[@]} -gt 0 ]]; then |
| 312 | SIM_EMERGE_FLAGS+=( |
| 313 | --reinstall-atoms="${PACKAGES[*]}" |
| 314 | --usepkg-exclude="${PACKAGES[*]}" |
| 315 | ) |
| 316 | fi |
Gregory Meinke | b0f0adc | 2018-04-17 12:02:28 -0600 | [diff] [blame] | 317 | |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 318 | # Calculate only the ebuild changes from the emerge simulation ignoring |
| 319 | # the virtual packages and the forced rebuild of autotest-all package. |
| 320 | BASE_INSTALL_PKGS=( $( \ |
| 321 | sudo -E "${EMERGE_CMD[@]}" "${SIM_EMERGE_FLAGS[@]}" "${PACKAGES[@]}" | \ |
| 322 | sed -n -E '/^\[ebuild /{s:^[^]]+\] +::;s: .*::;p}' | \ |
| 323 | grep -v -e '^virtual/' -e '^chromeos-base/autotest-all' | sort -u ) ) |
Gregory Meinke | b0f0adc | 2018-04-17 12:02:28 -0600 | [diff] [blame] | 324 | |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 325 | MOD_PKGS=() |
| 326 | if [[ "${#BASE_INSTALL_PKGS[@]}" -gt 0 ]]; then |
| 327 | info "New packages being installed: ${BASE_INSTALL_PKGS[*]}." |
Gregory Meinke | b0f0adc | 2018-04-17 12:02:28 -0600 | [diff] [blame] | 328 | # Convert specific versions into base package names |
| 329 | MOD_PKGS+=( $(\ |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 330 | equery-${FLAGS_board} list -p -o --format='$category/$name' \ |
| 331 | "${BASE_INSTALL_PKGS[@]}" | sort -u ) ) |
Mike Frysinger | 5a11e87 | 2018-09-05 16:29:02 -0400 | [diff] [blame] | 332 | # Remove Chrome as rebuilding it is expensive and almost never makes sense. |
| 333 | # Ignore grep exit status in case chromeos-chrome is the only package. |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 334 | MOD_PKGS=( $(printf '%s\n' "${MOD_PKGS[@]}" | \ |
Mike Frysinger | 5a11e87 | 2018-09-05 16:29:02 -0400 | [diff] [blame] | 335 | grep -v 'chromeos-base/chromeos-chrome' || :) ) |
Gregory Meinke | b0f0adc | 2018-04-17 12:02:28 -0600 | [diff] [blame] | 336 | fi |
Gregory Meinke | b0f0adc | 2018-04-17 12:02:28 -0600 | [diff] [blame] | 337 | |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 338 | FORCE_LOCAL_BUILD_PKGS+=( "${MOD_PKGS[@]}" ) |
| 339 | |
| 340 | if [[ "${#MOD_PKGS[@]}" -gt 0 ]]; then |
| 341 | info "calculating reverse dependencies on packages: ${MOD_PKGS[*]}" |
| 342 | REV_DEPS=( $(\ |
| 343 | equery-${FLAGS_board} -q depends --indirect "${MOD_PKGS[@]}" |\ |
| 344 | awk '{print $1}' | grep -v ^virtual/ | sort -u) ) |
| 345 | if [[ "${#REV_DEPS[@]}" -gt 0 ]]; then |
| 346 | # Convert specific versions into base package names |
| 347 | RMOD_PKGS=( $(\ |
Gregory Meinke | b0f0adc | 2018-04-17 12:02:28 -0600 | [diff] [blame] | 348 | equery-${FLAGS_board} -q list -p -o --format='$category/$name' \ |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 349 | "${REV_DEPS[@]}" | sort -u ) ) |
Mike Frysinger | 5a11e87 | 2018-09-05 16:29:02 -0400 | [diff] [blame] | 350 | # Remove Chrome as rebuilding it is expensive and almost never makes |
| 351 | # sense. Ignore grep exit status in case chromeos-chrome is the only |
| 352 | # package. |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 353 | RMOD_PKGS=( $(printf '%s\n' "${RMOD_PKGS[@]}" | \ |
Mike Frysinger | 5a11e87 | 2018-09-05 16:29:02 -0400 | [diff] [blame] | 354 | grep -v 'chromeos-base/chromeos-chrome' || :) ) |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 355 | info "final reverse dependencies that will be rebuilt: ${RMOD_PKGS[*]}" |
| 356 | FORCE_LOCAL_BUILD_PKGS+=( "${RMOD_PKGS[@]}" ) |
| 357 | fi |
Gregory Meinke | b0f0adc | 2018-04-17 12:02:28 -0600 | [diff] [blame] | 358 | fi |
Gregory Meinke | 0766df4 | 2018-08-23 11:36:12 -0600 | [diff] [blame] | 359 | fi # end FLAGS_withrevdeps |
Gregory Meinke | b0f0adc | 2018-04-17 12:02:28 -0600 | [diff] [blame] | 360 | |
Daniel Wang | af4d001 | 2015-07-17 11:52:05 -0700 | [diff] [blame] | 361 | if [[ ${#FORCE_LOCAL_BUILD_PKGS[@]} -gt 0 ]]; then |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 362 | EMERGE_FLAGS+=( |
Daniel Wang | af4d001 | 2015-07-17 11:52:05 -0700 | [diff] [blame] | 363 | --reinstall-atoms="${FORCE_LOCAL_BUILD_PKGS[*]}" |
| 364 | --usepkg-exclude="${FORCE_LOCAL_BUILD_PKGS[*]}" |
Mike Frysinger | 4114c79 | 2012-09-13 22:33:12 -0400 | [diff] [blame] | 365 | ) |
David James | 710a7d1 | 2011-12-21 15:57:02 -0800 | [diff] [blame] | 366 | fi |
Matt Tennant | 298f61a | 2012-06-25 21:54:33 -0700 | [diff] [blame] | 367 | |
Mike Frysinger | 76452ba | 2012-09-13 22:45:34 -0400 | [diff] [blame] | 368 | info "Merging board packages now" |
Matt Tennant | 298f61a | 2012-06-25 21:54:33 -0700 | [diff] [blame] | 369 | ( |
Hidehiko Abe | 7a41d34 | 2017-03-29 21:19:16 +0900 | [diff] [blame] | 370 | # Support goma on bots. This has to run in subshell, otherwise EXIT trap |
| 371 | # handler is overwritten. |
| 372 | if [[ "${FLAGS_run_goma}" -eq "${FLAGS_TRUE}" ]]; then |
| 373 | info "Starting goma compiler_proxy." |
| 374 | goma_ctl="${GOMA_DIR:-${HOME}/goma}/goma_ctl.py" |
Mike Frysinger | ea21dea | 2020-02-20 01:15:24 -0500 | [diff] [blame^] | 375 | "${goma_ctl}" restart |
| 376 | trap "'${goma_ctl}' stop" EXIT |
Hidehiko Abe | 7a41d34 | 2017-03-29 21:19:16 +0900 | [diff] [blame] | 377 | fi |
| 378 | |
Chris McDonald | 3b35990 | 2019-08-12 13:02:12 -0600 | [diff] [blame] | 379 | sudo -E "${EMERGE_CMD[@]}" "${EMERGE_FLAGS[@]}" "${PACKAGES[@]}" |
Matt Tennant | 298f61a | 2012-06-25 21:54:33 -0700 | [diff] [blame] | 380 | ) |
| 381 | |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 382 | echo "Builds complete" |
Bertrand SIMONNET | c7a46e2 | 2014-12-11 15:58:11 -0800 | [diff] [blame] | 383 | |
| 384 | if [[ ${FLAGS_withdebugsymbols} -eq ${FLAGS_TRUE} ]]; then |
| 385 | info "fetching the debug symbols" |
Mike Frysinger | 66accd2 | 2017-09-13 03:50:30 -0400 | [diff] [blame] | 386 | sudo -E "${CHROMITE_BIN}/cros_install_debug_syms" \ |
Bertrand SIMONNET | c7a46e2 | 2014-12-11 15:58:11 -0800 | [diff] [blame] | 387 | "--board=${FLAGS_board}" "--all" |
| 388 | fi |
| 389 | |
Matt Tennant | 298f61a | 2012-06-25 21:54:33 -0700 | [diff] [blame] | 390 | command_completed |
Brian Harring | cb78224 | 2011-12-13 19:48:44 -0800 | [diff] [blame] | 391 | echo "Done" |