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

Unified Diff: build/toolchain/linux/BUILD.gn

Issue 117863003: Work on GN toolchain definitions and build (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: merge Created 7 years 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « build/toolchain/goma.gni ('k') | build/toolchain/linux/find_android_compilers.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: build/toolchain/linux/BUILD.gn
diff --git a/build/toolchain/linux/BUILD.gn b/build/toolchain/linux/BUILD.gn
index 0532d80ea9cd97a77858cc3bec97480e11a5886d..393288b85817c537716eba9081b5313ec298548c 100644
--- a/build/toolchain/linux/BUILD.gn
+++ b/build/toolchain/linux/BUILD.gn
@@ -1,180 +1,74 @@
-# Copyright (c) 2013 The Chromium Authors. All rights reserved.
+# Copyright 2013 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
-cc = "gcc"
-cxx = "g++"
-ar = "ar"
-ld = cxx
+import("../clang.gni")
+import("../goma.gni")
+import("../gcc_toolchain.gni")
-# The toolchains below all issue the same commands with some different flags.
-# TODO(brettw) it would be nice to have a different way to express this without
-# so much duplication.
-cc_command = "$cc -MMD -MF \$out.d \$defines \$includes \$cflags \$cflags_c -c \$in -o \$out"
-cxx_command = "$cxx -MMD -MF \$out.d \$defines \$includes \$cflags \$cflags_cc -c \$in -o \$out"
-alink_command = "rm -f \$out && $ar rcs \$out \$in"
-solink_command = "if [ ! -e \$lib -o ! -e \${lib}.TOC ]; then $ld -shared \$ldflags -o \$lib -Wl,-soname=\$soname -Wl,--whole-archive \$in \$solibs -Wl,--no-whole-archive \$libs && { readelf -d \${lib} | grep SONAME ; nm -gD -f p \${lib} | cut -f1-2 -d' '; } > \${lib}.TOC; else $ld -shared \$ldflags -o \$lib -Wl,-soname=\$soname -Wl,--whole-archive \$in \$solibs -Wl,--no-whole-archive \$libs && { readelf -d \${lib} | grep SONAME ; nm -gD -f p \${lib} | cut -f1-2 -d' '; } > \${lib}.tmp && if ! cmp -s \${lib}.tmp \${lib}.TOC; then mv \${lib}.tmp \${lib}.TOC ; fi; fi"
-link_command = "$ld \$ldflags -o \$out -Wl,--start-group \$in \$solibs -Wl,--end-group \$libs"
-stamp_command = "\${postbuilds}touch \$out"
-copy_command = "ln -f \$in \$out 2>/dev/null || (rm -rf \$out && cp -af \$in \$out)"
-
-# ARM --------------------------------------------------------------------------
-
-cc = "arm-linux-gnueabi-gcc"
-cxx = "arm-linux-gnueabi-g++"
-ar = "arm-linux-gnueabi-ar"
-ld = cxx
-
-toolchain("arm") {
- # Make these apply to all tools below.
- lib_prefix = "-l"
- lib_dir_prefix="-L"
-
- tool("cc") {
- # cflags_pch_c
- command = cc_command
- description = "CC \$out"
- depfile = "\$out.d"
- deps = "gcc"
- }
- tool("cxx") {
- # cflags_pch_cc
- command = cxx_command
- description = "CXX \$out"
- depfile = "\$out.d"
- deps = "gcc"
- }
- tool("alink") {
- command = alink_command
- description = "AR \$out"
- }
- tool("solink") {
- command = solink_command
- description = "SOLINK \$lib"
- #pool = "link_pool"
- restat = "1"
- }
- tool("link") {
- command = link_command
- description = "LINK \$out"
- #pool = "link_pool"
- }
- tool("stamp") {
- command = stamp_command
- description = "STAMP \$out"
- }
- tool("copy") {
- command = copy_command
- description = "COPY \$in \$out"
+if (is_gyp) {
+ # Set the compilers for GYP to use. This logic is only relevant to GYP where
+ # there is "a" target compiler. In native GN builds, we have separate
+ # compilers for the toolchains below, any or all of which could be active in
+ # any given build.
+ if (is_clang) {
+ # Set the GYP header for all toolchains when running under Clang.
+ gyp_header = make_clang_global_settings
+ } else {
+ gyp_header = ""
}
- # When invoking this toolchain not as the default one, these args will be
- # passed to the build. They are ignored when this is the default toolchain.
- toolchain_args() {
- cpu_arch = "arm"
+ if (use_goma) {
+ # There is a TODO(yyanagisawa) in common.gypi about the make generator not
+ # supporting CC_wrapper without CC. As a result, we must add a condition
+ # when on the generator when we're not explicitly setting the variables
+ # above (which happens when gyp_header is empty at this point).
+ #
+ # GYP will interpret the file once for each generator, so we have to write
+ # this condition into the GYP file since the user could have more than one
+ # generator set.
+ if (gyp_header == "") {
+ gyp_header +=
+ "'conditions':" +
+ "['\"<(GENERATOR)\"==\"ninja\"', {" +
+ make_goma_global_settings +
+ "}],"
+ } else {
+ gyp_header += make_goma_global_settings
+ }
}
}
-# 32-bit -----------------------------------------------------------------------
+# ARM --------------------------------------------------------------------------
-toolchain("32") {
- # Make these apply to all tools below.
- lib_prefix = "-l"
- lib_dir_prefix="-L"
+gcc_toolchain("arm") {
+ cc = "arm-linux-gnueabi-gcc"
+ cxx = "arm-linux-gnueabi-g++"
+ ar = "arm-linux-gnueabi-ar"
+ ld = cxx
- tool("cc") {
- # cflags_pch_c
- command = cc_command
- description = "CC \$out"
- depfile = "\$out.d"
- deps = "gcc"
- }
- tool("cxx") {
- # cflags_pch_cc
- command = cxx_command
- description = "CXX \$out"
- depfile = "\$out.d"
- deps = "gcc"
- }
- tool("alink") {
- command = alink_command
- description = "AR \$out"
- }
- tool("solink") {
- command = solink_command
- description = "SOLINK \$lib"
- #pool = "link_pool"
- restat = "1"
- }
- tool("link") {
- command = link_command
- description = "LINK \$out"
- #pool = "link_pool"
- }
- tool("stamp") {
- command = stamp_command
- description = "STAMP \$out"
- }
- tool("copy") {
- command = copy_command
- description = "COPY \$in \$out"
- }
-
- # When invoking this toolchain not as the default one, these args will be
- # passed to the build. They are ignored when this is the default toolchain.
- toolchain_args() {
- cpu_arch = "x86"
- }
+ toolchain_cpu_arch = "arm"
+ toolchain_os = "linux"
}
-# 64-bit -----------------------------------------------------------------------
+# 32-bit -----------------------------------------------------------------------
-toolchain("64") {
- # Make these apply to all tools below.
- lib_prefix = "-l"
- lib_dir_prefix="-L"
+gcc_toolchain("x86") {
+ cc = "gcc"
+ cxx = "g++"
+ ar = "ar"
+ ld = cxx
- tool("cc") {
- # cflags_pch_c
- command = cc_command
- description = "CC \$out"
- depfile = "\$out.d"
- deps = "gcc"
- }
- tool("cxx") {
- # cflags_pch_cc
- command = cxx_command
- description = "CXX \$out"
- depfile = "\$out.d"
- deps = "gcc"
- }
- tool("alink") {
- command = alink_command
- description = "AR \$out"
- }
- tool("solink") {
- command = solink_command
- description = "SOLINK \$lib"
- #pool = "link_pool"
- restat = "1"
- }
- tool("link") {
- command = link_command
- description = "LINK \$out"
- #pool = "link_pool"
- }
- tool("stamp") {
- command = stamp_command
- description = "STAMP \$out"
- }
- tool("copy") {
- command = copy_command
- description = "COPY \$in \$out"
- }
+ toolchain_cpu_arch = "x86"
+ toolchain_os = "linux"
+}
- # When invoking this toolchain not as the default one, these args will be
- # passed to the build. They are ignored when this is the default toolchain.
- toolchain_args() {
- cpu_arch = "x64"
- }
+gcc_toolchain("x64") {
+ cc = "gcc"
+ cxx = "g++"
+ ar = "ar"
+ ld = cxx
+
+ toolchain_cpu_arch = "x64"
+ toolchain_os = "linux"
}
« no previous file with comments | « build/toolchain/goma.gni ('k') | build/toolchain/linux/find_android_compilers.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698