chromium/build/config/android/BUILD.gn

# Copyright 2014 The Chromium Authors
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.

import("//build/config/android/rules.gni")
import("//build/config/c++/c++.gni")
import("//build/config/compiler/compiler.gni")
import("//build/config/sanitizers/sanitizers.gni")

if (current_toolchain == default_toolchain) {
  import("//build/toolchain/concurrent_links.gni")
}

assert(is_android)

# This is included by reference in the //build/config/compiler config that
# is applied to all targets. It is here to separate out the logic that is
# Android-only.
config("compiler") {
  cflags = [
    "-ffunction-sections",
    "-fno-short-enums",
  ]
  defines = [
    "ANDROID",

    # https://android.googlesource.com/platform/ndk/+/master/docs/BuildSystemMaintainers.md#weak-symbols-for-api-definitions
    "__ANDROID_UNAVAILABLE_SYMBOLS_ARE_WEAK__",

    # The NDK has these things, but doesn't define the constants to say that it
    # does. Define them here instead.
    "HAVE_SYS_UIO_H",

    # Forces full rebuilds on NDK rolls. To rebuild everything when NDK version
    # stays the same, increment the suffix number.
    "ANDROID_NDK_VERSION_ROLL=${android_ndk_version}_1",
  ]

  if (android_64bit_current_cpu) {
    _max_page_size = 16384
  } else {
    _max_page_size = 4096
  }

  ldflags = [
    # Don't allow visible symbols from libraries that contain
    # assembly code with symbols that aren't hidden properly.
    # http://crbug.com/448386
    "-Wl,--exclude-libs=libvpx_assembly_arm.a",

    # Reduce the page size from 65536 in order to reduce binary size slightly
    # by shrinking the alignment gap between segments. This also causes all
    # segments to be mapped adjacently, which breakpad relies on.
    "-Wl,-z,max-page-size=$_max_page_size",
  ]

  if (current_cpu == "arm64") {
    if (arm_control_flow_integrity == "standard") {
      cflags += [ "-mbranch-protection=standard" ]
      rustflags = [ "-Zbranch-protection=bti" ]
    } else if (arm_control_flow_integrity == "pac") {
      cflags += [ "-mbranch-protection=pac-ret" ]
      rustflags = [ "-Zbranch-protection=pac-ret" ]
    }
  }

  # Disable TLSDESC for riscv64 until the Android NDK supports it. While
  # Chromium's clang turns it on by default for Android RISC-V devices, NDK r27
  # currently has it disabled. This can likely be removed in NDK r28.
  if (current_cpu == "riscv64") {
    cflags += [ "-mtls-dialect=trad" ]
  }

  # $compile_api_level corresponds to the API level used for the sysroot path
  # calculation in //build/config/android/config.gni
  if (android_64bit_target_cpu) {
    compile_api_level = android64_ndk_api_level
  } else {
    compile_api_level = android32_ndk_api_level
  }

  cflags += [ "--target=$android_abi_target$compile_api_level" ]
  ldflags += [ "--target=$android_abi_target$compile_api_level" ]

  # Assign any flags set for the C compiler to asmflags so that they are sent
  # to the assembler.
  asmflags = cflags
}

# This is included by reference in the //build/config/compiler:runtime_library
# config that is applied to all targets. It is here to separate out the logic
# that is Android-only. Please see that target for advice on what should go in
# :runtime_library vs. :compiler.
config("runtime_library") {
}

config("hide_all_but_jni_onload") {
  ldflags = [ "-Wl,--version-script=" + rebase_path(
                  "//build/android/android_only_explicit_jni_exports.lst",
                  root_build_dir) ]
}

config("hide_all_but_jni") {
  ldflags = [ "-Wl,--version-script=" +
              rebase_path("//build/android/android_only_jni_exports.lst",
                          root_build_dir) ]
}

config("lld_pack_relocations") {
  ldflags = [ "-Wl,--pack-dyn-relocs=android" ]
}

config("lld_relr_relocations") {
  # RELR supported API 30+, but supported 28+ with --use-android-relr-tags.
  # https://android.googlesource.com/platform/bionic/+/master/android-changes-for-ndk-developers.md#relative-relocations-relr
  ldflags = [ "-Wl,--pack-dyn-relocs=relr,--use-android-relr-tags" ]
}

config("lld_branch_target_hardening") {
  # Config opts a shared library into BTI linker hardening. This
  # is an opt-in config (rather than default-enabled) to avoid
  # interfering with the V8 CFI bots (crbug.com/1334614).
  if (current_cpu == "arm64") {
    if (arm_control_flow_integrity == "standard") {
      # Linking objects without GNU_PROPERTY_AARCH64_FEATURE_1_BTI
      # in their .gnu.note section implicitly results in the final
      # binary losing Branch Target Identification (BTI) support.
      # Issue a warning if this happens.
      ldflags = [ "-Wl,-z,force-bti" ]
    }
  }
}

# Used for instrumented build to generate the orderfile.
config("default_orderfile_instrumentation") {
  if (use_order_profiling) {
    cflags = [ "-finstrument-function-entry-bare" ]
    if (use_thin_lto) {
      # TODO(pcc): This should not be necessary. Remove once
      # https://reviews.llvm.org/D50016 lands and gets rolled in.
      ldflags = [ "-Wl,-u,__cyg_profile_func_enter_bare" ]
    }
  }
}

if (current_toolchain == default_toolchain) {
  # nocompile tests share output directory to avoid them all needing to rebuild
  # things. But this also means they can't run in parallel.
  pool("nocompile_pool") {
    depth = 1
  }

  # When defined, this pool should be used instead of link_pool for command
  # that need 1-2GB of RAM. https://crbug.com/1078460
  if (defined(java_cmd_pool_size)) {
    pool("java_cmd_pool") {
      depth = java_cmd_pool_size
    }
  }
}