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

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

Issue 2036263002: 💠 Make Android toolchains work when current_toolchain != target_toolchain (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: "$var" -> var Created 4 years, 6 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: build/toolchain/android/BUILD.gn
diff --git a/build/toolchain/android/BUILD.gn b/build/toolchain/android/BUILD.gn
index 52ac0a7d9880f1b82ea53f2e099c1a5261017b91..f0c815b0a0f20e8600e04f2091c8e41395998e2c 100644
--- a/build/toolchain/android/BUILD.gn
+++ b/build/toolchain/android/BUILD.gn
@@ -9,106 +9,114 @@ import("//build/toolchain/gcc_toolchain.gni")
# wrapper around gcc_toolchain to avoid duplication of logic.
#
# Parameters:
-# - android_ndk_sysroot
-# Sysroot for this architecture.
-# - android_ndk_lib_dir
-# Subdirectory inside of android_ndk_sysroot where libs go.
# - toolchain_cpu
-# Same as gcc_toolchain
+# Same as gcc_toolchain.
+# - toolchain_root
+# Path to cpu-specific toolchain within the ndk.
+# - sysroot
+# Sysroot for this architecture.
+# - lib_dir
+# Subdirectory inside of sysroot where libs go.
+# - binary_prefix
+# Prefix of compiler executables.
template("android_gcc_toolchain") {
gcc_toolchain(target_name) {
+ is_clang = invoker.is_clang
+ toolchain_cpu = invoker.toolchain_cpu
+ toolchain_os = "android"
+
# Make our manually injected libs relative to the build dir.
- android_ndk_lib = rebase_path(
- invoker.android_ndk_sysroot + "/" + invoker.android_ndk_lib_dir,
- root_build_dir)
+ _ndk_lib =
+ rebase_path(invoker.sysroot + "/" + invoker.lib_dir, root_build_dir)
+
+ libs_section_prefix = "$_ndk_lib/crtbegin_dynamic.o"
+ libs_section_postfix = "$_ndk_lib/crtend_android.o"
- libs_section_prefix = "$android_ndk_lib/crtbegin_dynamic.o"
- libs_section_postfix = "$android_ndk_lib/crtend_android.o"
+ solink_libs_section_prefix = "$_ndk_lib/crtbegin_so.o"
+ solink_libs_section_postfix = "$_ndk_lib/crtend_so.o"
- solink_libs_section_prefix = "$android_ndk_lib/crtbegin_so.o"
- solink_libs_section_postfix = "$android_ndk_lib/crtend_so.o"
+ _android_tool_prefix =
+ "${invoker.toolchain_root}/bin/${invoker.binary_prefix}-"
# The tools should be run relative to the build dir.
- tool_prefix = rebase_path("$android_tool_prefix", root_build_dir)
+ _tool_prefix = rebase_path("$_android_tool_prefix", root_build_dir)
- is_clang = invoker.is_clang
if (is_clang) {
- prefix = rebase_path("//third_party/llvm-build/Release+Asserts/bin",
- root_build_dir)
- cc = "$prefix/clang"
- cxx = "$prefix/clang++"
+ _prefix = rebase_path("//third_party/llvm-build/Release+Asserts/bin",
+ root_build_dir)
+ cc = "$_prefix/clang"
+ cxx = "$_prefix/clang++"
} else {
- cc = "${tool_prefix}gcc"
- cxx = "${tool_prefix}g++"
+ cc = "${_tool_prefix}gcc"
+ cxx = "${_tool_prefix}g++"
}
- ar = tool_prefix + "ar"
+ ar = _tool_prefix + "ar"
ld = cxx
- readelf = tool_prefix + "readelf"
- nm = tool_prefix + "nm"
- strip = "${tool_prefix}strip"
+ readelf = _tool_prefix + "readelf"
+ nm = _tool_prefix + "nm"
+ strip = "${_tool_prefix}strip"
# Don't use .cr.so for loadable_modules since they are always loaded via
# absolute path.
loadable_module_extension = ".so"
-
- toolchain_os = "android"
- toolchain_cpu = invoker.toolchain_cpu
}
}
template("android_gcc_toolchains_helper") {
android_gcc_toolchain(target_name) {
- android_ndk_sysroot = invoker.android_ndk_sysroot
- android_ndk_lib_dir = invoker.android_ndk_lib_dir
- toolchain_cpu = invoker.toolchain_cpu
+ forward_variables_from(invoker, "*")
}
android_gcc_toolchain("clang_$target_name") {
- android_ndk_sysroot = invoker.android_ndk_sysroot
- android_ndk_lib_dir = invoker.android_ndk_lib_dir
- toolchain_cpu = invoker.toolchain_cpu
+ forward_variables_from(invoker, "*")
is_clang = true
}
}
android_gcc_toolchains_helper("x86") {
- android_ndk_sysroot = "$android_ndk_root/$x86_android_sysroot_subdir"
- android_ndk_lib_dir = "usr/lib"
-
toolchain_cpu = "x86"
+ toolchain_root = x86_android_toolchain_root
+ sysroot = "$android_ndk_root/$x86_android_sysroot_subdir"
+ lib_dir = "usr/lib"
+ binary_prefix = "i686-linux-android"
}
android_gcc_toolchains_helper("arm") {
- android_ndk_sysroot = "$android_ndk_root/$arm_android_sysroot_subdir"
- android_ndk_lib_dir = "usr/lib"
-
toolchain_cpu = "arm"
+ toolchain_root = arm_android_toolchain_root
+ sysroot = "$android_ndk_root/$arm_android_sysroot_subdir"
+ lib_dir = "usr/lib"
+ binary_prefix = "arm-linux-androideabi"
}
android_gcc_toolchains_helper("mipsel") {
- android_ndk_sysroot = "$android_ndk_root/$mips_android_sysroot_subdir"
- android_ndk_lib_dir = "usr/lib"
-
toolchain_cpu = "mipsel"
+ toolchain_root = mips_android_toolchain_root
+ sysroot = "$android_ndk_root/$mips_android_sysroot_subdir"
+ lib_dir = "usr/lib"
+ binary_prefix = "mipsel-linux-android"
}
android_gcc_toolchains_helper("x64") {
- android_ndk_sysroot = "$android_ndk_root/$x86_64_android_sysroot_subdir"
- android_ndk_lib_dir = "usr/lib64"
-
toolchain_cpu = "x86_64"
+ toolchain_root = x86_64_android_toolchain_root
+ sysroot = "$android_ndk_root/$x86_64_android_sysroot_subdir"
+ lib_dir = "usr/lib64"
+ binary_prefix = "x86_64-linux-android"
}
android_gcc_toolchains_helper("arm64") {
- android_ndk_sysroot = "$android_ndk_root/$arm64_android_sysroot_subdir"
- android_ndk_lib_dir = "usr/lib"
-
- toolchain_cpu = "aarch64"
+ toolchain_cpu = "arm64"
+ toolchain_root = arm64_android_toolchain_root
+ sysroot = "$android_ndk_root/$arm64_android_sysroot_subdir"
+ lib_dir = "usr/lib"
+ binary_prefix = "aarch64-linux-android"
}
android_gcc_toolchains_helper("mips64el") {
- android_ndk_sysroot = "$android_ndk_root/$mips64_android_sysroot_subdir"
- android_ndk_lib_dir = "usr/lib64"
-
toolchain_cpu = "mips64el"
+ toolchain_root = mips64_android_toolchain_root
+ sysroot = "$android_ndk_root/$mips64_android_sysroot_subdir"
+ lib_dir = "usr/lib64"
+ binary_prefix = "mips64el-linux-android"
}
« 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