Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(20)

Side by Side Diff: build/config/compiler/BUILD.gn

Issue 2878513002: build: Use ICF more often now that our binutils is patched. (Closed)
Patch Set: Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 # Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 # Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 import("//build/config/android/config.gni") 5 import("//build/config/android/config.gni")
6 import("//build/config/chrome_build.gni") 6 import("//build/config/chrome_build.gni")
7 import("//build/config/chromecast_build.gni") 7 import("//build/config/chromecast_build.gni")
8 import("//build/config/compiler/compiler.gni") 8 import("//build/config/compiler/compiler.gni")
9 import("//build/toolchain/cc_wrapper.gni") 9 import("//build/toolchain/cc_wrapper.gni")
10 import("//build/toolchain/toolchain.gni") 10 import("//build/toolchain/toolchain.gni")
(...skipping 378 matching lines...) Expand 10 before | Expand all | Expand 10 after
389 # ] 389 # ]
390 #} 390 #}
391 } else if (linux_use_bundled_binutils) { 391 } else if (linux_use_bundled_binutils) {
392 # Gold is the default linker for the bundled binutils so we explicitly 392 # Gold is the default linker for the bundled binutils so we explicitly
393 # enable the bfd linker when use_gold is not set. 393 # enable the bfd linker when use_gold is not set.
394 ldflags += [ "-fuse-ld=bfd" ] 394 ldflags += [ "-fuse-ld=bfd" ]
395 } 395 }
396 396
397 if (is_posix && (use_gold || (use_lld && !is_nacl)) && !using_sanitizer && 397 if (is_posix && (use_gold || (use_lld && !is_nacl)) && !using_sanitizer &&
398 !(is_android && use_order_profiling)) { 398 !(is_android && use_order_profiling)) {
399 # TODO(crbug.com/576197) - gcc on x86 platforms + gold + icf=all 399 # TODO(thakis): Remove `!is_android` below once NDK gold has been rolled
400 # doesn't currently work on non-chromeos platforms. 400 # with the fix for https://sourceware.org/bugzilla/show_bug.cgi?id=17704
401 # Additionally, on Android x86 --icf=safe seems to cause issues as well. 401 # merged. See also https://crbug.com/663886
402 # Additionally, on cast Android x86, --icf=all causes issues. 402 # `linux_use_bundled_binutils` is to avoid breaking Linux distros which may
403 if (is_android && current_cpu == "x86") { 403 # still have a buggy gold.
404 ldflags += [ "-Wl,--icf=none" ] 404 if (!is_android && linux_use_bundled_binutils) {
Nico 2017/05/10 18:13:16 This is the default everywhere, yes?
pcc1 2017/05/10 18:17:20 Yes as best as I can tell from reading the gold an
405 } else if ((is_clang && !is_android) || is_chromeos ||
406 (current_cpu != "x86" && current_cpu != "x64")) {
407 # TODO(thakis): Remove `!is_android` above once our gold has been rolled
408 # with the fix for https://sourceware.org/bugzilla/show_bug.cgi?id=17704
409 # merged. See also https://crbug.com/663886
410 ldflags += [ "-Wl,--icf=all" ] 405 ldflags += [ "-Wl,--icf=all" ]
411 } else if (!is_android || is_clang) {
412 ldflags += [ "-Wl,--icf=safe" ]
413 } 406 }
414 } 407 }
415 408
416 if (linux_use_bundled_binutils) { 409 if (linux_use_bundled_binutils) {
417 cflags += [ "-B$binutils_path" ] 410 cflags += [ "-B$binutils_path" ]
418 } 411 }
419 412
420 # Clang-specific compiler flags setup. 413 # Clang-specific compiler flags setup.
421 # ------------------------------------ 414 # ------------------------------------
422 if (is_clang) { 415 if (is_clang) {
(...skipping 1328 matching lines...) Expand 10 before | Expand all | Expand 10 after
1751 1744
1752 if (is_ios || is_mac) { 1745 if (is_ios || is_mac) {
1753 # On Mac and iOS, this enables support for ARC (automatic ref-counting). 1746 # On Mac and iOS, this enables support for ARC (automatic ref-counting).
1754 # See http://clang.llvm.org/docs/AutomaticReferenceCounting.html. 1747 # See http://clang.llvm.org/docs/AutomaticReferenceCounting.html.
1755 config("enable_arc") { 1748 config("enable_arc") {
1756 common_flags = [ "-fobjc-arc" ] 1749 common_flags = [ "-fobjc-arc" ]
1757 cflags_objc = common_flags 1750 cflags_objc = common_flags
1758 cflags_objcc = common_flags 1751 cflags_objcc = common_flags
1759 } 1752 }
1760 } 1753 }
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698