blob: 7e960a7fae2654f301a362e80fb235839f8b438a [file] [log] [blame]
Colin Cross4d9c2d12016-07-29 12:48:20 -07001// Copyright 2016 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15package cc
16
17import (
Inseob Kim69378442019-06-03 19:10:47 +090018 "fmt"
Logan Chien41eabe62019-04-10 13:33:58 +080019 "io"
Jiyong Parkf1194352019-02-25 11:05:47 +090020 "path/filepath"
Jiyong Parkda732bd2018-11-02 18:23:15 +090021 "regexp"
Jooyung Han11b0fbd2021-02-05 02:28:22 +090022 "strconv"
Colin Cross4d9c2d12016-07-29 12:48:20 -070023 "strings"
Jiyong Parkda732bd2018-11-02 18:23:15 +090024 "sync"
Colin Cross4d9c2d12016-07-29 12:48:20 -070025
Colin Cross127bb8b2020-12-16 16:46:01 -080026 "github.com/google/blueprint"
Colin Cross26c34ed2016-09-30 17:10:16 -070027 "github.com/google/blueprint/pathtools"
Colin Cross4d9c2d12016-07-29 12:48:20 -070028
Colin Cross4d9c2d12016-07-29 12:48:20 -070029 "android/soong/android"
Rupert Shuttleworth095081c2021-03-25 09:06:03 +000030 "android/soong/bazel"
Dan Albertea4b7b92018-04-25 16:05:30 -070031 "android/soong/cc/config"
Colin Cross4d9c2d12016-07-29 12:48:20 -070032)
33
Chris Parsons3c27ca32020-11-20 12:42:07 -050034// LibraryProperties is a collection of properties shared by cc library rules.
Colin Crossb916a382016-07-29 17:28:03 -070035type LibraryProperties struct {
Colin Cross4d9c2d12016-07-29 12:48:20 -070036 // local file name to pass to the linker as -unexported_symbols_list
Colin Cross27b922f2019-03-04 22:35:41 -080037 Unexported_symbols_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070038 // local file name to pass to the linker as -force_symbols_not_weak_list
Colin Cross27b922f2019-03-04 22:35:41 -080039 Force_symbols_not_weak_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070040 // local file name to pass to the linker as -force_symbols_weak_list
Colin Cross27b922f2019-03-04 22:35:41 -080041 Force_symbols_weak_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070042
43 // rename host libraries to prevent overlap with system installed libraries
44 Unique_host_soname *bool
45
Dan Willemsene1240db2016-11-03 14:28:51 -070046 Aidl struct {
47 // export headers generated from .aidl sources
Nan Zhang0007d812017-11-07 10:57:05 -080048 Export_aidl_headers *bool
Dan Willemsene1240db2016-11-03 14:28:51 -070049 }
50
Colin Cross0c461f12016-10-20 16:11:43 -070051 Proto struct {
52 // export headers generated from .proto sources
Nan Zhang0007d812017-11-07 10:57:05 -080053 Export_proto_headers *bool
Colin Cross0c461f12016-10-20 16:11:43 -070054 }
Dan Albertf563d252017-10-13 00:29:00 -070055
Inseob Kimc0907f12019-02-08 21:00:45 +090056 Sysprop struct {
57 // Whether platform owns this sysprop library.
58 Platform *bool
Inseob Kimb3f22ca2019-03-05 12:40:24 +090059 } `blueprint:"mutated"`
Inseob Kimc0907f12019-02-08 21:00:45 +090060
Nan Zhang0007d812017-11-07 10:57:05 -080061 Static_ndk_lib *bool
Jiyong Park7ed9de32018-10-15 22:25:07 +090062
Florian Mayer6dab96c2020-12-31 11:39:48 +000063 // Generate stubs to make this library accessible to APEXes.
Jiyong Park7ed9de32018-10-15 22:25:07 +090064 Stubs struct {
65 // Relative path to the symbol map. The symbol map provides the list of
66 // symbols that are exported for stubs variant of this library.
Colin Cross27b922f2019-03-04 22:35:41 -080067 Symbol_file *string `android:"path"`
Jiyong Park7ed9de32018-10-15 22:25:07 +090068
Jiyong Parkd4a3a132021-03-17 20:21:35 +090069 // List versions to generate stubs libs for. The version name "current" is always
70 // implicitly added.
Jiyong Park7ed9de32018-10-15 22:25:07 +090071 Versions []string
72 }
dimitryd95964a2018-11-07 13:43:34 +010073
74 // set the name of the output
75 Stem *string `android:"arch_variant"`
76
Colin Cross0fd6a412019-08-16 14:22:10 -070077 // set suffix of the name of the output
78 Suffix *string `android:"arch_variant"`
79
80 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +090081 Vendor, Product struct {
Colin Cross0fd6a412019-08-16 14:22:10 -070082 // set suffix of the name of the output
83 Suffix *string `android:"arch_variant"`
84 }
85 }
86
dimitryd95964a2018-11-07 13:43:34 +010087 // Names of modules to be overridden. Listed modules can only be other shared libraries
88 // (in Make or Soong).
89 // This does not completely prevent installation of the overridden libraries, but if both
90 // binaries would be installed by default (in PRODUCT_PACKAGES) the other library will be removed
91 // from PRODUCT_PACKAGES.
92 Overrides []string
Logan Chiene3d7a0d2019-01-17 00:18:02 +080093
94 // Properties for ABI compatibility checker
95 Header_abi_checker struct {
Logan Chien41eabe62019-04-10 13:33:58 +080096 // Enable ABI checks (even if this is not an LLNDK/VNDK lib)
97 Enabled *bool
98
Logan Chiene3d7a0d2019-01-17 00:18:02 +080099 // Path to a symbol file that specifies the symbols to be included in the generated
100 // ABI dump file
Colin Cross27b922f2019-03-04 22:35:41 -0800101 Symbol_file *string `android:"path"`
Logan Chiene3d7a0d2019-01-17 00:18:02 +0800102
103 // Symbol versions that should be ignored from the symbol file
104 Exclude_symbol_versions []string
105
106 // Symbol tags that should be ignored from the symbol file
107 Exclude_symbol_tags []string
Logan Chien2a65dda2019-10-01 15:58:07 -0700108
109 // Run checks on all APIs (in addition to the ones referred by
110 // one of exported ELF symbols.)
111 Check_all_apis *bool
Logan Chiene3d7a0d2019-01-17 00:18:02 +0800112 }
Vic Yang6cd1be82019-06-24 16:08:48 -0700113
114 // Order symbols in .bss section by their sizes. Only useful for shared libraries.
115 Sort_bss_symbols_by_size *bool
Pete Bentley803e1612019-08-06 22:19:59 +0100116
117 // Inject boringssl hash into the shared library. This is only intended for use by external/boringssl.
118 Inject_bssl_hash *bool `android:"arch_variant"`
Colin Cross0477b422020-10-13 18:43:54 -0700119
Colin Cross127bb8b2020-12-16 16:46:01 -0800120 // If this is an LLNDK library, properties to describe the LLNDK stubs. Will be copied from
121 // the module pointed to by llndk_stubs if it is set.
122 Llndk llndkLibraryProperties
Colin Cross5271fea2021-04-27 13:06:04 -0700123
124 // If this is a vendor public library, properties to describe the vendor public library stubs.
125 Vendor_public_library vendorPublicLibraryProperties
Colin Crossa48ab5b2017-02-14 15:28:44 -0800126}
Colin Cross0c461f12016-10-20 16:11:43 -0700127
Chris Parsons3c27ca32020-11-20 12:42:07 -0500128// StaticProperties is a properties stanza to affect only attributes of the "static" variants of a
129// library module.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700130type StaticProperties struct {
131 Static StaticOrSharedProperties `android:"arch_variant"`
132}
133
Chris Parsons3c27ca32020-11-20 12:42:07 -0500134// SharedProperties is a properties stanza to affect only attributes of the "shared" variants of a
135// library module.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700136type SharedProperties struct {
137 Shared StaticOrSharedProperties `android:"arch_variant"`
138}
139
Chris Parsons3c27ca32020-11-20 12:42:07 -0500140// StaticOrSharedProperties is an embedded struct representing properties to affect attributes of
141// either only the "static" variants or only the "shared" variants of a library module. These override
142// the base properties of the same name.
143// Use `StaticProperties` or `SharedProperties`, depending on which variant is needed.
144// `StaticOrSharedProperties` exists only to avoid duplication.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700145type StaticOrSharedProperties struct {
Evgenii Stepanov2080bfe2020-07-24 15:35:40 -0700146 Srcs []string `android:"path,arch_variant"`
147
148 Sanitized Sanitized `android:"arch_variant"`
149
Colin Crosse1bb5d02019-09-24 14:55:04 -0700150 Cflags []string `android:"arch_variant"`
151
152 Enabled *bool `android:"arch_variant"`
153 Whole_static_libs []string `android:"arch_variant"`
154 Static_libs []string `android:"arch_variant"`
155 Shared_libs []string `android:"arch_variant"`
156 System_shared_libs []string `android:"arch_variant"`
157
158 Export_shared_lib_headers []string `android:"arch_variant"`
159 Export_static_lib_headers []string `android:"arch_variant"`
Jiyong Parka90ca002019-10-07 15:47:24 +0900160
161 Apex_available []string `android:"arch_variant"`
Colin Crosse1bb5d02019-09-24 14:55:04 -0700162}
163
Colin Crossa48ab5b2017-02-14 15:28:44 -0800164type LibraryMutatedProperties struct {
Colin Crossb916a382016-07-29 17:28:03 -0700165 // Build a static variant
166 BuildStatic bool `blueprint:"mutated"`
167 // Build a shared variant
168 BuildShared bool `blueprint:"mutated"`
169 // This variant is shared
170 VariantIsShared bool `blueprint:"mutated"`
171 // This variant is static
172 VariantIsStatic bool `blueprint:"mutated"`
Jiyong Park7ed9de32018-10-15 22:25:07 +0900173
174 // This variant is a stubs lib
175 BuildStubs bool `blueprint:"mutated"`
Jiyong Parkd4a3a132021-03-17 20:21:35 +0900176 // This variant is the latest version
177 IsLatestVersion bool `blueprint:"mutated"`
Jiyong Park7ed9de32018-10-15 22:25:07 +0900178 // Version of the stubs lib
179 StubsVersion string `blueprint:"mutated"`
Colin Crossd1f898e2020-08-18 18:35:15 -0700180 // List of all stubs versions associated with an implementation lib
181 AllStubsVersions []string `blueprint:"mutated"`
Colin Crossb916a382016-07-29 17:28:03 -0700182}
183
184type FlagExporterProperties struct {
185 // list of directories relative to the Blueprints file that will
Dan Willemsen273af7f2016-11-03 15:53:42 -0700186 // be added to the include path (using -I) for this module and any module that links
Colin Cross5d195602017-10-17 16:15:50 -0700187 // against this module. Directories listed in export_include_dirs do not need to be
188 // listed in local_include_dirs.
Colin Crossb916a382016-07-29 17:28:03 -0700189 Export_include_dirs []string `android:"arch_variant"`
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700190
Jiyong Park73c54ee2019-10-22 20:31:18 +0900191 // list of directories that will be added to the system include path
192 // using -isystem for this module and any module that links against this module.
193 Export_system_include_dirs []string `android:"arch_variant"`
194
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700195 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +0900196 Vendor, Product struct {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700197 // list of exported include directories, like
Justin Yun63e9ec72020-10-29 16:49:43 +0900198 // export_include_dirs, that will be applied to
199 // vendor or product variant of this library.
200 // This will overwrite any other declarations.
Steven Morelandb21df8f2018-01-05 14:42:54 -0800201 Override_export_include_dirs []string
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700202 }
203 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700204}
205
206func init() {
Paul Duffin6c26dc72019-12-19 15:02:40 +0000207 RegisterLibraryBuildComponents(android.InitRegistrationContext)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +0000208
209 android.RegisterBp2BuildMutator("cc_library_static", CcLibraryStaticBp2Build)
Jingwen Chen63930982021-03-24 10:04:33 -0400210 android.RegisterBp2BuildMutator("cc_library", CcLibraryBp2Build)
Paul Duffin6c26dc72019-12-19 15:02:40 +0000211}
212
213func RegisterLibraryBuildComponents(ctx android.RegistrationContext) {
214 ctx.RegisterModuleType("cc_library_static", LibraryStaticFactory)
215 ctx.RegisterModuleType("cc_library_shared", LibrarySharedFactory)
216 ctx.RegisterModuleType("cc_library", LibraryFactory)
217 ctx.RegisterModuleType("cc_library_host_static", LibraryHostStaticFactory)
218 ctx.RegisterModuleType("cc_library_host_shared", LibraryHostSharedFactory)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700219}
220
Jingwen Chen63930982021-03-24 10:04:33 -0400221// For bp2build conversion.
222type bazelCcLibraryAttributes struct {
Jingwen Chen53681ef2021-04-29 08:15:13 +0000223 Srcs bazel.LabelListAttribute
224 Hdrs bazel.LabelListAttribute
225 Copts bazel.StringListAttribute
226 Linkopts bazel.StringListAttribute
227 Deps bazel.LabelListAttribute
Rupert Shuttleworthc50fa8d2021-05-06 02:40:33 -0400228 Dynamic_deps bazel.LabelListAttribute
Jingwen Chen53681ef2021-04-29 08:15:13 +0000229 User_link_flags bazel.StringListAttribute
230 Includes bazel.StringListAttribute
231 Static_deps_for_shared bazel.LabelListAttribute
Lukacs T. Berki1353e592021-04-30 15:35:09 +0200232 Version_script bazel.LabelAttribute
Jingwen Chen63930982021-03-24 10:04:33 -0400233}
234
235type bazelCcLibrary struct {
236 android.BazelTargetModuleBase
237 bazelCcLibraryAttributes
238}
239
240func (m *bazelCcLibrary) Name() string {
241 return m.BaseModuleName()
242}
243
244func (m *bazelCcLibrary) GenerateAndroidBuildActions(ctx android.ModuleContext) {}
245
246func BazelCcLibraryFactory() android.Module {
247 module := &bazelCcLibrary{}
248 module.AddProperties(&module.bazelCcLibraryAttributes)
249 android.InitBazelTargetModule(module)
250 return module
251}
252
253func CcLibraryBp2Build(ctx android.TopDownMutatorContext) {
254 m, ok := ctx.Module().(*Module)
255 if !ok || !m.ConvertWithBp2build(ctx) {
256 return
257 }
258
259 if ctx.ModuleType() != "cc_library" {
260 return
261 }
262
Jingwen Chen179856a2021-05-03 09:15:48 +0000263 // For some cc_library modules, their static variants are ready to be
264 // converted, but not their shared variants. For these modules, delegate to
265 // the cc_library_static bp2build converter temporarily instead.
266 if android.GenerateCcLibraryStaticOnly(ctx) {
267 ccLibraryStaticBp2BuildInternal(ctx, m)
268 return
269 }
270
Jingwen Chen53681ef2021-04-29 08:15:13 +0000271 sharedAttrs := bp2BuildParseSharedProps(ctx, m)
272 staticAttrs := bp2BuildParseStaticProps(ctx, m)
Jingwen Chen107c0de2021-04-09 10:43:12 +0000273 compilerAttrs := bp2BuildParseCompilerProps(ctx, m)
274 linkerAttrs := bp2BuildParseLinkerProps(ctx, m)
Jingwen Chen882bcc12021-04-27 05:54:20 +0000275 exportedIncludes := bp2BuildParseExportedIncludes(ctx, m)
Jingwen Chen63930982021-03-24 10:04:33 -0400276
Jingwen Chen53681ef2021-04-29 08:15:13 +0000277 var srcs bazel.LabelListAttribute
278 srcs.Append(compilerAttrs.srcs)
279 srcs.Append(staticAttrs.srcs)
280
Jingwen Chen63930982021-03-24 10:04:33 -0400281 attrs := &bazelCcLibraryAttributes{
Jingwen Chen53681ef2021-04-29 08:15:13 +0000282 Srcs: srcs,
283 Copts: compilerAttrs.copts,
284 Linkopts: linkerAttrs.linkopts,
285 Deps: linkerAttrs.deps,
Rupert Shuttleworthc50fa8d2021-05-06 02:40:33 -0400286 Dynamic_deps: linkerAttrs.dynamicDeps,
Lukacs T. Berki1353e592021-04-30 15:35:09 +0200287 Version_script: linkerAttrs.versionScript,
Jingwen Chen53681ef2021-04-29 08:15:13 +0000288 Static_deps_for_shared: sharedAttrs.staticDeps,
289 Includes: exportedIncludes,
Jingwen Chen63930982021-03-24 10:04:33 -0400290 }
291
292 props := bazel.BazelTargetModuleProperties{
293 Rule_class: "cc_library",
294 Bzl_load_location: "//build/bazel/rules:full_cc_library.bzl",
295 }
296
297 ctx.CreateBazelTargetModule(BazelCcLibraryFactory, m.Name(), props, attrs)
298}
299
Patrice Arruda83c89e02019-03-25 15:32:39 -0700300// cc_library creates both static and/or shared libraries for a device and/or
301// host. By default, a cc_library has a single variant that targets the device.
302// Specifying `host_supported: true` also creates a library that targets the
303// host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700304func LibraryFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800305 module, _ := NewLibrary(android.HostAndDeviceSupported)
Paul Duffina0843f62019-12-13 19:50:38 +0000306 // Can be used as both a static and a shared library.
307 module.sdkMemberTypes = []android.SdkMemberType{
308 sharedLibrarySdkMemberType,
309 staticLibrarySdkMemberType,
Paul Duffin9b76c0b2020-03-12 10:24:35 +0000310 staticAndSharedLibrarySdkMemberType,
Paul Duffina0843f62019-12-13 19:50:38 +0000311 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700312 return module.Init()
313}
314
Patrice Arruda83c89e02019-03-25 15:32:39 -0700315// cc_library_static creates a static library for a device and/or host binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700316func LibraryStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800317 module, library := NewLibrary(android.HostAndDeviceSupported)
318 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000319 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Chris Parsons808d84c2021-03-09 20:43:32 -0500320 module.bazelHandler = &staticLibraryBazelHandler{module: module}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700321 return module.Init()
322}
323
Patrice Arruda83c89e02019-03-25 15:32:39 -0700324// cc_library_shared creates a shared library for a device and/or host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700325func LibrarySharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800326 module, library := NewLibrary(android.HostAndDeviceSupported)
327 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000328 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700329 return module.Init()
330}
331
Patrice Arruda83c89e02019-03-25 15:32:39 -0700332// cc_library_host_static creates a static library that is linkable to a host
333// binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700334func LibraryHostStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800335 module, library := NewLibrary(android.HostSupported)
336 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000337 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700338 return module.Init()
339}
340
Patrice Arruda83c89e02019-03-25 15:32:39 -0700341// cc_library_host_shared creates a shared library that is usable on a host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700342func LibraryHostSharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800343 module, library := NewLibrary(android.HostSupported)
344 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000345 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700346 return module.Init()
347}
348
Chris Parsons3c27ca32020-11-20 12:42:07 -0500349// flagExporter is a separated portion of libraryDecorator pertaining to exported
350// include paths and flags. Keeping this dependency-related information separate
351// from the rest of library information is helpful in keeping data more structured
352// and explicit.
Colin Cross4d9c2d12016-07-29 12:48:20 -0700353type flagExporter struct {
354 Properties FlagExporterProperties
355
Chris Parsons3c27ca32020-11-20 12:42:07 -0500356 dirs android.Paths // Include directories to be included with -I
357 systemDirs android.Paths // System include directories to be included with -isystem
358 flags []string // Exported raw flags.
Inseob Kim69378442019-06-03 19:10:47 +0900359 deps android.Paths
Inseob Kimd110f872019-12-06 13:15:38 +0900360 headers android.Paths
Colin Cross4d9c2d12016-07-29 12:48:20 -0700361}
362
Chris Parsons3c27ca32020-11-20 12:42:07 -0500363// exportedIncludes returns the effective include paths for this module and
364// any module that links against this module. This is obtained from
365// the export_include_dirs property in the appropriate target stanza.
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700366func (f *flagExporter) exportedIncludes(ctx ModuleContext) android.Paths {
Justin Yun6977e8a2020-10-29 18:24:11 +0900367 if ctx.inVendor() && f.Properties.Target.Vendor.Override_export_include_dirs != nil {
Steven Morelandb21df8f2018-01-05 14:42:54 -0800368 return android.PathsForModuleSrc(ctx, f.Properties.Target.Vendor.Override_export_include_dirs)
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700369 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900370 if ctx.inProduct() && f.Properties.Target.Product.Override_export_include_dirs != nil {
371 return android.PathsForModuleSrc(ctx, f.Properties.Target.Product.Override_export_include_dirs)
372 }
373 return android.PathsForModuleSrc(ctx, f.Properties.Export_include_dirs)
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700374}
375
Chris Parsons3c27ca32020-11-20 12:42:07 -0500376// exportIncludes registers the include directories and system include directories to be exported
377// transitively to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900378func (f *flagExporter) exportIncludes(ctx ModuleContext) {
Jiyong Park74955042019-10-22 20:19:51 +0900379 f.dirs = append(f.dirs, f.exportedIncludes(ctx)...)
Jiyong Park73c54ee2019-10-22 20:31:18 +0900380 f.systemDirs = append(f.systemDirs, android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700381}
382
Chris Parsons3c27ca32020-11-20 12:42:07 -0500383// exportIncludesAsSystem registers the include directories and system include directories to be
384// exported transitively both as system include directories to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900385func (f *flagExporter) exportIncludesAsSystem(ctx ModuleContext) {
Jiyong Park73c54ee2019-10-22 20:31:18 +0900386 // all dirs are force exported as system
Jiyong Park74955042019-10-22 20:19:51 +0900387 f.systemDirs = append(f.systemDirs, f.exportedIncludes(ctx)...)
Jiyong Park73c54ee2019-10-22 20:31:18 +0900388 f.systemDirs = append(f.systemDirs, android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)...)
Inseob Kim69378442019-06-03 19:10:47 +0900389}
390
Chris Parsons3c27ca32020-11-20 12:42:07 -0500391// reexportDirs registers the given directories as include directories to be exported transitively
392// to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900393func (f *flagExporter) reexportDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900394 f.dirs = append(f.dirs, dirs...)
395}
396
Chris Parsons3c27ca32020-11-20 12:42:07 -0500397// reexportSystemDirs registers the given directories as system include directories
398// to be exported transitively to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900399func (f *flagExporter) reexportSystemDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900400 f.systemDirs = append(f.systemDirs, dirs...)
401}
402
Chris Parsons3c27ca32020-11-20 12:42:07 -0500403// reexportFlags registers the flags to be exported transitively to modules depending on this
404// module.
Inseob Kim69378442019-06-03 19:10:47 +0900405func (f *flagExporter) reexportFlags(flags ...string) {
Jaewoong Jung3aff5782020-02-11 07:54:35 -0800406 if android.PrefixInList(flags, "-I") || android.PrefixInList(flags, "-isystem") {
407 panic(fmt.Errorf("Exporting invalid flag %q: "+
408 "use reexportDirs or reexportSystemDirs to export directories", flag))
Inseob Kim69378442019-06-03 19:10:47 +0900409 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700410 f.flags = append(f.flags, flags...)
411}
412
Inseob Kim69378442019-06-03 19:10:47 +0900413func (f *flagExporter) reexportDeps(deps ...android.Path) {
414 f.deps = append(f.deps, deps...)
415}
416
Inseob Kimd110f872019-12-06 13:15:38 +0900417// addExportedGeneratedHeaders does nothing but collects generated header files.
418// This can be differ to exportedDeps which may contain phony files to minimize ninja.
419func (f *flagExporter) addExportedGeneratedHeaders(headers ...android.Path) {
420 f.headers = append(f.headers, headers...)
421}
422
Colin Cross0de8a1e2020-09-18 14:15:30 -0700423func (f *flagExporter) setProvider(ctx android.ModuleContext) {
424 ctx.SetProvider(FlagExporterInfoProvider, FlagExporterInfo{
Chris Parsonsf60ecf02021-04-27 14:48:30 -0400425 // Comes from Export_include_dirs property, and those of exported transitive deps
426 IncludeDirs: android.FirstUniquePaths(f.dirs),
427 // Comes from Export_system_include_dirs property, and those of exported transitive deps
Colin Crossc82e6e22021-04-20 18:21:50 -0700428 SystemIncludeDirs: android.FirstUniquePaths(f.systemDirs),
Chris Parsonsf60ecf02021-04-27 14:48:30 -0400429 // Used in very few places as a one-off way of adding extra defines.
430 Flags: f.flags,
431 // Used sparingly, for extra files that need to be explicitly exported to dependers,
432 // or for phony files to minimize ninja.
433 Deps: f.deps,
434 // For exported generated headers, such as exported aidl headers, proto headers, or
435 // sysprop headers.
436 GeneratedHeaders: f.headers,
Colin Cross0de8a1e2020-09-18 14:15:30 -0700437 })
Inseob Kim69378442019-06-03 19:10:47 +0900438}
439
Colin Crossb916a382016-07-29 17:28:03 -0700440// libraryDecorator wraps baseCompiler, baseLinker and baseInstaller to provide library-specific
441// functionality: static vs. shared linkage, reusing object files for shared libraries
442type libraryDecorator struct {
Colin Crossa48ab5b2017-02-14 15:28:44 -0800443 Properties LibraryProperties
Colin Crosse1bb5d02019-09-24 14:55:04 -0700444 StaticProperties StaticProperties
445 SharedProperties SharedProperties
Colin Crossa48ab5b2017-02-14 15:28:44 -0800446 MutatedProperties LibraryMutatedProperties
Colin Cross4d9c2d12016-07-29 12:48:20 -0700447
448 // For reusing static library objects for shared library
Inseob Kim69378442019-06-03 19:10:47 +0900449 reuseObjects Objects
Colin Cross10d22312017-05-03 11:01:58 -0700450
Colin Cross26c34ed2016-09-30 17:10:16 -0700451 // table-of-contents file to optimize out relinking when possible
452 tocFile android.OptionalPath
Colin Cross4d9c2d12016-07-29 12:48:20 -0700453
Colin Cross4d9c2d12016-07-29 12:48:20 -0700454 flagExporter
Liz Kammerb6a55bf2021-04-12 15:42:51 -0400455 flagExporterInfo *FlagExporterInfo
456 stripper Stripper
Colin Cross4d9c2d12016-07-29 12:48:20 -0700457
Colin Cross4d9c2d12016-07-29 12:48:20 -0700458 // For whole_static_libs
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700459 objects Objects
Colin Cross4d9c2d12016-07-29 12:48:20 -0700460
461 // Uses the module's name if empty, but can be overridden. Does not include
462 // shlib suffix.
463 libName string
Colin Crossb916a382016-07-29 17:28:03 -0700464
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800465 sabi *sabi
466
Dan Willemsen581341d2017-02-09 16:16:31 -0800467 // Output archive of gcno coverage information files
468 coverageOutputFile android.OptionalPath
469
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800470 // linked Source Abi Dump
471 sAbiOutputFile android.OptionalPath
472
473 // Source Abi Diff
474 sAbiDiff android.OptionalPath
475
Colin Cross0875c522017-11-28 17:34:01 -0800476 // Location of the static library in the sysroot. Empty if the library is
477 // not included in the NDK.
478 ndkSysrootPath android.Path
479
Colin Crossb60190a2018-09-04 16:28:17 -0700480 // Location of the linked, unstripped library for shared libraries
481 unstrippedOutputFile android.Path
482
Dan Willemsen569edc52018-11-19 09:33:29 -0800483 // Location of the file that should be copied to dist dir when requested
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000484 distFile android.Path
Dan Willemsen569edc52018-11-19 09:33:29 -0800485
Colin Cross8e21aa52020-09-28 18:28:02 -0700486 versionScriptPath android.OptionalPath
Jiyong Park7ed9de32018-10-15 22:25:07 +0900487
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800488 postInstallCmds []string
Jiyong Parkf1194352019-02-25 11:05:47 +0900489
Vic Yangefd249e2018-11-12 20:19:56 -0800490 // If useCoreVariant is true, the vendor variant of a VNDK library is
491 // not installed.
Vic Yangd92090f2020-01-08 14:32:28 -0800492 useCoreVariant bool
493 checkSameCoreVariant bool
Vic Yangefd249e2018-11-12 20:19:56 -0800494
Colin Cross5ec407b2020-09-30 11:41:33 -0700495 skipAPIDefine bool
496
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100497 // Decorated interfaces
Colin Crossb916a382016-07-29 17:28:03 -0700498 *baseCompiler
499 *baseLinker
500 *baseInstaller
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900501
502 collectedSnapshotHeaders android.Paths
503}
504
Chris Parsons808d84c2021-03-09 20:43:32 -0500505type staticLibraryBazelHandler struct {
506 bazelHandler
507
508 module *Module
509}
510
511func (handler *staticLibraryBazelHandler) generateBazelBuildActions(ctx android.ModuleContext, label string) bool {
512 bazelCtx := ctx.Config().BazelContext
Liz Kammerfe23bf32021-04-09 16:17:05 -0400513 ccInfo, ok, err := bazelCtx.GetCcInfo(label, ctx.Arch().ArchType)
514 if err != nil {
515 ctx.ModuleErrorf("Error getting Bazel CcInfo: %s", err)
516 return false
517 }
Chris Parsons944e7d02021-03-11 11:08:46 -0500518 if !ok {
519 return ok
Chris Parsons808d84c2021-03-09 20:43:32 -0500520 }
Liz Kammerfe23bf32021-04-09 16:17:05 -0400521 outputPaths := ccInfo.OutputFiles
522 objPaths := ccInfo.CcObjectFiles
Chris Parsonseefc9e62021-04-02 17:36:47 -0400523 if len(outputPaths) > 1 {
Chris Parsons944e7d02021-03-11 11:08:46 -0500524 // TODO(cparsons): This is actually expected behavior for static libraries with no srcs.
525 // We should support this.
Chris Parsonseefc9e62021-04-02 17:36:47 -0400526 ctx.ModuleErrorf("expected at most one output file for '%s', but got %s", label, objPaths)
Chris Parsons944e7d02021-03-11 11:08:46 -0500527 return false
Chris Parsonseefc9e62021-04-02 17:36:47 -0400528 } else if len(outputPaths) == 0 {
529 handler.module.outputFile = android.OptionalPath{}
530 return true
Chris Parsons944e7d02021-03-11 11:08:46 -0500531 }
532 outputFilePath := android.PathForBazelOut(ctx, outputPaths[0])
533 handler.module.outputFile = android.OptionalPathForPath(outputFilePath)
534
535 objFiles := make(android.Paths, len(objPaths))
536 for i, objPath := range objPaths {
537 objFiles[i] = android.PathForBazelOut(ctx, objPath)
538 }
539 objects := Objects{
540 objFiles: objFiles,
541 }
542
543 ctx.SetProvider(StaticLibraryInfoProvider, StaticLibraryInfo{
544 StaticLibrary: outputFilePath,
545 ReuseObjects: objects,
546 Objects: objects,
547
548 // TODO(cparsons): Include transitive static libraries in this provider to support
549 // static libraries with deps.
550 TransitiveStaticLibrariesForOrdering: android.NewDepSetBuilder(android.TOPOLOGICAL).
551 Direct(outputFilePath).
552 Build(),
553 })
Chris Parsonsf60ecf02021-04-27 14:48:30 -0400554
555 ctx.SetProvider(FlagExporterInfoProvider, flagExporterInfoFromCcInfo(ctx, ccInfo))
Chris Parsonseefc9e62021-04-02 17:36:47 -0400556 if i, ok := handler.module.linker.(snapshotLibraryInterface); ok {
557 // Dependencies on this library will expect collectedSnapshotHeaders to
558 // be set, otherwise validation will fail. For now, set this to an empty
559 // list.
560 // TODO(cparsons): More closely mirror the collectHeadersForSnapshot
561 // implementation.
562 i.(*libraryDecorator).collectedSnapshotHeaders = android.Paths{}
563 }
564
Chris Parsons808d84c2021-03-09 20:43:32 -0500565 return ok
566}
567
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900568// collectHeadersForSnapshot collects all exported headers from library.
569// It globs header files in the source tree for exported include directories,
570// and tracks generated header files separately.
571//
572// This is to be called from GenerateAndroidBuildActions, and then collected
573// header files can be retrieved by snapshotHeaders().
574func (l *libraryDecorator) collectHeadersForSnapshot(ctx android.ModuleContext) {
575 ret := android.Paths{}
576
577 // Headers in the source tree should be globbed. On the contrast, generated headers
578 // can't be globbed, and they should be manually collected.
579 // So, we first filter out intermediate directories (which contains generated headers)
580 // from exported directories, and then glob headers under remaining directories.
Colin Cross0de8a1e2020-09-18 14:15:30 -0700581 for _, path := range append(android.CopyOfPaths(l.flagExporter.dirs), l.flagExporter.systemDirs...) {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900582 dir := path.String()
583 // Skip if dir is for generated headers
584 if strings.HasPrefix(dir, android.PathForOutput(ctx).String()) {
585 continue
586 }
Inseob Kim04f2d6a2020-05-29 22:30:58 +0900587 // libeigen wrongly exports the root directory "external/eigen". But only two
588 // subdirectories "Eigen" and "unsupported" contain exported header files. Even worse
589 // some of them have no extension. So we need special treatment for libeigen in order
590 // to glob correctly.
591 if dir == "external/eigen" {
592 // Only these two directories contains exported headers.
593 for _, subdir := range []string{"Eigen", "unsupported/Eigen"} {
594 glob, err := ctx.GlobWithDeps("external/eigen/"+subdir+"/**/*", nil)
595 if err != nil {
596 ctx.ModuleErrorf("glob failed: %#v", err)
597 return
598 }
599 for _, header := range glob {
600 if strings.HasSuffix(header, "/") {
601 continue
602 }
603 ext := filepath.Ext(header)
604 if ext != "" && ext != ".h" {
605 continue
606 }
607 ret = append(ret, android.PathForSource(ctx, header))
608 }
609 }
610 continue
611 }
Colin Crossec118d02021-01-22 18:05:59 +0000612 glob, err := ctx.GlobWithDeps(dir+"/**/*", nil)
613 if err != nil {
614 ctx.ModuleErrorf("glob failed: %#v", err)
615 return
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900616 }
Colin Crossec118d02021-01-22 18:05:59 +0000617 isLibcxx := strings.HasPrefix(dir, "external/libcxx/include")
Jose Galmes0d736912021-03-30 11:00:06 -0700618 for _, header := range glob {
Colin Crossec118d02021-01-22 18:05:59 +0000619 if isLibcxx {
620 // Glob all files under this special directory, because of C++ headers with no
621 // extension.
Jose Galmes0d736912021-03-30 11:00:06 -0700622 if strings.HasSuffix(header, "/") {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900623 continue
624 }
Colin Crossec118d02021-01-22 18:05:59 +0000625 } else {
626 // Filter out only the files with extensions that are headers.
627 found := false
628 for _, ext := range headerExts {
629 if strings.HasSuffix(header, ext) {
630 found = true
631 break
632 }
633 }
634 if !found {
635 continue
636 }
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900637 }
Jose Galmes0d736912021-03-30 11:00:06 -0700638 ret = append(ret, android.PathForSource(ctx, header))
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900639 }
640 }
641
642 // Collect generated headers
Colin Cross0de8a1e2020-09-18 14:15:30 -0700643 for _, header := range append(android.CopyOfPaths(l.flagExporter.headers), l.flagExporter.deps...) {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900644 // TODO(b/148123511): remove exportedDeps after cleaning up genrule
645 if strings.HasSuffix(header.Base(), "-phony") {
646 continue
647 }
648 ret = append(ret, header)
649 }
650
651 l.collectedSnapshotHeaders = ret
652}
653
654// This returns all exported header files, both generated ones and headers from source tree.
655// collectHeadersForSnapshot() must be called before calling this.
656func (l *libraryDecorator) snapshotHeaders() android.Paths {
657 if l.collectedSnapshotHeaders == nil {
658 panic("snapshotHeaders() must be called after collectHeadersForSnapshot()")
659 }
660 return l.collectedSnapshotHeaders
Colin Cross4d9c2d12016-07-29 12:48:20 -0700661}
662
Chris Parsons3c27ca32020-11-20 12:42:07 -0500663// linkerProps returns the list of properties structs relevant for this library. (For example, if
664// the library is cc_shared_library, then static-library properties are omitted.)
Colin Crossb916a382016-07-29 17:28:03 -0700665func (library *libraryDecorator) linkerProps() []interface{} {
666 var props []interface{}
667 props = append(props, library.baseLinker.linkerProps()...)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700668 props = append(props,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700669 &library.Properties,
Colin Crossa48ab5b2017-02-14 15:28:44 -0800670 &library.MutatedProperties,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700671 &library.flagExporter.Properties,
Colin Cross22f37952018-09-05 10:43:13 -0700672 &library.stripper.StripProperties)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700673
674 if library.MutatedProperties.BuildShared {
675 props = append(props, &library.SharedProperties)
676 }
677 if library.MutatedProperties.BuildStatic {
678 props = append(props, &library.StaticProperties)
679 }
680
681 return props
Colin Cross4d9c2d12016-07-29 12:48:20 -0700682}
683
Chris Parsons3c27ca32020-11-20 12:42:07 -0500684// linkerFlags takes a Flags struct and augments it to contain linker flags that are defined by this
685// library, or that are implied by attributes of this library (such as whether this library is a
686// shared library).
Colin Crossb916a382016-07-29 17:28:03 -0700687func (library *libraryDecorator) linkerFlags(ctx ModuleContext, flags Flags) Flags {
Colin Cross42742b82016-08-01 13:20:05 -0700688 flags = library.baseLinker.linkerFlags(ctx, flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700689
Colin Crossb916a382016-07-29 17:28:03 -0700690 // MinGW spits out warnings about -fPIC even for -fpie?!) being ignored because
691 // all code is position independent, and then those warnings get promoted to
692 // errors.
Colin Cross3edeee12017-04-04 12:59:48 -0700693 if !ctx.Windows() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800694 flags.Global.CFlags = append(flags.Global.CFlags, "-fPIC")
Colin Crossb916a382016-07-29 17:28:03 -0700695 }
696
697 if library.static() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800698 flags.Local.CFlags = append(flags.Local.CFlags, library.StaticProperties.Static.Cflags...)
Colin Crossa48ab5b2017-02-14 15:28:44 -0800699 } else if library.shared() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800700 flags.Local.CFlags = append(flags.Local.CFlags, library.SharedProperties.Shared.Cflags...)
Colin Crossb916a382016-07-29 17:28:03 -0700701 }
702
Colin Crossa48ab5b2017-02-14 15:28:44 -0800703 if library.shared() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700704 libName := library.getLibName(ctx)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700705 var f []string
Dan Willemsen01a405a2016-06-13 17:19:03 -0700706 if ctx.toolchain().Bionic() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700707 f = append(f,
708 "-nostdlib",
709 "-Wl,--gc-sections",
710 )
711 }
712
713 if ctx.Darwin() {
714 f = append(f,
715 "-dynamiclib",
716 "-single_module",
Colin Cross4d9c2d12016-07-29 12:48:20 -0700717 "-install_name @rpath/"+libName+flags.Toolchain.ShlibSuffix(),
718 )
Colin Cross7863cf52016-10-20 10:47:21 -0700719 if ctx.Arch().ArchType == android.X86 {
720 f = append(f,
721 "-read_only_relocs suppress",
722 )
723 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700724 } else {
Josh Gao75a50a22019-06-07 17:58:59 -0700725 f = append(f, "-shared")
726 if !ctx.Windows() {
727 f = append(f, "-Wl,-soname,"+libName+flags.Toolchain.ShlibSuffix())
728 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700729 }
730
Colin Cross4af21ed2019-11-04 09:37:55 -0800731 flags.Global.LdFlags = append(flags.Global.LdFlags, f...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700732 }
733
734 return flags
735}
736
Chris Parsons3c27ca32020-11-20 12:42:07 -0500737// compilerFlags takes a Flags and augments it to contain compile flags from global values,
738// per-target values, module type values, per-module Blueprints properties, extra flags from
739// `flags`, and generated sources from `deps`.
Colin Crossf18e1102017-11-16 14:33:08 -0800740func (library *libraryDecorator) compilerFlags(ctx ModuleContext, flags Flags, deps PathDeps) Flags {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700741 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700742 if len(exportIncludeDirs) > 0 {
Colin Crossdad8c952017-04-26 14:55:27 -0700743 f := includeDirsToFlags(exportIncludeDirs)
Colin Cross4af21ed2019-11-04 09:37:55 -0800744 flags.Local.CommonFlags = append(flags.Local.CommonFlags, f)
745 flags.Local.YasmFlags = append(flags.Local.YasmFlags, f)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700746 }
747
Jiyong Park7ed9de32018-10-15 22:25:07 +0900748 flags = library.baseCompiler.compilerFlags(ctx, flags, deps)
Colin Cross127bb8b2020-12-16 16:46:01 -0800749 if ctx.IsLlndk() {
750 // LLNDK libraries ignore most of the properties on the cc_library and use the
751 // LLNDK-specific properties instead.
752 // Wipe all the module-local properties, leaving only the global properties.
753 flags.Local = LocalOrGlobalFlags{}
754 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900755 if library.buildStubs() {
Jiyong Park64379952018-12-13 18:37:29 +0900756 // Remove -include <file> when compiling stubs. Otherwise, the force included
757 // headers might cause conflicting types error with the symbols in the
758 // generated stubs source code. e.g.
759 // double acos(double); // in header
760 // void acos() {} // in the generated source code
761 removeInclude := func(flags []string) []string {
762 ret := flags[:0]
763 for _, f := range flags {
764 if strings.HasPrefix(f, "-include ") {
765 continue
766 }
767 ret = append(ret, f)
768 }
769 return ret
770 }
Colin Cross4af21ed2019-11-04 09:37:55 -0800771 flags.Local.CommonFlags = removeInclude(flags.Local.CommonFlags)
772 flags.Local.CFlags = removeInclude(flags.Local.CFlags)
Jiyong Park64379952018-12-13 18:37:29 +0900773
Jiyong Park7ed9de32018-10-15 22:25:07 +0900774 flags = addStubLibraryCompilerFlags(flags)
775 }
776 return flags
Dan Willemsen273af7f2016-11-03 15:53:42 -0700777}
778
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800779func (library *libraryDecorator) headerAbiCheckerEnabled() bool {
780 return Bool(library.Properties.Header_abi_checker.Enabled)
Hsin-Yi Chen53489642019-07-31 17:10:45 +0800781}
782
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800783func (library *libraryDecorator) headerAbiCheckerExplicitlyDisabled() bool {
784 return !BoolDefault(library.Properties.Header_abi_checker.Enabled, true)
Logan Chien41eabe62019-04-10 13:33:58 +0800785}
786
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700787func (library *libraryDecorator) compile(ctx ModuleContext, flags Flags, deps PathDeps) Objects {
Colin Cross127bb8b2020-12-16 16:46:01 -0800788 if ctx.IsLlndk() {
789 // This is the vendor variant of an LLNDK library, build the LLNDK stubs.
790 vndkVer := ctx.Module().(*Module).VndkVersion()
791 if !inList(vndkVer, ctx.Config().PlatformVersionActiveCodenames()) || vndkVer == "" {
792 // For non-enforcing devices, vndkVer is empty. Use "current" in that case, too.
793 vndkVer = "current"
794 }
795 if library.stubsVersion() != "" {
796 vndkVer = library.stubsVersion()
797 }
798 objs, versionScript := compileStubLibrary(ctx, flags, String(library.Properties.Llndk.Symbol_file), vndkVer, "--llndk")
799 if !Bool(library.Properties.Llndk.Unversioned) {
800 library.versionScriptPath = android.OptionalPathForPath(versionScript)
801 }
802 return objs
803 }
Colin Cross5271fea2021-04-27 13:06:04 -0700804 if ctx.IsVendorPublicLibrary() {
805 objs, versionScript := compileStubLibrary(ctx, flags, String(library.Properties.Vendor_public_library.Symbol_file), "current", "")
806 if !Bool(library.Properties.Vendor_public_library.Unversioned) {
807 library.versionScriptPath = android.OptionalPathForPath(versionScript)
808 }
809 return objs
810 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900811 if library.buildStubs() {
Jiyong Parka4175572021-02-04 21:05:47 +0900812 symbolFile := String(library.Properties.Stubs.Symbol_file)
813 if symbolFile != "" && !strings.HasSuffix(symbolFile, ".map.txt") {
814 ctx.PropertyErrorf("symbol_file", "%q doesn't have .map.txt suffix", symbolFile)
815 return Objects{}
816 }
Jiyong Park3fd0baf2018-12-07 16:25:39 +0900817 objs, versionScript := compileStubLibrary(ctx, flags, String(library.Properties.Stubs.Symbol_file), library.MutatedProperties.StubsVersion, "--apex")
Colin Cross8e21aa52020-09-28 18:28:02 -0700818 library.versionScriptPath = android.OptionalPathForPath(versionScript)
Jiyong Park7ed9de32018-10-15 22:25:07 +0900819 return objs
820 }
821
Colin Cross5950f382016-12-13 12:50:57 -0800822 if !library.buildShared() && !library.buildStatic() {
823 if len(library.baseCompiler.Properties.Srcs) > 0 {
824 ctx.PropertyErrorf("srcs", "cc_library_headers must not have any srcs")
825 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700826 if len(library.StaticProperties.Static.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800827 ctx.PropertyErrorf("static.srcs", "cc_library_headers must not have any srcs")
828 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700829 if len(library.SharedProperties.Shared.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800830 ctx.PropertyErrorf("shared.srcs", "cc_library_headers must not have any srcs")
831 }
832 return Objects{}
833 }
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800834 if library.sabi.shouldCreateSourceAbiDump() {
Jayant Chowdharya4fce192017-09-06 13:10:03 -0700835 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800836 var SourceAbiFlags []string
837 for _, dir := range exportIncludeDirs.Strings() {
Jayant Chowdhary715cac32017-04-20 06:53:59 -0700838 SourceAbiFlags = append(SourceAbiFlags, "-I"+dir)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800839 }
Inseob Kim69378442019-06-03 19:10:47 +0900840 for _, reexportedInclude := range library.sabi.Properties.ReexportedIncludes {
841 SourceAbiFlags = append(SourceAbiFlags, "-I"+reexportedInclude)
Jayant Chowdhary715cac32017-04-20 06:53:59 -0700842 }
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800843 flags.SAbiFlags = SourceAbiFlags
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800844 totalLength := len(library.baseCompiler.Properties.Srcs) + len(deps.GeneratedSources) +
Colin Crosse1bb5d02019-09-24 14:55:04 -0700845 len(library.SharedProperties.Shared.Srcs) + len(library.StaticProperties.Static.Srcs)
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800846 if totalLength > 0 {
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800847 flags.SAbiDump = true
848 }
849 }
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700850 objs := library.baseCompiler.compile(ctx, flags, deps)
851 library.reuseObjects = objs
Colin Cross2f336352016-10-26 10:03:47 -0700852 buildFlags := flagsToBuilderFlags(flags)
Colin Crossb916a382016-07-29 17:28:03 -0700853
Colin Cross4d9c2d12016-07-29 12:48:20 -0700854 if library.static() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700855 srcs := android.PathsForModuleSrc(ctx, library.StaticProperties.Static.Srcs)
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700856 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceStaticLibrary,
Pirama Arumuga Nainarf231b192018-01-23 10:49:04 -0800857 srcs, library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossa48ab5b2017-02-14 15:28:44 -0800858 } else if library.shared() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700859 srcs := android.PathsForModuleSrc(ctx, library.SharedProperties.Shared.Srcs)
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700860 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceSharedLibrary,
Pirama Arumuga Nainarf231b192018-01-23 10:49:04 -0800861 srcs, library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossb916a382016-07-29 17:28:03 -0700862 }
863
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700864 return objs
Colin Crossb916a382016-07-29 17:28:03 -0700865}
866
867type libraryInterface interface {
Colin Cross3572cf72020-10-01 15:58:11 -0700868 versionedInterface
869
Colin Crossb916a382016-07-29 17:28:03 -0700870 static() bool
Inseob Kimae553032019-05-14 18:52:49 +0900871 shared() bool
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700872 objs() Objects
Colin Cross0de8a1e2020-09-18 14:15:30 -0700873 reuseObjs() Objects
Colin Cross26c34ed2016-09-30 17:10:16 -0700874 toc() android.OptionalPath
Colin Crossb916a382016-07-29 17:28:03 -0700875
876 // Returns true if the build options for the module have selected a static or shared build
877 buildStatic() bool
878 buildShared() bool
879
880 // Sets whether a specific variant is static or shared
Colin Crossa48ab5b2017-02-14 15:28:44 -0800881 setStatic()
882 setShared()
Logan Chien41eabe62019-04-10 13:33:58 +0800883
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800884 // Check whether header_abi_checker is enabled or explicitly disabled.
885 headerAbiCheckerEnabled() bool
886 headerAbiCheckerExplicitlyDisabled() bool
887
Logan Chien41eabe62019-04-10 13:33:58 +0800888 // Write LOCAL_ADDITIONAL_DEPENDENCIES for ABI diff
889 androidMkWriteAdditionalDependenciesForSourceAbiDiff(w io.Writer)
Jiyong Parka90ca002019-10-07 15:47:24 +0900890
891 availableFor(string) bool
Colin Crossb916a382016-07-29 17:28:03 -0700892}
893
Colin Crossc88c2722020-09-28 17:32:47 -0700894type versionedInterface interface {
895 buildStubs() bool
Jiyong Parkd4a3a132021-03-17 20:21:35 +0900896 setBuildStubs(isLatest bool)
Colin Crossc88c2722020-09-28 17:32:47 -0700897 hasStubsVariants() bool
898 setStubsVersion(string)
899 stubsVersion() string
900
Colin Cross3572cf72020-10-01 15:58:11 -0700901 stubsVersions(ctx android.BaseMutatorContext) []string
Colin Crossc88c2722020-09-28 17:32:47 -0700902 setAllStubsVersions([]string)
903 allStubsVersions() []string
Colin Cross0477b422020-10-13 18:43:54 -0700904
905 implementationModuleName(name string) string
Colin Cross127bb8b2020-12-16 16:46:01 -0800906 hasLLNDKStubs() bool
Colin Cross1f3f1302021-04-26 18:37:44 -0700907 hasLLNDKHeaders() bool
Colin Cross5271fea2021-04-27 13:06:04 -0700908 hasVendorPublicLibrary() bool
Colin Crossc88c2722020-09-28 17:32:47 -0700909}
910
911var _ libraryInterface = (*libraryDecorator)(nil)
912var _ versionedInterface = (*libraryDecorator)(nil)
913
Justin Yun6977e8a2020-10-29 18:24:11 +0900914func (library *libraryDecorator) getLibNameHelper(baseModuleName string, inVendor bool, inProduct bool) string {
Colin Crossb916a382016-07-29 17:28:03 -0700915 name := library.libName
916 if name == "" {
dimitryd95964a2018-11-07 13:43:34 +0100917 name = String(library.Properties.Stem)
918 if name == "" {
Jooyung Han0302a842019-10-30 18:43:49 +0900919 name = baseModuleName
dimitryd95964a2018-11-07 13:43:34 +0100920 }
Colin Crossb916a382016-07-29 17:28:03 -0700921 }
922
Colin Cross0fd6a412019-08-16 14:22:10 -0700923 suffix := ""
Justin Yun6977e8a2020-10-29 18:24:11 +0900924 if inVendor {
Colin Cross0fd6a412019-08-16 14:22:10 -0700925 suffix = String(library.Properties.Target.Vendor.Suffix)
Justin Yun6977e8a2020-10-29 18:24:11 +0900926 } else if inProduct {
927 suffix = String(library.Properties.Target.Product.Suffix)
Colin Cross0fd6a412019-08-16 14:22:10 -0700928 }
929 if suffix == "" {
930 suffix = String(library.Properties.Suffix)
931 }
932
Jooyung Han0302a842019-10-30 18:43:49 +0900933 return name + suffix
934}
935
Chris Parsons3c27ca32020-11-20 12:42:07 -0500936// getLibName returns the actual canonical name of the library (the name which
937// should be passed to the linker via linker flags).
Jooyung Han0302a842019-10-30 18:43:49 +0900938func (library *libraryDecorator) getLibName(ctx BaseModuleContext) string {
Justin Yun6977e8a2020-10-29 18:24:11 +0900939 name := library.getLibNameHelper(ctx.baseModuleName(), ctx.inVendor(), ctx.inProduct())
Colin Cross0fd6a412019-08-16 14:22:10 -0700940
Ivan Lozanof9e21722020-12-02 09:00:51 -0500941 if ctx.IsVndkExt() {
Jooyung Han4c2b9422019-10-22 19:53:47 +0900942 // vndk-ext lib should have the same name with original lib
943 ctx.VisitDirectDepsWithTag(vndkExtDepTag, func(module android.Module) {
944 originalName := module.(*Module).outputFile.Path()
945 name = strings.TrimSuffix(originalName.Base(), originalName.Ext())
946 })
Logan Chienf3511742017-10-31 18:04:35 +0800947 }
948
Colin Crossb916a382016-07-29 17:28:03 -0700949 if ctx.Host() && Bool(library.Properties.Unique_host_soname) {
950 if !strings.HasSuffix(name, "-host") {
951 name = name + "-host"
952 }
953 }
954
Inseob Kim0ce291e2019-07-04 14:38:27 +0900955 return name
Colin Crossb916a382016-07-29 17:28:03 -0700956}
957
Jiyong Parkda732bd2018-11-02 18:23:15 +0900958var versioningMacroNamesListMutex sync.Mutex
959
Colin Crossb916a382016-07-29 17:28:03 -0700960func (library *libraryDecorator) linkerInit(ctx BaseModuleContext) {
961 location := InstallInSystem
Dan Albert61f32122018-07-26 14:00:24 -0700962 if library.baseLinker.sanitize.inSanitizerDir() {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700963 location = InstallInSanitizerDir
Colin Crossb916a382016-07-29 17:28:03 -0700964 }
965 library.baseInstaller.location = location
Colin Crossb916a382016-07-29 17:28:03 -0700966 library.baseLinker.linkerInit(ctx)
Jiyong Park7ed9de32018-10-15 22:25:07 +0900967 // Let baseLinker know whether this variant is for stubs or not, so that
968 // it can omit things that are not required for linking stubs.
969 library.baseLinker.dynamicProperties.BuildStubs = library.buildStubs()
Jiyong Parkda732bd2018-11-02 18:23:15 +0900970
971 if library.buildStubs() {
972 macroNames := versioningMacroNamesList(ctx.Config())
973 myName := versioningMacroName(ctx.ModuleName())
974 versioningMacroNamesListMutex.Lock()
975 defer versioningMacroNamesListMutex.Unlock()
976 if (*macroNames)[myName] == "" {
977 (*macroNames)[myName] = ctx.ModuleName()
978 } else if (*macroNames)[myName] != ctx.ModuleName() {
979 ctx.ModuleErrorf("Macro name %q for versioning conflicts with macro name from module %q ", myName, (*macroNames)[myName])
980 }
981 }
Colin Crossb916a382016-07-29 17:28:03 -0700982}
983
dimitry0345ad82018-12-05 16:28:14 +0100984func (library *libraryDecorator) compilerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800985 if ctx.IsLlndk() {
986 // LLNDK libraries ignore most of the properties on the cc_library and use the
987 // LLNDK-specific properties instead.
988 return deps
989 }
990
dimitry0345ad82018-12-05 16:28:14 +0100991 deps = library.baseCompiler.compilerDeps(ctx, deps)
992
dimitry0345ad82018-12-05 16:28:14 +0100993 return deps
994}
995
Colin Cross37047f12016-12-13 17:06:13 -0800996func (library *libraryDecorator) linkerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800997 if ctx.IsLlndk() {
998 // LLNDK libraries ignore most of the properties on the cc_library and use the
999 // LLNDK-specific properties instead.
Colin Cross0fb7fcd2021-03-02 11:00:07 -08001000 deps.HeaderLibs = append([]string(nil), library.Properties.Llndk.Export_llndk_headers...)
1001 deps.ReexportHeaderLibHeaders = append([]string(nil), library.Properties.Llndk.Export_llndk_headers...)
Colin Cross127bb8b2020-12-16 16:46:01 -08001002 return deps
1003 }
Colin Cross5271fea2021-04-27 13:06:04 -07001004 if ctx.IsVendorPublicLibrary() {
1005 headers := library.Properties.Vendor_public_library.Export_public_headers
1006 deps.HeaderLibs = append([]string(nil), headers...)
1007 deps.ReexportHeaderLibHeaders = append([]string(nil), headers...)
1008 return deps
1009 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001010
Dan Willemsen3a26eef2018-12-03 15:25:46 -08001011 if library.static() {
Martin Stjernholm10566a02020-03-24 01:19:52 +00001012 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001013 if library.StaticProperties.Static.System_shared_libs != nil {
1014 library.baseLinker.Properties.System_shared_libs = library.StaticProperties.Static.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -08001015 }
1016 } else if library.shared() {
Martin Stjernholm10566a02020-03-24 01:19:52 +00001017 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001018 if library.SharedProperties.Shared.System_shared_libs != nil {
1019 library.baseLinker.Properties.System_shared_libs = library.SharedProperties.Shared.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -08001020 }
1021 }
1022
Colin Crossb916a382016-07-29 17:28:03 -07001023 deps = library.baseLinker.linkerDeps(ctx, deps)
1024
1025 if library.static() {
1026 deps.WholeStaticLibs = append(deps.WholeStaticLibs,
Colin Crosse1bb5d02019-09-24 14:55:04 -07001027 library.StaticProperties.Static.Whole_static_libs...)
1028 deps.StaticLibs = append(deps.StaticLibs, library.StaticProperties.Static.Static_libs...)
1029 deps.SharedLibs = append(deps.SharedLibs, library.StaticProperties.Static.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -08001030
Colin Crosse1bb5d02019-09-24 14:55:04 -07001031 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.StaticProperties.Static.Export_shared_lib_headers...)
1032 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.StaticProperties.Static.Export_static_lib_headers...)
Colin Crossa48ab5b2017-02-14 15:28:44 -08001033 } else if library.shared() {
Dan Willemsen2e47b342016-11-17 01:02:25 -08001034 if ctx.toolchain().Bionic() && !Bool(library.baseLinker.Properties.Nocrt) {
Dan Albert92fe7402020-07-15 13:33:30 -07001035 deps.CrtBegin = "crtbegin_so"
1036 deps.CrtEnd = "crtend_so"
Colin Cross4d9c2d12016-07-29 12:48:20 -07001037 }
Colin Crosse1bb5d02019-09-24 14:55:04 -07001038 deps.WholeStaticLibs = append(deps.WholeStaticLibs, library.SharedProperties.Shared.Whole_static_libs...)
1039 deps.StaticLibs = append(deps.StaticLibs, library.SharedProperties.Shared.Static_libs...)
1040 deps.SharedLibs = append(deps.SharedLibs, library.SharedProperties.Shared.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -08001041
Colin Crosse1bb5d02019-09-24 14:55:04 -07001042 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.SharedProperties.Shared.Export_shared_lib_headers...)
1043 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.SharedProperties.Shared.Export_static_lib_headers...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001044 }
Justin Yun6977e8a2020-10-29 18:24:11 +09001045 if ctx.inVendor() {
Jiyong Park52d25bd2017-10-13 09:17:01 +09001046 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
1047 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
1048 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +00001049 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
1050 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Jiyong Park52d25bd2017-10-13 09:17:01 +09001051 }
Justin Yun6977e8a2020-10-29 18:24:11 +09001052 if ctx.inProduct() {
1053 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
1054 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
1055 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
1056 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
1057 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
1058 }
Jiyong Parkf9332f12018-02-01 00:54:12 +09001059 if ctx.inRecovery() {
1060 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
1061 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
1062 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +00001063 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
1064 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001065 }
Yifan Hongcf4832c2020-01-21 17:04:13 -08001066 if ctx.inRamdisk() {
1067 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
1068 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
1069 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
1070 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
1071 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
1072 }
Yifan Hong6da33c22020-10-27 15:01:21 -07001073 if ctx.inVendorRamdisk() {
1074 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
1075 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
1076 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
1077 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
1078 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
1079 }
Colin Cross2383f3b2018-02-06 14:40:13 -08001080
Colin Cross4d9c2d12016-07-29 12:48:20 -07001081 return deps
1082}
1083
Paul Duffin13f02712020-03-06 12:30:43 +00001084func (library *libraryDecorator) linkerSpecifiedDeps(specifiedDeps specifiedDeps) specifiedDeps {
1085 specifiedDeps = library.baseLinker.linkerSpecifiedDeps(specifiedDeps)
1086 var properties StaticOrSharedProperties
1087 if library.static() {
1088 properties = library.StaticProperties.Static
1089 } else if library.shared() {
1090 properties = library.SharedProperties.Shared
1091 }
1092
1093 specifiedDeps.sharedLibs = append(specifiedDeps.sharedLibs, properties.Shared_libs...)
Martin Stjernholm10566a02020-03-24 01:19:52 +00001094
1095 // Must distinguish nil and [] in system_shared_libs - ensure that [] in
1096 // either input list doesn't come out as nil.
1097 if specifiedDeps.systemSharedLibs == nil {
1098 specifiedDeps.systemSharedLibs = properties.System_shared_libs
1099 } else {
1100 specifiedDeps.systemSharedLibs = append(specifiedDeps.systemSharedLibs, properties.System_shared_libs...)
1101 }
Paul Duffin13f02712020-03-06 12:30:43 +00001102
1103 specifiedDeps.sharedLibs = android.FirstUniqueStrings(specifiedDeps.sharedLibs)
Martin Stjernholm10566a02020-03-24 01:19:52 +00001104 if len(specifiedDeps.systemSharedLibs) > 0 {
1105 // Skip this if systemSharedLibs is either nil or [], to ensure they are
1106 // retained.
1107 specifiedDeps.systemSharedLibs = android.FirstUniqueStrings(specifiedDeps.systemSharedLibs)
1108 }
Paul Duffin13f02712020-03-06 12:30:43 +00001109 return specifiedDeps
1110}
1111
Colin Crossb916a382016-07-29 17:28:03 -07001112func (library *libraryDecorator) linkStatic(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001113 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001114
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001115 library.objects = deps.WholeStaticLibObjs.Copy()
1116 library.objects = library.objects.Append(objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001117
Inseob Kim0ce291e2019-07-04 14:38:27 +09001118 fileName := ctx.ModuleName() + staticLibraryExtension
Colin Cross86803cf2018-02-15 14:12:26 -08001119 outputFile := android.PathForModuleOut(ctx, fileName)
Dan Willemsen581341d2017-02-09 16:16:31 -08001120 builderFlags := flagsToBuilderFlags(flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001121
Dan Willemsen569edc52018-11-19 09:33:29 -08001122 if Bool(library.baseLinker.Properties.Use_version_lib) {
1123 if ctx.Host() {
1124 versionedOutputFile := outputFile
1125 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
1126 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1127 } else {
1128 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001129 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -08001130 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1131 }
Colin Cross86803cf2018-02-15 14:12:26 -08001132 }
1133
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001134 transformObjToStaticLib(ctx, library.objects.objFiles, deps.WholeStaticLibsFromPrebuilts, builderFlags, outputFile, objs.tidyFiles)
Dan Willemsen581341d2017-02-09 16:16:31 -08001135
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001136 library.coverageOutputFile = transformCoverageFilesToZip(ctx, library.objects, ctx.ModuleName())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001137
Colin Cross4d9c2d12016-07-29 12:48:20 -07001138 ctx.CheckbuildFile(outputFile)
1139
Colin Cross649d8172020-12-10 12:30:21 -08001140 if library.static() {
1141 ctx.SetProvider(StaticLibraryInfoProvider, StaticLibraryInfo{
1142 StaticLibrary: outputFile,
1143 ReuseObjects: library.reuseObjects,
1144 Objects: library.objects,
Colin Cross0de8a1e2020-09-18 14:15:30 -07001145
Colin Cross649d8172020-12-10 12:30:21 -08001146 TransitiveStaticLibrariesForOrdering: android.NewDepSetBuilder(android.TOPOLOGICAL).
1147 Direct(outputFile).
1148 Transitive(deps.TranstiveStaticLibrariesForOrdering).
1149 Build(),
1150 })
1151 }
1152
1153 if library.header() {
1154 ctx.SetProvider(HeaderLibraryInfoProvider, HeaderLibraryInfo{})
1155 }
Colin Cross0de8a1e2020-09-18 14:15:30 -07001156
Colin Cross4d9c2d12016-07-29 12:48:20 -07001157 return outputFile
1158}
1159
Colin Crossb916a382016-07-29 17:28:03 -07001160func (library *libraryDecorator) linkShared(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001161 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001162
1163 var linkerDeps android.Paths
Pirama Arumuga Nainarada83ec2017-08-31 23:38:27 -07001164 linkerDeps = append(linkerDeps, flags.LdFlagsDeps...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001165
Colin Cross2383f3b2018-02-06 14:40:13 -08001166 unexportedSymbols := ctx.ExpandOptionalSource(library.Properties.Unexported_symbols_list, "unexported_symbols_list")
1167 forceNotWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_not_weak_list, "force_symbols_not_weak_list")
1168 forceWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_weak_list, "force_symbols_weak_list")
Colin Cross4d9c2d12016-07-29 12:48:20 -07001169 if !ctx.Darwin() {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001170 if unexportedSymbols.Valid() {
1171 ctx.PropertyErrorf("unexported_symbols_list", "Only supported on Darwin")
1172 }
1173 if forceNotWeakSymbols.Valid() {
1174 ctx.PropertyErrorf("force_symbols_not_weak_list", "Only supported on Darwin")
1175 }
1176 if forceWeakSymbols.Valid() {
1177 ctx.PropertyErrorf("force_symbols_weak_list", "Only supported on Darwin")
1178 }
1179 } else {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001180 if unexportedSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001181 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-unexported_symbols_list,"+unexportedSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001182 linkerDeps = append(linkerDeps, unexportedSymbols.Path())
1183 }
1184 if forceNotWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001185 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_not_weak_list,"+forceNotWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001186 linkerDeps = append(linkerDeps, forceNotWeakSymbols.Path())
1187 }
1188 if forceWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001189 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_weak_list,"+forceWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001190 linkerDeps = append(linkerDeps, forceWeakSymbols.Path())
1191 }
1192 }
Colin Cross8e21aa52020-09-28 18:28:02 -07001193 if library.versionScriptPath.Valid() {
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001194 linkerScriptFlags := "-Wl,--version-script," + library.versionScriptPath.String()
Colin Cross4af21ed2019-11-04 09:37:55 -08001195 flags.Local.LdFlags = append(flags.Local.LdFlags, linkerScriptFlags)
Colin Cross8e21aa52020-09-28 18:28:02 -07001196 linkerDeps = append(linkerDeps, library.versionScriptPath.Path())
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001197 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001198
1199 fileName := library.getLibName(ctx) + flags.Toolchain.ShlibSuffix()
1200 outputFile := android.PathForModuleOut(ctx, fileName)
Colin Cross0de8a1e2020-09-18 14:15:30 -07001201 unstrippedOutputFile := outputFile
Colin Cross4d9c2d12016-07-29 12:48:20 -07001202
Josh Gao75a50a22019-06-07 17:58:59 -07001203 var implicitOutputs android.WritablePaths
1204 if ctx.Windows() {
1205 importLibraryPath := android.PathForModuleOut(ctx, pathtools.ReplaceExtension(fileName, "lib"))
1206
Colin Cross4af21ed2019-11-04 09:37:55 -08001207 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,--out-implib="+importLibraryPath.String())
Josh Gao75a50a22019-06-07 17:58:59 -07001208 implicitOutputs = append(implicitOutputs, importLibraryPath)
1209 }
1210
Colin Cross4d9c2d12016-07-29 12:48:20 -07001211 builderFlags := flagsToBuilderFlags(flags)
1212
Colin Crossb496cfd2018-09-10 16:50:05 -07001213 // Optimize out relinking against shared libraries whose interface hasn't changed by
1214 // depending on a table of contents file instead of the library itself.
Colin Cross70dda7e2019-10-01 22:05:35 -07001215 tocFile := outputFile.ReplaceExtension(ctx, flags.Toolchain.ShlibSuffix()[1:]+".toc")
Colin Crossb496cfd2018-09-10 16:50:05 -07001216 library.tocFile = android.OptionalPathForPath(tocFile)
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001217 transformSharedObjectToToc(ctx, outputFile, tocFile, builderFlags)
Colin Cross89562dc2016-10-03 17:47:19 -07001218
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001219 stripFlags := flagsToStripFlags(flags)
Colin Crossadc81a02020-12-14 17:01:55 -08001220 needsStrip := library.stripper.NeedsStrip(ctx)
1221 if library.buildStubs() {
1222 // No need to strip stubs libraries
1223 needsStrip = false
1224 }
1225 if needsStrip {
Yi Kongb5c34d72018-11-07 16:28:49 -08001226 if ctx.Darwin() {
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001227 stripFlags.StripUseGnuStrip = true
Yi Kongb5c34d72018-11-07 16:28:49 -08001228 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001229 strippedOutputFile := outputFile
1230 outputFile = android.PathForModuleOut(ctx, "unstripped", fileName)
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001231 library.stripper.StripExecutableOrSharedLib(ctx, outputFile, strippedOutputFile, stripFlags)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001232 }
Colin Crossb60190a2018-09-04 16:28:17 -07001233 library.unstrippedOutputFile = outputFile
1234
Colin Crossd7227f92019-09-05 14:26:33 -07001235 outputFile = maybeInjectBoringSSLHash(ctx, outputFile, library.Properties.Inject_bssl_hash, fileName)
Pete Bentley803e1612019-08-06 22:19:59 +01001236
Dan Willemsen569edc52018-11-19 09:33:29 -08001237 if Bool(library.baseLinker.Properties.Use_version_lib) {
1238 if ctx.Host() {
1239 versionedOutputFile := outputFile
1240 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
1241 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1242 } else {
1243 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001244 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -08001245
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001246 if library.stripper.NeedsStrip(ctx) {
Dan Willemsen569edc52018-11-19 09:33:29 -08001247 out := android.PathForModuleOut(ctx, "versioned-stripped", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001248 library.distFile = out
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001249 library.stripper.StripExecutableOrSharedLib(ctx, versionedOutputFile, out, stripFlags)
Dan Willemsen569edc52018-11-19 09:33:29 -08001250 }
1251
1252 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1253 }
Colin Cross86803cf2018-02-15 14:12:26 -08001254 }
1255
Jiyong Park64a44f22019-01-18 14:37:08 +09001256 sharedLibs := deps.EarlySharedLibs
1257 sharedLibs = append(sharedLibs, deps.SharedLibs...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001258 sharedLibs = append(sharedLibs, deps.LateSharedLibs...)
1259
Jiyong Park64a44f22019-01-18 14:37:08 +09001260 linkerDeps = append(linkerDeps, deps.EarlySharedLibsDeps...)
Colin Cross26c34ed2016-09-30 17:10:16 -07001261 linkerDeps = append(linkerDeps, deps.SharedLibsDeps...)
1262 linkerDeps = append(linkerDeps, deps.LateSharedLibsDeps...)
Dan Willemsena03cf6d2016-09-26 15:45:04 -07001263 linkerDeps = append(linkerDeps, objs.tidyFiles...)
Colin Cross26c34ed2016-09-30 17:10:16 -07001264
Colin Cross127bb8b2020-12-16 16:46:01 -08001265 if Bool(library.Properties.Sort_bss_symbols_by_size) && !library.buildStubs() {
Vic Yang6cd1be82019-06-24 16:08:48 -07001266 unsortedOutputFile := android.PathForModuleOut(ctx, "unsorted", fileName)
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001267 transformObjToDynamicBinary(ctx, objs.objFiles, sharedLibs,
Vic Yang6cd1be82019-06-24 16:08:48 -07001268 deps.StaticLibs, deps.LateStaticLibs, deps.WholeStaticLibs,
1269 linkerDeps, deps.CrtBegin, deps.CrtEnd, false, builderFlags, unsortedOutputFile, implicitOutputs)
1270
1271 symbolOrderingFile := android.PathForModuleOut(ctx, "unsorted", fileName+".symbol_order")
1272 symbolOrderingFlag := library.baseLinker.sortBssSymbolsBySize(ctx, unsortedOutputFile, symbolOrderingFile, builderFlags)
Colin Cross6d88dba2019-11-06 07:06:58 -08001273 builderFlags.localLdFlags += " " + symbolOrderingFlag
Vic Yang6cd1be82019-06-24 16:08:48 -07001274 linkerDeps = append(linkerDeps, symbolOrderingFile)
1275 }
1276
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001277 transformObjToDynamicBinary(ctx, objs.objFiles, sharedLibs,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001278 deps.StaticLibs, deps.LateStaticLibs, deps.WholeStaticLibs,
Josh Gao75a50a22019-06-07 17:58:59 -07001279 linkerDeps, deps.CrtBegin, deps.CrtEnd, false, builderFlags, outputFile, implicitOutputs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001280
Dan Willemsen581341d2017-02-09 16:16:31 -08001281 objs.coverageFiles = append(objs.coverageFiles, deps.StaticLibObjs.coverageFiles...)
1282 objs.coverageFiles = append(objs.coverageFiles, deps.WholeStaticLibObjs.coverageFiles...)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001283
1284 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.StaticLibObjs.sAbiDumpFiles...)
1285 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.WholeStaticLibObjs.sAbiDumpFiles...)
1286
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001287 library.coverageOutputFile = transformCoverageFilesToZip(ctx, objs, library.getLibName(ctx))
Colin Cross0de8a1e2020-09-18 14:15:30 -07001288 library.linkSAbiDumpFiles(ctx, objs, fileName, unstrippedOutputFile)
Dan Willemsen581341d2017-02-09 16:16:31 -08001289
Colin Cross0de8a1e2020-09-18 14:15:30 -07001290 var staticAnalogue *StaticLibraryInfo
1291 if static := ctx.GetDirectDepsWithTag(staticVariantTag); len(static) > 0 {
1292 s := ctx.OtherModuleProvider(static[0], StaticLibraryInfoProvider).(StaticLibraryInfo)
1293 staticAnalogue = &s
1294 }
1295
1296 ctx.SetProvider(SharedLibraryInfoProvider, SharedLibraryInfo{
1297 TableOfContents: android.OptionalPathForPath(tocFile),
1298 SharedLibrary: unstrippedOutputFile,
1299 UnstrippedSharedLibrary: library.unstrippedOutputFile,
1300 CoverageSharedLibrary: library.coverageOutputFile,
1301 StaticAnalogue: staticAnalogue,
Colin Cross2df81772021-01-26 11:00:18 -08001302 Target: ctx.Target(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001303 })
1304
1305 stubs := ctx.GetDirectDepsWithTag(stubImplDepTag)
1306 if len(stubs) > 0 {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001307 var stubsInfo []SharedStubLibrary
Colin Cross0de8a1e2020-09-18 14:15:30 -07001308 for _, stub := range stubs {
1309 stubInfo := ctx.OtherModuleProvider(stub, SharedLibraryInfoProvider).(SharedLibraryInfo)
1310 flagInfo := ctx.OtherModuleProvider(stub, FlagExporterInfoProvider).(FlagExporterInfo)
Chris Parsons3c27ca32020-11-20 12:42:07 -05001311 stubsInfo = append(stubsInfo, SharedStubLibrary{
Colin Cross31076b32020-10-23 17:22:06 -07001312 Version: moduleLibraryInterface(stub).stubsVersion(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001313 SharedLibraryInfo: stubInfo,
1314 FlagExporterInfo: flagInfo,
1315 })
1316 }
Chris Parsons3c27ca32020-11-20 12:42:07 -05001317 ctx.SetProvider(SharedLibraryStubsProvider, SharedLibraryStubsInfo{
1318 SharedStubLibraries: stubsInfo,
Colin Cross0de8a1e2020-09-18 14:15:30 -07001319
Colin Cross127bb8b2020-12-16 16:46:01 -08001320 IsLLNDK: ctx.IsLlndk(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001321 })
1322 }
1323
1324 return unstrippedOutputFile
Colin Cross4d9c2d12016-07-29 12:48:20 -07001325}
1326
Jiyong Parkaf6d8952019-01-31 12:21:23 +09001327func (library *libraryDecorator) unstrippedOutputFilePath() android.Path {
1328 return library.unstrippedOutputFile
1329}
1330
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001331func (library *libraryDecorator) disableStripping() {
1332 library.stripper.StripProperties.Strip.None = BoolPtr(true)
1333}
1334
Pirama Arumuga Nainar65c95ff2019-03-25 10:21:31 -07001335func (library *libraryDecorator) nativeCoverage() bool {
1336 if library.header() || library.buildStubs() {
1337 return false
1338 }
1339 return true
1340}
1341
Jiyong Parkee9a98d2019-08-09 14:44:36 +09001342func (library *libraryDecorator) coverageOutputFilePath() android.OptionalPath {
1343 return library.coverageOutputFile
1344}
1345
Logan Chien7eefdc42018-07-11 18:10:41 +08001346func getRefAbiDumpFile(ctx ModuleContext, vndkVersion, fileName string) android.Path {
Hsin-Yi Chen27d235f2020-03-26 17:50:29 +08001347 // The logic must be consistent with classifySourceAbiDump.
Colin Cross95f1ca02020-10-29 20:47:22 -07001348 isNdk := ctx.isNdk(ctx.Config())
Colin Cross127bb8b2020-12-16 16:46:01 -08001349 isLlndkOrVndk := ctx.IsLlndkPublic() || (ctx.useVndk() && ctx.isVndk())
Logan Chien7eefdc42018-07-11 18:10:41 +08001350
Hsin-Yi Chen53489642019-07-31 17:10:45 +08001351 refAbiDumpTextFile := android.PathForVndkRefAbiDump(ctx, vndkVersion, fileName, isNdk, isLlndkOrVndk, false)
1352 refAbiDumpGzipFile := android.PathForVndkRefAbiDump(ctx, vndkVersion, fileName, isNdk, isLlndkOrVndk, true)
Logan Chien7eefdc42018-07-11 18:10:41 +08001353
1354 if refAbiDumpTextFile.Valid() {
1355 if refAbiDumpGzipFile.Valid() {
1356 ctx.ModuleErrorf(
1357 "Two reference ABI dump files are found: %q and %q. Please delete the stale one.",
1358 refAbiDumpTextFile, refAbiDumpGzipFile)
1359 return nil
1360 }
1361 return refAbiDumpTextFile.Path()
1362 }
1363 if refAbiDumpGzipFile.Valid() {
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001364 return unzipRefDump(ctx, refAbiDumpGzipFile.Path(), fileName)
Logan Chien7eefdc42018-07-11 18:10:41 +08001365 }
1366 return nil
1367}
1368
Jayant Chowdhary6ab3d842017-06-26 12:52:58 -07001369func (library *libraryDecorator) linkSAbiDumpFiles(ctx ModuleContext, objs Objects, fileName string, soFile android.Path) {
Yo Chiang2bbadfa2020-12-14 11:42:16 +08001370 if library.sabi.shouldCreateSourceAbiDump() {
Inseob Kim96f17f02020-06-09 22:05:09 +09001371 var vndkVersion string
1372
1373 if ctx.useVndk() {
1374 // For modules linking against vndk, follow its vndk version
1375 vndkVersion = ctx.Module().(*Module).VndkVersion()
1376 } else {
1377 // Regard the other modules as PLATFORM_VNDK_VERSION
1378 vndkVersion = ctx.DeviceConfig().PlatformVndkVersion()
Logan Chienf3511742017-10-31 18:04:35 +08001379 }
1380
Jayant Chowdharya4fce192017-09-06 13:10:03 -07001381 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001382 var SourceAbiFlags []string
1383 for _, dir := range exportIncludeDirs.Strings() {
Jayant Chowdhary715cac32017-04-20 06:53:59 -07001384 SourceAbiFlags = append(SourceAbiFlags, "-I"+dir)
1385 }
Inseob Kim69378442019-06-03 19:10:47 +09001386 for _, reexportedInclude := range library.sabi.Properties.ReexportedIncludes {
1387 SourceAbiFlags = append(SourceAbiFlags, "-I"+reexportedInclude)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001388 }
1389 exportedHeaderFlags := strings.Join(SourceAbiFlags, " ")
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001390 library.sAbiOutputFile = transformDumpToLinkedDump(ctx, objs.sAbiDumpFiles, soFile, fileName, exportedHeaderFlags,
Jiyong Parka034b832019-08-27 14:02:19 +09001391 android.OptionalPathForModuleSrc(ctx, library.symbolFileForAbiCheck(ctx)),
Logan Chiene3d7a0d2019-01-17 00:18:02 +08001392 library.Properties.Header_abi_checker.Exclude_symbol_versions,
1393 library.Properties.Header_abi_checker.Exclude_symbol_tags)
Logan Chien2f2b8902018-07-10 15:01:19 +08001394
Yo Chiang2bbadfa2020-12-14 11:42:16 +08001395 addLsdumpPath(classifySourceAbiDump(ctx) + ":" + library.sAbiOutputFile.String())
Hsin-Yi Chen53489642019-07-31 17:10:45 +08001396
Logan Chien7eefdc42018-07-11 18:10:41 +08001397 refAbiDumpFile := getRefAbiDumpFile(ctx, vndkVersion, fileName)
1398 if refAbiDumpFile != nil {
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001399 library.sAbiDiff = sourceAbiDiff(ctx, library.sAbiOutputFile.Path(),
Logan Chien2a65dda2019-10-01 15:58:07 -07001400 refAbiDumpFile, fileName, exportedHeaderFlags,
1401 Bool(library.Properties.Header_abi_checker.Check_all_apis),
Colin Cross127bb8b2020-12-16 16:46:01 -08001402 ctx.IsLlndk(), ctx.isNdk(ctx.Config()), ctx.IsVndkExt())
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001403 }
1404 }
1405}
1406
Colin Cross127bb8b2020-12-16 16:46:01 -08001407func processLLNDKHeaders(ctx ModuleContext, srcHeaderDir string, outDir android.ModuleGenPath) android.Path {
1408 srcDir := android.PathForModuleSrc(ctx, srcHeaderDir)
1409 srcFiles := ctx.GlobFiles(filepath.Join(srcDir.String(), "**/*.h"), nil)
1410
1411 var installPaths []android.WritablePath
1412 for _, header := range srcFiles {
1413 headerDir := filepath.Dir(header.String())
1414 relHeaderDir, err := filepath.Rel(srcDir.String(), headerDir)
1415 if err != nil {
1416 ctx.ModuleErrorf("filepath.Rel(%q, %q) failed: %s",
1417 srcDir.String(), headerDir, err)
1418 continue
1419 }
1420
1421 installPaths = append(installPaths, outDir.Join(ctx, relHeaderDir, header.Base()))
1422 }
1423
1424 return processHeadersWithVersioner(ctx, srcDir, outDir, srcFiles, installPaths)
1425}
1426
Chris Parsons3c27ca32020-11-20 12:42:07 -05001427// link registers actions to link this library, and sets various fields
1428// on this library to reflect information that should be exported up the build
1429// tree (for example, exported flags and include paths).
Colin Crossb916a382016-07-29 17:28:03 -07001430func (library *libraryDecorator) link(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001431 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001432
Colin Cross127bb8b2020-12-16 16:46:01 -08001433 if ctx.IsLlndk() {
1434 if len(library.Properties.Llndk.Export_preprocessed_headers) > 0 {
1435 // This is the vendor variant of an LLNDK library with preprocessed headers.
1436 genHeaderOutDir := android.PathForModuleGen(ctx, "include")
1437
1438 var timestampFiles android.Paths
1439 for _, dir := range library.Properties.Llndk.Export_preprocessed_headers {
1440 timestampFiles = append(timestampFiles, processLLNDKHeaders(ctx, dir, genHeaderOutDir))
1441 }
1442
1443 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1444 library.reexportSystemDirs(genHeaderOutDir)
1445 } else {
1446 library.reexportDirs(genHeaderOutDir)
1447 }
1448
1449 library.reexportDeps(timestampFiles...)
1450 }
1451
Colin Cross0fb7fcd2021-03-02 11:00:07 -08001452 // override the module's export_include_dirs with llndk.override_export_include_dirs
1453 // if it is set.
1454 if override := library.Properties.Llndk.Override_export_include_dirs; override != nil {
1455 library.flagExporter.Properties.Export_include_dirs = override
1456 }
1457
Colin Cross127bb8b2020-12-16 16:46:01 -08001458 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1459 library.flagExporter.Properties.Export_system_include_dirs = append(
1460 library.flagExporter.Properties.Export_system_include_dirs,
1461 library.flagExporter.Properties.Export_include_dirs...)
1462 library.flagExporter.Properties.Export_include_dirs = nil
1463 }
1464 }
1465
Colin Cross5271fea2021-04-27 13:06:04 -07001466 if ctx.IsVendorPublicLibrary() {
1467 // override the module's export_include_dirs with vendor_public_library.override_export_include_dirs
1468 // if it is set.
1469 if override := library.Properties.Vendor_public_library.Override_export_include_dirs; override != nil {
1470 library.flagExporter.Properties.Export_include_dirs = override
1471 }
1472 }
1473
Chris Parsons3c27ca32020-11-20 12:42:07 -05001474 // Linking this library consists of linking `deps.Objs` (.o files in dependencies
1475 // of this library), together with `objs` (.o files created by compiling this
1476 // library).
Colin Crossad59e752017-11-16 14:29:11 -08001477 objs = deps.Objs.Copy().Append(objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001478 var out android.Path
Colin Crossa48ab5b2017-02-14 15:28:44 -08001479 if library.static() || library.header() {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001480 out = library.linkStatic(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001481 } else {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001482 out = library.linkShared(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001483 }
1484
Chris Parsons3c27ca32020-11-20 12:42:07 -05001485 // Export include paths and flags to be propagated up the tree.
Inseob Kim69378442019-06-03 19:10:47 +09001486 library.exportIncludes(ctx)
1487 library.reexportDirs(deps.ReexportedDirs...)
1488 library.reexportSystemDirs(deps.ReexportedSystemDirs...)
1489 library.reexportFlags(deps.ReexportedFlags...)
1490 library.reexportDeps(deps.ReexportedDeps...)
Inseob Kimd110f872019-12-06 13:15:38 +09001491 library.addExportedGeneratedHeaders(deps.ReexportedGeneratedHeaders...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001492
Chris Parsons3c27ca32020-11-20 12:42:07 -05001493 // Optionally export aidl headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001494 if Bool(library.Properties.Aidl.Export_aidl_headers) {
Dan Willemsene1240db2016-11-03 14:28:51 -07001495 if library.baseCompiler.hasSrcExt(".aidl") {
Jiyong Park74955042019-10-22 20:19:51 +09001496 dir := android.PathForModuleGen(ctx, "aidl")
Inseob Kim69378442019-06-03 19:10:47 +09001497 library.reexportDirs(dir)
Inseob Kimd110f872019-12-06 13:15:38 +09001498
Paul Duffin33056e82021-02-19 13:49:08 +00001499 library.reexportDeps(library.baseCompiler.aidlOrderOnlyDeps...)
1500 library.addExportedGeneratedHeaders(library.baseCompiler.aidlHeaders...)
Dan Willemsene1240db2016-11-03 14:28:51 -07001501 }
1502 }
1503
Chris Parsons3c27ca32020-11-20 12:42:07 -05001504 // Optionally export proto headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001505 if Bool(library.Properties.Proto.Export_proto_headers) {
Dan Willemsene1240db2016-11-03 14:28:51 -07001506 if library.baseCompiler.hasSrcExt(".proto") {
Jiyong Park74955042019-10-22 20:19:51 +09001507 var includes android.Paths
Colin Cross19878da2019-03-28 14:45:07 -07001508 if flags.proto.CanonicalPathFromRoot {
Jiyong Park74955042019-10-22 20:19:51 +09001509 includes = append(includes, flags.proto.SubDir)
Colin Cross10d22312017-05-03 11:01:58 -07001510 }
Jiyong Park74955042019-10-22 20:19:51 +09001511 includes = append(includes, flags.proto.Dir)
Inseob Kim69378442019-06-03 19:10:47 +09001512 library.reexportDirs(includes...)
Inseob Kimd110f872019-12-06 13:15:38 +09001513
Paul Duffin33056e82021-02-19 13:49:08 +00001514 library.reexportDeps(library.baseCompiler.protoOrderOnlyDeps...)
1515 library.addExportedGeneratedHeaders(library.baseCompiler.protoHeaders...)
Colin Cross0c461f12016-10-20 16:11:43 -07001516 }
1517 }
1518
Inseob Kim07def122020-11-23 14:43:02 +09001519 // If the library is sysprop_library, expose either public or internal header selectively.
Inseob Kim21f26902018-09-06 00:55:20 +09001520 if library.baseCompiler.hasSrcExt(".sysprop") {
Jiyong Park74955042019-10-22 20:19:51 +09001521 dir := android.PathForModuleGen(ctx, "sysprop", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001522 if library.Properties.Sysprop.Platform != nil {
Inseob Kimc0907f12019-02-08 21:00:45 +09001523 isOwnerPlatform := Bool(library.Properties.Sysprop.Platform)
1524
Inseob Kim07def122020-11-23 14:43:02 +09001525 // If the owner is different from the user, expose public header. That is,
1526 // 1) if the user is product (as owner can only be platform / vendor)
Inseob Kim06410042021-01-18 15:23:28 +09001527 // 2) if the owner is platform and the client is vendor
1528 // We don't care Platform -> Vendor dependency as it's already forbidden.
1529 if ctx.Device() && (ctx.ProductSpecific() || (isOwnerPlatform && ctx.inVendor())) {
Jiyong Park74955042019-10-22 20:19:51 +09001530 dir = android.PathForModuleGen(ctx, "sysprop/public", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001531 }
1532 }
1533
Paul Duffin37e0de52021-02-19 17:05:39 +00001534 // Make sure to only export headers which are within the include directory.
1535 _, headers := android.FilterPathListPredicate(library.baseCompiler.syspropHeaders, func(path android.Path) bool {
1536 _, isRel := android.MaybeRel(ctx, dir.String(), path.String())
1537 return isRel
1538 })
1539
Chris Parsons3c27ca32020-11-20 12:42:07 -05001540 // Add sysprop-related directories to the exported directories of this library.
Inseob Kim69378442019-06-03 19:10:47 +09001541 library.reexportDirs(dir)
Paul Duffin33056e82021-02-19 13:49:08 +00001542 library.reexportDeps(library.baseCompiler.syspropOrderOnlyDeps...)
Paul Duffin37e0de52021-02-19 17:05:39 +00001543 library.addExportedGeneratedHeaders(headers...)
Inseob Kim21f26902018-09-06 00:55:20 +09001544 }
1545
Chris Parsons3c27ca32020-11-20 12:42:07 -05001546 // Add stub-related flags if this library is a stub library.
Jiyong Park892a98f2020-12-14 09:20:00 +09001547 library.exportVersioningMacroIfNeeded(ctx)
Jiyong Parkda732bd2018-11-02 18:23:15 +09001548
Chris Parsons3c27ca32020-11-20 12:42:07 -05001549 // Propagate a Provider containing information about exported flags, deps, and include paths.
Colin Cross0de8a1e2020-09-18 14:15:30 -07001550 library.flagExporter.setProvider(ctx)
1551
Colin Cross4d9c2d12016-07-29 12:48:20 -07001552 return out
1553}
1554
Jiyong Park892a98f2020-12-14 09:20:00 +09001555func (library *libraryDecorator) exportVersioningMacroIfNeeded(ctx android.BaseModuleContext) {
Colin Cross127bb8b2020-12-16 16:46:01 -08001556 if library.buildStubs() && library.stubsVersion() != "" && !library.skipAPIDefine {
Jiyong Park892a98f2020-12-14 09:20:00 +09001557 name := versioningMacroName(ctx.Module().(*Module).ImplementationModuleName(ctx))
Jooyung Han11b0fbd2021-02-05 02:28:22 +09001558 apiLevel, err := android.ApiLevelFromUser(ctx, library.stubsVersion())
1559 if err != nil {
1560 ctx.ModuleErrorf("Can't export version macro: %s", err.Error())
1561 }
1562 library.reexportFlags("-D" + name + "=" + strconv.Itoa(apiLevel.FinalOrPreviewInt()))
Jiyong Park892a98f2020-12-14 09:20:00 +09001563 }
1564}
1565
Chris Parsons3c27ca32020-11-20 12:42:07 -05001566// buildStatic returns true if this library should be built as a static library.
Colin Crossb916a382016-07-29 17:28:03 -07001567func (library *libraryDecorator) buildStatic() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001568 return library.MutatedProperties.BuildStatic &&
1569 BoolDefault(library.StaticProperties.Static.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001570}
1571
Chris Parsons3c27ca32020-11-20 12:42:07 -05001572// buildShared returns true if this library should be built as a shared library.
Colin Crossb916a382016-07-29 17:28:03 -07001573func (library *libraryDecorator) buildShared() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001574 return library.MutatedProperties.BuildShared &&
1575 BoolDefault(library.SharedProperties.Shared.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001576}
1577
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001578func (library *libraryDecorator) objs() Objects {
1579 return library.objects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001580}
1581
Colin Cross0de8a1e2020-09-18 14:15:30 -07001582func (library *libraryDecorator) reuseObjs() Objects {
1583 return library.reuseObjects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001584}
1585
Colin Cross26c34ed2016-09-30 17:10:16 -07001586func (library *libraryDecorator) toc() android.OptionalPath {
1587 return library.tocFile
1588}
1589
Jiyong Parkf1194352019-02-25 11:05:47 +09001590func (library *libraryDecorator) installSymlinkToRuntimeApex(ctx ModuleContext, file android.Path) {
1591 dir := library.baseInstaller.installDir(ctx)
1592 dirOnDevice := android.InstallPathToOnDevicePath(ctx, dir)
1593 target := "/" + filepath.Join("apex", "com.android.runtime", dir.Base(), "bionic", file.Base())
1594 ctx.InstallAbsoluteSymlink(dir, file.Base(), target)
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001595 library.postInstallCmds = append(library.postInstallCmds, makeSymlinkCmd(dirOnDevice, file.Base(), target))
Jiyong Parkf1194352019-02-25 11:05:47 +09001596}
1597
Colin Crossb916a382016-07-29 17:28:03 -07001598func (library *libraryDecorator) install(ctx ModuleContext, file android.Path) {
Colin Crossc43ae772017-04-14 15:42:53 -07001599 if library.shared() {
Justin Yun8fe12122017-12-07 17:18:15 +09001600 if ctx.Device() && ctx.useVndk() {
Jooyung Han261e1582020-10-20 18:54:21 +09001601 // set subDir for VNDK extensions
Ivan Lozanof9e21722020-12-02 09:00:51 -05001602 if ctx.IsVndkExt() {
Jooyung Han261e1582020-10-20 18:54:21 +09001603 if ctx.isVndkSp() {
1604 library.baseInstaller.subDir = "vndk-sp"
1605 } else {
1606 library.baseInstaller.subDir = "vndk"
1607 }
1608 }
1609
Justin Yun31094b12020-12-24 16:11:23 +09001610 // In some cases we want to use core variant for VNDK-Core libs.
1611 // Skip product variant since VNDKs use only the vendor variant.
1612 if ctx.isVndk() && !ctx.isVndkSp() && !ctx.IsVndkExt() && !ctx.inProduct() {
Vic Yang1a5812a2020-01-31 10:38:40 -08001613 mayUseCoreVariant := true
1614
1615 if ctx.mustUseVendorVariant() {
1616 mayUseCoreVariant = false
1617 }
1618
Vic Yang1a5812a2020-01-31 10:38:40 -08001619 if ctx.Config().CFIEnabledForPath(ctx.ModuleDir()) && ctx.Arch().ArchType == android.Arm64 {
1620 mayUseCoreVariant = false
1621 }
1622
1623 if mayUseCoreVariant {
Vic Yangd92090f2020-01-08 14:32:28 -08001624 library.checkSameCoreVariant = true
1625 if ctx.DeviceConfig().VndkUseCoreVariant() {
1626 library.useCoreVariant = true
1627 }
Vic Yangefd249e2018-11-12 20:19:56 -08001628 }
Justin Yun8fe12122017-12-07 17:18:15 +09001629 }
Logan Chienf3511742017-10-31 18:04:35 +08001630
Jooyung Han261e1582020-10-20 18:54:21 +09001631 // do not install vndk libs
1632 // vndk libs are packaged into VNDK APEX
Ivan Lozanof9e21722020-12-02 09:00:51 -05001633 if ctx.isVndk() && !ctx.IsVndkExt() {
Jooyung Han261e1582020-10-20 18:54:21 +09001634 return
Justin Yun8effde42017-06-23 19:24:43 +09001635 }
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001636 } else if library.hasStubsVariants() && !ctx.Host() && ctx.directlyInAnyApex() {
Jiyong Parkf1194352019-02-25 11:05:47 +09001637 // Bionic libraries (e.g. libc.so) is installed to the bootstrap subdirectory.
1638 // The original path becomes a symlink to the corresponding file in the
1639 // runtime APEX.
Colin Cross3b19f5d2019-09-17 14:45:31 -07001640 translatedArch := ctx.Target().NativeBridge == android.NativeBridgeEnabled
Colin Cross56a83212020-09-15 18:30:11 -07001641 if InstallToBootstrap(ctx.baseModuleName(), ctx.Config()) && !library.buildStubs() &&
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001642 !translatedArch && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() {
Martin Stjernholm279de572019-09-10 23:18:20 +01001643 if ctx.Device() {
Jiyong Parkc3e2c862019-03-16 01:10:08 +09001644 library.installSymlinkToRuntimeApex(ctx, file)
1645 }
Jiyong Park429660f2019-01-16 22:31:11 +09001646 library.baseInstaller.subDir = "bootstrap"
1647 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001648 } else if ctx.directlyInAnyApex() && ctx.IsLlndk() && !isBionic(ctx.baseModuleName()) {
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001649 // Skip installing LLNDK (non-bionic) libraries moved to APEX.
Colin Crossa9c8c9f2020-12-16 10:20:23 -08001650 ctx.Module().HideFromMake()
Justin Yun8effde42017-06-23 19:24:43 +09001651 }
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001652
Colin Cross4d9c2d12016-07-29 12:48:20 -07001653 library.baseInstaller.install(ctx, file)
1654 }
Dan Albertf563d252017-10-13 00:29:00 -07001655
Dan Albert281f22b2017-12-13 15:03:47 -08001656 if Bool(library.Properties.Static_ndk_lib) && library.static() &&
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001657 !ctx.useVndk() && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() && ctx.Device() &&
Jiyong Park7ed9de32018-10-15 22:25:07 +09001658 library.baseLinker.sanitize.isUnsanitizedVariant() &&
Colin Cross95b07f22020-12-16 11:06:50 -08001659 ctx.isForPlatform() && !ctx.isPreventInstall() {
Dan Albertf563d252017-10-13 00:29:00 -07001660 installPath := getNdkSysrootBase(ctx).Join(
Dan Albertea4b7b92018-04-25 16:05:30 -07001661 ctx, "usr/lib", config.NDKTriple(ctx.toolchain()), file.Base())
Dan Albertf563d252017-10-13 00:29:00 -07001662
1663 ctx.ModuleBuild(pctx, android.ModuleBuildParams{
1664 Rule: android.Cp,
1665 Description: "install " + installPath.Base(),
1666 Output: installPath,
1667 Input: file,
1668 })
1669
Colin Cross0875c522017-11-28 17:34:01 -08001670 library.ndkSysrootPath = installPath
Dan Albertf563d252017-10-13 00:29:00 -07001671 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001672}
1673
Paul Duffin0cb37b92020-03-04 14:52:46 +00001674func (library *libraryDecorator) everInstallable() bool {
1675 // Only shared and static libraries are installed. Header libraries (which are
1676 // neither static or shared) are not installed.
1677 return library.shared() || library.static()
1678}
1679
Chris Parsons3c27ca32020-11-20 12:42:07 -05001680// static returns true if this library is for a "static' variant.
Colin Crossb916a382016-07-29 17:28:03 -07001681func (library *libraryDecorator) static() bool {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001682 return library.MutatedProperties.VariantIsStatic
Colin Cross4d9c2d12016-07-29 12:48:20 -07001683}
1684
Chris Parsons3c27ca32020-11-20 12:42:07 -05001685// shared returns true if this library is for a "shared' variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001686func (library *libraryDecorator) shared() bool {
1687 return library.MutatedProperties.VariantIsShared
1688}
1689
Chris Parsons3c27ca32020-11-20 12:42:07 -05001690// header returns true if this library is for a header-only variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001691func (library *libraryDecorator) header() bool {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001692 // Neither "static" nor "shared" implies this library is header-only.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001693 return !library.static() && !library.shared()
1694}
1695
Chris Parsons3c27ca32020-11-20 12:42:07 -05001696// setStatic marks the library variant as "static".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001697func (library *libraryDecorator) setStatic() {
1698 library.MutatedProperties.VariantIsStatic = true
1699 library.MutatedProperties.VariantIsShared = false
1700}
1701
Chris Parsons3c27ca32020-11-20 12:42:07 -05001702// setShared marks the library variant as "shared".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001703func (library *libraryDecorator) setShared() {
1704 library.MutatedProperties.VariantIsStatic = false
1705 library.MutatedProperties.VariantIsShared = true
Colin Crossb916a382016-07-29 17:28:03 -07001706}
1707
Chris Parsons3c27ca32020-11-20 12:42:07 -05001708// BuildOnlyStatic disables building this library as a shared library.
Colin Crossab3b7322016-12-09 14:46:15 -08001709func (library *libraryDecorator) BuildOnlyStatic() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001710 library.MutatedProperties.BuildShared = false
Colin Crossab3b7322016-12-09 14:46:15 -08001711}
1712
Chris Parsons3c27ca32020-11-20 12:42:07 -05001713// BuildOnlyShared disables building this library as a static library.
Colin Crossab3b7322016-12-09 14:46:15 -08001714func (library *libraryDecorator) BuildOnlyShared() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001715 library.MutatedProperties.BuildStatic = false
Colin Crossab3b7322016-12-09 14:46:15 -08001716}
1717
Chris Parsons3c27ca32020-11-20 12:42:07 -05001718// HeaderOnly disables building this library as a shared or static library;
1719// the library only exists to propagate header file dependencies up the build graph.
Colin Cross5950f382016-12-13 12:50:57 -08001720func (library *libraryDecorator) HeaderOnly() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001721 library.MutatedProperties.BuildShared = false
1722 library.MutatedProperties.BuildStatic = false
Colin Cross5950f382016-12-13 12:50:57 -08001723}
1724
Colin Cross127bb8b2020-12-16 16:46:01 -08001725// hasLLNDKStubs returns true if this cc_library module has a variant that will build LLNDK stubs.
1726func (library *libraryDecorator) hasLLNDKStubs() bool {
Colin Cross203b4212021-04-26 17:19:41 -07001727 return String(library.Properties.Llndk.Symbol_file) != ""
Colin Cross0fb7fcd2021-03-02 11:00:07 -08001728}
1729
Colin Cross203b4212021-04-26 17:19:41 -07001730// hasLLNDKStubs returns true if this cc_library module has a variant that will build LLNDK stubs.
Colin Cross1f3f1302021-04-26 18:37:44 -07001731func (library *libraryDecorator) hasLLNDKHeaders() bool {
1732 return Bool(library.Properties.Llndk.Llndk_headers)
1733}
1734
Colin Cross5271fea2021-04-27 13:06:04 -07001735// hasVendorPublicLibrary returns true if this cc_library module has a variant that will build
1736// vendor public library stubs.
1737func (library *libraryDecorator) hasVendorPublicLibrary() bool {
1738 return String(library.Properties.Vendor_public_library.Symbol_file) != ""
1739}
1740
Colin Cross0477b422020-10-13 18:43:54 -07001741func (library *libraryDecorator) implementationModuleName(name string) string {
1742 return name
1743}
1744
Jiyong Park7ed9de32018-10-15 22:25:07 +09001745func (library *libraryDecorator) buildStubs() bool {
1746 return library.MutatedProperties.BuildStubs
1747}
1748
Jiyong Parka034b832019-08-27 14:02:19 +09001749func (library *libraryDecorator) symbolFileForAbiCheck(ctx ModuleContext) *string {
1750 if library.Properties.Header_abi_checker.Symbol_file != nil {
1751 return library.Properties.Header_abi_checker.Symbol_file
1752 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001753 if ctx.Module().(*Module).IsLlndk() {
1754 return library.Properties.Llndk.Symbol_file
1755 }
Colin Cross31076b32020-10-23 17:22:06 -07001756 if library.hasStubsVariants() && library.Properties.Stubs.Symbol_file != nil {
Jiyong Parka034b832019-08-27 14:02:19 +09001757 return library.Properties.Stubs.Symbol_file
1758 }
1759 return nil
1760}
1761
Colin Crossc88c2722020-09-28 17:32:47 -07001762func (library *libraryDecorator) hasStubsVariants() bool {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001763 // Just having stubs.symbol_file is enough to create a stub variant. In that case
1764 // the stub for the future API level is created.
1765 return library.Properties.Stubs.Symbol_file != nil ||
1766 len(library.Properties.Stubs.Versions) > 0
Colin Crossc88c2722020-09-28 17:32:47 -07001767}
1768
Colin Cross3572cf72020-10-01 15:58:11 -07001769func (library *libraryDecorator) stubsVersions(ctx android.BaseMutatorContext) []string {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001770 if !library.hasStubsVariants() {
1771 return nil
1772 }
1773
1774 // Future API level is implicitly added if there isn't
1775 vers := library.Properties.Stubs.Versions
1776 if inList(android.FutureApiLevel.String(), vers) {
1777 return vers
1778 }
1779 // In some cases, people use the raw value "10000" in the versions property.
1780 // We shouldn't add the future API level in that case, otherwise there will
1781 // be two identical versions.
1782 if inList(strconv.Itoa(android.FutureApiLevel.FinalOrFutureInt()), vers) {
1783 return vers
1784 }
1785 return append(vers, android.FutureApiLevel.String())
Colin Crossc88c2722020-09-28 17:32:47 -07001786}
1787
1788func (library *libraryDecorator) setStubsVersion(version string) {
1789 library.MutatedProperties.StubsVersion = version
1790}
1791
Jiyong Park7ed9de32018-10-15 22:25:07 +09001792func (library *libraryDecorator) stubsVersion() string {
1793 return library.MutatedProperties.StubsVersion
1794}
1795
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001796func (library *libraryDecorator) setBuildStubs(isLatest bool) {
Colin Crossc88c2722020-09-28 17:32:47 -07001797 library.MutatedProperties.BuildStubs = true
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001798 library.MutatedProperties.IsLatestVersion = isLatest
Colin Crossc88c2722020-09-28 17:32:47 -07001799}
1800
1801func (library *libraryDecorator) setAllStubsVersions(versions []string) {
1802 library.MutatedProperties.AllStubsVersions = versions
1803}
1804
1805func (library *libraryDecorator) allStubsVersions() []string {
1806 return library.MutatedProperties.AllStubsVersions
1807}
1808
Jooyung Hanad4c1872020-02-27 17:56:44 +09001809func (library *libraryDecorator) isLatestStubVersion() bool {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001810 return library.MutatedProperties.IsLatestVersion
Jooyung Hanad4c1872020-02-27 17:56:44 +09001811}
1812
Jiyong Parka90ca002019-10-07 15:47:24 +09001813func (library *libraryDecorator) availableFor(what string) bool {
1814 var list []string
1815 if library.static() {
1816 list = library.StaticProperties.Static.Apex_available
1817 } else if library.shared() {
1818 list = library.SharedProperties.Shared.Apex_available
1819 }
1820 if len(list) == 0 {
1821 return false
1822 }
1823 return android.CheckAvailableForApex(what, list)
1824}
1825
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001826func (library *libraryDecorator) makeUninstallable(mod *Module) {
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001827 if library.static() && library.buildStatic() && !library.buildStubs() {
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001828 // If we're asked to make a static library uninstallable we don't do
1829 // anything since AndroidMkEntries always sets LOCAL_UNINSTALLABLE_MODULE
1830 // for these entries. This is done to still get the make targets for NOTICE
1831 // files from notice_files.mk, which other libraries might depend on.
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001832 return
1833 }
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001834 mod.ModuleBase.MakeUninstallable()
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001835}
1836
Colin Cross571cccf2019-02-04 11:22:08 -08001837var versioningMacroNamesListKey = android.NewOnceKey("versioningMacroNamesList")
1838
Chris Parsons3c27ca32020-11-20 12:42:07 -05001839// versioningMacroNamesList returns a singleton map, where keys are "version macro names",
1840// and values are the module name responsible for registering the version macro name.
1841//
1842// Version macros are used when building against stubs, to provide version information about
1843// the stub. Only stub libraries should have an entry in this list.
1844//
1845// For example, when building against libFoo#ver, __LIBFOO_API__ macro is set to ver so
1846// that headers from libFoo can be conditionally compiled (this may hide APIs
1847// that are not available for the version).
1848//
1849// This map is used to ensure that there aren't conflicts between these version macro names.
Jiyong Parkda732bd2018-11-02 18:23:15 +09001850func versioningMacroNamesList(config android.Config) *map[string]string {
Colin Cross571cccf2019-02-04 11:22:08 -08001851 return config.Once(versioningMacroNamesListKey, func() interface{} {
Jiyong Parkda732bd2018-11-02 18:23:15 +09001852 m := make(map[string]string)
1853 return &m
1854 }).(*map[string]string)
1855}
1856
1857// alphanumeric and _ characters are preserved.
1858// other characters are all converted to _
1859var charsNotForMacro = regexp.MustCompile("[^a-zA-Z0-9_]+")
1860
Chris Parsons3c27ca32020-11-20 12:42:07 -05001861// versioningMacroName returns the canonical version macro name for the given module.
Jiyong Parkda732bd2018-11-02 18:23:15 +09001862func versioningMacroName(moduleName string) string {
1863 macroName := charsNotForMacro.ReplaceAllString(moduleName, "_")
Jooyung Hanb04a4992020-03-13 18:57:35 +09001864 macroName = strings.ToUpper(macroName)
Jiyong Parkda732bd2018-11-02 18:23:15 +09001865 return "__" + macroName + "_API__"
1866}
1867
Chris Parsons3c27ca32020-11-20 12:42:07 -05001868// NewLibrary builds and returns a new Module corresponding to a C++ library.
1869// Individual module implementations which comprise a C++ library (or something like
1870// a C++ library) should call this function, set some fields on the result, and
1871// then call the Init function.
Colin Crossab3b7322016-12-09 14:46:15 -08001872func NewLibrary(hod android.HostOrDeviceSupported) (*Module, *libraryDecorator) {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001873 module := newModule(hod, android.MultilibBoth)
1874
Colin Crossb916a382016-07-29 17:28:03 -07001875 library := &libraryDecorator{
Colin Crossa48ab5b2017-02-14 15:28:44 -08001876 MutatedProperties: LibraryMutatedProperties{
Colin Crossab3b7322016-12-09 14:46:15 -08001877 BuildShared: true,
1878 BuildStatic: true,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001879 },
Colin Crossb916a382016-07-29 17:28:03 -07001880 baseCompiler: NewBaseCompiler(),
Dan Albert61f32122018-07-26 14:00:24 -07001881 baseLinker: NewBaseLinker(module.sanitize),
Colin Crossb916a382016-07-29 17:28:03 -07001882 baseInstaller: NewBaseInstaller("lib", "lib64", InstallInSystem),
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001883 sabi: module.sabi,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001884 }
1885
Colin Crossb916a382016-07-29 17:28:03 -07001886 module.compiler = library
1887 module.linker = library
1888 module.installer = library
Colin Cross31076b32020-10-23 17:22:06 -07001889 module.library = library
Colin Crossb916a382016-07-29 17:28:03 -07001890
1891 return module, library
1892}
1893
Colin Cross10d22312017-05-03 11:01:58 -07001894// connects a shared library to a static library in order to reuse its .o files to avoid
1895// compiling source files twice.
1896func reuseStaticLibrary(mctx android.BottomUpMutatorContext, static, shared *Module) {
1897 if staticCompiler, ok := static.compiler.(*libraryDecorator); ok {
1898 sharedCompiler := shared.compiler.(*libraryDecorator)
Dan Willemsen3a26eef2018-12-03 15:25:46 -08001899
1900 // Check libraries in addition to cflags, since libraries may be exporting different
1901 // include directories.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001902 if len(staticCompiler.StaticProperties.Static.Cflags) == 0 &&
1903 len(sharedCompiler.SharedProperties.Shared.Cflags) == 0 &&
1904 len(staticCompiler.StaticProperties.Static.Whole_static_libs) == 0 &&
1905 len(sharedCompiler.SharedProperties.Shared.Whole_static_libs) == 0 &&
1906 len(staticCompiler.StaticProperties.Static.Static_libs) == 0 &&
1907 len(sharedCompiler.SharedProperties.Shared.Static_libs) == 0 &&
1908 len(staticCompiler.StaticProperties.Static.Shared_libs) == 0 &&
1909 len(sharedCompiler.SharedProperties.Shared.Shared_libs) == 0 &&
Martin Stjernholm10566a02020-03-24 01:19:52 +00001910 // Compare System_shared_libs properties with nil because empty lists are
1911 // semantically significant for them.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001912 staticCompiler.StaticProperties.Static.System_shared_libs == nil &&
1913 sharedCompiler.SharedProperties.Shared.System_shared_libs == nil {
Colin Cross10d22312017-05-03 11:01:58 -07001914
1915 mctx.AddInterVariantDependency(reuseObjTag, shared, static)
1916 sharedCompiler.baseCompiler.Properties.OriginalSrcs =
1917 sharedCompiler.baseCompiler.Properties.Srcs
1918 sharedCompiler.baseCompiler.Properties.Srcs = nil
1919 sharedCompiler.baseCompiler.Properties.Generated_sources = nil
1920 }
Colin Cross0de8a1e2020-09-18 14:15:30 -07001921
1922 // This dep is just to reference static variant from shared variant
1923 mctx.AddInterVariantDependency(staticVariantTag, shared, static)
Colin Cross10d22312017-05-03 11:01:58 -07001924 }
1925}
1926
Chris Parsons3c27ca32020-11-20 12:42:07 -05001927// LinkageMutator adds "static" or "shared" variants for modules depending
1928// on whether the module can be built as a static library or a shared library.
Colin Crosse40b4ea2018-10-02 22:25:58 -07001929func LinkageMutator(mctx android.BottomUpMutatorContext) {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001930 ccPrebuilt := false
Colin Crossb916a382016-07-29 17:28:03 -07001931 if m, ok := mctx.Module().(*Module); ok && m.linker != nil {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001932 _, ccPrebuilt = m.linker.(prebuiltLibraryInterface)
Ivan Lozano52767be2019-10-18 14:49:46 -07001933 }
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001934 if ccPrebuilt {
Ivan Lozano52767be2019-10-18 14:49:46 -07001935 library := mctx.Module().(*Module).linker.(prebuiltLibraryInterface)
Colin Cross33b2fb72019-05-14 14:07:01 -07001936
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001937 // Differentiate between header only and building an actual static/shared library
Colin Cross127bb8b2020-12-16 16:46:01 -08001938 buildStatic := library.buildStatic()
1939 buildShared := library.buildShared()
1940 if buildStatic || buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001941 // Always create both the static and shared variants for prebuilt libraries, and then disable the one
1942 // that is not being used. This allows them to share the name of a cc_library module, which requires that
1943 // all the variants of the cc_library also exist on the prebuilt.
1944 modules := mctx.CreateLocalVariations("static", "shared")
1945 static := modules[0].(*Module)
1946 shared := modules[1].(*Module)
Colin Cross33b2fb72019-05-14 14:07:01 -07001947
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001948 static.linker.(prebuiltLibraryInterface).setStatic()
1949 shared.linker.(prebuiltLibraryInterface).setShared()
Colin Cross33b2fb72019-05-14 14:07:01 -07001950
Colin Cross127bb8b2020-12-16 16:46:01 -08001951 if buildShared {
Colin Cross81ca6cd2020-08-06 17:46:48 -07001952 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08001953 } else if buildStatic {
Colin Cross81ca6cd2020-08-06 17:46:48 -07001954 mctx.AliasVariation("static")
1955 }
1956
Colin Cross127bb8b2020-12-16 16:46:01 -08001957 if !buildStatic {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001958 static.linker.(prebuiltLibraryInterface).disablePrebuilt()
1959 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001960 if !buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001961 shared.linker.(prebuiltLibraryInterface).disablePrebuilt()
1962 }
1963 } else {
1964 // Header only
Colin Crossb916a382016-07-29 17:28:03 -07001965 }
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001966
Ivan Lozano52767be2019-10-18 14:49:46 -07001967 } else if library, ok := mctx.Module().(LinkableInterface); ok && library.CcLibraryInterface() {
Ivan Lozano52767be2019-10-18 14:49:46 -07001968
Ivan Lozano2b262972019-11-21 12:30:50 -08001969 // Non-cc.Modules may need an empty variant for their mutators.
1970 variations := []string{}
1971 if library.NonCcVariants() {
1972 variations = append(variations, "")
1973 }
1974
Colin Cross127bb8b2020-12-16 16:46:01 -08001975 isLLNDK := false
1976 if m, ok := mctx.Module().(*Module); ok {
Colin Cross203b4212021-04-26 17:19:41 -07001977 isLLNDK = m.IsLlndk()
Colin Cross127bb8b2020-12-16 16:46:01 -08001978 }
1979 buildStatic := library.BuildStaticVariant() && !isLLNDK
1980 buildShared := library.BuildSharedVariant()
1981 if buildStatic && buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08001982 variations := append([]string{"static", "shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001983
1984 modules := mctx.CreateLocalVariations(variations...)
1985 static := modules[0].(LinkableInterface)
1986 shared := modules[1].(LinkableInterface)
1987
1988 static.SetStatic()
1989 shared.SetShared()
1990
1991 if _, ok := library.(*Module); ok {
1992 reuseStaticLibrary(mctx, static.(*Module), shared.(*Module))
1993 }
Colin Cross81ca6cd2020-08-06 17:46:48 -07001994 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08001995 } else if buildStatic {
Ivan Lozano2b262972019-11-21 12:30:50 -08001996 variations := append([]string{"static"}, variations...)
1997
1998 modules := mctx.CreateLocalVariations(variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001999 modules[0].(LinkableInterface).SetStatic()
Colin Cross81ca6cd2020-08-06 17:46:48 -07002000 mctx.AliasVariation("static")
Colin Cross127bb8b2020-12-16 16:46:01 -08002001 } else if buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08002002 variations := append([]string{"shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07002003
Ivan Lozano2b262972019-11-21 12:30:50 -08002004 modules := mctx.CreateLocalVariations(variations...)
2005 modules[0].(LinkableInterface).SetShared()
Colin Cross81ca6cd2020-08-06 17:46:48 -07002006 mctx.AliasVariation("shared")
Ivan Lozano2b262972019-11-21 12:30:50 -08002007 } else if len(variations) > 0 {
2008 mctx.CreateLocalVariations(variations...)
Colin Cross81ca6cd2020-08-06 17:46:48 -07002009 mctx.AliasVariation(variations[0])
Ivan Lozano2b262972019-11-21 12:30:50 -08002010 }
Colin Crossb916a382016-07-29 17:28:03 -07002011 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07002012}
Jiyong Park7ed9de32018-10-15 22:25:07 +09002013
Chris Parsons3c27ca32020-11-20 12:42:07 -05002014// normalizeVersions modifies `versions` in place, so that each raw version
2015// string becomes its normalized canonical form.
2016// Validates that the versions in `versions` are specified in least to greatest order.
Jooyung Hanaed150d2020-04-02 01:41:41 +09002017func normalizeVersions(ctx android.BaseModuleContext, versions []string) {
Dan Albertc8060532020-07-22 22:32:17 -07002018 var previous android.ApiLevel
Jooyung Hanad4c1872020-02-27 17:56:44 +09002019 for i, v := range versions {
Dan Albertc8060532020-07-22 22:32:17 -07002020 ver, err := android.ApiLevelFromUser(ctx, v)
Jooyung Hanad4c1872020-02-27 17:56:44 +09002021 if err != nil {
Jooyung Hanaed150d2020-04-02 01:41:41 +09002022 ctx.PropertyErrorf("versions", "%s", err.Error())
2023 return
Jooyung Hanad4c1872020-02-27 17:56:44 +09002024 }
Dan Albertc8060532020-07-22 22:32:17 -07002025 if i > 0 && ver.LessThanOrEqualTo(previous) {
2026 ctx.PropertyErrorf("versions", "not sorted: %v", versions)
2027 }
2028 versions[i] = ver.String()
2029 previous = ver
Jooyung Hanaed150d2020-04-02 01:41:41 +09002030 }
Jooyung Hanad4c1872020-02-27 17:56:44 +09002031}
2032
Jooyung Han61b66e92020-03-21 14:21:46 +00002033func createVersionVariations(mctx android.BottomUpMutatorContext, versions []string) {
Colin Cross127bb8b2020-12-16 16:46:01 -08002034 // "" is for the non-stubs (implementation) variant for system modules, or the LLNDK variant
2035 // for LLNDK modules.
Colin Cross0de8a1e2020-09-18 14:15:30 -07002036 variants := append(android.CopyOf(versions), "")
Jooyung Han61b66e92020-03-21 14:21:46 +00002037
Colin Cross127bb8b2020-12-16 16:46:01 -08002038 m := mctx.Module().(*Module)
2039 isLLNDK := m.IsLlndk()
Colin Cross5271fea2021-04-27 13:06:04 -07002040 isVendorPublicLibrary := m.IsVendorPublicLibrary()
Colin Cross127bb8b2020-12-16 16:46:01 -08002041
Colin Crossd1f898e2020-08-18 18:35:15 -07002042 modules := mctx.CreateLocalVariations(variants...)
Jooyung Han61b66e92020-03-21 14:21:46 +00002043 for i, m := range modules {
Colin Cross127bb8b2020-12-16 16:46:01 -08002044
Colin Cross5271fea2021-04-27 13:06:04 -07002045 if variants[i] != "" || isLLNDK || isVendorPublicLibrary {
Colin Cross127bb8b2020-12-16 16:46:01 -08002046 // A stubs or LLNDK stubs variant.
Colin Cross31076b32020-10-23 17:22:06 -07002047 c := m.(*Module)
Colin Cross31076b32020-10-23 17:22:06 -07002048 c.sanitize = nil
2049 c.stl = nil
2050 c.Properties.PreventInstall = true
2051 lib := moduleLibraryInterface(m)
Jiyong Parkd4a3a132021-03-17 20:21:35 +09002052 isLatest := i == (len(versions) - 1)
2053 lib.setBuildStubs(isLatest)
Colin Cross127bb8b2020-12-16 16:46:01 -08002054
2055 if variants[i] != "" {
2056 // A non-LLNDK stubs module is hidden from make and has a dependency from the
2057 // implementation module to the stubs module.
2058 c.Properties.HideFromMake = true
2059 lib.setStubsVersion(variants[i])
2060 mctx.AddInterVariantDependency(stubImplDepTag, modules[len(modules)-1], modules[i])
2061 }
Jooyung Han61b66e92020-03-21 14:21:46 +00002062 }
2063 }
Colin Cross094faa52020-08-06 17:38:25 -07002064 mctx.AliasVariation("")
Colin Crossd1f898e2020-08-18 18:35:15 -07002065 latestVersion := ""
2066 if len(versions) > 0 {
2067 latestVersion = versions[len(versions)-1]
2068 }
2069 mctx.CreateAliasVariation("latest", latestVersion)
Jooyung Han61b66e92020-03-21 14:21:46 +00002070}
2071
Colin Crossbbc941b2020-09-30 12:27:01 -07002072func createPerApiVersionVariations(mctx android.BottomUpMutatorContext, minSdkVersion string) {
2073 from, err := nativeApiLevelFromUser(mctx, minSdkVersion)
2074 if err != nil {
2075 mctx.PropertyErrorf("min_sdk_version", err.Error())
2076 return
2077 }
2078
2079 versionStrs := ndkLibraryVersions(mctx, from)
2080 modules := mctx.CreateLocalVariations(versionStrs...)
2081
2082 for i, module := range modules {
2083 module.(*Module).Properties.Sdk_version = StringPtr(versionStrs[i])
Jiyong Parkfdaa5f72021-03-19 22:18:04 +09002084 module.(*Module).Properties.Min_sdk_version = StringPtr(versionStrs[i])
Colin Crossbbc941b2020-09-30 12:27:01 -07002085 }
2086}
2087
Colin Cross3146c5c2020-09-30 15:34:40 -07002088func CanBeOrLinkAgainstVersionVariants(module interface {
Jooyung Han624d35c2020-04-10 12:57:24 +09002089 Host() bool
2090 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07002091 InVendorRamdisk() bool
Jooyung Han624d35c2020-04-10 12:57:24 +09002092}) bool {
Jose Galmes6f843bc2020-12-11 13:36:29 -08002093 return !module.Host() && !module.InRamdisk() && !module.InVendorRamdisk()
Jooyung Han624d35c2020-04-10 12:57:24 +09002094}
2095
Colin Cross3146c5c2020-09-30 15:34:40 -07002096func CanBeVersionVariant(module interface {
2097 Host() bool
2098 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07002099 InVendorRamdisk() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07002100 InRecovery() bool
2101 CcLibraryInterface() bool
2102 Shared() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07002103}) bool {
2104 return CanBeOrLinkAgainstVersionVariants(module) &&
Colin Crossa717db72020-10-23 14:53:06 -07002105 module.CcLibraryInterface() && module.Shared()
Colin Cross3146c5c2020-09-30 15:34:40 -07002106}
2107
Colin Cross127bb8b2020-12-16 16:46:01 -08002108func moduleLibraryInterface(module blueprint.Module) libraryInterface {
Colin Cross31076b32020-10-23 17:22:06 -07002109 if m, ok := module.(*Module); ok {
2110 return m.library
2111 }
2112 return nil
2113}
2114
Colin Crossd1f898e2020-08-18 18:35:15 -07002115// versionSelector normalizes the versions in the Stubs.Versions property into MutatedProperties.AllStubsVersions,
2116// and propagates the value from implementation libraries to llndk libraries with the same name.
2117func versionSelectorMutator(mctx android.BottomUpMutatorContext) {
Colin Cross31076b32020-10-23 17:22:06 -07002118 if library := moduleLibraryInterface(mctx.Module()); library != nil && CanBeVersionVariant(mctx.Module().(*Module)) {
2119 if library.buildShared() {
2120 versions := library.stubsVersions(mctx)
Colin Cross3572cf72020-10-01 15:58:11 -07002121 if len(versions) > 0 {
2122 normalizeVersions(mctx, versions)
2123 if mctx.Failed() {
Colin Crossbbc941b2020-09-30 12:27:01 -07002124 return
2125 }
Colin Cross3572cf72020-10-01 15:58:11 -07002126 // Set the versions on the pre-mutated module so they can be read by any llndk modules that
2127 // depend on the implementation library and haven't been mutated yet.
Colin Cross31076b32020-10-23 17:22:06 -07002128 library.setAllStubsVersions(versions)
Colin Cross127bb8b2020-12-16 16:46:01 -08002129 }
2130
2131 if mctx.Module().(*Module).UseVndk() && library.hasLLNDKStubs() {
2132 // Propagate the version to the llndk stubs module.
2133 mctx.VisitDirectDepsWithTag(llndkStubDepTag, func(stubs android.Module) {
2134 if stubsLib := moduleLibraryInterface(stubs); stubsLib != nil {
2135 stubsLib.setAllStubsVersions(library.allStubsVersions())
2136 }
2137 })
Jiyong Park7ed9de32018-10-15 22:25:07 +09002138 }
Jooyung Han61b66e92020-03-21 14:21:46 +00002139 }
Colin Crossd1f898e2020-08-18 18:35:15 -07002140 }
2141}
Jooyung Han61b66e92020-03-21 14:21:46 +00002142
Colin Crossd1f898e2020-08-18 18:35:15 -07002143// versionMutator splits a module into the mandatory non-stubs variant
2144// (which is unnamed) and zero or more stubs variants.
2145func versionMutator(mctx android.BottomUpMutatorContext) {
Colin Cross31076b32020-10-23 17:22:06 -07002146 if library := moduleLibraryInterface(mctx.Module()); library != nil && CanBeVersionVariant(mctx.Module().(*Module)) {
2147 createVersionVariations(mctx, library.allStubsVersions())
Colin Crossbbc941b2020-09-30 12:27:01 -07002148 return
2149 }
2150
2151 if m, ok := mctx.Module().(*Module); ok {
2152 if m.SplitPerApiLevel() && m.IsSdkVariant() {
2153 if mctx.Os() != android.Android {
2154 return
2155 }
2156 createPerApiVersionVariations(mctx, m.MinSdkVersion())
2157 }
Jiyong Park7ed9de32018-10-15 22:25:07 +09002158 }
Jiyong Park7ed9de32018-10-15 22:25:07 +09002159}
Colin Crossd7227f92019-09-05 14:26:33 -07002160
2161// maybeInjectBoringSSLHash adds a rule to run bssl_inject_hash on the output file if the module has the
2162// inject_bssl_hash or if any static library dependencies have inject_bssl_hash set. It returns the output path
2163// that the linked output file should be written to.
2164// TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
2165func maybeInjectBoringSSLHash(ctx android.ModuleContext, outputFile android.ModuleOutPath,
2166 inject *bool, fileName string) android.ModuleOutPath {
2167 // TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
2168 injectBoringSSLHash := Bool(inject)
2169 ctx.VisitDirectDeps(func(dep android.Module) {
Colin Cross6e511a92020-07-27 21:26:48 -07002170 if tag, ok := ctx.OtherModuleDependencyTag(dep).(libraryDependencyTag); ok && tag.static() {
Colin Crossd7227f92019-09-05 14:26:33 -07002171 if cc, ok := dep.(*Module); ok {
2172 if library, ok := cc.linker.(*libraryDecorator); ok {
2173 if Bool(library.Properties.Inject_bssl_hash) {
2174 injectBoringSSLHash = true
2175 }
2176 }
2177 }
2178 }
2179 })
2180 if injectBoringSSLHash {
2181 hashedOutputfile := outputFile
2182 outputFile = android.PathForModuleOut(ctx, "unhashed", fileName)
2183
Colin Crossf1a035e2020-11-16 17:32:30 -08002184 rule := android.NewRuleBuilder(pctx, ctx)
Colin Crossd7227f92019-09-05 14:26:33 -07002185 rule.Command().
Colin Crossf1a035e2020-11-16 17:32:30 -08002186 BuiltTool("bssl_inject_hash").
Pete Bentley5c4be822019-10-01 17:03:17 +01002187 Flag("-sha256").
Colin Crossd7227f92019-09-05 14:26:33 -07002188 FlagWithInput("-in-object ", outputFile).
2189 FlagWithOutput("-o ", hashedOutputfile)
Colin Crossf1a035e2020-11-16 17:32:30 -08002190 rule.Build("injectCryptoHash", "inject crypto hash")
Colin Crossd7227f92019-09-05 14:26:33 -07002191 }
2192
2193 return outputFile
2194}
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002195
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002196type bazelCcLibraryStaticAttributes struct {
Jingwen Chen63930982021-03-24 10:04:33 -04002197 Copts bazel.StringListAttribute
Jingwen Chen07027912021-03-15 06:02:43 -04002198 Srcs bazel.LabelListAttribute
2199 Deps bazel.LabelListAttribute
Jingwen Chen63930982021-03-24 10:04:33 -04002200 Linkopts bazel.StringListAttribute
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002201 Linkstatic bool
Rupert Shuttleworthb8151682021-04-06 20:06:21 +00002202 Includes bazel.StringListAttribute
Jingwen Chen07027912021-03-15 06:02:43 -04002203 Hdrs bazel.LabelListAttribute
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002204}
2205
2206type bazelCcLibraryStatic struct {
2207 android.BazelTargetModuleBase
2208 bazelCcLibraryStaticAttributes
2209}
2210
2211func BazelCcLibraryStaticFactory() android.Module {
2212 module := &bazelCcLibraryStatic{}
2213 module.AddProperties(&module.bazelCcLibraryStaticAttributes)
2214 android.InitBazelTargetModule(module)
2215 return module
2216}
2217
Jingwen Chen179856a2021-05-03 09:15:48 +00002218func ccLibraryStaticBp2BuildInternal(ctx android.TopDownMutatorContext, module *Module) {
2219 compilerAttrs := bp2BuildParseCompilerProps(ctx, module)
2220 linkerAttrs := bp2BuildParseLinkerProps(ctx, module)
2221 exportedIncludes := bp2BuildParseExportedIncludes(ctx, module)
2222
2223 attrs := &bazelCcLibraryStaticAttributes{
2224 Copts: compilerAttrs.copts,
2225 Srcs: compilerAttrs.srcs,
2226 Deps: linkerAttrs.deps,
2227 Linkopts: linkerAttrs.linkopts,
2228 Linkstatic: true,
2229 Includes: exportedIncludes,
2230 }
2231
2232 props := bazel.BazelTargetModuleProperties{
2233 Rule_class: "cc_library_static",
2234 Bzl_load_location: "//build/bazel/rules:cc_library_static.bzl",
2235 }
2236
2237 ctx.CreateBazelTargetModule(BazelCcLibraryStaticFactory, module.Name(), props, attrs)
2238}
2239
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002240func CcLibraryStaticBp2Build(ctx android.TopDownMutatorContext) {
2241 module, ok := ctx.Module().(*Module)
2242 if !ok {
2243 // Not a cc module
2244 return
2245 }
2246 if !module.ConvertWithBp2build(ctx) {
2247 return
2248 }
2249 if ctx.ModuleType() != "cc_library_static" {
2250 return
2251 }
2252
Jingwen Chen179856a2021-05-03 09:15:48 +00002253 ccLibraryStaticBp2BuildInternal(ctx, module)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002254}
2255
2256func (m *bazelCcLibraryStatic) Name() string {
2257 return m.BaseModuleName()
2258}
2259
2260func (m *bazelCcLibraryStatic) GenerateAndroidBuildActions(ctx android.ModuleContext) {}