blob: 18f9fae28e28abaf1a648d9184fe5e8181f226ac [file] [log] [blame]
Colin Cross4d9c2d12016-07-29 12:48:20 -07001// Copyright 2016 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15package cc
16
17import (
Inseob Kim69378442019-06-03 19:10:47 +090018 "fmt"
Logan Chien41eabe62019-04-10 13:33:58 +080019 "io"
Jiyong Parkf1194352019-02-25 11:05:47 +090020 "path/filepath"
Jiyong Parkda732bd2018-11-02 18:23:15 +090021 "regexp"
Jooyung Han11b0fbd2021-02-05 02:28:22 +090022 "strconv"
Colin Cross4d9c2d12016-07-29 12:48:20 -070023 "strings"
Jiyong Parkda732bd2018-11-02 18:23:15 +090024 "sync"
Colin Cross4d9c2d12016-07-29 12:48:20 -070025
Colin Cross127bb8b2020-12-16 16:46:01 -080026 "github.com/google/blueprint"
Colin Cross26c34ed2016-09-30 17:10:16 -070027 "github.com/google/blueprint/pathtools"
Colin Cross4d9c2d12016-07-29 12:48:20 -070028
Colin Cross4d9c2d12016-07-29 12:48:20 -070029 "android/soong/android"
Rupert Shuttleworth095081c2021-03-25 09:06:03 +000030 "android/soong/bazel"
Dan Albertea4b7b92018-04-25 16:05:30 -070031 "android/soong/cc/config"
Colin Cross4d9c2d12016-07-29 12:48:20 -070032)
33
Chris Parsons3c27ca32020-11-20 12:42:07 -050034// LibraryProperties is a collection of properties shared by cc library rules.
Colin Crossb916a382016-07-29 17:28:03 -070035type LibraryProperties struct {
Colin Cross4d9c2d12016-07-29 12:48:20 -070036 // local file name to pass to the linker as -unexported_symbols_list
Colin Cross27b922f2019-03-04 22:35:41 -080037 Unexported_symbols_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070038 // local file name to pass to the linker as -force_symbols_not_weak_list
Colin Cross27b922f2019-03-04 22:35:41 -080039 Force_symbols_not_weak_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070040 // local file name to pass to the linker as -force_symbols_weak_list
Colin Cross27b922f2019-03-04 22:35:41 -080041 Force_symbols_weak_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070042
43 // rename host libraries to prevent overlap with system installed libraries
44 Unique_host_soname *bool
45
Dan Willemsene1240db2016-11-03 14:28:51 -070046 Aidl struct {
47 // export headers generated from .aidl sources
Nan Zhang0007d812017-11-07 10:57:05 -080048 Export_aidl_headers *bool
Dan Willemsene1240db2016-11-03 14:28:51 -070049 }
50
Colin Cross0c461f12016-10-20 16:11:43 -070051 Proto struct {
52 // export headers generated from .proto sources
Nan Zhang0007d812017-11-07 10:57:05 -080053 Export_proto_headers *bool
Colin Cross0c461f12016-10-20 16:11:43 -070054 }
Dan Albertf563d252017-10-13 00:29:00 -070055
Inseob Kimc0907f12019-02-08 21:00:45 +090056 Sysprop struct {
57 // Whether platform owns this sysprop library.
58 Platform *bool
Inseob Kimb3f22ca2019-03-05 12:40:24 +090059 } `blueprint:"mutated"`
Inseob Kimc0907f12019-02-08 21:00:45 +090060
Nan Zhang0007d812017-11-07 10:57:05 -080061 Static_ndk_lib *bool
Jiyong Park7ed9de32018-10-15 22:25:07 +090062
63 Stubs struct {
64 // Relative path to the symbol map. The symbol map provides the list of
65 // symbols that are exported for stubs variant of this library.
Colin Cross27b922f2019-03-04 22:35:41 -080066 Symbol_file *string `android:"path"`
Jiyong Park7ed9de32018-10-15 22:25:07 +090067
Jiyong Parkd4a3a132021-03-17 20:21:35 +090068 // List versions to generate stubs libs for. The version name "current" is always
69 // implicitly added.
Jiyong Park7ed9de32018-10-15 22:25:07 +090070 Versions []string
71 }
dimitryd95964a2018-11-07 13:43:34 +010072
73 // set the name of the output
74 Stem *string `android:"arch_variant"`
75
Colin Cross0fd6a412019-08-16 14:22:10 -070076 // set suffix of the name of the output
77 Suffix *string `android:"arch_variant"`
78
79 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +090080 Vendor, Product struct {
Colin Cross0fd6a412019-08-16 14:22:10 -070081 // set suffix of the name of the output
82 Suffix *string `android:"arch_variant"`
83 }
84 }
85
dimitryd95964a2018-11-07 13:43:34 +010086 // Names of modules to be overridden. Listed modules can only be other shared libraries
87 // (in Make or Soong).
88 // This does not completely prevent installation of the overridden libraries, but if both
89 // binaries would be installed by default (in PRODUCT_PACKAGES) the other library will be removed
90 // from PRODUCT_PACKAGES.
91 Overrides []string
Logan Chiene3d7a0d2019-01-17 00:18:02 +080092
93 // Properties for ABI compatibility checker
94 Header_abi_checker struct {
Logan Chien41eabe62019-04-10 13:33:58 +080095 // Enable ABI checks (even if this is not an LLNDK/VNDK lib)
96 Enabled *bool
97
Logan Chiene3d7a0d2019-01-17 00:18:02 +080098 // Path to a symbol file that specifies the symbols to be included in the generated
99 // ABI dump file
Colin Cross27b922f2019-03-04 22:35:41 -0800100 Symbol_file *string `android:"path"`
Logan Chiene3d7a0d2019-01-17 00:18:02 +0800101
102 // Symbol versions that should be ignored from the symbol file
103 Exclude_symbol_versions []string
104
105 // Symbol tags that should be ignored from the symbol file
106 Exclude_symbol_tags []string
Logan Chien2a65dda2019-10-01 15:58:07 -0700107
108 // Run checks on all APIs (in addition to the ones referred by
109 // one of exported ELF symbols.)
110 Check_all_apis *bool
Logan Chiene3d7a0d2019-01-17 00:18:02 +0800111 }
Vic Yang6cd1be82019-06-24 16:08:48 -0700112
113 // Order symbols in .bss section by their sizes. Only useful for shared libraries.
114 Sort_bss_symbols_by_size *bool
Pete Bentley803e1612019-08-06 22:19:59 +0100115
116 // Inject boringssl hash into the shared library. This is only intended for use by external/boringssl.
117 Inject_bssl_hash *bool `android:"arch_variant"`
Colin Cross0477b422020-10-13 18:43:54 -0700118
119 // If this is an LLNDK library, the name of the equivalent llndk_library module.
120 Llndk_stubs *string
Colin Cross127bb8b2020-12-16 16:46:01 -0800121
122 // If this is an LLNDK library, properties to describe the LLNDK stubs. Will be copied from
123 // the module pointed to by llndk_stubs if it is set.
124 Llndk llndkLibraryProperties
Colin Crossa48ab5b2017-02-14 15:28:44 -0800125}
Colin Cross0c461f12016-10-20 16:11:43 -0700126
Chris Parsons3c27ca32020-11-20 12:42:07 -0500127// StaticProperties is a properties stanza to affect only attributes of the "static" variants of a
128// library module.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700129type StaticProperties struct {
130 Static StaticOrSharedProperties `android:"arch_variant"`
131}
132
Chris Parsons3c27ca32020-11-20 12:42:07 -0500133// SharedProperties is a properties stanza to affect only attributes of the "shared" variants of a
134// library module.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700135type SharedProperties struct {
136 Shared StaticOrSharedProperties `android:"arch_variant"`
137}
138
Chris Parsons3c27ca32020-11-20 12:42:07 -0500139// StaticOrSharedProperties is an embedded struct representing properties to affect attributes of
140// either only the "static" variants or only the "shared" variants of a library module. These override
141// the base properties of the same name.
142// Use `StaticProperties` or `SharedProperties`, depending on which variant is needed.
143// `StaticOrSharedProperties` exists only to avoid duplication.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700144type StaticOrSharedProperties struct {
Evgenii Stepanov2080bfe2020-07-24 15:35:40 -0700145 Srcs []string `android:"path,arch_variant"`
146
147 Sanitized Sanitized `android:"arch_variant"`
148
Colin Crosse1bb5d02019-09-24 14:55:04 -0700149 Cflags []string `android:"arch_variant"`
150
151 Enabled *bool `android:"arch_variant"`
152 Whole_static_libs []string `android:"arch_variant"`
153 Static_libs []string `android:"arch_variant"`
154 Shared_libs []string `android:"arch_variant"`
155 System_shared_libs []string `android:"arch_variant"`
156
157 Export_shared_lib_headers []string `android:"arch_variant"`
158 Export_static_lib_headers []string `android:"arch_variant"`
Jiyong Parka90ca002019-10-07 15:47:24 +0900159
160 Apex_available []string `android:"arch_variant"`
Colin Crosse1bb5d02019-09-24 14:55:04 -0700161}
162
Colin Crossa48ab5b2017-02-14 15:28:44 -0800163type LibraryMutatedProperties struct {
Colin Crossb916a382016-07-29 17:28:03 -0700164 // Build a static variant
165 BuildStatic bool `blueprint:"mutated"`
166 // Build a shared variant
167 BuildShared bool `blueprint:"mutated"`
168 // This variant is shared
169 VariantIsShared bool `blueprint:"mutated"`
170 // This variant is static
171 VariantIsStatic bool `blueprint:"mutated"`
Jiyong Park7ed9de32018-10-15 22:25:07 +0900172
173 // This variant is a stubs lib
174 BuildStubs bool `blueprint:"mutated"`
Jiyong Parkd4a3a132021-03-17 20:21:35 +0900175 // This variant is the latest version
176 IsLatestVersion bool `blueprint:"mutated"`
Jiyong Park7ed9de32018-10-15 22:25:07 +0900177 // Version of the stubs lib
178 StubsVersion string `blueprint:"mutated"`
Colin Crossd1f898e2020-08-18 18:35:15 -0700179 // List of all stubs versions associated with an implementation lib
180 AllStubsVersions []string `blueprint:"mutated"`
Colin Crossb916a382016-07-29 17:28:03 -0700181}
182
183type FlagExporterProperties struct {
184 // list of directories relative to the Blueprints file that will
Dan Willemsen273af7f2016-11-03 15:53:42 -0700185 // be added to the include path (using -I) for this module and any module that links
Colin Cross5d195602017-10-17 16:15:50 -0700186 // against this module. Directories listed in export_include_dirs do not need to be
187 // listed in local_include_dirs.
Colin Crossb916a382016-07-29 17:28:03 -0700188 Export_include_dirs []string `android:"arch_variant"`
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700189
Jiyong Park73c54ee2019-10-22 20:31:18 +0900190 // list of directories that will be added to the system include path
191 // using -isystem for this module and any module that links against this module.
192 Export_system_include_dirs []string `android:"arch_variant"`
193
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700194 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +0900195 Vendor, Product struct {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700196 // list of exported include directories, like
Justin Yun63e9ec72020-10-29 16:49:43 +0900197 // export_include_dirs, that will be applied to
198 // vendor or product variant of this library.
199 // This will overwrite any other declarations.
Steven Morelandb21df8f2018-01-05 14:42:54 -0800200 Override_export_include_dirs []string
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700201 }
202 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700203}
204
205func init() {
Paul Duffin6c26dc72019-12-19 15:02:40 +0000206 RegisterLibraryBuildComponents(android.InitRegistrationContext)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +0000207
208 android.RegisterBp2BuildMutator("cc_library_static", CcLibraryStaticBp2Build)
Paul Duffin6c26dc72019-12-19 15:02:40 +0000209}
210
211func RegisterLibraryBuildComponents(ctx android.RegistrationContext) {
212 ctx.RegisterModuleType("cc_library_static", LibraryStaticFactory)
213 ctx.RegisterModuleType("cc_library_shared", LibrarySharedFactory)
214 ctx.RegisterModuleType("cc_library", LibraryFactory)
215 ctx.RegisterModuleType("cc_library_host_static", LibraryHostStaticFactory)
216 ctx.RegisterModuleType("cc_library_host_shared", LibraryHostSharedFactory)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700217}
218
Patrice Arruda83c89e02019-03-25 15:32:39 -0700219// cc_library creates both static and/or shared libraries for a device and/or
220// host. By default, a cc_library has a single variant that targets the device.
221// Specifying `host_supported: true` also creates a library that targets the
222// host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700223func LibraryFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800224 module, _ := NewLibrary(android.HostAndDeviceSupported)
Paul Duffina0843f62019-12-13 19:50:38 +0000225 // Can be used as both a static and a shared library.
226 module.sdkMemberTypes = []android.SdkMemberType{
227 sharedLibrarySdkMemberType,
228 staticLibrarySdkMemberType,
Paul Duffin9b76c0b2020-03-12 10:24:35 +0000229 staticAndSharedLibrarySdkMemberType,
Paul Duffina0843f62019-12-13 19:50:38 +0000230 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700231 return module.Init()
232}
233
Patrice Arruda83c89e02019-03-25 15:32:39 -0700234// cc_library_static creates a static library for a device and/or host binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700235func LibraryStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800236 module, library := NewLibrary(android.HostAndDeviceSupported)
237 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000238 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Chris Parsons808d84c2021-03-09 20:43:32 -0500239 module.bazelHandler = &staticLibraryBazelHandler{module: module}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700240 return module.Init()
241}
242
Patrice Arruda83c89e02019-03-25 15:32:39 -0700243// cc_library_shared creates a shared library for a device and/or host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700244func LibrarySharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800245 module, library := NewLibrary(android.HostAndDeviceSupported)
246 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000247 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700248 return module.Init()
249}
250
Patrice Arruda83c89e02019-03-25 15:32:39 -0700251// cc_library_host_static creates a static library that is linkable to a host
252// binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700253func LibraryHostStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800254 module, library := NewLibrary(android.HostSupported)
255 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000256 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700257 return module.Init()
258}
259
Patrice Arruda83c89e02019-03-25 15:32:39 -0700260// cc_library_host_shared creates a shared library that is usable on a host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700261func LibraryHostSharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800262 module, library := NewLibrary(android.HostSupported)
263 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000264 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700265 return module.Init()
266}
267
Chris Parsons3c27ca32020-11-20 12:42:07 -0500268// flagExporter is a separated portion of libraryDecorator pertaining to exported
269// include paths and flags. Keeping this dependency-related information separate
270// from the rest of library information is helpful in keeping data more structured
271// and explicit.
Colin Cross4d9c2d12016-07-29 12:48:20 -0700272type flagExporter struct {
273 Properties FlagExporterProperties
274
Chris Parsons3c27ca32020-11-20 12:42:07 -0500275 dirs android.Paths // Include directories to be included with -I
276 systemDirs android.Paths // System include directories to be included with -isystem
277 flags []string // Exported raw flags.
Inseob Kim69378442019-06-03 19:10:47 +0900278 deps android.Paths
Inseob Kimd110f872019-12-06 13:15:38 +0900279 headers android.Paths
Colin Cross4d9c2d12016-07-29 12:48:20 -0700280}
281
Chris Parsons3c27ca32020-11-20 12:42:07 -0500282// exportedIncludes returns the effective include paths for this module and
283// any module that links against this module. This is obtained from
284// the export_include_dirs property in the appropriate target stanza.
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700285func (f *flagExporter) exportedIncludes(ctx ModuleContext) android.Paths {
Justin Yun6977e8a2020-10-29 18:24:11 +0900286 if ctx.inVendor() && f.Properties.Target.Vendor.Override_export_include_dirs != nil {
Steven Morelandb21df8f2018-01-05 14:42:54 -0800287 return android.PathsForModuleSrc(ctx, f.Properties.Target.Vendor.Override_export_include_dirs)
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700288 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900289 if ctx.inProduct() && f.Properties.Target.Product.Override_export_include_dirs != nil {
290 return android.PathsForModuleSrc(ctx, f.Properties.Target.Product.Override_export_include_dirs)
291 }
292 return android.PathsForModuleSrc(ctx, f.Properties.Export_include_dirs)
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700293}
294
Chris Parsons3c27ca32020-11-20 12:42:07 -0500295// exportIncludes registers the include directories and system include directories to be exported
296// transitively to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900297func (f *flagExporter) exportIncludes(ctx ModuleContext) {
Jiyong Park74955042019-10-22 20:19:51 +0900298 f.dirs = append(f.dirs, 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)...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700300}
301
Chris Parsons3c27ca32020-11-20 12:42:07 -0500302// exportIncludesAsSystem registers the include directories and system include directories to be
303// exported transitively both as system include directories to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900304func (f *flagExporter) exportIncludesAsSystem(ctx ModuleContext) {
Jiyong Park73c54ee2019-10-22 20:31:18 +0900305 // all dirs are force exported as system
Jiyong Park74955042019-10-22 20:19:51 +0900306 f.systemDirs = append(f.systemDirs, f.exportedIncludes(ctx)...)
Jiyong Park73c54ee2019-10-22 20:31:18 +0900307 f.systemDirs = append(f.systemDirs, android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)...)
Inseob Kim69378442019-06-03 19:10:47 +0900308}
309
Chris Parsons3c27ca32020-11-20 12:42:07 -0500310// reexportDirs registers the given directories as include directories to be exported transitively
311// to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900312func (f *flagExporter) reexportDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900313 f.dirs = append(f.dirs, dirs...)
314}
315
Chris Parsons3c27ca32020-11-20 12:42:07 -0500316// reexportSystemDirs registers the given directories as system include directories
317// to be exported transitively to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900318func (f *flagExporter) reexportSystemDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900319 f.systemDirs = append(f.systemDirs, dirs...)
320}
321
Chris Parsons3c27ca32020-11-20 12:42:07 -0500322// reexportFlags registers the flags to be exported transitively to modules depending on this
323// module.
Inseob Kim69378442019-06-03 19:10:47 +0900324func (f *flagExporter) reexportFlags(flags ...string) {
Jaewoong Jung3aff5782020-02-11 07:54:35 -0800325 if android.PrefixInList(flags, "-I") || android.PrefixInList(flags, "-isystem") {
326 panic(fmt.Errorf("Exporting invalid flag %q: "+
327 "use reexportDirs or reexportSystemDirs to export directories", flag))
Inseob Kim69378442019-06-03 19:10:47 +0900328 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700329 f.flags = append(f.flags, flags...)
330}
331
Inseob Kim69378442019-06-03 19:10:47 +0900332func (f *flagExporter) reexportDeps(deps ...android.Path) {
333 f.deps = append(f.deps, deps...)
334}
335
Inseob Kimd110f872019-12-06 13:15:38 +0900336// addExportedGeneratedHeaders does nothing but collects generated header files.
337// This can be differ to exportedDeps which may contain phony files to minimize ninja.
338func (f *flagExporter) addExportedGeneratedHeaders(headers ...android.Path) {
339 f.headers = append(f.headers, headers...)
340}
341
Colin Cross0de8a1e2020-09-18 14:15:30 -0700342func (f *flagExporter) setProvider(ctx android.ModuleContext) {
343 ctx.SetProvider(FlagExporterInfoProvider, FlagExporterInfo{
344 IncludeDirs: f.dirs,
345 SystemIncludeDirs: f.systemDirs,
346 Flags: f.flags,
347 Deps: f.deps,
348 GeneratedHeaders: f.headers,
349 })
Inseob Kim69378442019-06-03 19:10:47 +0900350}
351
Colin Crossb916a382016-07-29 17:28:03 -0700352// libraryDecorator wraps baseCompiler, baseLinker and baseInstaller to provide library-specific
353// functionality: static vs. shared linkage, reusing object files for shared libraries
354type libraryDecorator struct {
Colin Crossa48ab5b2017-02-14 15:28:44 -0800355 Properties LibraryProperties
Colin Crosse1bb5d02019-09-24 14:55:04 -0700356 StaticProperties StaticProperties
357 SharedProperties SharedProperties
Colin Crossa48ab5b2017-02-14 15:28:44 -0800358 MutatedProperties LibraryMutatedProperties
Colin Cross4d9c2d12016-07-29 12:48:20 -0700359
360 // For reusing static library objects for shared library
Inseob Kim69378442019-06-03 19:10:47 +0900361 reuseObjects Objects
Colin Cross10d22312017-05-03 11:01:58 -0700362
Colin Cross26c34ed2016-09-30 17:10:16 -0700363 // table-of-contents file to optimize out relinking when possible
364 tocFile android.OptionalPath
Colin Cross4d9c2d12016-07-29 12:48:20 -0700365
Colin Cross4d9c2d12016-07-29 12:48:20 -0700366 flagExporter
Thiébaud Weksteend4587452020-08-19 14:53:01 +0200367 stripper Stripper
Colin Cross4d9c2d12016-07-29 12:48:20 -0700368
Colin Cross4d9c2d12016-07-29 12:48:20 -0700369 // For whole_static_libs
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700370 objects Objects
Colin Cross4d9c2d12016-07-29 12:48:20 -0700371
372 // Uses the module's name if empty, but can be overridden. Does not include
373 // shlib suffix.
374 libName string
Colin Crossb916a382016-07-29 17:28:03 -0700375
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800376 sabi *sabi
377
Dan Willemsen581341d2017-02-09 16:16:31 -0800378 // Output archive of gcno coverage information files
379 coverageOutputFile android.OptionalPath
380
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800381 // linked Source Abi Dump
382 sAbiOutputFile android.OptionalPath
383
384 // Source Abi Diff
385 sAbiDiff android.OptionalPath
386
Colin Cross0875c522017-11-28 17:34:01 -0800387 // Location of the static library in the sysroot. Empty if the library is
388 // not included in the NDK.
389 ndkSysrootPath android.Path
390
Colin Crossb60190a2018-09-04 16:28:17 -0700391 // Location of the linked, unstripped library for shared libraries
392 unstrippedOutputFile android.Path
393
Dan Willemsen569edc52018-11-19 09:33:29 -0800394 // Location of the file that should be copied to dist dir when requested
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000395 distFile android.Path
Dan Willemsen569edc52018-11-19 09:33:29 -0800396
Colin Cross8e21aa52020-09-28 18:28:02 -0700397 versionScriptPath android.OptionalPath
Jiyong Park7ed9de32018-10-15 22:25:07 +0900398
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800399 postInstallCmds []string
Jiyong Parkf1194352019-02-25 11:05:47 +0900400
Vic Yangefd249e2018-11-12 20:19:56 -0800401 // If useCoreVariant is true, the vendor variant of a VNDK library is
402 // not installed.
Vic Yangd92090f2020-01-08 14:32:28 -0800403 useCoreVariant bool
404 checkSameCoreVariant bool
Vic Yangefd249e2018-11-12 20:19:56 -0800405
Colin Cross5ec407b2020-09-30 11:41:33 -0700406 skipAPIDefine bool
407
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100408 // Decorated interfaces
Colin Crossb916a382016-07-29 17:28:03 -0700409 *baseCompiler
410 *baseLinker
411 *baseInstaller
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900412
413 collectedSnapshotHeaders android.Paths
414}
415
Chris Parsons808d84c2021-03-09 20:43:32 -0500416type staticLibraryBazelHandler struct {
417 bazelHandler
418
419 module *Module
420}
421
422func (handler *staticLibraryBazelHandler) generateBazelBuildActions(ctx android.ModuleContext, label string) bool {
423 bazelCtx := ctx.Config().BazelContext
Chris Parsons944e7d02021-03-11 11:08:46 -0500424 outputPaths, objPaths, ok := bazelCtx.GetOutputFilesAndCcObjectFiles(label, ctx.Arch().ArchType)
425 if !ok {
426 return ok
Chris Parsons808d84c2021-03-09 20:43:32 -0500427 }
Chris Parsonseefc9e62021-04-02 17:36:47 -0400428 if len(outputPaths) > 1 {
Chris Parsons944e7d02021-03-11 11:08:46 -0500429 // TODO(cparsons): This is actually expected behavior for static libraries with no srcs.
430 // We should support this.
Chris Parsonseefc9e62021-04-02 17:36:47 -0400431 ctx.ModuleErrorf("expected at most one output file for '%s', but got %s", label, objPaths)
Chris Parsons944e7d02021-03-11 11:08:46 -0500432 return false
Chris Parsonseefc9e62021-04-02 17:36:47 -0400433 } else if len(outputPaths) == 0 {
434 handler.module.outputFile = android.OptionalPath{}
435 return true
Chris Parsons944e7d02021-03-11 11:08:46 -0500436 }
437 outputFilePath := android.PathForBazelOut(ctx, outputPaths[0])
438 handler.module.outputFile = android.OptionalPathForPath(outputFilePath)
439
440 objFiles := make(android.Paths, len(objPaths))
441 for i, objPath := range objPaths {
442 objFiles[i] = android.PathForBazelOut(ctx, objPath)
443 }
444 objects := Objects{
445 objFiles: objFiles,
446 }
447
448 ctx.SetProvider(StaticLibraryInfoProvider, StaticLibraryInfo{
449 StaticLibrary: outputFilePath,
450 ReuseObjects: objects,
451 Objects: objects,
452
453 // TODO(cparsons): Include transitive static libraries in this provider to support
454 // static libraries with deps.
455 TransitiveStaticLibrariesForOrdering: android.NewDepSetBuilder(android.TOPOLOGICAL).
456 Direct(outputFilePath).
457 Build(),
458 })
Chris Parsonseefc9e62021-04-02 17:36:47 -0400459 if i, ok := handler.module.linker.(snapshotLibraryInterface); ok {
460 // Dependencies on this library will expect collectedSnapshotHeaders to
461 // be set, otherwise validation will fail. For now, set this to an empty
462 // list.
463 // TODO(cparsons): More closely mirror the collectHeadersForSnapshot
464 // implementation.
465 i.(*libraryDecorator).collectedSnapshotHeaders = android.Paths{}
466 }
467
Chris Parsons808d84c2021-03-09 20:43:32 -0500468 return ok
469}
470
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900471// collectHeadersForSnapshot collects all exported headers from library.
472// It globs header files in the source tree for exported include directories,
473// and tracks generated header files separately.
474//
475// This is to be called from GenerateAndroidBuildActions, and then collected
476// header files can be retrieved by snapshotHeaders().
477func (l *libraryDecorator) collectHeadersForSnapshot(ctx android.ModuleContext) {
478 ret := android.Paths{}
479
480 // Headers in the source tree should be globbed. On the contrast, generated headers
481 // can't be globbed, and they should be manually collected.
482 // So, we first filter out intermediate directories (which contains generated headers)
483 // from exported directories, and then glob headers under remaining directories.
Colin Cross0de8a1e2020-09-18 14:15:30 -0700484 for _, path := range append(android.CopyOfPaths(l.flagExporter.dirs), l.flagExporter.systemDirs...) {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900485 dir := path.String()
486 // Skip if dir is for generated headers
487 if strings.HasPrefix(dir, android.PathForOutput(ctx).String()) {
488 continue
489 }
Inseob Kim04f2d6a2020-05-29 22:30:58 +0900490 // libeigen wrongly exports the root directory "external/eigen". But only two
491 // subdirectories "Eigen" and "unsupported" contain exported header files. Even worse
492 // some of them have no extension. So we need special treatment for libeigen in order
493 // to glob correctly.
494 if dir == "external/eigen" {
495 // Only these two directories contains exported headers.
496 for _, subdir := range []string{"Eigen", "unsupported/Eigen"} {
497 glob, err := ctx.GlobWithDeps("external/eigen/"+subdir+"/**/*", nil)
498 if err != nil {
499 ctx.ModuleErrorf("glob failed: %#v", err)
500 return
501 }
502 for _, header := range glob {
503 if strings.HasSuffix(header, "/") {
504 continue
505 }
506 ext := filepath.Ext(header)
507 if ext != "" && ext != ".h" {
508 continue
509 }
510 ret = append(ret, android.PathForSource(ctx, header))
511 }
512 }
513 continue
514 }
Colin Crossec118d02021-01-22 18:05:59 +0000515 glob, err := ctx.GlobWithDeps(dir+"/**/*", nil)
516 if err != nil {
517 ctx.ModuleErrorf("glob failed: %#v", err)
518 return
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900519 }
Colin Crossec118d02021-01-22 18:05:59 +0000520 isLibcxx := strings.HasPrefix(dir, "external/libcxx/include")
Jose Galmes0d736912021-03-30 11:00:06 -0700521 for _, header := range glob {
Colin Crossec118d02021-01-22 18:05:59 +0000522 if isLibcxx {
523 // Glob all files under this special directory, because of C++ headers with no
524 // extension.
Jose Galmes0d736912021-03-30 11:00:06 -0700525 if strings.HasSuffix(header, "/") {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900526 continue
527 }
Colin Crossec118d02021-01-22 18:05:59 +0000528 } else {
529 // Filter out only the files with extensions that are headers.
530 found := false
531 for _, ext := range headerExts {
532 if strings.HasSuffix(header, ext) {
533 found = true
534 break
535 }
536 }
537 if !found {
538 continue
539 }
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900540 }
Jose Galmes0d736912021-03-30 11:00:06 -0700541 ret = append(ret, android.PathForSource(ctx, header))
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900542 }
543 }
544
545 // Collect generated headers
Colin Cross0de8a1e2020-09-18 14:15:30 -0700546 for _, header := range append(android.CopyOfPaths(l.flagExporter.headers), l.flagExporter.deps...) {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900547 // TODO(b/148123511): remove exportedDeps after cleaning up genrule
548 if strings.HasSuffix(header.Base(), "-phony") {
549 continue
550 }
551 ret = append(ret, header)
552 }
553
554 l.collectedSnapshotHeaders = ret
555}
556
557// This returns all exported header files, both generated ones and headers from source tree.
558// collectHeadersForSnapshot() must be called before calling this.
559func (l *libraryDecorator) snapshotHeaders() android.Paths {
560 if l.collectedSnapshotHeaders == nil {
561 panic("snapshotHeaders() must be called after collectHeadersForSnapshot()")
562 }
563 return l.collectedSnapshotHeaders
Colin Cross4d9c2d12016-07-29 12:48:20 -0700564}
565
Chris Parsons3c27ca32020-11-20 12:42:07 -0500566// linkerProps returns the list of properties structs relevant for this library. (For example, if
567// the library is cc_shared_library, then static-library properties are omitted.)
Colin Crossb916a382016-07-29 17:28:03 -0700568func (library *libraryDecorator) linkerProps() []interface{} {
569 var props []interface{}
570 props = append(props, library.baseLinker.linkerProps()...)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700571 props = append(props,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700572 &library.Properties,
Colin Crossa48ab5b2017-02-14 15:28:44 -0800573 &library.MutatedProperties,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700574 &library.flagExporter.Properties,
Colin Cross22f37952018-09-05 10:43:13 -0700575 &library.stripper.StripProperties)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700576
577 if library.MutatedProperties.BuildShared {
578 props = append(props, &library.SharedProperties)
579 }
580 if library.MutatedProperties.BuildStatic {
581 props = append(props, &library.StaticProperties)
582 }
583
584 return props
Colin Cross4d9c2d12016-07-29 12:48:20 -0700585}
586
Chris Parsons3c27ca32020-11-20 12:42:07 -0500587// linkerFlags takes a Flags struct and augments it to contain linker flags that are defined by this
588// library, or that are implied by attributes of this library (such as whether this library is a
589// shared library).
Colin Crossb916a382016-07-29 17:28:03 -0700590func (library *libraryDecorator) linkerFlags(ctx ModuleContext, flags Flags) Flags {
Colin Cross42742b82016-08-01 13:20:05 -0700591 flags = library.baseLinker.linkerFlags(ctx, flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700592
Colin Crossb916a382016-07-29 17:28:03 -0700593 // MinGW spits out warnings about -fPIC even for -fpie?!) being ignored because
594 // all code is position independent, and then those warnings get promoted to
595 // errors.
Colin Cross3edeee12017-04-04 12:59:48 -0700596 if !ctx.Windows() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800597 flags.Global.CFlags = append(flags.Global.CFlags, "-fPIC")
Colin Crossb916a382016-07-29 17:28:03 -0700598 }
599
600 if library.static() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800601 flags.Local.CFlags = append(flags.Local.CFlags, library.StaticProperties.Static.Cflags...)
Colin Crossa48ab5b2017-02-14 15:28:44 -0800602 } else if library.shared() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800603 flags.Local.CFlags = append(flags.Local.CFlags, library.SharedProperties.Shared.Cflags...)
Colin Crossb916a382016-07-29 17:28:03 -0700604 }
605
Colin Crossa48ab5b2017-02-14 15:28:44 -0800606 if library.shared() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700607 libName := library.getLibName(ctx)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700608 var f []string
Dan Willemsen01a405a2016-06-13 17:19:03 -0700609 if ctx.toolchain().Bionic() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700610 f = append(f,
611 "-nostdlib",
612 "-Wl,--gc-sections",
613 )
614 }
615
616 if ctx.Darwin() {
617 f = append(f,
618 "-dynamiclib",
619 "-single_module",
Colin Cross4d9c2d12016-07-29 12:48:20 -0700620 "-install_name @rpath/"+libName+flags.Toolchain.ShlibSuffix(),
621 )
Colin Cross7863cf52016-10-20 10:47:21 -0700622 if ctx.Arch().ArchType == android.X86 {
623 f = append(f,
624 "-read_only_relocs suppress",
625 )
626 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700627 } else {
Josh Gao75a50a22019-06-07 17:58:59 -0700628 f = append(f, "-shared")
629 if !ctx.Windows() {
630 f = append(f, "-Wl,-soname,"+libName+flags.Toolchain.ShlibSuffix())
631 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700632 }
633
Colin Cross4af21ed2019-11-04 09:37:55 -0800634 flags.Global.LdFlags = append(flags.Global.LdFlags, f...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700635 }
636
637 return flags
638}
639
Chris Parsons3c27ca32020-11-20 12:42:07 -0500640// compilerFlags takes a Flags and augments it to contain compile flags from global values,
641// per-target values, module type values, per-module Blueprints properties, extra flags from
642// `flags`, and generated sources from `deps`.
Colin Crossf18e1102017-11-16 14:33:08 -0800643func (library *libraryDecorator) compilerFlags(ctx ModuleContext, flags Flags, deps PathDeps) Flags {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700644 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700645 if len(exportIncludeDirs) > 0 {
Colin Crossdad8c952017-04-26 14:55:27 -0700646 f := includeDirsToFlags(exportIncludeDirs)
Colin Cross4af21ed2019-11-04 09:37:55 -0800647 flags.Local.CommonFlags = append(flags.Local.CommonFlags, f)
648 flags.Local.YasmFlags = append(flags.Local.YasmFlags, f)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700649 }
650
Jiyong Park7ed9de32018-10-15 22:25:07 +0900651 flags = library.baseCompiler.compilerFlags(ctx, flags, deps)
Colin Cross127bb8b2020-12-16 16:46:01 -0800652 if ctx.IsLlndk() {
653 // LLNDK libraries ignore most of the properties on the cc_library and use the
654 // LLNDK-specific properties instead.
655 // Wipe all the module-local properties, leaving only the global properties.
656 flags.Local = LocalOrGlobalFlags{}
657 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900658 if library.buildStubs() {
Jiyong Park64379952018-12-13 18:37:29 +0900659 // Remove -include <file> when compiling stubs. Otherwise, the force included
660 // headers might cause conflicting types error with the symbols in the
661 // generated stubs source code. e.g.
662 // double acos(double); // in header
663 // void acos() {} // in the generated source code
664 removeInclude := func(flags []string) []string {
665 ret := flags[:0]
666 for _, f := range flags {
667 if strings.HasPrefix(f, "-include ") {
668 continue
669 }
670 ret = append(ret, f)
671 }
672 return ret
673 }
Colin Cross4af21ed2019-11-04 09:37:55 -0800674 flags.Local.CommonFlags = removeInclude(flags.Local.CommonFlags)
675 flags.Local.CFlags = removeInclude(flags.Local.CFlags)
Jiyong Park64379952018-12-13 18:37:29 +0900676
Jiyong Park7ed9de32018-10-15 22:25:07 +0900677 flags = addStubLibraryCompilerFlags(flags)
678 }
679 return flags
Dan Willemsen273af7f2016-11-03 15:53:42 -0700680}
681
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800682func (library *libraryDecorator) headerAbiCheckerEnabled() bool {
683 return Bool(library.Properties.Header_abi_checker.Enabled)
Hsin-Yi Chen53489642019-07-31 17:10:45 +0800684}
685
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800686func (library *libraryDecorator) headerAbiCheckerExplicitlyDisabled() bool {
687 return !BoolDefault(library.Properties.Header_abi_checker.Enabled, true)
Logan Chien41eabe62019-04-10 13:33:58 +0800688}
689
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700690func (library *libraryDecorator) compile(ctx ModuleContext, flags Flags, deps PathDeps) Objects {
Colin Cross127bb8b2020-12-16 16:46:01 -0800691 if ctx.IsLlndk() {
692 // This is the vendor variant of an LLNDK library, build the LLNDK stubs.
693 vndkVer := ctx.Module().(*Module).VndkVersion()
694 if !inList(vndkVer, ctx.Config().PlatformVersionActiveCodenames()) || vndkVer == "" {
695 // For non-enforcing devices, vndkVer is empty. Use "current" in that case, too.
696 vndkVer = "current"
697 }
698 if library.stubsVersion() != "" {
699 vndkVer = library.stubsVersion()
700 }
701 objs, versionScript := compileStubLibrary(ctx, flags, String(library.Properties.Llndk.Symbol_file), vndkVer, "--llndk")
702 if !Bool(library.Properties.Llndk.Unversioned) {
703 library.versionScriptPath = android.OptionalPathForPath(versionScript)
704 }
705 return objs
706 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900707 if library.buildStubs() {
Jiyong Parka4175572021-02-04 21:05:47 +0900708 symbolFile := String(library.Properties.Stubs.Symbol_file)
709 if symbolFile != "" && !strings.HasSuffix(symbolFile, ".map.txt") {
710 ctx.PropertyErrorf("symbol_file", "%q doesn't have .map.txt suffix", symbolFile)
711 return Objects{}
712 }
Jiyong Park3fd0baf2018-12-07 16:25:39 +0900713 objs, versionScript := compileStubLibrary(ctx, flags, String(library.Properties.Stubs.Symbol_file), library.MutatedProperties.StubsVersion, "--apex")
Colin Cross8e21aa52020-09-28 18:28:02 -0700714 library.versionScriptPath = android.OptionalPathForPath(versionScript)
Jiyong Park7ed9de32018-10-15 22:25:07 +0900715 return objs
716 }
717
Colin Cross5950f382016-12-13 12:50:57 -0800718 if !library.buildShared() && !library.buildStatic() {
719 if len(library.baseCompiler.Properties.Srcs) > 0 {
720 ctx.PropertyErrorf("srcs", "cc_library_headers must not have any srcs")
721 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700722 if len(library.StaticProperties.Static.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800723 ctx.PropertyErrorf("static.srcs", "cc_library_headers must not have any srcs")
724 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700725 if len(library.SharedProperties.Shared.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800726 ctx.PropertyErrorf("shared.srcs", "cc_library_headers must not have any srcs")
727 }
728 return Objects{}
729 }
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800730 if library.sabi.shouldCreateSourceAbiDump() {
Jayant Chowdharya4fce192017-09-06 13:10:03 -0700731 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800732 var SourceAbiFlags []string
733 for _, dir := range exportIncludeDirs.Strings() {
Jayant Chowdhary715cac32017-04-20 06:53:59 -0700734 SourceAbiFlags = append(SourceAbiFlags, "-I"+dir)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800735 }
Inseob Kim69378442019-06-03 19:10:47 +0900736 for _, reexportedInclude := range library.sabi.Properties.ReexportedIncludes {
737 SourceAbiFlags = append(SourceAbiFlags, "-I"+reexportedInclude)
Jayant Chowdhary715cac32017-04-20 06:53:59 -0700738 }
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800739 flags.SAbiFlags = SourceAbiFlags
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800740 totalLength := len(library.baseCompiler.Properties.Srcs) + len(deps.GeneratedSources) +
Colin Crosse1bb5d02019-09-24 14:55:04 -0700741 len(library.SharedProperties.Shared.Srcs) + len(library.StaticProperties.Static.Srcs)
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800742 if totalLength > 0 {
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800743 flags.SAbiDump = true
744 }
745 }
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700746 objs := library.baseCompiler.compile(ctx, flags, deps)
747 library.reuseObjects = objs
Colin Cross2f336352016-10-26 10:03:47 -0700748 buildFlags := flagsToBuilderFlags(flags)
Colin Crossb916a382016-07-29 17:28:03 -0700749
Colin Cross4d9c2d12016-07-29 12:48:20 -0700750 if library.static() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700751 srcs := android.PathsForModuleSrc(ctx, library.StaticProperties.Static.Srcs)
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700752 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceStaticLibrary,
Pirama Arumuga Nainarf231b192018-01-23 10:49:04 -0800753 srcs, library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossa48ab5b2017-02-14 15:28:44 -0800754 } else if library.shared() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700755 srcs := android.PathsForModuleSrc(ctx, library.SharedProperties.Shared.Srcs)
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700756 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceSharedLibrary,
Pirama Arumuga Nainarf231b192018-01-23 10:49:04 -0800757 srcs, library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossb916a382016-07-29 17:28:03 -0700758 }
759
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700760 return objs
Colin Crossb916a382016-07-29 17:28:03 -0700761}
762
763type libraryInterface interface {
Colin Cross3572cf72020-10-01 15:58:11 -0700764 versionedInterface
765
Colin Crossb916a382016-07-29 17:28:03 -0700766 static() bool
Inseob Kimae553032019-05-14 18:52:49 +0900767 shared() bool
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700768 objs() Objects
Colin Cross0de8a1e2020-09-18 14:15:30 -0700769 reuseObjs() Objects
Colin Cross26c34ed2016-09-30 17:10:16 -0700770 toc() android.OptionalPath
Colin Crossb916a382016-07-29 17:28:03 -0700771
772 // Returns true if the build options for the module have selected a static or shared build
773 buildStatic() bool
774 buildShared() bool
775
776 // Sets whether a specific variant is static or shared
Colin Crossa48ab5b2017-02-14 15:28:44 -0800777 setStatic()
778 setShared()
Logan Chien41eabe62019-04-10 13:33:58 +0800779
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800780 // Check whether header_abi_checker is enabled or explicitly disabled.
781 headerAbiCheckerEnabled() bool
782 headerAbiCheckerExplicitlyDisabled() bool
783
Logan Chien41eabe62019-04-10 13:33:58 +0800784 // Write LOCAL_ADDITIONAL_DEPENDENCIES for ABI diff
785 androidMkWriteAdditionalDependenciesForSourceAbiDiff(w io.Writer)
Jiyong Parka90ca002019-10-07 15:47:24 +0900786
787 availableFor(string) bool
Colin Crossb916a382016-07-29 17:28:03 -0700788}
789
Colin Crossc88c2722020-09-28 17:32:47 -0700790type versionedInterface interface {
791 buildStubs() bool
Jiyong Parkd4a3a132021-03-17 20:21:35 +0900792 setBuildStubs(isLatest bool)
Colin Crossc88c2722020-09-28 17:32:47 -0700793 hasStubsVariants() bool
794 setStubsVersion(string)
795 stubsVersion() string
796
Colin Cross3572cf72020-10-01 15:58:11 -0700797 stubsVersions(ctx android.BaseMutatorContext) []string
Colin Crossc88c2722020-09-28 17:32:47 -0700798 setAllStubsVersions([]string)
799 allStubsVersions() []string
Colin Cross0477b422020-10-13 18:43:54 -0700800
801 implementationModuleName(name string) string
Colin Cross127bb8b2020-12-16 16:46:01 -0800802 hasLLNDKStubs() bool
Colin Crossc88c2722020-09-28 17:32:47 -0700803}
804
805var _ libraryInterface = (*libraryDecorator)(nil)
806var _ versionedInterface = (*libraryDecorator)(nil)
807
Justin Yun6977e8a2020-10-29 18:24:11 +0900808func (library *libraryDecorator) getLibNameHelper(baseModuleName string, inVendor bool, inProduct bool) string {
Colin Crossb916a382016-07-29 17:28:03 -0700809 name := library.libName
810 if name == "" {
dimitryd95964a2018-11-07 13:43:34 +0100811 name = String(library.Properties.Stem)
812 if name == "" {
Jooyung Han0302a842019-10-30 18:43:49 +0900813 name = baseModuleName
dimitryd95964a2018-11-07 13:43:34 +0100814 }
Colin Crossb916a382016-07-29 17:28:03 -0700815 }
816
Colin Cross0fd6a412019-08-16 14:22:10 -0700817 suffix := ""
Justin Yun6977e8a2020-10-29 18:24:11 +0900818 if inVendor {
Colin Cross0fd6a412019-08-16 14:22:10 -0700819 suffix = String(library.Properties.Target.Vendor.Suffix)
Justin Yun6977e8a2020-10-29 18:24:11 +0900820 } else if inProduct {
821 suffix = String(library.Properties.Target.Product.Suffix)
Colin Cross0fd6a412019-08-16 14:22:10 -0700822 }
823 if suffix == "" {
824 suffix = String(library.Properties.Suffix)
825 }
826
Jooyung Han0302a842019-10-30 18:43:49 +0900827 return name + suffix
828}
829
Chris Parsons3c27ca32020-11-20 12:42:07 -0500830// getLibName returns the actual canonical name of the library (the name which
831// should be passed to the linker via linker flags).
Jooyung Han0302a842019-10-30 18:43:49 +0900832func (library *libraryDecorator) getLibName(ctx BaseModuleContext) string {
Justin Yun6977e8a2020-10-29 18:24:11 +0900833 name := library.getLibNameHelper(ctx.baseModuleName(), ctx.inVendor(), ctx.inProduct())
Colin Cross0fd6a412019-08-16 14:22:10 -0700834
Ivan Lozanof9e21722020-12-02 09:00:51 -0500835 if ctx.IsVndkExt() {
Jooyung Han4c2b9422019-10-22 19:53:47 +0900836 // vndk-ext lib should have the same name with original lib
837 ctx.VisitDirectDepsWithTag(vndkExtDepTag, func(module android.Module) {
838 originalName := module.(*Module).outputFile.Path()
839 name = strings.TrimSuffix(originalName.Base(), originalName.Ext())
840 })
Logan Chienf3511742017-10-31 18:04:35 +0800841 }
842
Colin Crossb916a382016-07-29 17:28:03 -0700843 if ctx.Host() && Bool(library.Properties.Unique_host_soname) {
844 if !strings.HasSuffix(name, "-host") {
845 name = name + "-host"
846 }
847 }
848
Inseob Kim0ce291e2019-07-04 14:38:27 +0900849 return name
Colin Crossb916a382016-07-29 17:28:03 -0700850}
851
Jiyong Parkda732bd2018-11-02 18:23:15 +0900852var versioningMacroNamesListMutex sync.Mutex
853
Colin Crossb916a382016-07-29 17:28:03 -0700854func (library *libraryDecorator) linkerInit(ctx BaseModuleContext) {
855 location := InstallInSystem
Dan Albert61f32122018-07-26 14:00:24 -0700856 if library.baseLinker.sanitize.inSanitizerDir() {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700857 location = InstallInSanitizerDir
Colin Crossb916a382016-07-29 17:28:03 -0700858 }
859 library.baseInstaller.location = location
Colin Crossb916a382016-07-29 17:28:03 -0700860 library.baseLinker.linkerInit(ctx)
Jiyong Park7ed9de32018-10-15 22:25:07 +0900861 // Let baseLinker know whether this variant is for stubs or not, so that
862 // it can omit things that are not required for linking stubs.
863 library.baseLinker.dynamicProperties.BuildStubs = library.buildStubs()
Jiyong Parkda732bd2018-11-02 18:23:15 +0900864
865 if library.buildStubs() {
866 macroNames := versioningMacroNamesList(ctx.Config())
867 myName := versioningMacroName(ctx.ModuleName())
868 versioningMacroNamesListMutex.Lock()
869 defer versioningMacroNamesListMutex.Unlock()
870 if (*macroNames)[myName] == "" {
871 (*macroNames)[myName] = ctx.ModuleName()
872 } else if (*macroNames)[myName] != ctx.ModuleName() {
873 ctx.ModuleErrorf("Macro name %q for versioning conflicts with macro name from module %q ", myName, (*macroNames)[myName])
874 }
875 }
Colin Crossb916a382016-07-29 17:28:03 -0700876}
877
dimitry0345ad82018-12-05 16:28:14 +0100878func (library *libraryDecorator) compilerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800879 if ctx.IsLlndk() {
880 // LLNDK libraries ignore most of the properties on the cc_library and use the
881 // LLNDK-specific properties instead.
882 return deps
883 }
884
dimitry0345ad82018-12-05 16:28:14 +0100885 deps = library.baseCompiler.compilerDeps(ctx, deps)
886
dimitry0345ad82018-12-05 16:28:14 +0100887 return deps
888}
889
Colin Cross37047f12016-12-13 17:06:13 -0800890func (library *libraryDecorator) linkerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800891 if ctx.IsLlndk() {
892 // LLNDK libraries ignore most of the properties on the cc_library and use the
893 // LLNDK-specific properties instead.
894 deps.HeaderLibs = append(deps.HeaderLibs, library.Properties.Llndk.Export_llndk_headers...)
895 deps.ReexportHeaderLibHeaders = append(deps.ReexportHeaderLibHeaders,
896 library.Properties.Llndk.Export_llndk_headers...)
897 return deps
898 }
899
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800900 if library.static() {
Martin Stjernholm10566a02020-03-24 01:19:52 +0000901 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700902 if library.StaticProperties.Static.System_shared_libs != nil {
903 library.baseLinker.Properties.System_shared_libs = library.StaticProperties.Static.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800904 }
905 } else if library.shared() {
Martin Stjernholm10566a02020-03-24 01:19:52 +0000906 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700907 if library.SharedProperties.Shared.System_shared_libs != nil {
908 library.baseLinker.Properties.System_shared_libs = library.SharedProperties.Shared.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800909 }
910 }
911
Colin Crossb916a382016-07-29 17:28:03 -0700912 deps = library.baseLinker.linkerDeps(ctx, deps)
913
914 if library.static() {
915 deps.WholeStaticLibs = append(deps.WholeStaticLibs,
Colin Crosse1bb5d02019-09-24 14:55:04 -0700916 library.StaticProperties.Static.Whole_static_libs...)
917 deps.StaticLibs = append(deps.StaticLibs, library.StaticProperties.Static.Static_libs...)
918 deps.SharedLibs = append(deps.SharedLibs, library.StaticProperties.Static.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -0800919
Colin Crosse1bb5d02019-09-24 14:55:04 -0700920 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.StaticProperties.Static.Export_shared_lib_headers...)
921 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.StaticProperties.Static.Export_static_lib_headers...)
Colin Crossa48ab5b2017-02-14 15:28:44 -0800922 } else if library.shared() {
Dan Willemsen2e47b342016-11-17 01:02:25 -0800923 if ctx.toolchain().Bionic() && !Bool(library.baseLinker.Properties.Nocrt) {
Dan Albert92fe7402020-07-15 13:33:30 -0700924 deps.CrtBegin = "crtbegin_so"
925 deps.CrtEnd = "crtend_so"
Colin Cross4d9c2d12016-07-29 12:48:20 -0700926 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700927 deps.WholeStaticLibs = append(deps.WholeStaticLibs, library.SharedProperties.Shared.Whole_static_libs...)
928 deps.StaticLibs = append(deps.StaticLibs, library.SharedProperties.Shared.Static_libs...)
929 deps.SharedLibs = append(deps.SharedLibs, library.SharedProperties.Shared.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -0800930
Colin Crosse1bb5d02019-09-24 14:55:04 -0700931 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.SharedProperties.Shared.Export_shared_lib_headers...)
932 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.SharedProperties.Shared.Export_static_lib_headers...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700933 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900934 if ctx.inVendor() {
Jiyong Park52d25bd2017-10-13 09:17:01 +0900935 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
936 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
937 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +0000938 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
939 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Jiyong Park52d25bd2017-10-13 09:17:01 +0900940 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900941 if ctx.inProduct() {
942 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
943 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
944 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
945 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
946 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
947 }
Jiyong Parkf9332f12018-02-01 00:54:12 +0900948 if ctx.inRecovery() {
949 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
950 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
951 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +0000952 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
953 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900954 }
Yifan Hongcf4832c2020-01-21 17:04:13 -0800955 if ctx.inRamdisk() {
956 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
957 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
958 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
959 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
960 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
961 }
Yifan Hong6da33c22020-10-27 15:01:21 -0700962 if ctx.inVendorRamdisk() {
963 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
964 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
965 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
966 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
967 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
968 }
Colin Cross2383f3b2018-02-06 14:40:13 -0800969
Colin Cross4d9c2d12016-07-29 12:48:20 -0700970 return deps
971}
972
Paul Duffin13f02712020-03-06 12:30:43 +0000973func (library *libraryDecorator) linkerSpecifiedDeps(specifiedDeps specifiedDeps) specifiedDeps {
974 specifiedDeps = library.baseLinker.linkerSpecifiedDeps(specifiedDeps)
975 var properties StaticOrSharedProperties
976 if library.static() {
977 properties = library.StaticProperties.Static
978 } else if library.shared() {
979 properties = library.SharedProperties.Shared
980 }
981
982 specifiedDeps.sharedLibs = append(specifiedDeps.sharedLibs, properties.Shared_libs...)
Martin Stjernholm10566a02020-03-24 01:19:52 +0000983
984 // Must distinguish nil and [] in system_shared_libs - ensure that [] in
985 // either input list doesn't come out as nil.
986 if specifiedDeps.systemSharedLibs == nil {
987 specifiedDeps.systemSharedLibs = properties.System_shared_libs
988 } else {
989 specifiedDeps.systemSharedLibs = append(specifiedDeps.systemSharedLibs, properties.System_shared_libs...)
990 }
Paul Duffin13f02712020-03-06 12:30:43 +0000991
992 specifiedDeps.sharedLibs = android.FirstUniqueStrings(specifiedDeps.sharedLibs)
Martin Stjernholm10566a02020-03-24 01:19:52 +0000993 if len(specifiedDeps.systemSharedLibs) > 0 {
994 // Skip this if systemSharedLibs is either nil or [], to ensure they are
995 // retained.
996 specifiedDeps.systemSharedLibs = android.FirstUniqueStrings(specifiedDeps.systemSharedLibs)
997 }
Paul Duffin13f02712020-03-06 12:30:43 +0000998 return specifiedDeps
999}
1000
Colin Crossb916a382016-07-29 17:28:03 -07001001func (library *libraryDecorator) linkStatic(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001002 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001003
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001004 library.objects = deps.WholeStaticLibObjs.Copy()
1005 library.objects = library.objects.Append(objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001006
Inseob Kim0ce291e2019-07-04 14:38:27 +09001007 fileName := ctx.ModuleName() + staticLibraryExtension
Colin Cross86803cf2018-02-15 14:12:26 -08001008 outputFile := android.PathForModuleOut(ctx, fileName)
Dan Willemsen581341d2017-02-09 16:16:31 -08001009 builderFlags := flagsToBuilderFlags(flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001010
Dan Willemsen569edc52018-11-19 09:33:29 -08001011 if Bool(library.baseLinker.Properties.Use_version_lib) {
1012 if ctx.Host() {
1013 versionedOutputFile := outputFile
1014 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
1015 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1016 } else {
1017 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001018 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -08001019 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1020 }
Colin Cross86803cf2018-02-15 14:12:26 -08001021 }
1022
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001023 transformObjToStaticLib(ctx, library.objects.objFiles, deps.WholeStaticLibsFromPrebuilts, builderFlags, outputFile, objs.tidyFiles)
Dan Willemsen581341d2017-02-09 16:16:31 -08001024
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001025 library.coverageOutputFile = transformCoverageFilesToZip(ctx, library.objects, ctx.ModuleName())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001026
Colin Cross4d9c2d12016-07-29 12:48:20 -07001027 ctx.CheckbuildFile(outputFile)
1028
Colin Cross649d8172020-12-10 12:30:21 -08001029 if library.static() {
1030 ctx.SetProvider(StaticLibraryInfoProvider, StaticLibraryInfo{
1031 StaticLibrary: outputFile,
1032 ReuseObjects: library.reuseObjects,
1033 Objects: library.objects,
Colin Cross0de8a1e2020-09-18 14:15:30 -07001034
Colin Cross649d8172020-12-10 12:30:21 -08001035 TransitiveStaticLibrariesForOrdering: android.NewDepSetBuilder(android.TOPOLOGICAL).
1036 Direct(outputFile).
1037 Transitive(deps.TranstiveStaticLibrariesForOrdering).
1038 Build(),
1039 })
1040 }
1041
1042 if library.header() {
1043 ctx.SetProvider(HeaderLibraryInfoProvider, HeaderLibraryInfo{})
1044 }
Colin Cross0de8a1e2020-09-18 14:15:30 -07001045
Colin Cross4d9c2d12016-07-29 12:48:20 -07001046 return outputFile
1047}
1048
Colin Crossb916a382016-07-29 17:28:03 -07001049func (library *libraryDecorator) linkShared(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001050 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001051
1052 var linkerDeps android.Paths
Pirama Arumuga Nainarada83ec2017-08-31 23:38:27 -07001053 linkerDeps = append(linkerDeps, flags.LdFlagsDeps...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001054
Colin Cross2383f3b2018-02-06 14:40:13 -08001055 unexportedSymbols := ctx.ExpandOptionalSource(library.Properties.Unexported_symbols_list, "unexported_symbols_list")
1056 forceNotWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_not_weak_list, "force_symbols_not_weak_list")
1057 forceWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_weak_list, "force_symbols_weak_list")
Colin Cross4d9c2d12016-07-29 12:48:20 -07001058 if !ctx.Darwin() {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001059 if unexportedSymbols.Valid() {
1060 ctx.PropertyErrorf("unexported_symbols_list", "Only supported on Darwin")
1061 }
1062 if forceNotWeakSymbols.Valid() {
1063 ctx.PropertyErrorf("force_symbols_not_weak_list", "Only supported on Darwin")
1064 }
1065 if forceWeakSymbols.Valid() {
1066 ctx.PropertyErrorf("force_symbols_weak_list", "Only supported on Darwin")
1067 }
1068 } else {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001069 if unexportedSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001070 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-unexported_symbols_list,"+unexportedSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001071 linkerDeps = append(linkerDeps, unexportedSymbols.Path())
1072 }
1073 if forceNotWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001074 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_not_weak_list,"+forceNotWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001075 linkerDeps = append(linkerDeps, forceNotWeakSymbols.Path())
1076 }
1077 if forceWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001078 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_weak_list,"+forceWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001079 linkerDeps = append(linkerDeps, forceWeakSymbols.Path())
1080 }
1081 }
Colin Cross8e21aa52020-09-28 18:28:02 -07001082 if library.versionScriptPath.Valid() {
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001083 linkerScriptFlags := "-Wl,--version-script," + library.versionScriptPath.String()
Colin Cross4af21ed2019-11-04 09:37:55 -08001084 flags.Local.LdFlags = append(flags.Local.LdFlags, linkerScriptFlags)
Colin Cross8e21aa52020-09-28 18:28:02 -07001085 linkerDeps = append(linkerDeps, library.versionScriptPath.Path())
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001086 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001087
1088 fileName := library.getLibName(ctx) + flags.Toolchain.ShlibSuffix()
1089 outputFile := android.PathForModuleOut(ctx, fileName)
Colin Cross0de8a1e2020-09-18 14:15:30 -07001090 unstrippedOutputFile := outputFile
Colin Cross4d9c2d12016-07-29 12:48:20 -07001091
Josh Gao75a50a22019-06-07 17:58:59 -07001092 var implicitOutputs android.WritablePaths
1093 if ctx.Windows() {
1094 importLibraryPath := android.PathForModuleOut(ctx, pathtools.ReplaceExtension(fileName, "lib"))
1095
Colin Cross4af21ed2019-11-04 09:37:55 -08001096 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,--out-implib="+importLibraryPath.String())
Josh Gao75a50a22019-06-07 17:58:59 -07001097 implicitOutputs = append(implicitOutputs, importLibraryPath)
1098 }
1099
Colin Cross4d9c2d12016-07-29 12:48:20 -07001100 builderFlags := flagsToBuilderFlags(flags)
1101
Colin Crossb496cfd2018-09-10 16:50:05 -07001102 // Optimize out relinking against shared libraries whose interface hasn't changed by
1103 // depending on a table of contents file instead of the library itself.
Colin Cross70dda7e2019-10-01 22:05:35 -07001104 tocFile := outputFile.ReplaceExtension(ctx, flags.Toolchain.ShlibSuffix()[1:]+".toc")
Colin Crossb496cfd2018-09-10 16:50:05 -07001105 library.tocFile = android.OptionalPathForPath(tocFile)
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001106 transformSharedObjectToToc(ctx, outputFile, tocFile, builderFlags)
Colin Cross89562dc2016-10-03 17:47:19 -07001107
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001108 stripFlags := flagsToStripFlags(flags)
Colin Crossadc81a02020-12-14 17:01:55 -08001109 needsStrip := library.stripper.NeedsStrip(ctx)
1110 if library.buildStubs() {
1111 // No need to strip stubs libraries
1112 needsStrip = false
1113 }
1114 if needsStrip {
Yi Kongb5c34d72018-11-07 16:28:49 -08001115 if ctx.Darwin() {
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001116 stripFlags.StripUseGnuStrip = true
Yi Kongb5c34d72018-11-07 16:28:49 -08001117 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001118 strippedOutputFile := outputFile
1119 outputFile = android.PathForModuleOut(ctx, "unstripped", fileName)
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001120 library.stripper.StripExecutableOrSharedLib(ctx, outputFile, strippedOutputFile, stripFlags)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001121 }
Colin Crossb60190a2018-09-04 16:28:17 -07001122 library.unstrippedOutputFile = outputFile
1123
Colin Crossd7227f92019-09-05 14:26:33 -07001124 outputFile = maybeInjectBoringSSLHash(ctx, outputFile, library.Properties.Inject_bssl_hash, fileName)
Pete Bentley803e1612019-08-06 22:19:59 +01001125
Dan Willemsen569edc52018-11-19 09:33:29 -08001126 if Bool(library.baseLinker.Properties.Use_version_lib) {
1127 if ctx.Host() {
1128 versionedOutputFile := outputFile
1129 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
1130 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1131 } else {
1132 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001133 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -08001134
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001135 if library.stripper.NeedsStrip(ctx) {
Dan Willemsen569edc52018-11-19 09:33:29 -08001136 out := android.PathForModuleOut(ctx, "versioned-stripped", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001137 library.distFile = out
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001138 library.stripper.StripExecutableOrSharedLib(ctx, versionedOutputFile, out, stripFlags)
Dan Willemsen569edc52018-11-19 09:33:29 -08001139 }
1140
1141 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1142 }
Colin Cross86803cf2018-02-15 14:12:26 -08001143 }
1144
Jiyong Park64a44f22019-01-18 14:37:08 +09001145 sharedLibs := deps.EarlySharedLibs
1146 sharedLibs = append(sharedLibs, deps.SharedLibs...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001147 sharedLibs = append(sharedLibs, deps.LateSharedLibs...)
1148
Jiyong Park64a44f22019-01-18 14:37:08 +09001149 linkerDeps = append(linkerDeps, deps.EarlySharedLibsDeps...)
Colin Cross26c34ed2016-09-30 17:10:16 -07001150 linkerDeps = append(linkerDeps, deps.SharedLibsDeps...)
1151 linkerDeps = append(linkerDeps, deps.LateSharedLibsDeps...)
Dan Willemsena03cf6d2016-09-26 15:45:04 -07001152 linkerDeps = append(linkerDeps, objs.tidyFiles...)
Colin Cross26c34ed2016-09-30 17:10:16 -07001153
Colin Cross127bb8b2020-12-16 16:46:01 -08001154 if Bool(library.Properties.Sort_bss_symbols_by_size) && !library.buildStubs() {
Vic Yang6cd1be82019-06-24 16:08:48 -07001155 unsortedOutputFile := android.PathForModuleOut(ctx, "unsorted", fileName)
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001156 transformObjToDynamicBinary(ctx, objs.objFiles, sharedLibs,
Vic Yang6cd1be82019-06-24 16:08:48 -07001157 deps.StaticLibs, deps.LateStaticLibs, deps.WholeStaticLibs,
1158 linkerDeps, deps.CrtBegin, deps.CrtEnd, false, builderFlags, unsortedOutputFile, implicitOutputs)
1159
1160 symbolOrderingFile := android.PathForModuleOut(ctx, "unsorted", fileName+".symbol_order")
1161 symbolOrderingFlag := library.baseLinker.sortBssSymbolsBySize(ctx, unsortedOutputFile, symbolOrderingFile, builderFlags)
Colin Cross6d88dba2019-11-06 07:06:58 -08001162 builderFlags.localLdFlags += " " + symbolOrderingFlag
Vic Yang6cd1be82019-06-24 16:08:48 -07001163 linkerDeps = append(linkerDeps, symbolOrderingFile)
1164 }
1165
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001166 transformObjToDynamicBinary(ctx, objs.objFiles, sharedLibs,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001167 deps.StaticLibs, deps.LateStaticLibs, deps.WholeStaticLibs,
Josh Gao75a50a22019-06-07 17:58:59 -07001168 linkerDeps, deps.CrtBegin, deps.CrtEnd, false, builderFlags, outputFile, implicitOutputs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001169
Dan Willemsen581341d2017-02-09 16:16:31 -08001170 objs.coverageFiles = append(objs.coverageFiles, deps.StaticLibObjs.coverageFiles...)
1171 objs.coverageFiles = append(objs.coverageFiles, deps.WholeStaticLibObjs.coverageFiles...)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001172
1173 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.StaticLibObjs.sAbiDumpFiles...)
1174 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.WholeStaticLibObjs.sAbiDumpFiles...)
1175
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001176 library.coverageOutputFile = transformCoverageFilesToZip(ctx, objs, library.getLibName(ctx))
Colin Cross0de8a1e2020-09-18 14:15:30 -07001177 library.linkSAbiDumpFiles(ctx, objs, fileName, unstrippedOutputFile)
Dan Willemsen581341d2017-02-09 16:16:31 -08001178
Colin Cross0de8a1e2020-09-18 14:15:30 -07001179 var staticAnalogue *StaticLibraryInfo
1180 if static := ctx.GetDirectDepsWithTag(staticVariantTag); len(static) > 0 {
1181 s := ctx.OtherModuleProvider(static[0], StaticLibraryInfoProvider).(StaticLibraryInfo)
1182 staticAnalogue = &s
1183 }
1184
1185 ctx.SetProvider(SharedLibraryInfoProvider, SharedLibraryInfo{
1186 TableOfContents: android.OptionalPathForPath(tocFile),
1187 SharedLibrary: unstrippedOutputFile,
1188 UnstrippedSharedLibrary: library.unstrippedOutputFile,
1189 CoverageSharedLibrary: library.coverageOutputFile,
1190 StaticAnalogue: staticAnalogue,
1191 })
1192
1193 stubs := ctx.GetDirectDepsWithTag(stubImplDepTag)
1194 if len(stubs) > 0 {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001195 var stubsInfo []SharedStubLibrary
Colin Cross0de8a1e2020-09-18 14:15:30 -07001196 for _, stub := range stubs {
1197 stubInfo := ctx.OtherModuleProvider(stub, SharedLibraryInfoProvider).(SharedLibraryInfo)
1198 flagInfo := ctx.OtherModuleProvider(stub, FlagExporterInfoProvider).(FlagExporterInfo)
Chris Parsons3c27ca32020-11-20 12:42:07 -05001199 stubsInfo = append(stubsInfo, SharedStubLibrary{
Colin Cross31076b32020-10-23 17:22:06 -07001200 Version: moduleLibraryInterface(stub).stubsVersion(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001201 SharedLibraryInfo: stubInfo,
1202 FlagExporterInfo: flagInfo,
1203 })
1204 }
Chris Parsons3c27ca32020-11-20 12:42:07 -05001205 ctx.SetProvider(SharedLibraryStubsProvider, SharedLibraryStubsInfo{
1206 SharedStubLibraries: stubsInfo,
Colin Cross0de8a1e2020-09-18 14:15:30 -07001207
Colin Cross127bb8b2020-12-16 16:46:01 -08001208 IsLLNDK: ctx.IsLlndk(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001209 })
1210 }
1211
1212 return unstrippedOutputFile
Colin Cross4d9c2d12016-07-29 12:48:20 -07001213}
1214
Jiyong Parkaf6d8952019-01-31 12:21:23 +09001215func (library *libraryDecorator) unstrippedOutputFilePath() android.Path {
1216 return library.unstrippedOutputFile
1217}
1218
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001219func (library *libraryDecorator) disableStripping() {
1220 library.stripper.StripProperties.Strip.None = BoolPtr(true)
1221}
1222
Pirama Arumuga Nainar65c95ff2019-03-25 10:21:31 -07001223func (library *libraryDecorator) nativeCoverage() bool {
1224 if library.header() || library.buildStubs() {
1225 return false
1226 }
1227 return true
1228}
1229
Jiyong Parkee9a98d2019-08-09 14:44:36 +09001230func (library *libraryDecorator) coverageOutputFilePath() android.OptionalPath {
1231 return library.coverageOutputFile
1232}
1233
Logan Chien7eefdc42018-07-11 18:10:41 +08001234func getRefAbiDumpFile(ctx ModuleContext, vndkVersion, fileName string) android.Path {
Hsin-Yi Chen27d235f2020-03-26 17:50:29 +08001235 // The logic must be consistent with classifySourceAbiDump.
Colin Cross95f1ca02020-10-29 20:47:22 -07001236 isNdk := ctx.isNdk(ctx.Config())
Colin Cross127bb8b2020-12-16 16:46:01 -08001237 isLlndkOrVndk := ctx.IsLlndkPublic() || (ctx.useVndk() && ctx.isVndk())
Logan Chien7eefdc42018-07-11 18:10:41 +08001238
Hsin-Yi Chen53489642019-07-31 17:10:45 +08001239 refAbiDumpTextFile := android.PathForVndkRefAbiDump(ctx, vndkVersion, fileName, isNdk, isLlndkOrVndk, false)
1240 refAbiDumpGzipFile := android.PathForVndkRefAbiDump(ctx, vndkVersion, fileName, isNdk, isLlndkOrVndk, true)
Logan Chien7eefdc42018-07-11 18:10:41 +08001241
1242 if refAbiDumpTextFile.Valid() {
1243 if refAbiDumpGzipFile.Valid() {
1244 ctx.ModuleErrorf(
1245 "Two reference ABI dump files are found: %q and %q. Please delete the stale one.",
1246 refAbiDumpTextFile, refAbiDumpGzipFile)
1247 return nil
1248 }
1249 return refAbiDumpTextFile.Path()
1250 }
1251 if refAbiDumpGzipFile.Valid() {
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001252 return unzipRefDump(ctx, refAbiDumpGzipFile.Path(), fileName)
Logan Chien7eefdc42018-07-11 18:10:41 +08001253 }
1254 return nil
1255}
1256
Jayant Chowdhary6ab3d842017-06-26 12:52:58 -07001257func (library *libraryDecorator) linkSAbiDumpFiles(ctx ModuleContext, objs Objects, fileName string, soFile android.Path) {
Yo Chiang2bbadfa2020-12-14 11:42:16 +08001258 if library.sabi.shouldCreateSourceAbiDump() {
Inseob Kim96f17f02020-06-09 22:05:09 +09001259 var vndkVersion string
1260
1261 if ctx.useVndk() {
1262 // For modules linking against vndk, follow its vndk version
1263 vndkVersion = ctx.Module().(*Module).VndkVersion()
1264 } else {
1265 // Regard the other modules as PLATFORM_VNDK_VERSION
1266 vndkVersion = ctx.DeviceConfig().PlatformVndkVersion()
Logan Chienf3511742017-10-31 18:04:35 +08001267 }
1268
Jayant Chowdharya4fce192017-09-06 13:10:03 -07001269 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001270 var SourceAbiFlags []string
1271 for _, dir := range exportIncludeDirs.Strings() {
Jayant Chowdhary715cac32017-04-20 06:53:59 -07001272 SourceAbiFlags = append(SourceAbiFlags, "-I"+dir)
1273 }
Inseob Kim69378442019-06-03 19:10:47 +09001274 for _, reexportedInclude := range library.sabi.Properties.ReexportedIncludes {
1275 SourceAbiFlags = append(SourceAbiFlags, "-I"+reexportedInclude)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001276 }
1277 exportedHeaderFlags := strings.Join(SourceAbiFlags, " ")
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001278 library.sAbiOutputFile = transformDumpToLinkedDump(ctx, objs.sAbiDumpFiles, soFile, fileName, exportedHeaderFlags,
Jiyong Parka034b832019-08-27 14:02:19 +09001279 android.OptionalPathForModuleSrc(ctx, library.symbolFileForAbiCheck(ctx)),
Logan Chiene3d7a0d2019-01-17 00:18:02 +08001280 library.Properties.Header_abi_checker.Exclude_symbol_versions,
1281 library.Properties.Header_abi_checker.Exclude_symbol_tags)
Logan Chien2f2b8902018-07-10 15:01:19 +08001282
Yo Chiang2bbadfa2020-12-14 11:42:16 +08001283 addLsdumpPath(classifySourceAbiDump(ctx) + ":" + library.sAbiOutputFile.String())
Hsin-Yi Chen53489642019-07-31 17:10:45 +08001284
Logan Chien7eefdc42018-07-11 18:10:41 +08001285 refAbiDumpFile := getRefAbiDumpFile(ctx, vndkVersion, fileName)
1286 if refAbiDumpFile != nil {
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001287 library.sAbiDiff = sourceAbiDiff(ctx, library.sAbiOutputFile.Path(),
Logan Chien2a65dda2019-10-01 15:58:07 -07001288 refAbiDumpFile, fileName, exportedHeaderFlags,
1289 Bool(library.Properties.Header_abi_checker.Check_all_apis),
Colin Cross127bb8b2020-12-16 16:46:01 -08001290 ctx.IsLlndk(), ctx.isNdk(ctx.Config()), ctx.IsVndkExt())
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001291 }
1292 }
1293}
1294
Colin Cross127bb8b2020-12-16 16:46:01 -08001295func processLLNDKHeaders(ctx ModuleContext, srcHeaderDir string, outDir android.ModuleGenPath) android.Path {
1296 srcDir := android.PathForModuleSrc(ctx, srcHeaderDir)
1297 srcFiles := ctx.GlobFiles(filepath.Join(srcDir.String(), "**/*.h"), nil)
1298
1299 var installPaths []android.WritablePath
1300 for _, header := range srcFiles {
1301 headerDir := filepath.Dir(header.String())
1302 relHeaderDir, err := filepath.Rel(srcDir.String(), headerDir)
1303 if err != nil {
1304 ctx.ModuleErrorf("filepath.Rel(%q, %q) failed: %s",
1305 srcDir.String(), headerDir, err)
1306 continue
1307 }
1308
1309 installPaths = append(installPaths, outDir.Join(ctx, relHeaderDir, header.Base()))
1310 }
1311
1312 return processHeadersWithVersioner(ctx, srcDir, outDir, srcFiles, installPaths)
1313}
1314
Chris Parsons3c27ca32020-11-20 12:42:07 -05001315// link registers actions to link this library, and sets various fields
1316// on this library to reflect information that should be exported up the build
1317// tree (for example, exported flags and include paths).
Colin Crossb916a382016-07-29 17:28:03 -07001318func (library *libraryDecorator) link(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001319 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001320
Colin Cross127bb8b2020-12-16 16:46:01 -08001321 if ctx.IsLlndk() {
1322 if len(library.Properties.Llndk.Export_preprocessed_headers) > 0 {
1323 // This is the vendor variant of an LLNDK library with preprocessed headers.
1324 genHeaderOutDir := android.PathForModuleGen(ctx, "include")
1325
1326 var timestampFiles android.Paths
1327 for _, dir := range library.Properties.Llndk.Export_preprocessed_headers {
1328 timestampFiles = append(timestampFiles, processLLNDKHeaders(ctx, dir, genHeaderOutDir))
1329 }
1330
1331 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1332 library.reexportSystemDirs(genHeaderOutDir)
1333 } else {
1334 library.reexportDirs(genHeaderOutDir)
1335 }
1336
1337 library.reexportDeps(timestampFiles...)
1338 }
1339
1340 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1341 library.flagExporter.Properties.Export_system_include_dirs = append(
1342 library.flagExporter.Properties.Export_system_include_dirs,
1343 library.flagExporter.Properties.Export_include_dirs...)
1344 library.flagExporter.Properties.Export_include_dirs = nil
1345 }
1346 }
1347
Chris Parsons3c27ca32020-11-20 12:42:07 -05001348 // Linking this library consists of linking `deps.Objs` (.o files in dependencies
1349 // of this library), together with `objs` (.o files created by compiling this
1350 // library).
Colin Crossad59e752017-11-16 14:29:11 -08001351 objs = deps.Objs.Copy().Append(objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001352 var out android.Path
Colin Crossa48ab5b2017-02-14 15:28:44 -08001353 if library.static() || library.header() {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001354 out = library.linkStatic(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001355 } else {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001356 out = library.linkShared(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001357 }
1358
Chris Parsons3c27ca32020-11-20 12:42:07 -05001359 // Export include paths and flags to be propagated up the tree.
Inseob Kim69378442019-06-03 19:10:47 +09001360 library.exportIncludes(ctx)
1361 library.reexportDirs(deps.ReexportedDirs...)
1362 library.reexportSystemDirs(deps.ReexportedSystemDirs...)
1363 library.reexportFlags(deps.ReexportedFlags...)
1364 library.reexportDeps(deps.ReexportedDeps...)
Inseob Kimd110f872019-12-06 13:15:38 +09001365 library.addExportedGeneratedHeaders(deps.ReexportedGeneratedHeaders...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001366
Chris Parsons3c27ca32020-11-20 12:42:07 -05001367 // Optionally export aidl headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001368 if Bool(library.Properties.Aidl.Export_aidl_headers) {
Dan Willemsene1240db2016-11-03 14:28:51 -07001369 if library.baseCompiler.hasSrcExt(".aidl") {
Jiyong Park74955042019-10-22 20:19:51 +09001370 dir := android.PathForModuleGen(ctx, "aidl")
Inseob Kim69378442019-06-03 19:10:47 +09001371 library.reexportDirs(dir)
Inseob Kimd110f872019-12-06 13:15:38 +09001372
Paul Duffin33056e82021-02-19 13:49:08 +00001373 library.reexportDeps(library.baseCompiler.aidlOrderOnlyDeps...)
1374 library.addExportedGeneratedHeaders(library.baseCompiler.aidlHeaders...)
Dan Willemsene1240db2016-11-03 14:28:51 -07001375 }
1376 }
1377
Chris Parsons3c27ca32020-11-20 12:42:07 -05001378 // Optionally export proto headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001379 if Bool(library.Properties.Proto.Export_proto_headers) {
Dan Willemsene1240db2016-11-03 14:28:51 -07001380 if library.baseCompiler.hasSrcExt(".proto") {
Jiyong Park74955042019-10-22 20:19:51 +09001381 var includes android.Paths
Colin Cross19878da2019-03-28 14:45:07 -07001382 if flags.proto.CanonicalPathFromRoot {
Jiyong Park74955042019-10-22 20:19:51 +09001383 includes = append(includes, flags.proto.SubDir)
Colin Cross10d22312017-05-03 11:01:58 -07001384 }
Jiyong Park74955042019-10-22 20:19:51 +09001385 includes = append(includes, flags.proto.Dir)
Inseob Kim69378442019-06-03 19:10:47 +09001386 library.reexportDirs(includes...)
Inseob Kimd110f872019-12-06 13:15:38 +09001387
Paul Duffin33056e82021-02-19 13:49:08 +00001388 library.reexportDeps(library.baseCompiler.protoOrderOnlyDeps...)
1389 library.addExportedGeneratedHeaders(library.baseCompiler.protoHeaders...)
Colin Cross0c461f12016-10-20 16:11:43 -07001390 }
1391 }
1392
Inseob Kim07def122020-11-23 14:43:02 +09001393 // If the library is sysprop_library, expose either public or internal header selectively.
Inseob Kim21f26902018-09-06 00:55:20 +09001394 if library.baseCompiler.hasSrcExt(".sysprop") {
Jiyong Park74955042019-10-22 20:19:51 +09001395 dir := android.PathForModuleGen(ctx, "sysprop", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001396 if library.Properties.Sysprop.Platform != nil {
Inseob Kimc0907f12019-02-08 21:00:45 +09001397 isOwnerPlatform := Bool(library.Properties.Sysprop.Platform)
1398
Inseob Kim07def122020-11-23 14:43:02 +09001399 // If the owner is different from the user, expose public header. That is,
1400 // 1) if the user is product (as owner can only be platform / vendor)
Inseob Kim06410042021-01-18 15:23:28 +09001401 // 2) if the owner is platform and the client is vendor
1402 // We don't care Platform -> Vendor dependency as it's already forbidden.
1403 if ctx.Device() && (ctx.ProductSpecific() || (isOwnerPlatform && ctx.inVendor())) {
Jiyong Park74955042019-10-22 20:19:51 +09001404 dir = android.PathForModuleGen(ctx, "sysprop/public", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001405 }
1406 }
1407
Paul Duffin37e0de52021-02-19 17:05:39 +00001408 // Make sure to only export headers which are within the include directory.
1409 _, headers := android.FilterPathListPredicate(library.baseCompiler.syspropHeaders, func(path android.Path) bool {
1410 _, isRel := android.MaybeRel(ctx, dir.String(), path.String())
1411 return isRel
1412 })
1413
Chris Parsons3c27ca32020-11-20 12:42:07 -05001414 // Add sysprop-related directories to the exported directories of this library.
Inseob Kim69378442019-06-03 19:10:47 +09001415 library.reexportDirs(dir)
Paul Duffin33056e82021-02-19 13:49:08 +00001416 library.reexportDeps(library.baseCompiler.syspropOrderOnlyDeps...)
Paul Duffin37e0de52021-02-19 17:05:39 +00001417 library.addExportedGeneratedHeaders(headers...)
Inseob Kim21f26902018-09-06 00:55:20 +09001418 }
1419
Chris Parsons3c27ca32020-11-20 12:42:07 -05001420 // Add stub-related flags if this library is a stub library.
Jiyong Park892a98f2020-12-14 09:20:00 +09001421 library.exportVersioningMacroIfNeeded(ctx)
Jiyong Parkda732bd2018-11-02 18:23:15 +09001422
Chris Parsons3c27ca32020-11-20 12:42:07 -05001423 // Propagate a Provider containing information about exported flags, deps, and include paths.
Colin Cross0de8a1e2020-09-18 14:15:30 -07001424 library.flagExporter.setProvider(ctx)
1425
Colin Cross4d9c2d12016-07-29 12:48:20 -07001426 return out
1427}
1428
Jiyong Park892a98f2020-12-14 09:20:00 +09001429func (library *libraryDecorator) exportVersioningMacroIfNeeded(ctx android.BaseModuleContext) {
Colin Cross127bb8b2020-12-16 16:46:01 -08001430 if library.buildStubs() && library.stubsVersion() != "" && !library.skipAPIDefine {
Jiyong Park892a98f2020-12-14 09:20:00 +09001431 name := versioningMacroName(ctx.Module().(*Module).ImplementationModuleName(ctx))
Jooyung Han11b0fbd2021-02-05 02:28:22 +09001432 apiLevel, err := android.ApiLevelFromUser(ctx, library.stubsVersion())
1433 if err != nil {
1434 ctx.ModuleErrorf("Can't export version macro: %s", err.Error())
1435 }
1436 library.reexportFlags("-D" + name + "=" + strconv.Itoa(apiLevel.FinalOrPreviewInt()))
Jiyong Park892a98f2020-12-14 09:20:00 +09001437 }
1438}
1439
Chris Parsons3c27ca32020-11-20 12:42:07 -05001440// buildStatic returns true if this library should be built as a static library.
Colin Crossb916a382016-07-29 17:28:03 -07001441func (library *libraryDecorator) buildStatic() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001442 return library.MutatedProperties.BuildStatic &&
1443 BoolDefault(library.StaticProperties.Static.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001444}
1445
Chris Parsons3c27ca32020-11-20 12:42:07 -05001446// buildShared returns true if this library should be built as a shared library.
Colin Crossb916a382016-07-29 17:28:03 -07001447func (library *libraryDecorator) buildShared() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001448 return library.MutatedProperties.BuildShared &&
1449 BoolDefault(library.SharedProperties.Shared.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001450}
1451
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001452func (library *libraryDecorator) objs() Objects {
1453 return library.objects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001454}
1455
Colin Cross0de8a1e2020-09-18 14:15:30 -07001456func (library *libraryDecorator) reuseObjs() Objects {
1457 return library.reuseObjects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001458}
1459
Colin Cross26c34ed2016-09-30 17:10:16 -07001460func (library *libraryDecorator) toc() android.OptionalPath {
1461 return library.tocFile
1462}
1463
Jiyong Parkf1194352019-02-25 11:05:47 +09001464func (library *libraryDecorator) installSymlinkToRuntimeApex(ctx ModuleContext, file android.Path) {
1465 dir := library.baseInstaller.installDir(ctx)
1466 dirOnDevice := android.InstallPathToOnDevicePath(ctx, dir)
1467 target := "/" + filepath.Join("apex", "com.android.runtime", dir.Base(), "bionic", file.Base())
1468 ctx.InstallAbsoluteSymlink(dir, file.Base(), target)
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001469 library.postInstallCmds = append(library.postInstallCmds, makeSymlinkCmd(dirOnDevice, file.Base(), target))
Jiyong Parkf1194352019-02-25 11:05:47 +09001470}
1471
Colin Crossb916a382016-07-29 17:28:03 -07001472func (library *libraryDecorator) install(ctx ModuleContext, file android.Path) {
Colin Crossc43ae772017-04-14 15:42:53 -07001473 if library.shared() {
Justin Yun8fe12122017-12-07 17:18:15 +09001474 if ctx.Device() && ctx.useVndk() {
Jooyung Han261e1582020-10-20 18:54:21 +09001475 // set subDir for VNDK extensions
Ivan Lozanof9e21722020-12-02 09:00:51 -05001476 if ctx.IsVndkExt() {
Jooyung Han261e1582020-10-20 18:54:21 +09001477 if ctx.isVndkSp() {
1478 library.baseInstaller.subDir = "vndk-sp"
1479 } else {
1480 library.baseInstaller.subDir = "vndk"
1481 }
1482 }
1483
Justin Yun31094b12020-12-24 16:11:23 +09001484 // In some cases we want to use core variant for VNDK-Core libs.
1485 // Skip product variant since VNDKs use only the vendor variant.
1486 if ctx.isVndk() && !ctx.isVndkSp() && !ctx.IsVndkExt() && !ctx.inProduct() {
Vic Yang1a5812a2020-01-31 10:38:40 -08001487 mayUseCoreVariant := true
1488
1489 if ctx.mustUseVendorVariant() {
1490 mayUseCoreVariant = false
1491 }
1492
Vic Yang1a5812a2020-01-31 10:38:40 -08001493 if ctx.Config().CFIEnabledForPath(ctx.ModuleDir()) && ctx.Arch().ArchType == android.Arm64 {
1494 mayUseCoreVariant = false
1495 }
1496
1497 if mayUseCoreVariant {
Vic Yangd92090f2020-01-08 14:32:28 -08001498 library.checkSameCoreVariant = true
1499 if ctx.DeviceConfig().VndkUseCoreVariant() {
1500 library.useCoreVariant = true
1501 }
Vic Yangefd249e2018-11-12 20:19:56 -08001502 }
Justin Yun8fe12122017-12-07 17:18:15 +09001503 }
Logan Chienf3511742017-10-31 18:04:35 +08001504
Jooyung Han261e1582020-10-20 18:54:21 +09001505 // do not install vndk libs
1506 // vndk libs are packaged into VNDK APEX
Ivan Lozanof9e21722020-12-02 09:00:51 -05001507 if ctx.isVndk() && !ctx.IsVndkExt() {
Jooyung Han261e1582020-10-20 18:54:21 +09001508 return
Justin Yun8effde42017-06-23 19:24:43 +09001509 }
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001510 } else if library.hasStubsVariants() && !ctx.Host() && ctx.directlyInAnyApex() {
Jiyong Parkf1194352019-02-25 11:05:47 +09001511 // Bionic libraries (e.g. libc.so) is installed to the bootstrap subdirectory.
1512 // The original path becomes a symlink to the corresponding file in the
1513 // runtime APEX.
Colin Cross3b19f5d2019-09-17 14:45:31 -07001514 translatedArch := ctx.Target().NativeBridge == android.NativeBridgeEnabled
Colin Cross56a83212020-09-15 18:30:11 -07001515 if InstallToBootstrap(ctx.baseModuleName(), ctx.Config()) && !library.buildStubs() &&
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001516 !translatedArch && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() {
Martin Stjernholm279de572019-09-10 23:18:20 +01001517 if ctx.Device() {
Jiyong Parkc3e2c862019-03-16 01:10:08 +09001518 library.installSymlinkToRuntimeApex(ctx, file)
1519 }
Jiyong Park429660f2019-01-16 22:31:11 +09001520 library.baseInstaller.subDir = "bootstrap"
1521 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001522 } else if ctx.directlyInAnyApex() && ctx.IsLlndk() && !isBionic(ctx.baseModuleName()) {
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001523 // Skip installing LLNDK (non-bionic) libraries moved to APEX.
Colin Crossa9c8c9f2020-12-16 10:20:23 -08001524 ctx.Module().HideFromMake()
Justin Yun8effde42017-06-23 19:24:43 +09001525 }
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001526
Colin Cross4d9c2d12016-07-29 12:48:20 -07001527 library.baseInstaller.install(ctx, file)
1528 }
Dan Albertf563d252017-10-13 00:29:00 -07001529
Dan Albert281f22b2017-12-13 15:03:47 -08001530 if Bool(library.Properties.Static_ndk_lib) && library.static() &&
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001531 !ctx.useVndk() && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() && ctx.Device() &&
Jiyong Park7ed9de32018-10-15 22:25:07 +09001532 library.baseLinker.sanitize.isUnsanitizedVariant() &&
Colin Cross95b07f22020-12-16 11:06:50 -08001533 ctx.isForPlatform() && !ctx.isPreventInstall() {
Dan Albertf563d252017-10-13 00:29:00 -07001534 installPath := getNdkSysrootBase(ctx).Join(
Dan Albertea4b7b92018-04-25 16:05:30 -07001535 ctx, "usr/lib", config.NDKTriple(ctx.toolchain()), file.Base())
Dan Albertf563d252017-10-13 00:29:00 -07001536
1537 ctx.ModuleBuild(pctx, android.ModuleBuildParams{
1538 Rule: android.Cp,
1539 Description: "install " + installPath.Base(),
1540 Output: installPath,
1541 Input: file,
1542 })
1543
Colin Cross0875c522017-11-28 17:34:01 -08001544 library.ndkSysrootPath = installPath
Dan Albertf563d252017-10-13 00:29:00 -07001545 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001546}
1547
Paul Duffin0cb37b92020-03-04 14:52:46 +00001548func (library *libraryDecorator) everInstallable() bool {
1549 // Only shared and static libraries are installed. Header libraries (which are
1550 // neither static or shared) are not installed.
1551 return library.shared() || library.static()
1552}
1553
Chris Parsons3c27ca32020-11-20 12:42:07 -05001554// static returns true if this library is for a "static' variant.
Colin Crossb916a382016-07-29 17:28:03 -07001555func (library *libraryDecorator) static() bool {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001556 return library.MutatedProperties.VariantIsStatic
Colin Cross4d9c2d12016-07-29 12:48:20 -07001557}
1558
Chris Parsons3c27ca32020-11-20 12:42:07 -05001559// shared returns true if this library is for a "shared' variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001560func (library *libraryDecorator) shared() bool {
1561 return library.MutatedProperties.VariantIsShared
1562}
1563
Chris Parsons3c27ca32020-11-20 12:42:07 -05001564// header returns true if this library is for a header-only variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001565func (library *libraryDecorator) header() bool {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001566 // Neither "static" nor "shared" implies this library is header-only.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001567 return !library.static() && !library.shared()
1568}
1569
Chris Parsons3c27ca32020-11-20 12:42:07 -05001570// setStatic marks the library variant as "static".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001571func (library *libraryDecorator) setStatic() {
1572 library.MutatedProperties.VariantIsStatic = true
1573 library.MutatedProperties.VariantIsShared = false
1574}
1575
Chris Parsons3c27ca32020-11-20 12:42:07 -05001576// setShared marks the library variant as "shared".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001577func (library *libraryDecorator) setShared() {
1578 library.MutatedProperties.VariantIsStatic = false
1579 library.MutatedProperties.VariantIsShared = true
Colin Crossb916a382016-07-29 17:28:03 -07001580}
1581
Chris Parsons3c27ca32020-11-20 12:42:07 -05001582// BuildOnlyStatic disables building this library as a shared library.
Colin Crossab3b7322016-12-09 14:46:15 -08001583func (library *libraryDecorator) BuildOnlyStatic() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001584 library.MutatedProperties.BuildShared = false
Colin Crossab3b7322016-12-09 14:46:15 -08001585}
1586
Chris Parsons3c27ca32020-11-20 12:42:07 -05001587// BuildOnlyShared disables building this library as a static library.
Colin Crossab3b7322016-12-09 14:46:15 -08001588func (library *libraryDecorator) BuildOnlyShared() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001589 library.MutatedProperties.BuildStatic = false
Colin Crossab3b7322016-12-09 14:46:15 -08001590}
1591
Chris Parsons3c27ca32020-11-20 12:42:07 -05001592// HeaderOnly disables building this library as a shared or static library;
1593// the library only exists to propagate header file dependencies up the build graph.
Colin Cross5950f382016-12-13 12:50:57 -08001594func (library *libraryDecorator) HeaderOnly() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001595 library.MutatedProperties.BuildShared = false
1596 library.MutatedProperties.BuildStatic = false
Colin Cross5950f382016-12-13 12:50:57 -08001597}
1598
Colin Cross127bb8b2020-12-16 16:46:01 -08001599// hasLLNDKStubs returns true if this cc_library module has a variant that will build LLNDK stubs.
1600func (library *libraryDecorator) hasLLNDKStubs() bool {
1601 return String(library.Properties.Llndk_stubs) != ""
1602}
1603
Colin Cross0477b422020-10-13 18:43:54 -07001604func (library *libraryDecorator) implementationModuleName(name string) string {
1605 return name
1606}
1607
Jiyong Park7ed9de32018-10-15 22:25:07 +09001608func (library *libraryDecorator) buildStubs() bool {
1609 return library.MutatedProperties.BuildStubs
1610}
1611
Jiyong Parka034b832019-08-27 14:02:19 +09001612func (library *libraryDecorator) symbolFileForAbiCheck(ctx ModuleContext) *string {
1613 if library.Properties.Header_abi_checker.Symbol_file != nil {
1614 return library.Properties.Header_abi_checker.Symbol_file
1615 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001616 if ctx.Module().(*Module).IsLlndk() {
1617 return library.Properties.Llndk.Symbol_file
1618 }
Colin Cross31076b32020-10-23 17:22:06 -07001619 if library.hasStubsVariants() && library.Properties.Stubs.Symbol_file != nil {
Jiyong Parka034b832019-08-27 14:02:19 +09001620 return library.Properties.Stubs.Symbol_file
1621 }
1622 return nil
1623}
1624
Colin Crossc88c2722020-09-28 17:32:47 -07001625func (library *libraryDecorator) hasStubsVariants() bool {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001626 // Just having stubs.symbol_file is enough to create a stub variant. In that case
1627 // the stub for the future API level is created.
1628 return library.Properties.Stubs.Symbol_file != nil ||
1629 len(library.Properties.Stubs.Versions) > 0
Colin Crossc88c2722020-09-28 17:32:47 -07001630}
1631
Colin Cross3572cf72020-10-01 15:58:11 -07001632func (library *libraryDecorator) stubsVersions(ctx android.BaseMutatorContext) []string {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001633 if !library.hasStubsVariants() {
1634 return nil
1635 }
1636
1637 // Future API level is implicitly added if there isn't
1638 vers := library.Properties.Stubs.Versions
1639 if inList(android.FutureApiLevel.String(), vers) {
1640 return vers
1641 }
1642 // In some cases, people use the raw value "10000" in the versions property.
1643 // We shouldn't add the future API level in that case, otherwise there will
1644 // be two identical versions.
1645 if inList(strconv.Itoa(android.FutureApiLevel.FinalOrFutureInt()), vers) {
1646 return vers
1647 }
1648 return append(vers, android.FutureApiLevel.String())
Colin Crossc88c2722020-09-28 17:32:47 -07001649}
1650
1651func (library *libraryDecorator) setStubsVersion(version string) {
1652 library.MutatedProperties.StubsVersion = version
1653}
1654
Jiyong Park7ed9de32018-10-15 22:25:07 +09001655func (library *libraryDecorator) stubsVersion() string {
1656 return library.MutatedProperties.StubsVersion
1657}
1658
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001659func (library *libraryDecorator) setBuildStubs(isLatest bool) {
Colin Crossc88c2722020-09-28 17:32:47 -07001660 library.MutatedProperties.BuildStubs = true
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001661 library.MutatedProperties.IsLatestVersion = isLatest
Colin Crossc88c2722020-09-28 17:32:47 -07001662}
1663
1664func (library *libraryDecorator) setAllStubsVersions(versions []string) {
1665 library.MutatedProperties.AllStubsVersions = versions
1666}
1667
1668func (library *libraryDecorator) allStubsVersions() []string {
1669 return library.MutatedProperties.AllStubsVersions
1670}
1671
Jooyung Hanad4c1872020-02-27 17:56:44 +09001672func (library *libraryDecorator) isLatestStubVersion() bool {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001673 return library.MutatedProperties.IsLatestVersion
Jooyung Hanad4c1872020-02-27 17:56:44 +09001674}
1675
Jiyong Parka90ca002019-10-07 15:47:24 +09001676func (library *libraryDecorator) availableFor(what string) bool {
1677 var list []string
1678 if library.static() {
1679 list = library.StaticProperties.Static.Apex_available
1680 } else if library.shared() {
1681 list = library.SharedProperties.Shared.Apex_available
1682 }
1683 if len(list) == 0 {
1684 return false
1685 }
1686 return android.CheckAvailableForApex(what, list)
1687}
1688
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001689func (library *libraryDecorator) makeUninstallable(mod *Module) {
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001690 if library.static() && library.buildStatic() && !library.buildStubs() {
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001691 // If we're asked to make a static library uninstallable we don't do
1692 // anything since AndroidMkEntries always sets LOCAL_UNINSTALLABLE_MODULE
1693 // for these entries. This is done to still get the make targets for NOTICE
1694 // files from notice_files.mk, which other libraries might depend on.
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001695 return
1696 }
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001697 mod.ModuleBase.MakeUninstallable()
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001698}
1699
Colin Cross571cccf2019-02-04 11:22:08 -08001700var versioningMacroNamesListKey = android.NewOnceKey("versioningMacroNamesList")
1701
Chris Parsons3c27ca32020-11-20 12:42:07 -05001702// versioningMacroNamesList returns a singleton map, where keys are "version macro names",
1703// and values are the module name responsible for registering the version macro name.
1704//
1705// Version macros are used when building against stubs, to provide version information about
1706// the stub. Only stub libraries should have an entry in this list.
1707//
1708// For example, when building against libFoo#ver, __LIBFOO_API__ macro is set to ver so
1709// that headers from libFoo can be conditionally compiled (this may hide APIs
1710// that are not available for the version).
1711//
1712// This map is used to ensure that there aren't conflicts between these version macro names.
Jiyong Parkda732bd2018-11-02 18:23:15 +09001713func versioningMacroNamesList(config android.Config) *map[string]string {
Colin Cross571cccf2019-02-04 11:22:08 -08001714 return config.Once(versioningMacroNamesListKey, func() interface{} {
Jiyong Parkda732bd2018-11-02 18:23:15 +09001715 m := make(map[string]string)
1716 return &m
1717 }).(*map[string]string)
1718}
1719
1720// alphanumeric and _ characters are preserved.
1721// other characters are all converted to _
1722var charsNotForMacro = regexp.MustCompile("[^a-zA-Z0-9_]+")
1723
Chris Parsons3c27ca32020-11-20 12:42:07 -05001724// versioningMacroName returns the canonical version macro name for the given module.
Jiyong Parkda732bd2018-11-02 18:23:15 +09001725func versioningMacroName(moduleName string) string {
1726 macroName := charsNotForMacro.ReplaceAllString(moduleName, "_")
Jooyung Hanb04a4992020-03-13 18:57:35 +09001727 macroName = strings.ToUpper(macroName)
Jiyong Parkda732bd2018-11-02 18:23:15 +09001728 return "__" + macroName + "_API__"
1729}
1730
Chris Parsons3c27ca32020-11-20 12:42:07 -05001731// NewLibrary builds and returns a new Module corresponding to a C++ library.
1732// Individual module implementations which comprise a C++ library (or something like
1733// a C++ library) should call this function, set some fields on the result, and
1734// then call the Init function.
Colin Crossab3b7322016-12-09 14:46:15 -08001735func NewLibrary(hod android.HostOrDeviceSupported) (*Module, *libraryDecorator) {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001736 module := newModule(hod, android.MultilibBoth)
1737
Colin Crossb916a382016-07-29 17:28:03 -07001738 library := &libraryDecorator{
Colin Crossa48ab5b2017-02-14 15:28:44 -08001739 MutatedProperties: LibraryMutatedProperties{
Colin Crossab3b7322016-12-09 14:46:15 -08001740 BuildShared: true,
1741 BuildStatic: true,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001742 },
Colin Crossb916a382016-07-29 17:28:03 -07001743 baseCompiler: NewBaseCompiler(),
Dan Albert61f32122018-07-26 14:00:24 -07001744 baseLinker: NewBaseLinker(module.sanitize),
Colin Crossb916a382016-07-29 17:28:03 -07001745 baseInstaller: NewBaseInstaller("lib", "lib64", InstallInSystem),
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001746 sabi: module.sabi,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001747 }
1748
Colin Crossb916a382016-07-29 17:28:03 -07001749 module.compiler = library
1750 module.linker = library
1751 module.installer = library
Colin Cross31076b32020-10-23 17:22:06 -07001752 module.library = library
Colin Crossb916a382016-07-29 17:28:03 -07001753
1754 return module, library
1755}
1756
Colin Cross10d22312017-05-03 11:01:58 -07001757// connects a shared library to a static library in order to reuse its .o files to avoid
1758// compiling source files twice.
1759func reuseStaticLibrary(mctx android.BottomUpMutatorContext, static, shared *Module) {
1760 if staticCompiler, ok := static.compiler.(*libraryDecorator); ok {
1761 sharedCompiler := shared.compiler.(*libraryDecorator)
Dan Willemsen3a26eef2018-12-03 15:25:46 -08001762
1763 // Check libraries in addition to cflags, since libraries may be exporting different
1764 // include directories.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001765 if len(staticCompiler.StaticProperties.Static.Cflags) == 0 &&
1766 len(sharedCompiler.SharedProperties.Shared.Cflags) == 0 &&
1767 len(staticCompiler.StaticProperties.Static.Whole_static_libs) == 0 &&
1768 len(sharedCompiler.SharedProperties.Shared.Whole_static_libs) == 0 &&
1769 len(staticCompiler.StaticProperties.Static.Static_libs) == 0 &&
1770 len(sharedCompiler.SharedProperties.Shared.Static_libs) == 0 &&
1771 len(staticCompiler.StaticProperties.Static.Shared_libs) == 0 &&
1772 len(sharedCompiler.SharedProperties.Shared.Shared_libs) == 0 &&
Martin Stjernholm10566a02020-03-24 01:19:52 +00001773 // Compare System_shared_libs properties with nil because empty lists are
1774 // semantically significant for them.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001775 staticCompiler.StaticProperties.Static.System_shared_libs == nil &&
1776 sharedCompiler.SharedProperties.Shared.System_shared_libs == nil {
Colin Cross10d22312017-05-03 11:01:58 -07001777
1778 mctx.AddInterVariantDependency(reuseObjTag, shared, static)
1779 sharedCompiler.baseCompiler.Properties.OriginalSrcs =
1780 sharedCompiler.baseCompiler.Properties.Srcs
1781 sharedCompiler.baseCompiler.Properties.Srcs = nil
1782 sharedCompiler.baseCompiler.Properties.Generated_sources = nil
1783 }
Colin Cross0de8a1e2020-09-18 14:15:30 -07001784
1785 // This dep is just to reference static variant from shared variant
1786 mctx.AddInterVariantDependency(staticVariantTag, shared, static)
Colin Cross10d22312017-05-03 11:01:58 -07001787 }
1788}
1789
Chris Parsons3c27ca32020-11-20 12:42:07 -05001790// LinkageMutator adds "static" or "shared" variants for modules depending
1791// on whether the module can be built as a static library or a shared library.
Colin Crosse40b4ea2018-10-02 22:25:58 -07001792func LinkageMutator(mctx android.BottomUpMutatorContext) {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001793 ccPrebuilt := false
Colin Crossb916a382016-07-29 17:28:03 -07001794 if m, ok := mctx.Module().(*Module); ok && m.linker != nil {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001795 _, ccPrebuilt = m.linker.(prebuiltLibraryInterface)
Ivan Lozano52767be2019-10-18 14:49:46 -07001796 }
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001797 if ccPrebuilt {
Ivan Lozano52767be2019-10-18 14:49:46 -07001798 library := mctx.Module().(*Module).linker.(prebuiltLibraryInterface)
Colin Cross33b2fb72019-05-14 14:07:01 -07001799
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001800 // Differentiate between header only and building an actual static/shared library
Colin Cross127bb8b2020-12-16 16:46:01 -08001801 buildStatic := library.buildStatic()
1802 buildShared := library.buildShared()
1803 if buildStatic || buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001804 // Always create both the static and shared variants for prebuilt libraries, and then disable the one
1805 // that is not being used. This allows them to share the name of a cc_library module, which requires that
1806 // all the variants of the cc_library also exist on the prebuilt.
1807 modules := mctx.CreateLocalVariations("static", "shared")
1808 static := modules[0].(*Module)
1809 shared := modules[1].(*Module)
Colin Cross33b2fb72019-05-14 14:07:01 -07001810
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001811 static.linker.(prebuiltLibraryInterface).setStatic()
1812 shared.linker.(prebuiltLibraryInterface).setShared()
Colin Cross33b2fb72019-05-14 14:07:01 -07001813
Colin Cross127bb8b2020-12-16 16:46:01 -08001814 if buildShared {
Colin Cross81ca6cd2020-08-06 17:46:48 -07001815 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08001816 } else if buildStatic {
Colin Cross81ca6cd2020-08-06 17:46:48 -07001817 mctx.AliasVariation("static")
1818 }
1819
Colin Cross127bb8b2020-12-16 16:46:01 -08001820 if !buildStatic {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001821 static.linker.(prebuiltLibraryInterface).disablePrebuilt()
1822 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001823 if !buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001824 shared.linker.(prebuiltLibraryInterface).disablePrebuilt()
1825 }
1826 } else {
1827 // Header only
Colin Crossb916a382016-07-29 17:28:03 -07001828 }
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001829
Ivan Lozano52767be2019-10-18 14:49:46 -07001830 } else if library, ok := mctx.Module().(LinkableInterface); ok && library.CcLibraryInterface() {
Ivan Lozano52767be2019-10-18 14:49:46 -07001831
Ivan Lozano2b262972019-11-21 12:30:50 -08001832 // Non-cc.Modules may need an empty variant for their mutators.
1833 variations := []string{}
1834 if library.NonCcVariants() {
1835 variations = append(variations, "")
1836 }
1837
Colin Cross127bb8b2020-12-16 16:46:01 -08001838 isLLNDK := false
1839 if m, ok := mctx.Module().(*Module); ok {
Colin Cross127bb8b2020-12-16 16:46:01 -08001840 // Don't count the vestigial llndk_library module as isLLNDK, it needs a static
1841 // variant so that a cc_library_prebuilt can depend on it.
Colin Cross4f4f8eb2021-01-06 14:07:27 -08001842 isLLNDK = m.IsLlndk() && !isVestigialLLNDKModule(m)
Colin Cross127bb8b2020-12-16 16:46:01 -08001843 }
1844 buildStatic := library.BuildStaticVariant() && !isLLNDK
1845 buildShared := library.BuildSharedVariant()
1846 if buildStatic && buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08001847 variations := append([]string{"static", "shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001848
1849 modules := mctx.CreateLocalVariations(variations...)
1850 static := modules[0].(LinkableInterface)
1851 shared := modules[1].(LinkableInterface)
1852
1853 static.SetStatic()
1854 shared.SetShared()
1855
1856 if _, ok := library.(*Module); ok {
1857 reuseStaticLibrary(mctx, static.(*Module), shared.(*Module))
1858 }
Colin Cross81ca6cd2020-08-06 17:46:48 -07001859 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08001860 } else if buildStatic {
Ivan Lozano2b262972019-11-21 12:30:50 -08001861 variations := append([]string{"static"}, variations...)
1862
1863 modules := mctx.CreateLocalVariations(variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001864 modules[0].(LinkableInterface).SetStatic()
Colin Cross81ca6cd2020-08-06 17:46:48 -07001865 mctx.AliasVariation("static")
Colin Cross127bb8b2020-12-16 16:46:01 -08001866 } else if buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08001867 variations := append([]string{"shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001868
Ivan Lozano2b262972019-11-21 12:30:50 -08001869 modules := mctx.CreateLocalVariations(variations...)
1870 modules[0].(LinkableInterface).SetShared()
Colin Cross81ca6cd2020-08-06 17:46:48 -07001871 mctx.AliasVariation("shared")
Ivan Lozano2b262972019-11-21 12:30:50 -08001872 } else if len(variations) > 0 {
1873 mctx.CreateLocalVariations(variations...)
Colin Cross81ca6cd2020-08-06 17:46:48 -07001874 mctx.AliasVariation(variations[0])
Ivan Lozano2b262972019-11-21 12:30:50 -08001875 }
Colin Crossb916a382016-07-29 17:28:03 -07001876 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001877}
Jiyong Park7ed9de32018-10-15 22:25:07 +09001878
Chris Parsons3c27ca32020-11-20 12:42:07 -05001879// normalizeVersions modifies `versions` in place, so that each raw version
1880// string becomes its normalized canonical form.
1881// Validates that the versions in `versions` are specified in least to greatest order.
Jooyung Hanaed150d2020-04-02 01:41:41 +09001882func normalizeVersions(ctx android.BaseModuleContext, versions []string) {
Dan Albertc8060532020-07-22 22:32:17 -07001883 var previous android.ApiLevel
Jooyung Hanad4c1872020-02-27 17:56:44 +09001884 for i, v := range versions {
Dan Albertc8060532020-07-22 22:32:17 -07001885 ver, err := android.ApiLevelFromUser(ctx, v)
Jooyung Hanad4c1872020-02-27 17:56:44 +09001886 if err != nil {
Jooyung Hanaed150d2020-04-02 01:41:41 +09001887 ctx.PropertyErrorf("versions", "%s", err.Error())
1888 return
Jooyung Hanad4c1872020-02-27 17:56:44 +09001889 }
Dan Albertc8060532020-07-22 22:32:17 -07001890 if i > 0 && ver.LessThanOrEqualTo(previous) {
1891 ctx.PropertyErrorf("versions", "not sorted: %v", versions)
1892 }
1893 versions[i] = ver.String()
1894 previous = ver
Jooyung Hanaed150d2020-04-02 01:41:41 +09001895 }
Jooyung Hanad4c1872020-02-27 17:56:44 +09001896}
1897
Jooyung Han61b66e92020-03-21 14:21:46 +00001898func createVersionVariations(mctx android.BottomUpMutatorContext, versions []string) {
Colin Cross127bb8b2020-12-16 16:46:01 -08001899 // "" is for the non-stubs (implementation) variant for system modules, or the LLNDK variant
1900 // for LLNDK modules.
Colin Cross0de8a1e2020-09-18 14:15:30 -07001901 variants := append(android.CopyOf(versions), "")
Jooyung Han61b66e92020-03-21 14:21:46 +00001902
Colin Cross127bb8b2020-12-16 16:46:01 -08001903 m := mctx.Module().(*Module)
1904 isLLNDK := m.IsLlndk()
1905
Colin Crossd1f898e2020-08-18 18:35:15 -07001906 modules := mctx.CreateLocalVariations(variants...)
Jooyung Han61b66e92020-03-21 14:21:46 +00001907 for i, m := range modules {
Colin Cross127bb8b2020-12-16 16:46:01 -08001908
1909 if variants[i] != "" || isLLNDK {
1910 // A stubs or LLNDK stubs variant.
Colin Cross31076b32020-10-23 17:22:06 -07001911 c := m.(*Module)
Colin Cross31076b32020-10-23 17:22:06 -07001912 c.sanitize = nil
1913 c.stl = nil
1914 c.Properties.PreventInstall = true
1915 lib := moduleLibraryInterface(m)
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001916 isLatest := i == (len(versions) - 1)
1917 lib.setBuildStubs(isLatest)
Colin Cross127bb8b2020-12-16 16:46:01 -08001918
1919 if variants[i] != "" {
1920 // A non-LLNDK stubs module is hidden from make and has a dependency from the
1921 // implementation module to the stubs module.
1922 c.Properties.HideFromMake = true
1923 lib.setStubsVersion(variants[i])
1924 mctx.AddInterVariantDependency(stubImplDepTag, modules[len(modules)-1], modules[i])
1925 }
Jooyung Han61b66e92020-03-21 14:21:46 +00001926 }
1927 }
Colin Cross094faa52020-08-06 17:38:25 -07001928 mctx.AliasVariation("")
Colin Crossd1f898e2020-08-18 18:35:15 -07001929 latestVersion := ""
1930 if len(versions) > 0 {
1931 latestVersion = versions[len(versions)-1]
1932 }
1933 mctx.CreateAliasVariation("latest", latestVersion)
Jooyung Han61b66e92020-03-21 14:21:46 +00001934}
1935
Colin Crossbbc941b2020-09-30 12:27:01 -07001936func createPerApiVersionVariations(mctx android.BottomUpMutatorContext, minSdkVersion string) {
1937 from, err := nativeApiLevelFromUser(mctx, minSdkVersion)
1938 if err != nil {
1939 mctx.PropertyErrorf("min_sdk_version", err.Error())
1940 return
1941 }
1942
1943 versionStrs := ndkLibraryVersions(mctx, from)
1944 modules := mctx.CreateLocalVariations(versionStrs...)
1945
1946 for i, module := range modules {
1947 module.(*Module).Properties.Sdk_version = StringPtr(versionStrs[i])
Jiyong Parkfdaa5f72021-03-19 22:18:04 +09001948 module.(*Module).Properties.Min_sdk_version = StringPtr(versionStrs[i])
Colin Crossbbc941b2020-09-30 12:27:01 -07001949 }
1950}
1951
Colin Cross3146c5c2020-09-30 15:34:40 -07001952func CanBeOrLinkAgainstVersionVariants(module interface {
Jooyung Han624d35c2020-04-10 12:57:24 +09001953 Host() bool
1954 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001955 InVendorRamdisk() bool
Jooyung Han624d35c2020-04-10 12:57:24 +09001956}) bool {
Jose Galmes6f843bc2020-12-11 13:36:29 -08001957 return !module.Host() && !module.InRamdisk() && !module.InVendorRamdisk()
Jooyung Han624d35c2020-04-10 12:57:24 +09001958}
1959
Colin Cross3146c5c2020-09-30 15:34:40 -07001960func CanBeVersionVariant(module interface {
1961 Host() bool
1962 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001963 InVendorRamdisk() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07001964 InRecovery() bool
1965 CcLibraryInterface() bool
1966 Shared() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07001967}) bool {
1968 return CanBeOrLinkAgainstVersionVariants(module) &&
Colin Crossa717db72020-10-23 14:53:06 -07001969 module.CcLibraryInterface() && module.Shared()
Colin Cross3146c5c2020-09-30 15:34:40 -07001970}
1971
Colin Cross127bb8b2020-12-16 16:46:01 -08001972func moduleLibraryInterface(module blueprint.Module) libraryInterface {
Colin Cross31076b32020-10-23 17:22:06 -07001973 if m, ok := module.(*Module); ok {
1974 return m.library
1975 }
1976 return nil
1977}
1978
Colin Crossd1f898e2020-08-18 18:35:15 -07001979// versionSelector normalizes the versions in the Stubs.Versions property into MutatedProperties.AllStubsVersions,
1980// and propagates the value from implementation libraries to llndk libraries with the same name.
1981func versionSelectorMutator(mctx android.BottomUpMutatorContext) {
Colin Cross31076b32020-10-23 17:22:06 -07001982 if library := moduleLibraryInterface(mctx.Module()); library != nil && CanBeVersionVariant(mctx.Module().(*Module)) {
1983 if library.buildShared() {
1984 versions := library.stubsVersions(mctx)
Colin Cross3572cf72020-10-01 15:58:11 -07001985 if len(versions) > 0 {
1986 normalizeVersions(mctx, versions)
1987 if mctx.Failed() {
Colin Crossbbc941b2020-09-30 12:27:01 -07001988 return
1989 }
Colin Cross3572cf72020-10-01 15:58:11 -07001990 // Set the versions on the pre-mutated module so they can be read by any llndk modules that
1991 // depend on the implementation library and haven't been mutated yet.
Colin Cross31076b32020-10-23 17:22:06 -07001992 library.setAllStubsVersions(versions)
Colin Cross127bb8b2020-12-16 16:46:01 -08001993 }
1994
1995 if mctx.Module().(*Module).UseVndk() && library.hasLLNDKStubs() {
1996 // Propagate the version to the llndk stubs module.
1997 mctx.VisitDirectDepsWithTag(llndkStubDepTag, func(stubs android.Module) {
1998 if stubsLib := moduleLibraryInterface(stubs); stubsLib != nil {
1999 stubsLib.setAllStubsVersions(library.allStubsVersions())
2000 }
2001 })
Jiyong Park7ed9de32018-10-15 22:25:07 +09002002 }
Jooyung Han61b66e92020-03-21 14:21:46 +00002003 }
Colin Crossd1f898e2020-08-18 18:35:15 -07002004 }
2005}
Jooyung Han61b66e92020-03-21 14:21:46 +00002006
Colin Crossd1f898e2020-08-18 18:35:15 -07002007// versionMutator splits a module into the mandatory non-stubs variant
2008// (which is unnamed) and zero or more stubs variants.
2009func versionMutator(mctx android.BottomUpMutatorContext) {
Colin Cross31076b32020-10-23 17:22:06 -07002010 if library := moduleLibraryInterface(mctx.Module()); library != nil && CanBeVersionVariant(mctx.Module().(*Module)) {
2011 createVersionVariations(mctx, library.allStubsVersions())
Colin Crossbbc941b2020-09-30 12:27:01 -07002012 return
2013 }
2014
2015 if m, ok := mctx.Module().(*Module); ok {
2016 if m.SplitPerApiLevel() && m.IsSdkVariant() {
2017 if mctx.Os() != android.Android {
2018 return
2019 }
2020 createPerApiVersionVariations(mctx, m.MinSdkVersion())
2021 }
Jiyong Park7ed9de32018-10-15 22:25:07 +09002022 }
Jiyong Park7ed9de32018-10-15 22:25:07 +09002023}
Colin Crossd7227f92019-09-05 14:26:33 -07002024
2025// maybeInjectBoringSSLHash adds a rule to run bssl_inject_hash on the output file if the module has the
2026// inject_bssl_hash or if any static library dependencies have inject_bssl_hash set. It returns the output path
2027// that the linked output file should be written to.
2028// TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
2029func maybeInjectBoringSSLHash(ctx android.ModuleContext, outputFile android.ModuleOutPath,
2030 inject *bool, fileName string) android.ModuleOutPath {
2031 // TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
2032 injectBoringSSLHash := Bool(inject)
2033 ctx.VisitDirectDeps(func(dep android.Module) {
Colin Cross6e511a92020-07-27 21:26:48 -07002034 if tag, ok := ctx.OtherModuleDependencyTag(dep).(libraryDependencyTag); ok && tag.static() {
Colin Crossd7227f92019-09-05 14:26:33 -07002035 if cc, ok := dep.(*Module); ok {
2036 if library, ok := cc.linker.(*libraryDecorator); ok {
2037 if Bool(library.Properties.Inject_bssl_hash) {
2038 injectBoringSSLHash = true
2039 }
2040 }
2041 }
2042 }
2043 })
2044 if injectBoringSSLHash {
2045 hashedOutputfile := outputFile
2046 outputFile = android.PathForModuleOut(ctx, "unhashed", fileName)
2047
Colin Crossf1a035e2020-11-16 17:32:30 -08002048 rule := android.NewRuleBuilder(pctx, ctx)
Colin Crossd7227f92019-09-05 14:26:33 -07002049 rule.Command().
Colin Crossf1a035e2020-11-16 17:32:30 -08002050 BuiltTool("bssl_inject_hash").
Pete Bentley5c4be822019-10-01 17:03:17 +01002051 Flag("-sha256").
Colin Crossd7227f92019-09-05 14:26:33 -07002052 FlagWithInput("-in-object ", outputFile).
2053 FlagWithOutput("-o ", hashedOutputfile)
Colin Crossf1a035e2020-11-16 17:32:30 -08002054 rule.Build("injectCryptoHash", "inject crypto hash")
Colin Crossd7227f92019-09-05 14:26:33 -07002055 }
2056
2057 return outputFile
2058}
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002059
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002060type bazelCcLibraryStaticAttributes struct {
2061 Copts []string
Jingwen Chen07027912021-03-15 06:02:43 -04002062 Srcs bazel.LabelListAttribute
2063 Deps bazel.LabelListAttribute
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002064 Linkstatic bool
Rupert Shuttleworthb8151682021-04-06 20:06:21 +00002065 Includes bazel.StringListAttribute
Jingwen Chen07027912021-03-15 06:02:43 -04002066 Hdrs bazel.LabelListAttribute
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002067}
2068
2069type bazelCcLibraryStatic struct {
2070 android.BazelTargetModuleBase
2071 bazelCcLibraryStaticAttributes
2072}
2073
2074func BazelCcLibraryStaticFactory() android.Module {
2075 module := &bazelCcLibraryStatic{}
2076 module.AddProperties(&module.bazelCcLibraryStaticAttributes)
2077 android.InitBazelTargetModule(module)
2078 return module
2079}
2080
2081func CcLibraryStaticBp2Build(ctx android.TopDownMutatorContext) {
2082 module, ok := ctx.Module().(*Module)
2083 if !ok {
2084 // Not a cc module
2085 return
2086 }
2087 if !module.ConvertWithBp2build(ctx) {
2088 return
2089 }
2090 if ctx.ModuleType() != "cc_library_static" {
2091 return
2092 }
2093
2094 var copts []string
2095 var srcs []string
2096 var includeDirs []string
2097 var localIncludeDirs []string
2098 for _, props := range module.compiler.compilerProps() {
2099 if baseCompilerProps, ok := props.(*BaseCompilerProperties); ok {
2100 copts = baseCompilerProps.Cflags
2101 srcs = baseCompilerProps.Srcs
Rupert Shuttleworthb8151682021-04-06 20:06:21 +00002102 includeDirs = bp2BuildMakePathsRelativeToModule(ctx, baseCompilerProps.Include_dirs)
2103 localIncludeDirs = bp2BuildMakePathsRelativeToModule(ctx, baseCompilerProps.Local_include_dirs)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002104 break
2105 }
2106 }
Rupert Shuttleworthc58d3d22021-04-06 16:37:15 +00002107
2108 // Soong implicitly includes headers from the module's directory.
2109 // For Bazel builds to work we have to make these header includes explicit.
2110 if module.compiler.(*libraryDecorator).includeBuildDirectory() {
2111 localIncludeDirs = append(localIncludeDirs, ".")
2112 }
2113
2114 srcsLabels := android.BazelLabelForModuleSrc(ctx, srcs)
2115
2116 // For Bazel, be more explicit about headers - list all header files in include dirs as srcs
2117 for _, includeDir := range includeDirs {
2118 srcsLabels.Append(bp2BuildListHeadersInDir(ctx, includeDir))
2119 }
2120 for _, localIncludeDir := range localIncludeDirs {
2121 srcsLabels.Append(bp2BuildListHeadersInDir(ctx, localIncludeDir))
2122 }
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002123
2124 var staticLibs []string
2125 var wholeStaticLibs []string
2126 for _, props := range module.linker.linkerProps() {
2127 if baseLinkerProperties, ok := props.(*BaseLinkerProperties); ok {
2128 staticLibs = baseLinkerProperties.Static_libs
2129 wholeStaticLibs = baseLinkerProperties.Whole_static_libs
2130 break
2131 }
2132 }
2133
2134 // FIXME: Treat Static_libs and Whole_static_libs differently?
2135 allDeps := staticLibs
2136 allDeps = append(allDeps, wholeStaticLibs...)
2137
2138 depsLabels := android.BazelLabelForModuleDeps(ctx, allDeps)
2139
Rupert Shuttleworthb8151682021-04-06 20:06:21 +00002140 exportedIncludes, exportedIncludesHeaders := bp2BuildParseExportedIncludes(ctx, module)
2141
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002142 // FIXME: Unify absolute vs relative paths
2143 // FIXME: Use -I copts instead of setting includes= ?
Rupert Shuttleworthb8151682021-04-06 20:06:21 +00002144 allIncludes := exportedIncludes
2145 allIncludes.Value = append(allIncludes.Value, includeDirs...)
2146 allIncludes.Value = append(allIncludes.Value, localIncludeDirs...)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002147
Jingwen Chen91220d72021-03-24 02:18:33 -04002148 headerLibsLabels := bp2BuildParseHeaderLibs(ctx, module)
Jingwen Chen07027912021-03-15 06:02:43 -04002149 depsLabels.Append(headerLibsLabels.Value)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002150
2151 attrs := &bazelCcLibraryStaticAttributes{
2152 Copts: copts,
Rupert Shuttleworthc58d3d22021-04-06 16:37:15 +00002153 Srcs: bazel.MakeLabelListAttribute(srcsLabels),
Jingwen Chen07027912021-03-15 06:02:43 -04002154 Deps: bazel.MakeLabelListAttribute(depsLabels),
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002155 Linkstatic: true,
Rupert Shuttleworthb8151682021-04-06 20:06:21 +00002156 Includes: allIncludes,
2157 Hdrs: exportedIncludesHeaders,
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002158 }
2159
2160 props := bazel.BazelTargetModuleProperties{
2161 Rule_class: "cc_library_static",
2162 Bzl_load_location: "//build/bazel/rules:cc_library_static.bzl",
2163 }
2164
2165 ctx.CreateBazelTargetModule(BazelCcLibraryStaticFactory, module.Name(), props, attrs)
2166}
2167
2168func (m *bazelCcLibraryStatic) Name() string {
2169 return m.BaseModuleName()
2170}
2171
2172func (m *bazelCcLibraryStatic) GenerateAndroidBuildActions(ctx android.ModuleContext) {}