blob: 23556b09615f48715dd8bf2a8bef33fdde1bb84d [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"
Colin Cross4d9c2d12016-07-29 12:48:20 -070022 "strings"
Jiyong Parkda732bd2018-11-02 18:23:15 +090023 "sync"
Colin Cross4d9c2d12016-07-29 12:48:20 -070024
Colin Cross127bb8b2020-12-16 16:46:01 -080025 "github.com/google/blueprint"
Colin Cross26c34ed2016-09-30 17:10:16 -070026 "github.com/google/blueprint/pathtools"
Colin Cross4d9c2d12016-07-29 12:48:20 -070027
Colin Cross4d9c2d12016-07-29 12:48:20 -070028 "android/soong/android"
Dan Albertea4b7b92018-04-25 16:05:30 -070029 "android/soong/cc/config"
Colin Cross4d9c2d12016-07-29 12:48:20 -070030)
31
Chris Parsons3c27ca32020-11-20 12:42:07 -050032// LibraryProperties is a collection of properties shared by cc library rules.
Colin Crossb916a382016-07-29 17:28:03 -070033type LibraryProperties struct {
Colin Cross4d9c2d12016-07-29 12:48:20 -070034 // local file name to pass to the linker as -unexported_symbols_list
Colin Cross27b922f2019-03-04 22:35:41 -080035 Unexported_symbols_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070036 // local file name to pass to the linker as -force_symbols_not_weak_list
Colin Cross27b922f2019-03-04 22:35:41 -080037 Force_symbols_not_weak_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_weak_list
Colin Cross27b922f2019-03-04 22:35:41 -080039 Force_symbols_weak_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070040
41 // rename host libraries to prevent overlap with system installed libraries
42 Unique_host_soname *bool
43
Dan Willemsene1240db2016-11-03 14:28:51 -070044 Aidl struct {
45 // export headers generated from .aidl sources
Nan Zhang0007d812017-11-07 10:57:05 -080046 Export_aidl_headers *bool
Dan Willemsene1240db2016-11-03 14:28:51 -070047 }
48
Colin Cross0c461f12016-10-20 16:11:43 -070049 Proto struct {
50 // export headers generated from .proto sources
Nan Zhang0007d812017-11-07 10:57:05 -080051 Export_proto_headers *bool
Colin Cross0c461f12016-10-20 16:11:43 -070052 }
Dan Albertf563d252017-10-13 00:29:00 -070053
Inseob Kimc0907f12019-02-08 21:00:45 +090054 Sysprop struct {
55 // Whether platform owns this sysprop library.
56 Platform *bool
Inseob Kimb3f22ca2019-03-05 12:40:24 +090057 } `blueprint:"mutated"`
Inseob Kimc0907f12019-02-08 21:00:45 +090058
Nan Zhang0007d812017-11-07 10:57:05 -080059 Static_ndk_lib *bool
Jiyong Park7ed9de32018-10-15 22:25:07 +090060
61 Stubs struct {
62 // Relative path to the symbol map. The symbol map provides the list of
63 // symbols that are exported for stubs variant of this library.
Colin Cross27b922f2019-03-04 22:35:41 -080064 Symbol_file *string `android:"path"`
Jiyong Park7ed9de32018-10-15 22:25:07 +090065
66 // List versions to generate stubs libs for.
67 Versions []string
68 }
dimitryd95964a2018-11-07 13:43:34 +010069
70 // set the name of the output
71 Stem *string `android:"arch_variant"`
72
Colin Cross0fd6a412019-08-16 14:22:10 -070073 // set suffix of the name of the output
74 Suffix *string `android:"arch_variant"`
75
76 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +090077 Vendor, Product struct {
Colin Cross0fd6a412019-08-16 14:22:10 -070078 // set suffix of the name of the output
79 Suffix *string `android:"arch_variant"`
80 }
81 }
82
dimitryd95964a2018-11-07 13:43:34 +010083 // Names of modules to be overridden. Listed modules can only be other shared libraries
84 // (in Make or Soong).
85 // This does not completely prevent installation of the overridden libraries, but if both
86 // binaries would be installed by default (in PRODUCT_PACKAGES) the other library will be removed
87 // from PRODUCT_PACKAGES.
88 Overrides []string
Logan Chiene3d7a0d2019-01-17 00:18:02 +080089
90 // Properties for ABI compatibility checker
91 Header_abi_checker struct {
Logan Chien41eabe62019-04-10 13:33:58 +080092 // Enable ABI checks (even if this is not an LLNDK/VNDK lib)
93 Enabled *bool
94
Logan Chiene3d7a0d2019-01-17 00:18:02 +080095 // Path to a symbol file that specifies the symbols to be included in the generated
96 // ABI dump file
Colin Cross27b922f2019-03-04 22:35:41 -080097 Symbol_file *string `android:"path"`
Logan Chiene3d7a0d2019-01-17 00:18:02 +080098
99 // Symbol versions that should be ignored from the symbol file
100 Exclude_symbol_versions []string
101
102 // Symbol tags that should be ignored from the symbol file
103 Exclude_symbol_tags []string
Logan Chien2a65dda2019-10-01 15:58:07 -0700104
105 // Run checks on all APIs (in addition to the ones referred by
106 // one of exported ELF symbols.)
107 Check_all_apis *bool
Logan Chiene3d7a0d2019-01-17 00:18:02 +0800108 }
Vic Yang6cd1be82019-06-24 16:08:48 -0700109
110 // Order symbols in .bss section by their sizes. Only useful for shared libraries.
111 Sort_bss_symbols_by_size *bool
Pete Bentley803e1612019-08-06 22:19:59 +0100112
113 // Inject boringssl hash into the shared library. This is only intended for use by external/boringssl.
114 Inject_bssl_hash *bool `android:"arch_variant"`
Colin Cross0477b422020-10-13 18:43:54 -0700115
116 // If this is an LLNDK library, the name of the equivalent llndk_library module.
117 Llndk_stubs *string
Colin Cross127bb8b2020-12-16 16:46:01 -0800118
119 // If this is an LLNDK library, properties to describe the LLNDK stubs. Will be copied from
120 // the module pointed to by llndk_stubs if it is set.
121 Llndk llndkLibraryProperties
Colin Crossa48ab5b2017-02-14 15:28:44 -0800122}
Colin Cross0c461f12016-10-20 16:11:43 -0700123
Chris Parsons3c27ca32020-11-20 12:42:07 -0500124// StaticProperties is a properties stanza to affect only attributes of the "static" variants of a
125// library module.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700126type StaticProperties struct {
127 Static StaticOrSharedProperties `android:"arch_variant"`
128}
129
Chris Parsons3c27ca32020-11-20 12:42:07 -0500130// SharedProperties is a properties stanza to affect only attributes of the "shared" variants of a
131// library module.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700132type SharedProperties struct {
133 Shared StaticOrSharedProperties `android:"arch_variant"`
134}
135
Chris Parsons3c27ca32020-11-20 12:42:07 -0500136// StaticOrSharedProperties is an embedded struct representing properties to affect attributes of
137// either only the "static" variants or only the "shared" variants of a library module. These override
138// the base properties of the same name.
139// Use `StaticProperties` or `SharedProperties`, depending on which variant is needed.
140// `StaticOrSharedProperties` exists only to avoid duplication.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700141type StaticOrSharedProperties struct {
Evgenii Stepanov2080bfe2020-07-24 15:35:40 -0700142 Srcs []string `android:"path,arch_variant"`
143
144 Sanitized Sanitized `android:"arch_variant"`
145
Colin Crosse1bb5d02019-09-24 14:55:04 -0700146 Cflags []string `android:"arch_variant"`
147
148 Enabled *bool `android:"arch_variant"`
149 Whole_static_libs []string `android:"arch_variant"`
150 Static_libs []string `android:"arch_variant"`
151 Shared_libs []string `android:"arch_variant"`
152 System_shared_libs []string `android:"arch_variant"`
153
154 Export_shared_lib_headers []string `android:"arch_variant"`
155 Export_static_lib_headers []string `android:"arch_variant"`
Jiyong Parka90ca002019-10-07 15:47:24 +0900156
157 Apex_available []string `android:"arch_variant"`
Colin Crosse1bb5d02019-09-24 14:55:04 -0700158}
159
Colin Crossa48ab5b2017-02-14 15:28:44 -0800160type LibraryMutatedProperties struct {
Colin Crossb916a382016-07-29 17:28:03 -0700161 // Build a static variant
162 BuildStatic bool `blueprint:"mutated"`
163 // Build a shared variant
164 BuildShared bool `blueprint:"mutated"`
165 // This variant is shared
166 VariantIsShared bool `blueprint:"mutated"`
167 // This variant is static
168 VariantIsStatic bool `blueprint:"mutated"`
Jiyong Park7ed9de32018-10-15 22:25:07 +0900169
170 // This variant is a stubs lib
171 BuildStubs bool `blueprint:"mutated"`
172 // Version of the stubs lib
173 StubsVersion string `blueprint:"mutated"`
Colin Crossd1f898e2020-08-18 18:35:15 -0700174 // List of all stubs versions associated with an implementation lib
175 AllStubsVersions []string `blueprint:"mutated"`
Colin Crossb916a382016-07-29 17:28:03 -0700176}
177
178type FlagExporterProperties struct {
179 // list of directories relative to the Blueprints file that will
Dan Willemsen273af7f2016-11-03 15:53:42 -0700180 // be added to the include path (using -I) for this module and any module that links
Colin Cross5d195602017-10-17 16:15:50 -0700181 // against this module. Directories listed in export_include_dirs do not need to be
182 // listed in local_include_dirs.
Colin Crossb916a382016-07-29 17:28:03 -0700183 Export_include_dirs []string `android:"arch_variant"`
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700184
Jiyong Park73c54ee2019-10-22 20:31:18 +0900185 // list of directories that will be added to the system include path
186 // using -isystem for this module and any module that links against this module.
187 Export_system_include_dirs []string `android:"arch_variant"`
188
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700189 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +0900190 Vendor, Product struct {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700191 // list of exported include directories, like
Justin Yun63e9ec72020-10-29 16:49:43 +0900192 // export_include_dirs, that will be applied to
193 // vendor or product variant of this library.
194 // This will overwrite any other declarations.
Steven Morelandb21df8f2018-01-05 14:42:54 -0800195 Override_export_include_dirs []string
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700196 }
197 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700198}
199
200func init() {
Paul Duffin6c26dc72019-12-19 15:02:40 +0000201 RegisterLibraryBuildComponents(android.InitRegistrationContext)
202}
203
204func RegisterLibraryBuildComponents(ctx android.RegistrationContext) {
205 ctx.RegisterModuleType("cc_library_static", LibraryStaticFactory)
206 ctx.RegisterModuleType("cc_library_shared", LibrarySharedFactory)
207 ctx.RegisterModuleType("cc_library", LibraryFactory)
208 ctx.RegisterModuleType("cc_library_host_static", LibraryHostStaticFactory)
209 ctx.RegisterModuleType("cc_library_host_shared", LibraryHostSharedFactory)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700210}
211
Patrice Arruda83c89e02019-03-25 15:32:39 -0700212// cc_library creates both static and/or shared libraries for a device and/or
213// host. By default, a cc_library has a single variant that targets the device.
214// Specifying `host_supported: true` also creates a library that targets the
215// host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700216func LibraryFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800217 module, _ := NewLibrary(android.HostAndDeviceSupported)
Paul Duffina0843f62019-12-13 19:50:38 +0000218 // Can be used as both a static and a shared library.
219 module.sdkMemberTypes = []android.SdkMemberType{
220 sharedLibrarySdkMemberType,
221 staticLibrarySdkMemberType,
Paul Duffin9b76c0b2020-03-12 10:24:35 +0000222 staticAndSharedLibrarySdkMemberType,
Paul Duffina0843f62019-12-13 19:50:38 +0000223 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700224 return module.Init()
225}
226
Patrice Arruda83c89e02019-03-25 15:32:39 -0700227// cc_library_static creates a static library for a device and/or host binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700228func LibraryStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800229 module, library := NewLibrary(android.HostAndDeviceSupported)
230 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000231 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700232 return module.Init()
233}
234
Patrice Arruda83c89e02019-03-25 15:32:39 -0700235// cc_library_shared creates a shared library for a device and/or host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700236func LibrarySharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800237 module, library := NewLibrary(android.HostAndDeviceSupported)
238 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000239 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700240 return module.Init()
241}
242
Patrice Arruda83c89e02019-03-25 15:32:39 -0700243// cc_library_host_static creates a static library that is linkable to a host
244// binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700245func LibraryHostStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800246 module, library := NewLibrary(android.HostSupported)
247 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000248 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700249 return module.Init()
250}
251
Patrice Arruda83c89e02019-03-25 15:32:39 -0700252// cc_library_host_shared creates a shared library that is usable on a host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700253func LibraryHostSharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800254 module, library := NewLibrary(android.HostSupported)
255 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000256 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700257 return module.Init()
258}
259
Chris Parsons3c27ca32020-11-20 12:42:07 -0500260// flagExporter is a separated portion of libraryDecorator pertaining to exported
261// include paths and flags. Keeping this dependency-related information separate
262// from the rest of library information is helpful in keeping data more structured
263// and explicit.
Colin Cross4d9c2d12016-07-29 12:48:20 -0700264type flagExporter struct {
265 Properties FlagExporterProperties
266
Chris Parsons3c27ca32020-11-20 12:42:07 -0500267 dirs android.Paths // Include directories to be included with -I
268 systemDirs android.Paths // System include directories to be included with -isystem
269 flags []string // Exported raw flags.
Inseob Kim69378442019-06-03 19:10:47 +0900270 deps android.Paths
Inseob Kimd110f872019-12-06 13:15:38 +0900271 headers android.Paths
Colin Cross4d9c2d12016-07-29 12:48:20 -0700272}
273
Chris Parsons3c27ca32020-11-20 12:42:07 -0500274// exportedIncludes returns the effective include paths for this module and
275// any module that links against this module. This is obtained from
276// the export_include_dirs property in the appropriate target stanza.
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700277func (f *flagExporter) exportedIncludes(ctx ModuleContext) android.Paths {
Justin Yun6977e8a2020-10-29 18:24:11 +0900278 if ctx.inVendor() && f.Properties.Target.Vendor.Override_export_include_dirs != nil {
Steven Morelandb21df8f2018-01-05 14:42:54 -0800279 return android.PathsForModuleSrc(ctx, f.Properties.Target.Vendor.Override_export_include_dirs)
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700280 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900281 if ctx.inProduct() && f.Properties.Target.Product.Override_export_include_dirs != nil {
282 return android.PathsForModuleSrc(ctx, f.Properties.Target.Product.Override_export_include_dirs)
283 }
284 return android.PathsForModuleSrc(ctx, f.Properties.Export_include_dirs)
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700285}
286
Chris Parsons3c27ca32020-11-20 12:42:07 -0500287// exportIncludes registers the include directories and system include directories to be exported
288// transitively to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900289func (f *flagExporter) exportIncludes(ctx ModuleContext) {
Jiyong Park74955042019-10-22 20:19:51 +0900290 f.dirs = append(f.dirs, f.exportedIncludes(ctx)...)
Jiyong Park73c54ee2019-10-22 20:31:18 +0900291 f.systemDirs = append(f.systemDirs, android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700292}
293
Chris Parsons3c27ca32020-11-20 12:42:07 -0500294// exportIncludesAsSystem registers the include directories and system include directories to be
295// exported transitively both as system include directories to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900296func (f *flagExporter) exportIncludesAsSystem(ctx ModuleContext) {
Jiyong Park73c54ee2019-10-22 20:31:18 +0900297 // all dirs are force exported as system
Jiyong Park74955042019-10-22 20:19:51 +0900298 f.systemDirs = append(f.systemDirs, f.exportedIncludes(ctx)...)
Jiyong Park73c54ee2019-10-22 20:31:18 +0900299 f.systemDirs = append(f.systemDirs, android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)...)
Inseob Kim69378442019-06-03 19:10:47 +0900300}
301
Chris Parsons3c27ca32020-11-20 12:42:07 -0500302// reexportDirs registers the given directories as include directories to be exported transitively
303// to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900304func (f *flagExporter) reexportDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900305 f.dirs = append(f.dirs, dirs...)
306}
307
Chris Parsons3c27ca32020-11-20 12:42:07 -0500308// reexportSystemDirs registers the given directories as system include directories
309// to be exported transitively to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900310func (f *flagExporter) reexportSystemDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900311 f.systemDirs = append(f.systemDirs, dirs...)
312}
313
Chris Parsons3c27ca32020-11-20 12:42:07 -0500314// reexportFlags registers the flags to be exported transitively to modules depending on this
315// module.
Inseob Kim69378442019-06-03 19:10:47 +0900316func (f *flagExporter) reexportFlags(flags ...string) {
Jaewoong Jung3aff5782020-02-11 07:54:35 -0800317 if android.PrefixInList(flags, "-I") || android.PrefixInList(flags, "-isystem") {
318 panic(fmt.Errorf("Exporting invalid flag %q: "+
319 "use reexportDirs or reexportSystemDirs to export directories", flag))
Inseob Kim69378442019-06-03 19:10:47 +0900320 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700321 f.flags = append(f.flags, flags...)
322}
323
Inseob Kim69378442019-06-03 19:10:47 +0900324func (f *flagExporter) reexportDeps(deps ...android.Path) {
325 f.deps = append(f.deps, deps...)
326}
327
Inseob Kimd110f872019-12-06 13:15:38 +0900328// addExportedGeneratedHeaders does nothing but collects generated header files.
329// This can be differ to exportedDeps which may contain phony files to minimize ninja.
330func (f *flagExporter) addExportedGeneratedHeaders(headers ...android.Path) {
331 f.headers = append(f.headers, headers...)
332}
333
Colin Cross0de8a1e2020-09-18 14:15:30 -0700334func (f *flagExporter) setProvider(ctx android.ModuleContext) {
335 ctx.SetProvider(FlagExporterInfoProvider, FlagExporterInfo{
336 IncludeDirs: f.dirs,
337 SystemIncludeDirs: f.systemDirs,
338 Flags: f.flags,
339 Deps: f.deps,
340 GeneratedHeaders: f.headers,
341 })
Inseob Kim69378442019-06-03 19:10:47 +0900342}
343
Colin Crossb916a382016-07-29 17:28:03 -0700344// libraryDecorator wraps baseCompiler, baseLinker and baseInstaller to provide library-specific
345// functionality: static vs. shared linkage, reusing object files for shared libraries
346type libraryDecorator struct {
Colin Crossa48ab5b2017-02-14 15:28:44 -0800347 Properties LibraryProperties
Colin Crosse1bb5d02019-09-24 14:55:04 -0700348 StaticProperties StaticProperties
349 SharedProperties SharedProperties
Colin Crossa48ab5b2017-02-14 15:28:44 -0800350 MutatedProperties LibraryMutatedProperties
Colin Cross4d9c2d12016-07-29 12:48:20 -0700351
352 // For reusing static library objects for shared library
Inseob Kim69378442019-06-03 19:10:47 +0900353 reuseObjects Objects
Colin Cross10d22312017-05-03 11:01:58 -0700354
Colin Cross26c34ed2016-09-30 17:10:16 -0700355 // table-of-contents file to optimize out relinking when possible
356 tocFile android.OptionalPath
Colin Cross4d9c2d12016-07-29 12:48:20 -0700357
Colin Cross4d9c2d12016-07-29 12:48:20 -0700358 flagExporter
Thiébaud Weksteend4587452020-08-19 14:53:01 +0200359 stripper Stripper
Colin Cross4d9c2d12016-07-29 12:48:20 -0700360
Colin Cross4d9c2d12016-07-29 12:48:20 -0700361 // For whole_static_libs
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700362 objects Objects
Colin Cross4d9c2d12016-07-29 12:48:20 -0700363
364 // Uses the module's name if empty, but can be overridden. Does not include
365 // shlib suffix.
366 libName string
Colin Crossb916a382016-07-29 17:28:03 -0700367
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800368 sabi *sabi
369
Dan Willemsen581341d2017-02-09 16:16:31 -0800370 // Output archive of gcno coverage information files
371 coverageOutputFile android.OptionalPath
372
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800373 // linked Source Abi Dump
374 sAbiOutputFile android.OptionalPath
375
376 // Source Abi Diff
377 sAbiDiff android.OptionalPath
378
Colin Cross0875c522017-11-28 17:34:01 -0800379 // Location of the static library in the sysroot. Empty if the library is
380 // not included in the NDK.
381 ndkSysrootPath android.Path
382
Colin Crossb60190a2018-09-04 16:28:17 -0700383 // Location of the linked, unstripped library for shared libraries
384 unstrippedOutputFile android.Path
385
Dan Willemsen569edc52018-11-19 09:33:29 -0800386 // Location of the file that should be copied to dist dir when requested
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000387 distFile android.Path
Dan Willemsen569edc52018-11-19 09:33:29 -0800388
Colin Cross8e21aa52020-09-28 18:28:02 -0700389 versionScriptPath android.OptionalPath
Jiyong Park7ed9de32018-10-15 22:25:07 +0900390
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800391 postInstallCmds []string
Jiyong Parkf1194352019-02-25 11:05:47 +0900392
Vic Yangefd249e2018-11-12 20:19:56 -0800393 // If useCoreVariant is true, the vendor variant of a VNDK library is
394 // not installed.
Vic Yangd92090f2020-01-08 14:32:28 -0800395 useCoreVariant bool
396 checkSameCoreVariant bool
Vic Yangefd249e2018-11-12 20:19:56 -0800397
Colin Cross5ec407b2020-09-30 11:41:33 -0700398 skipAPIDefine bool
399
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100400 // Decorated interfaces
Colin Crossb916a382016-07-29 17:28:03 -0700401 *baseCompiler
402 *baseLinker
403 *baseInstaller
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900404
405 collectedSnapshotHeaders android.Paths
406}
407
408// collectHeadersForSnapshot collects all exported headers from library.
409// It globs header files in the source tree for exported include directories,
410// and tracks generated header files separately.
411//
412// This is to be called from GenerateAndroidBuildActions, and then collected
413// header files can be retrieved by snapshotHeaders().
414func (l *libraryDecorator) collectHeadersForSnapshot(ctx android.ModuleContext) {
415 ret := android.Paths{}
416
417 // Headers in the source tree should be globbed. On the contrast, generated headers
418 // can't be globbed, and they should be manually collected.
419 // So, we first filter out intermediate directories (which contains generated headers)
420 // from exported directories, and then glob headers under remaining directories.
Colin Cross0de8a1e2020-09-18 14:15:30 -0700421 for _, path := range append(android.CopyOfPaths(l.flagExporter.dirs), l.flagExporter.systemDirs...) {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900422 dir := path.String()
423 // Skip if dir is for generated headers
424 if strings.HasPrefix(dir, android.PathForOutput(ctx).String()) {
425 continue
426 }
Inseob Kim04f2d6a2020-05-29 22:30:58 +0900427 // libeigen wrongly exports the root directory "external/eigen". But only two
428 // subdirectories "Eigen" and "unsupported" contain exported header files. Even worse
429 // some of them have no extension. So we need special treatment for libeigen in order
430 // to glob correctly.
431 if dir == "external/eigen" {
432 // Only these two directories contains exported headers.
433 for _, subdir := range []string{"Eigen", "unsupported/Eigen"} {
434 glob, err := ctx.GlobWithDeps("external/eigen/"+subdir+"/**/*", nil)
435 if err != nil {
436 ctx.ModuleErrorf("glob failed: %#v", err)
437 return
438 }
439 for _, header := range glob {
440 if strings.HasSuffix(header, "/") {
441 continue
442 }
443 ext := filepath.Ext(header)
444 if ext != "" && ext != ".h" {
445 continue
446 }
447 ret = append(ret, android.PathForSource(ctx, header))
448 }
449 }
450 continue
451 }
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900452 exts := headerExts
453 // Glob all files under this special directory, because of C++ headers.
454 if strings.HasPrefix(dir, "external/libcxx/include") {
455 exts = []string{""}
456 }
457 for _, ext := range exts {
458 glob, err := ctx.GlobWithDeps(dir+"/**/*"+ext, nil)
459 if err != nil {
460 ctx.ModuleErrorf("glob failed: %#v", err)
461 return
462 }
463 for _, header := range glob {
464 if strings.HasSuffix(header, "/") {
465 continue
466 }
467 ret = append(ret, android.PathForSource(ctx, header))
468 }
469 }
470 }
471
472 // Collect generated headers
Colin Cross0de8a1e2020-09-18 14:15:30 -0700473 for _, header := range append(android.CopyOfPaths(l.flagExporter.headers), l.flagExporter.deps...) {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900474 // TODO(b/148123511): remove exportedDeps after cleaning up genrule
475 if strings.HasSuffix(header.Base(), "-phony") {
476 continue
477 }
478 ret = append(ret, header)
479 }
480
481 l.collectedSnapshotHeaders = ret
482}
483
484// This returns all exported header files, both generated ones and headers from source tree.
485// collectHeadersForSnapshot() must be called before calling this.
486func (l *libraryDecorator) snapshotHeaders() android.Paths {
487 if l.collectedSnapshotHeaders == nil {
488 panic("snapshotHeaders() must be called after collectHeadersForSnapshot()")
489 }
490 return l.collectedSnapshotHeaders
Colin Cross4d9c2d12016-07-29 12:48:20 -0700491}
492
Chris Parsons3c27ca32020-11-20 12:42:07 -0500493// linkerProps returns the list of properties structs relevant for this library. (For example, if
494// the library is cc_shared_library, then static-library properties are omitted.)
Colin Crossb916a382016-07-29 17:28:03 -0700495func (library *libraryDecorator) linkerProps() []interface{} {
496 var props []interface{}
497 props = append(props, library.baseLinker.linkerProps()...)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700498 props = append(props,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700499 &library.Properties,
Colin Crossa48ab5b2017-02-14 15:28:44 -0800500 &library.MutatedProperties,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700501 &library.flagExporter.Properties,
Colin Cross22f37952018-09-05 10:43:13 -0700502 &library.stripper.StripProperties)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700503
504 if library.MutatedProperties.BuildShared {
505 props = append(props, &library.SharedProperties)
506 }
507 if library.MutatedProperties.BuildStatic {
508 props = append(props, &library.StaticProperties)
509 }
510
511 return props
Colin Cross4d9c2d12016-07-29 12:48:20 -0700512}
513
Chris Parsons3c27ca32020-11-20 12:42:07 -0500514// linkerFlags takes a Flags struct and augments it to contain linker flags that are defined by this
515// library, or that are implied by attributes of this library (such as whether this library is a
516// shared library).
Colin Crossb916a382016-07-29 17:28:03 -0700517func (library *libraryDecorator) linkerFlags(ctx ModuleContext, flags Flags) Flags {
Colin Cross42742b82016-08-01 13:20:05 -0700518 flags = library.baseLinker.linkerFlags(ctx, flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700519
Colin Crossb916a382016-07-29 17:28:03 -0700520 // MinGW spits out warnings about -fPIC even for -fpie?!) being ignored because
521 // all code is position independent, and then those warnings get promoted to
522 // errors.
Colin Cross3edeee12017-04-04 12:59:48 -0700523 if !ctx.Windows() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800524 flags.Global.CFlags = append(flags.Global.CFlags, "-fPIC")
Colin Crossb916a382016-07-29 17:28:03 -0700525 }
526
527 if library.static() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800528 flags.Local.CFlags = append(flags.Local.CFlags, library.StaticProperties.Static.Cflags...)
Colin Crossa48ab5b2017-02-14 15:28:44 -0800529 } else if library.shared() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800530 flags.Local.CFlags = append(flags.Local.CFlags, library.SharedProperties.Shared.Cflags...)
Colin Crossb916a382016-07-29 17:28:03 -0700531 }
532
Colin Crossa48ab5b2017-02-14 15:28:44 -0800533 if library.shared() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700534 libName := library.getLibName(ctx)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700535 var f []string
Dan Willemsen01a405a2016-06-13 17:19:03 -0700536 if ctx.toolchain().Bionic() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700537 f = append(f,
538 "-nostdlib",
539 "-Wl,--gc-sections",
540 )
541 }
542
543 if ctx.Darwin() {
544 f = append(f,
545 "-dynamiclib",
546 "-single_module",
Colin Cross4d9c2d12016-07-29 12:48:20 -0700547 "-install_name @rpath/"+libName+flags.Toolchain.ShlibSuffix(),
548 )
Colin Cross7863cf52016-10-20 10:47:21 -0700549 if ctx.Arch().ArchType == android.X86 {
550 f = append(f,
551 "-read_only_relocs suppress",
552 )
553 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700554 } else {
Josh Gao75a50a22019-06-07 17:58:59 -0700555 f = append(f, "-shared")
556 if !ctx.Windows() {
557 f = append(f, "-Wl,-soname,"+libName+flags.Toolchain.ShlibSuffix())
558 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700559 }
560
Colin Cross4af21ed2019-11-04 09:37:55 -0800561 flags.Global.LdFlags = append(flags.Global.LdFlags, f...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700562 }
563
564 return flags
565}
566
Chris Parsons3c27ca32020-11-20 12:42:07 -0500567// compilerFlags takes a Flags and augments it to contain compile flags from global values,
568// per-target values, module type values, per-module Blueprints properties, extra flags from
569// `flags`, and generated sources from `deps`.
Colin Crossf18e1102017-11-16 14:33:08 -0800570func (library *libraryDecorator) compilerFlags(ctx ModuleContext, flags Flags, deps PathDeps) Flags {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700571 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700572 if len(exportIncludeDirs) > 0 {
Colin Crossdad8c952017-04-26 14:55:27 -0700573 f := includeDirsToFlags(exportIncludeDirs)
Colin Cross4af21ed2019-11-04 09:37:55 -0800574 flags.Local.CommonFlags = append(flags.Local.CommonFlags, f)
575 flags.Local.YasmFlags = append(flags.Local.YasmFlags, f)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700576 }
577
Jiyong Park7ed9de32018-10-15 22:25:07 +0900578 flags = library.baseCompiler.compilerFlags(ctx, flags, deps)
Colin Cross127bb8b2020-12-16 16:46:01 -0800579 if ctx.IsLlndk() {
580 // LLNDK libraries ignore most of the properties on the cc_library and use the
581 // LLNDK-specific properties instead.
582 // Wipe all the module-local properties, leaving only the global properties.
583 flags.Local = LocalOrGlobalFlags{}
584 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900585 if library.buildStubs() {
Jiyong Park64379952018-12-13 18:37:29 +0900586 // Remove -include <file> when compiling stubs. Otherwise, the force included
587 // headers might cause conflicting types error with the symbols in the
588 // generated stubs source code. e.g.
589 // double acos(double); // in header
590 // void acos() {} // in the generated source code
591 removeInclude := func(flags []string) []string {
592 ret := flags[:0]
593 for _, f := range flags {
594 if strings.HasPrefix(f, "-include ") {
595 continue
596 }
597 ret = append(ret, f)
598 }
599 return ret
600 }
Colin Cross4af21ed2019-11-04 09:37:55 -0800601 flags.Local.CommonFlags = removeInclude(flags.Local.CommonFlags)
602 flags.Local.CFlags = removeInclude(flags.Local.CFlags)
Jiyong Park64379952018-12-13 18:37:29 +0900603
Jiyong Park7ed9de32018-10-15 22:25:07 +0900604 flags = addStubLibraryCompilerFlags(flags)
605 }
606 return flags
Dan Willemsen273af7f2016-11-03 15:53:42 -0700607}
608
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800609func (library *libraryDecorator) headerAbiCheckerEnabled() bool {
610 return Bool(library.Properties.Header_abi_checker.Enabled)
Hsin-Yi Chen53489642019-07-31 17:10:45 +0800611}
612
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800613func (library *libraryDecorator) headerAbiCheckerExplicitlyDisabled() bool {
614 return !BoolDefault(library.Properties.Header_abi_checker.Enabled, true)
Logan Chien41eabe62019-04-10 13:33:58 +0800615}
616
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700617func (library *libraryDecorator) compile(ctx ModuleContext, flags Flags, deps PathDeps) Objects {
Colin Cross127bb8b2020-12-16 16:46:01 -0800618 if ctx.IsLlndk() {
619 // This is the vendor variant of an LLNDK library, build the LLNDK stubs.
620 vndkVer := ctx.Module().(*Module).VndkVersion()
621 if !inList(vndkVer, ctx.Config().PlatformVersionActiveCodenames()) || vndkVer == "" {
622 // For non-enforcing devices, vndkVer is empty. Use "current" in that case, too.
623 vndkVer = "current"
624 }
625 if library.stubsVersion() != "" {
626 vndkVer = library.stubsVersion()
627 }
628 objs, versionScript := compileStubLibrary(ctx, flags, String(library.Properties.Llndk.Symbol_file), vndkVer, "--llndk")
629 if !Bool(library.Properties.Llndk.Unversioned) {
630 library.versionScriptPath = android.OptionalPathForPath(versionScript)
631 }
632 return objs
633 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900634 if library.buildStubs() {
Jiyong Park3fd0baf2018-12-07 16:25:39 +0900635 objs, versionScript := compileStubLibrary(ctx, flags, String(library.Properties.Stubs.Symbol_file), library.MutatedProperties.StubsVersion, "--apex")
Colin Cross8e21aa52020-09-28 18:28:02 -0700636 library.versionScriptPath = android.OptionalPathForPath(versionScript)
Jiyong Park7ed9de32018-10-15 22:25:07 +0900637 return objs
638 }
639
Colin Cross5950f382016-12-13 12:50:57 -0800640 if !library.buildShared() && !library.buildStatic() {
641 if len(library.baseCompiler.Properties.Srcs) > 0 {
642 ctx.PropertyErrorf("srcs", "cc_library_headers must not have any srcs")
643 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700644 if len(library.StaticProperties.Static.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800645 ctx.PropertyErrorf("static.srcs", "cc_library_headers must not have any srcs")
646 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700647 if len(library.SharedProperties.Shared.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800648 ctx.PropertyErrorf("shared.srcs", "cc_library_headers must not have any srcs")
649 }
650 return Objects{}
651 }
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800652 if library.sabi.shouldCreateSourceAbiDump() {
Jayant Chowdharya4fce192017-09-06 13:10:03 -0700653 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800654 var SourceAbiFlags []string
655 for _, dir := range exportIncludeDirs.Strings() {
Jayant Chowdhary715cac32017-04-20 06:53:59 -0700656 SourceAbiFlags = append(SourceAbiFlags, "-I"+dir)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800657 }
Inseob Kim69378442019-06-03 19:10:47 +0900658 for _, reexportedInclude := range library.sabi.Properties.ReexportedIncludes {
659 SourceAbiFlags = append(SourceAbiFlags, "-I"+reexportedInclude)
Jayant Chowdhary715cac32017-04-20 06:53:59 -0700660 }
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800661 flags.SAbiFlags = SourceAbiFlags
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800662 totalLength := len(library.baseCompiler.Properties.Srcs) + len(deps.GeneratedSources) +
Colin Crosse1bb5d02019-09-24 14:55:04 -0700663 len(library.SharedProperties.Shared.Srcs) + len(library.StaticProperties.Static.Srcs)
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800664 if totalLength > 0 {
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800665 flags.SAbiDump = true
666 }
667 }
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700668 objs := library.baseCompiler.compile(ctx, flags, deps)
669 library.reuseObjects = objs
Colin Cross2f336352016-10-26 10:03:47 -0700670 buildFlags := flagsToBuilderFlags(flags)
Colin Crossb916a382016-07-29 17:28:03 -0700671
Colin Cross4d9c2d12016-07-29 12:48:20 -0700672 if library.static() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700673 srcs := android.PathsForModuleSrc(ctx, library.StaticProperties.Static.Srcs)
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700674 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceStaticLibrary,
Pirama Arumuga Nainarf231b192018-01-23 10:49:04 -0800675 srcs, library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossa48ab5b2017-02-14 15:28:44 -0800676 } else if library.shared() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700677 srcs := android.PathsForModuleSrc(ctx, library.SharedProperties.Shared.Srcs)
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700678 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceSharedLibrary,
Pirama Arumuga Nainarf231b192018-01-23 10:49:04 -0800679 srcs, library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossb916a382016-07-29 17:28:03 -0700680 }
681
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700682 return objs
Colin Crossb916a382016-07-29 17:28:03 -0700683}
684
685type libraryInterface interface {
Colin Cross3572cf72020-10-01 15:58:11 -0700686 versionedInterface
687
Colin Crossb916a382016-07-29 17:28:03 -0700688 static() bool
Inseob Kimae553032019-05-14 18:52:49 +0900689 shared() bool
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700690 objs() Objects
Colin Cross0de8a1e2020-09-18 14:15:30 -0700691 reuseObjs() Objects
Colin Cross26c34ed2016-09-30 17:10:16 -0700692 toc() android.OptionalPath
Colin Crossb916a382016-07-29 17:28:03 -0700693
694 // Returns true if the build options for the module have selected a static or shared build
695 buildStatic() bool
696 buildShared() bool
697
698 // Sets whether a specific variant is static or shared
Colin Crossa48ab5b2017-02-14 15:28:44 -0800699 setStatic()
700 setShared()
Logan Chien41eabe62019-04-10 13:33:58 +0800701
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800702 // Check whether header_abi_checker is enabled or explicitly disabled.
703 headerAbiCheckerEnabled() bool
704 headerAbiCheckerExplicitlyDisabled() bool
705
Logan Chien41eabe62019-04-10 13:33:58 +0800706 // Write LOCAL_ADDITIONAL_DEPENDENCIES for ABI diff
707 androidMkWriteAdditionalDependenciesForSourceAbiDiff(w io.Writer)
Jiyong Parka90ca002019-10-07 15:47:24 +0900708
709 availableFor(string) bool
Colin Crossb916a382016-07-29 17:28:03 -0700710}
711
Colin Crossc88c2722020-09-28 17:32:47 -0700712type versionedInterface interface {
713 buildStubs() bool
714 setBuildStubs()
715 hasStubsVariants() bool
716 setStubsVersion(string)
717 stubsVersion() string
718
Colin Cross3572cf72020-10-01 15:58:11 -0700719 stubsVersions(ctx android.BaseMutatorContext) []string
Colin Crossc88c2722020-09-28 17:32:47 -0700720 setAllStubsVersions([]string)
721 allStubsVersions() []string
Colin Cross0477b422020-10-13 18:43:54 -0700722
723 implementationModuleName(name string) string
Colin Cross127bb8b2020-12-16 16:46:01 -0800724 hasLLNDKStubs() bool
Colin Crossc88c2722020-09-28 17:32:47 -0700725}
726
727var _ libraryInterface = (*libraryDecorator)(nil)
728var _ versionedInterface = (*libraryDecorator)(nil)
729
Justin Yun6977e8a2020-10-29 18:24:11 +0900730func (library *libraryDecorator) getLibNameHelper(baseModuleName string, inVendor bool, inProduct bool) string {
Colin Crossb916a382016-07-29 17:28:03 -0700731 name := library.libName
732 if name == "" {
dimitryd95964a2018-11-07 13:43:34 +0100733 name = String(library.Properties.Stem)
734 if name == "" {
Jooyung Han0302a842019-10-30 18:43:49 +0900735 name = baseModuleName
dimitryd95964a2018-11-07 13:43:34 +0100736 }
Colin Crossb916a382016-07-29 17:28:03 -0700737 }
738
Colin Cross0fd6a412019-08-16 14:22:10 -0700739 suffix := ""
Justin Yun6977e8a2020-10-29 18:24:11 +0900740 if inVendor {
Colin Cross0fd6a412019-08-16 14:22:10 -0700741 suffix = String(library.Properties.Target.Vendor.Suffix)
Justin Yun6977e8a2020-10-29 18:24:11 +0900742 } else if inProduct {
743 suffix = String(library.Properties.Target.Product.Suffix)
Colin Cross0fd6a412019-08-16 14:22:10 -0700744 }
745 if suffix == "" {
746 suffix = String(library.Properties.Suffix)
747 }
748
Jooyung Han0302a842019-10-30 18:43:49 +0900749 return name + suffix
750}
751
Chris Parsons3c27ca32020-11-20 12:42:07 -0500752// getLibName returns the actual canonical name of the library (the name which
753// should be passed to the linker via linker flags).
Jooyung Han0302a842019-10-30 18:43:49 +0900754func (library *libraryDecorator) getLibName(ctx BaseModuleContext) string {
Justin Yun6977e8a2020-10-29 18:24:11 +0900755 name := library.getLibNameHelper(ctx.baseModuleName(), ctx.inVendor(), ctx.inProduct())
Colin Cross0fd6a412019-08-16 14:22:10 -0700756
Ivan Lozanof9e21722020-12-02 09:00:51 -0500757 if ctx.IsVndkExt() {
Jooyung Han4c2b9422019-10-22 19:53:47 +0900758 // vndk-ext lib should have the same name with original lib
759 ctx.VisitDirectDepsWithTag(vndkExtDepTag, func(module android.Module) {
760 originalName := module.(*Module).outputFile.Path()
761 name = strings.TrimSuffix(originalName.Base(), originalName.Ext())
762 })
Logan Chienf3511742017-10-31 18:04:35 +0800763 }
764
Colin Crossb916a382016-07-29 17:28:03 -0700765 if ctx.Host() && Bool(library.Properties.Unique_host_soname) {
766 if !strings.HasSuffix(name, "-host") {
767 name = name + "-host"
768 }
769 }
770
Inseob Kim0ce291e2019-07-04 14:38:27 +0900771 return name
Colin Crossb916a382016-07-29 17:28:03 -0700772}
773
Jiyong Parkda732bd2018-11-02 18:23:15 +0900774var versioningMacroNamesListMutex sync.Mutex
775
Colin Crossb916a382016-07-29 17:28:03 -0700776func (library *libraryDecorator) linkerInit(ctx BaseModuleContext) {
777 location := InstallInSystem
Dan Albert61f32122018-07-26 14:00:24 -0700778 if library.baseLinker.sanitize.inSanitizerDir() {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700779 location = InstallInSanitizerDir
Colin Crossb916a382016-07-29 17:28:03 -0700780 }
781 library.baseInstaller.location = location
Colin Crossb916a382016-07-29 17:28:03 -0700782 library.baseLinker.linkerInit(ctx)
Jiyong Park7ed9de32018-10-15 22:25:07 +0900783 // Let baseLinker know whether this variant is for stubs or not, so that
784 // it can omit things that are not required for linking stubs.
785 library.baseLinker.dynamicProperties.BuildStubs = library.buildStubs()
Jiyong Parkda732bd2018-11-02 18:23:15 +0900786
787 if library.buildStubs() {
788 macroNames := versioningMacroNamesList(ctx.Config())
789 myName := versioningMacroName(ctx.ModuleName())
790 versioningMacroNamesListMutex.Lock()
791 defer versioningMacroNamesListMutex.Unlock()
792 if (*macroNames)[myName] == "" {
793 (*macroNames)[myName] = ctx.ModuleName()
794 } else if (*macroNames)[myName] != ctx.ModuleName() {
795 ctx.ModuleErrorf("Macro name %q for versioning conflicts with macro name from module %q ", myName, (*macroNames)[myName])
796 }
797 }
Colin Crossb916a382016-07-29 17:28:03 -0700798}
799
dimitry0345ad82018-12-05 16:28:14 +0100800func (library *libraryDecorator) compilerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800801 if ctx.IsLlndk() {
802 // LLNDK libraries ignore most of the properties on the cc_library and use the
803 // LLNDK-specific properties instead.
804 return deps
805 }
806
dimitry0345ad82018-12-05 16:28:14 +0100807 deps = library.baseCompiler.compilerDeps(ctx, deps)
808
dimitry0345ad82018-12-05 16:28:14 +0100809 return deps
810}
811
Colin Cross37047f12016-12-13 17:06:13 -0800812func (library *libraryDecorator) linkerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800813 if ctx.IsLlndk() {
814 // LLNDK libraries ignore most of the properties on the cc_library and use the
815 // LLNDK-specific properties instead.
816 deps.HeaderLibs = append(deps.HeaderLibs, library.Properties.Llndk.Export_llndk_headers...)
817 deps.ReexportHeaderLibHeaders = append(deps.ReexportHeaderLibHeaders,
818 library.Properties.Llndk.Export_llndk_headers...)
819 return deps
820 }
821
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800822 if library.static() {
Martin Stjernholm10566a02020-03-24 01:19:52 +0000823 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700824 if library.StaticProperties.Static.System_shared_libs != nil {
825 library.baseLinker.Properties.System_shared_libs = library.StaticProperties.Static.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800826 }
827 } else if library.shared() {
Martin Stjernholm10566a02020-03-24 01:19:52 +0000828 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700829 if library.SharedProperties.Shared.System_shared_libs != nil {
830 library.baseLinker.Properties.System_shared_libs = library.SharedProperties.Shared.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800831 }
832 }
833
Colin Crossb916a382016-07-29 17:28:03 -0700834 deps = library.baseLinker.linkerDeps(ctx, deps)
835
836 if library.static() {
837 deps.WholeStaticLibs = append(deps.WholeStaticLibs,
Colin Crosse1bb5d02019-09-24 14:55:04 -0700838 library.StaticProperties.Static.Whole_static_libs...)
839 deps.StaticLibs = append(deps.StaticLibs, library.StaticProperties.Static.Static_libs...)
840 deps.SharedLibs = append(deps.SharedLibs, library.StaticProperties.Static.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -0800841
Colin Crosse1bb5d02019-09-24 14:55:04 -0700842 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.StaticProperties.Static.Export_shared_lib_headers...)
843 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.StaticProperties.Static.Export_static_lib_headers...)
Colin Crossa48ab5b2017-02-14 15:28:44 -0800844 } else if library.shared() {
Dan Willemsen2e47b342016-11-17 01:02:25 -0800845 if ctx.toolchain().Bionic() && !Bool(library.baseLinker.Properties.Nocrt) {
Dan Albert92fe7402020-07-15 13:33:30 -0700846 deps.CrtBegin = "crtbegin_so"
847 deps.CrtEnd = "crtend_so"
Colin Cross4d9c2d12016-07-29 12:48:20 -0700848 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700849 deps.WholeStaticLibs = append(deps.WholeStaticLibs, library.SharedProperties.Shared.Whole_static_libs...)
850 deps.StaticLibs = append(deps.StaticLibs, library.SharedProperties.Shared.Static_libs...)
851 deps.SharedLibs = append(deps.SharedLibs, library.SharedProperties.Shared.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -0800852
Colin Crosse1bb5d02019-09-24 14:55:04 -0700853 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.SharedProperties.Shared.Export_shared_lib_headers...)
854 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.SharedProperties.Shared.Export_static_lib_headers...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700855 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900856 if ctx.inVendor() {
Jiyong Park52d25bd2017-10-13 09:17:01 +0900857 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
858 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
859 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +0000860 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
861 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Jiyong Park52d25bd2017-10-13 09:17:01 +0900862 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900863 if ctx.inProduct() {
864 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
865 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
866 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
867 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
868 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
869 }
Jiyong Parkf9332f12018-02-01 00:54:12 +0900870 if ctx.inRecovery() {
871 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
872 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
873 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +0000874 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
875 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900876 }
Yifan Hongcf4832c2020-01-21 17:04:13 -0800877 if ctx.inRamdisk() {
878 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
879 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
880 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
881 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
882 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
883 }
Yifan Hong6da33c22020-10-27 15:01:21 -0700884 if ctx.inVendorRamdisk() {
885 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
886 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
887 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
888 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
889 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
890 }
Colin Cross2383f3b2018-02-06 14:40:13 -0800891
Colin Cross4d9c2d12016-07-29 12:48:20 -0700892 return deps
893}
894
Paul Duffin13f02712020-03-06 12:30:43 +0000895func (library *libraryDecorator) linkerSpecifiedDeps(specifiedDeps specifiedDeps) specifiedDeps {
896 specifiedDeps = library.baseLinker.linkerSpecifiedDeps(specifiedDeps)
897 var properties StaticOrSharedProperties
898 if library.static() {
899 properties = library.StaticProperties.Static
900 } else if library.shared() {
901 properties = library.SharedProperties.Shared
902 }
903
904 specifiedDeps.sharedLibs = append(specifiedDeps.sharedLibs, properties.Shared_libs...)
Martin Stjernholm10566a02020-03-24 01:19:52 +0000905
906 // Must distinguish nil and [] in system_shared_libs - ensure that [] in
907 // either input list doesn't come out as nil.
908 if specifiedDeps.systemSharedLibs == nil {
909 specifiedDeps.systemSharedLibs = properties.System_shared_libs
910 } else {
911 specifiedDeps.systemSharedLibs = append(specifiedDeps.systemSharedLibs, properties.System_shared_libs...)
912 }
Paul Duffin13f02712020-03-06 12:30:43 +0000913
914 specifiedDeps.sharedLibs = android.FirstUniqueStrings(specifiedDeps.sharedLibs)
Martin Stjernholm10566a02020-03-24 01:19:52 +0000915 if len(specifiedDeps.systemSharedLibs) > 0 {
916 // Skip this if systemSharedLibs is either nil or [], to ensure they are
917 // retained.
918 specifiedDeps.systemSharedLibs = android.FirstUniqueStrings(specifiedDeps.systemSharedLibs)
919 }
Paul Duffin13f02712020-03-06 12:30:43 +0000920 return specifiedDeps
921}
922
Colin Crossb916a382016-07-29 17:28:03 -0700923func (library *libraryDecorator) linkStatic(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700924 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700925
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700926 library.objects = deps.WholeStaticLibObjs.Copy()
927 library.objects = library.objects.Append(objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700928
Inseob Kim0ce291e2019-07-04 14:38:27 +0900929 fileName := ctx.ModuleName() + staticLibraryExtension
Colin Cross86803cf2018-02-15 14:12:26 -0800930 outputFile := android.PathForModuleOut(ctx, fileName)
Dan Willemsen581341d2017-02-09 16:16:31 -0800931 builderFlags := flagsToBuilderFlags(flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700932
Dan Willemsen569edc52018-11-19 09:33:29 -0800933 if Bool(library.baseLinker.Properties.Use_version_lib) {
934 if ctx.Host() {
935 versionedOutputFile := outputFile
936 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
937 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
938 } else {
939 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000940 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -0800941 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
942 }
Colin Cross86803cf2018-02-15 14:12:26 -0800943 }
944
Chris Parsonsbf4f55f2020-11-23 17:02:44 -0500945 transformObjToStaticLib(ctx, library.objects.objFiles, deps.WholeStaticLibsFromPrebuilts, builderFlags, outputFile, objs.tidyFiles)
Dan Willemsen581341d2017-02-09 16:16:31 -0800946
Chris Parsonsbf4f55f2020-11-23 17:02:44 -0500947 library.coverageOutputFile = transformCoverageFilesToZip(ctx, library.objects, ctx.ModuleName())
Colin Cross4d9c2d12016-07-29 12:48:20 -0700948
Colin Cross4d9c2d12016-07-29 12:48:20 -0700949 ctx.CheckbuildFile(outputFile)
950
Colin Cross649d8172020-12-10 12:30:21 -0800951 if library.static() {
952 ctx.SetProvider(StaticLibraryInfoProvider, StaticLibraryInfo{
953 StaticLibrary: outputFile,
954 ReuseObjects: library.reuseObjects,
955 Objects: library.objects,
Colin Cross0de8a1e2020-09-18 14:15:30 -0700956
Colin Cross649d8172020-12-10 12:30:21 -0800957 TransitiveStaticLibrariesForOrdering: android.NewDepSetBuilder(android.TOPOLOGICAL).
958 Direct(outputFile).
959 Transitive(deps.TranstiveStaticLibrariesForOrdering).
960 Build(),
961 })
962 }
963
964 if library.header() {
965 ctx.SetProvider(HeaderLibraryInfoProvider, HeaderLibraryInfo{})
966 }
Colin Cross0de8a1e2020-09-18 14:15:30 -0700967
Colin Cross4d9c2d12016-07-29 12:48:20 -0700968 return outputFile
969}
970
Colin Crossb916a382016-07-29 17:28:03 -0700971func (library *libraryDecorator) linkShared(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700972 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700973
974 var linkerDeps android.Paths
Pirama Arumuga Nainarada83ec2017-08-31 23:38:27 -0700975 linkerDeps = append(linkerDeps, flags.LdFlagsDeps...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700976
Colin Cross2383f3b2018-02-06 14:40:13 -0800977 unexportedSymbols := ctx.ExpandOptionalSource(library.Properties.Unexported_symbols_list, "unexported_symbols_list")
978 forceNotWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_not_weak_list, "force_symbols_not_weak_list")
979 forceWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_weak_list, "force_symbols_weak_list")
Colin Cross4d9c2d12016-07-29 12:48:20 -0700980 if !ctx.Darwin() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700981 if unexportedSymbols.Valid() {
982 ctx.PropertyErrorf("unexported_symbols_list", "Only supported on Darwin")
983 }
984 if forceNotWeakSymbols.Valid() {
985 ctx.PropertyErrorf("force_symbols_not_weak_list", "Only supported on Darwin")
986 }
987 if forceWeakSymbols.Valid() {
988 ctx.PropertyErrorf("force_symbols_weak_list", "Only supported on Darwin")
989 }
990 } else {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700991 if unexportedSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800992 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-unexported_symbols_list,"+unexportedSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -0700993 linkerDeps = append(linkerDeps, unexportedSymbols.Path())
994 }
995 if forceNotWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800996 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_not_weak_list,"+forceNotWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -0700997 linkerDeps = append(linkerDeps, forceNotWeakSymbols.Path())
998 }
999 if forceWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001000 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_weak_list,"+forceWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001001 linkerDeps = append(linkerDeps, forceWeakSymbols.Path())
1002 }
1003 }
Colin Cross8e21aa52020-09-28 18:28:02 -07001004 if library.versionScriptPath.Valid() {
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001005 linkerScriptFlags := "-Wl,--version-script," + library.versionScriptPath.String()
Colin Cross4af21ed2019-11-04 09:37:55 -08001006 flags.Local.LdFlags = append(flags.Local.LdFlags, linkerScriptFlags)
Colin Cross8e21aa52020-09-28 18:28:02 -07001007 linkerDeps = append(linkerDeps, library.versionScriptPath.Path())
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001008 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001009
1010 fileName := library.getLibName(ctx) + flags.Toolchain.ShlibSuffix()
1011 outputFile := android.PathForModuleOut(ctx, fileName)
Colin Cross0de8a1e2020-09-18 14:15:30 -07001012 unstrippedOutputFile := outputFile
Colin Cross4d9c2d12016-07-29 12:48:20 -07001013
Josh Gao75a50a22019-06-07 17:58:59 -07001014 var implicitOutputs android.WritablePaths
1015 if ctx.Windows() {
1016 importLibraryPath := android.PathForModuleOut(ctx, pathtools.ReplaceExtension(fileName, "lib"))
1017
Colin Cross4af21ed2019-11-04 09:37:55 -08001018 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,--out-implib="+importLibraryPath.String())
Josh Gao75a50a22019-06-07 17:58:59 -07001019 implicitOutputs = append(implicitOutputs, importLibraryPath)
1020 }
1021
Colin Cross4d9c2d12016-07-29 12:48:20 -07001022 builderFlags := flagsToBuilderFlags(flags)
1023
Colin Crossb496cfd2018-09-10 16:50:05 -07001024 // Optimize out relinking against shared libraries whose interface hasn't changed by
1025 // depending on a table of contents file instead of the library itself.
Colin Cross70dda7e2019-10-01 22:05:35 -07001026 tocFile := outputFile.ReplaceExtension(ctx, flags.Toolchain.ShlibSuffix()[1:]+".toc")
Colin Crossb496cfd2018-09-10 16:50:05 -07001027 library.tocFile = android.OptionalPathForPath(tocFile)
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001028 transformSharedObjectToToc(ctx, outputFile, tocFile, builderFlags)
Colin Cross89562dc2016-10-03 17:47:19 -07001029
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001030 stripFlags := flagsToStripFlags(flags)
Colin Crossadc81a02020-12-14 17:01:55 -08001031 needsStrip := library.stripper.NeedsStrip(ctx)
1032 if library.buildStubs() {
1033 // No need to strip stubs libraries
1034 needsStrip = false
1035 }
1036 if needsStrip {
Yi Kongb5c34d72018-11-07 16:28:49 -08001037 if ctx.Darwin() {
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001038 stripFlags.StripUseGnuStrip = true
Yi Kongb5c34d72018-11-07 16:28:49 -08001039 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001040 strippedOutputFile := outputFile
1041 outputFile = android.PathForModuleOut(ctx, "unstripped", fileName)
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001042 library.stripper.StripExecutableOrSharedLib(ctx, outputFile, strippedOutputFile, stripFlags)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001043 }
Colin Crossb60190a2018-09-04 16:28:17 -07001044 library.unstrippedOutputFile = outputFile
1045
Colin Crossd7227f92019-09-05 14:26:33 -07001046 outputFile = maybeInjectBoringSSLHash(ctx, outputFile, library.Properties.Inject_bssl_hash, fileName)
Pete Bentley803e1612019-08-06 22:19:59 +01001047
Dan Willemsen569edc52018-11-19 09:33:29 -08001048 if Bool(library.baseLinker.Properties.Use_version_lib) {
1049 if ctx.Host() {
1050 versionedOutputFile := outputFile
1051 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
1052 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1053 } else {
1054 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001055 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -08001056
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001057 if library.stripper.NeedsStrip(ctx) {
Dan Willemsen569edc52018-11-19 09:33:29 -08001058 out := android.PathForModuleOut(ctx, "versioned-stripped", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001059 library.distFile = out
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001060 library.stripper.StripExecutableOrSharedLib(ctx, versionedOutputFile, out, stripFlags)
Dan Willemsen569edc52018-11-19 09:33:29 -08001061 }
1062
1063 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1064 }
Colin Cross86803cf2018-02-15 14:12:26 -08001065 }
1066
Jiyong Park64a44f22019-01-18 14:37:08 +09001067 sharedLibs := deps.EarlySharedLibs
1068 sharedLibs = append(sharedLibs, deps.SharedLibs...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001069 sharedLibs = append(sharedLibs, deps.LateSharedLibs...)
1070
Jiyong Park64a44f22019-01-18 14:37:08 +09001071 linkerDeps = append(linkerDeps, deps.EarlySharedLibsDeps...)
Colin Cross26c34ed2016-09-30 17:10:16 -07001072 linkerDeps = append(linkerDeps, deps.SharedLibsDeps...)
1073 linkerDeps = append(linkerDeps, deps.LateSharedLibsDeps...)
Dan Willemsena03cf6d2016-09-26 15:45:04 -07001074 linkerDeps = append(linkerDeps, objs.tidyFiles...)
Colin Cross26c34ed2016-09-30 17:10:16 -07001075
Colin Cross127bb8b2020-12-16 16:46:01 -08001076 if Bool(library.Properties.Sort_bss_symbols_by_size) && !library.buildStubs() {
Vic Yang6cd1be82019-06-24 16:08:48 -07001077 unsortedOutputFile := android.PathForModuleOut(ctx, "unsorted", fileName)
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001078 transformObjToDynamicBinary(ctx, objs.objFiles, sharedLibs,
Vic Yang6cd1be82019-06-24 16:08:48 -07001079 deps.StaticLibs, deps.LateStaticLibs, deps.WholeStaticLibs,
1080 linkerDeps, deps.CrtBegin, deps.CrtEnd, false, builderFlags, unsortedOutputFile, implicitOutputs)
1081
1082 symbolOrderingFile := android.PathForModuleOut(ctx, "unsorted", fileName+".symbol_order")
1083 symbolOrderingFlag := library.baseLinker.sortBssSymbolsBySize(ctx, unsortedOutputFile, symbolOrderingFile, builderFlags)
Colin Cross6d88dba2019-11-06 07:06:58 -08001084 builderFlags.localLdFlags += " " + symbolOrderingFlag
Vic Yang6cd1be82019-06-24 16:08:48 -07001085 linkerDeps = append(linkerDeps, symbolOrderingFile)
1086 }
1087
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001088 transformObjToDynamicBinary(ctx, objs.objFiles, sharedLibs,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001089 deps.StaticLibs, deps.LateStaticLibs, deps.WholeStaticLibs,
Josh Gao75a50a22019-06-07 17:58:59 -07001090 linkerDeps, deps.CrtBegin, deps.CrtEnd, false, builderFlags, outputFile, implicitOutputs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001091
Dan Willemsen581341d2017-02-09 16:16:31 -08001092 objs.coverageFiles = append(objs.coverageFiles, deps.StaticLibObjs.coverageFiles...)
1093 objs.coverageFiles = append(objs.coverageFiles, deps.WholeStaticLibObjs.coverageFiles...)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001094
1095 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.StaticLibObjs.sAbiDumpFiles...)
1096 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.WholeStaticLibObjs.sAbiDumpFiles...)
1097
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001098 library.coverageOutputFile = transformCoverageFilesToZip(ctx, objs, library.getLibName(ctx))
Colin Cross0de8a1e2020-09-18 14:15:30 -07001099 library.linkSAbiDumpFiles(ctx, objs, fileName, unstrippedOutputFile)
Dan Willemsen581341d2017-02-09 16:16:31 -08001100
Colin Cross0de8a1e2020-09-18 14:15:30 -07001101 var staticAnalogue *StaticLibraryInfo
1102 if static := ctx.GetDirectDepsWithTag(staticVariantTag); len(static) > 0 {
1103 s := ctx.OtherModuleProvider(static[0], StaticLibraryInfoProvider).(StaticLibraryInfo)
1104 staticAnalogue = &s
1105 }
1106
1107 ctx.SetProvider(SharedLibraryInfoProvider, SharedLibraryInfo{
1108 TableOfContents: android.OptionalPathForPath(tocFile),
1109 SharedLibrary: unstrippedOutputFile,
1110 UnstrippedSharedLibrary: library.unstrippedOutputFile,
1111 CoverageSharedLibrary: library.coverageOutputFile,
1112 StaticAnalogue: staticAnalogue,
1113 })
1114
1115 stubs := ctx.GetDirectDepsWithTag(stubImplDepTag)
1116 if len(stubs) > 0 {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001117 var stubsInfo []SharedStubLibrary
Colin Cross0de8a1e2020-09-18 14:15:30 -07001118 for _, stub := range stubs {
1119 stubInfo := ctx.OtherModuleProvider(stub, SharedLibraryInfoProvider).(SharedLibraryInfo)
1120 flagInfo := ctx.OtherModuleProvider(stub, FlagExporterInfoProvider).(FlagExporterInfo)
Chris Parsons3c27ca32020-11-20 12:42:07 -05001121 stubsInfo = append(stubsInfo, SharedStubLibrary{
Colin Cross31076b32020-10-23 17:22:06 -07001122 Version: moduleLibraryInterface(stub).stubsVersion(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001123 SharedLibraryInfo: stubInfo,
1124 FlagExporterInfo: flagInfo,
1125 })
1126 }
Chris Parsons3c27ca32020-11-20 12:42:07 -05001127 ctx.SetProvider(SharedLibraryStubsProvider, SharedLibraryStubsInfo{
1128 SharedStubLibraries: stubsInfo,
Colin Cross0de8a1e2020-09-18 14:15:30 -07001129
Colin Cross127bb8b2020-12-16 16:46:01 -08001130 IsLLNDK: ctx.IsLlndk(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001131 })
1132 }
1133
1134 return unstrippedOutputFile
Colin Cross4d9c2d12016-07-29 12:48:20 -07001135}
1136
Jiyong Parkaf6d8952019-01-31 12:21:23 +09001137func (library *libraryDecorator) unstrippedOutputFilePath() android.Path {
1138 return library.unstrippedOutputFile
1139}
1140
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001141func (library *libraryDecorator) disableStripping() {
1142 library.stripper.StripProperties.Strip.None = BoolPtr(true)
1143}
1144
Pirama Arumuga Nainar65c95ff2019-03-25 10:21:31 -07001145func (library *libraryDecorator) nativeCoverage() bool {
1146 if library.header() || library.buildStubs() {
1147 return false
1148 }
1149 return true
1150}
1151
Jiyong Parkee9a98d2019-08-09 14:44:36 +09001152func (library *libraryDecorator) coverageOutputFilePath() android.OptionalPath {
1153 return library.coverageOutputFile
1154}
1155
Logan Chien7eefdc42018-07-11 18:10:41 +08001156func getRefAbiDumpFile(ctx ModuleContext, vndkVersion, fileName string) android.Path {
Hsin-Yi Chen27d235f2020-03-26 17:50:29 +08001157 // The logic must be consistent with classifySourceAbiDump.
Colin Cross95f1ca02020-10-29 20:47:22 -07001158 isNdk := ctx.isNdk(ctx.Config())
Colin Cross127bb8b2020-12-16 16:46:01 -08001159 isLlndkOrVndk := ctx.IsLlndkPublic() || (ctx.useVndk() && ctx.isVndk())
Logan Chien7eefdc42018-07-11 18:10:41 +08001160
Hsin-Yi Chen53489642019-07-31 17:10:45 +08001161 refAbiDumpTextFile := android.PathForVndkRefAbiDump(ctx, vndkVersion, fileName, isNdk, isLlndkOrVndk, false)
1162 refAbiDumpGzipFile := android.PathForVndkRefAbiDump(ctx, vndkVersion, fileName, isNdk, isLlndkOrVndk, true)
Logan Chien7eefdc42018-07-11 18:10:41 +08001163
1164 if refAbiDumpTextFile.Valid() {
1165 if refAbiDumpGzipFile.Valid() {
1166 ctx.ModuleErrorf(
1167 "Two reference ABI dump files are found: %q and %q. Please delete the stale one.",
1168 refAbiDumpTextFile, refAbiDumpGzipFile)
1169 return nil
1170 }
1171 return refAbiDumpTextFile.Path()
1172 }
1173 if refAbiDumpGzipFile.Valid() {
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001174 return unzipRefDump(ctx, refAbiDumpGzipFile.Path(), fileName)
Logan Chien7eefdc42018-07-11 18:10:41 +08001175 }
1176 return nil
1177}
1178
Jayant Chowdhary6ab3d842017-06-26 12:52:58 -07001179func (library *libraryDecorator) linkSAbiDumpFiles(ctx ModuleContext, objs Objects, fileName string, soFile android.Path) {
Yo Chiang2bbadfa2020-12-14 11:42:16 +08001180 if library.sabi.shouldCreateSourceAbiDump() {
Inseob Kim96f17f02020-06-09 22:05:09 +09001181 var vndkVersion string
1182
1183 if ctx.useVndk() {
1184 // For modules linking against vndk, follow its vndk version
1185 vndkVersion = ctx.Module().(*Module).VndkVersion()
1186 } else {
1187 // Regard the other modules as PLATFORM_VNDK_VERSION
1188 vndkVersion = ctx.DeviceConfig().PlatformVndkVersion()
Logan Chienf3511742017-10-31 18:04:35 +08001189 }
1190
Jayant Chowdharya4fce192017-09-06 13:10:03 -07001191 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001192 var SourceAbiFlags []string
1193 for _, dir := range exportIncludeDirs.Strings() {
Jayant Chowdhary715cac32017-04-20 06:53:59 -07001194 SourceAbiFlags = append(SourceAbiFlags, "-I"+dir)
1195 }
Inseob Kim69378442019-06-03 19:10:47 +09001196 for _, reexportedInclude := range library.sabi.Properties.ReexportedIncludes {
1197 SourceAbiFlags = append(SourceAbiFlags, "-I"+reexportedInclude)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001198 }
1199 exportedHeaderFlags := strings.Join(SourceAbiFlags, " ")
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001200 library.sAbiOutputFile = transformDumpToLinkedDump(ctx, objs.sAbiDumpFiles, soFile, fileName, exportedHeaderFlags,
Jiyong Parka034b832019-08-27 14:02:19 +09001201 android.OptionalPathForModuleSrc(ctx, library.symbolFileForAbiCheck(ctx)),
Logan Chiene3d7a0d2019-01-17 00:18:02 +08001202 library.Properties.Header_abi_checker.Exclude_symbol_versions,
1203 library.Properties.Header_abi_checker.Exclude_symbol_tags)
Logan Chien2f2b8902018-07-10 15:01:19 +08001204
Yo Chiang2bbadfa2020-12-14 11:42:16 +08001205 addLsdumpPath(classifySourceAbiDump(ctx) + ":" + library.sAbiOutputFile.String())
Hsin-Yi Chen53489642019-07-31 17:10:45 +08001206
Logan Chien7eefdc42018-07-11 18:10:41 +08001207 refAbiDumpFile := getRefAbiDumpFile(ctx, vndkVersion, fileName)
1208 if refAbiDumpFile != nil {
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001209 library.sAbiDiff = sourceAbiDiff(ctx, library.sAbiOutputFile.Path(),
Logan Chien2a65dda2019-10-01 15:58:07 -07001210 refAbiDumpFile, fileName, exportedHeaderFlags,
1211 Bool(library.Properties.Header_abi_checker.Check_all_apis),
Colin Cross127bb8b2020-12-16 16:46:01 -08001212 ctx.IsLlndk(), ctx.isNdk(ctx.Config()), ctx.IsVndkExt())
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001213 }
1214 }
1215}
1216
Colin Cross127bb8b2020-12-16 16:46:01 -08001217func processLLNDKHeaders(ctx ModuleContext, srcHeaderDir string, outDir android.ModuleGenPath) android.Path {
1218 srcDir := android.PathForModuleSrc(ctx, srcHeaderDir)
1219 srcFiles := ctx.GlobFiles(filepath.Join(srcDir.String(), "**/*.h"), nil)
1220
1221 var installPaths []android.WritablePath
1222 for _, header := range srcFiles {
1223 headerDir := filepath.Dir(header.String())
1224 relHeaderDir, err := filepath.Rel(srcDir.String(), headerDir)
1225 if err != nil {
1226 ctx.ModuleErrorf("filepath.Rel(%q, %q) failed: %s",
1227 srcDir.String(), headerDir, err)
1228 continue
1229 }
1230
1231 installPaths = append(installPaths, outDir.Join(ctx, relHeaderDir, header.Base()))
1232 }
1233
1234 return processHeadersWithVersioner(ctx, srcDir, outDir, srcFiles, installPaths)
1235}
1236
Chris Parsons3c27ca32020-11-20 12:42:07 -05001237// link registers actions to link this library, and sets various fields
1238// on this library to reflect information that should be exported up the build
1239// tree (for example, exported flags and include paths).
Colin Crossb916a382016-07-29 17:28:03 -07001240func (library *libraryDecorator) link(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001241 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001242
Colin Cross127bb8b2020-12-16 16:46:01 -08001243 if ctx.IsLlndk() {
1244 if len(library.Properties.Llndk.Export_preprocessed_headers) > 0 {
1245 // This is the vendor variant of an LLNDK library with preprocessed headers.
1246 genHeaderOutDir := android.PathForModuleGen(ctx, "include")
1247
1248 var timestampFiles android.Paths
1249 for _, dir := range library.Properties.Llndk.Export_preprocessed_headers {
1250 timestampFiles = append(timestampFiles, processLLNDKHeaders(ctx, dir, genHeaderOutDir))
1251 }
1252
1253 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1254 library.reexportSystemDirs(genHeaderOutDir)
1255 } else {
1256 library.reexportDirs(genHeaderOutDir)
1257 }
1258
1259 library.reexportDeps(timestampFiles...)
1260 }
1261
1262 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1263 library.flagExporter.Properties.Export_system_include_dirs = append(
1264 library.flagExporter.Properties.Export_system_include_dirs,
1265 library.flagExporter.Properties.Export_include_dirs...)
1266 library.flagExporter.Properties.Export_include_dirs = nil
1267 }
1268 }
1269
Chris Parsons3c27ca32020-11-20 12:42:07 -05001270 // Linking this library consists of linking `deps.Objs` (.o files in dependencies
1271 // of this library), together with `objs` (.o files created by compiling this
1272 // library).
Colin Crossad59e752017-11-16 14:29:11 -08001273 objs = deps.Objs.Copy().Append(objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001274 var out android.Path
Colin Crossa48ab5b2017-02-14 15:28:44 -08001275 if library.static() || library.header() {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001276 out = library.linkStatic(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001277 } else {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001278 out = library.linkShared(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001279 }
1280
Chris Parsons3c27ca32020-11-20 12:42:07 -05001281 // Export include paths and flags to be propagated up the tree.
Inseob Kim69378442019-06-03 19:10:47 +09001282 library.exportIncludes(ctx)
1283 library.reexportDirs(deps.ReexportedDirs...)
1284 library.reexportSystemDirs(deps.ReexportedSystemDirs...)
1285 library.reexportFlags(deps.ReexportedFlags...)
1286 library.reexportDeps(deps.ReexportedDeps...)
Inseob Kimd110f872019-12-06 13:15:38 +09001287 library.addExportedGeneratedHeaders(deps.ReexportedGeneratedHeaders...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001288
Chris Parsons3c27ca32020-11-20 12:42:07 -05001289 // Optionally export aidl headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001290 if Bool(library.Properties.Aidl.Export_aidl_headers) {
Dan Willemsene1240db2016-11-03 14:28:51 -07001291 if library.baseCompiler.hasSrcExt(".aidl") {
Jiyong Park74955042019-10-22 20:19:51 +09001292 dir := android.PathForModuleGen(ctx, "aidl")
Inseob Kim69378442019-06-03 19:10:47 +09001293 library.reexportDirs(dir)
Inseob Kimd110f872019-12-06 13:15:38 +09001294
1295 // TODO: restrict to aidl deps
1296 library.reexportDeps(library.baseCompiler.pathDeps...)
1297 library.addExportedGeneratedHeaders(library.baseCompiler.pathDeps...)
Dan Willemsene1240db2016-11-03 14:28:51 -07001298 }
1299 }
1300
Chris Parsons3c27ca32020-11-20 12:42:07 -05001301 // Optionally export proto headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001302 if Bool(library.Properties.Proto.Export_proto_headers) {
Dan Willemsene1240db2016-11-03 14:28:51 -07001303 if library.baseCompiler.hasSrcExt(".proto") {
Jiyong Park74955042019-10-22 20:19:51 +09001304 var includes android.Paths
Colin Cross19878da2019-03-28 14:45:07 -07001305 if flags.proto.CanonicalPathFromRoot {
Jiyong Park74955042019-10-22 20:19:51 +09001306 includes = append(includes, flags.proto.SubDir)
Colin Cross10d22312017-05-03 11:01:58 -07001307 }
Jiyong Park74955042019-10-22 20:19:51 +09001308 includes = append(includes, flags.proto.Dir)
Inseob Kim69378442019-06-03 19:10:47 +09001309 library.reexportDirs(includes...)
Inseob Kimd110f872019-12-06 13:15:38 +09001310
1311 // TODO: restrict to proto deps
1312 library.reexportDeps(library.baseCompiler.pathDeps...)
1313 library.addExportedGeneratedHeaders(library.baseCompiler.pathDeps...)
Colin Cross0c461f12016-10-20 16:11:43 -07001314 }
1315 }
1316
Inseob Kim07def122020-11-23 14:43:02 +09001317 // If the library is sysprop_library, expose either public or internal header selectively.
Inseob Kim21f26902018-09-06 00:55:20 +09001318 if library.baseCompiler.hasSrcExt(".sysprop") {
Jiyong Park74955042019-10-22 20:19:51 +09001319 dir := android.PathForModuleGen(ctx, "sysprop", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001320 if library.Properties.Sysprop.Platform != nil {
Inseob Kim07def122020-11-23 14:43:02 +09001321 isClientProduct := ctx.ProductSpecific() && !ctx.useVndk()
1322 isClientVendor := ctx.useVndk()
Inseob Kimc0907f12019-02-08 21:00:45 +09001323 isOwnerPlatform := Bool(library.Properties.Sysprop.Platform)
1324
Inseob Kim07def122020-11-23 14:43:02 +09001325 // If the owner is different from the user, expose public header. That is,
1326 // 1) if the user is product (as owner can only be platform / vendor)
1327 // 2) if one is platform and the other is vendor
1328 // Exceptions are ramdisk and recovery. They are not enforced at all. So
1329 // they always use internal header.
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001330 if !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() &&
Inseob Kim07def122020-11-23 14:43:02 +09001331 (isClientProduct || (isOwnerPlatform == isClientVendor)) {
Jiyong Park74955042019-10-22 20:19:51 +09001332 dir = android.PathForModuleGen(ctx, "sysprop/public", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001333 }
1334 }
1335
Chris Parsons3c27ca32020-11-20 12:42:07 -05001336 // Add sysprop-related directories to the exported directories of this library.
Inseob Kim69378442019-06-03 19:10:47 +09001337 library.reexportDirs(dir)
1338 library.reexportDeps(library.baseCompiler.pathDeps...)
Inseob Kimd110f872019-12-06 13:15:38 +09001339 library.addExportedGeneratedHeaders(library.baseCompiler.pathDeps...)
Inseob Kim21f26902018-09-06 00:55:20 +09001340 }
1341
Chris Parsons3c27ca32020-11-20 12:42:07 -05001342 // Add stub-related flags if this library is a stub library.
Jiyong Park892a98f2020-12-14 09:20:00 +09001343 library.exportVersioningMacroIfNeeded(ctx)
Jiyong Parkda732bd2018-11-02 18:23:15 +09001344
Chris Parsons3c27ca32020-11-20 12:42:07 -05001345 // Propagate a Provider containing information about exported flags, deps, and include paths.
Colin Cross0de8a1e2020-09-18 14:15:30 -07001346 library.flagExporter.setProvider(ctx)
1347
Colin Cross4d9c2d12016-07-29 12:48:20 -07001348 return out
1349}
1350
Jiyong Park892a98f2020-12-14 09:20:00 +09001351func (library *libraryDecorator) exportVersioningMacroIfNeeded(ctx android.BaseModuleContext) {
Colin Cross127bb8b2020-12-16 16:46:01 -08001352 if library.buildStubs() && library.stubsVersion() != "" && !library.skipAPIDefine {
Jiyong Park892a98f2020-12-14 09:20:00 +09001353 name := versioningMacroName(ctx.Module().(*Module).ImplementationModuleName(ctx))
1354 ver := library.stubsVersion()
1355 library.reexportFlags("-D" + name + "=" + ver)
1356 }
1357}
1358
Chris Parsons3c27ca32020-11-20 12:42:07 -05001359// buildStatic returns true if this library should be built as a static library.
Colin Crossb916a382016-07-29 17:28:03 -07001360func (library *libraryDecorator) buildStatic() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001361 return library.MutatedProperties.BuildStatic &&
1362 BoolDefault(library.StaticProperties.Static.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001363}
1364
Chris Parsons3c27ca32020-11-20 12:42:07 -05001365// buildShared returns true if this library should be built as a shared library.
Colin Crossb916a382016-07-29 17:28:03 -07001366func (library *libraryDecorator) buildShared() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001367 return library.MutatedProperties.BuildShared &&
1368 BoolDefault(library.SharedProperties.Shared.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001369}
1370
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001371func (library *libraryDecorator) objs() Objects {
1372 return library.objects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001373}
1374
Colin Cross0de8a1e2020-09-18 14:15:30 -07001375func (library *libraryDecorator) reuseObjs() Objects {
1376 return library.reuseObjects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001377}
1378
Colin Cross26c34ed2016-09-30 17:10:16 -07001379func (library *libraryDecorator) toc() android.OptionalPath {
1380 return library.tocFile
1381}
1382
Jiyong Parkf1194352019-02-25 11:05:47 +09001383func (library *libraryDecorator) installSymlinkToRuntimeApex(ctx ModuleContext, file android.Path) {
1384 dir := library.baseInstaller.installDir(ctx)
1385 dirOnDevice := android.InstallPathToOnDevicePath(ctx, dir)
1386 target := "/" + filepath.Join("apex", "com.android.runtime", dir.Base(), "bionic", file.Base())
1387 ctx.InstallAbsoluteSymlink(dir, file.Base(), target)
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001388 library.postInstallCmds = append(library.postInstallCmds, makeSymlinkCmd(dirOnDevice, file.Base(), target))
Jiyong Parkf1194352019-02-25 11:05:47 +09001389}
1390
Colin Crossb916a382016-07-29 17:28:03 -07001391func (library *libraryDecorator) install(ctx ModuleContext, file android.Path) {
Colin Crossc43ae772017-04-14 15:42:53 -07001392 if library.shared() {
Justin Yun8fe12122017-12-07 17:18:15 +09001393 if ctx.Device() && ctx.useVndk() {
Jooyung Han261e1582020-10-20 18:54:21 +09001394 // set subDir for VNDK extensions
Ivan Lozanof9e21722020-12-02 09:00:51 -05001395 if ctx.IsVndkExt() {
Jooyung Han261e1582020-10-20 18:54:21 +09001396 if ctx.isVndkSp() {
1397 library.baseInstaller.subDir = "vndk-sp"
1398 } else {
1399 library.baseInstaller.subDir = "vndk"
1400 }
1401 }
1402
Justin Yun31094b12020-12-24 16:11:23 +09001403 // In some cases we want to use core variant for VNDK-Core libs.
1404 // Skip product variant since VNDKs use only the vendor variant.
1405 if ctx.isVndk() && !ctx.isVndkSp() && !ctx.IsVndkExt() && !ctx.inProduct() {
Vic Yang1a5812a2020-01-31 10:38:40 -08001406 mayUseCoreVariant := true
1407
1408 if ctx.mustUseVendorVariant() {
1409 mayUseCoreVariant = false
1410 }
1411
Vic Yang1a5812a2020-01-31 10:38:40 -08001412 if ctx.Config().CFIEnabledForPath(ctx.ModuleDir()) && ctx.Arch().ArchType == android.Arm64 {
1413 mayUseCoreVariant = false
1414 }
1415
1416 if mayUseCoreVariant {
Vic Yangd92090f2020-01-08 14:32:28 -08001417 library.checkSameCoreVariant = true
1418 if ctx.DeviceConfig().VndkUseCoreVariant() {
1419 library.useCoreVariant = true
1420 }
Vic Yangefd249e2018-11-12 20:19:56 -08001421 }
Justin Yun8fe12122017-12-07 17:18:15 +09001422 }
Logan Chienf3511742017-10-31 18:04:35 +08001423
Jooyung Han261e1582020-10-20 18:54:21 +09001424 // do not install vndk libs
1425 // vndk libs are packaged into VNDK APEX
Ivan Lozanof9e21722020-12-02 09:00:51 -05001426 if ctx.isVndk() && !ctx.IsVndkExt() {
Jooyung Han261e1582020-10-20 18:54:21 +09001427 return
Justin Yun8effde42017-06-23 19:24:43 +09001428 }
Colin Cross56a83212020-09-15 18:30:11 -07001429 } else if len(library.Properties.Stubs.Versions) > 0 && !ctx.Host() && ctx.directlyInAnyApex() {
Jiyong Parkf1194352019-02-25 11:05:47 +09001430 // Bionic libraries (e.g. libc.so) is installed to the bootstrap subdirectory.
1431 // The original path becomes a symlink to the corresponding file in the
1432 // runtime APEX.
Colin Cross3b19f5d2019-09-17 14:45:31 -07001433 translatedArch := ctx.Target().NativeBridge == android.NativeBridgeEnabled
Colin Cross56a83212020-09-15 18:30:11 -07001434 if InstallToBootstrap(ctx.baseModuleName(), ctx.Config()) && !library.buildStubs() &&
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001435 !translatedArch && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() {
Martin Stjernholm279de572019-09-10 23:18:20 +01001436 if ctx.Device() {
Jiyong Parkc3e2c862019-03-16 01:10:08 +09001437 library.installSymlinkToRuntimeApex(ctx, file)
1438 }
Jiyong Park429660f2019-01-16 22:31:11 +09001439 library.baseInstaller.subDir = "bootstrap"
1440 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001441 } else if ctx.directlyInAnyApex() && ctx.IsLlndk() && !isBionic(ctx.baseModuleName()) {
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001442 // Skip installing LLNDK (non-bionic) libraries moved to APEX.
Colin Crossa9c8c9f2020-12-16 10:20:23 -08001443 ctx.Module().HideFromMake()
Justin Yun8effde42017-06-23 19:24:43 +09001444 }
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001445
Colin Cross4d9c2d12016-07-29 12:48:20 -07001446 library.baseInstaller.install(ctx, file)
1447 }
Dan Albertf563d252017-10-13 00:29:00 -07001448
Dan Albert281f22b2017-12-13 15:03:47 -08001449 if Bool(library.Properties.Static_ndk_lib) && library.static() &&
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001450 !ctx.useVndk() && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() && ctx.Device() &&
Jiyong Park7ed9de32018-10-15 22:25:07 +09001451 library.baseLinker.sanitize.isUnsanitizedVariant() &&
Colin Cross95b07f22020-12-16 11:06:50 -08001452 ctx.isForPlatform() && !ctx.isPreventInstall() {
Dan Albertf563d252017-10-13 00:29:00 -07001453 installPath := getNdkSysrootBase(ctx).Join(
Dan Albertea4b7b92018-04-25 16:05:30 -07001454 ctx, "usr/lib", config.NDKTriple(ctx.toolchain()), file.Base())
Dan Albertf563d252017-10-13 00:29:00 -07001455
1456 ctx.ModuleBuild(pctx, android.ModuleBuildParams{
1457 Rule: android.Cp,
1458 Description: "install " + installPath.Base(),
1459 Output: installPath,
1460 Input: file,
1461 })
1462
Colin Cross0875c522017-11-28 17:34:01 -08001463 library.ndkSysrootPath = installPath
Dan Albertf563d252017-10-13 00:29:00 -07001464 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001465}
1466
Paul Duffin0cb37b92020-03-04 14:52:46 +00001467func (library *libraryDecorator) everInstallable() bool {
1468 // Only shared and static libraries are installed. Header libraries (which are
1469 // neither static or shared) are not installed.
1470 return library.shared() || library.static()
1471}
1472
Chris Parsons3c27ca32020-11-20 12:42:07 -05001473// static returns true if this library is for a "static' variant.
Colin Crossb916a382016-07-29 17:28:03 -07001474func (library *libraryDecorator) static() bool {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001475 return library.MutatedProperties.VariantIsStatic
Colin Cross4d9c2d12016-07-29 12:48:20 -07001476}
1477
Chris Parsons3c27ca32020-11-20 12:42:07 -05001478// shared returns true if this library is for a "shared' variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001479func (library *libraryDecorator) shared() bool {
1480 return library.MutatedProperties.VariantIsShared
1481}
1482
Chris Parsons3c27ca32020-11-20 12:42:07 -05001483// header returns true if this library is for a header-only variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001484func (library *libraryDecorator) header() bool {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001485 // Neither "static" nor "shared" implies this library is header-only.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001486 return !library.static() && !library.shared()
1487}
1488
Chris Parsons3c27ca32020-11-20 12:42:07 -05001489// setStatic marks the library variant as "static".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001490func (library *libraryDecorator) setStatic() {
1491 library.MutatedProperties.VariantIsStatic = true
1492 library.MutatedProperties.VariantIsShared = false
1493}
1494
Chris Parsons3c27ca32020-11-20 12:42:07 -05001495// setShared marks the library variant as "shared".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001496func (library *libraryDecorator) setShared() {
1497 library.MutatedProperties.VariantIsStatic = false
1498 library.MutatedProperties.VariantIsShared = true
Colin Crossb916a382016-07-29 17:28:03 -07001499}
1500
Chris Parsons3c27ca32020-11-20 12:42:07 -05001501// BuildOnlyStatic disables building this library as a shared library.
Colin Crossab3b7322016-12-09 14:46:15 -08001502func (library *libraryDecorator) BuildOnlyStatic() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001503 library.MutatedProperties.BuildShared = false
Colin Crossab3b7322016-12-09 14:46:15 -08001504}
1505
Chris Parsons3c27ca32020-11-20 12:42:07 -05001506// BuildOnlyShared disables building this library as a static library.
Colin Crossab3b7322016-12-09 14:46:15 -08001507func (library *libraryDecorator) BuildOnlyShared() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001508 library.MutatedProperties.BuildStatic = false
Colin Crossab3b7322016-12-09 14:46:15 -08001509}
1510
Chris Parsons3c27ca32020-11-20 12:42:07 -05001511// HeaderOnly disables building this library as a shared or static library;
1512// the library only exists to propagate header file dependencies up the build graph.
Colin Cross5950f382016-12-13 12:50:57 -08001513func (library *libraryDecorator) HeaderOnly() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001514 library.MutatedProperties.BuildShared = false
1515 library.MutatedProperties.BuildStatic = false
Colin Cross5950f382016-12-13 12:50:57 -08001516}
1517
Colin Cross127bb8b2020-12-16 16:46:01 -08001518// hasLLNDKStubs returns true if this cc_library module has a variant that will build LLNDK stubs.
1519func (library *libraryDecorator) hasLLNDKStubs() bool {
1520 return String(library.Properties.Llndk_stubs) != ""
1521}
1522
Colin Cross0477b422020-10-13 18:43:54 -07001523func (library *libraryDecorator) implementationModuleName(name string) string {
1524 return name
1525}
1526
Jiyong Park7ed9de32018-10-15 22:25:07 +09001527func (library *libraryDecorator) buildStubs() bool {
1528 return library.MutatedProperties.BuildStubs
1529}
1530
Jiyong Parka034b832019-08-27 14:02:19 +09001531func (library *libraryDecorator) symbolFileForAbiCheck(ctx ModuleContext) *string {
1532 if library.Properties.Header_abi_checker.Symbol_file != nil {
1533 return library.Properties.Header_abi_checker.Symbol_file
1534 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001535 if ctx.Module().(*Module).IsLlndk() {
1536 return library.Properties.Llndk.Symbol_file
1537 }
Colin Cross31076b32020-10-23 17:22:06 -07001538 if library.hasStubsVariants() && library.Properties.Stubs.Symbol_file != nil {
Jiyong Parka034b832019-08-27 14:02:19 +09001539 return library.Properties.Stubs.Symbol_file
1540 }
1541 return nil
1542}
1543
Colin Crossc88c2722020-09-28 17:32:47 -07001544func (library *libraryDecorator) hasStubsVariants() bool {
1545 return len(library.Properties.Stubs.Versions) > 0
1546}
1547
Colin Cross3572cf72020-10-01 15:58:11 -07001548func (library *libraryDecorator) stubsVersions(ctx android.BaseMutatorContext) []string {
Colin Crossc88c2722020-09-28 17:32:47 -07001549 return library.Properties.Stubs.Versions
1550}
1551
1552func (library *libraryDecorator) setStubsVersion(version string) {
1553 library.MutatedProperties.StubsVersion = version
1554}
1555
Jiyong Park7ed9de32018-10-15 22:25:07 +09001556func (library *libraryDecorator) stubsVersion() string {
1557 return library.MutatedProperties.StubsVersion
1558}
1559
Colin Crossc88c2722020-09-28 17:32:47 -07001560func (library *libraryDecorator) setBuildStubs() {
1561 library.MutatedProperties.BuildStubs = true
1562}
1563
1564func (library *libraryDecorator) setAllStubsVersions(versions []string) {
1565 library.MutatedProperties.AllStubsVersions = versions
1566}
1567
1568func (library *libraryDecorator) allStubsVersions() []string {
1569 return library.MutatedProperties.AllStubsVersions
1570}
1571
Jooyung Hanad4c1872020-02-27 17:56:44 +09001572func (library *libraryDecorator) isLatestStubVersion() bool {
1573 versions := library.Properties.Stubs.Versions
1574 return versions[len(versions)-1] == library.stubsVersion()
1575}
1576
Jiyong Parka90ca002019-10-07 15:47:24 +09001577func (library *libraryDecorator) availableFor(what string) bool {
1578 var list []string
1579 if library.static() {
1580 list = library.StaticProperties.Static.Apex_available
1581 } else if library.shared() {
1582 list = library.SharedProperties.Shared.Apex_available
1583 }
1584 if len(list) == 0 {
1585 return false
1586 }
1587 return android.CheckAvailableForApex(what, list)
1588}
1589
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001590func (library *libraryDecorator) makeUninstallable(mod *Module) {
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001591 if library.static() && library.buildStatic() && !library.buildStubs() {
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001592 // If we're asked to make a static library uninstallable we don't do
1593 // anything since AndroidMkEntries always sets LOCAL_UNINSTALLABLE_MODULE
1594 // for these entries. This is done to still get the make targets for NOTICE
1595 // files from notice_files.mk, which other libraries might depend on.
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001596 return
1597 }
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001598 mod.ModuleBase.MakeUninstallable()
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001599}
1600
Colin Cross571cccf2019-02-04 11:22:08 -08001601var versioningMacroNamesListKey = android.NewOnceKey("versioningMacroNamesList")
1602
Chris Parsons3c27ca32020-11-20 12:42:07 -05001603// versioningMacroNamesList returns a singleton map, where keys are "version macro names",
1604// and values are the module name responsible for registering the version macro name.
1605//
1606// Version macros are used when building against stubs, to provide version information about
1607// the stub. Only stub libraries should have an entry in this list.
1608//
1609// For example, when building against libFoo#ver, __LIBFOO_API__ macro is set to ver so
1610// that headers from libFoo can be conditionally compiled (this may hide APIs
1611// that are not available for the version).
1612//
1613// This map is used to ensure that there aren't conflicts between these version macro names.
Jiyong Parkda732bd2018-11-02 18:23:15 +09001614func versioningMacroNamesList(config android.Config) *map[string]string {
Colin Cross571cccf2019-02-04 11:22:08 -08001615 return config.Once(versioningMacroNamesListKey, func() interface{} {
Jiyong Parkda732bd2018-11-02 18:23:15 +09001616 m := make(map[string]string)
1617 return &m
1618 }).(*map[string]string)
1619}
1620
1621// alphanumeric and _ characters are preserved.
1622// other characters are all converted to _
1623var charsNotForMacro = regexp.MustCompile("[^a-zA-Z0-9_]+")
1624
Chris Parsons3c27ca32020-11-20 12:42:07 -05001625// versioningMacroName returns the canonical version macro name for the given module.
Jiyong Parkda732bd2018-11-02 18:23:15 +09001626func versioningMacroName(moduleName string) string {
1627 macroName := charsNotForMacro.ReplaceAllString(moduleName, "_")
Jooyung Hanb04a4992020-03-13 18:57:35 +09001628 macroName = strings.ToUpper(macroName)
Jiyong Parkda732bd2018-11-02 18:23:15 +09001629 return "__" + macroName + "_API__"
1630}
1631
Chris Parsons3c27ca32020-11-20 12:42:07 -05001632// NewLibrary builds and returns a new Module corresponding to a C++ library.
1633// Individual module implementations which comprise a C++ library (or something like
1634// a C++ library) should call this function, set some fields on the result, and
1635// then call the Init function.
Colin Crossab3b7322016-12-09 14:46:15 -08001636func NewLibrary(hod android.HostOrDeviceSupported) (*Module, *libraryDecorator) {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001637 module := newModule(hod, android.MultilibBoth)
1638
Colin Crossb916a382016-07-29 17:28:03 -07001639 library := &libraryDecorator{
Colin Crossa48ab5b2017-02-14 15:28:44 -08001640 MutatedProperties: LibraryMutatedProperties{
Colin Crossab3b7322016-12-09 14:46:15 -08001641 BuildShared: true,
1642 BuildStatic: true,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001643 },
Colin Crossb916a382016-07-29 17:28:03 -07001644 baseCompiler: NewBaseCompiler(),
Dan Albert61f32122018-07-26 14:00:24 -07001645 baseLinker: NewBaseLinker(module.sanitize),
Colin Crossb916a382016-07-29 17:28:03 -07001646 baseInstaller: NewBaseInstaller("lib", "lib64", InstallInSystem),
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001647 sabi: module.sabi,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001648 }
1649
Colin Crossb916a382016-07-29 17:28:03 -07001650 module.compiler = library
1651 module.linker = library
1652 module.installer = library
Colin Cross31076b32020-10-23 17:22:06 -07001653 module.library = library
Colin Crossb916a382016-07-29 17:28:03 -07001654
1655 return module, library
1656}
1657
Colin Cross10d22312017-05-03 11:01:58 -07001658// connects a shared library to a static library in order to reuse its .o files to avoid
1659// compiling source files twice.
1660func reuseStaticLibrary(mctx android.BottomUpMutatorContext, static, shared *Module) {
1661 if staticCompiler, ok := static.compiler.(*libraryDecorator); ok {
1662 sharedCompiler := shared.compiler.(*libraryDecorator)
Dan Willemsen3a26eef2018-12-03 15:25:46 -08001663
1664 // Check libraries in addition to cflags, since libraries may be exporting different
1665 // include directories.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001666 if len(staticCompiler.StaticProperties.Static.Cflags) == 0 &&
1667 len(sharedCompiler.SharedProperties.Shared.Cflags) == 0 &&
1668 len(staticCompiler.StaticProperties.Static.Whole_static_libs) == 0 &&
1669 len(sharedCompiler.SharedProperties.Shared.Whole_static_libs) == 0 &&
1670 len(staticCompiler.StaticProperties.Static.Static_libs) == 0 &&
1671 len(sharedCompiler.SharedProperties.Shared.Static_libs) == 0 &&
1672 len(staticCompiler.StaticProperties.Static.Shared_libs) == 0 &&
1673 len(sharedCompiler.SharedProperties.Shared.Shared_libs) == 0 &&
Martin Stjernholm10566a02020-03-24 01:19:52 +00001674 // Compare System_shared_libs properties with nil because empty lists are
1675 // semantically significant for them.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001676 staticCompiler.StaticProperties.Static.System_shared_libs == nil &&
1677 sharedCompiler.SharedProperties.Shared.System_shared_libs == nil {
Colin Cross10d22312017-05-03 11:01:58 -07001678
1679 mctx.AddInterVariantDependency(reuseObjTag, shared, static)
1680 sharedCompiler.baseCompiler.Properties.OriginalSrcs =
1681 sharedCompiler.baseCompiler.Properties.Srcs
1682 sharedCompiler.baseCompiler.Properties.Srcs = nil
1683 sharedCompiler.baseCompiler.Properties.Generated_sources = nil
1684 }
Colin Cross0de8a1e2020-09-18 14:15:30 -07001685
1686 // This dep is just to reference static variant from shared variant
1687 mctx.AddInterVariantDependency(staticVariantTag, shared, static)
Colin Cross10d22312017-05-03 11:01:58 -07001688 }
1689}
1690
Chris Parsons3c27ca32020-11-20 12:42:07 -05001691// LinkageMutator adds "static" or "shared" variants for modules depending
1692// on whether the module can be built as a static library or a shared library.
Colin Crosse40b4ea2018-10-02 22:25:58 -07001693func LinkageMutator(mctx android.BottomUpMutatorContext) {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001694 ccPrebuilt := false
Colin Crossb916a382016-07-29 17:28:03 -07001695 if m, ok := mctx.Module().(*Module); ok && m.linker != nil {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001696 _, ccPrebuilt = m.linker.(prebuiltLibraryInterface)
Ivan Lozano52767be2019-10-18 14:49:46 -07001697 }
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001698 if ccPrebuilt {
Ivan Lozano52767be2019-10-18 14:49:46 -07001699 library := mctx.Module().(*Module).linker.(prebuiltLibraryInterface)
Colin Cross33b2fb72019-05-14 14:07:01 -07001700
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001701 // Differentiate between header only and building an actual static/shared library
Colin Cross127bb8b2020-12-16 16:46:01 -08001702 buildStatic := library.buildStatic()
1703 buildShared := library.buildShared()
1704 if buildStatic || buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001705 // Always create both the static and shared variants for prebuilt libraries, and then disable the one
1706 // that is not being used. This allows them to share the name of a cc_library module, which requires that
1707 // all the variants of the cc_library also exist on the prebuilt.
1708 modules := mctx.CreateLocalVariations("static", "shared")
1709 static := modules[0].(*Module)
1710 shared := modules[1].(*Module)
Colin Cross33b2fb72019-05-14 14:07:01 -07001711
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001712 static.linker.(prebuiltLibraryInterface).setStatic()
1713 shared.linker.(prebuiltLibraryInterface).setShared()
Colin Cross33b2fb72019-05-14 14:07:01 -07001714
Colin Cross127bb8b2020-12-16 16:46:01 -08001715 if buildShared {
Colin Cross81ca6cd2020-08-06 17:46:48 -07001716 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08001717 } else if buildStatic {
Colin Cross81ca6cd2020-08-06 17:46:48 -07001718 mctx.AliasVariation("static")
1719 }
1720
Colin Cross127bb8b2020-12-16 16:46:01 -08001721 if !buildStatic {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001722 static.linker.(prebuiltLibraryInterface).disablePrebuilt()
1723 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001724 if !buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001725 shared.linker.(prebuiltLibraryInterface).disablePrebuilt()
1726 }
1727 } else {
1728 // Header only
Colin Crossb916a382016-07-29 17:28:03 -07001729 }
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001730
Ivan Lozano52767be2019-10-18 14:49:46 -07001731 } else if library, ok := mctx.Module().(LinkableInterface); ok && library.CcLibraryInterface() {
Ivan Lozano52767be2019-10-18 14:49:46 -07001732
Ivan Lozano2b262972019-11-21 12:30:50 -08001733 // Non-cc.Modules may need an empty variant for their mutators.
1734 variations := []string{}
1735 if library.NonCcVariants() {
1736 variations = append(variations, "")
1737 }
1738
Colin Cross127bb8b2020-12-16 16:46:01 -08001739 isLLNDK := false
1740 if m, ok := mctx.Module().(*Module); ok {
1741 isLLNDK = m.IsLlndk()
1742 // Don't count the vestigial llndk_library module as isLLNDK, it needs a static
1743 // variant so that a cc_library_prebuilt can depend on it.
1744 if _, ok := m.linker.(*llndkStubDecorator); ok {
1745 isLLNDK = false
1746 }
1747 }
1748 buildStatic := library.BuildStaticVariant() && !isLLNDK
1749 buildShared := library.BuildSharedVariant()
1750 if buildStatic && buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08001751 variations := append([]string{"static", "shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001752
1753 modules := mctx.CreateLocalVariations(variations...)
1754 static := modules[0].(LinkableInterface)
1755 shared := modules[1].(LinkableInterface)
1756
1757 static.SetStatic()
1758 shared.SetShared()
1759
1760 if _, ok := library.(*Module); ok {
1761 reuseStaticLibrary(mctx, static.(*Module), shared.(*Module))
1762 }
Colin Cross81ca6cd2020-08-06 17:46:48 -07001763 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08001764 } else if buildStatic {
Ivan Lozano2b262972019-11-21 12:30:50 -08001765 variations := append([]string{"static"}, variations...)
1766
1767 modules := mctx.CreateLocalVariations(variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001768 modules[0].(LinkableInterface).SetStatic()
Colin Cross81ca6cd2020-08-06 17:46:48 -07001769 mctx.AliasVariation("static")
Colin Cross127bb8b2020-12-16 16:46:01 -08001770 } else if buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08001771 variations := append([]string{"shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001772
Ivan Lozano2b262972019-11-21 12:30:50 -08001773 modules := mctx.CreateLocalVariations(variations...)
1774 modules[0].(LinkableInterface).SetShared()
Colin Cross81ca6cd2020-08-06 17:46:48 -07001775 mctx.AliasVariation("shared")
Ivan Lozano2b262972019-11-21 12:30:50 -08001776 } else if len(variations) > 0 {
1777 mctx.CreateLocalVariations(variations...)
Colin Cross81ca6cd2020-08-06 17:46:48 -07001778 mctx.AliasVariation(variations[0])
Ivan Lozano2b262972019-11-21 12:30:50 -08001779 }
Colin Crossb916a382016-07-29 17:28:03 -07001780 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001781}
Jiyong Park7ed9de32018-10-15 22:25:07 +09001782
Chris Parsons3c27ca32020-11-20 12:42:07 -05001783// normalizeVersions modifies `versions` in place, so that each raw version
1784// string becomes its normalized canonical form.
1785// Validates that the versions in `versions` are specified in least to greatest order.
Jooyung Hanaed150d2020-04-02 01:41:41 +09001786func normalizeVersions(ctx android.BaseModuleContext, versions []string) {
Dan Albertc8060532020-07-22 22:32:17 -07001787 var previous android.ApiLevel
Jooyung Hanad4c1872020-02-27 17:56:44 +09001788 for i, v := range versions {
Dan Albertc8060532020-07-22 22:32:17 -07001789 ver, err := android.ApiLevelFromUser(ctx, v)
Jooyung Hanad4c1872020-02-27 17:56:44 +09001790 if err != nil {
Jooyung Hanaed150d2020-04-02 01:41:41 +09001791 ctx.PropertyErrorf("versions", "%s", err.Error())
1792 return
Jooyung Hanad4c1872020-02-27 17:56:44 +09001793 }
Dan Albertc8060532020-07-22 22:32:17 -07001794 if i > 0 && ver.LessThanOrEqualTo(previous) {
1795 ctx.PropertyErrorf("versions", "not sorted: %v", versions)
1796 }
1797 versions[i] = ver.String()
1798 previous = ver
Jooyung Hanaed150d2020-04-02 01:41:41 +09001799 }
Jooyung Hanad4c1872020-02-27 17:56:44 +09001800}
1801
Jooyung Han61b66e92020-03-21 14:21:46 +00001802func createVersionVariations(mctx android.BottomUpMutatorContext, versions []string) {
Colin Cross127bb8b2020-12-16 16:46:01 -08001803 // "" is for the non-stubs (implementation) variant for system modules, or the LLNDK variant
1804 // for LLNDK modules.
Colin Cross0de8a1e2020-09-18 14:15:30 -07001805 variants := append(android.CopyOf(versions), "")
Jooyung Han61b66e92020-03-21 14:21:46 +00001806
Colin Cross127bb8b2020-12-16 16:46:01 -08001807 m := mctx.Module().(*Module)
1808 isLLNDK := m.IsLlndk()
1809
Colin Crossd1f898e2020-08-18 18:35:15 -07001810 modules := mctx.CreateLocalVariations(variants...)
Jooyung Han61b66e92020-03-21 14:21:46 +00001811 for i, m := range modules {
Colin Cross127bb8b2020-12-16 16:46:01 -08001812
1813 if variants[i] != "" || isLLNDK {
1814 // A stubs or LLNDK stubs variant.
Colin Cross31076b32020-10-23 17:22:06 -07001815 c := m.(*Module)
Colin Cross31076b32020-10-23 17:22:06 -07001816 c.sanitize = nil
1817 c.stl = nil
1818 c.Properties.PreventInstall = true
1819 lib := moduleLibraryInterface(m)
1820 lib.setBuildStubs()
Colin Cross127bb8b2020-12-16 16:46:01 -08001821
1822 if variants[i] != "" {
1823 // A non-LLNDK stubs module is hidden from make and has a dependency from the
1824 // implementation module to the stubs module.
1825 c.Properties.HideFromMake = true
1826 lib.setStubsVersion(variants[i])
1827 mctx.AddInterVariantDependency(stubImplDepTag, modules[len(modules)-1], modules[i])
1828 }
Jooyung Han61b66e92020-03-21 14:21:46 +00001829 }
1830 }
Colin Cross094faa52020-08-06 17:38:25 -07001831 mctx.AliasVariation("")
Colin Crossd1f898e2020-08-18 18:35:15 -07001832 latestVersion := ""
1833 if len(versions) > 0 {
1834 latestVersion = versions[len(versions)-1]
1835 }
1836 mctx.CreateAliasVariation("latest", latestVersion)
Jooyung Han61b66e92020-03-21 14:21:46 +00001837}
1838
Colin Crossbbc941b2020-09-30 12:27:01 -07001839func createPerApiVersionVariations(mctx android.BottomUpMutatorContext, minSdkVersion string) {
1840 from, err := nativeApiLevelFromUser(mctx, minSdkVersion)
1841 if err != nil {
1842 mctx.PropertyErrorf("min_sdk_version", err.Error())
1843 return
1844 }
1845
1846 versionStrs := ndkLibraryVersions(mctx, from)
1847 modules := mctx.CreateLocalVariations(versionStrs...)
1848
1849 for i, module := range modules {
1850 module.(*Module).Properties.Sdk_version = StringPtr(versionStrs[i])
1851 }
1852}
1853
Colin Cross3146c5c2020-09-30 15:34:40 -07001854func CanBeOrLinkAgainstVersionVariants(module interface {
Jooyung Han624d35c2020-04-10 12:57:24 +09001855 Host() bool
1856 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001857 InVendorRamdisk() bool
Jooyung Han624d35c2020-04-10 12:57:24 +09001858 InRecovery() bool
1859}) bool {
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001860 return !module.Host() && !module.InRamdisk() && !module.InVendorRamdisk() && !module.InRecovery()
Jooyung Han624d35c2020-04-10 12:57:24 +09001861}
1862
Colin Cross3146c5c2020-09-30 15:34:40 -07001863func CanBeVersionVariant(module interface {
1864 Host() bool
1865 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001866 InVendorRamdisk() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07001867 InRecovery() bool
1868 CcLibraryInterface() bool
1869 Shared() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07001870}) bool {
1871 return CanBeOrLinkAgainstVersionVariants(module) &&
Colin Crossa717db72020-10-23 14:53:06 -07001872 module.CcLibraryInterface() && module.Shared()
Colin Cross3146c5c2020-09-30 15:34:40 -07001873}
1874
Colin Cross127bb8b2020-12-16 16:46:01 -08001875func moduleLibraryInterface(module blueprint.Module) libraryInterface {
Colin Cross31076b32020-10-23 17:22:06 -07001876 if m, ok := module.(*Module); ok {
1877 return m.library
1878 }
1879 return nil
1880}
1881
Colin Crossd1f898e2020-08-18 18:35:15 -07001882// versionSelector normalizes the versions in the Stubs.Versions property into MutatedProperties.AllStubsVersions,
1883// and propagates the value from implementation libraries to llndk libraries with the same name.
1884func versionSelectorMutator(mctx android.BottomUpMutatorContext) {
Colin Cross31076b32020-10-23 17:22:06 -07001885 if library := moduleLibraryInterface(mctx.Module()); library != nil && CanBeVersionVariant(mctx.Module().(*Module)) {
1886 if library.buildShared() {
1887 versions := library.stubsVersions(mctx)
Colin Cross3572cf72020-10-01 15:58:11 -07001888 if len(versions) > 0 {
1889 normalizeVersions(mctx, versions)
1890 if mctx.Failed() {
Colin Crossbbc941b2020-09-30 12:27:01 -07001891 return
1892 }
Colin Cross3572cf72020-10-01 15:58:11 -07001893 // Set the versions on the pre-mutated module so they can be read by any llndk modules that
1894 // depend on the implementation library and haven't been mutated yet.
Colin Cross31076b32020-10-23 17:22:06 -07001895 library.setAllStubsVersions(versions)
Colin Cross127bb8b2020-12-16 16:46:01 -08001896 }
1897
1898 if mctx.Module().(*Module).UseVndk() && library.hasLLNDKStubs() {
1899 // Propagate the version to the llndk stubs module.
1900 mctx.VisitDirectDepsWithTag(llndkStubDepTag, func(stubs android.Module) {
1901 if stubsLib := moduleLibraryInterface(stubs); stubsLib != nil {
1902 stubsLib.setAllStubsVersions(library.allStubsVersions())
1903 }
1904 })
Jiyong Park7ed9de32018-10-15 22:25:07 +09001905 }
Jooyung Han61b66e92020-03-21 14:21:46 +00001906 }
Colin Crossd1f898e2020-08-18 18:35:15 -07001907 }
1908}
Jooyung Han61b66e92020-03-21 14:21:46 +00001909
Colin Crossd1f898e2020-08-18 18:35:15 -07001910// versionMutator splits a module into the mandatory non-stubs variant
1911// (which is unnamed) and zero or more stubs variants.
1912func versionMutator(mctx android.BottomUpMutatorContext) {
Colin Cross31076b32020-10-23 17:22:06 -07001913 if library := moduleLibraryInterface(mctx.Module()); library != nil && CanBeVersionVariant(mctx.Module().(*Module)) {
1914 createVersionVariations(mctx, library.allStubsVersions())
Colin Crossbbc941b2020-09-30 12:27:01 -07001915 return
1916 }
1917
1918 if m, ok := mctx.Module().(*Module); ok {
1919 if m.SplitPerApiLevel() && m.IsSdkVariant() {
1920 if mctx.Os() != android.Android {
1921 return
1922 }
1923 createPerApiVersionVariations(mctx, m.MinSdkVersion())
1924 }
Jiyong Park7ed9de32018-10-15 22:25:07 +09001925 }
Jiyong Park7ed9de32018-10-15 22:25:07 +09001926}
Colin Crossd7227f92019-09-05 14:26:33 -07001927
1928// maybeInjectBoringSSLHash adds a rule to run bssl_inject_hash on the output file if the module has the
1929// inject_bssl_hash or if any static library dependencies have inject_bssl_hash set. It returns the output path
1930// that the linked output file should be written to.
1931// TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
1932func maybeInjectBoringSSLHash(ctx android.ModuleContext, outputFile android.ModuleOutPath,
1933 inject *bool, fileName string) android.ModuleOutPath {
1934 // TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
1935 injectBoringSSLHash := Bool(inject)
1936 ctx.VisitDirectDeps(func(dep android.Module) {
Colin Cross6e511a92020-07-27 21:26:48 -07001937 if tag, ok := ctx.OtherModuleDependencyTag(dep).(libraryDependencyTag); ok && tag.static() {
Colin Crossd7227f92019-09-05 14:26:33 -07001938 if cc, ok := dep.(*Module); ok {
1939 if library, ok := cc.linker.(*libraryDecorator); ok {
1940 if Bool(library.Properties.Inject_bssl_hash) {
1941 injectBoringSSLHash = true
1942 }
1943 }
1944 }
1945 }
1946 })
1947 if injectBoringSSLHash {
1948 hashedOutputfile := outputFile
1949 outputFile = android.PathForModuleOut(ctx, "unhashed", fileName)
1950
Colin Crossf1a035e2020-11-16 17:32:30 -08001951 rule := android.NewRuleBuilder(pctx, ctx)
Colin Crossd7227f92019-09-05 14:26:33 -07001952 rule.Command().
Colin Crossf1a035e2020-11-16 17:32:30 -08001953 BuiltTool("bssl_inject_hash").
Pete Bentley5c4be822019-10-01 17:03:17 +01001954 Flag("-sha256").
Colin Crossd7227f92019-09-05 14:26:33 -07001955 FlagWithInput("-in-object ", outputFile).
1956 FlagWithOutput("-o ", hashedOutputfile)
Colin Crossf1a035e2020-11-16 17:32:30 -08001957 rule.Build("injectCryptoHash", "inject crypto hash")
Colin Crossd7227f92019-09-05 14:26:33 -07001958 }
1959
1960 return outputFile
1961}