xref: /aosp_15_r20/external/cronet/build/config/android/BUILD.gn (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker# Copyright 2014 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker# Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker# found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker
5*6777b538SAndroid Build Coastguard Workerimport("//build/config/android/rules.gni")
6*6777b538SAndroid Build Coastguard Workerimport("//build/config/c++/c++.gni")
7*6777b538SAndroid Build Coastguard Workerimport("//build/config/compiler/compiler.gni")
8*6777b538SAndroid Build Coastguard Workerimport("//build/config/sanitizers/sanitizers.gni")
9*6777b538SAndroid Build Coastguard Worker
10*6777b538SAndroid Build Coastguard Workerif (current_toolchain == default_toolchain) {
11*6777b538SAndroid Build Coastguard Worker  import("//build/toolchain/concurrent_links.gni")
12*6777b538SAndroid Build Coastguard Worker}
13*6777b538SAndroid Build Coastguard Worker
14*6777b538SAndroid Build Coastguard Workerassert(is_android)
15*6777b538SAndroid Build Coastguard Worker
16*6777b538SAndroid Build Coastguard Worker# This is included by reference in the //build/config/compiler config that
17*6777b538SAndroid Build Coastguard Worker# is applied to all targets. It is here to separate out the logic that is
18*6777b538SAndroid Build Coastguard Worker# Android-only.
19*6777b538SAndroid Build Coastguard Workerconfig("compiler") {
20*6777b538SAndroid Build Coastguard Worker  cflags = [
21*6777b538SAndroid Build Coastguard Worker    "-ffunction-sections",
22*6777b538SAndroid Build Coastguard Worker    "-fno-short-enums",
23*6777b538SAndroid Build Coastguard Worker  ]
24*6777b538SAndroid Build Coastguard Worker  defines = [
25*6777b538SAndroid Build Coastguard Worker    "ANDROID",
26*6777b538SAndroid Build Coastguard Worker
27*6777b538SAndroid Build Coastguard Worker    # https://android.googlesource.com/platform/ndk/+/master/docs/BuildSystemMaintainers.md#weak-symbols-for-api-definitions
28*6777b538SAndroid Build Coastguard Worker    "__ANDROID_UNAVAILABLE_SYMBOLS_ARE_WEAK__",
29*6777b538SAndroid Build Coastguard Worker
30*6777b538SAndroid Build Coastguard Worker    # The NDK has these things, but doesn't define the constants to say that it
31*6777b538SAndroid Build Coastguard Worker    # does. Define them here instead.
32*6777b538SAndroid Build Coastguard Worker    "HAVE_SYS_UIO_H",
33*6777b538SAndroid Build Coastguard Worker
34*6777b538SAndroid Build Coastguard Worker    # Forces full rebuilds on NDK rolls. To rebuild everything when NDK version
35*6777b538SAndroid Build Coastguard Worker    # stays the same, increment the suffix number.
36*6777b538SAndroid Build Coastguard Worker    "ANDROID_NDK_VERSION_ROLL=${android_ndk_version}_1",
37*6777b538SAndroid Build Coastguard Worker  ]
38*6777b538SAndroid Build Coastguard Worker
39*6777b538SAndroid Build Coastguard Worker  if (android_64bit_current_cpu) {
40*6777b538SAndroid Build Coastguard Worker    _max_page_size = 16384
41*6777b538SAndroid Build Coastguard Worker  } else {
42*6777b538SAndroid Build Coastguard Worker    _max_page_size = 4096
43*6777b538SAndroid Build Coastguard Worker  }
44*6777b538SAndroid Build Coastguard Worker
45*6777b538SAndroid Build Coastguard Worker  ldflags = [
46*6777b538SAndroid Build Coastguard Worker    # Don't allow visible symbols from libraries that contain
47*6777b538SAndroid Build Coastguard Worker    # assembly code with symbols that aren't hidden properly.
48*6777b538SAndroid Build Coastguard Worker    # http://crbug.com/448386
49*6777b538SAndroid Build Coastguard Worker    "-Wl,--exclude-libs=libvpx_assembly_arm.a",
50*6777b538SAndroid Build Coastguard Worker
51*6777b538SAndroid Build Coastguard Worker    # Reduce the page size from 65536 in order to reduce binary size slightly
52*6777b538SAndroid Build Coastguard Worker    # by shrinking the alignment gap between segments. This also causes all
53*6777b538SAndroid Build Coastguard Worker    # segments to be mapped adjacently, which breakpad relies on.
54*6777b538SAndroid Build Coastguard Worker    "-Wl,-z,max-page-size=$_max_page_size",
55*6777b538SAndroid Build Coastguard Worker  ]
56*6777b538SAndroid Build Coastguard Worker
57*6777b538SAndroid Build Coastguard Worker  if (current_cpu == "arm64") {
58*6777b538SAndroid Build Coastguard Worker    if (arm_control_flow_integrity == "standard") {
59*6777b538SAndroid Build Coastguard Worker      cflags += [ "-mbranch-protection=standard" ]
60*6777b538SAndroid Build Coastguard Worker      rustflags = [ "-Zbranch-protection=bti" ]
61*6777b538SAndroid Build Coastguard Worker    } else if (arm_control_flow_integrity == "pac") {
62*6777b538SAndroid Build Coastguard Worker      cflags += [ "-mbranch-protection=pac-ret" ]
63*6777b538SAndroid Build Coastguard Worker      rustflags = [ "-Zbranch-protection=pac-ret" ]
64*6777b538SAndroid Build Coastguard Worker    }
65*6777b538SAndroid Build Coastguard Worker  }
66*6777b538SAndroid Build Coastguard Worker
67*6777b538SAndroid Build Coastguard Worker  # $compile_api_level corresponds to the API level used for the sysroot path
68*6777b538SAndroid Build Coastguard Worker  # calculation in //build/config/android/config.gni
69*6777b538SAndroid Build Coastguard Worker  if (android_64bit_target_cpu) {
70*6777b538SAndroid Build Coastguard Worker    compile_api_level = android64_ndk_api_level
71*6777b538SAndroid Build Coastguard Worker  } else {
72*6777b538SAndroid Build Coastguard Worker    compile_api_level = android32_ndk_api_level
73*6777b538SAndroid Build Coastguard Worker  }
74*6777b538SAndroid Build Coastguard Worker
75*6777b538SAndroid Build Coastguard Worker  cflags += [ "--target=$android_abi_target$compile_api_level" ]
76*6777b538SAndroid Build Coastguard Worker  ldflags += [ "--target=$android_abi_target$compile_api_level" ]
77*6777b538SAndroid Build Coastguard Worker
78*6777b538SAndroid Build Coastguard Worker  # Assign any flags set for the C compiler to asmflags so that they are sent
79*6777b538SAndroid Build Coastguard Worker  # to the assembler.
80*6777b538SAndroid Build Coastguard Worker  asmflags = cflags
81*6777b538SAndroid Build Coastguard Worker}
82*6777b538SAndroid Build Coastguard Worker
83*6777b538SAndroid Build Coastguard Worker# This is included by reference in the //build/config/compiler:runtime_library
84*6777b538SAndroid Build Coastguard Worker# config that is applied to all targets. It is here to separate out the logic
85*6777b538SAndroid Build Coastguard Worker# that is Android-only. Please see that target for advice on what should go in
86*6777b538SAndroid Build Coastguard Worker# :runtime_library vs. :compiler.
87*6777b538SAndroid Build Coastguard Workerconfig("runtime_library") {
88*6777b538SAndroid Build Coastguard Worker}
89*6777b538SAndroid Build Coastguard Worker
90*6777b538SAndroid Build Coastguard Workerconfig("hide_all_but_jni_onload") {
91*6777b538SAndroid Build Coastguard Worker  ldflags = [ "-Wl,--version-script=" + rebase_path(
92*6777b538SAndroid Build Coastguard Worker                  "//build/android/android_only_explicit_jni_exports.lst",
93*6777b538SAndroid Build Coastguard Worker                  root_build_dir) ]
94*6777b538SAndroid Build Coastguard Worker}
95*6777b538SAndroid Build Coastguard Worker
96*6777b538SAndroid Build Coastguard Workerconfig("hide_all_but_jni") {
97*6777b538SAndroid Build Coastguard Worker  ldflags = [ "-Wl,--version-script=" +
98*6777b538SAndroid Build Coastguard Worker              rebase_path("//build/android/android_only_jni_exports.lst",
99*6777b538SAndroid Build Coastguard Worker                          root_build_dir) ]
100*6777b538SAndroid Build Coastguard Worker}
101*6777b538SAndroid Build Coastguard Worker
102*6777b538SAndroid Build Coastguard Workerconfig("lld_pack_relocations") {
103*6777b538SAndroid Build Coastguard Worker  ldflags = [ "-Wl,--pack-dyn-relocs=android" ]
104*6777b538SAndroid Build Coastguard Worker}
105*6777b538SAndroid Build Coastguard Worker
106*6777b538SAndroid Build Coastguard Workerconfig("lld_relr_relocations") {
107*6777b538SAndroid Build Coastguard Worker  # RELR supported API 30+, but supported 28+ with --use-android-relr-tags.
108*6777b538SAndroid Build Coastguard Worker  # https://android.googlesource.com/platform/bionic/+/master/android-changes-for-ndk-developers.md#relative-relocations-relr
109*6777b538SAndroid Build Coastguard Worker  ldflags = [ "-Wl,--pack-dyn-relocs=relr,--use-android-relr-tags" ]
110*6777b538SAndroid Build Coastguard Worker}
111*6777b538SAndroid Build Coastguard Worker
112*6777b538SAndroid Build Coastguard Workerconfig("lld_branch_target_hardening") {
113*6777b538SAndroid Build Coastguard Worker  # Config opts a shared library into BTI linker hardening. This
114*6777b538SAndroid Build Coastguard Worker  # is an opt-in config (rather than default-enabled) to avoid
115*6777b538SAndroid Build Coastguard Worker  # interfering with the V8 CFI bots (crbug.com/1334614).
116*6777b538SAndroid Build Coastguard Worker  if (current_cpu == "arm64") {
117*6777b538SAndroid Build Coastguard Worker    if (arm_control_flow_integrity == "standard") {
118*6777b538SAndroid Build Coastguard Worker      # Linking objects without GNU_PROPERTY_AARCH64_FEATURE_1_BTI
119*6777b538SAndroid Build Coastguard Worker      # in their .gnu.note section implicitly results in the final
120*6777b538SAndroid Build Coastguard Worker      # binary losing Branch Target Identification (BTI) support.
121*6777b538SAndroid Build Coastguard Worker      # Issue a warning if this happens.
122*6777b538SAndroid Build Coastguard Worker      ldflags = [ "-Wl,-z,force-bti" ]
123*6777b538SAndroid Build Coastguard Worker    }
124*6777b538SAndroid Build Coastguard Worker  }
125*6777b538SAndroid Build Coastguard Worker}
126*6777b538SAndroid Build Coastguard Worker
127*6777b538SAndroid Build Coastguard Worker# Used for instrumented build to generate the orderfile.
128*6777b538SAndroid Build Coastguard Workerconfig("default_orderfile_instrumentation") {
129*6777b538SAndroid Build Coastguard Worker  if (use_order_profiling) {
130*6777b538SAndroid Build Coastguard Worker    cflags = [ "-finstrument-function-entry-bare" ]
131*6777b538SAndroid Build Coastguard Worker    if (use_thin_lto) {
132*6777b538SAndroid Build Coastguard Worker      # TODO(pcc): This should not be necessary. Remove once
133*6777b538SAndroid Build Coastguard Worker      # https://reviews.llvm.org/D50016 lands and gets rolled in.
134*6777b538SAndroid Build Coastguard Worker      ldflags = [ "-Wl,-u,__cyg_profile_func_enter_bare" ]
135*6777b538SAndroid Build Coastguard Worker    }
136*6777b538SAndroid Build Coastguard Worker  }
137*6777b538SAndroid Build Coastguard Worker}
138*6777b538SAndroid Build Coastguard Worker
139*6777b538SAndroid Build Coastguard Workerif (current_toolchain == default_toolchain) {
140*6777b538SAndroid Build Coastguard Worker  # nocompile tests share output directory to avoid them all needing to rebuild
141*6777b538SAndroid Build Coastguard Worker  # things. But this also means they can't run in parallel.
142*6777b538SAndroid Build Coastguard Worker  pool("nocompile_pool") {
143*6777b538SAndroid Build Coastguard Worker    depth = 1
144*6777b538SAndroid Build Coastguard Worker  }
145*6777b538SAndroid Build Coastguard Worker
146*6777b538SAndroid Build Coastguard Worker  # When defined, this pool should be used instead of link_pool for command
147*6777b538SAndroid Build Coastguard Worker  # that need 1-2GB of RAM. https://crbug.com/1078460
148*6777b538SAndroid Build Coastguard Worker  if (defined(java_cmd_pool_size)) {
149*6777b538SAndroid Build Coastguard Worker    pool("java_cmd_pool") {
150*6777b538SAndroid Build Coastguard Worker      depth = java_cmd_pool_size
151*6777b538SAndroid Build Coastguard Worker    }
152*6777b538SAndroid Build Coastguard Worker  }
153*6777b538SAndroid Build Coastguard Worker}
154