blob: f459e80fff4dbf6b35222c7f2343e2abd12bef35 [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
68 // List versions to generate stubs libs for.
69 Versions []string
70 }
dimitryd95964a2018-11-07 13:43:34 +010071
72 // set the name of the output
73 Stem *string `android:"arch_variant"`
74
Colin Cross0fd6a412019-08-16 14:22:10 -070075 // set suffix of the name of the output
76 Suffix *string `android:"arch_variant"`
77
78 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +090079 Vendor, Product struct {
Colin Cross0fd6a412019-08-16 14:22:10 -070080 // set suffix of the name of the output
81 Suffix *string `android:"arch_variant"`
82 }
83 }
84
dimitryd95964a2018-11-07 13:43:34 +010085 // Names of modules to be overridden. Listed modules can only be other shared libraries
86 // (in Make or Soong).
87 // This does not completely prevent installation of the overridden libraries, but if both
88 // binaries would be installed by default (in PRODUCT_PACKAGES) the other library will be removed
89 // from PRODUCT_PACKAGES.
90 Overrides []string
Logan Chiene3d7a0d2019-01-17 00:18:02 +080091
92 // Properties for ABI compatibility checker
93 Header_abi_checker struct {
Logan Chien41eabe62019-04-10 13:33:58 +080094 // Enable ABI checks (even if this is not an LLNDK/VNDK lib)
95 Enabled *bool
96
Logan Chiene3d7a0d2019-01-17 00:18:02 +080097 // Path to a symbol file that specifies the symbols to be included in the generated
98 // ABI dump file
Colin Cross27b922f2019-03-04 22:35:41 -080099 Symbol_file *string `android:"path"`
Logan Chiene3d7a0d2019-01-17 00:18:02 +0800100
101 // Symbol versions that should be ignored from the symbol file
102 Exclude_symbol_versions []string
103
104 // Symbol tags that should be ignored from the symbol file
105 Exclude_symbol_tags []string
Logan Chien2a65dda2019-10-01 15:58:07 -0700106
107 // Run checks on all APIs (in addition to the ones referred by
108 // one of exported ELF symbols.)
109 Check_all_apis *bool
Logan Chiene3d7a0d2019-01-17 00:18:02 +0800110 }
Vic Yang6cd1be82019-06-24 16:08:48 -0700111
112 // Order symbols in .bss section by their sizes. Only useful for shared libraries.
113 Sort_bss_symbols_by_size *bool
Pete Bentley803e1612019-08-06 22:19:59 +0100114
115 // Inject boringssl hash into the shared library. This is only intended for use by external/boringssl.
116 Inject_bssl_hash *bool `android:"arch_variant"`
Colin Cross0477b422020-10-13 18:43:54 -0700117
118 // If this is an LLNDK library, the name of the equivalent llndk_library module.
119 Llndk_stubs *string
Colin Cross127bb8b2020-12-16 16:46:01 -0800120
121 // If this is an LLNDK library, properties to describe the LLNDK stubs. Will be copied from
122 // the module pointed to by llndk_stubs if it is set.
123 Llndk llndkLibraryProperties
Colin Crossa48ab5b2017-02-14 15:28:44 -0800124}
Colin Cross0c461f12016-10-20 16:11:43 -0700125
Chris Parsons3c27ca32020-11-20 12:42:07 -0500126// StaticProperties is a properties stanza to affect only attributes of the "static" variants of a
127// library module.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700128type StaticProperties struct {
129 Static StaticOrSharedProperties `android:"arch_variant"`
130}
131
Chris Parsons3c27ca32020-11-20 12:42:07 -0500132// SharedProperties is a properties stanza to affect only attributes of the "shared" variants of a
133// library module.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700134type SharedProperties struct {
135 Shared StaticOrSharedProperties `android:"arch_variant"`
136}
137
Chris Parsons3c27ca32020-11-20 12:42:07 -0500138// StaticOrSharedProperties is an embedded struct representing properties to affect attributes of
139// either only the "static" variants or only the "shared" variants of a library module. These override
140// the base properties of the same name.
141// Use `StaticProperties` or `SharedProperties`, depending on which variant is needed.
142// `StaticOrSharedProperties` exists only to avoid duplication.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700143type StaticOrSharedProperties struct {
Evgenii Stepanov2080bfe2020-07-24 15:35:40 -0700144 Srcs []string `android:"path,arch_variant"`
145
146 Sanitized Sanitized `android:"arch_variant"`
147
Colin Crosse1bb5d02019-09-24 14:55:04 -0700148 Cflags []string `android:"arch_variant"`
149
150 Enabled *bool `android:"arch_variant"`
151 Whole_static_libs []string `android:"arch_variant"`
152 Static_libs []string `android:"arch_variant"`
153 Shared_libs []string `android:"arch_variant"`
154 System_shared_libs []string `android:"arch_variant"`
155
156 Export_shared_lib_headers []string `android:"arch_variant"`
157 Export_static_lib_headers []string `android:"arch_variant"`
Jiyong Parka90ca002019-10-07 15:47:24 +0900158
159 Apex_available []string `android:"arch_variant"`
Colin Crosse1bb5d02019-09-24 14:55:04 -0700160}
161
Colin Crossa48ab5b2017-02-14 15:28:44 -0800162type LibraryMutatedProperties struct {
Colin Crossb916a382016-07-29 17:28:03 -0700163 // Build a static variant
164 BuildStatic bool `blueprint:"mutated"`
165 // Build a shared variant
166 BuildShared bool `blueprint:"mutated"`
167 // This variant is shared
168 VariantIsShared bool `blueprint:"mutated"`
169 // This variant is static
170 VariantIsStatic bool `blueprint:"mutated"`
Jiyong Park7ed9de32018-10-15 22:25:07 +0900171
172 // This variant is a stubs lib
173 BuildStubs bool `blueprint:"mutated"`
174 // Version of the stubs lib
175 StubsVersion string `blueprint:"mutated"`
Colin Crossd1f898e2020-08-18 18:35:15 -0700176 // List of all stubs versions associated with an implementation lib
177 AllStubsVersions []string `blueprint:"mutated"`
Colin Crossb916a382016-07-29 17:28:03 -0700178}
179
180type FlagExporterProperties struct {
181 // list of directories relative to the Blueprints file that will
Dan Willemsen273af7f2016-11-03 15:53:42 -0700182 // be added to the include path (using -I) for this module and any module that links
Colin Cross5d195602017-10-17 16:15:50 -0700183 // against this module. Directories listed in export_include_dirs do not need to be
184 // listed in local_include_dirs.
Colin Crossb916a382016-07-29 17:28:03 -0700185 Export_include_dirs []string `android:"arch_variant"`
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700186
Jiyong Park73c54ee2019-10-22 20:31:18 +0900187 // list of directories that will be added to the system include path
188 // using -isystem for this module and any module that links against this module.
189 Export_system_include_dirs []string `android:"arch_variant"`
190
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700191 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +0900192 Vendor, Product struct {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700193 // list of exported include directories, like
Justin Yun63e9ec72020-10-29 16:49:43 +0900194 // export_include_dirs, that will be applied to
195 // vendor or product variant of this library.
196 // This will overwrite any other declarations.
Steven Morelandb21df8f2018-01-05 14:42:54 -0800197 Override_export_include_dirs []string
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700198 }
199 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700200}
201
202func init() {
Paul Duffin6c26dc72019-12-19 15:02:40 +0000203 RegisterLibraryBuildComponents(android.InitRegistrationContext)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +0000204
205 android.RegisterBp2BuildMutator("cc_library_static", CcLibraryStaticBp2Build)
Paul Duffin6c26dc72019-12-19 15:02:40 +0000206}
207
208func RegisterLibraryBuildComponents(ctx android.RegistrationContext) {
209 ctx.RegisterModuleType("cc_library_static", LibraryStaticFactory)
210 ctx.RegisterModuleType("cc_library_shared", LibrarySharedFactory)
211 ctx.RegisterModuleType("cc_library", LibraryFactory)
212 ctx.RegisterModuleType("cc_library_host_static", LibraryHostStaticFactory)
213 ctx.RegisterModuleType("cc_library_host_shared", LibraryHostSharedFactory)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700214}
215
Patrice Arruda83c89e02019-03-25 15:32:39 -0700216// cc_library creates both static and/or shared libraries for a device and/or
217// host. By default, a cc_library has a single variant that targets the device.
218// Specifying `host_supported: true` also creates a library that targets the
219// host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700220func LibraryFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800221 module, _ := NewLibrary(android.HostAndDeviceSupported)
Paul Duffina0843f62019-12-13 19:50:38 +0000222 // Can be used as both a static and a shared library.
223 module.sdkMemberTypes = []android.SdkMemberType{
224 sharedLibrarySdkMemberType,
225 staticLibrarySdkMemberType,
Paul Duffin9b76c0b2020-03-12 10:24:35 +0000226 staticAndSharedLibrarySdkMemberType,
Paul Duffina0843f62019-12-13 19:50:38 +0000227 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700228 return module.Init()
229}
230
Patrice Arruda83c89e02019-03-25 15:32:39 -0700231// cc_library_static creates a static library for a device and/or host binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700232func LibraryStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800233 module, library := NewLibrary(android.HostAndDeviceSupported)
234 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000235 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Chris Parsons808d84c2021-03-09 20:43:32 -0500236 module.bazelHandler = &staticLibraryBazelHandler{module: module}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700237 return module.Init()
238}
239
Patrice Arruda83c89e02019-03-25 15:32:39 -0700240// cc_library_shared creates a shared library for a device and/or host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700241func LibrarySharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800242 module, library := NewLibrary(android.HostAndDeviceSupported)
243 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000244 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700245 return module.Init()
246}
247
Patrice Arruda83c89e02019-03-25 15:32:39 -0700248// cc_library_host_static creates a static library that is linkable to a host
249// binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700250func LibraryHostStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800251 module, library := NewLibrary(android.HostSupported)
252 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000253 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700254 return module.Init()
255}
256
Patrice Arruda83c89e02019-03-25 15:32:39 -0700257// cc_library_host_shared creates a shared library that is usable on a host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700258func LibraryHostSharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800259 module, library := NewLibrary(android.HostSupported)
260 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000261 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700262 return module.Init()
263}
264
Chris Parsons3c27ca32020-11-20 12:42:07 -0500265// flagExporter is a separated portion of libraryDecorator pertaining to exported
266// include paths and flags. Keeping this dependency-related information separate
267// from the rest of library information is helpful in keeping data more structured
268// and explicit.
Colin Cross4d9c2d12016-07-29 12:48:20 -0700269type flagExporter struct {
270 Properties FlagExporterProperties
271
Chris Parsons3c27ca32020-11-20 12:42:07 -0500272 dirs android.Paths // Include directories to be included with -I
273 systemDirs android.Paths // System include directories to be included with -isystem
274 flags []string // Exported raw flags.
Inseob Kim69378442019-06-03 19:10:47 +0900275 deps android.Paths
Inseob Kimd110f872019-12-06 13:15:38 +0900276 headers android.Paths
Colin Cross4d9c2d12016-07-29 12:48:20 -0700277}
278
Chris Parsons3c27ca32020-11-20 12:42:07 -0500279// exportedIncludes returns the effective include paths for this module and
280// any module that links against this module. This is obtained from
281// the export_include_dirs property in the appropriate target stanza.
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700282func (f *flagExporter) exportedIncludes(ctx ModuleContext) android.Paths {
Justin Yun6977e8a2020-10-29 18:24:11 +0900283 if ctx.inVendor() && f.Properties.Target.Vendor.Override_export_include_dirs != nil {
Steven Morelandb21df8f2018-01-05 14:42:54 -0800284 return android.PathsForModuleSrc(ctx, f.Properties.Target.Vendor.Override_export_include_dirs)
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700285 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900286 if ctx.inProduct() && f.Properties.Target.Product.Override_export_include_dirs != nil {
287 return android.PathsForModuleSrc(ctx, f.Properties.Target.Product.Override_export_include_dirs)
288 }
289 return android.PathsForModuleSrc(ctx, f.Properties.Export_include_dirs)
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700290}
291
Chris Parsons3c27ca32020-11-20 12:42:07 -0500292// exportIncludes registers the include directories and system include directories to be exported
293// transitively to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900294func (f *flagExporter) exportIncludes(ctx ModuleContext) {
Jiyong Park74955042019-10-22 20:19:51 +0900295 f.dirs = append(f.dirs, f.exportedIncludes(ctx)...)
Jiyong Park73c54ee2019-10-22 20:31:18 +0900296 f.systemDirs = append(f.systemDirs, android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700297}
298
Chris Parsons3c27ca32020-11-20 12:42:07 -0500299// exportIncludesAsSystem registers the include directories and system include directories to be
300// exported transitively both as system include directories to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900301func (f *flagExporter) exportIncludesAsSystem(ctx ModuleContext) {
Jiyong Park73c54ee2019-10-22 20:31:18 +0900302 // all dirs are force exported as system
Jiyong Park74955042019-10-22 20:19:51 +0900303 f.systemDirs = append(f.systemDirs, f.exportedIncludes(ctx)...)
Jiyong Park73c54ee2019-10-22 20:31:18 +0900304 f.systemDirs = append(f.systemDirs, android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)...)
Inseob Kim69378442019-06-03 19:10:47 +0900305}
306
Chris Parsons3c27ca32020-11-20 12:42:07 -0500307// reexportDirs registers the given directories as include directories to be exported transitively
308// to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900309func (f *flagExporter) reexportDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900310 f.dirs = append(f.dirs, dirs...)
311}
312
Chris Parsons3c27ca32020-11-20 12:42:07 -0500313// reexportSystemDirs registers the given directories as system include directories
314// to be exported transitively to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900315func (f *flagExporter) reexportSystemDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900316 f.systemDirs = append(f.systemDirs, dirs...)
317}
318
Chris Parsons3c27ca32020-11-20 12:42:07 -0500319// reexportFlags registers the flags to be exported transitively to modules depending on this
320// module.
Inseob Kim69378442019-06-03 19:10:47 +0900321func (f *flagExporter) reexportFlags(flags ...string) {
Jaewoong Jung3aff5782020-02-11 07:54:35 -0800322 if android.PrefixInList(flags, "-I") || android.PrefixInList(flags, "-isystem") {
323 panic(fmt.Errorf("Exporting invalid flag %q: "+
324 "use reexportDirs or reexportSystemDirs to export directories", flag))
Inseob Kim69378442019-06-03 19:10:47 +0900325 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700326 f.flags = append(f.flags, flags...)
327}
328
Inseob Kim69378442019-06-03 19:10:47 +0900329func (f *flagExporter) reexportDeps(deps ...android.Path) {
330 f.deps = append(f.deps, deps...)
331}
332
Inseob Kimd110f872019-12-06 13:15:38 +0900333// addExportedGeneratedHeaders does nothing but collects generated header files.
334// This can be differ to exportedDeps which may contain phony files to minimize ninja.
335func (f *flagExporter) addExportedGeneratedHeaders(headers ...android.Path) {
336 f.headers = append(f.headers, headers...)
337}
338
Colin Cross0de8a1e2020-09-18 14:15:30 -0700339func (f *flagExporter) setProvider(ctx android.ModuleContext) {
340 ctx.SetProvider(FlagExporterInfoProvider, FlagExporterInfo{
341 IncludeDirs: f.dirs,
342 SystemIncludeDirs: f.systemDirs,
343 Flags: f.flags,
344 Deps: f.deps,
345 GeneratedHeaders: f.headers,
346 })
Inseob Kim69378442019-06-03 19:10:47 +0900347}
348
Colin Crossb916a382016-07-29 17:28:03 -0700349// libraryDecorator wraps baseCompiler, baseLinker and baseInstaller to provide library-specific
350// functionality: static vs. shared linkage, reusing object files for shared libraries
351type libraryDecorator struct {
Colin Crossa48ab5b2017-02-14 15:28:44 -0800352 Properties LibraryProperties
Colin Crosse1bb5d02019-09-24 14:55:04 -0700353 StaticProperties StaticProperties
354 SharedProperties SharedProperties
Colin Crossa48ab5b2017-02-14 15:28:44 -0800355 MutatedProperties LibraryMutatedProperties
Colin Cross4d9c2d12016-07-29 12:48:20 -0700356
357 // For reusing static library objects for shared library
Inseob Kim69378442019-06-03 19:10:47 +0900358 reuseObjects Objects
Colin Cross10d22312017-05-03 11:01:58 -0700359
Colin Cross26c34ed2016-09-30 17:10:16 -0700360 // table-of-contents file to optimize out relinking when possible
361 tocFile android.OptionalPath
Colin Cross4d9c2d12016-07-29 12:48:20 -0700362
Colin Cross4d9c2d12016-07-29 12:48:20 -0700363 flagExporter
Thiébaud Weksteend4587452020-08-19 14:53:01 +0200364 stripper Stripper
Colin Cross4d9c2d12016-07-29 12:48:20 -0700365
Colin Cross4d9c2d12016-07-29 12:48:20 -0700366 // For whole_static_libs
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700367 objects Objects
Colin Cross4d9c2d12016-07-29 12:48:20 -0700368
369 // Uses the module's name if empty, but can be overridden. Does not include
370 // shlib suffix.
371 libName string
Colin Crossb916a382016-07-29 17:28:03 -0700372
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800373 sabi *sabi
374
Dan Willemsen581341d2017-02-09 16:16:31 -0800375 // Output archive of gcno coverage information files
376 coverageOutputFile android.OptionalPath
377
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800378 // linked Source Abi Dump
379 sAbiOutputFile android.OptionalPath
380
381 // Source Abi Diff
382 sAbiDiff android.OptionalPath
383
Colin Cross0875c522017-11-28 17:34:01 -0800384 // Location of the static library in the sysroot. Empty if the library is
385 // not included in the NDK.
386 ndkSysrootPath android.Path
387
Colin Crossb60190a2018-09-04 16:28:17 -0700388 // Location of the linked, unstripped library for shared libraries
389 unstrippedOutputFile android.Path
390
Dan Willemsen569edc52018-11-19 09:33:29 -0800391 // Location of the file that should be copied to dist dir when requested
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000392 distFile android.Path
Dan Willemsen569edc52018-11-19 09:33:29 -0800393
Colin Cross8e21aa52020-09-28 18:28:02 -0700394 versionScriptPath android.OptionalPath
Jiyong Park7ed9de32018-10-15 22:25:07 +0900395
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800396 postInstallCmds []string
Jiyong Parkf1194352019-02-25 11:05:47 +0900397
Vic Yangefd249e2018-11-12 20:19:56 -0800398 // If useCoreVariant is true, the vendor variant of a VNDK library is
399 // not installed.
Vic Yangd92090f2020-01-08 14:32:28 -0800400 useCoreVariant bool
401 checkSameCoreVariant bool
Vic Yangefd249e2018-11-12 20:19:56 -0800402
Colin Cross5ec407b2020-09-30 11:41:33 -0700403 skipAPIDefine bool
404
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100405 // Decorated interfaces
Colin Crossb916a382016-07-29 17:28:03 -0700406 *baseCompiler
407 *baseLinker
408 *baseInstaller
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900409
410 collectedSnapshotHeaders android.Paths
411}
412
Chris Parsons808d84c2021-03-09 20:43:32 -0500413type staticLibraryBazelHandler struct {
414 bazelHandler
415
416 module *Module
417}
418
419func (handler *staticLibraryBazelHandler) generateBazelBuildActions(ctx android.ModuleContext, label string) bool {
420 bazelCtx := ctx.Config().BazelContext
Chris Parsons944e7d02021-03-11 11:08:46 -0500421 outputPaths, objPaths, ok := bazelCtx.GetOutputFilesAndCcObjectFiles(label, ctx.Arch().ArchType)
422 if !ok {
423 return ok
Chris Parsons808d84c2021-03-09 20:43:32 -0500424 }
Chris Parsons944e7d02021-03-11 11:08:46 -0500425 if len(outputPaths) != 1 {
426 // TODO(cparsons): This is actually expected behavior for static libraries with no srcs.
427 // We should support this.
428 ctx.ModuleErrorf("expected exactly one output file for '%s', but got %s", label, objPaths)
429 return false
430 }
431 outputFilePath := android.PathForBazelOut(ctx, outputPaths[0])
432 handler.module.outputFile = android.OptionalPathForPath(outputFilePath)
433
434 objFiles := make(android.Paths, len(objPaths))
435 for i, objPath := range objPaths {
436 objFiles[i] = android.PathForBazelOut(ctx, objPath)
437 }
438 objects := Objects{
439 objFiles: objFiles,
440 }
441
442 ctx.SetProvider(StaticLibraryInfoProvider, StaticLibraryInfo{
443 StaticLibrary: outputFilePath,
444 ReuseObjects: objects,
445 Objects: objects,
446
447 // TODO(cparsons): Include transitive static libraries in this provider to support
448 // static libraries with deps.
449 TransitiveStaticLibrariesForOrdering: android.NewDepSetBuilder(android.TOPOLOGICAL).
450 Direct(outputFilePath).
451 Build(),
452 })
453 handler.module.outputFile = android.OptionalPathForPath(android.PathForBazelOut(ctx, objPaths[0]))
Chris Parsons808d84c2021-03-09 20:43:32 -0500454 return ok
455}
456
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900457// collectHeadersForSnapshot collects all exported headers from library.
458// It globs header files in the source tree for exported include directories,
459// and tracks generated header files separately.
460//
461// This is to be called from GenerateAndroidBuildActions, and then collected
462// header files can be retrieved by snapshotHeaders().
463func (l *libraryDecorator) collectHeadersForSnapshot(ctx android.ModuleContext) {
464 ret := android.Paths{}
465
466 // Headers in the source tree should be globbed. On the contrast, generated headers
467 // can't be globbed, and they should be manually collected.
468 // So, we first filter out intermediate directories (which contains generated headers)
469 // from exported directories, and then glob headers under remaining directories.
Colin Cross0de8a1e2020-09-18 14:15:30 -0700470 for _, path := range append(android.CopyOfPaths(l.flagExporter.dirs), l.flagExporter.systemDirs...) {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900471 dir := path.String()
472 // Skip if dir is for generated headers
473 if strings.HasPrefix(dir, android.PathForOutput(ctx).String()) {
474 continue
475 }
Inseob Kim04f2d6a2020-05-29 22:30:58 +0900476 // libeigen wrongly exports the root directory "external/eigen". But only two
477 // subdirectories "Eigen" and "unsupported" contain exported header files. Even worse
478 // some of them have no extension. So we need special treatment for libeigen in order
479 // to glob correctly.
480 if dir == "external/eigen" {
481 // Only these two directories contains exported headers.
482 for _, subdir := range []string{"Eigen", "unsupported/Eigen"} {
483 glob, err := ctx.GlobWithDeps("external/eigen/"+subdir+"/**/*", nil)
484 if err != nil {
485 ctx.ModuleErrorf("glob failed: %#v", err)
486 return
487 }
488 for _, header := range glob {
489 if strings.HasSuffix(header, "/") {
490 continue
491 }
492 ext := filepath.Ext(header)
493 if ext != "" && ext != ".h" {
494 continue
495 }
496 ret = append(ret, android.PathForSource(ctx, header))
497 }
498 }
499 continue
500 }
Colin Crossec118d02021-01-22 18:05:59 +0000501 glob, err := ctx.GlobWithDeps(dir+"/**/*", nil)
502 if err != nil {
503 ctx.ModuleErrorf("glob failed: %#v", err)
504 return
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900505 }
Colin Crossec118d02021-01-22 18:05:59 +0000506 isLibcxx := strings.HasPrefix(dir, "external/libcxx/include")
Jose Galmes0d736912021-03-30 11:00:06 -0700507 for _, header := range glob {
Colin Crossec118d02021-01-22 18:05:59 +0000508 if isLibcxx {
509 // Glob all files under this special directory, because of C++ headers with no
510 // extension.
Jose Galmes0d736912021-03-30 11:00:06 -0700511 if strings.HasSuffix(header, "/") {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900512 continue
513 }
Colin Crossec118d02021-01-22 18:05:59 +0000514 } else {
515 // Filter out only the files with extensions that are headers.
516 found := false
517 for _, ext := range headerExts {
518 if strings.HasSuffix(header, ext) {
519 found = true
520 break
521 }
522 }
523 if !found {
524 continue
525 }
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900526 }
Jose Galmes0d736912021-03-30 11:00:06 -0700527 ret = append(ret, android.PathForSource(ctx, header))
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900528 }
529 }
530
531 // Collect generated headers
Colin Cross0de8a1e2020-09-18 14:15:30 -0700532 for _, header := range append(android.CopyOfPaths(l.flagExporter.headers), l.flagExporter.deps...) {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900533 // TODO(b/148123511): remove exportedDeps after cleaning up genrule
534 if strings.HasSuffix(header.Base(), "-phony") {
535 continue
536 }
537 ret = append(ret, header)
538 }
539
540 l.collectedSnapshotHeaders = ret
541}
542
543// This returns all exported header files, both generated ones and headers from source tree.
544// collectHeadersForSnapshot() must be called before calling this.
545func (l *libraryDecorator) snapshotHeaders() android.Paths {
546 if l.collectedSnapshotHeaders == nil {
547 panic("snapshotHeaders() must be called after collectHeadersForSnapshot()")
548 }
549 return l.collectedSnapshotHeaders
Colin Cross4d9c2d12016-07-29 12:48:20 -0700550}
551
Chris Parsons3c27ca32020-11-20 12:42:07 -0500552// linkerProps returns the list of properties structs relevant for this library. (For example, if
553// the library is cc_shared_library, then static-library properties are omitted.)
Colin Crossb916a382016-07-29 17:28:03 -0700554func (library *libraryDecorator) linkerProps() []interface{} {
555 var props []interface{}
556 props = append(props, library.baseLinker.linkerProps()...)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700557 props = append(props,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700558 &library.Properties,
Colin Crossa48ab5b2017-02-14 15:28:44 -0800559 &library.MutatedProperties,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700560 &library.flagExporter.Properties,
Colin Cross22f37952018-09-05 10:43:13 -0700561 &library.stripper.StripProperties)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700562
563 if library.MutatedProperties.BuildShared {
564 props = append(props, &library.SharedProperties)
565 }
566 if library.MutatedProperties.BuildStatic {
567 props = append(props, &library.StaticProperties)
568 }
569
570 return props
Colin Cross4d9c2d12016-07-29 12:48:20 -0700571}
572
Chris Parsons3c27ca32020-11-20 12:42:07 -0500573// linkerFlags takes a Flags struct and augments it to contain linker flags that are defined by this
574// library, or that are implied by attributes of this library (such as whether this library is a
575// shared library).
Colin Crossb916a382016-07-29 17:28:03 -0700576func (library *libraryDecorator) linkerFlags(ctx ModuleContext, flags Flags) Flags {
Colin Cross42742b82016-08-01 13:20:05 -0700577 flags = library.baseLinker.linkerFlags(ctx, flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700578
Colin Crossb916a382016-07-29 17:28:03 -0700579 // MinGW spits out warnings about -fPIC even for -fpie?!) being ignored because
580 // all code is position independent, and then those warnings get promoted to
581 // errors.
Colin Cross3edeee12017-04-04 12:59:48 -0700582 if !ctx.Windows() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800583 flags.Global.CFlags = append(flags.Global.CFlags, "-fPIC")
Colin Crossb916a382016-07-29 17:28:03 -0700584 }
585
586 if library.static() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800587 flags.Local.CFlags = append(flags.Local.CFlags, library.StaticProperties.Static.Cflags...)
Colin Crossa48ab5b2017-02-14 15:28:44 -0800588 } else if library.shared() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800589 flags.Local.CFlags = append(flags.Local.CFlags, library.SharedProperties.Shared.Cflags...)
Colin Crossb916a382016-07-29 17:28:03 -0700590 }
591
Colin Crossa48ab5b2017-02-14 15:28:44 -0800592 if library.shared() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700593 libName := library.getLibName(ctx)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700594 var f []string
Dan Willemsen01a405a2016-06-13 17:19:03 -0700595 if ctx.toolchain().Bionic() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700596 f = append(f,
597 "-nostdlib",
598 "-Wl,--gc-sections",
599 )
600 }
601
602 if ctx.Darwin() {
603 f = append(f,
604 "-dynamiclib",
605 "-single_module",
Colin Cross4d9c2d12016-07-29 12:48:20 -0700606 "-install_name @rpath/"+libName+flags.Toolchain.ShlibSuffix(),
607 )
Colin Cross7863cf52016-10-20 10:47:21 -0700608 if ctx.Arch().ArchType == android.X86 {
609 f = append(f,
610 "-read_only_relocs suppress",
611 )
612 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700613 } else {
Josh Gao75a50a22019-06-07 17:58:59 -0700614 f = append(f, "-shared")
615 if !ctx.Windows() {
616 f = append(f, "-Wl,-soname,"+libName+flags.Toolchain.ShlibSuffix())
617 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700618 }
619
Colin Cross4af21ed2019-11-04 09:37:55 -0800620 flags.Global.LdFlags = append(flags.Global.LdFlags, f...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700621 }
622
623 return flags
624}
625
Chris Parsons3c27ca32020-11-20 12:42:07 -0500626// compilerFlags takes a Flags and augments it to contain compile flags from global values,
627// per-target values, module type values, per-module Blueprints properties, extra flags from
628// `flags`, and generated sources from `deps`.
Colin Crossf18e1102017-11-16 14:33:08 -0800629func (library *libraryDecorator) compilerFlags(ctx ModuleContext, flags Flags, deps PathDeps) Flags {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700630 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700631 if len(exportIncludeDirs) > 0 {
Colin Crossdad8c952017-04-26 14:55:27 -0700632 f := includeDirsToFlags(exportIncludeDirs)
Colin Cross4af21ed2019-11-04 09:37:55 -0800633 flags.Local.CommonFlags = append(flags.Local.CommonFlags, f)
634 flags.Local.YasmFlags = append(flags.Local.YasmFlags, f)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700635 }
636
Jiyong Park7ed9de32018-10-15 22:25:07 +0900637 flags = library.baseCompiler.compilerFlags(ctx, flags, deps)
Colin Cross127bb8b2020-12-16 16:46:01 -0800638 if ctx.IsLlndk() {
639 // LLNDK libraries ignore most of the properties on the cc_library and use the
640 // LLNDK-specific properties instead.
641 // Wipe all the module-local properties, leaving only the global properties.
642 flags.Local = LocalOrGlobalFlags{}
643 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900644 if library.buildStubs() {
Jiyong Park64379952018-12-13 18:37:29 +0900645 // Remove -include <file> when compiling stubs. Otherwise, the force included
646 // headers might cause conflicting types error with the symbols in the
647 // generated stubs source code. e.g.
648 // double acos(double); // in header
649 // void acos() {} // in the generated source code
650 removeInclude := func(flags []string) []string {
651 ret := flags[:0]
652 for _, f := range flags {
653 if strings.HasPrefix(f, "-include ") {
654 continue
655 }
656 ret = append(ret, f)
657 }
658 return ret
659 }
Colin Cross4af21ed2019-11-04 09:37:55 -0800660 flags.Local.CommonFlags = removeInclude(flags.Local.CommonFlags)
661 flags.Local.CFlags = removeInclude(flags.Local.CFlags)
Jiyong Park64379952018-12-13 18:37:29 +0900662
Jiyong Park7ed9de32018-10-15 22:25:07 +0900663 flags = addStubLibraryCompilerFlags(flags)
664 }
665 return flags
Dan Willemsen273af7f2016-11-03 15:53:42 -0700666}
667
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800668func (library *libraryDecorator) headerAbiCheckerEnabled() bool {
669 return Bool(library.Properties.Header_abi_checker.Enabled)
Hsin-Yi Chen53489642019-07-31 17:10:45 +0800670}
671
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800672func (library *libraryDecorator) headerAbiCheckerExplicitlyDisabled() bool {
673 return !BoolDefault(library.Properties.Header_abi_checker.Enabled, true)
Logan Chien41eabe62019-04-10 13:33:58 +0800674}
675
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700676func (library *libraryDecorator) compile(ctx ModuleContext, flags Flags, deps PathDeps) Objects {
Colin Cross127bb8b2020-12-16 16:46:01 -0800677 if ctx.IsLlndk() {
678 // This is the vendor variant of an LLNDK library, build the LLNDK stubs.
679 vndkVer := ctx.Module().(*Module).VndkVersion()
680 if !inList(vndkVer, ctx.Config().PlatformVersionActiveCodenames()) || vndkVer == "" {
681 // For non-enforcing devices, vndkVer is empty. Use "current" in that case, too.
682 vndkVer = "current"
683 }
684 if library.stubsVersion() != "" {
685 vndkVer = library.stubsVersion()
686 }
687 objs, versionScript := compileStubLibrary(ctx, flags, String(library.Properties.Llndk.Symbol_file), vndkVer, "--llndk")
688 if !Bool(library.Properties.Llndk.Unversioned) {
689 library.versionScriptPath = android.OptionalPathForPath(versionScript)
690 }
691 return objs
692 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900693 if library.buildStubs() {
Jiyong Parka4175572021-02-04 21:05:47 +0900694 symbolFile := String(library.Properties.Stubs.Symbol_file)
695 if symbolFile != "" && !strings.HasSuffix(symbolFile, ".map.txt") {
696 ctx.PropertyErrorf("symbol_file", "%q doesn't have .map.txt suffix", symbolFile)
697 return Objects{}
698 }
Jiyong Park3fd0baf2018-12-07 16:25:39 +0900699 objs, versionScript := compileStubLibrary(ctx, flags, String(library.Properties.Stubs.Symbol_file), library.MutatedProperties.StubsVersion, "--apex")
Colin Cross8e21aa52020-09-28 18:28:02 -0700700 library.versionScriptPath = android.OptionalPathForPath(versionScript)
Jiyong Park7ed9de32018-10-15 22:25:07 +0900701 return objs
702 }
703
Colin Cross5950f382016-12-13 12:50:57 -0800704 if !library.buildShared() && !library.buildStatic() {
705 if len(library.baseCompiler.Properties.Srcs) > 0 {
706 ctx.PropertyErrorf("srcs", "cc_library_headers must not have any srcs")
707 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700708 if len(library.StaticProperties.Static.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800709 ctx.PropertyErrorf("static.srcs", "cc_library_headers must not have any srcs")
710 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700711 if len(library.SharedProperties.Shared.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800712 ctx.PropertyErrorf("shared.srcs", "cc_library_headers must not have any srcs")
713 }
714 return Objects{}
715 }
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800716 if library.sabi.shouldCreateSourceAbiDump() {
Jayant Chowdharya4fce192017-09-06 13:10:03 -0700717 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800718 var SourceAbiFlags []string
719 for _, dir := range exportIncludeDirs.Strings() {
Jayant Chowdhary715cac32017-04-20 06:53:59 -0700720 SourceAbiFlags = append(SourceAbiFlags, "-I"+dir)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800721 }
Inseob Kim69378442019-06-03 19:10:47 +0900722 for _, reexportedInclude := range library.sabi.Properties.ReexportedIncludes {
723 SourceAbiFlags = append(SourceAbiFlags, "-I"+reexportedInclude)
Jayant Chowdhary715cac32017-04-20 06:53:59 -0700724 }
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800725 flags.SAbiFlags = SourceAbiFlags
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800726 totalLength := len(library.baseCompiler.Properties.Srcs) + len(deps.GeneratedSources) +
Colin Crosse1bb5d02019-09-24 14:55:04 -0700727 len(library.SharedProperties.Shared.Srcs) + len(library.StaticProperties.Static.Srcs)
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800728 if totalLength > 0 {
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800729 flags.SAbiDump = true
730 }
731 }
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700732 objs := library.baseCompiler.compile(ctx, flags, deps)
733 library.reuseObjects = objs
Colin Cross2f336352016-10-26 10:03:47 -0700734 buildFlags := flagsToBuilderFlags(flags)
Colin Crossb916a382016-07-29 17:28:03 -0700735
Colin Cross4d9c2d12016-07-29 12:48:20 -0700736 if library.static() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700737 srcs := android.PathsForModuleSrc(ctx, library.StaticProperties.Static.Srcs)
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700738 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceStaticLibrary,
Pirama Arumuga Nainarf231b192018-01-23 10:49:04 -0800739 srcs, library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossa48ab5b2017-02-14 15:28:44 -0800740 } else if library.shared() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700741 srcs := android.PathsForModuleSrc(ctx, library.SharedProperties.Shared.Srcs)
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700742 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceSharedLibrary,
Pirama Arumuga Nainarf231b192018-01-23 10:49:04 -0800743 srcs, library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossb916a382016-07-29 17:28:03 -0700744 }
745
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700746 return objs
Colin Crossb916a382016-07-29 17:28:03 -0700747}
748
749type libraryInterface interface {
Colin Cross3572cf72020-10-01 15:58:11 -0700750 versionedInterface
751
Colin Crossb916a382016-07-29 17:28:03 -0700752 static() bool
Inseob Kimae553032019-05-14 18:52:49 +0900753 shared() bool
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700754 objs() Objects
Colin Cross0de8a1e2020-09-18 14:15:30 -0700755 reuseObjs() Objects
Colin Cross26c34ed2016-09-30 17:10:16 -0700756 toc() android.OptionalPath
Colin Crossb916a382016-07-29 17:28:03 -0700757
758 // Returns true if the build options for the module have selected a static or shared build
759 buildStatic() bool
760 buildShared() bool
761
762 // Sets whether a specific variant is static or shared
Colin Crossa48ab5b2017-02-14 15:28:44 -0800763 setStatic()
764 setShared()
Logan Chien41eabe62019-04-10 13:33:58 +0800765
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800766 // Check whether header_abi_checker is enabled or explicitly disabled.
767 headerAbiCheckerEnabled() bool
768 headerAbiCheckerExplicitlyDisabled() bool
769
Logan Chien41eabe62019-04-10 13:33:58 +0800770 // Write LOCAL_ADDITIONAL_DEPENDENCIES for ABI diff
771 androidMkWriteAdditionalDependenciesForSourceAbiDiff(w io.Writer)
Jiyong Parka90ca002019-10-07 15:47:24 +0900772
773 availableFor(string) bool
Colin Crossb916a382016-07-29 17:28:03 -0700774}
775
Colin Crossc88c2722020-09-28 17:32:47 -0700776type versionedInterface interface {
777 buildStubs() bool
778 setBuildStubs()
779 hasStubsVariants() bool
780 setStubsVersion(string)
781 stubsVersion() string
782
Colin Cross3572cf72020-10-01 15:58:11 -0700783 stubsVersions(ctx android.BaseMutatorContext) []string
Colin Crossc88c2722020-09-28 17:32:47 -0700784 setAllStubsVersions([]string)
785 allStubsVersions() []string
Colin Cross0477b422020-10-13 18:43:54 -0700786
787 implementationModuleName(name string) string
Colin Cross127bb8b2020-12-16 16:46:01 -0800788 hasLLNDKStubs() bool
Colin Crossc88c2722020-09-28 17:32:47 -0700789}
790
791var _ libraryInterface = (*libraryDecorator)(nil)
792var _ versionedInterface = (*libraryDecorator)(nil)
793
Justin Yun6977e8a2020-10-29 18:24:11 +0900794func (library *libraryDecorator) getLibNameHelper(baseModuleName string, inVendor bool, inProduct bool) string {
Colin Crossb916a382016-07-29 17:28:03 -0700795 name := library.libName
796 if name == "" {
dimitryd95964a2018-11-07 13:43:34 +0100797 name = String(library.Properties.Stem)
798 if name == "" {
Jooyung Han0302a842019-10-30 18:43:49 +0900799 name = baseModuleName
dimitryd95964a2018-11-07 13:43:34 +0100800 }
Colin Crossb916a382016-07-29 17:28:03 -0700801 }
802
Colin Cross0fd6a412019-08-16 14:22:10 -0700803 suffix := ""
Justin Yun6977e8a2020-10-29 18:24:11 +0900804 if inVendor {
Colin Cross0fd6a412019-08-16 14:22:10 -0700805 suffix = String(library.Properties.Target.Vendor.Suffix)
Justin Yun6977e8a2020-10-29 18:24:11 +0900806 } else if inProduct {
807 suffix = String(library.Properties.Target.Product.Suffix)
Colin Cross0fd6a412019-08-16 14:22:10 -0700808 }
809 if suffix == "" {
810 suffix = String(library.Properties.Suffix)
811 }
812
Jooyung Han0302a842019-10-30 18:43:49 +0900813 return name + suffix
814}
815
Chris Parsons3c27ca32020-11-20 12:42:07 -0500816// getLibName returns the actual canonical name of the library (the name which
817// should be passed to the linker via linker flags).
Jooyung Han0302a842019-10-30 18:43:49 +0900818func (library *libraryDecorator) getLibName(ctx BaseModuleContext) string {
Justin Yun6977e8a2020-10-29 18:24:11 +0900819 name := library.getLibNameHelper(ctx.baseModuleName(), ctx.inVendor(), ctx.inProduct())
Colin Cross0fd6a412019-08-16 14:22:10 -0700820
Ivan Lozanof9e21722020-12-02 09:00:51 -0500821 if ctx.IsVndkExt() {
Jooyung Han4c2b9422019-10-22 19:53:47 +0900822 // vndk-ext lib should have the same name with original lib
823 ctx.VisitDirectDepsWithTag(vndkExtDepTag, func(module android.Module) {
824 originalName := module.(*Module).outputFile.Path()
825 name = strings.TrimSuffix(originalName.Base(), originalName.Ext())
826 })
Logan Chienf3511742017-10-31 18:04:35 +0800827 }
828
Colin Crossb916a382016-07-29 17:28:03 -0700829 if ctx.Host() && Bool(library.Properties.Unique_host_soname) {
830 if !strings.HasSuffix(name, "-host") {
831 name = name + "-host"
832 }
833 }
834
Inseob Kim0ce291e2019-07-04 14:38:27 +0900835 return name
Colin Crossb916a382016-07-29 17:28:03 -0700836}
837
Jiyong Parkda732bd2018-11-02 18:23:15 +0900838var versioningMacroNamesListMutex sync.Mutex
839
Colin Crossb916a382016-07-29 17:28:03 -0700840func (library *libraryDecorator) linkerInit(ctx BaseModuleContext) {
841 location := InstallInSystem
Dan Albert61f32122018-07-26 14:00:24 -0700842 if library.baseLinker.sanitize.inSanitizerDir() {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700843 location = InstallInSanitizerDir
Colin Crossb916a382016-07-29 17:28:03 -0700844 }
845 library.baseInstaller.location = location
Colin Crossb916a382016-07-29 17:28:03 -0700846 library.baseLinker.linkerInit(ctx)
Jiyong Park7ed9de32018-10-15 22:25:07 +0900847 // Let baseLinker know whether this variant is for stubs or not, so that
848 // it can omit things that are not required for linking stubs.
849 library.baseLinker.dynamicProperties.BuildStubs = library.buildStubs()
Jiyong Parkda732bd2018-11-02 18:23:15 +0900850
851 if library.buildStubs() {
852 macroNames := versioningMacroNamesList(ctx.Config())
853 myName := versioningMacroName(ctx.ModuleName())
854 versioningMacroNamesListMutex.Lock()
855 defer versioningMacroNamesListMutex.Unlock()
856 if (*macroNames)[myName] == "" {
857 (*macroNames)[myName] = ctx.ModuleName()
858 } else if (*macroNames)[myName] != ctx.ModuleName() {
859 ctx.ModuleErrorf("Macro name %q for versioning conflicts with macro name from module %q ", myName, (*macroNames)[myName])
860 }
861 }
Colin Crossb916a382016-07-29 17:28:03 -0700862}
863
dimitry0345ad82018-12-05 16:28:14 +0100864func (library *libraryDecorator) compilerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800865 if ctx.IsLlndk() {
866 // LLNDK libraries ignore most of the properties on the cc_library and use the
867 // LLNDK-specific properties instead.
868 return deps
869 }
870
dimitry0345ad82018-12-05 16:28:14 +0100871 deps = library.baseCompiler.compilerDeps(ctx, deps)
872
dimitry0345ad82018-12-05 16:28:14 +0100873 return deps
874}
875
Colin Cross37047f12016-12-13 17:06:13 -0800876func (library *libraryDecorator) linkerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800877 if ctx.IsLlndk() {
878 // LLNDK libraries ignore most of the properties on the cc_library and use the
879 // LLNDK-specific properties instead.
880 deps.HeaderLibs = append(deps.HeaderLibs, library.Properties.Llndk.Export_llndk_headers...)
881 deps.ReexportHeaderLibHeaders = append(deps.ReexportHeaderLibHeaders,
882 library.Properties.Llndk.Export_llndk_headers...)
883 return deps
884 }
885
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800886 if library.static() {
Martin Stjernholm10566a02020-03-24 01:19:52 +0000887 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700888 if library.StaticProperties.Static.System_shared_libs != nil {
889 library.baseLinker.Properties.System_shared_libs = library.StaticProperties.Static.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800890 }
891 } else if library.shared() {
Martin Stjernholm10566a02020-03-24 01:19:52 +0000892 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700893 if library.SharedProperties.Shared.System_shared_libs != nil {
894 library.baseLinker.Properties.System_shared_libs = library.SharedProperties.Shared.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800895 }
896 }
897
Colin Crossb916a382016-07-29 17:28:03 -0700898 deps = library.baseLinker.linkerDeps(ctx, deps)
899
900 if library.static() {
901 deps.WholeStaticLibs = append(deps.WholeStaticLibs,
Colin Crosse1bb5d02019-09-24 14:55:04 -0700902 library.StaticProperties.Static.Whole_static_libs...)
903 deps.StaticLibs = append(deps.StaticLibs, library.StaticProperties.Static.Static_libs...)
904 deps.SharedLibs = append(deps.SharedLibs, library.StaticProperties.Static.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -0800905
Colin Crosse1bb5d02019-09-24 14:55:04 -0700906 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.StaticProperties.Static.Export_shared_lib_headers...)
907 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.StaticProperties.Static.Export_static_lib_headers...)
Colin Crossa48ab5b2017-02-14 15:28:44 -0800908 } else if library.shared() {
Dan Willemsen2e47b342016-11-17 01:02:25 -0800909 if ctx.toolchain().Bionic() && !Bool(library.baseLinker.Properties.Nocrt) {
Dan Albert92fe7402020-07-15 13:33:30 -0700910 deps.CrtBegin = "crtbegin_so"
911 deps.CrtEnd = "crtend_so"
Colin Cross4d9c2d12016-07-29 12:48:20 -0700912 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700913 deps.WholeStaticLibs = append(deps.WholeStaticLibs, library.SharedProperties.Shared.Whole_static_libs...)
914 deps.StaticLibs = append(deps.StaticLibs, library.SharedProperties.Shared.Static_libs...)
915 deps.SharedLibs = append(deps.SharedLibs, library.SharedProperties.Shared.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -0800916
Colin Crosse1bb5d02019-09-24 14:55:04 -0700917 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.SharedProperties.Shared.Export_shared_lib_headers...)
918 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.SharedProperties.Shared.Export_static_lib_headers...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700919 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900920 if ctx.inVendor() {
Jiyong Park52d25bd2017-10-13 09:17:01 +0900921 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
922 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
923 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +0000924 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
925 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Jiyong Park52d25bd2017-10-13 09:17:01 +0900926 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900927 if ctx.inProduct() {
928 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
929 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
930 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
931 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
932 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
933 }
Jiyong Parkf9332f12018-02-01 00:54:12 +0900934 if ctx.inRecovery() {
935 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
936 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
937 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +0000938 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
939 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900940 }
Yifan Hongcf4832c2020-01-21 17:04:13 -0800941 if ctx.inRamdisk() {
942 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
943 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
944 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
945 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
946 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
947 }
Yifan Hong6da33c22020-10-27 15:01:21 -0700948 if ctx.inVendorRamdisk() {
949 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
950 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
951 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
952 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
953 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
954 }
Colin Cross2383f3b2018-02-06 14:40:13 -0800955
Colin Cross4d9c2d12016-07-29 12:48:20 -0700956 return deps
957}
958
Paul Duffin13f02712020-03-06 12:30:43 +0000959func (library *libraryDecorator) linkerSpecifiedDeps(specifiedDeps specifiedDeps) specifiedDeps {
960 specifiedDeps = library.baseLinker.linkerSpecifiedDeps(specifiedDeps)
961 var properties StaticOrSharedProperties
962 if library.static() {
963 properties = library.StaticProperties.Static
964 } else if library.shared() {
965 properties = library.SharedProperties.Shared
966 }
967
968 specifiedDeps.sharedLibs = append(specifiedDeps.sharedLibs, properties.Shared_libs...)
Martin Stjernholm10566a02020-03-24 01:19:52 +0000969
970 // Must distinguish nil and [] in system_shared_libs - ensure that [] in
971 // either input list doesn't come out as nil.
972 if specifiedDeps.systemSharedLibs == nil {
973 specifiedDeps.systemSharedLibs = properties.System_shared_libs
974 } else {
975 specifiedDeps.systemSharedLibs = append(specifiedDeps.systemSharedLibs, properties.System_shared_libs...)
976 }
Paul Duffin13f02712020-03-06 12:30:43 +0000977
978 specifiedDeps.sharedLibs = android.FirstUniqueStrings(specifiedDeps.sharedLibs)
Martin Stjernholm10566a02020-03-24 01:19:52 +0000979 if len(specifiedDeps.systemSharedLibs) > 0 {
980 // Skip this if systemSharedLibs is either nil or [], to ensure they are
981 // retained.
982 specifiedDeps.systemSharedLibs = android.FirstUniqueStrings(specifiedDeps.systemSharedLibs)
983 }
Paul Duffin13f02712020-03-06 12:30:43 +0000984 return specifiedDeps
985}
986
Colin Crossb916a382016-07-29 17:28:03 -0700987func (library *libraryDecorator) linkStatic(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700988 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700989
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700990 library.objects = deps.WholeStaticLibObjs.Copy()
991 library.objects = library.objects.Append(objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700992
Inseob Kim0ce291e2019-07-04 14:38:27 +0900993 fileName := ctx.ModuleName() + staticLibraryExtension
Colin Cross86803cf2018-02-15 14:12:26 -0800994 outputFile := android.PathForModuleOut(ctx, fileName)
Dan Willemsen581341d2017-02-09 16:16:31 -0800995 builderFlags := flagsToBuilderFlags(flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700996
Dan Willemsen569edc52018-11-19 09:33:29 -0800997 if Bool(library.baseLinker.Properties.Use_version_lib) {
998 if ctx.Host() {
999 versionedOutputFile := outputFile
1000 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
1001 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1002 } else {
1003 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001004 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -08001005 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1006 }
Colin Cross86803cf2018-02-15 14:12:26 -08001007 }
1008
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001009 transformObjToStaticLib(ctx, library.objects.objFiles, deps.WholeStaticLibsFromPrebuilts, builderFlags, outputFile, objs.tidyFiles)
Dan Willemsen581341d2017-02-09 16:16:31 -08001010
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001011 library.coverageOutputFile = transformCoverageFilesToZip(ctx, library.objects, ctx.ModuleName())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001012
Colin Cross4d9c2d12016-07-29 12:48:20 -07001013 ctx.CheckbuildFile(outputFile)
1014
Colin Cross649d8172020-12-10 12:30:21 -08001015 if library.static() {
1016 ctx.SetProvider(StaticLibraryInfoProvider, StaticLibraryInfo{
1017 StaticLibrary: outputFile,
1018 ReuseObjects: library.reuseObjects,
1019 Objects: library.objects,
Colin Cross0de8a1e2020-09-18 14:15:30 -07001020
Colin Cross649d8172020-12-10 12:30:21 -08001021 TransitiveStaticLibrariesForOrdering: android.NewDepSetBuilder(android.TOPOLOGICAL).
1022 Direct(outputFile).
1023 Transitive(deps.TranstiveStaticLibrariesForOrdering).
1024 Build(),
1025 })
1026 }
1027
1028 if library.header() {
1029 ctx.SetProvider(HeaderLibraryInfoProvider, HeaderLibraryInfo{})
1030 }
Colin Cross0de8a1e2020-09-18 14:15:30 -07001031
Colin Cross4d9c2d12016-07-29 12:48:20 -07001032 return outputFile
1033}
1034
Colin Crossb916a382016-07-29 17:28:03 -07001035func (library *libraryDecorator) linkShared(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001036 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001037
1038 var linkerDeps android.Paths
Pirama Arumuga Nainarada83ec2017-08-31 23:38:27 -07001039 linkerDeps = append(linkerDeps, flags.LdFlagsDeps...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001040
Colin Cross2383f3b2018-02-06 14:40:13 -08001041 unexportedSymbols := ctx.ExpandOptionalSource(library.Properties.Unexported_symbols_list, "unexported_symbols_list")
1042 forceNotWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_not_weak_list, "force_symbols_not_weak_list")
1043 forceWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_weak_list, "force_symbols_weak_list")
Colin Cross4d9c2d12016-07-29 12:48:20 -07001044 if !ctx.Darwin() {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001045 if unexportedSymbols.Valid() {
1046 ctx.PropertyErrorf("unexported_symbols_list", "Only supported on Darwin")
1047 }
1048 if forceNotWeakSymbols.Valid() {
1049 ctx.PropertyErrorf("force_symbols_not_weak_list", "Only supported on Darwin")
1050 }
1051 if forceWeakSymbols.Valid() {
1052 ctx.PropertyErrorf("force_symbols_weak_list", "Only supported on Darwin")
1053 }
1054 } else {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001055 if unexportedSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001056 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-unexported_symbols_list,"+unexportedSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001057 linkerDeps = append(linkerDeps, unexportedSymbols.Path())
1058 }
1059 if forceNotWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001060 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_not_weak_list,"+forceNotWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001061 linkerDeps = append(linkerDeps, forceNotWeakSymbols.Path())
1062 }
1063 if forceWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001064 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_weak_list,"+forceWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001065 linkerDeps = append(linkerDeps, forceWeakSymbols.Path())
1066 }
1067 }
Colin Cross8e21aa52020-09-28 18:28:02 -07001068 if library.versionScriptPath.Valid() {
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001069 linkerScriptFlags := "-Wl,--version-script," + library.versionScriptPath.String()
Colin Cross4af21ed2019-11-04 09:37:55 -08001070 flags.Local.LdFlags = append(flags.Local.LdFlags, linkerScriptFlags)
Colin Cross8e21aa52020-09-28 18:28:02 -07001071 linkerDeps = append(linkerDeps, library.versionScriptPath.Path())
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001072 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001073
1074 fileName := library.getLibName(ctx) + flags.Toolchain.ShlibSuffix()
1075 outputFile := android.PathForModuleOut(ctx, fileName)
Colin Cross0de8a1e2020-09-18 14:15:30 -07001076 unstrippedOutputFile := outputFile
Colin Cross4d9c2d12016-07-29 12:48:20 -07001077
Josh Gao75a50a22019-06-07 17:58:59 -07001078 var implicitOutputs android.WritablePaths
1079 if ctx.Windows() {
1080 importLibraryPath := android.PathForModuleOut(ctx, pathtools.ReplaceExtension(fileName, "lib"))
1081
Colin Cross4af21ed2019-11-04 09:37:55 -08001082 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,--out-implib="+importLibraryPath.String())
Josh Gao75a50a22019-06-07 17:58:59 -07001083 implicitOutputs = append(implicitOutputs, importLibraryPath)
1084 }
1085
Colin Cross4d9c2d12016-07-29 12:48:20 -07001086 builderFlags := flagsToBuilderFlags(flags)
1087
Colin Crossb496cfd2018-09-10 16:50:05 -07001088 // Optimize out relinking against shared libraries whose interface hasn't changed by
1089 // depending on a table of contents file instead of the library itself.
Colin Cross70dda7e2019-10-01 22:05:35 -07001090 tocFile := outputFile.ReplaceExtension(ctx, flags.Toolchain.ShlibSuffix()[1:]+".toc")
Colin Crossb496cfd2018-09-10 16:50:05 -07001091 library.tocFile = android.OptionalPathForPath(tocFile)
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001092 transformSharedObjectToToc(ctx, outputFile, tocFile, builderFlags)
Colin Cross89562dc2016-10-03 17:47:19 -07001093
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001094 stripFlags := flagsToStripFlags(flags)
Colin Crossadc81a02020-12-14 17:01:55 -08001095 needsStrip := library.stripper.NeedsStrip(ctx)
1096 if library.buildStubs() {
1097 // No need to strip stubs libraries
1098 needsStrip = false
1099 }
1100 if needsStrip {
Yi Kongb5c34d72018-11-07 16:28:49 -08001101 if ctx.Darwin() {
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001102 stripFlags.StripUseGnuStrip = true
Yi Kongb5c34d72018-11-07 16:28:49 -08001103 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001104 strippedOutputFile := outputFile
1105 outputFile = android.PathForModuleOut(ctx, "unstripped", fileName)
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001106 library.stripper.StripExecutableOrSharedLib(ctx, outputFile, strippedOutputFile, stripFlags)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001107 }
Colin Crossb60190a2018-09-04 16:28:17 -07001108 library.unstrippedOutputFile = outputFile
1109
Colin Crossd7227f92019-09-05 14:26:33 -07001110 outputFile = maybeInjectBoringSSLHash(ctx, outputFile, library.Properties.Inject_bssl_hash, fileName)
Pete Bentley803e1612019-08-06 22:19:59 +01001111
Dan Willemsen569edc52018-11-19 09:33:29 -08001112 if Bool(library.baseLinker.Properties.Use_version_lib) {
1113 if ctx.Host() {
1114 versionedOutputFile := outputFile
1115 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
1116 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1117 } else {
1118 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001119 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -08001120
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001121 if library.stripper.NeedsStrip(ctx) {
Dan Willemsen569edc52018-11-19 09:33:29 -08001122 out := android.PathForModuleOut(ctx, "versioned-stripped", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001123 library.distFile = out
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001124 library.stripper.StripExecutableOrSharedLib(ctx, versionedOutputFile, out, stripFlags)
Dan Willemsen569edc52018-11-19 09:33:29 -08001125 }
1126
1127 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1128 }
Colin Cross86803cf2018-02-15 14:12:26 -08001129 }
1130
Jiyong Park64a44f22019-01-18 14:37:08 +09001131 sharedLibs := deps.EarlySharedLibs
1132 sharedLibs = append(sharedLibs, deps.SharedLibs...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001133 sharedLibs = append(sharedLibs, deps.LateSharedLibs...)
1134
Jiyong Park64a44f22019-01-18 14:37:08 +09001135 linkerDeps = append(linkerDeps, deps.EarlySharedLibsDeps...)
Colin Cross26c34ed2016-09-30 17:10:16 -07001136 linkerDeps = append(linkerDeps, deps.SharedLibsDeps...)
1137 linkerDeps = append(linkerDeps, deps.LateSharedLibsDeps...)
Dan Willemsena03cf6d2016-09-26 15:45:04 -07001138 linkerDeps = append(linkerDeps, objs.tidyFiles...)
Colin Cross26c34ed2016-09-30 17:10:16 -07001139
Colin Cross127bb8b2020-12-16 16:46:01 -08001140 if Bool(library.Properties.Sort_bss_symbols_by_size) && !library.buildStubs() {
Vic Yang6cd1be82019-06-24 16:08:48 -07001141 unsortedOutputFile := android.PathForModuleOut(ctx, "unsorted", fileName)
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001142 transformObjToDynamicBinary(ctx, objs.objFiles, sharedLibs,
Vic Yang6cd1be82019-06-24 16:08:48 -07001143 deps.StaticLibs, deps.LateStaticLibs, deps.WholeStaticLibs,
1144 linkerDeps, deps.CrtBegin, deps.CrtEnd, false, builderFlags, unsortedOutputFile, implicitOutputs)
1145
1146 symbolOrderingFile := android.PathForModuleOut(ctx, "unsorted", fileName+".symbol_order")
1147 symbolOrderingFlag := library.baseLinker.sortBssSymbolsBySize(ctx, unsortedOutputFile, symbolOrderingFile, builderFlags)
Colin Cross6d88dba2019-11-06 07:06:58 -08001148 builderFlags.localLdFlags += " " + symbolOrderingFlag
Vic Yang6cd1be82019-06-24 16:08:48 -07001149 linkerDeps = append(linkerDeps, symbolOrderingFile)
1150 }
1151
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001152 transformObjToDynamicBinary(ctx, objs.objFiles, sharedLibs,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001153 deps.StaticLibs, deps.LateStaticLibs, deps.WholeStaticLibs,
Josh Gao75a50a22019-06-07 17:58:59 -07001154 linkerDeps, deps.CrtBegin, deps.CrtEnd, false, builderFlags, outputFile, implicitOutputs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001155
Dan Willemsen581341d2017-02-09 16:16:31 -08001156 objs.coverageFiles = append(objs.coverageFiles, deps.StaticLibObjs.coverageFiles...)
1157 objs.coverageFiles = append(objs.coverageFiles, deps.WholeStaticLibObjs.coverageFiles...)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001158
1159 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.StaticLibObjs.sAbiDumpFiles...)
1160 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.WholeStaticLibObjs.sAbiDumpFiles...)
1161
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001162 library.coverageOutputFile = transformCoverageFilesToZip(ctx, objs, library.getLibName(ctx))
Colin Cross0de8a1e2020-09-18 14:15:30 -07001163 library.linkSAbiDumpFiles(ctx, objs, fileName, unstrippedOutputFile)
Dan Willemsen581341d2017-02-09 16:16:31 -08001164
Colin Cross0de8a1e2020-09-18 14:15:30 -07001165 var staticAnalogue *StaticLibraryInfo
1166 if static := ctx.GetDirectDepsWithTag(staticVariantTag); len(static) > 0 {
1167 s := ctx.OtherModuleProvider(static[0], StaticLibraryInfoProvider).(StaticLibraryInfo)
1168 staticAnalogue = &s
1169 }
1170
1171 ctx.SetProvider(SharedLibraryInfoProvider, SharedLibraryInfo{
1172 TableOfContents: android.OptionalPathForPath(tocFile),
1173 SharedLibrary: unstrippedOutputFile,
1174 UnstrippedSharedLibrary: library.unstrippedOutputFile,
1175 CoverageSharedLibrary: library.coverageOutputFile,
1176 StaticAnalogue: staticAnalogue,
1177 })
1178
1179 stubs := ctx.GetDirectDepsWithTag(stubImplDepTag)
1180 if len(stubs) > 0 {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001181 var stubsInfo []SharedStubLibrary
Colin Cross0de8a1e2020-09-18 14:15:30 -07001182 for _, stub := range stubs {
1183 stubInfo := ctx.OtherModuleProvider(stub, SharedLibraryInfoProvider).(SharedLibraryInfo)
1184 flagInfo := ctx.OtherModuleProvider(stub, FlagExporterInfoProvider).(FlagExporterInfo)
Chris Parsons3c27ca32020-11-20 12:42:07 -05001185 stubsInfo = append(stubsInfo, SharedStubLibrary{
Colin Cross31076b32020-10-23 17:22:06 -07001186 Version: moduleLibraryInterface(stub).stubsVersion(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001187 SharedLibraryInfo: stubInfo,
1188 FlagExporterInfo: flagInfo,
1189 })
1190 }
Chris Parsons3c27ca32020-11-20 12:42:07 -05001191 ctx.SetProvider(SharedLibraryStubsProvider, SharedLibraryStubsInfo{
1192 SharedStubLibraries: stubsInfo,
Colin Cross0de8a1e2020-09-18 14:15:30 -07001193
Colin Cross127bb8b2020-12-16 16:46:01 -08001194 IsLLNDK: ctx.IsLlndk(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001195 })
1196 }
1197
1198 return unstrippedOutputFile
Colin Cross4d9c2d12016-07-29 12:48:20 -07001199}
1200
Jiyong Parkaf6d8952019-01-31 12:21:23 +09001201func (library *libraryDecorator) unstrippedOutputFilePath() android.Path {
1202 return library.unstrippedOutputFile
1203}
1204
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001205func (library *libraryDecorator) disableStripping() {
1206 library.stripper.StripProperties.Strip.None = BoolPtr(true)
1207}
1208
Pirama Arumuga Nainar65c95ff2019-03-25 10:21:31 -07001209func (library *libraryDecorator) nativeCoverage() bool {
1210 if library.header() || library.buildStubs() {
1211 return false
1212 }
1213 return true
1214}
1215
Jiyong Parkee9a98d2019-08-09 14:44:36 +09001216func (library *libraryDecorator) coverageOutputFilePath() android.OptionalPath {
1217 return library.coverageOutputFile
1218}
1219
Logan Chien7eefdc42018-07-11 18:10:41 +08001220func getRefAbiDumpFile(ctx ModuleContext, vndkVersion, fileName string) android.Path {
Hsin-Yi Chen27d235f2020-03-26 17:50:29 +08001221 // The logic must be consistent with classifySourceAbiDump.
Colin Cross95f1ca02020-10-29 20:47:22 -07001222 isNdk := ctx.isNdk(ctx.Config())
Colin Cross127bb8b2020-12-16 16:46:01 -08001223 isLlndkOrVndk := ctx.IsLlndkPublic() || (ctx.useVndk() && ctx.isVndk())
Logan Chien7eefdc42018-07-11 18:10:41 +08001224
Hsin-Yi Chen53489642019-07-31 17:10:45 +08001225 refAbiDumpTextFile := android.PathForVndkRefAbiDump(ctx, vndkVersion, fileName, isNdk, isLlndkOrVndk, false)
1226 refAbiDumpGzipFile := android.PathForVndkRefAbiDump(ctx, vndkVersion, fileName, isNdk, isLlndkOrVndk, true)
Logan Chien7eefdc42018-07-11 18:10:41 +08001227
1228 if refAbiDumpTextFile.Valid() {
1229 if refAbiDumpGzipFile.Valid() {
1230 ctx.ModuleErrorf(
1231 "Two reference ABI dump files are found: %q and %q. Please delete the stale one.",
1232 refAbiDumpTextFile, refAbiDumpGzipFile)
1233 return nil
1234 }
1235 return refAbiDumpTextFile.Path()
1236 }
1237 if refAbiDumpGzipFile.Valid() {
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001238 return unzipRefDump(ctx, refAbiDumpGzipFile.Path(), fileName)
Logan Chien7eefdc42018-07-11 18:10:41 +08001239 }
1240 return nil
1241}
1242
Jayant Chowdhary6ab3d842017-06-26 12:52:58 -07001243func (library *libraryDecorator) linkSAbiDumpFiles(ctx ModuleContext, objs Objects, fileName string, soFile android.Path) {
Yo Chiang2bbadfa2020-12-14 11:42:16 +08001244 if library.sabi.shouldCreateSourceAbiDump() {
Inseob Kim96f17f02020-06-09 22:05:09 +09001245 var vndkVersion string
1246
1247 if ctx.useVndk() {
1248 // For modules linking against vndk, follow its vndk version
1249 vndkVersion = ctx.Module().(*Module).VndkVersion()
1250 } else {
1251 // Regard the other modules as PLATFORM_VNDK_VERSION
1252 vndkVersion = ctx.DeviceConfig().PlatformVndkVersion()
Logan Chienf3511742017-10-31 18:04:35 +08001253 }
1254
Jayant Chowdharya4fce192017-09-06 13:10:03 -07001255 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001256 var SourceAbiFlags []string
1257 for _, dir := range exportIncludeDirs.Strings() {
Jayant Chowdhary715cac32017-04-20 06:53:59 -07001258 SourceAbiFlags = append(SourceAbiFlags, "-I"+dir)
1259 }
Inseob Kim69378442019-06-03 19:10:47 +09001260 for _, reexportedInclude := range library.sabi.Properties.ReexportedIncludes {
1261 SourceAbiFlags = append(SourceAbiFlags, "-I"+reexportedInclude)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001262 }
1263 exportedHeaderFlags := strings.Join(SourceAbiFlags, " ")
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001264 library.sAbiOutputFile = transformDumpToLinkedDump(ctx, objs.sAbiDumpFiles, soFile, fileName, exportedHeaderFlags,
Jiyong Parka034b832019-08-27 14:02:19 +09001265 android.OptionalPathForModuleSrc(ctx, library.symbolFileForAbiCheck(ctx)),
Logan Chiene3d7a0d2019-01-17 00:18:02 +08001266 library.Properties.Header_abi_checker.Exclude_symbol_versions,
1267 library.Properties.Header_abi_checker.Exclude_symbol_tags)
Logan Chien2f2b8902018-07-10 15:01:19 +08001268
Yo Chiang2bbadfa2020-12-14 11:42:16 +08001269 addLsdumpPath(classifySourceAbiDump(ctx) + ":" + library.sAbiOutputFile.String())
Hsin-Yi Chen53489642019-07-31 17:10:45 +08001270
Logan Chien7eefdc42018-07-11 18:10:41 +08001271 refAbiDumpFile := getRefAbiDumpFile(ctx, vndkVersion, fileName)
1272 if refAbiDumpFile != nil {
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001273 library.sAbiDiff = sourceAbiDiff(ctx, library.sAbiOutputFile.Path(),
Logan Chien2a65dda2019-10-01 15:58:07 -07001274 refAbiDumpFile, fileName, exportedHeaderFlags,
1275 Bool(library.Properties.Header_abi_checker.Check_all_apis),
Colin Cross127bb8b2020-12-16 16:46:01 -08001276 ctx.IsLlndk(), ctx.isNdk(ctx.Config()), ctx.IsVndkExt())
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001277 }
1278 }
1279}
1280
Colin Cross127bb8b2020-12-16 16:46:01 -08001281func processLLNDKHeaders(ctx ModuleContext, srcHeaderDir string, outDir android.ModuleGenPath) android.Path {
1282 srcDir := android.PathForModuleSrc(ctx, srcHeaderDir)
1283 srcFiles := ctx.GlobFiles(filepath.Join(srcDir.String(), "**/*.h"), nil)
1284
1285 var installPaths []android.WritablePath
1286 for _, header := range srcFiles {
1287 headerDir := filepath.Dir(header.String())
1288 relHeaderDir, err := filepath.Rel(srcDir.String(), headerDir)
1289 if err != nil {
1290 ctx.ModuleErrorf("filepath.Rel(%q, %q) failed: %s",
1291 srcDir.String(), headerDir, err)
1292 continue
1293 }
1294
1295 installPaths = append(installPaths, outDir.Join(ctx, relHeaderDir, header.Base()))
1296 }
1297
1298 return processHeadersWithVersioner(ctx, srcDir, outDir, srcFiles, installPaths)
1299}
1300
Chris Parsons3c27ca32020-11-20 12:42:07 -05001301// link registers actions to link this library, and sets various fields
1302// on this library to reflect information that should be exported up the build
1303// tree (for example, exported flags and include paths).
Colin Crossb916a382016-07-29 17:28:03 -07001304func (library *libraryDecorator) link(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001305 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001306
Colin Cross127bb8b2020-12-16 16:46:01 -08001307 if ctx.IsLlndk() {
1308 if len(library.Properties.Llndk.Export_preprocessed_headers) > 0 {
1309 // This is the vendor variant of an LLNDK library with preprocessed headers.
1310 genHeaderOutDir := android.PathForModuleGen(ctx, "include")
1311
1312 var timestampFiles android.Paths
1313 for _, dir := range library.Properties.Llndk.Export_preprocessed_headers {
1314 timestampFiles = append(timestampFiles, processLLNDKHeaders(ctx, dir, genHeaderOutDir))
1315 }
1316
1317 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1318 library.reexportSystemDirs(genHeaderOutDir)
1319 } else {
1320 library.reexportDirs(genHeaderOutDir)
1321 }
1322
1323 library.reexportDeps(timestampFiles...)
1324 }
1325
1326 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1327 library.flagExporter.Properties.Export_system_include_dirs = append(
1328 library.flagExporter.Properties.Export_system_include_dirs,
1329 library.flagExporter.Properties.Export_include_dirs...)
1330 library.flagExporter.Properties.Export_include_dirs = nil
1331 }
1332 }
1333
Chris Parsons3c27ca32020-11-20 12:42:07 -05001334 // Linking this library consists of linking `deps.Objs` (.o files in dependencies
1335 // of this library), together with `objs` (.o files created by compiling this
1336 // library).
Colin Crossad59e752017-11-16 14:29:11 -08001337 objs = deps.Objs.Copy().Append(objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001338 var out android.Path
Colin Crossa48ab5b2017-02-14 15:28:44 -08001339 if library.static() || library.header() {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001340 out = library.linkStatic(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001341 } else {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001342 out = library.linkShared(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001343 }
1344
Chris Parsons3c27ca32020-11-20 12:42:07 -05001345 // Export include paths and flags to be propagated up the tree.
Inseob Kim69378442019-06-03 19:10:47 +09001346 library.exportIncludes(ctx)
1347 library.reexportDirs(deps.ReexportedDirs...)
1348 library.reexportSystemDirs(deps.ReexportedSystemDirs...)
1349 library.reexportFlags(deps.ReexportedFlags...)
1350 library.reexportDeps(deps.ReexportedDeps...)
Inseob Kimd110f872019-12-06 13:15:38 +09001351 library.addExportedGeneratedHeaders(deps.ReexportedGeneratedHeaders...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001352
Chris Parsons3c27ca32020-11-20 12:42:07 -05001353 // Optionally export aidl headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001354 if Bool(library.Properties.Aidl.Export_aidl_headers) {
Dan Willemsene1240db2016-11-03 14:28:51 -07001355 if library.baseCompiler.hasSrcExt(".aidl") {
Jiyong Park74955042019-10-22 20:19:51 +09001356 dir := android.PathForModuleGen(ctx, "aidl")
Inseob Kim69378442019-06-03 19:10:47 +09001357 library.reexportDirs(dir)
Inseob Kimd110f872019-12-06 13:15:38 +09001358
Paul Duffin33056e82021-02-19 13:49:08 +00001359 library.reexportDeps(library.baseCompiler.aidlOrderOnlyDeps...)
1360 library.addExportedGeneratedHeaders(library.baseCompiler.aidlHeaders...)
Dan Willemsene1240db2016-11-03 14:28:51 -07001361 }
1362 }
1363
Chris Parsons3c27ca32020-11-20 12:42:07 -05001364 // Optionally export proto headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001365 if Bool(library.Properties.Proto.Export_proto_headers) {
Dan Willemsene1240db2016-11-03 14:28:51 -07001366 if library.baseCompiler.hasSrcExt(".proto") {
Jiyong Park74955042019-10-22 20:19:51 +09001367 var includes android.Paths
Colin Cross19878da2019-03-28 14:45:07 -07001368 if flags.proto.CanonicalPathFromRoot {
Jiyong Park74955042019-10-22 20:19:51 +09001369 includes = append(includes, flags.proto.SubDir)
Colin Cross10d22312017-05-03 11:01:58 -07001370 }
Jiyong Park74955042019-10-22 20:19:51 +09001371 includes = append(includes, flags.proto.Dir)
Inseob Kim69378442019-06-03 19:10:47 +09001372 library.reexportDirs(includes...)
Inseob Kimd110f872019-12-06 13:15:38 +09001373
Paul Duffin33056e82021-02-19 13:49:08 +00001374 library.reexportDeps(library.baseCompiler.protoOrderOnlyDeps...)
1375 library.addExportedGeneratedHeaders(library.baseCompiler.protoHeaders...)
Colin Cross0c461f12016-10-20 16:11:43 -07001376 }
1377 }
1378
Inseob Kim07def122020-11-23 14:43:02 +09001379 // If the library is sysprop_library, expose either public or internal header selectively.
Inseob Kim21f26902018-09-06 00:55:20 +09001380 if library.baseCompiler.hasSrcExt(".sysprop") {
Jiyong Park74955042019-10-22 20:19:51 +09001381 dir := android.PathForModuleGen(ctx, "sysprop", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001382 if library.Properties.Sysprop.Platform != nil {
Inseob Kimc0907f12019-02-08 21:00:45 +09001383 isOwnerPlatform := Bool(library.Properties.Sysprop.Platform)
1384
Inseob Kim07def122020-11-23 14:43:02 +09001385 // If the owner is different from the user, expose public header. That is,
1386 // 1) if the user is product (as owner can only be platform / vendor)
Inseob Kim06410042021-01-18 15:23:28 +09001387 // 2) if the owner is platform and the client is vendor
1388 // We don't care Platform -> Vendor dependency as it's already forbidden.
1389 if ctx.Device() && (ctx.ProductSpecific() || (isOwnerPlatform && ctx.inVendor())) {
Jiyong Park74955042019-10-22 20:19:51 +09001390 dir = android.PathForModuleGen(ctx, "sysprop/public", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001391 }
1392 }
1393
Paul Duffin37e0de52021-02-19 17:05:39 +00001394 // Make sure to only export headers which are within the include directory.
1395 _, headers := android.FilterPathListPredicate(library.baseCompiler.syspropHeaders, func(path android.Path) bool {
1396 _, isRel := android.MaybeRel(ctx, dir.String(), path.String())
1397 return isRel
1398 })
1399
Chris Parsons3c27ca32020-11-20 12:42:07 -05001400 // Add sysprop-related directories to the exported directories of this library.
Inseob Kim69378442019-06-03 19:10:47 +09001401 library.reexportDirs(dir)
Paul Duffin33056e82021-02-19 13:49:08 +00001402 library.reexportDeps(library.baseCompiler.syspropOrderOnlyDeps...)
Paul Duffin37e0de52021-02-19 17:05:39 +00001403 library.addExportedGeneratedHeaders(headers...)
Inseob Kim21f26902018-09-06 00:55:20 +09001404 }
1405
Chris Parsons3c27ca32020-11-20 12:42:07 -05001406 // Add stub-related flags if this library is a stub library.
Jiyong Park892a98f2020-12-14 09:20:00 +09001407 library.exportVersioningMacroIfNeeded(ctx)
Jiyong Parkda732bd2018-11-02 18:23:15 +09001408
Chris Parsons3c27ca32020-11-20 12:42:07 -05001409 // Propagate a Provider containing information about exported flags, deps, and include paths.
Colin Cross0de8a1e2020-09-18 14:15:30 -07001410 library.flagExporter.setProvider(ctx)
1411
Colin Cross4d9c2d12016-07-29 12:48:20 -07001412 return out
1413}
1414
Jiyong Park892a98f2020-12-14 09:20:00 +09001415func (library *libraryDecorator) exportVersioningMacroIfNeeded(ctx android.BaseModuleContext) {
Colin Cross127bb8b2020-12-16 16:46:01 -08001416 if library.buildStubs() && library.stubsVersion() != "" && !library.skipAPIDefine {
Jiyong Park892a98f2020-12-14 09:20:00 +09001417 name := versioningMacroName(ctx.Module().(*Module).ImplementationModuleName(ctx))
Jooyung Han11b0fbd2021-02-05 02:28:22 +09001418 apiLevel, err := android.ApiLevelFromUser(ctx, library.stubsVersion())
1419 if err != nil {
1420 ctx.ModuleErrorf("Can't export version macro: %s", err.Error())
1421 }
1422 library.reexportFlags("-D" + name + "=" + strconv.Itoa(apiLevel.FinalOrPreviewInt()))
Jiyong Park892a98f2020-12-14 09:20:00 +09001423 }
1424}
1425
Chris Parsons3c27ca32020-11-20 12:42:07 -05001426// buildStatic returns true if this library should be built as a static library.
Colin Crossb916a382016-07-29 17:28:03 -07001427func (library *libraryDecorator) buildStatic() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001428 return library.MutatedProperties.BuildStatic &&
1429 BoolDefault(library.StaticProperties.Static.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001430}
1431
Chris Parsons3c27ca32020-11-20 12:42:07 -05001432// buildShared returns true if this library should be built as a shared library.
Colin Crossb916a382016-07-29 17:28:03 -07001433func (library *libraryDecorator) buildShared() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001434 return library.MutatedProperties.BuildShared &&
1435 BoolDefault(library.SharedProperties.Shared.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001436}
1437
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001438func (library *libraryDecorator) objs() Objects {
1439 return library.objects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001440}
1441
Colin Cross0de8a1e2020-09-18 14:15:30 -07001442func (library *libraryDecorator) reuseObjs() Objects {
1443 return library.reuseObjects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001444}
1445
Colin Cross26c34ed2016-09-30 17:10:16 -07001446func (library *libraryDecorator) toc() android.OptionalPath {
1447 return library.tocFile
1448}
1449
Jiyong Parkf1194352019-02-25 11:05:47 +09001450func (library *libraryDecorator) installSymlinkToRuntimeApex(ctx ModuleContext, file android.Path) {
1451 dir := library.baseInstaller.installDir(ctx)
1452 dirOnDevice := android.InstallPathToOnDevicePath(ctx, dir)
1453 target := "/" + filepath.Join("apex", "com.android.runtime", dir.Base(), "bionic", file.Base())
1454 ctx.InstallAbsoluteSymlink(dir, file.Base(), target)
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001455 library.postInstallCmds = append(library.postInstallCmds, makeSymlinkCmd(dirOnDevice, file.Base(), target))
Jiyong Parkf1194352019-02-25 11:05:47 +09001456}
1457
Colin Crossb916a382016-07-29 17:28:03 -07001458func (library *libraryDecorator) install(ctx ModuleContext, file android.Path) {
Colin Crossc43ae772017-04-14 15:42:53 -07001459 if library.shared() {
Justin Yun8fe12122017-12-07 17:18:15 +09001460 if ctx.Device() && ctx.useVndk() {
Jooyung Han261e1582020-10-20 18:54:21 +09001461 // set subDir for VNDK extensions
Ivan Lozanof9e21722020-12-02 09:00:51 -05001462 if ctx.IsVndkExt() {
Jooyung Han261e1582020-10-20 18:54:21 +09001463 if ctx.isVndkSp() {
1464 library.baseInstaller.subDir = "vndk-sp"
1465 } else {
1466 library.baseInstaller.subDir = "vndk"
1467 }
1468 }
1469
Justin Yun31094b12020-12-24 16:11:23 +09001470 // In some cases we want to use core variant for VNDK-Core libs.
1471 // Skip product variant since VNDKs use only the vendor variant.
1472 if ctx.isVndk() && !ctx.isVndkSp() && !ctx.IsVndkExt() && !ctx.inProduct() {
Vic Yang1a5812a2020-01-31 10:38:40 -08001473 mayUseCoreVariant := true
1474
1475 if ctx.mustUseVendorVariant() {
1476 mayUseCoreVariant = false
1477 }
1478
Vic Yang1a5812a2020-01-31 10:38:40 -08001479 if ctx.Config().CFIEnabledForPath(ctx.ModuleDir()) && ctx.Arch().ArchType == android.Arm64 {
1480 mayUseCoreVariant = false
1481 }
1482
1483 if mayUseCoreVariant {
Vic Yangd92090f2020-01-08 14:32:28 -08001484 library.checkSameCoreVariant = true
1485 if ctx.DeviceConfig().VndkUseCoreVariant() {
1486 library.useCoreVariant = true
1487 }
Vic Yangefd249e2018-11-12 20:19:56 -08001488 }
Justin Yun8fe12122017-12-07 17:18:15 +09001489 }
Logan Chienf3511742017-10-31 18:04:35 +08001490
Jooyung Han261e1582020-10-20 18:54:21 +09001491 // do not install vndk libs
1492 // vndk libs are packaged into VNDK APEX
Ivan Lozanof9e21722020-12-02 09:00:51 -05001493 if ctx.isVndk() && !ctx.IsVndkExt() {
Jooyung Han261e1582020-10-20 18:54:21 +09001494 return
Justin Yun8effde42017-06-23 19:24:43 +09001495 }
Colin Cross56a83212020-09-15 18:30:11 -07001496 } else if len(library.Properties.Stubs.Versions) > 0 && !ctx.Host() && ctx.directlyInAnyApex() {
Jiyong Parkf1194352019-02-25 11:05:47 +09001497 // Bionic libraries (e.g. libc.so) is installed to the bootstrap subdirectory.
1498 // The original path becomes a symlink to the corresponding file in the
1499 // runtime APEX.
Colin Cross3b19f5d2019-09-17 14:45:31 -07001500 translatedArch := ctx.Target().NativeBridge == android.NativeBridgeEnabled
Colin Cross56a83212020-09-15 18:30:11 -07001501 if InstallToBootstrap(ctx.baseModuleName(), ctx.Config()) && !library.buildStubs() &&
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001502 !translatedArch && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() {
Martin Stjernholm279de572019-09-10 23:18:20 +01001503 if ctx.Device() {
Jiyong Parkc3e2c862019-03-16 01:10:08 +09001504 library.installSymlinkToRuntimeApex(ctx, file)
1505 }
Jiyong Park429660f2019-01-16 22:31:11 +09001506 library.baseInstaller.subDir = "bootstrap"
1507 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001508 } else if ctx.directlyInAnyApex() && ctx.IsLlndk() && !isBionic(ctx.baseModuleName()) {
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001509 // Skip installing LLNDK (non-bionic) libraries moved to APEX.
Colin Crossa9c8c9f2020-12-16 10:20:23 -08001510 ctx.Module().HideFromMake()
Justin Yun8effde42017-06-23 19:24:43 +09001511 }
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001512
Colin Cross4d9c2d12016-07-29 12:48:20 -07001513 library.baseInstaller.install(ctx, file)
1514 }
Dan Albertf563d252017-10-13 00:29:00 -07001515
Dan Albert281f22b2017-12-13 15:03:47 -08001516 if Bool(library.Properties.Static_ndk_lib) && library.static() &&
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001517 !ctx.useVndk() && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() && ctx.Device() &&
Jiyong Park7ed9de32018-10-15 22:25:07 +09001518 library.baseLinker.sanitize.isUnsanitizedVariant() &&
Colin Cross95b07f22020-12-16 11:06:50 -08001519 ctx.isForPlatform() && !ctx.isPreventInstall() {
Dan Albertf563d252017-10-13 00:29:00 -07001520 installPath := getNdkSysrootBase(ctx).Join(
Dan Albertea4b7b92018-04-25 16:05:30 -07001521 ctx, "usr/lib", config.NDKTriple(ctx.toolchain()), file.Base())
Dan Albertf563d252017-10-13 00:29:00 -07001522
1523 ctx.ModuleBuild(pctx, android.ModuleBuildParams{
1524 Rule: android.Cp,
1525 Description: "install " + installPath.Base(),
1526 Output: installPath,
1527 Input: file,
1528 })
1529
Colin Cross0875c522017-11-28 17:34:01 -08001530 library.ndkSysrootPath = installPath
Dan Albertf563d252017-10-13 00:29:00 -07001531 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001532}
1533
Paul Duffin0cb37b92020-03-04 14:52:46 +00001534func (library *libraryDecorator) everInstallable() bool {
1535 // Only shared and static libraries are installed. Header libraries (which are
1536 // neither static or shared) are not installed.
1537 return library.shared() || library.static()
1538}
1539
Chris Parsons3c27ca32020-11-20 12:42:07 -05001540// static returns true if this library is for a "static' variant.
Colin Crossb916a382016-07-29 17:28:03 -07001541func (library *libraryDecorator) static() bool {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001542 return library.MutatedProperties.VariantIsStatic
Colin Cross4d9c2d12016-07-29 12:48:20 -07001543}
1544
Chris Parsons3c27ca32020-11-20 12:42:07 -05001545// shared returns true if this library is for a "shared' variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001546func (library *libraryDecorator) shared() bool {
1547 return library.MutatedProperties.VariantIsShared
1548}
1549
Chris Parsons3c27ca32020-11-20 12:42:07 -05001550// header returns true if this library is for a header-only variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001551func (library *libraryDecorator) header() bool {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001552 // Neither "static" nor "shared" implies this library is header-only.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001553 return !library.static() && !library.shared()
1554}
1555
Chris Parsons3c27ca32020-11-20 12:42:07 -05001556// setStatic marks the library variant as "static".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001557func (library *libraryDecorator) setStatic() {
1558 library.MutatedProperties.VariantIsStatic = true
1559 library.MutatedProperties.VariantIsShared = false
1560}
1561
Chris Parsons3c27ca32020-11-20 12:42:07 -05001562// setShared marks the library variant as "shared".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001563func (library *libraryDecorator) setShared() {
1564 library.MutatedProperties.VariantIsStatic = false
1565 library.MutatedProperties.VariantIsShared = true
Colin Crossb916a382016-07-29 17:28:03 -07001566}
1567
Chris Parsons3c27ca32020-11-20 12:42:07 -05001568// BuildOnlyStatic disables building this library as a shared library.
Colin Crossab3b7322016-12-09 14:46:15 -08001569func (library *libraryDecorator) BuildOnlyStatic() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001570 library.MutatedProperties.BuildShared = false
Colin Crossab3b7322016-12-09 14:46:15 -08001571}
1572
Chris Parsons3c27ca32020-11-20 12:42:07 -05001573// BuildOnlyShared disables building this library as a static library.
Colin Crossab3b7322016-12-09 14:46:15 -08001574func (library *libraryDecorator) BuildOnlyShared() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001575 library.MutatedProperties.BuildStatic = false
Colin Crossab3b7322016-12-09 14:46:15 -08001576}
1577
Chris Parsons3c27ca32020-11-20 12:42:07 -05001578// HeaderOnly disables building this library as a shared or static library;
1579// the library only exists to propagate header file dependencies up the build graph.
Colin Cross5950f382016-12-13 12:50:57 -08001580func (library *libraryDecorator) HeaderOnly() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001581 library.MutatedProperties.BuildShared = false
1582 library.MutatedProperties.BuildStatic = false
Colin Cross5950f382016-12-13 12:50:57 -08001583}
1584
Colin Cross127bb8b2020-12-16 16:46:01 -08001585// hasLLNDKStubs returns true if this cc_library module has a variant that will build LLNDK stubs.
1586func (library *libraryDecorator) hasLLNDKStubs() bool {
1587 return String(library.Properties.Llndk_stubs) != ""
1588}
1589
Colin Cross0477b422020-10-13 18:43:54 -07001590func (library *libraryDecorator) implementationModuleName(name string) string {
1591 return name
1592}
1593
Jiyong Park7ed9de32018-10-15 22:25:07 +09001594func (library *libraryDecorator) buildStubs() bool {
1595 return library.MutatedProperties.BuildStubs
1596}
1597
Jiyong Parka034b832019-08-27 14:02:19 +09001598func (library *libraryDecorator) symbolFileForAbiCheck(ctx ModuleContext) *string {
1599 if library.Properties.Header_abi_checker.Symbol_file != nil {
1600 return library.Properties.Header_abi_checker.Symbol_file
1601 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001602 if ctx.Module().(*Module).IsLlndk() {
1603 return library.Properties.Llndk.Symbol_file
1604 }
Colin Cross31076b32020-10-23 17:22:06 -07001605 if library.hasStubsVariants() && library.Properties.Stubs.Symbol_file != nil {
Jiyong Parka034b832019-08-27 14:02:19 +09001606 return library.Properties.Stubs.Symbol_file
1607 }
1608 return nil
1609}
1610
Colin Crossc88c2722020-09-28 17:32:47 -07001611func (library *libraryDecorator) hasStubsVariants() bool {
1612 return len(library.Properties.Stubs.Versions) > 0
1613}
1614
Colin Cross3572cf72020-10-01 15:58:11 -07001615func (library *libraryDecorator) stubsVersions(ctx android.BaseMutatorContext) []string {
Colin Crossc88c2722020-09-28 17:32:47 -07001616 return library.Properties.Stubs.Versions
1617}
1618
1619func (library *libraryDecorator) setStubsVersion(version string) {
1620 library.MutatedProperties.StubsVersion = version
1621}
1622
Jiyong Park7ed9de32018-10-15 22:25:07 +09001623func (library *libraryDecorator) stubsVersion() string {
1624 return library.MutatedProperties.StubsVersion
1625}
1626
Colin Crossc88c2722020-09-28 17:32:47 -07001627func (library *libraryDecorator) setBuildStubs() {
1628 library.MutatedProperties.BuildStubs = true
1629}
1630
1631func (library *libraryDecorator) setAllStubsVersions(versions []string) {
1632 library.MutatedProperties.AllStubsVersions = versions
1633}
1634
1635func (library *libraryDecorator) allStubsVersions() []string {
1636 return library.MutatedProperties.AllStubsVersions
1637}
1638
Jooyung Hanad4c1872020-02-27 17:56:44 +09001639func (library *libraryDecorator) isLatestStubVersion() bool {
1640 versions := library.Properties.Stubs.Versions
1641 return versions[len(versions)-1] == library.stubsVersion()
1642}
1643
Jiyong Parka90ca002019-10-07 15:47:24 +09001644func (library *libraryDecorator) availableFor(what string) bool {
1645 var list []string
1646 if library.static() {
1647 list = library.StaticProperties.Static.Apex_available
1648 } else if library.shared() {
1649 list = library.SharedProperties.Shared.Apex_available
1650 }
1651 if len(list) == 0 {
1652 return false
1653 }
1654 return android.CheckAvailableForApex(what, list)
1655}
1656
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001657func (library *libraryDecorator) makeUninstallable(mod *Module) {
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001658 if library.static() && library.buildStatic() && !library.buildStubs() {
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001659 // If we're asked to make a static library uninstallable we don't do
1660 // anything since AndroidMkEntries always sets LOCAL_UNINSTALLABLE_MODULE
1661 // for these entries. This is done to still get the make targets for NOTICE
1662 // files from notice_files.mk, which other libraries might depend on.
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001663 return
1664 }
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001665 mod.ModuleBase.MakeUninstallable()
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001666}
1667
Colin Cross571cccf2019-02-04 11:22:08 -08001668var versioningMacroNamesListKey = android.NewOnceKey("versioningMacroNamesList")
1669
Chris Parsons3c27ca32020-11-20 12:42:07 -05001670// versioningMacroNamesList returns a singleton map, where keys are "version macro names",
1671// and values are the module name responsible for registering the version macro name.
1672//
1673// Version macros are used when building against stubs, to provide version information about
1674// the stub. Only stub libraries should have an entry in this list.
1675//
1676// For example, when building against libFoo#ver, __LIBFOO_API__ macro is set to ver so
1677// that headers from libFoo can be conditionally compiled (this may hide APIs
1678// that are not available for the version).
1679//
1680// This map is used to ensure that there aren't conflicts between these version macro names.
Jiyong Parkda732bd2018-11-02 18:23:15 +09001681func versioningMacroNamesList(config android.Config) *map[string]string {
Colin Cross571cccf2019-02-04 11:22:08 -08001682 return config.Once(versioningMacroNamesListKey, func() interface{} {
Jiyong Parkda732bd2018-11-02 18:23:15 +09001683 m := make(map[string]string)
1684 return &m
1685 }).(*map[string]string)
1686}
1687
1688// alphanumeric and _ characters are preserved.
1689// other characters are all converted to _
1690var charsNotForMacro = regexp.MustCompile("[^a-zA-Z0-9_]+")
1691
Chris Parsons3c27ca32020-11-20 12:42:07 -05001692// versioningMacroName returns the canonical version macro name for the given module.
Jiyong Parkda732bd2018-11-02 18:23:15 +09001693func versioningMacroName(moduleName string) string {
1694 macroName := charsNotForMacro.ReplaceAllString(moduleName, "_")
Jooyung Hanb04a4992020-03-13 18:57:35 +09001695 macroName = strings.ToUpper(macroName)
Jiyong Parkda732bd2018-11-02 18:23:15 +09001696 return "__" + macroName + "_API__"
1697}
1698
Chris Parsons3c27ca32020-11-20 12:42:07 -05001699// NewLibrary builds and returns a new Module corresponding to a C++ library.
1700// Individual module implementations which comprise a C++ library (or something like
1701// a C++ library) should call this function, set some fields on the result, and
1702// then call the Init function.
Colin Crossab3b7322016-12-09 14:46:15 -08001703func NewLibrary(hod android.HostOrDeviceSupported) (*Module, *libraryDecorator) {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001704 module := newModule(hod, android.MultilibBoth)
1705
Colin Crossb916a382016-07-29 17:28:03 -07001706 library := &libraryDecorator{
Colin Crossa48ab5b2017-02-14 15:28:44 -08001707 MutatedProperties: LibraryMutatedProperties{
Colin Crossab3b7322016-12-09 14:46:15 -08001708 BuildShared: true,
1709 BuildStatic: true,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001710 },
Colin Crossb916a382016-07-29 17:28:03 -07001711 baseCompiler: NewBaseCompiler(),
Dan Albert61f32122018-07-26 14:00:24 -07001712 baseLinker: NewBaseLinker(module.sanitize),
Colin Crossb916a382016-07-29 17:28:03 -07001713 baseInstaller: NewBaseInstaller("lib", "lib64", InstallInSystem),
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001714 sabi: module.sabi,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001715 }
1716
Colin Crossb916a382016-07-29 17:28:03 -07001717 module.compiler = library
1718 module.linker = library
1719 module.installer = library
Colin Cross31076b32020-10-23 17:22:06 -07001720 module.library = library
Colin Crossb916a382016-07-29 17:28:03 -07001721
1722 return module, library
1723}
1724
Colin Cross10d22312017-05-03 11:01:58 -07001725// connects a shared library to a static library in order to reuse its .o files to avoid
1726// compiling source files twice.
1727func reuseStaticLibrary(mctx android.BottomUpMutatorContext, static, shared *Module) {
1728 if staticCompiler, ok := static.compiler.(*libraryDecorator); ok {
1729 sharedCompiler := shared.compiler.(*libraryDecorator)
Dan Willemsen3a26eef2018-12-03 15:25:46 -08001730
1731 // Check libraries in addition to cflags, since libraries may be exporting different
1732 // include directories.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001733 if len(staticCompiler.StaticProperties.Static.Cflags) == 0 &&
1734 len(sharedCompiler.SharedProperties.Shared.Cflags) == 0 &&
1735 len(staticCompiler.StaticProperties.Static.Whole_static_libs) == 0 &&
1736 len(sharedCompiler.SharedProperties.Shared.Whole_static_libs) == 0 &&
1737 len(staticCompiler.StaticProperties.Static.Static_libs) == 0 &&
1738 len(sharedCompiler.SharedProperties.Shared.Static_libs) == 0 &&
1739 len(staticCompiler.StaticProperties.Static.Shared_libs) == 0 &&
1740 len(sharedCompiler.SharedProperties.Shared.Shared_libs) == 0 &&
Martin Stjernholm10566a02020-03-24 01:19:52 +00001741 // Compare System_shared_libs properties with nil because empty lists are
1742 // semantically significant for them.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001743 staticCompiler.StaticProperties.Static.System_shared_libs == nil &&
1744 sharedCompiler.SharedProperties.Shared.System_shared_libs == nil {
Colin Cross10d22312017-05-03 11:01:58 -07001745
1746 mctx.AddInterVariantDependency(reuseObjTag, shared, static)
1747 sharedCompiler.baseCompiler.Properties.OriginalSrcs =
1748 sharedCompiler.baseCompiler.Properties.Srcs
1749 sharedCompiler.baseCompiler.Properties.Srcs = nil
1750 sharedCompiler.baseCompiler.Properties.Generated_sources = nil
1751 }
Colin Cross0de8a1e2020-09-18 14:15:30 -07001752
1753 // This dep is just to reference static variant from shared variant
1754 mctx.AddInterVariantDependency(staticVariantTag, shared, static)
Colin Cross10d22312017-05-03 11:01:58 -07001755 }
1756}
1757
Chris Parsons3c27ca32020-11-20 12:42:07 -05001758// LinkageMutator adds "static" or "shared" variants for modules depending
1759// on whether the module can be built as a static library or a shared library.
Colin Crosse40b4ea2018-10-02 22:25:58 -07001760func LinkageMutator(mctx android.BottomUpMutatorContext) {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001761 ccPrebuilt := false
Colin Crossb916a382016-07-29 17:28:03 -07001762 if m, ok := mctx.Module().(*Module); ok && m.linker != nil {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001763 _, ccPrebuilt = m.linker.(prebuiltLibraryInterface)
Ivan Lozano52767be2019-10-18 14:49:46 -07001764 }
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001765 if ccPrebuilt {
Ivan Lozano52767be2019-10-18 14:49:46 -07001766 library := mctx.Module().(*Module).linker.(prebuiltLibraryInterface)
Colin Cross33b2fb72019-05-14 14:07:01 -07001767
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001768 // Differentiate between header only and building an actual static/shared library
Colin Cross127bb8b2020-12-16 16:46:01 -08001769 buildStatic := library.buildStatic()
1770 buildShared := library.buildShared()
1771 if buildStatic || buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001772 // Always create both the static and shared variants for prebuilt libraries, and then disable the one
1773 // that is not being used. This allows them to share the name of a cc_library module, which requires that
1774 // all the variants of the cc_library also exist on the prebuilt.
1775 modules := mctx.CreateLocalVariations("static", "shared")
1776 static := modules[0].(*Module)
1777 shared := modules[1].(*Module)
Colin Cross33b2fb72019-05-14 14:07:01 -07001778
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001779 static.linker.(prebuiltLibraryInterface).setStatic()
1780 shared.linker.(prebuiltLibraryInterface).setShared()
Colin Cross33b2fb72019-05-14 14:07:01 -07001781
Colin Cross127bb8b2020-12-16 16:46:01 -08001782 if buildShared {
Colin Cross81ca6cd2020-08-06 17:46:48 -07001783 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08001784 } else if buildStatic {
Colin Cross81ca6cd2020-08-06 17:46:48 -07001785 mctx.AliasVariation("static")
1786 }
1787
Colin Cross127bb8b2020-12-16 16:46:01 -08001788 if !buildStatic {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001789 static.linker.(prebuiltLibraryInterface).disablePrebuilt()
1790 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001791 if !buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001792 shared.linker.(prebuiltLibraryInterface).disablePrebuilt()
1793 }
1794 } else {
1795 // Header only
Colin Crossb916a382016-07-29 17:28:03 -07001796 }
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001797
Ivan Lozano52767be2019-10-18 14:49:46 -07001798 } else if library, ok := mctx.Module().(LinkableInterface); ok && library.CcLibraryInterface() {
Ivan Lozano52767be2019-10-18 14:49:46 -07001799
Ivan Lozano2b262972019-11-21 12:30:50 -08001800 // Non-cc.Modules may need an empty variant for their mutators.
1801 variations := []string{}
1802 if library.NonCcVariants() {
1803 variations = append(variations, "")
1804 }
1805
Colin Cross127bb8b2020-12-16 16:46:01 -08001806 isLLNDK := false
1807 if m, ok := mctx.Module().(*Module); ok {
Colin Cross127bb8b2020-12-16 16:46:01 -08001808 // Don't count the vestigial llndk_library module as isLLNDK, it needs a static
1809 // variant so that a cc_library_prebuilt can depend on it.
Colin Cross4f4f8eb2021-01-06 14:07:27 -08001810 isLLNDK = m.IsLlndk() && !isVestigialLLNDKModule(m)
Colin Cross127bb8b2020-12-16 16:46:01 -08001811 }
1812 buildStatic := library.BuildStaticVariant() && !isLLNDK
1813 buildShared := library.BuildSharedVariant()
1814 if buildStatic && buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08001815 variations := append([]string{"static", "shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001816
1817 modules := mctx.CreateLocalVariations(variations...)
1818 static := modules[0].(LinkableInterface)
1819 shared := modules[1].(LinkableInterface)
1820
1821 static.SetStatic()
1822 shared.SetShared()
1823
1824 if _, ok := library.(*Module); ok {
1825 reuseStaticLibrary(mctx, static.(*Module), shared.(*Module))
1826 }
Colin Cross81ca6cd2020-08-06 17:46:48 -07001827 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08001828 } else if buildStatic {
Ivan Lozano2b262972019-11-21 12:30:50 -08001829 variations := append([]string{"static"}, variations...)
1830
1831 modules := mctx.CreateLocalVariations(variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001832 modules[0].(LinkableInterface).SetStatic()
Colin Cross81ca6cd2020-08-06 17:46:48 -07001833 mctx.AliasVariation("static")
Colin Cross127bb8b2020-12-16 16:46:01 -08001834 } else if buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08001835 variations := append([]string{"shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001836
Ivan Lozano2b262972019-11-21 12:30:50 -08001837 modules := mctx.CreateLocalVariations(variations...)
1838 modules[0].(LinkableInterface).SetShared()
Colin Cross81ca6cd2020-08-06 17:46:48 -07001839 mctx.AliasVariation("shared")
Ivan Lozano2b262972019-11-21 12:30:50 -08001840 } else if len(variations) > 0 {
1841 mctx.CreateLocalVariations(variations...)
Colin Cross81ca6cd2020-08-06 17:46:48 -07001842 mctx.AliasVariation(variations[0])
Ivan Lozano2b262972019-11-21 12:30:50 -08001843 }
Colin Crossb916a382016-07-29 17:28:03 -07001844 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001845}
Jiyong Park7ed9de32018-10-15 22:25:07 +09001846
Chris Parsons3c27ca32020-11-20 12:42:07 -05001847// normalizeVersions modifies `versions` in place, so that each raw version
1848// string becomes its normalized canonical form.
1849// Validates that the versions in `versions` are specified in least to greatest order.
Jooyung Hanaed150d2020-04-02 01:41:41 +09001850func normalizeVersions(ctx android.BaseModuleContext, versions []string) {
Dan Albertc8060532020-07-22 22:32:17 -07001851 var previous android.ApiLevel
Jooyung Hanad4c1872020-02-27 17:56:44 +09001852 for i, v := range versions {
Dan Albertc8060532020-07-22 22:32:17 -07001853 ver, err := android.ApiLevelFromUser(ctx, v)
Jooyung Hanad4c1872020-02-27 17:56:44 +09001854 if err != nil {
Jooyung Hanaed150d2020-04-02 01:41:41 +09001855 ctx.PropertyErrorf("versions", "%s", err.Error())
1856 return
Jooyung Hanad4c1872020-02-27 17:56:44 +09001857 }
Dan Albertc8060532020-07-22 22:32:17 -07001858 if i > 0 && ver.LessThanOrEqualTo(previous) {
1859 ctx.PropertyErrorf("versions", "not sorted: %v", versions)
1860 }
1861 versions[i] = ver.String()
1862 previous = ver
Jooyung Hanaed150d2020-04-02 01:41:41 +09001863 }
Jooyung Hanad4c1872020-02-27 17:56:44 +09001864}
1865
Jooyung Han61b66e92020-03-21 14:21:46 +00001866func createVersionVariations(mctx android.BottomUpMutatorContext, versions []string) {
Colin Cross127bb8b2020-12-16 16:46:01 -08001867 // "" is for the non-stubs (implementation) variant for system modules, or the LLNDK variant
1868 // for LLNDK modules.
Colin Cross0de8a1e2020-09-18 14:15:30 -07001869 variants := append(android.CopyOf(versions), "")
Jooyung Han61b66e92020-03-21 14:21:46 +00001870
Colin Cross127bb8b2020-12-16 16:46:01 -08001871 m := mctx.Module().(*Module)
1872 isLLNDK := m.IsLlndk()
1873
Colin Crossd1f898e2020-08-18 18:35:15 -07001874 modules := mctx.CreateLocalVariations(variants...)
Jooyung Han61b66e92020-03-21 14:21:46 +00001875 for i, m := range modules {
Colin Cross127bb8b2020-12-16 16:46:01 -08001876
1877 if variants[i] != "" || isLLNDK {
1878 // A stubs or LLNDK stubs variant.
Colin Cross31076b32020-10-23 17:22:06 -07001879 c := m.(*Module)
Colin Cross31076b32020-10-23 17:22:06 -07001880 c.sanitize = nil
1881 c.stl = nil
1882 c.Properties.PreventInstall = true
1883 lib := moduleLibraryInterface(m)
1884 lib.setBuildStubs()
Colin Cross127bb8b2020-12-16 16:46:01 -08001885
1886 if variants[i] != "" {
1887 // A non-LLNDK stubs module is hidden from make and has a dependency from the
1888 // implementation module to the stubs module.
1889 c.Properties.HideFromMake = true
1890 lib.setStubsVersion(variants[i])
1891 mctx.AddInterVariantDependency(stubImplDepTag, modules[len(modules)-1], modules[i])
1892 }
Jooyung Han61b66e92020-03-21 14:21:46 +00001893 }
1894 }
Colin Cross094faa52020-08-06 17:38:25 -07001895 mctx.AliasVariation("")
Colin Crossd1f898e2020-08-18 18:35:15 -07001896 latestVersion := ""
1897 if len(versions) > 0 {
1898 latestVersion = versions[len(versions)-1]
1899 }
1900 mctx.CreateAliasVariation("latest", latestVersion)
Jooyung Han61b66e92020-03-21 14:21:46 +00001901}
1902
Colin Crossbbc941b2020-09-30 12:27:01 -07001903func createPerApiVersionVariations(mctx android.BottomUpMutatorContext, minSdkVersion string) {
1904 from, err := nativeApiLevelFromUser(mctx, minSdkVersion)
1905 if err != nil {
1906 mctx.PropertyErrorf("min_sdk_version", err.Error())
1907 return
1908 }
1909
1910 versionStrs := ndkLibraryVersions(mctx, from)
1911 modules := mctx.CreateLocalVariations(versionStrs...)
1912
1913 for i, module := range modules {
1914 module.(*Module).Properties.Sdk_version = StringPtr(versionStrs[i])
Jiyong Parkfdaa5f72021-03-19 22:18:04 +09001915 module.(*Module).Properties.Min_sdk_version = StringPtr(versionStrs[i])
Colin Crossbbc941b2020-09-30 12:27:01 -07001916 }
1917}
1918
Colin Cross3146c5c2020-09-30 15:34:40 -07001919func CanBeOrLinkAgainstVersionVariants(module interface {
Jooyung Han624d35c2020-04-10 12:57:24 +09001920 Host() bool
1921 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001922 InVendorRamdisk() bool
Jooyung Han624d35c2020-04-10 12:57:24 +09001923}) bool {
Jose Galmes6f843bc2020-12-11 13:36:29 -08001924 return !module.Host() && !module.InRamdisk() && !module.InVendorRamdisk()
Jooyung Han624d35c2020-04-10 12:57:24 +09001925}
1926
Colin Cross3146c5c2020-09-30 15:34:40 -07001927func CanBeVersionVariant(module interface {
1928 Host() bool
1929 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001930 InVendorRamdisk() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07001931 InRecovery() bool
1932 CcLibraryInterface() bool
1933 Shared() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07001934}) bool {
1935 return CanBeOrLinkAgainstVersionVariants(module) &&
Colin Crossa717db72020-10-23 14:53:06 -07001936 module.CcLibraryInterface() && module.Shared()
Colin Cross3146c5c2020-09-30 15:34:40 -07001937}
1938
Colin Cross127bb8b2020-12-16 16:46:01 -08001939func moduleLibraryInterface(module blueprint.Module) libraryInterface {
Colin Cross31076b32020-10-23 17:22:06 -07001940 if m, ok := module.(*Module); ok {
1941 return m.library
1942 }
1943 return nil
1944}
1945
Colin Crossd1f898e2020-08-18 18:35:15 -07001946// versionSelector normalizes the versions in the Stubs.Versions property into MutatedProperties.AllStubsVersions,
1947// and propagates the value from implementation libraries to llndk libraries with the same name.
1948func versionSelectorMutator(mctx android.BottomUpMutatorContext) {
Colin Cross31076b32020-10-23 17:22:06 -07001949 if library := moduleLibraryInterface(mctx.Module()); library != nil && CanBeVersionVariant(mctx.Module().(*Module)) {
1950 if library.buildShared() {
1951 versions := library.stubsVersions(mctx)
Colin Cross3572cf72020-10-01 15:58:11 -07001952 if len(versions) > 0 {
1953 normalizeVersions(mctx, versions)
1954 if mctx.Failed() {
Colin Crossbbc941b2020-09-30 12:27:01 -07001955 return
1956 }
Colin Cross3572cf72020-10-01 15:58:11 -07001957 // Set the versions on the pre-mutated module so they can be read by any llndk modules that
1958 // depend on the implementation library and haven't been mutated yet.
Colin Cross31076b32020-10-23 17:22:06 -07001959 library.setAllStubsVersions(versions)
Colin Cross127bb8b2020-12-16 16:46:01 -08001960 }
1961
1962 if mctx.Module().(*Module).UseVndk() && library.hasLLNDKStubs() {
1963 // Propagate the version to the llndk stubs module.
1964 mctx.VisitDirectDepsWithTag(llndkStubDepTag, func(stubs android.Module) {
1965 if stubsLib := moduleLibraryInterface(stubs); stubsLib != nil {
1966 stubsLib.setAllStubsVersions(library.allStubsVersions())
1967 }
1968 })
Jiyong Park7ed9de32018-10-15 22:25:07 +09001969 }
Jooyung Han61b66e92020-03-21 14:21:46 +00001970 }
Colin Crossd1f898e2020-08-18 18:35:15 -07001971 }
1972}
Jooyung Han61b66e92020-03-21 14:21:46 +00001973
Colin Crossd1f898e2020-08-18 18:35:15 -07001974// versionMutator splits a module into the mandatory non-stubs variant
1975// (which is unnamed) and zero or more stubs variants.
1976func versionMutator(mctx android.BottomUpMutatorContext) {
Colin Cross31076b32020-10-23 17:22:06 -07001977 if library := moduleLibraryInterface(mctx.Module()); library != nil && CanBeVersionVariant(mctx.Module().(*Module)) {
1978 createVersionVariations(mctx, library.allStubsVersions())
Colin Crossbbc941b2020-09-30 12:27:01 -07001979 return
1980 }
1981
1982 if m, ok := mctx.Module().(*Module); ok {
1983 if m.SplitPerApiLevel() && m.IsSdkVariant() {
1984 if mctx.Os() != android.Android {
1985 return
1986 }
1987 createPerApiVersionVariations(mctx, m.MinSdkVersion())
1988 }
Jiyong Park7ed9de32018-10-15 22:25:07 +09001989 }
Jiyong Park7ed9de32018-10-15 22:25:07 +09001990}
Colin Crossd7227f92019-09-05 14:26:33 -07001991
1992// maybeInjectBoringSSLHash adds a rule to run bssl_inject_hash on the output file if the module has the
1993// inject_bssl_hash or if any static library dependencies have inject_bssl_hash set. It returns the output path
1994// that the linked output file should be written to.
1995// TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
1996func maybeInjectBoringSSLHash(ctx android.ModuleContext, outputFile android.ModuleOutPath,
1997 inject *bool, fileName string) android.ModuleOutPath {
1998 // TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
1999 injectBoringSSLHash := Bool(inject)
2000 ctx.VisitDirectDeps(func(dep android.Module) {
Colin Cross6e511a92020-07-27 21:26:48 -07002001 if tag, ok := ctx.OtherModuleDependencyTag(dep).(libraryDependencyTag); ok && tag.static() {
Colin Crossd7227f92019-09-05 14:26:33 -07002002 if cc, ok := dep.(*Module); ok {
2003 if library, ok := cc.linker.(*libraryDecorator); ok {
2004 if Bool(library.Properties.Inject_bssl_hash) {
2005 injectBoringSSLHash = true
2006 }
2007 }
2008 }
2009 }
2010 })
2011 if injectBoringSSLHash {
2012 hashedOutputfile := outputFile
2013 outputFile = android.PathForModuleOut(ctx, "unhashed", fileName)
2014
Colin Crossf1a035e2020-11-16 17:32:30 -08002015 rule := android.NewRuleBuilder(pctx, ctx)
Colin Crossd7227f92019-09-05 14:26:33 -07002016 rule.Command().
Colin Crossf1a035e2020-11-16 17:32:30 -08002017 BuiltTool("bssl_inject_hash").
Pete Bentley5c4be822019-10-01 17:03:17 +01002018 Flag("-sha256").
Colin Crossd7227f92019-09-05 14:26:33 -07002019 FlagWithInput("-in-object ", outputFile).
2020 FlagWithOutput("-o ", hashedOutputfile)
Colin Crossf1a035e2020-11-16 17:32:30 -08002021 rule.Build("injectCryptoHash", "inject crypto hash")
Colin Crossd7227f92019-09-05 14:26:33 -07002022 }
2023
2024 return outputFile
2025}
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002026
Jingwen Chen07027912021-03-15 06:02:43 -04002027func Bp2BuildParseHeaderLibs(ctx android.TopDownMutatorContext, module *Module) bazel.LabelListAttribute {
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002028 var headerLibs []string
2029 for _, linkerProps := range module.linker.linkerProps() {
2030 if baseLinkerProps, ok := linkerProps.(*BaseLinkerProperties); ok {
2031 headerLibs = baseLinkerProps.Header_libs
2032 // FIXME: re-export include dirs from baseLinkerProps.Export_header_lib_headers?
2033 break
2034 }
2035 }
Jingwen Chen07027912021-03-15 06:02:43 -04002036 headerLibsLabels := bazel.MakeLabelListAttribute(android.BazelLabelForModuleDeps(ctx, headerLibs))
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002037 return headerLibsLabels
2038}
2039
Jingwen Chen07027912021-03-15 06:02:43 -04002040func Bp2BuildParseExportedIncludes(ctx android.TopDownMutatorContext, module *Module) (bazel.LabelListAttribute, bazel.LabelListAttribute) {
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002041 libraryDecorator := module.linker.(*libraryDecorator)
2042
2043 includeDirs := libraryDecorator.flagExporter.Properties.Export_system_include_dirs
2044 includeDirs = append(includeDirs, libraryDecorator.flagExporter.Properties.Export_include_dirs...)
2045
2046 includeDirsLabels := android.BazelLabelForModuleSrc(ctx, includeDirs)
2047
2048 var includeDirGlobs []string
2049 for _, includeDir := range includeDirs {
2050 includeDirGlobs = append(includeDirGlobs, includeDir+"/**/*.h")
2051 includeDirGlobs = append(includeDirGlobs, includeDir+"/**/*.inc")
2052 includeDirGlobs = append(includeDirGlobs, includeDir+"/**/*.hpp")
2053 }
2054
2055 headersLabels := android.BazelLabelForModuleSrc(ctx, includeDirGlobs)
Jingwen Chen07027912021-03-15 06:02:43 -04002056 return bazel.MakeLabelListAttribute(includeDirsLabels), bazel.MakeLabelListAttribute(headersLabels)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002057}
2058
2059type bazelCcLibraryStaticAttributes struct {
2060 Copts []string
Jingwen Chen07027912021-03-15 06:02:43 -04002061 Srcs bazel.LabelListAttribute
2062 Deps bazel.LabelListAttribute
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002063 Linkstatic bool
Jingwen Chen07027912021-03-15 06:02:43 -04002064 Includes bazel.LabelListAttribute
2065 Hdrs bazel.LabelListAttribute
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002066}
2067
2068type bazelCcLibraryStatic struct {
2069 android.BazelTargetModuleBase
2070 bazelCcLibraryStaticAttributes
2071}
2072
2073func BazelCcLibraryStaticFactory() android.Module {
2074 module := &bazelCcLibraryStatic{}
2075 module.AddProperties(&module.bazelCcLibraryStaticAttributes)
2076 android.InitBazelTargetModule(module)
2077 return module
2078}
2079
2080func CcLibraryStaticBp2Build(ctx android.TopDownMutatorContext) {
2081 module, ok := ctx.Module().(*Module)
2082 if !ok {
2083 // Not a cc module
2084 return
2085 }
2086 if !module.ConvertWithBp2build(ctx) {
2087 return
2088 }
2089 if ctx.ModuleType() != "cc_library_static" {
2090 return
2091 }
2092
2093 var copts []string
2094 var srcs []string
2095 var includeDirs []string
2096 var localIncludeDirs []string
2097 for _, props := range module.compiler.compilerProps() {
2098 if baseCompilerProps, ok := props.(*BaseCompilerProperties); ok {
2099 copts = baseCompilerProps.Cflags
2100 srcs = baseCompilerProps.Srcs
2101 includeDirs = baseCompilerProps.Include_dirs
2102 localIncludeDirs = baseCompilerProps.Local_include_dirs
2103 break
2104 }
2105 }
Jingwen Chen07027912021-03-15 06:02:43 -04002106 srcsLabels := bazel.MakeLabelListAttribute(android.BazelLabelForModuleSrc(ctx, srcs))
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002107
2108 var staticLibs []string
2109 var wholeStaticLibs []string
2110 for _, props := range module.linker.linkerProps() {
2111 if baseLinkerProperties, ok := props.(*BaseLinkerProperties); ok {
2112 staticLibs = baseLinkerProperties.Static_libs
2113 wholeStaticLibs = baseLinkerProperties.Whole_static_libs
2114 break
2115 }
2116 }
2117
2118 // FIXME: Treat Static_libs and Whole_static_libs differently?
2119 allDeps := staticLibs
2120 allDeps = append(allDeps, wholeStaticLibs...)
2121
2122 depsLabels := android.BazelLabelForModuleDeps(ctx, allDeps)
2123
2124 // FIXME: Unify absolute vs relative paths
2125 // FIXME: Use -I copts instead of setting includes= ?
2126 allIncludes := includeDirs
2127 allIncludes = append(allIncludes, localIncludeDirs...)
2128 includesLabels := android.BazelLabelForModuleSrc(ctx, allIncludes)
2129
2130 exportedIncludesLabels, exportedIncludesHeadersLabels := Bp2BuildParseExportedIncludes(ctx, module)
Jingwen Chen07027912021-03-15 06:02:43 -04002131 includesLabels.Append(exportedIncludesLabels.Value)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002132
2133 headerLibsLabels := Bp2BuildParseHeaderLibs(ctx, module)
Jingwen Chen07027912021-03-15 06:02:43 -04002134 depsLabels.Append(headerLibsLabels.Value)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002135
2136 attrs := &bazelCcLibraryStaticAttributes{
2137 Copts: copts,
Jingwen Chen07027912021-03-15 06:02:43 -04002138 Srcs: srcsLabels,
2139 Deps: bazel.MakeLabelListAttribute(depsLabels),
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002140 Linkstatic: true,
Jingwen Chen07027912021-03-15 06:02:43 -04002141 Includes: bazel.MakeLabelListAttribute(includesLabels),
2142 Hdrs: exportedIncludesHeadersLabels,
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002143 }
2144
2145 props := bazel.BazelTargetModuleProperties{
2146 Rule_class: "cc_library_static",
2147 Bzl_load_location: "//build/bazel/rules:cc_library_static.bzl",
2148 }
2149
2150 ctx.CreateBazelTargetModule(BazelCcLibraryStaticFactory, module.Name(), props, attrs)
2151}
2152
2153func (m *bazelCcLibraryStatic) Name() string {
2154 return m.BaseModuleName()
2155}
2156
2157func (m *bazelCcLibraryStatic) GenerateAndroidBuildActions(ctx android.ModuleContext) {}