blob: 53be3a593fa4b21f3627e2f8c0ae5050377533cd [file] [log] [blame]
Colin Cross4d9c2d12016-07-29 12:48:20 -07001// Copyright 2016 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15package cc
16
17import (
Inseob Kim69378442019-06-03 19:10:47 +090018 "fmt"
Logan Chien41eabe62019-04-10 13:33:58 +080019 "io"
Jiyong Parkf1194352019-02-25 11:05:47 +090020 "path/filepath"
Jiyong Parkda732bd2018-11-02 18:23:15 +090021 "regexp"
Jooyung Han11b0fbd2021-02-05 02:28:22 +090022 "strconv"
Colin Cross4d9c2d12016-07-29 12:48:20 -070023 "strings"
Jiyong Parkda732bd2018-11-02 18:23:15 +090024 "sync"
Colin Cross4d9c2d12016-07-29 12:48:20 -070025
Colin Cross127bb8b2020-12-16 16:46:01 -080026 "github.com/google/blueprint"
Colin Cross26c34ed2016-09-30 17:10:16 -070027 "github.com/google/blueprint/pathtools"
Colin Cross4d9c2d12016-07-29 12:48:20 -070028
Colin Cross4d9c2d12016-07-29 12:48:20 -070029 "android/soong/android"
Rupert Shuttleworth095081c2021-03-25 09:06:03 +000030 "android/soong/bazel"
Dan Albertea4b7b92018-04-25 16:05:30 -070031 "android/soong/cc/config"
Colin Cross4d9c2d12016-07-29 12:48:20 -070032)
33
Chris Parsons3c27ca32020-11-20 12:42:07 -050034// LibraryProperties is a collection of properties shared by cc library rules.
Colin Crossb916a382016-07-29 17:28:03 -070035type LibraryProperties struct {
Colin Cross4d9c2d12016-07-29 12:48:20 -070036 // local file name to pass to the linker as -unexported_symbols_list
Colin Cross27b922f2019-03-04 22:35:41 -080037 Unexported_symbols_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070038 // local file name to pass to the linker as -force_symbols_not_weak_list
Colin Cross27b922f2019-03-04 22:35:41 -080039 Force_symbols_not_weak_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070040 // local file name to pass to the linker as -force_symbols_weak_list
Colin Cross27b922f2019-03-04 22:35:41 -080041 Force_symbols_weak_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070042
43 // rename host libraries to prevent overlap with system installed libraries
44 Unique_host_soname *bool
45
Dan Willemsene1240db2016-11-03 14:28:51 -070046 Aidl struct {
47 // export headers generated from .aidl sources
Nan Zhang0007d812017-11-07 10:57:05 -080048 Export_aidl_headers *bool
Dan Willemsene1240db2016-11-03 14:28:51 -070049 }
50
Colin Cross0c461f12016-10-20 16:11:43 -070051 Proto struct {
52 // export headers generated from .proto sources
Nan Zhang0007d812017-11-07 10:57:05 -080053 Export_proto_headers *bool
Colin Cross0c461f12016-10-20 16:11:43 -070054 }
Dan Albertf563d252017-10-13 00:29:00 -070055
Inseob Kimc0907f12019-02-08 21:00:45 +090056 Sysprop struct {
57 // Whether platform owns this sysprop library.
58 Platform *bool
Inseob Kimb3f22ca2019-03-05 12:40:24 +090059 } `blueprint:"mutated"`
Inseob Kimc0907f12019-02-08 21:00:45 +090060
Nan Zhang0007d812017-11-07 10:57:05 -080061 Static_ndk_lib *bool
Jiyong Park7ed9de32018-10-15 22:25:07 +090062
63 Stubs struct {
64 // Relative path to the symbol map. The symbol map provides the list of
65 // symbols that are exported for stubs variant of this library.
Colin Cross27b922f2019-03-04 22:35:41 -080066 Symbol_file *string `android:"path"`
Jiyong Park7ed9de32018-10-15 22:25:07 +090067
Jiyong Parkd4a3a132021-03-17 20:21:35 +090068 // List versions to generate stubs libs for. The version name "current" is always
69 // implicitly added.
Jiyong Park7ed9de32018-10-15 22:25:07 +090070 Versions []string
71 }
dimitryd95964a2018-11-07 13:43:34 +010072
73 // set the name of the output
74 Stem *string `android:"arch_variant"`
75
Colin Cross0fd6a412019-08-16 14:22:10 -070076 // set suffix of the name of the output
77 Suffix *string `android:"arch_variant"`
78
79 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +090080 Vendor, Product struct {
Colin Cross0fd6a412019-08-16 14:22:10 -070081 // set suffix of the name of the output
82 Suffix *string `android:"arch_variant"`
83 }
84 }
85
dimitryd95964a2018-11-07 13:43:34 +010086 // Names of modules to be overridden. Listed modules can only be other shared libraries
87 // (in Make or Soong).
88 // This does not completely prevent installation of the overridden libraries, but if both
89 // binaries would be installed by default (in PRODUCT_PACKAGES) the other library will be removed
90 // from PRODUCT_PACKAGES.
91 Overrides []string
Logan Chiene3d7a0d2019-01-17 00:18:02 +080092
93 // Properties for ABI compatibility checker
94 Header_abi_checker struct {
Logan Chien41eabe62019-04-10 13:33:58 +080095 // Enable ABI checks (even if this is not an LLNDK/VNDK lib)
96 Enabled *bool
97
Logan Chiene3d7a0d2019-01-17 00:18:02 +080098 // Path to a symbol file that specifies the symbols to be included in the generated
99 // ABI dump file
Colin Cross27b922f2019-03-04 22:35:41 -0800100 Symbol_file *string `android:"path"`
Logan Chiene3d7a0d2019-01-17 00:18:02 +0800101
102 // Symbol versions that should be ignored from the symbol file
103 Exclude_symbol_versions []string
104
105 // Symbol tags that should be ignored from the symbol file
106 Exclude_symbol_tags []string
Logan Chien2a65dda2019-10-01 15:58:07 -0700107
108 // Run checks on all APIs (in addition to the ones referred by
109 // one of exported ELF symbols.)
110 Check_all_apis *bool
Logan Chiene3d7a0d2019-01-17 00:18:02 +0800111 }
Vic Yang6cd1be82019-06-24 16:08:48 -0700112
113 // Order symbols in .bss section by their sizes. Only useful for shared libraries.
114 Sort_bss_symbols_by_size *bool
Pete Bentley803e1612019-08-06 22:19:59 +0100115
116 // Inject boringssl hash into the shared library. This is only intended for use by external/boringssl.
117 Inject_bssl_hash *bool `android:"arch_variant"`
Colin Cross0477b422020-10-13 18:43:54 -0700118
119 // If this is an LLNDK library, the name of the equivalent llndk_library module.
120 Llndk_stubs *string
Colin Cross127bb8b2020-12-16 16:46:01 -0800121
122 // If this is an LLNDK library, properties to describe the LLNDK stubs. Will be copied from
123 // the module pointed to by llndk_stubs if it is set.
124 Llndk llndkLibraryProperties
Colin Crossa48ab5b2017-02-14 15:28:44 -0800125}
Colin Cross0c461f12016-10-20 16:11:43 -0700126
Chris Parsons3c27ca32020-11-20 12:42:07 -0500127// StaticProperties is a properties stanza to affect only attributes of the "static" variants of a
128// library module.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700129type StaticProperties struct {
130 Static StaticOrSharedProperties `android:"arch_variant"`
131}
132
Chris Parsons3c27ca32020-11-20 12:42:07 -0500133// SharedProperties is a properties stanza to affect only attributes of the "shared" variants of a
134// library module.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700135type SharedProperties struct {
136 Shared StaticOrSharedProperties `android:"arch_variant"`
137}
138
Chris Parsons3c27ca32020-11-20 12:42:07 -0500139// StaticOrSharedProperties is an embedded struct representing properties to affect attributes of
140// either only the "static" variants or only the "shared" variants of a library module. These override
141// the base properties of the same name.
142// Use `StaticProperties` or `SharedProperties`, depending on which variant is needed.
143// `StaticOrSharedProperties` exists only to avoid duplication.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700144type StaticOrSharedProperties struct {
Evgenii Stepanov2080bfe2020-07-24 15:35:40 -0700145 Srcs []string `android:"path,arch_variant"`
146
147 Sanitized Sanitized `android:"arch_variant"`
148
Colin Crosse1bb5d02019-09-24 14:55:04 -0700149 Cflags []string `android:"arch_variant"`
150
151 Enabled *bool `android:"arch_variant"`
152 Whole_static_libs []string `android:"arch_variant"`
153 Static_libs []string `android:"arch_variant"`
154 Shared_libs []string `android:"arch_variant"`
155 System_shared_libs []string `android:"arch_variant"`
156
157 Export_shared_lib_headers []string `android:"arch_variant"`
158 Export_static_lib_headers []string `android:"arch_variant"`
Jiyong Parka90ca002019-10-07 15:47:24 +0900159
160 Apex_available []string `android:"arch_variant"`
Colin Crosse1bb5d02019-09-24 14:55:04 -0700161}
162
Colin Crossa48ab5b2017-02-14 15:28:44 -0800163type LibraryMutatedProperties struct {
Colin Crossb916a382016-07-29 17:28:03 -0700164 // Build a static variant
165 BuildStatic bool `blueprint:"mutated"`
166 // Build a shared variant
167 BuildShared bool `blueprint:"mutated"`
168 // This variant is shared
169 VariantIsShared bool `blueprint:"mutated"`
170 // This variant is static
171 VariantIsStatic bool `blueprint:"mutated"`
Jiyong Park7ed9de32018-10-15 22:25:07 +0900172
173 // This variant is a stubs lib
174 BuildStubs bool `blueprint:"mutated"`
Jiyong Parkd4a3a132021-03-17 20:21:35 +0900175 // This variant is the latest version
176 IsLatestVersion bool `blueprint:"mutated"`
Jiyong Park7ed9de32018-10-15 22:25:07 +0900177 // Version of the stubs lib
178 StubsVersion string `blueprint:"mutated"`
Colin Crossd1f898e2020-08-18 18:35:15 -0700179 // List of all stubs versions associated with an implementation lib
180 AllStubsVersions []string `blueprint:"mutated"`
Colin Crossb916a382016-07-29 17:28:03 -0700181}
182
183type FlagExporterProperties struct {
184 // list of directories relative to the Blueprints file that will
Dan Willemsen273af7f2016-11-03 15:53:42 -0700185 // be added to the include path (using -I) for this module and any module that links
Colin Cross5d195602017-10-17 16:15:50 -0700186 // against this module. Directories listed in export_include_dirs do not need to be
187 // listed in local_include_dirs.
Colin Crossb916a382016-07-29 17:28:03 -0700188 Export_include_dirs []string `android:"arch_variant"`
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700189
Jiyong Park73c54ee2019-10-22 20:31:18 +0900190 // list of directories that will be added to the system include path
191 // using -isystem for this module and any module that links against this module.
192 Export_system_include_dirs []string `android:"arch_variant"`
193
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700194 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +0900195 Vendor, Product struct {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700196 // list of exported include directories, like
Justin Yun63e9ec72020-10-29 16:49:43 +0900197 // export_include_dirs, that will be applied to
198 // vendor or product variant of this library.
199 // This will overwrite any other declarations.
Steven Morelandb21df8f2018-01-05 14:42:54 -0800200 Override_export_include_dirs []string
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700201 }
202 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700203}
204
205func init() {
Paul Duffin6c26dc72019-12-19 15:02:40 +0000206 RegisterLibraryBuildComponents(android.InitRegistrationContext)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +0000207
208 android.RegisterBp2BuildMutator("cc_library_static", CcLibraryStaticBp2Build)
Jingwen Chen63930982021-03-24 10:04:33 -0400209 android.RegisterBp2BuildMutator("cc_library", CcLibraryBp2Build)
Paul Duffin6c26dc72019-12-19 15:02:40 +0000210}
211
212func RegisterLibraryBuildComponents(ctx android.RegistrationContext) {
213 ctx.RegisterModuleType("cc_library_static", LibraryStaticFactory)
214 ctx.RegisterModuleType("cc_library_shared", LibrarySharedFactory)
215 ctx.RegisterModuleType("cc_library", LibraryFactory)
216 ctx.RegisterModuleType("cc_library_host_static", LibraryHostStaticFactory)
217 ctx.RegisterModuleType("cc_library_host_shared", LibraryHostSharedFactory)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700218}
219
Jingwen Chen63930982021-03-24 10:04:33 -0400220// For bp2build conversion.
221type bazelCcLibraryAttributes struct {
222 Srcs bazel.LabelListAttribute
223 Hdrs bazel.LabelListAttribute
224 Copts bazel.StringListAttribute
225 Linkopts bazel.StringListAttribute
226 Deps bazel.LabelListAttribute
227 User_link_flags bazel.StringListAttribute
228 Includes bazel.StringListAttribute
229}
230
231type bazelCcLibrary struct {
232 android.BazelTargetModuleBase
233 bazelCcLibraryAttributes
234}
235
236func (m *bazelCcLibrary) Name() string {
237 return m.BaseModuleName()
238}
239
240func (m *bazelCcLibrary) GenerateAndroidBuildActions(ctx android.ModuleContext) {}
241
242func BazelCcLibraryFactory() android.Module {
243 module := &bazelCcLibrary{}
244 module.AddProperties(&module.bazelCcLibraryAttributes)
245 android.InitBazelTargetModule(module)
246 return module
247}
248
249func CcLibraryBp2Build(ctx android.TopDownMutatorContext) {
250 m, ok := ctx.Module().(*Module)
251 if !ok || !m.ConvertWithBp2build(ctx) {
252 return
253 }
254
255 if ctx.ModuleType() != "cc_library" {
256 return
257 }
258
Jingwen Chen107c0de2021-04-09 10:43:12 +0000259 compilerAttrs := bp2BuildParseCompilerProps(ctx, m)
260 linkerAttrs := bp2BuildParseLinkerProps(ctx, m)
Jingwen Chen63930982021-03-24 10:04:33 -0400261 exportedIncludes, exportedIncludesHeaders := bp2BuildParseExportedIncludes(ctx, m)
Jingwen Chen107c0de2021-04-09 10:43:12 +0000262 compilerAttrs.hdrs.Append(exportedIncludesHeaders)
Jingwen Chen63930982021-03-24 10:04:33 -0400263
264 attrs := &bazelCcLibraryAttributes{
Jingwen Chen107c0de2021-04-09 10:43:12 +0000265 Srcs: compilerAttrs.srcs,
266 Hdrs: compilerAttrs.hdrs,
267 Copts: compilerAttrs.copts,
268 Linkopts: linkerAttrs.linkopts,
269 Deps: linkerAttrs.deps,
Jingwen Chen63930982021-03-24 10:04:33 -0400270 Includes: exportedIncludes,
271 }
272
273 props := bazel.BazelTargetModuleProperties{
274 Rule_class: "cc_library",
275 Bzl_load_location: "//build/bazel/rules:full_cc_library.bzl",
276 }
277
278 ctx.CreateBazelTargetModule(BazelCcLibraryFactory, m.Name(), props, attrs)
279}
280
Patrice Arruda83c89e02019-03-25 15:32:39 -0700281// cc_library creates both static and/or shared libraries for a device and/or
282// host. By default, a cc_library has a single variant that targets the device.
283// Specifying `host_supported: true` also creates a library that targets the
284// host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700285func LibraryFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800286 module, _ := NewLibrary(android.HostAndDeviceSupported)
Paul Duffina0843f62019-12-13 19:50:38 +0000287 // Can be used as both a static and a shared library.
288 module.sdkMemberTypes = []android.SdkMemberType{
289 sharedLibrarySdkMemberType,
290 staticLibrarySdkMemberType,
Paul Duffin9b76c0b2020-03-12 10:24:35 +0000291 staticAndSharedLibrarySdkMemberType,
Paul Duffina0843f62019-12-13 19:50:38 +0000292 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700293 return module.Init()
294}
295
Patrice Arruda83c89e02019-03-25 15:32:39 -0700296// cc_library_static creates a static library for a device and/or host binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700297func LibraryStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800298 module, library := NewLibrary(android.HostAndDeviceSupported)
299 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000300 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Chris Parsons808d84c2021-03-09 20:43:32 -0500301 module.bazelHandler = &staticLibraryBazelHandler{module: module}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700302 return module.Init()
303}
304
Patrice Arruda83c89e02019-03-25 15:32:39 -0700305// cc_library_shared creates a shared library for a device and/or host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700306func LibrarySharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800307 module, library := NewLibrary(android.HostAndDeviceSupported)
308 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000309 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700310 return module.Init()
311}
312
Patrice Arruda83c89e02019-03-25 15:32:39 -0700313// cc_library_host_static creates a static library that is linkable to a host
314// binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700315func LibraryHostStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800316 module, library := NewLibrary(android.HostSupported)
317 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000318 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700319 return module.Init()
320}
321
Patrice Arruda83c89e02019-03-25 15:32:39 -0700322// cc_library_host_shared creates a shared library that is usable on a host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700323func LibraryHostSharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800324 module, library := NewLibrary(android.HostSupported)
325 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000326 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700327 return module.Init()
328}
329
Chris Parsons3c27ca32020-11-20 12:42:07 -0500330// flagExporter is a separated portion of libraryDecorator pertaining to exported
331// include paths and flags. Keeping this dependency-related information separate
332// from the rest of library information is helpful in keeping data more structured
333// and explicit.
Colin Cross4d9c2d12016-07-29 12:48:20 -0700334type flagExporter struct {
335 Properties FlagExporterProperties
336
Chris Parsons3c27ca32020-11-20 12:42:07 -0500337 dirs android.Paths // Include directories to be included with -I
338 systemDirs android.Paths // System include directories to be included with -isystem
339 flags []string // Exported raw flags.
Inseob Kim69378442019-06-03 19:10:47 +0900340 deps android.Paths
Inseob Kimd110f872019-12-06 13:15:38 +0900341 headers android.Paths
Colin Cross4d9c2d12016-07-29 12:48:20 -0700342}
343
Chris Parsons3c27ca32020-11-20 12:42:07 -0500344// exportedIncludes returns the effective include paths for this module and
345// any module that links against this module. This is obtained from
346// the export_include_dirs property in the appropriate target stanza.
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700347func (f *flagExporter) exportedIncludes(ctx ModuleContext) android.Paths {
Justin Yun6977e8a2020-10-29 18:24:11 +0900348 if ctx.inVendor() && f.Properties.Target.Vendor.Override_export_include_dirs != nil {
Steven Morelandb21df8f2018-01-05 14:42:54 -0800349 return android.PathsForModuleSrc(ctx, f.Properties.Target.Vendor.Override_export_include_dirs)
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700350 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900351 if ctx.inProduct() && f.Properties.Target.Product.Override_export_include_dirs != nil {
352 return android.PathsForModuleSrc(ctx, f.Properties.Target.Product.Override_export_include_dirs)
353 }
354 return android.PathsForModuleSrc(ctx, f.Properties.Export_include_dirs)
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700355}
356
Chris Parsons3c27ca32020-11-20 12:42:07 -0500357// exportIncludes registers the include directories and system include directories to be exported
358// transitively to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900359func (f *flagExporter) exportIncludes(ctx ModuleContext) {
Jiyong Park74955042019-10-22 20:19:51 +0900360 f.dirs = append(f.dirs, f.exportedIncludes(ctx)...)
Jiyong Park73c54ee2019-10-22 20:31:18 +0900361 f.systemDirs = append(f.systemDirs, android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700362}
363
Chris Parsons3c27ca32020-11-20 12:42:07 -0500364// exportIncludesAsSystem registers the include directories and system include directories to be
365// exported transitively both as system include directories to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900366func (f *flagExporter) exportIncludesAsSystem(ctx ModuleContext) {
Jiyong Park73c54ee2019-10-22 20:31:18 +0900367 // all dirs are force exported as system
Jiyong Park74955042019-10-22 20:19:51 +0900368 f.systemDirs = append(f.systemDirs, f.exportedIncludes(ctx)...)
Jiyong Park73c54ee2019-10-22 20:31:18 +0900369 f.systemDirs = append(f.systemDirs, android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)...)
Inseob Kim69378442019-06-03 19:10:47 +0900370}
371
Chris Parsons3c27ca32020-11-20 12:42:07 -0500372// reexportDirs registers the given directories as include directories to be exported transitively
373// to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900374func (f *flagExporter) reexportDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900375 f.dirs = append(f.dirs, dirs...)
376}
377
Chris Parsons3c27ca32020-11-20 12:42:07 -0500378// reexportSystemDirs registers the given directories as system include directories
379// to be exported transitively to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900380func (f *flagExporter) reexportSystemDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900381 f.systemDirs = append(f.systemDirs, dirs...)
382}
383
Chris Parsons3c27ca32020-11-20 12:42:07 -0500384// reexportFlags registers the flags to be exported transitively to modules depending on this
385// module.
Inseob Kim69378442019-06-03 19:10:47 +0900386func (f *flagExporter) reexportFlags(flags ...string) {
Jaewoong Jung3aff5782020-02-11 07:54:35 -0800387 if android.PrefixInList(flags, "-I") || android.PrefixInList(flags, "-isystem") {
388 panic(fmt.Errorf("Exporting invalid flag %q: "+
389 "use reexportDirs or reexportSystemDirs to export directories", flag))
Inseob Kim69378442019-06-03 19:10:47 +0900390 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700391 f.flags = append(f.flags, flags...)
392}
393
Inseob Kim69378442019-06-03 19:10:47 +0900394func (f *flagExporter) reexportDeps(deps ...android.Path) {
395 f.deps = append(f.deps, deps...)
396}
397
Inseob Kimd110f872019-12-06 13:15:38 +0900398// addExportedGeneratedHeaders does nothing but collects generated header files.
399// This can be differ to exportedDeps which may contain phony files to minimize ninja.
400func (f *flagExporter) addExportedGeneratedHeaders(headers ...android.Path) {
401 f.headers = append(f.headers, headers...)
402}
403
Colin Cross0de8a1e2020-09-18 14:15:30 -0700404func (f *flagExporter) setProvider(ctx android.ModuleContext) {
405 ctx.SetProvider(FlagExporterInfoProvider, FlagExporterInfo{
406 IncludeDirs: f.dirs,
407 SystemIncludeDirs: f.systemDirs,
408 Flags: f.flags,
409 Deps: f.deps,
410 GeneratedHeaders: f.headers,
411 })
Inseob Kim69378442019-06-03 19:10:47 +0900412}
413
Colin Crossb916a382016-07-29 17:28:03 -0700414// libraryDecorator wraps baseCompiler, baseLinker and baseInstaller to provide library-specific
415// functionality: static vs. shared linkage, reusing object files for shared libraries
416type libraryDecorator struct {
Colin Crossa48ab5b2017-02-14 15:28:44 -0800417 Properties LibraryProperties
Colin Crosse1bb5d02019-09-24 14:55:04 -0700418 StaticProperties StaticProperties
419 SharedProperties SharedProperties
Colin Crossa48ab5b2017-02-14 15:28:44 -0800420 MutatedProperties LibraryMutatedProperties
Colin Cross4d9c2d12016-07-29 12:48:20 -0700421
422 // For reusing static library objects for shared library
Inseob Kim69378442019-06-03 19:10:47 +0900423 reuseObjects Objects
Colin Cross10d22312017-05-03 11:01:58 -0700424
Colin Cross26c34ed2016-09-30 17:10:16 -0700425 // table-of-contents file to optimize out relinking when possible
426 tocFile android.OptionalPath
Colin Cross4d9c2d12016-07-29 12:48:20 -0700427
Colin Cross4d9c2d12016-07-29 12:48:20 -0700428 flagExporter
Thiébaud Weksteend4587452020-08-19 14:53:01 +0200429 stripper Stripper
Colin Cross4d9c2d12016-07-29 12:48:20 -0700430
Colin Cross4d9c2d12016-07-29 12:48:20 -0700431 // For whole_static_libs
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700432 objects Objects
Colin Cross4d9c2d12016-07-29 12:48:20 -0700433
434 // Uses the module's name if empty, but can be overridden. Does not include
435 // shlib suffix.
436 libName string
Colin Crossb916a382016-07-29 17:28:03 -0700437
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800438 sabi *sabi
439
Dan Willemsen581341d2017-02-09 16:16:31 -0800440 // Output archive of gcno coverage information files
441 coverageOutputFile android.OptionalPath
442
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800443 // linked Source Abi Dump
444 sAbiOutputFile android.OptionalPath
445
446 // Source Abi Diff
447 sAbiDiff android.OptionalPath
448
Colin Cross0875c522017-11-28 17:34:01 -0800449 // Location of the static library in the sysroot. Empty if the library is
450 // not included in the NDK.
451 ndkSysrootPath android.Path
452
Colin Crossb60190a2018-09-04 16:28:17 -0700453 // Location of the linked, unstripped library for shared libraries
454 unstrippedOutputFile android.Path
455
Dan Willemsen569edc52018-11-19 09:33:29 -0800456 // Location of the file that should be copied to dist dir when requested
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000457 distFile android.Path
Dan Willemsen569edc52018-11-19 09:33:29 -0800458
Colin Cross8e21aa52020-09-28 18:28:02 -0700459 versionScriptPath android.OptionalPath
Jiyong Park7ed9de32018-10-15 22:25:07 +0900460
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800461 postInstallCmds []string
Jiyong Parkf1194352019-02-25 11:05:47 +0900462
Vic Yangefd249e2018-11-12 20:19:56 -0800463 // If useCoreVariant is true, the vendor variant of a VNDK library is
464 // not installed.
Vic Yangd92090f2020-01-08 14:32:28 -0800465 useCoreVariant bool
466 checkSameCoreVariant bool
Vic Yangefd249e2018-11-12 20:19:56 -0800467
Colin Cross5ec407b2020-09-30 11:41:33 -0700468 skipAPIDefine bool
469
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100470 // Decorated interfaces
Colin Crossb916a382016-07-29 17:28:03 -0700471 *baseCompiler
472 *baseLinker
473 *baseInstaller
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900474
475 collectedSnapshotHeaders android.Paths
476}
477
Chris Parsons808d84c2021-03-09 20:43:32 -0500478type staticLibraryBazelHandler struct {
479 bazelHandler
480
481 module *Module
482}
483
484func (handler *staticLibraryBazelHandler) generateBazelBuildActions(ctx android.ModuleContext, label string) bool {
485 bazelCtx := ctx.Config().BazelContext
Liz Kammerfe23bf32021-04-09 16:17:05 -0400486 ccInfo, ok, err := bazelCtx.GetCcInfo(label, ctx.Arch().ArchType)
487 if err != nil {
488 ctx.ModuleErrorf("Error getting Bazel CcInfo: %s", err)
489 return false
490 }
Chris Parsons944e7d02021-03-11 11:08:46 -0500491 if !ok {
492 return ok
Chris Parsons808d84c2021-03-09 20:43:32 -0500493 }
Liz Kammerfe23bf32021-04-09 16:17:05 -0400494 outputPaths := ccInfo.OutputFiles
495 objPaths := ccInfo.CcObjectFiles
Chris Parsonseefc9e62021-04-02 17:36:47 -0400496 if len(outputPaths) > 1 {
Chris Parsons944e7d02021-03-11 11:08:46 -0500497 // TODO(cparsons): This is actually expected behavior for static libraries with no srcs.
498 // We should support this.
Chris Parsonseefc9e62021-04-02 17:36:47 -0400499 ctx.ModuleErrorf("expected at most one output file for '%s', but got %s", label, objPaths)
Chris Parsons944e7d02021-03-11 11:08:46 -0500500 return false
Chris Parsonseefc9e62021-04-02 17:36:47 -0400501 } else if len(outputPaths) == 0 {
502 handler.module.outputFile = android.OptionalPath{}
503 return true
Chris Parsons944e7d02021-03-11 11:08:46 -0500504 }
505 outputFilePath := android.PathForBazelOut(ctx, outputPaths[0])
506 handler.module.outputFile = android.OptionalPathForPath(outputFilePath)
507
508 objFiles := make(android.Paths, len(objPaths))
509 for i, objPath := range objPaths {
510 objFiles[i] = android.PathForBazelOut(ctx, objPath)
511 }
512 objects := Objects{
513 objFiles: objFiles,
514 }
515
516 ctx.SetProvider(StaticLibraryInfoProvider, StaticLibraryInfo{
517 StaticLibrary: outputFilePath,
518 ReuseObjects: objects,
519 Objects: objects,
520
521 // TODO(cparsons): Include transitive static libraries in this provider to support
522 // static libraries with deps.
523 TransitiveStaticLibrariesForOrdering: android.NewDepSetBuilder(android.TOPOLOGICAL).
524 Direct(outputFilePath).
525 Build(),
526 })
Chris Parsonseefc9e62021-04-02 17:36:47 -0400527 if i, ok := handler.module.linker.(snapshotLibraryInterface); ok {
528 // Dependencies on this library will expect collectedSnapshotHeaders to
529 // be set, otherwise validation will fail. For now, set this to an empty
530 // list.
531 // TODO(cparsons): More closely mirror the collectHeadersForSnapshot
532 // implementation.
533 i.(*libraryDecorator).collectedSnapshotHeaders = android.Paths{}
534 }
535
Chris Parsons808d84c2021-03-09 20:43:32 -0500536 return ok
537}
538
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900539// collectHeadersForSnapshot collects all exported headers from library.
540// It globs header files in the source tree for exported include directories,
541// and tracks generated header files separately.
542//
543// This is to be called from GenerateAndroidBuildActions, and then collected
544// header files can be retrieved by snapshotHeaders().
545func (l *libraryDecorator) collectHeadersForSnapshot(ctx android.ModuleContext) {
546 ret := android.Paths{}
547
548 // Headers in the source tree should be globbed. On the contrast, generated headers
549 // can't be globbed, and they should be manually collected.
550 // So, we first filter out intermediate directories (which contains generated headers)
551 // from exported directories, and then glob headers under remaining directories.
Colin Cross0de8a1e2020-09-18 14:15:30 -0700552 for _, path := range append(android.CopyOfPaths(l.flagExporter.dirs), l.flagExporter.systemDirs...) {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900553 dir := path.String()
554 // Skip if dir is for generated headers
555 if strings.HasPrefix(dir, android.PathForOutput(ctx).String()) {
556 continue
557 }
Inseob Kim04f2d6a2020-05-29 22:30:58 +0900558 // libeigen wrongly exports the root directory "external/eigen". But only two
559 // subdirectories "Eigen" and "unsupported" contain exported header files. Even worse
560 // some of them have no extension. So we need special treatment for libeigen in order
561 // to glob correctly.
562 if dir == "external/eigen" {
563 // Only these two directories contains exported headers.
564 for _, subdir := range []string{"Eigen", "unsupported/Eigen"} {
565 glob, err := ctx.GlobWithDeps("external/eigen/"+subdir+"/**/*", nil)
566 if err != nil {
567 ctx.ModuleErrorf("glob failed: %#v", err)
568 return
569 }
570 for _, header := range glob {
571 if strings.HasSuffix(header, "/") {
572 continue
573 }
574 ext := filepath.Ext(header)
575 if ext != "" && ext != ".h" {
576 continue
577 }
578 ret = append(ret, android.PathForSource(ctx, header))
579 }
580 }
581 continue
582 }
Colin Crossec118d02021-01-22 18:05:59 +0000583 glob, err := ctx.GlobWithDeps(dir+"/**/*", nil)
584 if err != nil {
585 ctx.ModuleErrorf("glob failed: %#v", err)
586 return
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900587 }
Colin Crossec118d02021-01-22 18:05:59 +0000588 isLibcxx := strings.HasPrefix(dir, "external/libcxx/include")
Jose Galmes0d736912021-03-30 11:00:06 -0700589 for _, header := range glob {
Colin Crossec118d02021-01-22 18:05:59 +0000590 if isLibcxx {
591 // Glob all files under this special directory, because of C++ headers with no
592 // extension.
Jose Galmes0d736912021-03-30 11:00:06 -0700593 if strings.HasSuffix(header, "/") {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900594 continue
595 }
Colin Crossec118d02021-01-22 18:05:59 +0000596 } else {
597 // Filter out only the files with extensions that are headers.
598 found := false
599 for _, ext := range headerExts {
600 if strings.HasSuffix(header, ext) {
601 found = true
602 break
603 }
604 }
605 if !found {
606 continue
607 }
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900608 }
Jose Galmes0d736912021-03-30 11:00:06 -0700609 ret = append(ret, android.PathForSource(ctx, header))
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900610 }
611 }
612
613 // Collect generated headers
Colin Cross0de8a1e2020-09-18 14:15:30 -0700614 for _, header := range append(android.CopyOfPaths(l.flagExporter.headers), l.flagExporter.deps...) {
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900615 // TODO(b/148123511): remove exportedDeps after cleaning up genrule
616 if strings.HasSuffix(header.Base(), "-phony") {
617 continue
618 }
619 ret = append(ret, header)
620 }
621
622 l.collectedSnapshotHeaders = ret
623}
624
625// This returns all exported header files, both generated ones and headers from source tree.
626// collectHeadersForSnapshot() must be called before calling this.
627func (l *libraryDecorator) snapshotHeaders() android.Paths {
628 if l.collectedSnapshotHeaders == nil {
629 panic("snapshotHeaders() must be called after collectHeadersForSnapshot()")
630 }
631 return l.collectedSnapshotHeaders
Colin Cross4d9c2d12016-07-29 12:48:20 -0700632}
633
Chris Parsons3c27ca32020-11-20 12:42:07 -0500634// linkerProps returns the list of properties structs relevant for this library. (For example, if
635// the library is cc_shared_library, then static-library properties are omitted.)
Colin Crossb916a382016-07-29 17:28:03 -0700636func (library *libraryDecorator) linkerProps() []interface{} {
637 var props []interface{}
638 props = append(props, library.baseLinker.linkerProps()...)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700639 props = append(props,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700640 &library.Properties,
Colin Crossa48ab5b2017-02-14 15:28:44 -0800641 &library.MutatedProperties,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700642 &library.flagExporter.Properties,
Colin Cross22f37952018-09-05 10:43:13 -0700643 &library.stripper.StripProperties)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700644
645 if library.MutatedProperties.BuildShared {
646 props = append(props, &library.SharedProperties)
647 }
648 if library.MutatedProperties.BuildStatic {
649 props = append(props, &library.StaticProperties)
650 }
651
652 return props
Colin Cross4d9c2d12016-07-29 12:48:20 -0700653}
654
Chris Parsons3c27ca32020-11-20 12:42:07 -0500655// linkerFlags takes a Flags struct and augments it to contain linker flags that are defined by this
656// library, or that are implied by attributes of this library (such as whether this library is a
657// shared library).
Colin Crossb916a382016-07-29 17:28:03 -0700658func (library *libraryDecorator) linkerFlags(ctx ModuleContext, flags Flags) Flags {
Colin Cross42742b82016-08-01 13:20:05 -0700659 flags = library.baseLinker.linkerFlags(ctx, flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700660
Colin Crossb916a382016-07-29 17:28:03 -0700661 // MinGW spits out warnings about -fPIC even for -fpie?!) being ignored because
662 // all code is position independent, and then those warnings get promoted to
663 // errors.
Colin Cross3edeee12017-04-04 12:59:48 -0700664 if !ctx.Windows() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800665 flags.Global.CFlags = append(flags.Global.CFlags, "-fPIC")
Colin Crossb916a382016-07-29 17:28:03 -0700666 }
667
668 if library.static() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800669 flags.Local.CFlags = append(flags.Local.CFlags, library.StaticProperties.Static.Cflags...)
Colin Crossa48ab5b2017-02-14 15:28:44 -0800670 } else if library.shared() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800671 flags.Local.CFlags = append(flags.Local.CFlags, library.SharedProperties.Shared.Cflags...)
Colin Crossb916a382016-07-29 17:28:03 -0700672 }
673
Colin Crossa48ab5b2017-02-14 15:28:44 -0800674 if library.shared() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700675 libName := library.getLibName(ctx)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700676 var f []string
Dan Willemsen01a405a2016-06-13 17:19:03 -0700677 if ctx.toolchain().Bionic() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700678 f = append(f,
679 "-nostdlib",
680 "-Wl,--gc-sections",
681 )
682 }
683
684 if ctx.Darwin() {
685 f = append(f,
686 "-dynamiclib",
687 "-single_module",
Colin Cross4d9c2d12016-07-29 12:48:20 -0700688 "-install_name @rpath/"+libName+flags.Toolchain.ShlibSuffix(),
689 )
Colin Cross7863cf52016-10-20 10:47:21 -0700690 if ctx.Arch().ArchType == android.X86 {
691 f = append(f,
692 "-read_only_relocs suppress",
693 )
694 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700695 } else {
Josh Gao75a50a22019-06-07 17:58:59 -0700696 f = append(f, "-shared")
697 if !ctx.Windows() {
698 f = append(f, "-Wl,-soname,"+libName+flags.Toolchain.ShlibSuffix())
699 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700700 }
701
Colin Cross4af21ed2019-11-04 09:37:55 -0800702 flags.Global.LdFlags = append(flags.Global.LdFlags, f...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700703 }
704
705 return flags
706}
707
Chris Parsons3c27ca32020-11-20 12:42:07 -0500708// compilerFlags takes a Flags and augments it to contain compile flags from global values,
709// per-target values, module type values, per-module Blueprints properties, extra flags from
710// `flags`, and generated sources from `deps`.
Colin Crossf18e1102017-11-16 14:33:08 -0800711func (library *libraryDecorator) compilerFlags(ctx ModuleContext, flags Flags, deps PathDeps) Flags {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700712 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700713 if len(exportIncludeDirs) > 0 {
Colin Crossdad8c952017-04-26 14:55:27 -0700714 f := includeDirsToFlags(exportIncludeDirs)
Colin Cross4af21ed2019-11-04 09:37:55 -0800715 flags.Local.CommonFlags = append(flags.Local.CommonFlags, f)
716 flags.Local.YasmFlags = append(flags.Local.YasmFlags, f)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700717 }
718
Jiyong Park7ed9de32018-10-15 22:25:07 +0900719 flags = library.baseCompiler.compilerFlags(ctx, flags, deps)
Colin Cross127bb8b2020-12-16 16:46:01 -0800720 if ctx.IsLlndk() {
721 // LLNDK libraries ignore most of the properties on the cc_library and use the
722 // LLNDK-specific properties instead.
723 // Wipe all the module-local properties, leaving only the global properties.
724 flags.Local = LocalOrGlobalFlags{}
725 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900726 if library.buildStubs() {
Jiyong Park64379952018-12-13 18:37:29 +0900727 // Remove -include <file> when compiling stubs. Otherwise, the force included
728 // headers might cause conflicting types error with the symbols in the
729 // generated stubs source code. e.g.
730 // double acos(double); // in header
731 // void acos() {} // in the generated source code
732 removeInclude := func(flags []string) []string {
733 ret := flags[:0]
734 for _, f := range flags {
735 if strings.HasPrefix(f, "-include ") {
736 continue
737 }
738 ret = append(ret, f)
739 }
740 return ret
741 }
Colin Cross4af21ed2019-11-04 09:37:55 -0800742 flags.Local.CommonFlags = removeInclude(flags.Local.CommonFlags)
743 flags.Local.CFlags = removeInclude(flags.Local.CFlags)
Jiyong Park64379952018-12-13 18:37:29 +0900744
Jiyong Park7ed9de32018-10-15 22:25:07 +0900745 flags = addStubLibraryCompilerFlags(flags)
746 }
747 return flags
Dan Willemsen273af7f2016-11-03 15:53:42 -0700748}
749
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800750func (library *libraryDecorator) headerAbiCheckerEnabled() bool {
751 return Bool(library.Properties.Header_abi_checker.Enabled)
Hsin-Yi Chen53489642019-07-31 17:10:45 +0800752}
753
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800754func (library *libraryDecorator) headerAbiCheckerExplicitlyDisabled() bool {
755 return !BoolDefault(library.Properties.Header_abi_checker.Enabled, true)
Logan Chien41eabe62019-04-10 13:33:58 +0800756}
757
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700758func (library *libraryDecorator) compile(ctx ModuleContext, flags Flags, deps PathDeps) Objects {
Colin Cross127bb8b2020-12-16 16:46:01 -0800759 if ctx.IsLlndk() {
760 // This is the vendor variant of an LLNDK library, build the LLNDK stubs.
761 vndkVer := ctx.Module().(*Module).VndkVersion()
762 if !inList(vndkVer, ctx.Config().PlatformVersionActiveCodenames()) || vndkVer == "" {
763 // For non-enforcing devices, vndkVer is empty. Use "current" in that case, too.
764 vndkVer = "current"
765 }
766 if library.stubsVersion() != "" {
767 vndkVer = library.stubsVersion()
768 }
769 objs, versionScript := compileStubLibrary(ctx, flags, String(library.Properties.Llndk.Symbol_file), vndkVer, "--llndk")
770 if !Bool(library.Properties.Llndk.Unversioned) {
771 library.versionScriptPath = android.OptionalPathForPath(versionScript)
772 }
773 return objs
774 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900775 if library.buildStubs() {
Jiyong Parka4175572021-02-04 21:05:47 +0900776 symbolFile := String(library.Properties.Stubs.Symbol_file)
777 if symbolFile != "" && !strings.HasSuffix(symbolFile, ".map.txt") {
778 ctx.PropertyErrorf("symbol_file", "%q doesn't have .map.txt suffix", symbolFile)
779 return Objects{}
780 }
Jiyong Park3fd0baf2018-12-07 16:25:39 +0900781 objs, versionScript := compileStubLibrary(ctx, flags, String(library.Properties.Stubs.Symbol_file), library.MutatedProperties.StubsVersion, "--apex")
Colin Cross8e21aa52020-09-28 18:28:02 -0700782 library.versionScriptPath = android.OptionalPathForPath(versionScript)
Jiyong Park7ed9de32018-10-15 22:25:07 +0900783 return objs
784 }
785
Colin Cross5950f382016-12-13 12:50:57 -0800786 if !library.buildShared() && !library.buildStatic() {
787 if len(library.baseCompiler.Properties.Srcs) > 0 {
788 ctx.PropertyErrorf("srcs", "cc_library_headers must not have any srcs")
789 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700790 if len(library.StaticProperties.Static.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800791 ctx.PropertyErrorf("static.srcs", "cc_library_headers must not have any srcs")
792 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700793 if len(library.SharedProperties.Shared.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800794 ctx.PropertyErrorf("shared.srcs", "cc_library_headers must not have any srcs")
795 }
796 return Objects{}
797 }
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800798 if library.sabi.shouldCreateSourceAbiDump() {
Jayant Chowdharya4fce192017-09-06 13:10:03 -0700799 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800800 var SourceAbiFlags []string
801 for _, dir := range exportIncludeDirs.Strings() {
Jayant Chowdhary715cac32017-04-20 06:53:59 -0700802 SourceAbiFlags = append(SourceAbiFlags, "-I"+dir)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800803 }
Inseob Kim69378442019-06-03 19:10:47 +0900804 for _, reexportedInclude := range library.sabi.Properties.ReexportedIncludes {
805 SourceAbiFlags = append(SourceAbiFlags, "-I"+reexportedInclude)
Jayant Chowdhary715cac32017-04-20 06:53:59 -0700806 }
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800807 flags.SAbiFlags = SourceAbiFlags
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800808 totalLength := len(library.baseCompiler.Properties.Srcs) + len(deps.GeneratedSources) +
Colin Crosse1bb5d02019-09-24 14:55:04 -0700809 len(library.SharedProperties.Shared.Srcs) + len(library.StaticProperties.Static.Srcs)
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800810 if totalLength > 0 {
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800811 flags.SAbiDump = true
812 }
813 }
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700814 objs := library.baseCompiler.compile(ctx, flags, deps)
815 library.reuseObjects = objs
Colin Cross2f336352016-10-26 10:03:47 -0700816 buildFlags := flagsToBuilderFlags(flags)
Colin Crossb916a382016-07-29 17:28:03 -0700817
Colin Cross4d9c2d12016-07-29 12:48:20 -0700818 if library.static() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700819 srcs := android.PathsForModuleSrc(ctx, library.StaticProperties.Static.Srcs)
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700820 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceStaticLibrary,
Pirama Arumuga Nainarf231b192018-01-23 10:49:04 -0800821 srcs, library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossa48ab5b2017-02-14 15:28:44 -0800822 } else if library.shared() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700823 srcs := android.PathsForModuleSrc(ctx, library.SharedProperties.Shared.Srcs)
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700824 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceSharedLibrary,
Pirama Arumuga Nainarf231b192018-01-23 10:49:04 -0800825 srcs, library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossb916a382016-07-29 17:28:03 -0700826 }
827
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700828 return objs
Colin Crossb916a382016-07-29 17:28:03 -0700829}
830
831type libraryInterface interface {
Colin Cross3572cf72020-10-01 15:58:11 -0700832 versionedInterface
833
Colin Crossb916a382016-07-29 17:28:03 -0700834 static() bool
Inseob Kimae553032019-05-14 18:52:49 +0900835 shared() bool
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700836 objs() Objects
Colin Cross0de8a1e2020-09-18 14:15:30 -0700837 reuseObjs() Objects
Colin Cross26c34ed2016-09-30 17:10:16 -0700838 toc() android.OptionalPath
Colin Crossb916a382016-07-29 17:28:03 -0700839
840 // Returns true if the build options for the module have selected a static or shared build
841 buildStatic() bool
842 buildShared() bool
843
844 // Sets whether a specific variant is static or shared
Colin Crossa48ab5b2017-02-14 15:28:44 -0800845 setStatic()
846 setShared()
Logan Chien41eabe62019-04-10 13:33:58 +0800847
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800848 // Check whether header_abi_checker is enabled or explicitly disabled.
849 headerAbiCheckerEnabled() bool
850 headerAbiCheckerExplicitlyDisabled() bool
851
Logan Chien41eabe62019-04-10 13:33:58 +0800852 // Write LOCAL_ADDITIONAL_DEPENDENCIES for ABI diff
853 androidMkWriteAdditionalDependenciesForSourceAbiDiff(w io.Writer)
Jiyong Parka90ca002019-10-07 15:47:24 +0900854
855 availableFor(string) bool
Colin Crossb916a382016-07-29 17:28:03 -0700856}
857
Colin Crossc88c2722020-09-28 17:32:47 -0700858type versionedInterface interface {
859 buildStubs() bool
Jiyong Parkd4a3a132021-03-17 20:21:35 +0900860 setBuildStubs(isLatest bool)
Colin Crossc88c2722020-09-28 17:32:47 -0700861 hasStubsVariants() bool
862 setStubsVersion(string)
863 stubsVersion() string
864
Colin Cross3572cf72020-10-01 15:58:11 -0700865 stubsVersions(ctx android.BaseMutatorContext) []string
Colin Crossc88c2722020-09-28 17:32:47 -0700866 setAllStubsVersions([]string)
867 allStubsVersions() []string
Colin Cross0477b422020-10-13 18:43:54 -0700868
869 implementationModuleName(name string) string
Colin Cross127bb8b2020-12-16 16:46:01 -0800870 hasLLNDKStubs() bool
Colin Crossc88c2722020-09-28 17:32:47 -0700871}
872
873var _ libraryInterface = (*libraryDecorator)(nil)
874var _ versionedInterface = (*libraryDecorator)(nil)
875
Justin Yun6977e8a2020-10-29 18:24:11 +0900876func (library *libraryDecorator) getLibNameHelper(baseModuleName string, inVendor bool, inProduct bool) string {
Colin Crossb916a382016-07-29 17:28:03 -0700877 name := library.libName
878 if name == "" {
dimitryd95964a2018-11-07 13:43:34 +0100879 name = String(library.Properties.Stem)
880 if name == "" {
Jooyung Han0302a842019-10-30 18:43:49 +0900881 name = baseModuleName
dimitryd95964a2018-11-07 13:43:34 +0100882 }
Colin Crossb916a382016-07-29 17:28:03 -0700883 }
884
Colin Cross0fd6a412019-08-16 14:22:10 -0700885 suffix := ""
Justin Yun6977e8a2020-10-29 18:24:11 +0900886 if inVendor {
Colin Cross0fd6a412019-08-16 14:22:10 -0700887 suffix = String(library.Properties.Target.Vendor.Suffix)
Justin Yun6977e8a2020-10-29 18:24:11 +0900888 } else if inProduct {
889 suffix = String(library.Properties.Target.Product.Suffix)
Colin Cross0fd6a412019-08-16 14:22:10 -0700890 }
891 if suffix == "" {
892 suffix = String(library.Properties.Suffix)
893 }
894
Jooyung Han0302a842019-10-30 18:43:49 +0900895 return name + suffix
896}
897
Chris Parsons3c27ca32020-11-20 12:42:07 -0500898// getLibName returns the actual canonical name of the library (the name which
899// should be passed to the linker via linker flags).
Jooyung Han0302a842019-10-30 18:43:49 +0900900func (library *libraryDecorator) getLibName(ctx BaseModuleContext) string {
Justin Yun6977e8a2020-10-29 18:24:11 +0900901 name := library.getLibNameHelper(ctx.baseModuleName(), ctx.inVendor(), ctx.inProduct())
Colin Cross0fd6a412019-08-16 14:22:10 -0700902
Ivan Lozanof9e21722020-12-02 09:00:51 -0500903 if ctx.IsVndkExt() {
Jooyung Han4c2b9422019-10-22 19:53:47 +0900904 // vndk-ext lib should have the same name with original lib
905 ctx.VisitDirectDepsWithTag(vndkExtDepTag, func(module android.Module) {
906 originalName := module.(*Module).outputFile.Path()
907 name = strings.TrimSuffix(originalName.Base(), originalName.Ext())
908 })
Logan Chienf3511742017-10-31 18:04:35 +0800909 }
910
Colin Crossb916a382016-07-29 17:28:03 -0700911 if ctx.Host() && Bool(library.Properties.Unique_host_soname) {
912 if !strings.HasSuffix(name, "-host") {
913 name = name + "-host"
914 }
915 }
916
Inseob Kim0ce291e2019-07-04 14:38:27 +0900917 return name
Colin Crossb916a382016-07-29 17:28:03 -0700918}
919
Jiyong Parkda732bd2018-11-02 18:23:15 +0900920var versioningMacroNamesListMutex sync.Mutex
921
Colin Crossb916a382016-07-29 17:28:03 -0700922func (library *libraryDecorator) linkerInit(ctx BaseModuleContext) {
923 location := InstallInSystem
Dan Albert61f32122018-07-26 14:00:24 -0700924 if library.baseLinker.sanitize.inSanitizerDir() {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700925 location = InstallInSanitizerDir
Colin Crossb916a382016-07-29 17:28:03 -0700926 }
927 library.baseInstaller.location = location
Colin Crossb916a382016-07-29 17:28:03 -0700928 library.baseLinker.linkerInit(ctx)
Jiyong Park7ed9de32018-10-15 22:25:07 +0900929 // Let baseLinker know whether this variant is for stubs or not, so that
930 // it can omit things that are not required for linking stubs.
931 library.baseLinker.dynamicProperties.BuildStubs = library.buildStubs()
Jiyong Parkda732bd2018-11-02 18:23:15 +0900932
933 if library.buildStubs() {
934 macroNames := versioningMacroNamesList(ctx.Config())
935 myName := versioningMacroName(ctx.ModuleName())
936 versioningMacroNamesListMutex.Lock()
937 defer versioningMacroNamesListMutex.Unlock()
938 if (*macroNames)[myName] == "" {
939 (*macroNames)[myName] = ctx.ModuleName()
940 } else if (*macroNames)[myName] != ctx.ModuleName() {
941 ctx.ModuleErrorf("Macro name %q for versioning conflicts with macro name from module %q ", myName, (*macroNames)[myName])
942 }
943 }
Colin Crossb916a382016-07-29 17:28:03 -0700944}
945
dimitry0345ad82018-12-05 16:28:14 +0100946func (library *libraryDecorator) compilerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800947 if ctx.IsLlndk() {
948 // LLNDK libraries ignore most of the properties on the cc_library and use the
949 // LLNDK-specific properties instead.
950 return deps
951 }
952
dimitry0345ad82018-12-05 16:28:14 +0100953 deps = library.baseCompiler.compilerDeps(ctx, deps)
954
dimitry0345ad82018-12-05 16:28:14 +0100955 return deps
956}
957
Colin Cross37047f12016-12-13 17:06:13 -0800958func (library *libraryDecorator) linkerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800959 if ctx.IsLlndk() {
960 // LLNDK libraries ignore most of the properties on the cc_library and use the
961 // LLNDK-specific properties instead.
962 deps.HeaderLibs = append(deps.HeaderLibs, library.Properties.Llndk.Export_llndk_headers...)
963 deps.ReexportHeaderLibHeaders = append(deps.ReexportHeaderLibHeaders,
964 library.Properties.Llndk.Export_llndk_headers...)
965 return deps
966 }
967
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800968 if library.static() {
Martin Stjernholm10566a02020-03-24 01:19:52 +0000969 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700970 if library.StaticProperties.Static.System_shared_libs != nil {
971 library.baseLinker.Properties.System_shared_libs = library.StaticProperties.Static.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800972 }
973 } else if library.shared() {
Martin Stjernholm10566a02020-03-24 01:19:52 +0000974 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700975 if library.SharedProperties.Shared.System_shared_libs != nil {
976 library.baseLinker.Properties.System_shared_libs = library.SharedProperties.Shared.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800977 }
978 }
979
Colin Crossb916a382016-07-29 17:28:03 -0700980 deps = library.baseLinker.linkerDeps(ctx, deps)
981
982 if library.static() {
983 deps.WholeStaticLibs = append(deps.WholeStaticLibs,
Colin Crosse1bb5d02019-09-24 14:55:04 -0700984 library.StaticProperties.Static.Whole_static_libs...)
985 deps.StaticLibs = append(deps.StaticLibs, library.StaticProperties.Static.Static_libs...)
986 deps.SharedLibs = append(deps.SharedLibs, library.StaticProperties.Static.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -0800987
Colin Crosse1bb5d02019-09-24 14:55:04 -0700988 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.StaticProperties.Static.Export_shared_lib_headers...)
989 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.StaticProperties.Static.Export_static_lib_headers...)
Colin Crossa48ab5b2017-02-14 15:28:44 -0800990 } else if library.shared() {
Dan Willemsen2e47b342016-11-17 01:02:25 -0800991 if ctx.toolchain().Bionic() && !Bool(library.baseLinker.Properties.Nocrt) {
Dan Albert92fe7402020-07-15 13:33:30 -0700992 deps.CrtBegin = "crtbegin_so"
993 deps.CrtEnd = "crtend_so"
Colin Cross4d9c2d12016-07-29 12:48:20 -0700994 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700995 deps.WholeStaticLibs = append(deps.WholeStaticLibs, library.SharedProperties.Shared.Whole_static_libs...)
996 deps.StaticLibs = append(deps.StaticLibs, library.SharedProperties.Shared.Static_libs...)
997 deps.SharedLibs = append(deps.SharedLibs, library.SharedProperties.Shared.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -0800998
Colin Crosse1bb5d02019-09-24 14:55:04 -0700999 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.SharedProperties.Shared.Export_shared_lib_headers...)
1000 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.SharedProperties.Shared.Export_static_lib_headers...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001001 }
Justin Yun6977e8a2020-10-29 18:24:11 +09001002 if ctx.inVendor() {
Jiyong Park52d25bd2017-10-13 09:17:01 +09001003 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
1004 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
1005 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +00001006 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
1007 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Jiyong Park52d25bd2017-10-13 09:17:01 +09001008 }
Justin Yun6977e8a2020-10-29 18:24:11 +09001009 if ctx.inProduct() {
1010 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
1011 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
1012 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
1013 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
1014 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
1015 }
Jiyong Parkf9332f12018-02-01 00:54:12 +09001016 if ctx.inRecovery() {
1017 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
1018 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
1019 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +00001020 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
1021 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001022 }
Yifan Hongcf4832c2020-01-21 17:04:13 -08001023 if ctx.inRamdisk() {
1024 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
1025 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
1026 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
1027 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
1028 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
1029 }
Yifan Hong6da33c22020-10-27 15:01:21 -07001030 if ctx.inVendorRamdisk() {
1031 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
1032 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
1033 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
1034 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
1035 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
1036 }
Colin Cross2383f3b2018-02-06 14:40:13 -08001037
Colin Cross4d9c2d12016-07-29 12:48:20 -07001038 return deps
1039}
1040
Paul Duffin13f02712020-03-06 12:30:43 +00001041func (library *libraryDecorator) linkerSpecifiedDeps(specifiedDeps specifiedDeps) specifiedDeps {
1042 specifiedDeps = library.baseLinker.linkerSpecifiedDeps(specifiedDeps)
1043 var properties StaticOrSharedProperties
1044 if library.static() {
1045 properties = library.StaticProperties.Static
1046 } else if library.shared() {
1047 properties = library.SharedProperties.Shared
1048 }
1049
1050 specifiedDeps.sharedLibs = append(specifiedDeps.sharedLibs, properties.Shared_libs...)
Martin Stjernholm10566a02020-03-24 01:19:52 +00001051
1052 // Must distinguish nil and [] in system_shared_libs - ensure that [] in
1053 // either input list doesn't come out as nil.
1054 if specifiedDeps.systemSharedLibs == nil {
1055 specifiedDeps.systemSharedLibs = properties.System_shared_libs
1056 } else {
1057 specifiedDeps.systemSharedLibs = append(specifiedDeps.systemSharedLibs, properties.System_shared_libs...)
1058 }
Paul Duffin13f02712020-03-06 12:30:43 +00001059
1060 specifiedDeps.sharedLibs = android.FirstUniqueStrings(specifiedDeps.sharedLibs)
Martin Stjernholm10566a02020-03-24 01:19:52 +00001061 if len(specifiedDeps.systemSharedLibs) > 0 {
1062 // Skip this if systemSharedLibs is either nil or [], to ensure they are
1063 // retained.
1064 specifiedDeps.systemSharedLibs = android.FirstUniqueStrings(specifiedDeps.systemSharedLibs)
1065 }
Paul Duffin13f02712020-03-06 12:30:43 +00001066 return specifiedDeps
1067}
1068
Colin Crossb916a382016-07-29 17:28:03 -07001069func (library *libraryDecorator) linkStatic(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001070 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001071
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001072 library.objects = deps.WholeStaticLibObjs.Copy()
1073 library.objects = library.objects.Append(objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001074
Inseob Kim0ce291e2019-07-04 14:38:27 +09001075 fileName := ctx.ModuleName() + staticLibraryExtension
Colin Cross86803cf2018-02-15 14:12:26 -08001076 outputFile := android.PathForModuleOut(ctx, fileName)
Dan Willemsen581341d2017-02-09 16:16:31 -08001077 builderFlags := flagsToBuilderFlags(flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001078
Dan Willemsen569edc52018-11-19 09:33:29 -08001079 if Bool(library.baseLinker.Properties.Use_version_lib) {
1080 if ctx.Host() {
1081 versionedOutputFile := outputFile
1082 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
1083 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1084 } else {
1085 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001086 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -08001087 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1088 }
Colin Cross86803cf2018-02-15 14:12:26 -08001089 }
1090
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001091 transformObjToStaticLib(ctx, library.objects.objFiles, deps.WholeStaticLibsFromPrebuilts, builderFlags, outputFile, objs.tidyFiles)
Dan Willemsen581341d2017-02-09 16:16:31 -08001092
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001093 library.coverageOutputFile = transformCoverageFilesToZip(ctx, library.objects, ctx.ModuleName())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001094
Colin Cross4d9c2d12016-07-29 12:48:20 -07001095 ctx.CheckbuildFile(outputFile)
1096
Colin Cross649d8172020-12-10 12:30:21 -08001097 if library.static() {
1098 ctx.SetProvider(StaticLibraryInfoProvider, StaticLibraryInfo{
1099 StaticLibrary: outputFile,
1100 ReuseObjects: library.reuseObjects,
1101 Objects: library.objects,
Colin Cross0de8a1e2020-09-18 14:15:30 -07001102
Colin Cross649d8172020-12-10 12:30:21 -08001103 TransitiveStaticLibrariesForOrdering: android.NewDepSetBuilder(android.TOPOLOGICAL).
1104 Direct(outputFile).
1105 Transitive(deps.TranstiveStaticLibrariesForOrdering).
1106 Build(),
1107 })
1108 }
1109
1110 if library.header() {
1111 ctx.SetProvider(HeaderLibraryInfoProvider, HeaderLibraryInfo{})
1112 }
Colin Cross0de8a1e2020-09-18 14:15:30 -07001113
Colin Cross4d9c2d12016-07-29 12:48:20 -07001114 return outputFile
1115}
1116
Colin Crossb916a382016-07-29 17:28:03 -07001117func (library *libraryDecorator) linkShared(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001118 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001119
1120 var linkerDeps android.Paths
Pirama Arumuga Nainarada83ec2017-08-31 23:38:27 -07001121 linkerDeps = append(linkerDeps, flags.LdFlagsDeps...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001122
Colin Cross2383f3b2018-02-06 14:40:13 -08001123 unexportedSymbols := ctx.ExpandOptionalSource(library.Properties.Unexported_symbols_list, "unexported_symbols_list")
1124 forceNotWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_not_weak_list, "force_symbols_not_weak_list")
1125 forceWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_weak_list, "force_symbols_weak_list")
Colin Cross4d9c2d12016-07-29 12:48:20 -07001126 if !ctx.Darwin() {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001127 if unexportedSymbols.Valid() {
1128 ctx.PropertyErrorf("unexported_symbols_list", "Only supported on Darwin")
1129 }
1130 if forceNotWeakSymbols.Valid() {
1131 ctx.PropertyErrorf("force_symbols_not_weak_list", "Only supported on Darwin")
1132 }
1133 if forceWeakSymbols.Valid() {
1134 ctx.PropertyErrorf("force_symbols_weak_list", "Only supported on Darwin")
1135 }
1136 } else {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001137 if unexportedSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001138 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-unexported_symbols_list,"+unexportedSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001139 linkerDeps = append(linkerDeps, unexportedSymbols.Path())
1140 }
1141 if forceNotWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001142 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_not_weak_list,"+forceNotWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001143 linkerDeps = append(linkerDeps, forceNotWeakSymbols.Path())
1144 }
1145 if forceWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001146 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_weak_list,"+forceWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001147 linkerDeps = append(linkerDeps, forceWeakSymbols.Path())
1148 }
1149 }
Colin Cross8e21aa52020-09-28 18:28:02 -07001150 if library.versionScriptPath.Valid() {
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001151 linkerScriptFlags := "-Wl,--version-script," + library.versionScriptPath.String()
Colin Cross4af21ed2019-11-04 09:37:55 -08001152 flags.Local.LdFlags = append(flags.Local.LdFlags, linkerScriptFlags)
Colin Cross8e21aa52020-09-28 18:28:02 -07001153 linkerDeps = append(linkerDeps, library.versionScriptPath.Path())
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001154 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001155
1156 fileName := library.getLibName(ctx) + flags.Toolchain.ShlibSuffix()
1157 outputFile := android.PathForModuleOut(ctx, fileName)
Colin Cross0de8a1e2020-09-18 14:15:30 -07001158 unstrippedOutputFile := outputFile
Colin Cross4d9c2d12016-07-29 12:48:20 -07001159
Josh Gao75a50a22019-06-07 17:58:59 -07001160 var implicitOutputs android.WritablePaths
1161 if ctx.Windows() {
1162 importLibraryPath := android.PathForModuleOut(ctx, pathtools.ReplaceExtension(fileName, "lib"))
1163
Colin Cross4af21ed2019-11-04 09:37:55 -08001164 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,--out-implib="+importLibraryPath.String())
Josh Gao75a50a22019-06-07 17:58:59 -07001165 implicitOutputs = append(implicitOutputs, importLibraryPath)
1166 }
1167
Colin Cross4d9c2d12016-07-29 12:48:20 -07001168 builderFlags := flagsToBuilderFlags(flags)
1169
Colin Crossb496cfd2018-09-10 16:50:05 -07001170 // Optimize out relinking against shared libraries whose interface hasn't changed by
1171 // depending on a table of contents file instead of the library itself.
Colin Cross70dda7e2019-10-01 22:05:35 -07001172 tocFile := outputFile.ReplaceExtension(ctx, flags.Toolchain.ShlibSuffix()[1:]+".toc")
Colin Crossb496cfd2018-09-10 16:50:05 -07001173 library.tocFile = android.OptionalPathForPath(tocFile)
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001174 transformSharedObjectToToc(ctx, outputFile, tocFile, builderFlags)
Colin Cross89562dc2016-10-03 17:47:19 -07001175
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001176 stripFlags := flagsToStripFlags(flags)
Colin Crossadc81a02020-12-14 17:01:55 -08001177 needsStrip := library.stripper.NeedsStrip(ctx)
1178 if library.buildStubs() {
1179 // No need to strip stubs libraries
1180 needsStrip = false
1181 }
1182 if needsStrip {
Yi Kongb5c34d72018-11-07 16:28:49 -08001183 if ctx.Darwin() {
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001184 stripFlags.StripUseGnuStrip = true
Yi Kongb5c34d72018-11-07 16:28:49 -08001185 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001186 strippedOutputFile := outputFile
1187 outputFile = android.PathForModuleOut(ctx, "unstripped", fileName)
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001188 library.stripper.StripExecutableOrSharedLib(ctx, outputFile, strippedOutputFile, stripFlags)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001189 }
Colin Crossb60190a2018-09-04 16:28:17 -07001190 library.unstrippedOutputFile = outputFile
1191
Colin Crossd7227f92019-09-05 14:26:33 -07001192 outputFile = maybeInjectBoringSSLHash(ctx, outputFile, library.Properties.Inject_bssl_hash, fileName)
Pete Bentley803e1612019-08-06 22:19:59 +01001193
Dan Willemsen569edc52018-11-19 09:33:29 -08001194 if Bool(library.baseLinker.Properties.Use_version_lib) {
1195 if ctx.Host() {
1196 versionedOutputFile := outputFile
1197 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
1198 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1199 } else {
1200 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001201 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -08001202
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001203 if library.stripper.NeedsStrip(ctx) {
Dan Willemsen569edc52018-11-19 09:33:29 -08001204 out := android.PathForModuleOut(ctx, "versioned-stripped", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001205 library.distFile = out
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001206 library.stripper.StripExecutableOrSharedLib(ctx, versionedOutputFile, out, stripFlags)
Dan Willemsen569edc52018-11-19 09:33:29 -08001207 }
1208
1209 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1210 }
Colin Cross86803cf2018-02-15 14:12:26 -08001211 }
1212
Jiyong Park64a44f22019-01-18 14:37:08 +09001213 sharedLibs := deps.EarlySharedLibs
1214 sharedLibs = append(sharedLibs, deps.SharedLibs...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001215 sharedLibs = append(sharedLibs, deps.LateSharedLibs...)
1216
Jiyong Park64a44f22019-01-18 14:37:08 +09001217 linkerDeps = append(linkerDeps, deps.EarlySharedLibsDeps...)
Colin Cross26c34ed2016-09-30 17:10:16 -07001218 linkerDeps = append(linkerDeps, deps.SharedLibsDeps...)
1219 linkerDeps = append(linkerDeps, deps.LateSharedLibsDeps...)
Dan Willemsena03cf6d2016-09-26 15:45:04 -07001220 linkerDeps = append(linkerDeps, objs.tidyFiles...)
Colin Cross26c34ed2016-09-30 17:10:16 -07001221
Colin Cross127bb8b2020-12-16 16:46:01 -08001222 if Bool(library.Properties.Sort_bss_symbols_by_size) && !library.buildStubs() {
Vic Yang6cd1be82019-06-24 16:08:48 -07001223 unsortedOutputFile := android.PathForModuleOut(ctx, "unsorted", fileName)
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001224 transformObjToDynamicBinary(ctx, objs.objFiles, sharedLibs,
Vic Yang6cd1be82019-06-24 16:08:48 -07001225 deps.StaticLibs, deps.LateStaticLibs, deps.WholeStaticLibs,
1226 linkerDeps, deps.CrtBegin, deps.CrtEnd, false, builderFlags, unsortedOutputFile, implicitOutputs)
1227
1228 symbolOrderingFile := android.PathForModuleOut(ctx, "unsorted", fileName+".symbol_order")
1229 symbolOrderingFlag := library.baseLinker.sortBssSymbolsBySize(ctx, unsortedOutputFile, symbolOrderingFile, builderFlags)
Colin Cross6d88dba2019-11-06 07:06:58 -08001230 builderFlags.localLdFlags += " " + symbolOrderingFlag
Vic Yang6cd1be82019-06-24 16:08:48 -07001231 linkerDeps = append(linkerDeps, symbolOrderingFile)
1232 }
1233
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001234 transformObjToDynamicBinary(ctx, objs.objFiles, sharedLibs,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001235 deps.StaticLibs, deps.LateStaticLibs, deps.WholeStaticLibs,
Josh Gao75a50a22019-06-07 17:58:59 -07001236 linkerDeps, deps.CrtBegin, deps.CrtEnd, false, builderFlags, outputFile, implicitOutputs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001237
Dan Willemsen581341d2017-02-09 16:16:31 -08001238 objs.coverageFiles = append(objs.coverageFiles, deps.StaticLibObjs.coverageFiles...)
1239 objs.coverageFiles = append(objs.coverageFiles, deps.WholeStaticLibObjs.coverageFiles...)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001240
1241 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.StaticLibObjs.sAbiDumpFiles...)
1242 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.WholeStaticLibObjs.sAbiDumpFiles...)
1243
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001244 library.coverageOutputFile = transformCoverageFilesToZip(ctx, objs, library.getLibName(ctx))
Colin Cross0de8a1e2020-09-18 14:15:30 -07001245 library.linkSAbiDumpFiles(ctx, objs, fileName, unstrippedOutputFile)
Dan Willemsen581341d2017-02-09 16:16:31 -08001246
Colin Cross0de8a1e2020-09-18 14:15:30 -07001247 var staticAnalogue *StaticLibraryInfo
1248 if static := ctx.GetDirectDepsWithTag(staticVariantTag); len(static) > 0 {
1249 s := ctx.OtherModuleProvider(static[0], StaticLibraryInfoProvider).(StaticLibraryInfo)
1250 staticAnalogue = &s
1251 }
1252
1253 ctx.SetProvider(SharedLibraryInfoProvider, SharedLibraryInfo{
1254 TableOfContents: android.OptionalPathForPath(tocFile),
1255 SharedLibrary: unstrippedOutputFile,
1256 UnstrippedSharedLibrary: library.unstrippedOutputFile,
1257 CoverageSharedLibrary: library.coverageOutputFile,
1258 StaticAnalogue: staticAnalogue,
1259 })
1260
1261 stubs := ctx.GetDirectDepsWithTag(stubImplDepTag)
1262 if len(stubs) > 0 {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001263 var stubsInfo []SharedStubLibrary
Colin Cross0de8a1e2020-09-18 14:15:30 -07001264 for _, stub := range stubs {
1265 stubInfo := ctx.OtherModuleProvider(stub, SharedLibraryInfoProvider).(SharedLibraryInfo)
1266 flagInfo := ctx.OtherModuleProvider(stub, FlagExporterInfoProvider).(FlagExporterInfo)
Chris Parsons3c27ca32020-11-20 12:42:07 -05001267 stubsInfo = append(stubsInfo, SharedStubLibrary{
Colin Cross31076b32020-10-23 17:22:06 -07001268 Version: moduleLibraryInterface(stub).stubsVersion(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001269 SharedLibraryInfo: stubInfo,
1270 FlagExporterInfo: flagInfo,
1271 })
1272 }
Chris Parsons3c27ca32020-11-20 12:42:07 -05001273 ctx.SetProvider(SharedLibraryStubsProvider, SharedLibraryStubsInfo{
1274 SharedStubLibraries: stubsInfo,
Colin Cross0de8a1e2020-09-18 14:15:30 -07001275
Colin Cross127bb8b2020-12-16 16:46:01 -08001276 IsLLNDK: ctx.IsLlndk(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001277 })
1278 }
1279
1280 return unstrippedOutputFile
Colin Cross4d9c2d12016-07-29 12:48:20 -07001281}
1282
Jiyong Parkaf6d8952019-01-31 12:21:23 +09001283func (library *libraryDecorator) unstrippedOutputFilePath() android.Path {
1284 return library.unstrippedOutputFile
1285}
1286
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001287func (library *libraryDecorator) disableStripping() {
1288 library.stripper.StripProperties.Strip.None = BoolPtr(true)
1289}
1290
Pirama Arumuga Nainar65c95ff2019-03-25 10:21:31 -07001291func (library *libraryDecorator) nativeCoverage() bool {
1292 if library.header() || library.buildStubs() {
1293 return false
1294 }
1295 return true
1296}
1297
Jiyong Parkee9a98d2019-08-09 14:44:36 +09001298func (library *libraryDecorator) coverageOutputFilePath() android.OptionalPath {
1299 return library.coverageOutputFile
1300}
1301
Logan Chien7eefdc42018-07-11 18:10:41 +08001302func getRefAbiDumpFile(ctx ModuleContext, vndkVersion, fileName string) android.Path {
Hsin-Yi Chen27d235f2020-03-26 17:50:29 +08001303 // The logic must be consistent with classifySourceAbiDump.
Colin Cross95f1ca02020-10-29 20:47:22 -07001304 isNdk := ctx.isNdk(ctx.Config())
Colin Cross127bb8b2020-12-16 16:46:01 -08001305 isLlndkOrVndk := ctx.IsLlndkPublic() || (ctx.useVndk() && ctx.isVndk())
Logan Chien7eefdc42018-07-11 18:10:41 +08001306
Hsin-Yi Chen53489642019-07-31 17:10:45 +08001307 refAbiDumpTextFile := android.PathForVndkRefAbiDump(ctx, vndkVersion, fileName, isNdk, isLlndkOrVndk, false)
1308 refAbiDumpGzipFile := android.PathForVndkRefAbiDump(ctx, vndkVersion, fileName, isNdk, isLlndkOrVndk, true)
Logan Chien7eefdc42018-07-11 18:10:41 +08001309
1310 if refAbiDumpTextFile.Valid() {
1311 if refAbiDumpGzipFile.Valid() {
1312 ctx.ModuleErrorf(
1313 "Two reference ABI dump files are found: %q and %q. Please delete the stale one.",
1314 refAbiDumpTextFile, refAbiDumpGzipFile)
1315 return nil
1316 }
1317 return refAbiDumpTextFile.Path()
1318 }
1319 if refAbiDumpGzipFile.Valid() {
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001320 return unzipRefDump(ctx, refAbiDumpGzipFile.Path(), fileName)
Logan Chien7eefdc42018-07-11 18:10:41 +08001321 }
1322 return nil
1323}
1324
Jayant Chowdhary6ab3d842017-06-26 12:52:58 -07001325func (library *libraryDecorator) linkSAbiDumpFiles(ctx ModuleContext, objs Objects, fileName string, soFile android.Path) {
Yo Chiang2bbadfa2020-12-14 11:42:16 +08001326 if library.sabi.shouldCreateSourceAbiDump() {
Inseob Kim96f17f02020-06-09 22:05:09 +09001327 var vndkVersion string
1328
1329 if ctx.useVndk() {
1330 // For modules linking against vndk, follow its vndk version
1331 vndkVersion = ctx.Module().(*Module).VndkVersion()
1332 } else {
1333 // Regard the other modules as PLATFORM_VNDK_VERSION
1334 vndkVersion = ctx.DeviceConfig().PlatformVndkVersion()
Logan Chienf3511742017-10-31 18:04:35 +08001335 }
1336
Jayant Chowdharya4fce192017-09-06 13:10:03 -07001337 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001338 var SourceAbiFlags []string
1339 for _, dir := range exportIncludeDirs.Strings() {
Jayant Chowdhary715cac32017-04-20 06:53:59 -07001340 SourceAbiFlags = append(SourceAbiFlags, "-I"+dir)
1341 }
Inseob Kim69378442019-06-03 19:10:47 +09001342 for _, reexportedInclude := range library.sabi.Properties.ReexportedIncludes {
1343 SourceAbiFlags = append(SourceAbiFlags, "-I"+reexportedInclude)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001344 }
1345 exportedHeaderFlags := strings.Join(SourceAbiFlags, " ")
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001346 library.sAbiOutputFile = transformDumpToLinkedDump(ctx, objs.sAbiDumpFiles, soFile, fileName, exportedHeaderFlags,
Jiyong Parka034b832019-08-27 14:02:19 +09001347 android.OptionalPathForModuleSrc(ctx, library.symbolFileForAbiCheck(ctx)),
Logan Chiene3d7a0d2019-01-17 00:18:02 +08001348 library.Properties.Header_abi_checker.Exclude_symbol_versions,
1349 library.Properties.Header_abi_checker.Exclude_symbol_tags)
Logan Chien2f2b8902018-07-10 15:01:19 +08001350
Yo Chiang2bbadfa2020-12-14 11:42:16 +08001351 addLsdumpPath(classifySourceAbiDump(ctx) + ":" + library.sAbiOutputFile.String())
Hsin-Yi Chen53489642019-07-31 17:10:45 +08001352
Logan Chien7eefdc42018-07-11 18:10:41 +08001353 refAbiDumpFile := getRefAbiDumpFile(ctx, vndkVersion, fileName)
1354 if refAbiDumpFile != nil {
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001355 library.sAbiDiff = sourceAbiDiff(ctx, library.sAbiOutputFile.Path(),
Logan Chien2a65dda2019-10-01 15:58:07 -07001356 refAbiDumpFile, fileName, exportedHeaderFlags,
1357 Bool(library.Properties.Header_abi_checker.Check_all_apis),
Colin Cross127bb8b2020-12-16 16:46:01 -08001358 ctx.IsLlndk(), ctx.isNdk(ctx.Config()), ctx.IsVndkExt())
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001359 }
1360 }
1361}
1362
Colin Cross127bb8b2020-12-16 16:46:01 -08001363func processLLNDKHeaders(ctx ModuleContext, srcHeaderDir string, outDir android.ModuleGenPath) android.Path {
1364 srcDir := android.PathForModuleSrc(ctx, srcHeaderDir)
1365 srcFiles := ctx.GlobFiles(filepath.Join(srcDir.String(), "**/*.h"), nil)
1366
1367 var installPaths []android.WritablePath
1368 for _, header := range srcFiles {
1369 headerDir := filepath.Dir(header.String())
1370 relHeaderDir, err := filepath.Rel(srcDir.String(), headerDir)
1371 if err != nil {
1372 ctx.ModuleErrorf("filepath.Rel(%q, %q) failed: %s",
1373 srcDir.String(), headerDir, err)
1374 continue
1375 }
1376
1377 installPaths = append(installPaths, outDir.Join(ctx, relHeaderDir, header.Base()))
1378 }
1379
1380 return processHeadersWithVersioner(ctx, srcDir, outDir, srcFiles, installPaths)
1381}
1382
Chris Parsons3c27ca32020-11-20 12:42:07 -05001383// link registers actions to link this library, and sets various fields
1384// on this library to reflect information that should be exported up the build
1385// tree (for example, exported flags and include paths).
Colin Crossb916a382016-07-29 17:28:03 -07001386func (library *libraryDecorator) link(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001387 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001388
Colin Cross127bb8b2020-12-16 16:46:01 -08001389 if ctx.IsLlndk() {
1390 if len(library.Properties.Llndk.Export_preprocessed_headers) > 0 {
1391 // This is the vendor variant of an LLNDK library with preprocessed headers.
1392 genHeaderOutDir := android.PathForModuleGen(ctx, "include")
1393
1394 var timestampFiles android.Paths
1395 for _, dir := range library.Properties.Llndk.Export_preprocessed_headers {
1396 timestampFiles = append(timestampFiles, processLLNDKHeaders(ctx, dir, genHeaderOutDir))
1397 }
1398
1399 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1400 library.reexportSystemDirs(genHeaderOutDir)
1401 } else {
1402 library.reexportDirs(genHeaderOutDir)
1403 }
1404
1405 library.reexportDeps(timestampFiles...)
1406 }
1407
1408 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1409 library.flagExporter.Properties.Export_system_include_dirs = append(
1410 library.flagExporter.Properties.Export_system_include_dirs,
1411 library.flagExporter.Properties.Export_include_dirs...)
1412 library.flagExporter.Properties.Export_include_dirs = nil
1413 }
1414 }
1415
Chris Parsons3c27ca32020-11-20 12:42:07 -05001416 // Linking this library consists of linking `deps.Objs` (.o files in dependencies
1417 // of this library), together with `objs` (.o files created by compiling this
1418 // library).
Colin Crossad59e752017-11-16 14:29:11 -08001419 objs = deps.Objs.Copy().Append(objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001420 var out android.Path
Colin Crossa48ab5b2017-02-14 15:28:44 -08001421 if library.static() || library.header() {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001422 out = library.linkStatic(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001423 } else {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001424 out = library.linkShared(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001425 }
1426
Chris Parsons3c27ca32020-11-20 12:42:07 -05001427 // Export include paths and flags to be propagated up the tree.
Inseob Kim69378442019-06-03 19:10:47 +09001428 library.exportIncludes(ctx)
1429 library.reexportDirs(deps.ReexportedDirs...)
1430 library.reexportSystemDirs(deps.ReexportedSystemDirs...)
1431 library.reexportFlags(deps.ReexportedFlags...)
1432 library.reexportDeps(deps.ReexportedDeps...)
Inseob Kimd110f872019-12-06 13:15:38 +09001433 library.addExportedGeneratedHeaders(deps.ReexportedGeneratedHeaders...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001434
Chris Parsons3c27ca32020-11-20 12:42:07 -05001435 // Optionally export aidl headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001436 if Bool(library.Properties.Aidl.Export_aidl_headers) {
Dan Willemsene1240db2016-11-03 14:28:51 -07001437 if library.baseCompiler.hasSrcExt(".aidl") {
Jiyong Park74955042019-10-22 20:19:51 +09001438 dir := android.PathForModuleGen(ctx, "aidl")
Inseob Kim69378442019-06-03 19:10:47 +09001439 library.reexportDirs(dir)
Inseob Kimd110f872019-12-06 13:15:38 +09001440
Paul Duffin33056e82021-02-19 13:49:08 +00001441 library.reexportDeps(library.baseCompiler.aidlOrderOnlyDeps...)
1442 library.addExportedGeneratedHeaders(library.baseCompiler.aidlHeaders...)
Dan Willemsene1240db2016-11-03 14:28:51 -07001443 }
1444 }
1445
Chris Parsons3c27ca32020-11-20 12:42:07 -05001446 // Optionally export proto headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001447 if Bool(library.Properties.Proto.Export_proto_headers) {
Dan Willemsene1240db2016-11-03 14:28:51 -07001448 if library.baseCompiler.hasSrcExt(".proto") {
Jiyong Park74955042019-10-22 20:19:51 +09001449 var includes android.Paths
Colin Cross19878da2019-03-28 14:45:07 -07001450 if flags.proto.CanonicalPathFromRoot {
Jiyong Park74955042019-10-22 20:19:51 +09001451 includes = append(includes, flags.proto.SubDir)
Colin Cross10d22312017-05-03 11:01:58 -07001452 }
Jiyong Park74955042019-10-22 20:19:51 +09001453 includes = append(includes, flags.proto.Dir)
Inseob Kim69378442019-06-03 19:10:47 +09001454 library.reexportDirs(includes...)
Inseob Kimd110f872019-12-06 13:15:38 +09001455
Paul Duffin33056e82021-02-19 13:49:08 +00001456 library.reexportDeps(library.baseCompiler.protoOrderOnlyDeps...)
1457 library.addExportedGeneratedHeaders(library.baseCompiler.protoHeaders...)
Colin Cross0c461f12016-10-20 16:11:43 -07001458 }
1459 }
1460
Inseob Kim07def122020-11-23 14:43:02 +09001461 // If the library is sysprop_library, expose either public or internal header selectively.
Inseob Kim21f26902018-09-06 00:55:20 +09001462 if library.baseCompiler.hasSrcExt(".sysprop") {
Jiyong Park74955042019-10-22 20:19:51 +09001463 dir := android.PathForModuleGen(ctx, "sysprop", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001464 if library.Properties.Sysprop.Platform != nil {
Inseob Kimc0907f12019-02-08 21:00:45 +09001465 isOwnerPlatform := Bool(library.Properties.Sysprop.Platform)
1466
Inseob Kim07def122020-11-23 14:43:02 +09001467 // If the owner is different from the user, expose public header. That is,
1468 // 1) if the user is product (as owner can only be platform / vendor)
Inseob Kim06410042021-01-18 15:23:28 +09001469 // 2) if the owner is platform and the client is vendor
1470 // We don't care Platform -> Vendor dependency as it's already forbidden.
1471 if ctx.Device() && (ctx.ProductSpecific() || (isOwnerPlatform && ctx.inVendor())) {
Jiyong Park74955042019-10-22 20:19:51 +09001472 dir = android.PathForModuleGen(ctx, "sysprop/public", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001473 }
1474 }
1475
Paul Duffin37e0de52021-02-19 17:05:39 +00001476 // Make sure to only export headers which are within the include directory.
1477 _, headers := android.FilterPathListPredicate(library.baseCompiler.syspropHeaders, func(path android.Path) bool {
1478 _, isRel := android.MaybeRel(ctx, dir.String(), path.String())
1479 return isRel
1480 })
1481
Chris Parsons3c27ca32020-11-20 12:42:07 -05001482 // Add sysprop-related directories to the exported directories of this library.
Inseob Kim69378442019-06-03 19:10:47 +09001483 library.reexportDirs(dir)
Paul Duffin33056e82021-02-19 13:49:08 +00001484 library.reexportDeps(library.baseCompiler.syspropOrderOnlyDeps...)
Paul Duffin37e0de52021-02-19 17:05:39 +00001485 library.addExportedGeneratedHeaders(headers...)
Inseob Kim21f26902018-09-06 00:55:20 +09001486 }
1487
Chris Parsons3c27ca32020-11-20 12:42:07 -05001488 // Add stub-related flags if this library is a stub library.
Jiyong Park892a98f2020-12-14 09:20:00 +09001489 library.exportVersioningMacroIfNeeded(ctx)
Jiyong Parkda732bd2018-11-02 18:23:15 +09001490
Chris Parsons3c27ca32020-11-20 12:42:07 -05001491 // Propagate a Provider containing information about exported flags, deps, and include paths.
Colin Cross0de8a1e2020-09-18 14:15:30 -07001492 library.flagExporter.setProvider(ctx)
1493
Colin Cross4d9c2d12016-07-29 12:48:20 -07001494 return out
1495}
1496
Jiyong Park892a98f2020-12-14 09:20:00 +09001497func (library *libraryDecorator) exportVersioningMacroIfNeeded(ctx android.BaseModuleContext) {
Colin Cross127bb8b2020-12-16 16:46:01 -08001498 if library.buildStubs() && library.stubsVersion() != "" && !library.skipAPIDefine {
Jiyong Park892a98f2020-12-14 09:20:00 +09001499 name := versioningMacroName(ctx.Module().(*Module).ImplementationModuleName(ctx))
Jooyung Han11b0fbd2021-02-05 02:28:22 +09001500 apiLevel, err := android.ApiLevelFromUser(ctx, library.stubsVersion())
1501 if err != nil {
1502 ctx.ModuleErrorf("Can't export version macro: %s", err.Error())
1503 }
1504 library.reexportFlags("-D" + name + "=" + strconv.Itoa(apiLevel.FinalOrPreviewInt()))
Jiyong Park892a98f2020-12-14 09:20:00 +09001505 }
1506}
1507
Chris Parsons3c27ca32020-11-20 12:42:07 -05001508// buildStatic returns true if this library should be built as a static library.
Colin Crossb916a382016-07-29 17:28:03 -07001509func (library *libraryDecorator) buildStatic() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001510 return library.MutatedProperties.BuildStatic &&
1511 BoolDefault(library.StaticProperties.Static.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001512}
1513
Chris Parsons3c27ca32020-11-20 12:42:07 -05001514// buildShared returns true if this library should be built as a shared library.
Colin Crossb916a382016-07-29 17:28:03 -07001515func (library *libraryDecorator) buildShared() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001516 return library.MutatedProperties.BuildShared &&
1517 BoolDefault(library.SharedProperties.Shared.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001518}
1519
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001520func (library *libraryDecorator) objs() Objects {
1521 return library.objects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001522}
1523
Colin Cross0de8a1e2020-09-18 14:15:30 -07001524func (library *libraryDecorator) reuseObjs() Objects {
1525 return library.reuseObjects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001526}
1527
Colin Cross26c34ed2016-09-30 17:10:16 -07001528func (library *libraryDecorator) toc() android.OptionalPath {
1529 return library.tocFile
1530}
1531
Jiyong Parkf1194352019-02-25 11:05:47 +09001532func (library *libraryDecorator) installSymlinkToRuntimeApex(ctx ModuleContext, file android.Path) {
1533 dir := library.baseInstaller.installDir(ctx)
1534 dirOnDevice := android.InstallPathToOnDevicePath(ctx, dir)
1535 target := "/" + filepath.Join("apex", "com.android.runtime", dir.Base(), "bionic", file.Base())
1536 ctx.InstallAbsoluteSymlink(dir, file.Base(), target)
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001537 library.postInstallCmds = append(library.postInstallCmds, makeSymlinkCmd(dirOnDevice, file.Base(), target))
Jiyong Parkf1194352019-02-25 11:05:47 +09001538}
1539
Colin Crossb916a382016-07-29 17:28:03 -07001540func (library *libraryDecorator) install(ctx ModuleContext, file android.Path) {
Colin Crossc43ae772017-04-14 15:42:53 -07001541 if library.shared() {
Justin Yun8fe12122017-12-07 17:18:15 +09001542 if ctx.Device() && ctx.useVndk() {
Jooyung Han261e1582020-10-20 18:54:21 +09001543 // set subDir for VNDK extensions
Ivan Lozanof9e21722020-12-02 09:00:51 -05001544 if ctx.IsVndkExt() {
Jooyung Han261e1582020-10-20 18:54:21 +09001545 if ctx.isVndkSp() {
1546 library.baseInstaller.subDir = "vndk-sp"
1547 } else {
1548 library.baseInstaller.subDir = "vndk"
1549 }
1550 }
1551
Justin Yun31094b12020-12-24 16:11:23 +09001552 // In some cases we want to use core variant for VNDK-Core libs.
1553 // Skip product variant since VNDKs use only the vendor variant.
1554 if ctx.isVndk() && !ctx.isVndkSp() && !ctx.IsVndkExt() && !ctx.inProduct() {
Vic Yang1a5812a2020-01-31 10:38:40 -08001555 mayUseCoreVariant := true
1556
1557 if ctx.mustUseVendorVariant() {
1558 mayUseCoreVariant = false
1559 }
1560
Vic Yang1a5812a2020-01-31 10:38:40 -08001561 if ctx.Config().CFIEnabledForPath(ctx.ModuleDir()) && ctx.Arch().ArchType == android.Arm64 {
1562 mayUseCoreVariant = false
1563 }
1564
1565 if mayUseCoreVariant {
Vic Yangd92090f2020-01-08 14:32:28 -08001566 library.checkSameCoreVariant = true
1567 if ctx.DeviceConfig().VndkUseCoreVariant() {
1568 library.useCoreVariant = true
1569 }
Vic Yangefd249e2018-11-12 20:19:56 -08001570 }
Justin Yun8fe12122017-12-07 17:18:15 +09001571 }
Logan Chienf3511742017-10-31 18:04:35 +08001572
Jooyung Han261e1582020-10-20 18:54:21 +09001573 // do not install vndk libs
1574 // vndk libs are packaged into VNDK APEX
Ivan Lozanof9e21722020-12-02 09:00:51 -05001575 if ctx.isVndk() && !ctx.IsVndkExt() {
Jooyung Han261e1582020-10-20 18:54:21 +09001576 return
Justin Yun8effde42017-06-23 19:24:43 +09001577 }
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001578 } else if library.hasStubsVariants() && !ctx.Host() && ctx.directlyInAnyApex() {
Jiyong Parkf1194352019-02-25 11:05:47 +09001579 // Bionic libraries (e.g. libc.so) is installed to the bootstrap subdirectory.
1580 // The original path becomes a symlink to the corresponding file in the
1581 // runtime APEX.
Colin Cross3b19f5d2019-09-17 14:45:31 -07001582 translatedArch := ctx.Target().NativeBridge == android.NativeBridgeEnabled
Colin Cross56a83212020-09-15 18:30:11 -07001583 if InstallToBootstrap(ctx.baseModuleName(), ctx.Config()) && !library.buildStubs() &&
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001584 !translatedArch && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() {
Martin Stjernholm279de572019-09-10 23:18:20 +01001585 if ctx.Device() {
Jiyong Parkc3e2c862019-03-16 01:10:08 +09001586 library.installSymlinkToRuntimeApex(ctx, file)
1587 }
Jiyong Park429660f2019-01-16 22:31:11 +09001588 library.baseInstaller.subDir = "bootstrap"
1589 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001590 } else if ctx.directlyInAnyApex() && ctx.IsLlndk() && !isBionic(ctx.baseModuleName()) {
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001591 // Skip installing LLNDK (non-bionic) libraries moved to APEX.
Colin Crossa9c8c9f2020-12-16 10:20:23 -08001592 ctx.Module().HideFromMake()
Justin Yun8effde42017-06-23 19:24:43 +09001593 }
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001594
Colin Cross4d9c2d12016-07-29 12:48:20 -07001595 library.baseInstaller.install(ctx, file)
1596 }
Dan Albertf563d252017-10-13 00:29:00 -07001597
Dan Albert281f22b2017-12-13 15:03:47 -08001598 if Bool(library.Properties.Static_ndk_lib) && library.static() &&
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001599 !ctx.useVndk() && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() && ctx.Device() &&
Jiyong Park7ed9de32018-10-15 22:25:07 +09001600 library.baseLinker.sanitize.isUnsanitizedVariant() &&
Colin Cross95b07f22020-12-16 11:06:50 -08001601 ctx.isForPlatform() && !ctx.isPreventInstall() {
Dan Albertf563d252017-10-13 00:29:00 -07001602 installPath := getNdkSysrootBase(ctx).Join(
Dan Albertea4b7b92018-04-25 16:05:30 -07001603 ctx, "usr/lib", config.NDKTriple(ctx.toolchain()), file.Base())
Dan Albertf563d252017-10-13 00:29:00 -07001604
1605 ctx.ModuleBuild(pctx, android.ModuleBuildParams{
1606 Rule: android.Cp,
1607 Description: "install " + installPath.Base(),
1608 Output: installPath,
1609 Input: file,
1610 })
1611
Colin Cross0875c522017-11-28 17:34:01 -08001612 library.ndkSysrootPath = installPath
Dan Albertf563d252017-10-13 00:29:00 -07001613 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001614}
1615
Paul Duffin0cb37b92020-03-04 14:52:46 +00001616func (library *libraryDecorator) everInstallable() bool {
1617 // Only shared and static libraries are installed. Header libraries (which are
1618 // neither static or shared) are not installed.
1619 return library.shared() || library.static()
1620}
1621
Chris Parsons3c27ca32020-11-20 12:42:07 -05001622// static returns true if this library is for a "static' variant.
Colin Crossb916a382016-07-29 17:28:03 -07001623func (library *libraryDecorator) static() bool {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001624 return library.MutatedProperties.VariantIsStatic
Colin Cross4d9c2d12016-07-29 12:48:20 -07001625}
1626
Chris Parsons3c27ca32020-11-20 12:42:07 -05001627// shared returns true if this library is for a "shared' variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001628func (library *libraryDecorator) shared() bool {
1629 return library.MutatedProperties.VariantIsShared
1630}
1631
Chris Parsons3c27ca32020-11-20 12:42:07 -05001632// header returns true if this library is for a header-only variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001633func (library *libraryDecorator) header() bool {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001634 // Neither "static" nor "shared" implies this library is header-only.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001635 return !library.static() && !library.shared()
1636}
1637
Chris Parsons3c27ca32020-11-20 12:42:07 -05001638// setStatic marks the library variant as "static".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001639func (library *libraryDecorator) setStatic() {
1640 library.MutatedProperties.VariantIsStatic = true
1641 library.MutatedProperties.VariantIsShared = false
1642}
1643
Chris Parsons3c27ca32020-11-20 12:42:07 -05001644// setShared marks the library variant as "shared".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001645func (library *libraryDecorator) setShared() {
1646 library.MutatedProperties.VariantIsStatic = false
1647 library.MutatedProperties.VariantIsShared = true
Colin Crossb916a382016-07-29 17:28:03 -07001648}
1649
Chris Parsons3c27ca32020-11-20 12:42:07 -05001650// BuildOnlyStatic disables building this library as a shared library.
Colin Crossab3b7322016-12-09 14:46:15 -08001651func (library *libraryDecorator) BuildOnlyStatic() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001652 library.MutatedProperties.BuildShared = false
Colin Crossab3b7322016-12-09 14:46:15 -08001653}
1654
Chris Parsons3c27ca32020-11-20 12:42:07 -05001655// BuildOnlyShared disables building this library as a static library.
Colin Crossab3b7322016-12-09 14:46:15 -08001656func (library *libraryDecorator) BuildOnlyShared() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001657 library.MutatedProperties.BuildStatic = false
Colin Crossab3b7322016-12-09 14:46:15 -08001658}
1659
Chris Parsons3c27ca32020-11-20 12:42:07 -05001660// HeaderOnly disables building this library as a shared or static library;
1661// the library only exists to propagate header file dependencies up the build graph.
Colin Cross5950f382016-12-13 12:50:57 -08001662func (library *libraryDecorator) HeaderOnly() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001663 library.MutatedProperties.BuildShared = false
1664 library.MutatedProperties.BuildStatic = false
Colin Cross5950f382016-12-13 12:50:57 -08001665}
1666
Colin Cross127bb8b2020-12-16 16:46:01 -08001667// hasLLNDKStubs returns true if this cc_library module has a variant that will build LLNDK stubs.
1668func (library *libraryDecorator) hasLLNDKStubs() bool {
1669 return String(library.Properties.Llndk_stubs) != ""
1670}
1671
Colin Cross0477b422020-10-13 18:43:54 -07001672func (library *libraryDecorator) implementationModuleName(name string) string {
1673 return name
1674}
1675
Jiyong Park7ed9de32018-10-15 22:25:07 +09001676func (library *libraryDecorator) buildStubs() bool {
1677 return library.MutatedProperties.BuildStubs
1678}
1679
Jiyong Parka034b832019-08-27 14:02:19 +09001680func (library *libraryDecorator) symbolFileForAbiCheck(ctx ModuleContext) *string {
1681 if library.Properties.Header_abi_checker.Symbol_file != nil {
1682 return library.Properties.Header_abi_checker.Symbol_file
1683 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001684 if ctx.Module().(*Module).IsLlndk() {
1685 return library.Properties.Llndk.Symbol_file
1686 }
Colin Cross31076b32020-10-23 17:22:06 -07001687 if library.hasStubsVariants() && library.Properties.Stubs.Symbol_file != nil {
Jiyong Parka034b832019-08-27 14:02:19 +09001688 return library.Properties.Stubs.Symbol_file
1689 }
1690 return nil
1691}
1692
Colin Crossc88c2722020-09-28 17:32:47 -07001693func (library *libraryDecorator) hasStubsVariants() bool {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001694 // Just having stubs.symbol_file is enough to create a stub variant. In that case
1695 // the stub for the future API level is created.
1696 return library.Properties.Stubs.Symbol_file != nil ||
1697 len(library.Properties.Stubs.Versions) > 0
Colin Crossc88c2722020-09-28 17:32:47 -07001698}
1699
Colin Cross3572cf72020-10-01 15:58:11 -07001700func (library *libraryDecorator) stubsVersions(ctx android.BaseMutatorContext) []string {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001701 if !library.hasStubsVariants() {
1702 return nil
1703 }
1704
1705 // Future API level is implicitly added if there isn't
1706 vers := library.Properties.Stubs.Versions
1707 if inList(android.FutureApiLevel.String(), vers) {
1708 return vers
1709 }
1710 // In some cases, people use the raw value "10000" in the versions property.
1711 // We shouldn't add the future API level in that case, otherwise there will
1712 // be two identical versions.
1713 if inList(strconv.Itoa(android.FutureApiLevel.FinalOrFutureInt()), vers) {
1714 return vers
1715 }
1716 return append(vers, android.FutureApiLevel.String())
Colin Crossc88c2722020-09-28 17:32:47 -07001717}
1718
1719func (library *libraryDecorator) setStubsVersion(version string) {
1720 library.MutatedProperties.StubsVersion = version
1721}
1722
Jiyong Park7ed9de32018-10-15 22:25:07 +09001723func (library *libraryDecorator) stubsVersion() string {
1724 return library.MutatedProperties.StubsVersion
1725}
1726
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001727func (library *libraryDecorator) setBuildStubs(isLatest bool) {
Colin Crossc88c2722020-09-28 17:32:47 -07001728 library.MutatedProperties.BuildStubs = true
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001729 library.MutatedProperties.IsLatestVersion = isLatest
Colin Crossc88c2722020-09-28 17:32:47 -07001730}
1731
1732func (library *libraryDecorator) setAllStubsVersions(versions []string) {
1733 library.MutatedProperties.AllStubsVersions = versions
1734}
1735
1736func (library *libraryDecorator) allStubsVersions() []string {
1737 return library.MutatedProperties.AllStubsVersions
1738}
1739
Jooyung Hanad4c1872020-02-27 17:56:44 +09001740func (library *libraryDecorator) isLatestStubVersion() bool {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001741 return library.MutatedProperties.IsLatestVersion
Jooyung Hanad4c1872020-02-27 17:56:44 +09001742}
1743
Jiyong Parka90ca002019-10-07 15:47:24 +09001744func (library *libraryDecorator) availableFor(what string) bool {
1745 var list []string
1746 if library.static() {
1747 list = library.StaticProperties.Static.Apex_available
1748 } else if library.shared() {
1749 list = library.SharedProperties.Shared.Apex_available
1750 }
1751 if len(list) == 0 {
1752 return false
1753 }
1754 return android.CheckAvailableForApex(what, list)
1755}
1756
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001757func (library *libraryDecorator) makeUninstallable(mod *Module) {
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001758 if library.static() && library.buildStatic() && !library.buildStubs() {
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001759 // If we're asked to make a static library uninstallable we don't do
1760 // anything since AndroidMkEntries always sets LOCAL_UNINSTALLABLE_MODULE
1761 // for these entries. This is done to still get the make targets for NOTICE
1762 // files from notice_files.mk, which other libraries might depend on.
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001763 return
1764 }
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001765 mod.ModuleBase.MakeUninstallable()
Martin Stjernholmbf37d162020-03-31 16:05:34 +01001766}
1767
Colin Cross571cccf2019-02-04 11:22:08 -08001768var versioningMacroNamesListKey = android.NewOnceKey("versioningMacroNamesList")
1769
Chris Parsons3c27ca32020-11-20 12:42:07 -05001770// versioningMacroNamesList returns a singleton map, where keys are "version macro names",
1771// and values are the module name responsible for registering the version macro name.
1772//
1773// Version macros are used when building against stubs, to provide version information about
1774// the stub. Only stub libraries should have an entry in this list.
1775//
1776// For example, when building against libFoo#ver, __LIBFOO_API__ macro is set to ver so
1777// that headers from libFoo can be conditionally compiled (this may hide APIs
1778// that are not available for the version).
1779//
1780// This map is used to ensure that there aren't conflicts between these version macro names.
Jiyong Parkda732bd2018-11-02 18:23:15 +09001781func versioningMacroNamesList(config android.Config) *map[string]string {
Colin Cross571cccf2019-02-04 11:22:08 -08001782 return config.Once(versioningMacroNamesListKey, func() interface{} {
Jiyong Parkda732bd2018-11-02 18:23:15 +09001783 m := make(map[string]string)
1784 return &m
1785 }).(*map[string]string)
1786}
1787
1788// alphanumeric and _ characters are preserved.
1789// other characters are all converted to _
1790var charsNotForMacro = regexp.MustCompile("[^a-zA-Z0-9_]+")
1791
Chris Parsons3c27ca32020-11-20 12:42:07 -05001792// versioningMacroName returns the canonical version macro name for the given module.
Jiyong Parkda732bd2018-11-02 18:23:15 +09001793func versioningMacroName(moduleName string) string {
1794 macroName := charsNotForMacro.ReplaceAllString(moduleName, "_")
Jooyung Hanb04a4992020-03-13 18:57:35 +09001795 macroName = strings.ToUpper(macroName)
Jiyong Parkda732bd2018-11-02 18:23:15 +09001796 return "__" + macroName + "_API__"
1797}
1798
Chris Parsons3c27ca32020-11-20 12:42:07 -05001799// NewLibrary builds and returns a new Module corresponding to a C++ library.
1800// Individual module implementations which comprise a C++ library (or something like
1801// a C++ library) should call this function, set some fields on the result, and
1802// then call the Init function.
Colin Crossab3b7322016-12-09 14:46:15 -08001803func NewLibrary(hod android.HostOrDeviceSupported) (*Module, *libraryDecorator) {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001804 module := newModule(hod, android.MultilibBoth)
1805
Colin Crossb916a382016-07-29 17:28:03 -07001806 library := &libraryDecorator{
Colin Crossa48ab5b2017-02-14 15:28:44 -08001807 MutatedProperties: LibraryMutatedProperties{
Colin Crossab3b7322016-12-09 14:46:15 -08001808 BuildShared: true,
1809 BuildStatic: true,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001810 },
Colin Crossb916a382016-07-29 17:28:03 -07001811 baseCompiler: NewBaseCompiler(),
Dan Albert61f32122018-07-26 14:00:24 -07001812 baseLinker: NewBaseLinker(module.sanitize),
Colin Crossb916a382016-07-29 17:28:03 -07001813 baseInstaller: NewBaseInstaller("lib", "lib64", InstallInSystem),
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001814 sabi: module.sabi,
Colin Cross4d9c2d12016-07-29 12:48:20 -07001815 }
1816
Colin Crossb916a382016-07-29 17:28:03 -07001817 module.compiler = library
1818 module.linker = library
1819 module.installer = library
Colin Cross31076b32020-10-23 17:22:06 -07001820 module.library = library
Colin Crossb916a382016-07-29 17:28:03 -07001821
1822 return module, library
1823}
1824
Colin Cross10d22312017-05-03 11:01:58 -07001825// connects a shared library to a static library in order to reuse its .o files to avoid
1826// compiling source files twice.
1827func reuseStaticLibrary(mctx android.BottomUpMutatorContext, static, shared *Module) {
1828 if staticCompiler, ok := static.compiler.(*libraryDecorator); ok {
1829 sharedCompiler := shared.compiler.(*libraryDecorator)
Dan Willemsen3a26eef2018-12-03 15:25:46 -08001830
1831 // Check libraries in addition to cflags, since libraries may be exporting different
1832 // include directories.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001833 if len(staticCompiler.StaticProperties.Static.Cflags) == 0 &&
1834 len(sharedCompiler.SharedProperties.Shared.Cflags) == 0 &&
1835 len(staticCompiler.StaticProperties.Static.Whole_static_libs) == 0 &&
1836 len(sharedCompiler.SharedProperties.Shared.Whole_static_libs) == 0 &&
1837 len(staticCompiler.StaticProperties.Static.Static_libs) == 0 &&
1838 len(sharedCompiler.SharedProperties.Shared.Static_libs) == 0 &&
1839 len(staticCompiler.StaticProperties.Static.Shared_libs) == 0 &&
1840 len(sharedCompiler.SharedProperties.Shared.Shared_libs) == 0 &&
Martin Stjernholm10566a02020-03-24 01:19:52 +00001841 // Compare System_shared_libs properties with nil because empty lists are
1842 // semantically significant for them.
Colin Crosse1bb5d02019-09-24 14:55:04 -07001843 staticCompiler.StaticProperties.Static.System_shared_libs == nil &&
1844 sharedCompiler.SharedProperties.Shared.System_shared_libs == nil {
Colin Cross10d22312017-05-03 11:01:58 -07001845
1846 mctx.AddInterVariantDependency(reuseObjTag, shared, static)
1847 sharedCompiler.baseCompiler.Properties.OriginalSrcs =
1848 sharedCompiler.baseCompiler.Properties.Srcs
1849 sharedCompiler.baseCompiler.Properties.Srcs = nil
1850 sharedCompiler.baseCompiler.Properties.Generated_sources = nil
1851 }
Colin Cross0de8a1e2020-09-18 14:15:30 -07001852
1853 // This dep is just to reference static variant from shared variant
1854 mctx.AddInterVariantDependency(staticVariantTag, shared, static)
Colin Cross10d22312017-05-03 11:01:58 -07001855 }
1856}
1857
Chris Parsons3c27ca32020-11-20 12:42:07 -05001858// LinkageMutator adds "static" or "shared" variants for modules depending
1859// on whether the module can be built as a static library or a shared library.
Colin Crosse40b4ea2018-10-02 22:25:58 -07001860func LinkageMutator(mctx android.BottomUpMutatorContext) {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001861 ccPrebuilt := false
Colin Crossb916a382016-07-29 17:28:03 -07001862 if m, ok := mctx.Module().(*Module); ok && m.linker != nil {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001863 _, ccPrebuilt = m.linker.(prebuiltLibraryInterface)
Ivan Lozano52767be2019-10-18 14:49:46 -07001864 }
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001865 if ccPrebuilt {
Ivan Lozano52767be2019-10-18 14:49:46 -07001866 library := mctx.Module().(*Module).linker.(prebuiltLibraryInterface)
Colin Cross33b2fb72019-05-14 14:07:01 -07001867
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001868 // Differentiate between header only and building an actual static/shared library
Colin Cross127bb8b2020-12-16 16:46:01 -08001869 buildStatic := library.buildStatic()
1870 buildShared := library.buildShared()
1871 if buildStatic || buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001872 // Always create both the static and shared variants for prebuilt libraries, and then disable the one
1873 // that is not being used. This allows them to share the name of a cc_library module, which requires that
1874 // all the variants of the cc_library also exist on the prebuilt.
1875 modules := mctx.CreateLocalVariations("static", "shared")
1876 static := modules[0].(*Module)
1877 shared := modules[1].(*Module)
Colin Cross33b2fb72019-05-14 14:07:01 -07001878
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001879 static.linker.(prebuiltLibraryInterface).setStatic()
1880 shared.linker.(prebuiltLibraryInterface).setShared()
Colin Cross33b2fb72019-05-14 14:07:01 -07001881
Colin Cross127bb8b2020-12-16 16:46:01 -08001882 if buildShared {
Colin Cross81ca6cd2020-08-06 17:46:48 -07001883 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08001884 } else if buildStatic {
Colin Cross81ca6cd2020-08-06 17:46:48 -07001885 mctx.AliasVariation("static")
1886 }
1887
Colin Cross127bb8b2020-12-16 16:46:01 -08001888 if !buildStatic {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001889 static.linker.(prebuiltLibraryInterface).disablePrebuilt()
1890 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001891 if !buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001892 shared.linker.(prebuiltLibraryInterface).disablePrebuilt()
1893 }
1894 } else {
1895 // Header only
Colin Crossb916a382016-07-29 17:28:03 -07001896 }
Paul Duffinf5ea9e12020-02-21 10:57:00 +00001897
Ivan Lozano52767be2019-10-18 14:49:46 -07001898 } else if library, ok := mctx.Module().(LinkableInterface); ok && library.CcLibraryInterface() {
Ivan Lozano52767be2019-10-18 14:49:46 -07001899
Ivan Lozano2b262972019-11-21 12:30:50 -08001900 // Non-cc.Modules may need an empty variant for their mutators.
1901 variations := []string{}
1902 if library.NonCcVariants() {
1903 variations = append(variations, "")
1904 }
1905
Colin Cross127bb8b2020-12-16 16:46:01 -08001906 isLLNDK := false
1907 if m, ok := mctx.Module().(*Module); ok {
Colin Cross127bb8b2020-12-16 16:46:01 -08001908 // Don't count the vestigial llndk_library module as isLLNDK, it needs a static
1909 // variant so that a cc_library_prebuilt can depend on it.
Colin Cross4f4f8eb2021-01-06 14:07:27 -08001910 isLLNDK = m.IsLlndk() && !isVestigialLLNDKModule(m)
Colin Cross127bb8b2020-12-16 16:46:01 -08001911 }
1912 buildStatic := library.BuildStaticVariant() && !isLLNDK
1913 buildShared := library.BuildSharedVariant()
1914 if buildStatic && buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08001915 variations := append([]string{"static", "shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001916
1917 modules := mctx.CreateLocalVariations(variations...)
1918 static := modules[0].(LinkableInterface)
1919 shared := modules[1].(LinkableInterface)
1920
1921 static.SetStatic()
1922 shared.SetShared()
1923
1924 if _, ok := library.(*Module); ok {
1925 reuseStaticLibrary(mctx, static.(*Module), shared.(*Module))
1926 }
Colin Cross81ca6cd2020-08-06 17:46:48 -07001927 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08001928 } else if buildStatic {
Ivan Lozano2b262972019-11-21 12:30:50 -08001929 variations := append([]string{"static"}, variations...)
1930
1931 modules := mctx.CreateLocalVariations(variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001932 modules[0].(LinkableInterface).SetStatic()
Colin Cross81ca6cd2020-08-06 17:46:48 -07001933 mctx.AliasVariation("static")
Colin Cross127bb8b2020-12-16 16:46:01 -08001934 } else if buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08001935 variations := append([]string{"shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07001936
Ivan Lozano2b262972019-11-21 12:30:50 -08001937 modules := mctx.CreateLocalVariations(variations...)
1938 modules[0].(LinkableInterface).SetShared()
Colin Cross81ca6cd2020-08-06 17:46:48 -07001939 mctx.AliasVariation("shared")
Ivan Lozano2b262972019-11-21 12:30:50 -08001940 } else if len(variations) > 0 {
1941 mctx.CreateLocalVariations(variations...)
Colin Cross81ca6cd2020-08-06 17:46:48 -07001942 mctx.AliasVariation(variations[0])
Ivan Lozano2b262972019-11-21 12:30:50 -08001943 }
Colin Crossb916a382016-07-29 17:28:03 -07001944 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001945}
Jiyong Park7ed9de32018-10-15 22:25:07 +09001946
Chris Parsons3c27ca32020-11-20 12:42:07 -05001947// normalizeVersions modifies `versions` in place, so that each raw version
1948// string becomes its normalized canonical form.
1949// Validates that the versions in `versions` are specified in least to greatest order.
Jooyung Hanaed150d2020-04-02 01:41:41 +09001950func normalizeVersions(ctx android.BaseModuleContext, versions []string) {
Dan Albertc8060532020-07-22 22:32:17 -07001951 var previous android.ApiLevel
Jooyung Hanad4c1872020-02-27 17:56:44 +09001952 for i, v := range versions {
Dan Albertc8060532020-07-22 22:32:17 -07001953 ver, err := android.ApiLevelFromUser(ctx, v)
Jooyung Hanad4c1872020-02-27 17:56:44 +09001954 if err != nil {
Jooyung Hanaed150d2020-04-02 01:41:41 +09001955 ctx.PropertyErrorf("versions", "%s", err.Error())
1956 return
Jooyung Hanad4c1872020-02-27 17:56:44 +09001957 }
Dan Albertc8060532020-07-22 22:32:17 -07001958 if i > 0 && ver.LessThanOrEqualTo(previous) {
1959 ctx.PropertyErrorf("versions", "not sorted: %v", versions)
1960 }
1961 versions[i] = ver.String()
1962 previous = ver
Jooyung Hanaed150d2020-04-02 01:41:41 +09001963 }
Jooyung Hanad4c1872020-02-27 17:56:44 +09001964}
1965
Jooyung Han61b66e92020-03-21 14:21:46 +00001966func createVersionVariations(mctx android.BottomUpMutatorContext, versions []string) {
Colin Cross127bb8b2020-12-16 16:46:01 -08001967 // "" is for the non-stubs (implementation) variant for system modules, or the LLNDK variant
1968 // for LLNDK modules.
Colin Cross0de8a1e2020-09-18 14:15:30 -07001969 variants := append(android.CopyOf(versions), "")
Jooyung Han61b66e92020-03-21 14:21:46 +00001970
Colin Cross127bb8b2020-12-16 16:46:01 -08001971 m := mctx.Module().(*Module)
1972 isLLNDK := m.IsLlndk()
1973
Colin Crossd1f898e2020-08-18 18:35:15 -07001974 modules := mctx.CreateLocalVariations(variants...)
Jooyung Han61b66e92020-03-21 14:21:46 +00001975 for i, m := range modules {
Colin Cross127bb8b2020-12-16 16:46:01 -08001976
1977 if variants[i] != "" || isLLNDK {
1978 // A stubs or LLNDK stubs variant.
Colin Cross31076b32020-10-23 17:22:06 -07001979 c := m.(*Module)
Colin Cross31076b32020-10-23 17:22:06 -07001980 c.sanitize = nil
1981 c.stl = nil
1982 c.Properties.PreventInstall = true
1983 lib := moduleLibraryInterface(m)
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001984 isLatest := i == (len(versions) - 1)
1985 lib.setBuildStubs(isLatest)
Colin Cross127bb8b2020-12-16 16:46:01 -08001986
1987 if variants[i] != "" {
1988 // A non-LLNDK stubs module is hidden from make and has a dependency from the
1989 // implementation module to the stubs module.
1990 c.Properties.HideFromMake = true
1991 lib.setStubsVersion(variants[i])
1992 mctx.AddInterVariantDependency(stubImplDepTag, modules[len(modules)-1], modules[i])
1993 }
Jooyung Han61b66e92020-03-21 14:21:46 +00001994 }
1995 }
Colin Cross094faa52020-08-06 17:38:25 -07001996 mctx.AliasVariation("")
Colin Crossd1f898e2020-08-18 18:35:15 -07001997 latestVersion := ""
1998 if len(versions) > 0 {
1999 latestVersion = versions[len(versions)-1]
2000 }
2001 mctx.CreateAliasVariation("latest", latestVersion)
Jooyung Han61b66e92020-03-21 14:21:46 +00002002}
2003
Colin Crossbbc941b2020-09-30 12:27:01 -07002004func createPerApiVersionVariations(mctx android.BottomUpMutatorContext, minSdkVersion string) {
2005 from, err := nativeApiLevelFromUser(mctx, minSdkVersion)
2006 if err != nil {
2007 mctx.PropertyErrorf("min_sdk_version", err.Error())
2008 return
2009 }
2010
2011 versionStrs := ndkLibraryVersions(mctx, from)
2012 modules := mctx.CreateLocalVariations(versionStrs...)
2013
2014 for i, module := range modules {
2015 module.(*Module).Properties.Sdk_version = StringPtr(versionStrs[i])
Jiyong Parkfdaa5f72021-03-19 22:18:04 +09002016 module.(*Module).Properties.Min_sdk_version = StringPtr(versionStrs[i])
Colin Crossbbc941b2020-09-30 12:27:01 -07002017 }
2018}
2019
Colin Cross3146c5c2020-09-30 15:34:40 -07002020func CanBeOrLinkAgainstVersionVariants(module interface {
Jooyung Han624d35c2020-04-10 12:57:24 +09002021 Host() bool
2022 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07002023 InVendorRamdisk() bool
Jooyung Han624d35c2020-04-10 12:57:24 +09002024}) bool {
Jose Galmes6f843bc2020-12-11 13:36:29 -08002025 return !module.Host() && !module.InRamdisk() && !module.InVendorRamdisk()
Jooyung Han624d35c2020-04-10 12:57:24 +09002026}
2027
Colin Cross3146c5c2020-09-30 15:34:40 -07002028func CanBeVersionVariant(module interface {
2029 Host() bool
2030 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07002031 InVendorRamdisk() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07002032 InRecovery() bool
2033 CcLibraryInterface() bool
2034 Shared() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07002035}) bool {
2036 return CanBeOrLinkAgainstVersionVariants(module) &&
Colin Crossa717db72020-10-23 14:53:06 -07002037 module.CcLibraryInterface() && module.Shared()
Colin Cross3146c5c2020-09-30 15:34:40 -07002038}
2039
Colin Cross127bb8b2020-12-16 16:46:01 -08002040func moduleLibraryInterface(module blueprint.Module) libraryInterface {
Colin Cross31076b32020-10-23 17:22:06 -07002041 if m, ok := module.(*Module); ok {
2042 return m.library
2043 }
2044 return nil
2045}
2046
Colin Crossd1f898e2020-08-18 18:35:15 -07002047// versionSelector normalizes the versions in the Stubs.Versions property into MutatedProperties.AllStubsVersions,
2048// and propagates the value from implementation libraries to llndk libraries with the same name.
2049func versionSelectorMutator(mctx android.BottomUpMutatorContext) {
Colin Cross31076b32020-10-23 17:22:06 -07002050 if library := moduleLibraryInterface(mctx.Module()); library != nil && CanBeVersionVariant(mctx.Module().(*Module)) {
2051 if library.buildShared() {
2052 versions := library.stubsVersions(mctx)
Colin Cross3572cf72020-10-01 15:58:11 -07002053 if len(versions) > 0 {
2054 normalizeVersions(mctx, versions)
2055 if mctx.Failed() {
Colin Crossbbc941b2020-09-30 12:27:01 -07002056 return
2057 }
Colin Cross3572cf72020-10-01 15:58:11 -07002058 // Set the versions on the pre-mutated module so they can be read by any llndk modules that
2059 // depend on the implementation library and haven't been mutated yet.
Colin Cross31076b32020-10-23 17:22:06 -07002060 library.setAllStubsVersions(versions)
Colin Cross127bb8b2020-12-16 16:46:01 -08002061 }
2062
2063 if mctx.Module().(*Module).UseVndk() && library.hasLLNDKStubs() {
2064 // Propagate the version to the llndk stubs module.
2065 mctx.VisitDirectDepsWithTag(llndkStubDepTag, func(stubs android.Module) {
2066 if stubsLib := moduleLibraryInterface(stubs); stubsLib != nil {
2067 stubsLib.setAllStubsVersions(library.allStubsVersions())
2068 }
2069 })
Jiyong Park7ed9de32018-10-15 22:25:07 +09002070 }
Jooyung Han61b66e92020-03-21 14:21:46 +00002071 }
Colin Crossd1f898e2020-08-18 18:35:15 -07002072 }
2073}
Jooyung Han61b66e92020-03-21 14:21:46 +00002074
Colin Crossd1f898e2020-08-18 18:35:15 -07002075// versionMutator splits a module into the mandatory non-stubs variant
2076// (which is unnamed) and zero or more stubs variants.
2077func versionMutator(mctx android.BottomUpMutatorContext) {
Colin Cross31076b32020-10-23 17:22:06 -07002078 if library := moduleLibraryInterface(mctx.Module()); library != nil && CanBeVersionVariant(mctx.Module().(*Module)) {
2079 createVersionVariations(mctx, library.allStubsVersions())
Colin Crossbbc941b2020-09-30 12:27:01 -07002080 return
2081 }
2082
2083 if m, ok := mctx.Module().(*Module); ok {
2084 if m.SplitPerApiLevel() && m.IsSdkVariant() {
2085 if mctx.Os() != android.Android {
2086 return
2087 }
2088 createPerApiVersionVariations(mctx, m.MinSdkVersion())
2089 }
Jiyong Park7ed9de32018-10-15 22:25:07 +09002090 }
Jiyong Park7ed9de32018-10-15 22:25:07 +09002091}
Colin Crossd7227f92019-09-05 14:26:33 -07002092
2093// maybeInjectBoringSSLHash adds a rule to run bssl_inject_hash on the output file if the module has the
2094// inject_bssl_hash or if any static library dependencies have inject_bssl_hash set. It returns the output path
2095// that the linked output file should be written to.
2096// TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
2097func maybeInjectBoringSSLHash(ctx android.ModuleContext, outputFile android.ModuleOutPath,
2098 inject *bool, fileName string) android.ModuleOutPath {
2099 // TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
2100 injectBoringSSLHash := Bool(inject)
2101 ctx.VisitDirectDeps(func(dep android.Module) {
Colin Cross6e511a92020-07-27 21:26:48 -07002102 if tag, ok := ctx.OtherModuleDependencyTag(dep).(libraryDependencyTag); ok && tag.static() {
Colin Crossd7227f92019-09-05 14:26:33 -07002103 if cc, ok := dep.(*Module); ok {
2104 if library, ok := cc.linker.(*libraryDecorator); ok {
2105 if Bool(library.Properties.Inject_bssl_hash) {
2106 injectBoringSSLHash = true
2107 }
2108 }
2109 }
2110 }
2111 })
2112 if injectBoringSSLHash {
2113 hashedOutputfile := outputFile
2114 outputFile = android.PathForModuleOut(ctx, "unhashed", fileName)
2115
Colin Crossf1a035e2020-11-16 17:32:30 -08002116 rule := android.NewRuleBuilder(pctx, ctx)
Colin Crossd7227f92019-09-05 14:26:33 -07002117 rule.Command().
Colin Crossf1a035e2020-11-16 17:32:30 -08002118 BuiltTool("bssl_inject_hash").
Pete Bentley5c4be822019-10-01 17:03:17 +01002119 Flag("-sha256").
Colin Crossd7227f92019-09-05 14:26:33 -07002120 FlagWithInput("-in-object ", outputFile).
2121 FlagWithOutput("-o ", hashedOutputfile)
Colin Crossf1a035e2020-11-16 17:32:30 -08002122 rule.Build("injectCryptoHash", "inject crypto hash")
Colin Crossd7227f92019-09-05 14:26:33 -07002123 }
2124
2125 return outputFile
2126}
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002127
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002128type bazelCcLibraryStaticAttributes struct {
Jingwen Chen63930982021-03-24 10:04:33 -04002129 Copts bazel.StringListAttribute
Jingwen Chen07027912021-03-15 06:02:43 -04002130 Srcs bazel.LabelListAttribute
2131 Deps bazel.LabelListAttribute
Jingwen Chen63930982021-03-24 10:04:33 -04002132 Linkopts bazel.StringListAttribute
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002133 Linkstatic bool
Rupert Shuttleworthb8151682021-04-06 20:06:21 +00002134 Includes bazel.StringListAttribute
Jingwen Chen07027912021-03-15 06:02:43 -04002135 Hdrs bazel.LabelListAttribute
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002136}
2137
2138type bazelCcLibraryStatic struct {
2139 android.BazelTargetModuleBase
2140 bazelCcLibraryStaticAttributes
2141}
2142
2143func BazelCcLibraryStaticFactory() android.Module {
2144 module := &bazelCcLibraryStatic{}
2145 module.AddProperties(&module.bazelCcLibraryStaticAttributes)
2146 android.InitBazelTargetModule(module)
2147 return module
2148}
2149
2150func CcLibraryStaticBp2Build(ctx android.TopDownMutatorContext) {
2151 module, ok := ctx.Module().(*Module)
2152 if !ok {
2153 // Not a cc module
2154 return
2155 }
2156 if !module.ConvertWithBp2build(ctx) {
2157 return
2158 }
2159 if ctx.ModuleType() != "cc_library_static" {
2160 return
2161 }
2162
Jingwen Chen107c0de2021-04-09 10:43:12 +00002163 compilerAttrs := bp2BuildParseCompilerProps(ctx, module)
Jingwen Chen63930982021-03-24 10:04:33 -04002164
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002165 var includeDirs []string
2166 var localIncludeDirs []string
2167 for _, props := range module.compiler.compilerProps() {
2168 if baseCompilerProps, ok := props.(*BaseCompilerProperties); ok {
Jingwen Chen107c0de2021-04-09 10:43:12 +00002169 // TODO: these should be arch and os specific.
Rupert Shuttleworthb8151682021-04-06 20:06:21 +00002170 includeDirs = bp2BuildMakePathsRelativeToModule(ctx, baseCompilerProps.Include_dirs)
2171 localIncludeDirs = bp2BuildMakePathsRelativeToModule(ctx, baseCompilerProps.Local_include_dirs)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002172 break
2173 }
2174 }
Rupert Shuttleworthc58d3d22021-04-06 16:37:15 +00002175
2176 // Soong implicitly includes headers from the module's directory.
2177 // For Bazel builds to work we have to make these header includes explicit.
2178 if module.compiler.(*libraryDecorator).includeBuildDirectory() {
2179 localIncludeDirs = append(localIncludeDirs, ".")
2180 }
2181
Rupert Shuttleworthc58d3d22021-04-06 16:37:15 +00002182 // For Bazel, be more explicit about headers - list all header files in include dirs as srcs
2183 for _, includeDir := range includeDirs {
Jingwen Chen107c0de2021-04-09 10:43:12 +00002184 compilerAttrs.srcs.Value.Append(bp2BuildListHeadersInDir(ctx, includeDir))
Rupert Shuttleworthc58d3d22021-04-06 16:37:15 +00002185 }
2186 for _, localIncludeDir := range localIncludeDirs {
Jingwen Chen107c0de2021-04-09 10:43:12 +00002187 compilerAttrs.srcs.Value.Append(bp2BuildListHeadersInDir(ctx, localIncludeDir))
Rupert Shuttleworthc58d3d22021-04-06 16:37:15 +00002188 }
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002189
2190 var staticLibs []string
2191 var wholeStaticLibs []string
2192 for _, props := range module.linker.linkerProps() {
Jingwen Chen107c0de2021-04-09 10:43:12 +00002193 // TODO: move this into bp2buildParseLinkerProps
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002194 if baseLinkerProperties, ok := props.(*BaseLinkerProperties); ok {
2195 staticLibs = baseLinkerProperties.Static_libs
2196 wholeStaticLibs = baseLinkerProperties.Whole_static_libs
2197 break
2198 }
2199 }
2200
2201 // FIXME: Treat Static_libs and Whole_static_libs differently?
2202 allDeps := staticLibs
2203 allDeps = append(allDeps, wholeStaticLibs...)
2204
2205 depsLabels := android.BazelLabelForModuleDeps(ctx, allDeps)
2206
Rupert Shuttleworthb8151682021-04-06 20:06:21 +00002207 exportedIncludes, exportedIncludesHeaders := bp2BuildParseExportedIncludes(ctx, module)
2208
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002209 // FIXME: Unify absolute vs relative paths
2210 // FIXME: Use -I copts instead of setting includes= ?
Rupert Shuttleworthb8151682021-04-06 20:06:21 +00002211 allIncludes := exportedIncludes
2212 allIncludes.Value = append(allIncludes.Value, includeDirs...)
2213 allIncludes.Value = append(allIncludes.Value, localIncludeDirs...)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002214
Jingwen Chen107c0de2021-04-09 10:43:12 +00002215 compilerAttrs.hdrs.Append(exportedIncludesHeaders)
Jingwen Chen63930982021-03-24 10:04:33 -04002216
Jingwen Chen107c0de2021-04-09 10:43:12 +00002217 linkerAttrs := bp2BuildParseLinkerProps(ctx, module)
2218 depsLabels.Append(linkerAttrs.deps.Value)
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002219
2220 attrs := &bazelCcLibraryStaticAttributes{
Jingwen Chen107c0de2021-04-09 10:43:12 +00002221 Copts: compilerAttrs.copts,
2222 Srcs: compilerAttrs.srcs,
Jingwen Chen07027912021-03-15 06:02:43 -04002223 Deps: bazel.MakeLabelListAttribute(depsLabels),
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002224 Linkstatic: true,
Rupert Shuttleworthb8151682021-04-06 20:06:21 +00002225 Includes: allIncludes,
Jingwen Chen107c0de2021-04-09 10:43:12 +00002226 Hdrs: compilerAttrs.hdrs,
Rupert Shuttleworth095081c2021-03-25 09:06:03 +00002227 }
2228
2229 props := bazel.BazelTargetModuleProperties{
2230 Rule_class: "cc_library_static",
2231 Bzl_load_location: "//build/bazel/rules:cc_library_static.bzl",
2232 }
2233
2234 ctx.CreateBazelTargetModule(BazelCcLibraryStaticFactory, module.Name(), props, attrs)
2235}
2236
2237func (m *bazelCcLibraryStatic) Name() string {
2238 return m.BaseModuleName()
2239}
2240
2241func (m *bazelCcLibraryStatic) GenerateAndroidBuildActions(ctx android.ModuleContext) {}