| Index: build/toolchain/android/BUILD.gn
|
| diff --git a/build/toolchain/android/BUILD.gn b/build/toolchain/android/BUILD.gn
|
| index bdf26323e6e7d04f78144c3702e7d986bec22312..dc3bfeddab776e9bdfe9da5358d7e68599319f4b 100644
|
| --- a/build/toolchain/android/BUILD.gn
|
| +++ b/build/toolchain/android/BUILD.gn
|
| @@ -2,49 +2,66 @@
|
| # Use of this source code is governed by a BSD-style license that can be
|
| # found in the LICENSE file.
|
|
|
| -import("//build/config/android/config.gni")
|
| +import("//build/config/sysroot.gni") # Imports android/config.gni.
|
| import("//build/toolchain/clang.gni")
|
| import("//build/toolchain/goma.gni")
|
| import("//build/toolchain/gcc_toolchain.gni")
|
|
|
| -# Get the Android version of the name of the build host's architecture.
|
| -if (build_cpu_arch == "x64") {
|
| - android_host_arch = "x86_64"
|
| -} else if (build_cpu_arch == "x86") {
|
| - android_host_arch = "x86"
|
| -} else {
|
| - assert(false, "Need Android toolchain support for your build OS.")
|
| +# The Android GCC toolchains share most of the same parameters, so we have this
|
| +# 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.
|
| +# - tool_prefix
|
| +# Prefix to be added to the tool names.
|
| +# - toolchain_cpu_arch
|
| +# Same as gcc_toolchain
|
| +template("android_gcc_toolchain") {
|
| + gcc_toolchain(target_name) {
|
| + # 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)
|
| +
|
| + libs_section_prefix = "$android_ndk_lib/crtbegin_dynamic.o"
|
| + libs_section_postfix = "$android_ndk_lib/crtend_android.o"
|
| +
|
| + # The tools should be run relative to the build dir.
|
| + tool_prefix = rebase_path(invoker.tool_prefix, root_build_dir)
|
| +
|
| + cc = tool_prefix + "gcc"
|
| + cxx = tool_prefix + "g++"
|
| + ar = tool_prefix + "ar"
|
| + ld = cxx
|
| +
|
| + toolchain_os = "android"
|
| + toolchain_cpu_arch = invoker.toolchain_cpu_arch
|
| + }
|
| }
|
|
|
| -gcc_toolchain("x86") {
|
| - prefix = "$android_ndk_root/toolchains/x86-4.6/prebuilt/$build_os-$android_host_arch/bin/i686-linux-android-"
|
| - cc = prefix + "gcc"
|
| - cxx = prefix + "g++"
|
| - ar = prefix + "ar"
|
| - ld = cxx
|
| +android_gcc_toolchain("x86") {
|
| + android_ndk_sysroot = "$android_ndk_root/$x86_android_sysroot_subdir"
|
| + android_ndk_lib_dir = "usr/lib"
|
|
|
| + tool_prefix = "$x86_android_toolchain_root/bin/i686-linux-android-"
|
| toolchain_cpu_arch = "x86"
|
| - toolchain_os = "android"
|
| }
|
|
|
| -gcc_toolchain("arm") {
|
| - prefix = "$android_ndk_root/toolchains/arm-linux-androideabi-4.6/prebuilt/$build_os-$android_host_arch/bin/arm-linux-androideabi-"
|
| - cc = prefix + "gcc"
|
| - cxx = prefix + "g++"
|
| - ar = prefix + "ar"
|
| - ld = cxx
|
| +android_gcc_toolchain("arm") {
|
| + android_ndk_sysroot = "$android_ndk_root/$arm_android_sysroot_subdir"
|
| + android_ndk_lib_dir = "usr/lib"
|
|
|
| + tool_prefix = "$arm_android_toolchain_root/bin/arm-linux-androideabi-"
|
| toolchain_cpu_arch = "arm"
|
| - toolchain_os = "android"
|
| }
|
|
|
| -gcc_toolchain("mipsel") {
|
| - prefix = "$android_ndk_root/toolchains/mipsel-linux-android-4.6/prebuilt/$build_os-$android_host_arch/bin/mipsel-linux-android-"
|
| - cc = prefix + "gcc"
|
| - cxx = prefix + "g++"
|
| - ar = prefix + "ar"
|
| - ld = cxx
|
| +android_gcc_toolchain("mipsel") {
|
| + android_ndk_sysroot = "$android_ndk_root/$mips_android_sysroot_subdir"
|
| + android_ndk_lib_dir = "usr/lib"
|
|
|
| + tool_prefix = "$mips_android_toolchain_root/bin/mipsel-linux-android-"
|
| toolchain_cpu_arch = "mipsel"
|
| - toolchain_os = "android"
|
| }
|
|
|