Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 1 | // Copyright 2016 Google Inc. All rights reserved. |
| 2 | // |
| 3 | // Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 | // you may not use this file except in compliance with the License. |
| 5 | // You may obtain a copy of the License at |
| 6 | // |
| 7 | // http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | // |
| 9 | // Unless required by applicable law or agreed to in writing, software |
| 10 | // distributed under the License is distributed on an "AS IS" BASIS, |
| 11 | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 12 | // See the License for the specific language governing permissions and |
| 13 | // limitations under the License. |
| 14 | |
Colin Cross | b98c8b0 | 2016-07-29 13:44:28 -0700 | [diff] [blame] | 15 | package config |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 16 | |
| 17 | import ( |
Colin Cross | 0c66bc6 | 2021-07-20 09:47:41 -0700 | [diff] [blame] | 18 | "runtime" |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 19 | "strings" |
| 20 | |
| 21 | "android/soong/android" |
Ramy Medhat | 9a90fe5 | 2020-04-13 13:21:23 -0400 | [diff] [blame] | 22 | "android/soong/remoteexec" |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 23 | ) |
| 24 | |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 25 | var ( |
Leo Li | 8756b37 | 2017-05-22 16:11:34 -0700 | [diff] [blame] | 26 | // Flags used by lots of devices. Putting them in package static variables |
| 27 | // will save bytes in build.ninja so they aren't repeated for every file |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 28 | commonGlobalCflags = []string{ |
| 29 | "-DANDROID", |
| 30 | "-fmessage-length=0", |
| 31 | "-W", |
| 32 | "-Wall", |
| 33 | "-Wno-unused", |
| 34 | "-Winit-self", |
| 35 | "-Wpointer-arith", |
George Burgess IV | fb81db2 | 2020-02-22 19:28:56 -0800 | [diff] [blame] | 36 | "-Wunreachable-code-loop-increment", |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 37 | |
Colin Cross | 7278afc | 2017-11-02 22:38:32 -0700 | [diff] [blame] | 38 | // Make paths in deps files relative |
| 39 | "-no-canonical-prefixes", |
| 40 | |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 41 | "-DNDEBUG", |
| 42 | "-UDEBUG", |
Colin Cross | 7278afc | 2017-11-02 22:38:32 -0700 | [diff] [blame] | 43 | |
| 44 | "-fno-exceptions", |
| 45 | "-Wno-multichar", |
| 46 | |
| 47 | "-O2", |
| 48 | "-g", |
Yi Kong | 110cd5f | 2020-11-04 01:44:15 +0800 | [diff] [blame] | 49 | "-fdebug-info-for-profiling", |
Colin Cross | 7278afc | 2017-11-02 22:38:32 -0700 | [diff] [blame] | 50 | |
| 51 | "-fno-strict-aliasing", |
Dan Willemsen | 5d980c8 | 2019-08-27 19:37:10 -0700 | [diff] [blame] | 52 | |
| 53 | "-Werror=date-time", |
Elliott Hughes | 2cdbdf1 | 2019-12-03 18:13:00 -0800 | [diff] [blame] | 54 | "-Werror=pragma-pack", |
| 55 | "-Werror=pragma-pack-suspicious-include", |
Christopher Di Bella | 23a991c | 2020-11-11 22:41:32 +0000 | [diff] [blame] | 56 | "-Werror=string-plus-int", |
George Burgess IV | fb81db2 | 2020-02-22 19:28:56 -0800 | [diff] [blame] | 57 | "-Werror=unreachable-code-loop-increment", |
Colin Cross | 9cc59c1 | 2021-07-14 17:59:54 -0700 | [diff] [blame] | 58 | |
| 59 | "-D__compiler_offsetof=__builtin_offsetof", |
| 60 | |
| 61 | // Emit address-significance table which allows linker to perform safe ICF. Clang does |
| 62 | // not emit the table by default on Android since NDK still uses GNU binutils. |
| 63 | "-faddrsig", |
| 64 | |
| 65 | // Turn on -fcommon explicitly, since Clang now defaults to -fno-common. The cleanup bug |
| 66 | // tracking this is http://b/151457797. |
| 67 | "-fcommon", |
| 68 | |
| 69 | // Help catch common 32/64-bit errors. |
| 70 | "-Werror=int-conversion", |
| 71 | |
| 72 | // Enable the new pass manager. |
| 73 | "-fexperimental-new-pass-manager", |
| 74 | |
| 75 | // Disable overly aggressive warning for macros defined with a leading underscore |
| 76 | // This happens in AndroidConfig.h, which is included nearly everywhere. |
| 77 | // TODO: can we remove this now? |
| 78 | "-Wno-reserved-id-macro", |
| 79 | |
Colin Cross | 9cc59c1 | 2021-07-14 17:59:54 -0700 | [diff] [blame] | 80 | // Force clang to always output color diagnostics. Ninja will strip the ANSI |
| 81 | // color codes if it is not running in a terminal. |
| 82 | "-fcolor-diagnostics", |
| 83 | |
| 84 | // Warnings from clang-7.0 |
| 85 | "-Wno-sign-compare", |
| 86 | |
| 87 | // Warnings from clang-8.0 |
| 88 | "-Wno-defaulted-function-deleted", |
| 89 | |
| 90 | // Disable -Winconsistent-missing-override until we can clean up the existing |
| 91 | // codebase for it. |
| 92 | "-Wno-inconsistent-missing-override", |
| 93 | |
| 94 | // Warnings from clang-10 |
| 95 | // Nested and array designated initialization is nice to have. |
| 96 | "-Wno-c99-designator", |
| 97 | |
| 98 | // Warnings from clang-12 |
| 99 | "-Wno-gnu-folding-constant", |
| 100 | |
| 101 | // Calls to the APIs that are newer than the min sdk version of the caller should be |
| 102 | // guarded with __builtin_available. |
| 103 | "-Wunguarded-availability", |
| 104 | // This macro allows the bionic versioning.h to indirectly determine whether the |
| 105 | // option -Wunguarded-availability is on or not. |
| 106 | "-D__ANDROID_UNAVAILABLE_SYMBOLS_ARE_WEAK__", |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 107 | } |
| 108 | |
Colin Cross | 6f6a428 | 2016-10-17 14:19:06 -0700 | [diff] [blame] | 109 | commonGlobalConlyflags = []string{} |
Elliott Hughes | 5a0401a | 2016-10-07 13:12:58 -0700 | [diff] [blame] | 110 | |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 111 | deviceGlobalCflags = []string{ |
Colin Cross | 133dbe7 | 2017-11-02 22:55:19 -0700 | [diff] [blame] | 112 | "-ffunction-sections", |
Colin Cross | ea3141d | 2017-11-06 14:02:02 -0800 | [diff] [blame] | 113 | "-fdata-sections", |
| 114 | "-fno-short-enums", |
Colin Cross | 133dbe7 | 2017-11-02 22:55:19 -0700 | [diff] [blame] | 115 | "-funwind-tables", |
| 116 | "-fstack-protector-strong", |
| 117 | "-Wa,--noexecstack", |
| 118 | "-D_FORTIFY_SOURCE=2", |
| 119 | |
| 120 | "-Wstrict-aliasing=2", |
| 121 | |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 122 | "-Werror=return-type", |
| 123 | "-Werror=non-virtual-dtor", |
| 124 | "-Werror=address", |
| 125 | "-Werror=sequence-point", |
Colin Cross | 133dbe7 | 2017-11-02 22:55:19 -0700 | [diff] [blame] | 126 | "-Werror=format-security", |
Colin Cross | c8bed31 | 2021-07-14 17:56:21 -0700 | [diff] [blame] | 127 | "-nostdlibinc", |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 128 | } |
| 129 | |
Colin Cross | 26f1450 | 2017-11-06 13:59:48 -0800 | [diff] [blame] | 130 | deviceGlobalCppflags = []string{ |
| 131 | "-fvisibility-inlines-hidden", |
| 132 | } |
| 133 | |
Colin Cross | 324a457 | 2017-11-02 23:09:41 -0700 | [diff] [blame] | 134 | deviceGlobalLdflags = []string{ |
| 135 | "-Wl,-z,noexecstack", |
| 136 | "-Wl,-z,relro", |
| 137 | "-Wl,-z,now", |
| 138 | "-Wl,--build-id=md5", |
| 139 | "-Wl,--warn-shared-textrel", |
| 140 | "-Wl,--fatal-warnings", |
| 141 | "-Wl,--no-undefined-version", |
Ryan Prichard | b35a85e | 2021-01-13 19:18:53 -0800 | [diff] [blame] | 142 | // TODO: Eventually we should link against a libunwind.a with hidden symbols, and then these |
| 143 | // --exclude-libs arguments can be removed. |
Christopher Ferris | c3a1e22 | 2019-04-10 17:57:50 -0700 | [diff] [blame] | 144 | "-Wl,--exclude-libs,libgcc.a", |
Yi Kong | 3d8792f | 2019-05-06 16:18:33 -0700 | [diff] [blame] | 145 | "-Wl,--exclude-libs,libgcc_stripped.a", |
Peter Collingbourne | e5ba286 | 2019-12-10 18:37:45 -0800 | [diff] [blame] | 146 | "-Wl,--exclude-libs,libunwind_llvm.a", |
Ryan Prichard | b35a85e | 2021-01-13 19:18:53 -0800 | [diff] [blame] | 147 | "-Wl,--exclude-libs,libunwind.a", |
Ryo Hashimoto | 5818b93 | 2021-03-23 15:05:22 +0900 | [diff] [blame] | 148 | "-Wl,--icf=safe", |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 149 | } |
| 150 | |
Colin Cross | 33bac24 | 2021-07-14 17:03:16 -0700 | [diff] [blame] | 151 | deviceGlobalLldflags = append(deviceGlobalLdflags, |
Chih-Hung Hsieh | 02b4da5 | 2018-04-03 11:33:34 -0700 | [diff] [blame] | 152 | []string{ |
Chih-Hung Hsieh | 02b4da5 | 2018-04-03 11:33:34 -0700 | [diff] [blame] | 153 | "-fuse-ld=lld", |
| 154 | }...) |
| 155 | |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 156 | hostGlobalCflags = []string{} |
| 157 | |
Colin Cross | 26f1450 | 2017-11-06 13:59:48 -0800 | [diff] [blame] | 158 | hostGlobalCppflags = []string{} |
| 159 | |
Colin Cross | 324a457 | 2017-11-02 23:09:41 -0700 | [diff] [blame] | 160 | hostGlobalLdflags = []string{} |
| 161 | |
Chih-Hung Hsieh | 3101a96 | 2018-04-17 14:16:05 -0700 | [diff] [blame] | 162 | hostGlobalLldflags = []string{"-fuse-ld=lld"} |
Chih-Hung Hsieh | 02b4da5 | 2018-04-03 11:33:34 -0700 | [diff] [blame] | 163 | |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 164 | commonGlobalCppflags = []string{ |
| 165 | "-Wsign-promo", |
Colin Cross | c8bed31 | 2021-07-14 17:56:21 -0700 | [diff] [blame] | 166 | |
| 167 | // -Wimplicit-fallthrough is not enabled by -Wall. |
| 168 | "-Wimplicit-fallthrough", |
| 169 | |
| 170 | // Enable clang's thread-safety annotations in libcxx. |
| 171 | "-D_LIBCPP_ENABLE_THREAD_SAFETY_ANNOTATIONS", |
| 172 | |
| 173 | // libc++'s math.h has an #include_next outside of system_headers. |
| 174 | "-Wno-gnu-include-next", |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 175 | } |
| 176 | |
| 177 | noOverrideGlobalCflags = []string{ |
Christopher Di Bella | 23a991c | 2020-11-11 22:41:32 +0000 | [diff] [blame] | 178 | "-Werror=bool-operation", |
| 179 | "-Werror=implicit-int-float-conversion", |
| 180 | "-Werror=int-in-bool-context", |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 181 | "-Werror=int-to-pointer-cast", |
| 182 | "-Werror=pointer-to-int-cast", |
Christopher Di Bella | 23a991c | 2020-11-11 22:41:32 +0000 | [diff] [blame] | 183 | "-Werror=string-compare", |
| 184 | "-Werror=xor-used-as-pow", |
Stephen Hines | 2210e72 | 2020-07-15 11:11:57 -0700 | [diff] [blame] | 185 | // http://b/161386391 for -Wno-void-pointer-to-enum-cast |
| 186 | "-Wno-void-pointer-to-enum-cast", |
| 187 | // http://b/161386391 for -Wno-void-pointer-to-int-cast |
| 188 | "-Wno-void-pointer-to-int-cast", |
| 189 | // http://b/161386391 for -Wno-pointer-to-int-cast |
| 190 | "-Wno-pointer-to-int-cast", |
George Burgess IV | 6c69164 | 2019-09-18 17:52:05 -0700 | [diff] [blame] | 191 | "-Werror=fortify-source", |
Colin Cross | c8bed31 | 2021-07-14 17:56:21 -0700 | [diff] [blame] | 192 | |
| 193 | "-Werror=address-of-temporary", |
| 194 | // Bug: http://b/29823425 Disable -Wnull-dereference until the |
| 195 | // new cases detected by this warning in Clang r271374 are |
| 196 | // fixed. |
| 197 | //"-Werror=null-dereference", |
| 198 | "-Werror=return-type", |
| 199 | |
| 200 | // http://b/72331526 Disable -Wtautological-* until the instances detected by these |
| 201 | // new warnings are fixed. |
| 202 | "-Wno-tautological-constant-compare", |
| 203 | "-Wno-tautological-type-limit-compare", |
| 204 | // http://b/145210666 |
| 205 | "-Wno-reorder-init-list", |
| 206 | // http://b/145211066 |
| 207 | "-Wno-implicit-int-float-conversion", |
| 208 | // New warnings to be fixed after clang-r377782. |
| 209 | "-Wno-int-in-bool-context", // http://b/148287349 |
| 210 | "-Wno-sizeof-array-div", // http://b/148815709 |
| 211 | "-Wno-tautological-overlap-compare", // http://b/148815696 |
| 212 | // New warnings to be fixed after clang-r383902. |
| 213 | "-Wno-deprecated-copy", // http://b/153746672 |
| 214 | "-Wno-range-loop-construct", // http://b/153747076 |
| 215 | "-Wno-misleading-indentation", // http://b/153746954 |
| 216 | "-Wno-zero-as-null-pointer-constant", // http://b/68236239 |
| 217 | "-Wno-deprecated-anon-enum-enum-conversion", // http://b/153746485 |
| 218 | "-Wno-deprecated-enum-enum-conversion", // http://b/153746563 |
| 219 | "-Wno-string-compare", // http://b/153764102 |
| 220 | "-Wno-enum-enum-conversion", // http://b/154138986 |
| 221 | "-Wno-enum-float-conversion", // http://b/154255917 |
| 222 | "-Wno-pessimizing-move", // http://b/154270751 |
| 223 | // New warnings to be fixed after clang-r399163 |
| 224 | "-Wno-non-c-typedef-for-linkage", // http://b/161304145 |
| 225 | // New warnings to be fixed after clang-r407598 |
| 226 | "-Wno-string-concatenation", // http://b/175068488 |
Yabin Cui | 10bf3b8 | 2021-08-10 15:42:10 +0000 | [diff] [blame] | 227 | // New warnings to be fixed after clang-r428724 |
| 228 | "-Wno-align-mismatch", // http://b/193679946 |
Yi Kong | e827329 | 2021-08-31 14:04:18 +0800 | [diff] [blame] | 229 | // New warnings to be fixed after clang-r433403 |
| 230 | "-Wno-error=unused-but-set-variable", // http://b/197240255 |
| 231 | "-Wno-error=unused-but-set-parameter", // http://b/197240255 |
Colin Cross | c8bed31 | 2021-07-14 17:56:21 -0700 | [diff] [blame] | 232 | } |
| 233 | |
| 234 | // Extra cflags for external third-party projects to disable warnings that |
| 235 | // are infeasible to fix in all the external projects and their upstream repos. |
| 236 | extraExternalCflags = []string{ |
| 237 | "-Wno-enum-compare", |
| 238 | "-Wno-enum-compare-switch", |
| 239 | |
| 240 | // http://b/72331524 Allow null pointer arithmetic until the instances detected by |
| 241 | // this new warning are fixed. |
| 242 | "-Wno-null-pointer-arithmetic", |
| 243 | |
| 244 | // Bug: http://b/29823425 Disable -Wnull-dereference until the |
| 245 | // new instances detected by this warning are fixed. |
| 246 | "-Wno-null-dereference", |
| 247 | |
| 248 | // http://b/145211477 |
| 249 | "-Wno-pointer-compare", |
| 250 | // http://b/145211022 |
| 251 | "-Wno-xor-used-as-pow", |
| 252 | // http://b/145211022 |
| 253 | "-Wno-final-dtor-non-final-class", |
| 254 | |
| 255 | // http://b/165945989 |
| 256 | "-Wno-psabi", |
Yi Kong | e827329 | 2021-08-31 14:04:18 +0800 | [diff] [blame] | 257 | |
| 258 | // http://b/199369603 |
| 259 | "-Wno-null-pointer-subtraction", |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 260 | } |
| 261 | |
Colin Cross | b98c8b0 | 2016-07-29 13:44:28 -0700 | [diff] [blame] | 262 | IllegalFlags = []string{ |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 263 | "-w", |
| 264 | } |
Colin Cross | 6f6a428 | 2016-10-17 14:19:06 -0700 | [diff] [blame] | 265 | |
Dan Albert | 043833c | 2017-02-03 16:13:38 -0800 | [diff] [blame] | 266 | CStdVersion = "gnu99" |
Elliott Hughes | 34e4e41 | 2018-11-30 16:03:06 +0000 | [diff] [blame] | 267 | CppStdVersion = "gnu++17" |
Dan Albert | 043833c | 2017-02-03 16:13:38 -0800 | [diff] [blame] | 268 | ExperimentalCStdVersion = "gnu11" |
Elliott Hughes | 3797612 | 2018-11-28 14:16:39 -0800 | [diff] [blame] | 269 | ExperimentalCppStdVersion = "gnu++2a" |
Jayant Chowdhary | 6e8115a | 2017-05-09 10:21:52 -0700 | [diff] [blame] | 270 | |
Leo Li | 8756b37 | 2017-05-22 16:11:34 -0700 | [diff] [blame] | 271 | // prebuilts/clang default settings. |
| 272 | ClangDefaultBase = "prebuilts/clang/host" |
Stephen Hines | b7b0ae1 | 2021-10-14 01:21:21 -0700 | [diff] [blame] | 273 | ClangDefaultVersion = "clang-r433403b" |
| 274 | ClangDefaultShortVersion = "13.0.3" |
Chih-Hung Hsieh | 64a38dc | 2017-11-14 14:09:14 -0800 | [diff] [blame] | 275 | |
Chih-Hung Hsieh | 775edde | 2017-12-24 22:24:47 -0800 | [diff] [blame] | 276 | // Directories with warnings from Android.bp files. |
Chih-Hung Hsieh | 64a38dc | 2017-11-14 14:09:14 -0800 | [diff] [blame] | 277 | WarningAllowedProjects = []string{ |
Chih-Hung Hsieh | 64a38dc | 2017-11-14 14:09:14 -0800 | [diff] [blame] | 278 | "device/", |
Chih-Hung Hsieh | 64a38dc | 2017-11-14 14:09:14 -0800 | [diff] [blame] | 279 | "vendor/", |
| 280 | } |
| 281 | |
Chih-Hung Hsieh | 775edde | 2017-12-24 22:24:47 -0800 | [diff] [blame] | 282 | // Directories with warnings from Android.mk files. |
| 283 | WarningAllowedOldProjects = []string{} |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 284 | ) |
| 285 | |
Colin Cross | b98c8b0 | 2016-07-29 13:44:28 -0700 | [diff] [blame] | 286 | var pctx = android.NewPackageContext("android/soong/cc/config") |
| 287 | |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 288 | func init() { |
Colin Cross | 0c66bc6 | 2021-07-20 09:47:41 -0700 | [diff] [blame] | 289 | if runtime.GOOS == "linux" { |
Kousik Kumar | d207cbe | 2020-10-20 05:52:49 +0000 | [diff] [blame] | 290 | commonGlobalCflags = append(commonGlobalCflags, "-fdebug-prefix-map=/proc/self/cwd=") |
| 291 | } |
| 292 | |
Jingwen Chen | 51a1e1c | 2021-05-20 13:40:14 +0000 | [diff] [blame] | 293 | exportStringListStaticVariable("CommonGlobalConlyflags", commonGlobalConlyflags) |
| 294 | exportStringListStaticVariable("DeviceGlobalCppflags", deviceGlobalCppflags) |
| 295 | exportStringListStaticVariable("DeviceGlobalLdflags", deviceGlobalLdflags) |
| 296 | exportStringListStaticVariable("DeviceGlobalLldflags", deviceGlobalLldflags) |
| 297 | exportStringListStaticVariable("HostGlobalCppflags", hostGlobalCppflags) |
| 298 | exportStringListStaticVariable("HostGlobalLdflags", hostGlobalLdflags) |
| 299 | exportStringListStaticVariable("HostGlobalLldflags", hostGlobalLldflags) |
Jingwen Chen | bf61afb | 2021-05-06 13:31:18 +0000 | [diff] [blame] | 300 | |
Colin Cross | 0523ba2 | 2021-07-14 18:45:05 -0700 | [diff] [blame] | 301 | // Export the static default CommonGlobalCflags to Bazel. |
Jingwen Chen | bf61afb | 2021-05-06 13:31:18 +0000 | [diff] [blame] | 302 | // TODO(187086342): handle cflags that are set in VariableFuncs. |
Colin Cross | 0523ba2 | 2021-07-14 18:45:05 -0700 | [diff] [blame] | 303 | bazelCommonGlobalCflags := append( |
Colin Cross | 33bac24 | 2021-07-14 17:03:16 -0700 | [diff] [blame] | 304 | commonGlobalCflags, |
Jingwen Chen | bf61afb | 2021-05-06 13:31:18 +0000 | [diff] [blame] | 305 | []string{ |
Jingwen Chen | bf61afb | 2021-05-06 13:31:18 +0000 | [diff] [blame] | 306 | // Default to zero initialization. |
| 307 | "-ftrivial-auto-var-init=zero", |
| 308 | "-enable-trivial-auto-var-init-zero-knowing-it-will-be-removed-from-clang", |
| 309 | }...) |
Colin Cross | 0523ba2 | 2021-07-14 18:45:05 -0700 | [diff] [blame] | 310 | exportedStringListVars.Set("CommonGlobalCflags", bazelCommonGlobalCflags) |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 311 | |
Colin Cross | 0523ba2 | 2021-07-14 18:45:05 -0700 | [diff] [blame] | 312 | pctx.VariableFunc("CommonGlobalCflags", func(ctx android.PackageVarContext) string { |
Colin Cross | 33bac24 | 2021-07-14 17:03:16 -0700 | [diff] [blame] | 313 | flags := commonGlobalCflags |
Stephen Hines | 66c8b44 | 2019-06-10 17:40:12 -0700 | [diff] [blame] | 314 | |
| 315 | // http://b/131390872 |
| 316 | // Automatically initialize any uninitialized stack variables. |
Stephen Hines | 5c873ac | 2020-05-14 00:59:09 +0000 | [diff] [blame] | 317 | // Prefer zero-init if multiple options are set. |
Stephen Hines | 66c8b44 | 2019-06-10 17:40:12 -0700 | [diff] [blame] | 318 | if ctx.Config().IsEnvTrue("AUTO_ZERO_INITIALIZE") { |
| 319 | flags = append(flags, "-ftrivial-auto-var-init=zero -enable-trivial-auto-var-init-zero-knowing-it-will-be-removed-from-clang") |
| 320 | } else if ctx.Config().IsEnvTrue("AUTO_PATTERN_INITIALIZE") { |
| 321 | flags = append(flags, "-ftrivial-auto-var-init=pattern") |
Stephen Hines | 797e195 | 2020-01-28 14:43:11 -0800 | [diff] [blame] | 322 | } else if ctx.Config().IsEnvTrue("AUTO_UNINITIALIZE") { |
| 323 | flags = append(flags, "-ftrivial-auto-var-init=uninitialized") |
Stephen Hines | 0e1d5d8 | 2020-01-30 15:06:00 -0800 | [diff] [blame] | 324 | } else { |
Stephen Hines | 5c873ac | 2020-05-14 00:59:09 +0000 | [diff] [blame] | 325 | // Default to zero initialization. |
| 326 | flags = append(flags, "-ftrivial-auto-var-init=zero -enable-trivial-auto-var-init-zero-knowing-it-will-be-removed-from-clang") |
Stephen Hines | 66c8b44 | 2019-06-10 17:40:12 -0700 | [diff] [blame] | 327 | } |
Yi Kong | 62e75f5 | 2021-08-18 15:38:20 +0800 | [diff] [blame] | 328 | |
| 329 | // Workaround for ccache with clang. |
| 330 | // See http://petereisentraut.blogspot.com/2011/05/ccache-and-clang.html. |
| 331 | if ctx.Config().IsEnvTrue("USE_CCACHE") { |
| 332 | flags = append(flags, "-Wno-unused-command-line-argument") |
| 333 | } |
Stephen Hines | 66c8b44 | 2019-06-10 17:40:12 -0700 | [diff] [blame] | 334 | return strings.Join(flags, " ") |
| 335 | }) |
| 336 | |
Colin Cross | 0523ba2 | 2021-07-14 18:45:05 -0700 | [diff] [blame] | 337 | // Export the static default DeviceGlobalCflags to Bazel. |
Jingwen Chen | bf61afb | 2021-05-06 13:31:18 +0000 | [diff] [blame] | 338 | // TODO(187086342): handle cflags that are set in VariableFuncs. |
Colin Cross | 0523ba2 | 2021-07-14 18:45:05 -0700 | [diff] [blame] | 339 | exportedStringListVars.Set("DeviceGlobalCflags", deviceGlobalCflags) |
Jingwen Chen | bf61afb | 2021-05-06 13:31:18 +0000 | [diff] [blame] | 340 | |
Colin Cross | 0523ba2 | 2021-07-14 18:45:05 -0700 | [diff] [blame] | 341 | pctx.VariableFunc("DeviceGlobalCflags", func(ctx android.PackageVarContext) string { |
Colin Cross | c8bed31 | 2021-07-14 17:56:21 -0700 | [diff] [blame] | 342 | return strings.Join(deviceGlobalCflags, " ") |
Doug Horn | c32c6b0 | 2019-01-17 14:44:05 -0800 | [diff] [blame] | 343 | }) |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 344 | |
Colin Cross | 0523ba2 | 2021-07-14 18:45:05 -0700 | [diff] [blame] | 345 | exportStringListStaticVariable("HostGlobalCflags", hostGlobalCflags) |
| 346 | exportStringListStaticVariable("NoOverrideGlobalCflags", noOverrideGlobalCflags) |
| 347 | exportStringListStaticVariable("CommonGlobalCppflags", commonGlobalCppflags) |
| 348 | exportStringListStaticVariable("ExternalCflags", extraExternalCflags) |
Yi Kong | cc80f8d | 2018-06-06 14:42:44 -0700 | [diff] [blame] | 349 | |
Colin Cross | 1cfd89a | 2016-09-15 09:30:46 -0700 | [diff] [blame] | 350 | // Everything in these lists is a crime against abstraction and dependency tracking. |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 351 | // Do not add anything to this list. |
Jingwen Chen | 2199995 | 2021-05-19 05:53:51 +0000 | [diff] [blame] | 352 | commonGlobalIncludes := []string{ |
| 353 | "system/core/include", |
| 354 | "system/logging/liblog/include", |
| 355 | "system/media/audio/include", |
| 356 | "hardware/libhardware/include", |
| 357 | "hardware/libhardware_legacy/include", |
| 358 | "hardware/ril/include", |
| 359 | "frameworks/native/include", |
| 360 | "frameworks/native/opengl/include", |
| 361 | "frameworks/av/include", |
| 362 | } |
Jingwen Chen | 51a1e1c | 2021-05-20 13:40:14 +0000 | [diff] [blame] | 363 | exportedStringListVars.Set("CommonGlobalIncludes", commonGlobalIncludes) |
Jingwen Chen | 2199995 | 2021-05-19 05:53:51 +0000 | [diff] [blame] | 364 | pctx.PrefixedExistentPathsForSourcesVariable("CommonGlobalIncludes", "-I", commonGlobalIncludes) |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 365 | |
Alex Márquez Pérez Muñíz Díaz Púras Thaureaux | a38e518 | 2021-08-12 21:37:35 +0000 | [diff] [blame] | 366 | exportStringStaticVariable("CLANG_DEFAULT_VERSION", ClangDefaultVersion) |
| 367 | exportStringStaticVariable("CLANG_DEFAULT_SHORT_VERSION", ClangDefaultShortVersion) |
| 368 | |
Dan Willemsen | 9fe1410 | 2021-07-13 21:52:04 -0700 | [diff] [blame] | 369 | pctx.StaticVariableWithEnvOverride("ClangBase", "LLVM_PREBUILTS_BASE", ClangDefaultBase) |
| 370 | pctx.StaticVariableWithEnvOverride("ClangVersion", "LLVM_PREBUILTS_VERSION", ClangDefaultVersion) |
Colin Cross | b98c8b0 | 2016-07-29 13:44:28 -0700 | [diff] [blame] | 371 | pctx.StaticVariable("ClangPath", "${ClangBase}/${HostPrebuiltTag}/${ClangVersion}") |
| 372 | pctx.StaticVariable("ClangBin", "${ClangPath}/bin") |
| 373 | |
Dan Willemsen | 9fe1410 | 2021-07-13 21:52:04 -0700 | [diff] [blame] | 374 | pctx.StaticVariableWithEnvOverride("ClangShortVersion", "LLVM_RELEASE_VERSION", ClangDefaultShortVersion) |
Stephen Hines | 755fe07 | 2018-01-24 19:58:36 -0800 | [diff] [blame] | 375 | pctx.StaticVariable("ClangAsanLibDir", "${ClangBase}/linux-x86/${ClangVersion}/lib64/clang/${ClangShortVersion}/lib/linux") |
Alistair Strachan | 777475c | 2016-08-26 12:55:49 -0700 | [diff] [blame] | 376 | |
Jayant Chowdhary | e622d20 | 2017-02-01 19:19:52 -0800 | [diff] [blame] | 377 | // These are tied to the version of LLVM directly in external/llvm, so they might trail the host prebuilts |
| 378 | // being used for the rest of the build process. |
| 379 | pctx.SourcePathVariable("RSClangBase", "prebuilts/clang/host") |
| 380 | pctx.SourcePathVariable("RSClangVersion", "clang-3289846") |
| 381 | pctx.SourcePathVariable("RSReleaseVersion", "3.8") |
| 382 | pctx.StaticVariable("RSLLVMPrebuiltsPath", "${RSClangBase}/${HostPrebuiltTag}/${RSClangVersion}/bin") |
| 383 | pctx.StaticVariable("RSIncludePath", "${RSLLVMPrebuiltsPath}/../lib64/clang/${RSReleaseVersion}/include") |
| 384 | |
Jeff Gaston | 734e380 | 2017-04-10 15:47:24 -0700 | [diff] [blame] | 385 | pctx.PrefixedExistentPathsForSourcesVariable("RsGlobalIncludes", "-I", |
Colin Cross | 2a252be | 2017-05-01 17:37:24 -0700 | [diff] [blame] | 386 | []string{ |
| 387 | "external/clang/lib/Headers", |
| 388 | "frameworks/rs/script_api/include", |
| 389 | }) |
| 390 | |
Dan Willemsen | 54daaf0 | 2018-03-12 13:24:09 -0700 | [diff] [blame] | 391 | pctx.VariableFunc("CcWrapper", func(ctx android.PackageVarContext) string { |
| 392 | if override := ctx.Config().Getenv("CC_WRAPPER"); override != "" { |
| 393 | return override + " " |
Alistair Strachan | 777475c | 2016-08-26 12:55:49 -0700 | [diff] [blame] | 394 | } |
Dan Willemsen | 54daaf0 | 2018-03-12 13:24:09 -0700 | [diff] [blame] | 395 | return "" |
Alistair Strachan | 777475c | 2016-08-26 12:55:49 -0700 | [diff] [blame] | 396 | }) |
Ramy Medhat | 9a90fe5 | 2020-04-13 13:21:23 -0400 | [diff] [blame] | 397 | |
Colin Cross | 77cdcfd | 2021-03-12 11:28:25 -0800 | [diff] [blame] | 398 | pctx.StaticVariableWithEnvOverride("RECXXPool", "RBE_CXX_POOL", remoteexec.DefaultPool) |
| 399 | pctx.StaticVariableWithEnvOverride("RECXXLinksPool", "RBE_CXX_LINKS_POOL", remoteexec.DefaultPool) |
| 400 | pctx.StaticVariableWithEnvOverride("REClangTidyPool", "RBE_CLANG_TIDY_POOL", remoteexec.DefaultPool) |
| 401 | pctx.StaticVariableWithEnvOverride("RECXXLinksExecStrategy", "RBE_CXX_LINKS_EXEC_STRATEGY", remoteexec.LocalExecStrategy) |
| 402 | pctx.StaticVariableWithEnvOverride("REClangTidyExecStrategy", "RBE_CLANG_TIDY_EXEC_STRATEGY", remoteexec.LocalExecStrategy) |
| 403 | pctx.StaticVariableWithEnvOverride("REAbiDumperExecStrategy", "RBE_ABI_DUMPER_EXEC_STRATEGY", remoteexec.LocalExecStrategy) |
| 404 | pctx.StaticVariableWithEnvOverride("REAbiLinkerExecStrategy", "RBE_ABI_LINKER_EXEC_STRATEGY", remoteexec.LocalExecStrategy) |
Colin Cross | 4d9c2d1 | 2016-07-29 12:48:20 -0700 | [diff] [blame] | 405 | } |
| 406 | |
Chris Parsons | 3b1f83d | 2021-10-14 14:08:38 -0400 | [diff] [blame^] | 407 | var HostPrebuiltTag = exportVariableConfigMethod("HostPrebuiltTag", android.Config.PrebuiltOS) |
Dan Willemsen | 9fe1410 | 2021-07-13 21:52:04 -0700 | [diff] [blame] | 408 | |
| 409 | func ClangPath(ctx android.PathContext, file string) android.SourcePath { |
| 410 | type clangToolKey string |
| 411 | |
| 412 | key := android.NewCustomOnceKey(clangToolKey(file)) |
| 413 | |
| 414 | return ctx.Config().OnceSourcePath(key, func() android.SourcePath { |
| 415 | return clangPath(ctx).Join(ctx, file) |
| 416 | }) |
| 417 | } |
| 418 | |
| 419 | var clangPathKey = android.NewOnceKey("clangPath") |
| 420 | |
| 421 | func clangPath(ctx android.PathContext) android.SourcePath { |
| 422 | return ctx.Config().OnceSourcePath(clangPathKey, func() android.SourcePath { |
| 423 | clangBase := ClangDefaultBase |
| 424 | if override := ctx.Config().Getenv("LLVM_PREBUILTS_BASE"); override != "" { |
| 425 | clangBase = override |
| 426 | } |
| 427 | clangVersion := ClangDefaultVersion |
| 428 | if override := ctx.Config().Getenv("LLVM_PREBUILTS_VERSION"); override != "" { |
| 429 | clangVersion = override |
| 430 | } |
| 431 | return android.PathForSource(ctx, clangBase, ctx.Config().PrebuiltOS(), clangVersion) |
| 432 | }) |
| 433 | } |