blob: 7cc5a18edc5a68c8f657b67e19dbbde5fb30c33c [file] [log] [blame]
Colin Cross4d9c2d12016-07-29 12:48:20 -07001// Copyright 2016 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15package cc
16
17import (
Inseob Kim69378442019-06-03 19:10:47 +090018 "fmt"
Logan Chien41eabe62019-04-10 13:33:58 +080019 "io"
Jiyong Parkf1194352019-02-25 11:05:47 +090020 "path/filepath"
Jiyong Parkda732bd2018-11-02 18:23:15 +090021 "regexp"
Colin Crossadd04a82024-05-22 09:57:59 -070022 "slices"
Jooyung Han11b0fbd2021-02-05 02:28:22 +090023 "strconv"
Colin Cross4d9c2d12016-07-29 12:48:20 -070024 "strings"
Jiyong Parkda732bd2018-11-02 18:23:15 +090025 "sync"
Colin Cross4d9c2d12016-07-29 12:48:20 -070026
Colin Cross4d9c2d12016-07-29 12:48:20 -070027 "android/soong/android"
Kiyoung Kimaa394802024-01-08 12:55:45 +090028
Chris Parsons51f8c392021-08-03 21:01:05 -040029 "github.com/google/blueprint"
30 "github.com/google/blueprint/pathtools"
Spandan Das4238c652022-09-09 01:38:47 +000031 "github.com/google/blueprint/proptools"
Colin Cross4d9c2d12016-07-29 12:48:20 -070032)
33
Liz Kammer2b376bc2022-01-12 12:00:49 -050034// LibraryProperties is a collection of properties shared by cc library rules/cc.
Colin Crossb916a382016-07-29 17:28:03 -070035type LibraryProperties struct {
Colin Cross4d9c2d12016-07-29 12:48:20 -070036 // local file name to pass to the linker as -unexported_symbols_list
Colin Cross27b922f2019-03-04 22:35:41 -080037 Unexported_symbols_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070038 // local file name to pass to the linker as -force_symbols_not_weak_list
Colin Cross27b922f2019-03-04 22:35:41 -080039 Force_symbols_not_weak_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070040 // local file name to pass to the linker as -force_symbols_weak_list
Colin Cross27b922f2019-03-04 22:35:41 -080041 Force_symbols_weak_list *string `android:"path,arch_variant"`
Colin Cross4d9c2d12016-07-29 12:48:20 -070042
43 // rename host libraries to prevent overlap with system installed libraries
44 Unique_host_soname *bool
45
Dan Willemsene1240db2016-11-03 14:28:51 -070046 Aidl struct {
47 // export headers generated from .aidl sources
Nan Zhang0007d812017-11-07 10:57:05 -080048 Export_aidl_headers *bool
Dan Willemsene1240db2016-11-03 14:28:51 -070049 }
50
Colin Cross0c461f12016-10-20 16:11:43 -070051 Proto struct {
52 // export headers generated from .proto sources
Nan Zhang0007d812017-11-07 10:57:05 -080053 Export_proto_headers *bool
Colin Cross0c461f12016-10-20 16:11:43 -070054 }
Dan Albertf563d252017-10-13 00:29:00 -070055
Inseob Kimc0907f12019-02-08 21:00:45 +090056 Sysprop struct {
57 // Whether platform owns this sysprop library.
58 Platform *bool
Inseob Kimb3f22ca2019-03-05 12:40:24 +090059 } `blueprint:"mutated"`
Inseob Kimc0907f12019-02-08 21:00:45 +090060
Nan Zhang0007d812017-11-07 10:57:05 -080061 Static_ndk_lib *bool
Jiyong Park7ed9de32018-10-15 22:25:07 +090062
Florian Mayer6dab96c2020-12-31 11:39:48 +000063 // Generate stubs to make this library accessible to APEXes.
Jiyong Park7ed9de32018-10-15 22:25:07 +090064 Stubs struct {
65 // Relative path to the symbol map. The symbol map provides the list of
66 // symbols that are exported for stubs variant of this library.
Colin Cross27b922f2019-03-04 22:35:41 -080067 Symbol_file *string `android:"path"`
Jiyong Park7ed9de32018-10-15 22:25:07 +090068
Jiyong Parkd4a3a132021-03-17 20:21:35 +090069 // List versions to generate stubs libs for. The version name "current" is always
70 // implicitly added.
Jiyong Park7ed9de32018-10-15 22:25:07 +090071 Versions []string
Alan Stokes73feba32022-11-14 12:21:24 +000072
73 // Whether to not require the implementation of the library to be installed if a
74 // client of the stubs is installed. Defaults to true; set to false if the
75 // implementation is made available by some other means, e.g. in a Microdroid
76 // virtual machine.
77 Implementation_installable *bool
Jiyong Park7ed9de32018-10-15 22:25:07 +090078 }
dimitryd95964a2018-11-07 13:43:34 +010079
80 // set the name of the output
81 Stem *string `android:"arch_variant"`
82
Colin Cross0fd6a412019-08-16 14:22:10 -070083 // set suffix of the name of the output
84 Suffix *string `android:"arch_variant"`
85
Hsin-Yi Chen8feb4132022-12-26 15:54:36 +080086 // Properties for ABI compatibility checker.
87 Header_abi_checker headerAbiCheckerProperties
88
Colin Cross0fd6a412019-08-16 14:22:10 -070089 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +090090 Vendor, Product struct {
Colin Cross0fd6a412019-08-16 14:22:10 -070091 // set suffix of the name of the output
92 Suffix *string `android:"arch_variant"`
Hsin-Yi Chen8feb4132022-12-26 15:54:36 +080093
94 Header_abi_checker headerAbiCheckerProperties
Jooyung Han85707de2023-12-01 14:21:13 +090095
96 // Disable stubs for vendor/product variants
97 // This is a workaround to keep `stubs` only for "core" variant (not product/vendor).
98 // It would be nice if we could put `stubs` into a `target: { core: {} }`
99 // block but it's not supported in soong yet. This could be removed/simplified once we have
100 // a better syntax.
101 No_stubs bool
Hsin-Yi Chen8feb4132022-12-26 15:54:36 +0800102 }
103
104 Platform struct {
105 Header_abi_checker headerAbiCheckerProperties
Colin Cross0fd6a412019-08-16 14:22:10 -0700106 }
107 }
108
dimitryd95964a2018-11-07 13:43:34 +0100109 // Names of modules to be overridden. Listed modules can only be other shared libraries
110 // (in Make or Soong).
111 // This does not completely prevent installation of the overridden libraries, but if both
112 // binaries would be installed by default (in PRODUCT_PACKAGES) the other library will be removed
113 // from PRODUCT_PACKAGES.
114 Overrides []string
Logan Chiene3d7a0d2019-01-17 00:18:02 +0800115
Pete Bentley803e1612019-08-06 22:19:59 +0100116 // 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
Colin Cross127bb8b2020-12-16 16:46:01 -0800119 // If this is an LLNDK library, properties to describe the LLNDK stubs. Will be copied from
120 // the module pointed to by llndk_stubs if it is set.
121 Llndk llndkLibraryProperties
Colin Cross5271fea2021-04-27 13:06:04 -0700122
123 // If this is a vendor public library, properties to describe the vendor public library stubs.
124 Vendor_public_library vendorPublicLibraryProperties
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
Chih-Hung Hsieh769a51c2021-09-17 17:18:39 -0700147 Tidy_disabled_srcs []string `android:"path,arch_variant"`
148
Chih-Hung Hsieh9db8a0c2022-02-17 12:54:45 -0800149 Tidy_timeout_srcs []string `android:"path,arch_variant"`
150
Evgenii Stepanov2080bfe2020-07-24 15:35:40 -0700151 Sanitized Sanitized `android:"arch_variant"`
152
Cole Fauste96c16a2024-06-13 14:51:14 -0700153 Cflags proptools.Configurable[[]string] `android:"arch_variant"`
Colin Crosse1bb5d02019-09-24 14:55:04 -0700154
Colin Cross6b8f4252021-07-22 11:39:44 -0700155 Enabled *bool `android:"arch_variant"`
156 Whole_static_libs []string `android:"arch_variant"`
157 Static_libs []string `android:"arch_variant"`
158 Shared_libs []string `android:"arch_variant"`
159 System_shared_libs []string `android:"arch_variant"`
Colin Crosse1bb5d02019-09-24 14:55:04 -0700160
161 Export_shared_lib_headers []string `android:"arch_variant"`
162 Export_static_lib_headers []string `android:"arch_variant"`
Jiyong Parka90ca002019-10-07 15:47:24 +0900163
164 Apex_available []string `android:"arch_variant"`
Colin Cross1bc94122021-10-28 13:25:54 -0700165
166 Installable *bool `android:"arch_variant"`
Colin Crosse1bb5d02019-09-24 14:55:04 -0700167}
168
Colin Crossa48ab5b2017-02-14 15:28:44 -0800169type LibraryMutatedProperties struct {
Colin Crossb916a382016-07-29 17:28:03 -0700170 // Build a static variant
171 BuildStatic bool `blueprint:"mutated"`
172 // Build a shared variant
173 BuildShared bool `blueprint:"mutated"`
174 // This variant is shared
175 VariantIsShared bool `blueprint:"mutated"`
176 // This variant is static
177 VariantIsStatic bool `blueprint:"mutated"`
Jiyong Park7ed9de32018-10-15 22:25:07 +0900178
179 // This variant is a stubs lib
180 BuildStubs bool `blueprint:"mutated"`
Jiyong Parkd4a3a132021-03-17 20:21:35 +0900181 // This variant is the latest version
182 IsLatestVersion bool `blueprint:"mutated"`
Jiyong Park7ed9de32018-10-15 22:25:07 +0900183 // Version of the stubs lib
184 StubsVersion string `blueprint:"mutated"`
Colin Crossd1f898e2020-08-18 18:35:15 -0700185 // List of all stubs versions associated with an implementation lib
186 AllStubsVersions []string `blueprint:"mutated"`
Colin Crossb916a382016-07-29 17:28:03 -0700187}
188
189type FlagExporterProperties struct {
190 // list of directories relative to the Blueprints file that will
Dan Willemsen273af7f2016-11-03 15:53:42 -0700191 // be added to the include path (using -I) for this module and any module that links
Colin Cross5d195602017-10-17 16:15:50 -0700192 // against this module. Directories listed in export_include_dirs do not need to be
193 // listed in local_include_dirs.
Aleks Todorovc9becde2024-06-10 12:51:53 +0100194 Export_include_dirs proptools.Configurable[[]string] `android:"arch_variant,variant_prepend"`
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700195
Jiyong Park73c54ee2019-10-22 20:31:18 +0900196 // list of directories that will be added to the system include path
197 // using -isystem for this module and any module that links against this module.
Colin Cross0ed579e2021-06-29 00:51:12 +0000198 Export_system_include_dirs []string `android:"arch_variant,variant_prepend"`
Jiyong Park73c54ee2019-10-22 20:31:18 +0900199
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700200 Target struct {
Justin Yun63e9ec72020-10-29 16:49:43 +0900201 Vendor, Product struct {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700202 // list of exported include directories, like
Justin Yun63e9ec72020-10-29 16:49:43 +0900203 // export_include_dirs, that will be applied to
204 // vendor or product variant of this library.
205 // This will overwrite any other declarations.
Steven Morelandb21df8f2018-01-05 14:42:54 -0800206 Override_export_include_dirs []string
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700207 }
208 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700209}
210
211func init() {
Paul Duffin6c26dc72019-12-19 15:02:40 +0000212 RegisterLibraryBuildComponents(android.InitRegistrationContext)
213}
214
215func RegisterLibraryBuildComponents(ctx android.RegistrationContext) {
216 ctx.RegisterModuleType("cc_library_static", LibraryStaticFactory)
217 ctx.RegisterModuleType("cc_library_shared", LibrarySharedFactory)
218 ctx.RegisterModuleType("cc_library", LibraryFactory)
219 ctx.RegisterModuleType("cc_library_host_static", LibraryHostStaticFactory)
220 ctx.RegisterModuleType("cc_library_host_shared", LibraryHostSharedFactory)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700221}
222
Patrice Arruda83c89e02019-03-25 15:32:39 -0700223// cc_library creates both static and/or shared libraries for a device and/or
224// host. By default, a cc_library has a single variant that targets the device.
225// Specifying `host_supported: true` also creates a library that targets the
226// host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700227func LibraryFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800228 module, _ := NewLibrary(android.HostAndDeviceSupported)
Paul Duffina0843f62019-12-13 19:50:38 +0000229 // Can be used as both a static and a shared library.
230 module.sdkMemberTypes = []android.SdkMemberType{
231 sharedLibrarySdkMemberType,
232 staticLibrarySdkMemberType,
Paul Duffin9b76c0b2020-03-12 10:24:35 +0000233 staticAndSharedLibrarySdkMemberType,
Paul Duffina0843f62019-12-13 19:50:38 +0000234 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700235 return module.Init()
236}
237
Patrice Arruda83c89e02019-03-25 15:32:39 -0700238// cc_library_static creates a static library for a device and/or host binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700239func LibraryStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800240 module, library := NewLibrary(android.HostAndDeviceSupported)
241 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000242 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700243 return module.Init()
244}
245
Patrice Arruda83c89e02019-03-25 15:32:39 -0700246// cc_library_shared creates a shared library for a device and/or host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700247func LibrarySharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800248 module, library := NewLibrary(android.HostAndDeviceSupported)
249 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000250 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700251 return module.Init()
252}
253
Patrice Arruda83c89e02019-03-25 15:32:39 -0700254// cc_library_host_static creates a static library that is linkable to a host
255// binary.
Steven Morelandf9e62162017-11-02 17:00:50 -0700256func LibraryHostStaticFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800257 module, library := NewLibrary(android.HostSupported)
258 library.BuildOnlyStatic()
Paul Duffina0843f62019-12-13 19:50:38 +0000259 module.sdkMemberTypes = []android.SdkMemberType{staticLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700260 return module.Init()
261}
262
Patrice Arruda83c89e02019-03-25 15:32:39 -0700263// cc_library_host_shared creates a shared library that is usable on a host.
Steven Morelandf9e62162017-11-02 17:00:50 -0700264func LibraryHostSharedFactory() android.Module {
Colin Crossab3b7322016-12-09 14:46:15 -0800265 module, library := NewLibrary(android.HostSupported)
266 library.BuildOnlyShared()
Paul Duffina0843f62019-12-13 19:50:38 +0000267 module.sdkMemberTypes = []android.SdkMemberType{sharedLibrarySdkMemberType}
Colin Cross4d9c2d12016-07-29 12:48:20 -0700268 return module.Init()
269}
270
Chris Parsons3c27ca32020-11-20 12:42:07 -0500271// flagExporter is a separated portion of libraryDecorator pertaining to exported
272// include paths and flags. Keeping this dependency-related information separate
273// from the rest of library information is helpful in keeping data more structured
274// and explicit.
Colin Cross4d9c2d12016-07-29 12:48:20 -0700275type flagExporter struct {
276 Properties FlagExporterProperties
277
Ivan Lozano0a468a42024-05-13 21:03:34 -0400278 dirs android.Paths // Include directories to be included with -I
279 systemDirs android.Paths // System include directories to be included with -isystem
280 flags []string // Exported raw flags.
281 deps android.Paths
282 headers android.Paths
283 rustRlibDeps []RustRlibDep
Colin Cross4d9c2d12016-07-29 12:48:20 -0700284}
285
Chris Parsons3c27ca32020-11-20 12:42:07 -0500286// exportedIncludes returns the effective include paths for this module and
287// any module that links against this module. This is obtained from
288// the export_include_dirs property in the appropriate target stanza.
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700289func (f *flagExporter) exportedIncludes(ctx ModuleContext) android.Paths {
Justin Yun6977e8a2020-10-29 18:24:11 +0900290 if ctx.inVendor() && f.Properties.Target.Vendor.Override_export_include_dirs != nil {
Steven Morelandb21df8f2018-01-05 14:42:54 -0800291 return android.PathsForModuleSrc(ctx, f.Properties.Target.Vendor.Override_export_include_dirs)
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700292 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900293 if ctx.inProduct() && f.Properties.Target.Product.Override_export_include_dirs != nil {
294 return android.PathsForModuleSrc(ctx, f.Properties.Target.Product.Override_export_include_dirs)
295 }
Aleks Todorovc9becde2024-06-10 12:51:53 +0100296 return android.PathsForModuleSrc(ctx, f.Properties.Export_include_dirs.GetOrDefault(ctx, nil))
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700297}
298
Hsin-Yi Chen5f228b02024-04-02 12:38:47 +0800299func (f *flagExporter) exportedSystemIncludes(ctx ModuleContext) android.Paths {
300 return android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)
301}
302
Chris Parsons3c27ca32020-11-20 12:42:07 -0500303// exportIncludes registers the include directories and system include directories to be exported
304// transitively to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900305func (f *flagExporter) exportIncludes(ctx ModuleContext) {
Jiyong Park74955042019-10-22 20:19:51 +0900306 f.dirs = append(f.dirs, f.exportedIncludes(ctx)...)
Jiyong Park73c54ee2019-10-22 20:31:18 +0900307 f.systemDirs = append(f.systemDirs, android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700308}
309
Chris Parsons3c27ca32020-11-20 12:42:07 -0500310// exportIncludesAsSystem registers the include directories and system include directories to be
311// exported transitively both as system include directories to modules depending on this module.
Inseob Kim69378442019-06-03 19:10:47 +0900312func (f *flagExporter) exportIncludesAsSystem(ctx ModuleContext) {
Jiyong Park73c54ee2019-10-22 20:31:18 +0900313 // all dirs are force exported as system
Jiyong Park74955042019-10-22 20:19:51 +0900314 f.systemDirs = append(f.systemDirs, f.exportedIncludes(ctx)...)
Jiyong Park73c54ee2019-10-22 20:31:18 +0900315 f.systemDirs = append(f.systemDirs, android.PathsForModuleSrc(ctx, f.Properties.Export_system_include_dirs)...)
Inseob Kim69378442019-06-03 19:10:47 +0900316}
317
Chris Parsons3c27ca32020-11-20 12:42:07 -0500318// reexportDirs registers the given directories as include directories to be exported transitively
319// to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900320func (f *flagExporter) reexportDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900321 f.dirs = append(f.dirs, dirs...)
322}
323
Chris Parsons3c27ca32020-11-20 12:42:07 -0500324// reexportSystemDirs registers the given directories as system include directories
325// to be exported transitively to modules depending on this module.
Jiyong Park74955042019-10-22 20:19:51 +0900326func (f *flagExporter) reexportSystemDirs(dirs ...android.Path) {
Inseob Kim69378442019-06-03 19:10:47 +0900327 f.systemDirs = append(f.systemDirs, dirs...)
328}
329
Chris Parsons3c27ca32020-11-20 12:42:07 -0500330// reexportFlags registers the flags to be exported transitively to modules depending on this
331// module.
Inseob Kim69378442019-06-03 19:10:47 +0900332func (f *flagExporter) reexportFlags(flags ...string) {
Jaewoong Jung3aff5782020-02-11 07:54:35 -0800333 if android.PrefixInList(flags, "-I") || android.PrefixInList(flags, "-isystem") {
334 panic(fmt.Errorf("Exporting invalid flag %q: "+
335 "use reexportDirs or reexportSystemDirs to export directories", flag))
Inseob Kim69378442019-06-03 19:10:47 +0900336 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700337 f.flags = append(f.flags, flags...)
338}
339
Inseob Kim69378442019-06-03 19:10:47 +0900340func (f *flagExporter) reexportDeps(deps ...android.Path) {
341 f.deps = append(f.deps, deps...)
342}
343
Ivan Lozano0a468a42024-05-13 21:03:34 -0400344func (f *flagExporter) reexportRustStaticDeps(deps ...RustRlibDep) {
345 f.rustRlibDeps = append(f.rustRlibDeps, deps...)
346}
347
Inseob Kimd110f872019-12-06 13:15:38 +0900348// addExportedGeneratedHeaders does nothing but collects generated header files.
349// This can be differ to exportedDeps which may contain phony files to minimize ninja.
350func (f *flagExporter) addExportedGeneratedHeaders(headers ...android.Path) {
351 f.headers = append(f.headers, headers...)
352}
353
Colin Cross0de8a1e2020-09-18 14:15:30 -0700354func (f *flagExporter) setProvider(ctx android.ModuleContext) {
Colin Cross40213022023-12-13 15:19:49 -0800355 android.SetProvider(ctx, FlagExporterInfoProvider, FlagExporterInfo{
Chris Parsonsf60ecf02021-04-27 14:48:30 -0400356 // Comes from Export_include_dirs property, and those of exported transitive deps
357 IncludeDirs: android.FirstUniquePaths(f.dirs),
358 // Comes from Export_system_include_dirs property, and those of exported transitive deps
Colin Crossc82e6e22021-04-20 18:21:50 -0700359 SystemIncludeDirs: android.FirstUniquePaths(f.systemDirs),
Chris Parsonsf60ecf02021-04-27 14:48:30 -0400360 // Used in very few places as a one-off way of adding extra defines.
361 Flags: f.flags,
362 // Used sparingly, for extra files that need to be explicitly exported to dependers,
363 // or for phony files to minimize ninja.
364 Deps: f.deps,
Ivan Lozano0a468a42024-05-13 21:03:34 -0400365 // Used for exporting rlib deps of static libraries to dependents.
366 RustRlibDeps: f.rustRlibDeps,
Chris Parsonsf60ecf02021-04-27 14:48:30 -0400367 // For exported generated headers, such as exported aidl headers, proto headers, or
368 // sysprop headers.
369 GeneratedHeaders: f.headers,
Colin Cross0de8a1e2020-09-18 14:15:30 -0700370 })
Inseob Kim69378442019-06-03 19:10:47 +0900371}
372
Colin Crossb916a382016-07-29 17:28:03 -0700373// libraryDecorator wraps baseCompiler, baseLinker and baseInstaller to provide library-specific
374// functionality: static vs. shared linkage, reusing object files for shared libraries
375type libraryDecorator struct {
Colin Crossa48ab5b2017-02-14 15:28:44 -0800376 Properties LibraryProperties
Colin Crosse1bb5d02019-09-24 14:55:04 -0700377 StaticProperties StaticProperties
378 SharedProperties SharedProperties
Colin Crossa48ab5b2017-02-14 15:28:44 -0800379 MutatedProperties LibraryMutatedProperties
Colin Cross4d9c2d12016-07-29 12:48:20 -0700380
381 // For reusing static library objects for shared library
Inseob Kim69378442019-06-03 19:10:47 +0900382 reuseObjects Objects
Colin Cross10d22312017-05-03 11:01:58 -0700383
Colin Cross26c34ed2016-09-30 17:10:16 -0700384 // table-of-contents file to optimize out relinking when possible
385 tocFile android.OptionalPath
Colin Cross4d9c2d12016-07-29 12:48:20 -0700386
Colin Cross4d9c2d12016-07-29 12:48:20 -0700387 flagExporter
Liz Kammerb6a55bf2021-04-12 15:42:51 -0400388 flagExporterInfo *FlagExporterInfo
389 stripper Stripper
Colin Cross4d9c2d12016-07-29 12:48:20 -0700390
Colin Cross4d9c2d12016-07-29 12:48:20 -0700391 // For whole_static_libs
Colin Crossa2bcf2c2022-02-11 13:11:55 -0800392 objects Objects
393 wholeStaticLibsFromPrebuilts android.Paths
Colin Cross4d9c2d12016-07-29 12:48:20 -0700394
395 // Uses the module's name if empty, but can be overridden. Does not include
396 // shlib suffix.
397 libName string
Colin Crossb916a382016-07-29 17:28:03 -0700398
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800399 sabi *sabi
400
Dan Willemsen581341d2017-02-09 16:16:31 -0800401 // Output archive of gcno coverage information files
402 coverageOutputFile android.OptionalPath
403
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800404 // Source Abi Diff
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +0800405 sAbiDiff android.Paths
Mu-Le Lee0a9005e2022-07-05 09:49:50 +0000406
Colin Cross0875c522017-11-28 17:34:01 -0800407 // Location of the static library in the sysroot. Empty if the library is
408 // not included in the NDK.
409 ndkSysrootPath android.Path
410
Colin Crossb60190a2018-09-04 16:28:17 -0700411 // Location of the linked, unstripped library for shared libraries
412 unstrippedOutputFile android.Path
Wei Li5f5d2712023-12-11 15:40:29 -0800413 // Location of the linked, stripped library for shared libraries, strip: "all"
414 strippedAllOutputFile android.Path
Colin Crossb60190a2018-09-04 16:28:17 -0700415
Dan Willemsen569edc52018-11-19 09:33:29 -0800416 // Location of the file that should be copied to dist dir when requested
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000417 distFile android.Path
Dan Willemsen569edc52018-11-19 09:33:29 -0800418
Colin Cross8e21aa52020-09-28 18:28:02 -0700419 versionScriptPath android.OptionalPath
Jiyong Park7ed9de32018-10-15 22:25:07 +0900420
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800421 postInstallCmds []string
Jiyong Parkf1194352019-02-25 11:05:47 +0900422
Colin Cross5ec407b2020-09-30 11:41:33 -0700423 skipAPIDefine bool
424
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100425 // Decorated interfaces
Colin Crossb916a382016-07-29 17:28:03 -0700426 *baseCompiler
427 *baseLinker
428 *baseInstaller
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900429
sophiez4c4f8032021-08-16 22:54:00 -0700430 apiListCoverageXmlPath android.ModuleOutPath
Inseob Kimeda2e9c2020-03-03 22:06:32 +0900431}
432
Chris Parsons3c27ca32020-11-20 12:42:07 -0500433// linkerProps returns the list of properties structs relevant for this library. (For example, if
434// the library is cc_shared_library, then static-library properties are omitted.)
Colin Crossb916a382016-07-29 17:28:03 -0700435func (library *libraryDecorator) linkerProps() []interface{} {
436 var props []interface{}
437 props = append(props, library.baseLinker.linkerProps()...)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700438 props = append(props,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700439 &library.Properties,
Colin Crossa48ab5b2017-02-14 15:28:44 -0800440 &library.MutatedProperties,
Colin Cross4d9c2d12016-07-29 12:48:20 -0700441 &library.flagExporter.Properties,
Colin Cross22f37952018-09-05 10:43:13 -0700442 &library.stripper.StripProperties)
Colin Crosse1bb5d02019-09-24 14:55:04 -0700443
444 if library.MutatedProperties.BuildShared {
445 props = append(props, &library.SharedProperties)
446 }
447 if library.MutatedProperties.BuildStatic {
448 props = append(props, &library.StaticProperties)
449 }
450
451 return props
Colin Cross4d9c2d12016-07-29 12:48:20 -0700452}
453
Chris Parsons3c27ca32020-11-20 12:42:07 -0500454// linkerFlags takes a Flags struct and augments it to contain linker flags that are defined by this
455// library, or that are implied by attributes of this library (such as whether this library is a
456// shared library).
Colin Crossb916a382016-07-29 17:28:03 -0700457func (library *libraryDecorator) linkerFlags(ctx ModuleContext, flags Flags) Flags {
Colin Cross42742b82016-08-01 13:20:05 -0700458 flags = library.baseLinker.linkerFlags(ctx, flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700459
Colin Crossb916a382016-07-29 17:28:03 -0700460 // MinGW spits out warnings about -fPIC even for -fpie?!) being ignored because
461 // all code is position independent, and then those warnings get promoted to
462 // errors.
Colin Cross3edeee12017-04-04 12:59:48 -0700463 if !ctx.Windows() {
Colin Cross4af21ed2019-11-04 09:37:55 -0800464 flags.Global.CFlags = append(flags.Global.CFlags, "-fPIC")
Colin Crossb916a382016-07-29 17:28:03 -0700465 }
466
467 if library.static() {
Cole Fauste96c16a2024-06-13 14:51:14 -0700468 flags.Local.CFlags = append(flags.Local.CFlags, library.StaticProperties.Static.Cflags.GetOrDefault(ctx, nil)...)
Colin Crossa48ab5b2017-02-14 15:28:44 -0800469 } else if library.shared() {
Cole Fauste96c16a2024-06-13 14:51:14 -0700470 flags.Local.CFlags = append(flags.Local.CFlags, library.SharedProperties.Shared.Cflags.GetOrDefault(ctx, nil)...)
Colin Crossb916a382016-07-29 17:28:03 -0700471 }
472
Colin Crossa48ab5b2017-02-14 15:28:44 -0800473 if library.shared() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700474 libName := library.getLibName(ctx)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700475 var f []string
Dan Willemsen01a405a2016-06-13 17:19:03 -0700476 if ctx.toolchain().Bionic() {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700477 f = append(f,
478 "-nostdlib",
479 "-Wl,--gc-sections",
480 )
481 }
482
483 if ctx.Darwin() {
484 f = append(f,
485 "-dynamiclib",
Colin Cross4d9c2d12016-07-29 12:48:20 -0700486 "-install_name @rpath/"+libName+flags.Toolchain.ShlibSuffix(),
487 )
Colin Cross7863cf52016-10-20 10:47:21 -0700488 if ctx.Arch().ArchType == android.X86 {
489 f = append(f,
490 "-read_only_relocs suppress",
491 )
492 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700493 } else {
Josh Gao75a50a22019-06-07 17:58:59 -0700494 f = append(f, "-shared")
495 if !ctx.Windows() {
496 f = append(f, "-Wl,-soname,"+libName+flags.Toolchain.ShlibSuffix())
497 }
Colin Cross4d9c2d12016-07-29 12:48:20 -0700498 }
499
Colin Cross4af21ed2019-11-04 09:37:55 -0800500 flags.Global.LdFlags = append(flags.Global.LdFlags, f...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700501 }
502
503 return flags
504}
505
Chris Parsons3c27ca32020-11-20 12:42:07 -0500506// compilerFlags takes a Flags and augments it to contain compile flags from global values,
507// per-target values, module type values, per-module Blueprints properties, extra flags from
508// `flags`, and generated sources from `deps`.
Colin Crossf18e1102017-11-16 14:33:08 -0800509func (library *libraryDecorator) compilerFlags(ctx ModuleContext, flags Flags, deps PathDeps) Flags {
Dan Willemsen4416e5d2017-04-06 12:43:22 -0700510 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700511 if len(exportIncludeDirs) > 0 {
Colin Crossdad8c952017-04-26 14:55:27 -0700512 f := includeDirsToFlags(exportIncludeDirs)
Colin Cross4af21ed2019-11-04 09:37:55 -0800513 flags.Local.CommonFlags = append(flags.Local.CommonFlags, f)
514 flags.Local.YasmFlags = append(flags.Local.YasmFlags, f)
Dan Willemsen273af7f2016-11-03 15:53:42 -0700515 }
516
Jiyong Park7ed9de32018-10-15 22:25:07 +0900517 flags = library.baseCompiler.compilerFlags(ctx, flags, deps)
Colin Cross127bb8b2020-12-16 16:46:01 -0800518 if ctx.IsLlndk() {
519 // LLNDK libraries ignore most of the properties on the cc_library and use the
520 // LLNDK-specific properties instead.
521 // Wipe all the module-local properties, leaving only the global properties.
522 flags.Local = LocalOrGlobalFlags{}
523 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900524 if library.buildStubs() {
Jiyong Park64379952018-12-13 18:37:29 +0900525 // Remove -include <file> when compiling stubs. Otherwise, the force included
526 // headers might cause conflicting types error with the symbols in the
527 // generated stubs source code. e.g.
528 // double acos(double); // in header
529 // void acos() {} // in the generated source code
530 removeInclude := func(flags []string) []string {
531 ret := flags[:0]
532 for _, f := range flags {
533 if strings.HasPrefix(f, "-include ") {
534 continue
535 }
536 ret = append(ret, f)
537 }
538 return ret
539 }
Colin Cross4af21ed2019-11-04 09:37:55 -0800540 flags.Local.CommonFlags = removeInclude(flags.Local.CommonFlags)
541 flags.Local.CFlags = removeInclude(flags.Local.CFlags)
Jiyong Park64379952018-12-13 18:37:29 +0900542
Jiyong Park7ed9de32018-10-15 22:25:07 +0900543 flags = addStubLibraryCompilerFlags(flags)
544 }
545 return flags
Dan Willemsen273af7f2016-11-03 15:53:42 -0700546}
547
Hsin-Yi Chen8feb4132022-12-26 15:54:36 +0800548func (library *libraryDecorator) getHeaderAbiCheckerProperties(ctx android.BaseModuleContext) headerAbiCheckerProperties {
549 m := ctx.Module().(*Module)
550 variantProps := &library.Properties.Target.Platform.Header_abi_checker
551 if m.InVendor() {
552 variantProps = &library.Properties.Target.Vendor.Header_abi_checker
553 } else if m.InProduct() {
554 variantProps = &library.Properties.Target.Product.Header_abi_checker
555 }
556 props := library.Properties.Header_abi_checker
557 err := proptools.AppendProperties(&props, variantProps, nil)
558 if err != nil {
559 ctx.ModuleErrorf("Cannot merge headerAbiCheckerProperties: %s", err.Error())
560 }
561 return props
Logan Chien41eabe62019-04-10 13:33:58 +0800562}
563
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700564func (library *libraryDecorator) compile(ctx ModuleContext, flags Flags, deps PathDeps) Objects {
Colin Cross127bb8b2020-12-16 16:46:01 -0800565 if ctx.IsLlndk() {
Jooyung Han33eb6152024-03-11 15:46:48 +0900566 vendorApiLevel := ctx.Config().VendorApiLevel()
567 if vendorApiLevel == "" {
568 // TODO(b/321892570): Some tests relying on old fixtures which
569 // doesn't set vendorApiLevel. Needs to fix them.
570 vendorApiLevel = ctx.Config().PlatformSdkVersion().String()
571 }
Colin Cross127bb8b2020-12-16 16:46:01 -0800572 // This is the vendor variant of an LLNDK library, build the LLNDK stubs.
Dan Albertf1d14c72020-07-30 14:32:55 -0700573 nativeAbiResult := parseNativeAbiDefinition(ctx,
574 String(library.Properties.Llndk.Symbol_file),
Jooyung Han33eb6152024-03-11 15:46:48 +0900575 android.ApiLevelOrPanic(ctx, vendorApiLevel), "--llndk")
Dan Albertf1d14c72020-07-30 14:32:55 -0700576 objs := compileStubLibrary(ctx, flags, nativeAbiResult.stubSrc)
Colin Cross127bb8b2020-12-16 16:46:01 -0800577 if !Bool(library.Properties.Llndk.Unversioned) {
Dan Albertf1d14c72020-07-30 14:32:55 -0700578 library.versionScriptPath = android.OptionalPathForPath(
579 nativeAbiResult.versionScript)
Colin Cross127bb8b2020-12-16 16:46:01 -0800580 }
581 return objs
582 }
Colin Cross5271fea2021-04-27 13:06:04 -0700583 if ctx.IsVendorPublicLibrary() {
Dan Albertf1d14c72020-07-30 14:32:55 -0700584 nativeAbiResult := parseNativeAbiDefinition(ctx,
585 String(library.Properties.Vendor_public_library.Symbol_file),
586 android.FutureApiLevel, "")
587 objs := compileStubLibrary(ctx, flags, nativeAbiResult.stubSrc)
Colin Cross5271fea2021-04-27 13:06:04 -0700588 if !Bool(library.Properties.Vendor_public_library.Unversioned) {
Dan Albertf1d14c72020-07-30 14:32:55 -0700589 library.versionScriptPath = android.OptionalPathForPath(nativeAbiResult.versionScript)
Colin Cross5271fea2021-04-27 13:06:04 -0700590 }
591 return objs
592 }
Jiyong Park7ed9de32018-10-15 22:25:07 +0900593 if library.buildStubs() {
Jiyong Parka4175572021-02-04 21:05:47 +0900594 symbolFile := String(library.Properties.Stubs.Symbol_file)
595 if symbolFile != "" && !strings.HasSuffix(symbolFile, ".map.txt") {
596 ctx.PropertyErrorf("symbol_file", "%q doesn't have .map.txt suffix", symbolFile)
597 return Objects{}
598 }
Jiyong Park85cc35a2022-07-17 11:30:47 +0900599 // b/239274367 --apex and --systemapi filters symbols tagged with # apex and #
600 // systemapi, respectively. The former is for symbols defined in platform libraries
601 // and the latter is for symbols defined in APEXes.
Spandan Das934c97d2023-01-18 23:54:13 +0000602 // A single library can contain either # apex or # systemapi, but not both.
603 // The stub generator (ndkstubgen) is additive, so passing _both_ of these to it should be a no-op.
604 // However, having this distinction helps guard accidental
605 // promotion or demotion of API and also helps the API review process b/191371676
Jiyong Park85cc35a2022-07-17 11:30:47 +0900606 var flag string
607 if ctx.Module().(android.ApexModule).NotInPlatform() {
608 flag = "--apex"
609 } else {
Jiyong Parkffea9b32022-07-17 17:32:56 +0900610 flag = "--systemapi"
Jiyong Park85cc35a2022-07-17 11:30:47 +0900611 }
Jiyong Parkaa27c082022-09-26 21:16:09 +0900612 // b/184712170, unless the lib is an NDK library, exclude all public symbols from
613 // the stub so that it is mandated that all symbols are explicitly marked with
614 // either apex or systemapi.
615 if !ctx.Module().(*Module).IsNdk(ctx.Config()) {
616 flag = flag + " --no-ndk"
617 }
Dan Albertf1d14c72020-07-30 14:32:55 -0700618 nativeAbiResult := parseNativeAbiDefinition(ctx, symbolFile,
Jiyong Park85cc35a2022-07-17 11:30:47 +0900619 android.ApiLevelOrPanic(ctx, library.MutatedProperties.StubsVersion), flag)
Dan Albertf1d14c72020-07-30 14:32:55 -0700620 objs := compileStubLibrary(ctx, flags, nativeAbiResult.stubSrc)
621 library.versionScriptPath = android.OptionalPathForPath(
622 nativeAbiResult.versionScript)
sophiez4c4f8032021-08-16 22:54:00 -0700623
624 // Parse symbol file to get API list for coverage
Colin Crossceaa5322021-09-28 16:37:50 -0700625 if library.stubsVersion() == "current" && ctx.PrimaryArch() && !ctx.inRecovery() && !ctx.inProduct() && !ctx.inVendor() {
sophiez4c4f8032021-08-16 22:54:00 -0700626 library.apiListCoverageXmlPath = parseSymbolFileForAPICoverage(ctx, symbolFile)
627 }
628
Jiyong Park7ed9de32018-10-15 22:25:07 +0900629 return objs
630 }
631
Colin Cross5950f382016-12-13 12:50:57 -0800632 if !library.buildShared() && !library.buildStatic() {
633 if len(library.baseCompiler.Properties.Srcs) > 0 {
634 ctx.PropertyErrorf("srcs", "cc_library_headers must not have any srcs")
635 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700636 if len(library.StaticProperties.Static.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800637 ctx.PropertyErrorf("static.srcs", "cc_library_headers must not have any srcs")
638 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700639 if len(library.SharedProperties.Shared.Srcs) > 0 {
Colin Cross5950f382016-12-13 12:50:57 -0800640 ctx.PropertyErrorf("shared.srcs", "cc_library_headers must not have any srcs")
641 }
642 return Objects{}
643 }
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800644 if library.sabi.shouldCreateSourceAbiDump() {
Hsin-Yi Chenaf369882024-03-29 20:10:36 +0800645 dirs := library.exportedIncludeDirsForAbiCheck(ctx)
646 flags.SAbiFlags = make([]string, 0, len(dirs))
647 for _, dir := range dirs {
648 flags.SAbiFlags = append(flags.SAbiFlags, "-I"+dir)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800649 }
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800650 totalLength := len(library.baseCompiler.Properties.Srcs) + len(deps.GeneratedSources) +
Colin Crosse1bb5d02019-09-24 14:55:04 -0700651 len(library.SharedProperties.Shared.Srcs) + len(library.StaticProperties.Static.Srcs)
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800652 if totalLength > 0 {
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -0800653 flags.SAbiDump = true
654 }
655 }
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700656 objs := library.baseCompiler.compile(ctx, flags, deps)
657 library.reuseObjects = objs
Colin Cross2f336352016-10-26 10:03:47 -0700658 buildFlags := flagsToBuilderFlags(flags)
Colin Crossb916a382016-07-29 17:28:03 -0700659
Colin Cross4d9c2d12016-07-29 12:48:20 -0700660 if library.static() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700661 srcs := android.PathsForModuleSrc(ctx, library.StaticProperties.Static.Srcs)
Chih-Hung Hsieh769a51c2021-09-17 17:18:39 -0700662 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceStaticLibrary, srcs,
663 android.PathsForModuleSrc(ctx, library.StaticProperties.Static.Tidy_disabled_srcs),
Chih-Hung Hsieh9db8a0c2022-02-17 12:54:45 -0800664 android.PathsForModuleSrc(ctx, library.StaticProperties.Static.Tidy_timeout_srcs),
Chih-Hung Hsieh769a51c2021-09-17 17:18:39 -0700665 library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossa48ab5b2017-02-14 15:28:44 -0800666 } else if library.shared() {
Colin Crosse1bb5d02019-09-24 14:55:04 -0700667 srcs := android.PathsForModuleSrc(ctx, library.SharedProperties.Shared.Srcs)
Chih-Hung Hsieh769a51c2021-09-17 17:18:39 -0700668 objs = objs.Append(compileObjs(ctx, buildFlags, android.DeviceSharedLibrary, srcs,
669 android.PathsForModuleSrc(ctx, library.SharedProperties.Shared.Tidy_disabled_srcs),
Chih-Hung Hsieh9db8a0c2022-02-17 12:54:45 -0800670 android.PathsForModuleSrc(ctx, library.SharedProperties.Shared.Tidy_timeout_srcs),
Chih-Hung Hsieh769a51c2021-09-17 17:18:39 -0700671 library.baseCompiler.pathDeps, library.baseCompiler.cFlagsDeps))
Colin Crossb916a382016-07-29 17:28:03 -0700672 }
673
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700674 return objs
Colin Crossb916a382016-07-29 17:28:03 -0700675}
676
677type libraryInterface interface {
Colin Cross3572cf72020-10-01 15:58:11 -0700678 versionedInterface
679
Colin Crossb916a382016-07-29 17:28:03 -0700680 static() bool
Inseob Kimae553032019-05-14 18:52:49 +0900681 shared() bool
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700682 objs() Objects
Colin Cross0de8a1e2020-09-18 14:15:30 -0700683 reuseObjs() Objects
Colin Cross26c34ed2016-09-30 17:10:16 -0700684 toc() android.OptionalPath
Colin Crossb916a382016-07-29 17:28:03 -0700685
686 // Returns true if the build options for the module have selected a static or shared build
687 buildStatic() bool
688 buildShared() bool
689
690 // Sets whether a specific variant is static or shared
Colin Crossa48ab5b2017-02-14 15:28:44 -0800691 setStatic()
692 setShared()
Logan Chien41eabe62019-04-10 13:33:58 +0800693
Hsin-Yi Chen8feb4132022-12-26 15:54:36 +0800694 // Gets the ABI properties for vendor, product, or platform variant
695 getHeaderAbiCheckerProperties(ctx android.BaseModuleContext) headerAbiCheckerProperties
Yo Chiang2bbadfa2020-12-14 11:42:16 +0800696
Logan Chien41eabe62019-04-10 13:33:58 +0800697 // Write LOCAL_ADDITIONAL_DEPENDENCIES for ABI diff
698 androidMkWriteAdditionalDependenciesForSourceAbiDiff(w io.Writer)
Jiyong Parka90ca002019-10-07 15:47:24 +0900699
700 availableFor(string) bool
Colin Crossceaa5322021-09-28 16:37:50 -0700701
702 getAPIListCoverageXMLPath() android.ModuleOutPath
Colin Cross1bc94122021-10-28 13:25:54 -0700703
704 installable() *bool
Colin Crossb916a382016-07-29 17:28:03 -0700705}
706
Colin Crossc88c2722020-09-28 17:32:47 -0700707type versionedInterface interface {
708 buildStubs() bool
Jiyong Parkd4a3a132021-03-17 20:21:35 +0900709 setBuildStubs(isLatest bool)
Colin Crossc88c2722020-09-28 17:32:47 -0700710 hasStubsVariants() bool
Alan Stokes73feba32022-11-14 12:21:24 +0000711 isStubsImplementationRequired() bool
Colin Crossc88c2722020-09-28 17:32:47 -0700712 setStubsVersion(string)
713 stubsVersion() string
714
Colin Crossadd04a82024-05-22 09:57:59 -0700715 stubsVersions(ctx android.BaseModuleContext) []string
Colin Crossc88c2722020-09-28 17:32:47 -0700716 setAllStubsVersions([]string)
717 allStubsVersions() []string
Colin Cross0477b422020-10-13 18:43:54 -0700718
719 implementationModuleName(name string) string
Colin Cross127bb8b2020-12-16 16:46:01 -0800720 hasLLNDKStubs() bool
Colin Cross1f3f1302021-04-26 18:37:44 -0700721 hasLLNDKHeaders() bool
Colin Cross5271fea2021-04-27 13:06:04 -0700722 hasVendorPublicLibrary() bool
Colin Crossc88c2722020-09-28 17:32:47 -0700723}
724
725var _ libraryInterface = (*libraryDecorator)(nil)
726var _ versionedInterface = (*libraryDecorator)(nil)
727
Justin Yun6977e8a2020-10-29 18:24:11 +0900728func (library *libraryDecorator) getLibNameHelper(baseModuleName string, inVendor bool, inProduct bool) string {
Colin Crossb916a382016-07-29 17:28:03 -0700729 name := library.libName
730 if name == "" {
dimitryd95964a2018-11-07 13:43:34 +0100731 name = String(library.Properties.Stem)
732 if name == "" {
Jooyung Han0302a842019-10-30 18:43:49 +0900733 name = baseModuleName
dimitryd95964a2018-11-07 13:43:34 +0100734 }
Colin Crossb916a382016-07-29 17:28:03 -0700735 }
736
Colin Cross0fd6a412019-08-16 14:22:10 -0700737 suffix := ""
Justin Yun6977e8a2020-10-29 18:24:11 +0900738 if inVendor {
Colin Cross0fd6a412019-08-16 14:22:10 -0700739 suffix = String(library.Properties.Target.Vendor.Suffix)
Justin Yun6977e8a2020-10-29 18:24:11 +0900740 } else if inProduct {
741 suffix = String(library.Properties.Target.Product.Suffix)
Colin Cross0fd6a412019-08-16 14:22:10 -0700742 }
743 if suffix == "" {
744 suffix = String(library.Properties.Suffix)
745 }
746
Jooyung Han0302a842019-10-30 18:43:49 +0900747 return name + suffix
748}
749
Chris Parsons3c27ca32020-11-20 12:42:07 -0500750// getLibName returns the actual canonical name of the library (the name which
751// should be passed to the linker via linker flags).
Jooyung Han0302a842019-10-30 18:43:49 +0900752func (library *libraryDecorator) getLibName(ctx BaseModuleContext) string {
Justin Yun6977e8a2020-10-29 18:24:11 +0900753 name := library.getLibNameHelper(ctx.baseModuleName(), ctx.inVendor(), ctx.inProduct())
Colin Cross0fd6a412019-08-16 14:22:10 -0700754
Colin Crossb916a382016-07-29 17:28:03 -0700755 if ctx.Host() && Bool(library.Properties.Unique_host_soname) {
756 if !strings.HasSuffix(name, "-host") {
757 name = name + "-host"
758 }
759 }
760
Inseob Kim0ce291e2019-07-04 14:38:27 +0900761 return name
Colin Crossb916a382016-07-29 17:28:03 -0700762}
763
Jiyong Parkda732bd2018-11-02 18:23:15 +0900764var versioningMacroNamesListMutex sync.Mutex
765
Colin Crossb916a382016-07-29 17:28:03 -0700766func (library *libraryDecorator) linkerInit(ctx BaseModuleContext) {
767 location := InstallInSystem
Dan Albert61f32122018-07-26 14:00:24 -0700768 if library.baseLinker.sanitize.inSanitizerDir() {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700769 location = InstallInSanitizerDir
Colin Crossb916a382016-07-29 17:28:03 -0700770 }
771 library.baseInstaller.location = location
Colin Crossb916a382016-07-29 17:28:03 -0700772 library.baseLinker.linkerInit(ctx)
Jiyong Park7ed9de32018-10-15 22:25:07 +0900773 // Let baseLinker know whether this variant is for stubs or not, so that
774 // it can omit things that are not required for linking stubs.
775 library.baseLinker.dynamicProperties.BuildStubs = library.buildStubs()
Jiyong Parkda732bd2018-11-02 18:23:15 +0900776
777 if library.buildStubs() {
778 macroNames := versioningMacroNamesList(ctx.Config())
779 myName := versioningMacroName(ctx.ModuleName())
780 versioningMacroNamesListMutex.Lock()
781 defer versioningMacroNamesListMutex.Unlock()
782 if (*macroNames)[myName] == "" {
783 (*macroNames)[myName] = ctx.ModuleName()
784 } else if (*macroNames)[myName] != ctx.ModuleName() {
785 ctx.ModuleErrorf("Macro name %q for versioning conflicts with macro name from module %q ", myName, (*macroNames)[myName])
786 }
787 }
Colin Crossb916a382016-07-29 17:28:03 -0700788}
789
dimitry0345ad82018-12-05 16:28:14 +0100790func (library *libraryDecorator) compilerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800791 if ctx.IsLlndk() {
792 // LLNDK libraries ignore most of the properties on the cc_library and use the
793 // LLNDK-specific properties instead.
794 return deps
795 }
796
dimitry0345ad82018-12-05 16:28:14 +0100797 deps = library.baseCompiler.compilerDeps(ctx, deps)
798
dimitry0345ad82018-12-05 16:28:14 +0100799 return deps
800}
801
Colin Cross37047f12016-12-13 17:06:13 -0800802func (library *libraryDecorator) linkerDeps(ctx DepsContext, deps Deps) Deps {
Colin Cross127bb8b2020-12-16 16:46:01 -0800803 if ctx.IsLlndk() {
804 // LLNDK libraries ignore most of the properties on the cc_library and use the
805 // LLNDK-specific properties instead.
Colin Cross0fb7fcd2021-03-02 11:00:07 -0800806 deps.HeaderLibs = append([]string(nil), library.Properties.Llndk.Export_llndk_headers...)
807 deps.ReexportHeaderLibHeaders = append([]string(nil), library.Properties.Llndk.Export_llndk_headers...)
Colin Cross127bb8b2020-12-16 16:46:01 -0800808 return deps
809 }
Colin Cross5271fea2021-04-27 13:06:04 -0700810 if ctx.IsVendorPublicLibrary() {
811 headers := library.Properties.Vendor_public_library.Export_public_headers
812 deps.HeaderLibs = append([]string(nil), headers...)
813 deps.ReexportHeaderLibHeaders = append([]string(nil), headers...)
814 return deps
815 }
Colin Cross127bb8b2020-12-16 16:46:01 -0800816
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800817 if library.static() {
Martin Stjernholm10566a02020-03-24 01:19:52 +0000818 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700819 if library.StaticProperties.Static.System_shared_libs != nil {
820 library.baseLinker.Properties.System_shared_libs = library.StaticProperties.Static.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800821 }
822 } else if library.shared() {
Martin Stjernholm10566a02020-03-24 01:19:52 +0000823 // Compare with nil because an empty list needs to be propagated.
Colin Crosse1bb5d02019-09-24 14:55:04 -0700824 if library.SharedProperties.Shared.System_shared_libs != nil {
825 library.baseLinker.Properties.System_shared_libs = library.SharedProperties.Shared.System_shared_libs
Dan Willemsen3a26eef2018-12-03 15:25:46 -0800826 }
827 }
828
Colin Crossb916a382016-07-29 17:28:03 -0700829 deps = library.baseLinker.linkerDeps(ctx, deps)
830
831 if library.static() {
832 deps.WholeStaticLibs = append(deps.WholeStaticLibs,
Colin Crosse1bb5d02019-09-24 14:55:04 -0700833 library.StaticProperties.Static.Whole_static_libs...)
834 deps.StaticLibs = append(deps.StaticLibs, library.StaticProperties.Static.Static_libs...)
835 deps.SharedLibs = append(deps.SharedLibs, library.StaticProperties.Static.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -0800836
Colin Crosse1bb5d02019-09-24 14:55:04 -0700837 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.StaticProperties.Static.Export_shared_lib_headers...)
838 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.StaticProperties.Static.Export_static_lib_headers...)
Colin Crossa48ab5b2017-02-14 15:28:44 -0800839 } else if library.shared() {
Alex Márquez Pérez Muñíz Díaz Puras Thaureaux01ec55e2023-01-30 22:53:04 +0000840 if library.baseLinker.Properties.crt() {
Colin Crossd1a28132021-06-21 17:34:47 -0700841 deps.CrtBegin = append(deps.CrtBegin, ctx.toolchain().CrtBeginSharedLibrary()...)
842 deps.CrtEnd = append(deps.CrtEnd, ctx.toolchain().CrtEndSharedLibrary()...)
Kalesh Singhf4ffe0a2024-01-29 13:01:51 -0800843
844 }
845 if library.baseLinker.Properties.crtPadSegment() {
846 deps.CrtEnd = append(deps.CrtEnd, ctx.toolchain().CrtPadSegmentSharedLibrary()...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700847 }
Colin Crosse1bb5d02019-09-24 14:55:04 -0700848 deps.WholeStaticLibs = append(deps.WholeStaticLibs, library.SharedProperties.Shared.Whole_static_libs...)
849 deps.StaticLibs = append(deps.StaticLibs, library.SharedProperties.Shared.Static_libs...)
850 deps.SharedLibs = append(deps.SharedLibs, library.SharedProperties.Shared.Shared_libs...)
Colin Crosseefe9a32019-01-22 14:41:08 -0800851
Colin Crosse1bb5d02019-09-24 14:55:04 -0700852 deps.ReexportSharedLibHeaders = append(deps.ReexportSharedLibHeaders, library.SharedProperties.Shared.Export_shared_lib_headers...)
853 deps.ReexportStaticLibHeaders = append(deps.ReexportStaticLibHeaders, library.SharedProperties.Shared.Export_static_lib_headers...)
Hsin-Yi Chen715142a2024-03-27 16:31:16 +0800854
855 deps.LlndkHeaderLibs = append(deps.LlndkHeaderLibs, library.Properties.Llndk.Export_llndk_headers...)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700856 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900857 if ctx.inVendor() {
Jiyong Park52d25bd2017-10-13 09:17:01 +0900858 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
859 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
860 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +0000861 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_shared_libs)
862 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor.Exclude_static_libs)
Jiyong Park52d25bd2017-10-13 09:17:01 +0900863 }
Justin Yun6977e8a2020-10-29 18:24:11 +0900864 if ctx.inProduct() {
865 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
866 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
867 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
868 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_shared_libs)
869 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Product.Exclude_static_libs)
870 }
Jiyong Parkf9332f12018-02-01 00:54:12 +0900871 if ctx.inRecovery() {
872 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
873 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
874 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Victor Chang51271c12019-01-30 16:02:22 +0000875 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_shared_libs)
876 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Recovery.Exclude_static_libs)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900877 }
Yifan Hongcf4832c2020-01-21 17:04:13 -0800878 if ctx.inRamdisk() {
879 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
880 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
881 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
882 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_shared_libs)
883 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Ramdisk.Exclude_static_libs)
884 }
Yifan Hong6da33c22020-10-27 15:01:21 -0700885 if ctx.inVendorRamdisk() {
886 deps.WholeStaticLibs = removeListFromList(deps.WholeStaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
887 deps.SharedLibs = removeListFromList(deps.SharedLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
888 deps.StaticLibs = removeListFromList(deps.StaticLibs, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
889 deps.ReexportSharedLibHeaders = removeListFromList(deps.ReexportSharedLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_shared_libs)
890 deps.ReexportStaticLibHeaders = removeListFromList(deps.ReexportStaticLibHeaders, library.baseLinker.Properties.Target.Vendor_ramdisk.Exclude_static_libs)
891 }
Colin Cross2383f3b2018-02-06 14:40:13 -0800892
Colin Cross4d9c2d12016-07-29 12:48:20 -0700893 return deps
894}
895
Paul Duffin13f02712020-03-06 12:30:43 +0000896func (library *libraryDecorator) linkerSpecifiedDeps(specifiedDeps specifiedDeps) specifiedDeps {
897 specifiedDeps = library.baseLinker.linkerSpecifiedDeps(specifiedDeps)
898 var properties StaticOrSharedProperties
899 if library.static() {
900 properties = library.StaticProperties.Static
901 } else if library.shared() {
902 properties = library.SharedProperties.Shared
903 }
904
905 specifiedDeps.sharedLibs = append(specifiedDeps.sharedLibs, properties.Shared_libs...)
Martin Stjernholm10566a02020-03-24 01:19:52 +0000906
907 // Must distinguish nil and [] in system_shared_libs - ensure that [] in
908 // either input list doesn't come out as nil.
909 if specifiedDeps.systemSharedLibs == nil {
910 specifiedDeps.systemSharedLibs = properties.System_shared_libs
911 } else {
912 specifiedDeps.systemSharedLibs = append(specifiedDeps.systemSharedLibs, properties.System_shared_libs...)
913 }
Paul Duffin13f02712020-03-06 12:30:43 +0000914
915 specifiedDeps.sharedLibs = android.FirstUniqueStrings(specifiedDeps.sharedLibs)
Martin Stjernholm10566a02020-03-24 01:19:52 +0000916 if len(specifiedDeps.systemSharedLibs) > 0 {
917 // Skip this if systemSharedLibs is either nil or [], to ensure they are
918 // retained.
919 specifiedDeps.systemSharedLibs = android.FirstUniqueStrings(specifiedDeps.systemSharedLibs)
920 }
Paul Duffin13f02712020-03-06 12:30:43 +0000921 return specifiedDeps
922}
923
Colin Cross4a9e6ec2023-12-18 15:29:41 -0800924func (library *libraryDecorator) moduleInfoJSON(ctx ModuleContext, moduleInfoJSON *android.ModuleInfoJSON) {
925 if library.static() {
926 moduleInfoJSON.Class = []string{"STATIC_LIBRARIES"}
927 moduleInfoJSON.Uninstallable = true
928 } else if library.shared() {
929 moduleInfoJSON.Class = []string{"SHARED_LIBRARIES"}
930 } else if library.header() {
931 moduleInfoJSON.Class = []string{"HEADER_LIBRARIES"}
932 moduleInfoJSON.Uninstallable = true
933 }
934
935 if library.buildStubs() && library.stubsVersion() != "" {
936 moduleInfoJSON.SubName += "." + library.stubsVersion()
937 }
938
939 // If a library providing a stub is included in an APEX, the private APIs of the library
940 // is accessible only inside the APEX. From outside of the APEX, clients can only use the
941 // public APIs via the stub. To enforce this, the (latest version of the) stub gets the
942 // name of the library. The impl library instead gets the `.bootstrap` suffix to so that
943 // they can be exceptionally used directly when APEXes are not available (e.g. during the
944 // very early stage in the boot process).
945 if len(library.Properties.Stubs.Versions) > 0 && !ctx.Host() && ctx.notInPlatform() &&
946 !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() && !ctx.useVndk() && !ctx.static() {
947 if library.buildStubs() && library.isLatestStubVersion() {
948 moduleInfoJSON.SubName = ""
949 }
950 if !library.buildStubs() {
951 moduleInfoJSON.SubName = ".bootstrap"
952 }
953 }
954
955 library.baseLinker.moduleInfoJSON(ctx, moduleInfoJSON)
956}
957
Colin Crossb916a382016-07-29 17:28:03 -0700958func (library *libraryDecorator) linkStatic(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700959 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -0700960
Dan Willemsen5cb580f2016-09-26 17:33:01 -0700961 library.objects = deps.WholeStaticLibObjs.Copy()
962 library.objects = library.objects.Append(objs)
Colin Crossa2bcf2c2022-02-11 13:11:55 -0800963 library.wholeStaticLibsFromPrebuilts = android.CopyOfPaths(deps.WholeStaticLibsFromPrebuilts)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700964
Inseob Kim0ce291e2019-07-04 14:38:27 +0900965 fileName := ctx.ModuleName() + staticLibraryExtension
Colin Cross86803cf2018-02-15 14:12:26 -0800966 outputFile := android.PathForModuleOut(ctx, fileName)
Dan Willemsen581341d2017-02-09 16:16:31 -0800967 builderFlags := flagsToBuilderFlags(flags)
Colin Cross4d9c2d12016-07-29 12:48:20 -0700968
Dan Willemsen569edc52018-11-19 09:33:29 -0800969 if Bool(library.baseLinker.Properties.Use_version_lib) {
970 if ctx.Host() {
971 versionedOutputFile := outputFile
972 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
973 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
974 } else {
975 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000976 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -0800977 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
978 }
Colin Cross86803cf2018-02-15 14:12:26 -0800979 }
980
Chih-Hung Hsieh7540a782022-01-08 19:56:09 -0800981 transformObjToStaticLib(ctx, library.objects.objFiles, deps.WholeStaticLibsFromPrebuilts, builderFlags, outputFile, nil, objs.tidyDepFiles)
Dan Willemsen581341d2017-02-09 16:16:31 -0800982
Chris Parsonsbf4f55f2020-11-23 17:02:44 -0500983 library.coverageOutputFile = transformCoverageFilesToZip(ctx, library.objects, ctx.ModuleName())
Colin Cross4d9c2d12016-07-29 12:48:20 -0700984
Colin Cross4d9c2d12016-07-29 12:48:20 -0700985 ctx.CheckbuildFile(outputFile)
986
Colin Cross649d8172020-12-10 12:30:21 -0800987 if library.static() {
Colin Cross40213022023-12-13 15:19:49 -0800988 android.SetProvider(ctx, StaticLibraryInfoProvider, StaticLibraryInfo{
Colin Crossa2bcf2c2022-02-11 13:11:55 -0800989 StaticLibrary: outputFile,
990 ReuseObjects: library.reuseObjects,
991 Objects: library.objects,
992 WholeStaticLibsFromPrebuilts: library.wholeStaticLibsFromPrebuilts,
Colin Cross0de8a1e2020-09-18 14:15:30 -0700993
Colin Crossc85750b2022-04-21 12:50:51 -0700994 TransitiveStaticLibrariesForOrdering: android.NewDepSetBuilder[android.Path](android.TOPOLOGICAL).
Colin Cross649d8172020-12-10 12:30:21 -0800995 Direct(outputFile).
996 Transitive(deps.TranstiveStaticLibrariesForOrdering).
997 Build(),
998 })
999 }
1000
1001 if library.header() {
Colin Cross40213022023-12-13 15:19:49 -08001002 android.SetProvider(ctx, HeaderLibraryInfoProvider, HeaderLibraryInfo{})
Colin Cross649d8172020-12-10 12:30:21 -08001003 }
Colin Cross0de8a1e2020-09-18 14:15:30 -07001004
Colin Cross4d9c2d12016-07-29 12:48:20 -07001005 return outputFile
1006}
1007
Chih-Hung Hsiehf6ca1b92021-12-05 18:02:50 -08001008func ndkSharedLibDeps(ctx ModuleContext) android.Paths {
1009 if ctx.Module().(*Module).IsSdkVariant() {
1010 // The NDK sysroot timestamp file depends on all the NDK
1011 // sysroot header and shared library files.
1012 return android.Paths{getNdkBaseTimestampFile(ctx)}
1013 }
1014 return nil
1015}
1016
Colin Crossb916a382016-07-29 17:28:03 -07001017func (library *libraryDecorator) linkShared(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001018 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001019
1020 var linkerDeps android.Paths
Pirama Arumuga Nainarada83ec2017-08-31 23:38:27 -07001021 linkerDeps = append(linkerDeps, flags.LdFlagsDeps...)
Chih-Hung Hsiehf6ca1b92021-12-05 18:02:50 -08001022 linkerDeps = append(linkerDeps, ndkSharedLibDeps(ctx)...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001023
Colin Cross2383f3b2018-02-06 14:40:13 -08001024 unexportedSymbols := ctx.ExpandOptionalSource(library.Properties.Unexported_symbols_list, "unexported_symbols_list")
1025 forceNotWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_not_weak_list, "force_symbols_not_weak_list")
1026 forceWeakSymbols := ctx.ExpandOptionalSource(library.Properties.Force_symbols_weak_list, "force_symbols_weak_list")
Colin Cross4d9c2d12016-07-29 12:48:20 -07001027 if !ctx.Darwin() {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001028 if unexportedSymbols.Valid() {
1029 ctx.PropertyErrorf("unexported_symbols_list", "Only supported on Darwin")
1030 }
1031 if forceNotWeakSymbols.Valid() {
1032 ctx.PropertyErrorf("force_symbols_not_weak_list", "Only supported on Darwin")
1033 }
1034 if forceWeakSymbols.Valid() {
1035 ctx.PropertyErrorf("force_symbols_weak_list", "Only supported on Darwin")
1036 }
1037 } else {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001038 if unexportedSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001039 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-unexported_symbols_list,"+unexportedSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001040 linkerDeps = append(linkerDeps, unexportedSymbols.Path())
1041 }
1042 if forceNotWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001043 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_not_weak_list,"+forceNotWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001044 linkerDeps = append(linkerDeps, forceNotWeakSymbols.Path())
1045 }
1046 if forceWeakSymbols.Valid() {
Colin Cross4af21ed2019-11-04 09:37:55 -08001047 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,-force_symbols_weak_list,"+forceWeakSymbols.String())
Colin Cross4d9c2d12016-07-29 12:48:20 -07001048 linkerDeps = append(linkerDeps, forceWeakSymbols.Path())
1049 }
1050 }
Colin Cross8e21aa52020-09-28 18:28:02 -07001051 if library.versionScriptPath.Valid() {
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001052 linkerScriptFlags := "-Wl,--version-script," + library.versionScriptPath.String()
Colin Cross4af21ed2019-11-04 09:37:55 -08001053 flags.Local.LdFlags = append(flags.Local.LdFlags, linkerScriptFlags)
Colin Cross8e21aa52020-09-28 18:28:02 -07001054 linkerDeps = append(linkerDeps, library.versionScriptPath.Path())
Jiyong Parkc1e7f482019-01-12 13:39:10 +09001055 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001056
1057 fileName := library.getLibName(ctx) + flags.Toolchain.ShlibSuffix()
1058 outputFile := android.PathForModuleOut(ctx, fileName)
Colin Cross0de8a1e2020-09-18 14:15:30 -07001059 unstrippedOutputFile := outputFile
Colin Cross4d9c2d12016-07-29 12:48:20 -07001060
Josh Gao75a50a22019-06-07 17:58:59 -07001061 var implicitOutputs android.WritablePaths
1062 if ctx.Windows() {
1063 importLibraryPath := android.PathForModuleOut(ctx, pathtools.ReplaceExtension(fileName, "lib"))
1064
Colin Cross4af21ed2019-11-04 09:37:55 -08001065 flags.Local.LdFlags = append(flags.Local.LdFlags, "-Wl,--out-implib="+importLibraryPath.String())
Josh Gao75a50a22019-06-07 17:58:59 -07001066 implicitOutputs = append(implicitOutputs, importLibraryPath)
1067 }
1068
Colin Cross4d9c2d12016-07-29 12:48:20 -07001069 builderFlags := flagsToBuilderFlags(flags)
1070
Dan Willemsen47450072021-10-19 20:24:49 -07001071 if ctx.Darwin() && deps.DarwinSecondArchOutput.Valid() {
1072 fatOutputFile := outputFile
1073 outputFile = android.PathForModuleOut(ctx, "pre-fat", fileName)
1074 transformDarwinUniversalBinary(ctx, fatOutputFile, outputFile, deps.DarwinSecondArchOutput.Path())
1075 }
1076
Colin Crossb496cfd2018-09-10 16:50:05 -07001077 // Optimize out relinking against shared libraries whose interface hasn't changed by
1078 // depending on a table of contents file instead of the library itself.
Colin Cross70dda7e2019-10-01 22:05:35 -07001079 tocFile := outputFile.ReplaceExtension(ctx, flags.Toolchain.ShlibSuffix()[1:]+".toc")
Colin Crossb496cfd2018-09-10 16:50:05 -07001080 library.tocFile = android.OptionalPathForPath(tocFile)
Ivan Lozano7b0781d2021-11-03 15:30:18 -04001081 TransformSharedObjectToToc(ctx, outputFile, tocFile)
Colin Cross89562dc2016-10-03 17:47:19 -07001082
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001083 stripFlags := flagsToStripFlags(flags)
Colin Crossadc81a02020-12-14 17:01:55 -08001084 needsStrip := library.stripper.NeedsStrip(ctx)
1085 if library.buildStubs() {
1086 // No need to strip stubs libraries
1087 needsStrip = false
1088 }
1089 if needsStrip {
Yi Kongb5c34d72018-11-07 16:28:49 -08001090 if ctx.Darwin() {
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001091 stripFlags.StripUseGnuStrip = true
Yi Kongb5c34d72018-11-07 16:28:49 -08001092 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001093 strippedOutputFile := outputFile
1094 outputFile = android.PathForModuleOut(ctx, "unstripped", fileName)
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001095 library.stripper.StripExecutableOrSharedLib(ctx, outputFile, strippedOutputFile, stripFlags)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001096 }
Colin Crossb60190a2018-09-04 16:28:17 -07001097 library.unstrippedOutputFile = outputFile
1098
Colin Crossd7227f92019-09-05 14:26:33 -07001099 outputFile = maybeInjectBoringSSLHash(ctx, outputFile, library.Properties.Inject_bssl_hash, fileName)
Pete Bentley803e1612019-08-06 22:19:59 +01001100
Dan Willemsen569edc52018-11-19 09:33:29 -08001101 if Bool(library.baseLinker.Properties.Use_version_lib) {
1102 if ctx.Host() {
1103 versionedOutputFile := outputFile
1104 outputFile = android.PathForModuleOut(ctx, "unversioned", fileName)
1105 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1106 } else {
1107 versionedOutputFile := android.PathForModuleOut(ctx, "versioned", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001108 library.distFile = versionedOutputFile
Dan Willemsen569edc52018-11-19 09:33:29 -08001109
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001110 if library.stripper.NeedsStrip(ctx) {
Dan Willemsen569edc52018-11-19 09:33:29 -08001111 out := android.PathForModuleOut(ctx, "versioned-stripped", fileName)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001112 library.distFile = out
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001113 library.stripper.StripExecutableOrSharedLib(ctx, versionedOutputFile, out, stripFlags)
Dan Willemsen569edc52018-11-19 09:33:29 -08001114 }
1115
1116 library.injectVersionSymbol(ctx, outputFile, versionedOutputFile)
1117 }
Colin Cross86803cf2018-02-15 14:12:26 -08001118 }
1119
Wei Li5f5d2712023-12-11 15:40:29 -08001120 // Generate an output file for dist as if strip: "all" is set on the module.
1121 // Currently this is for layoutlib release process only.
1122 for _, dist := range ctx.Module().(*Module).Dists() {
1123 if dist.Tag != nil && *dist.Tag == "stripped_all" {
1124 strippedAllOutputFile := android.PathForModuleOut(ctx, "stripped_all", fileName)
1125 transformStrip(ctx, outputFile, strippedAllOutputFile, StripFlags{Toolchain: flags.Toolchain})
1126 library.strippedAllOutputFile = strippedAllOutputFile
1127 break
1128 }
1129 }
1130
Jiyong Park64a44f22019-01-18 14:37:08 +09001131 sharedLibs := deps.EarlySharedLibs
1132 sharedLibs = append(sharedLibs, deps.SharedLibs...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001133 sharedLibs = append(sharedLibs, deps.LateSharedLibs...)
1134
Jiyong Park64a44f22019-01-18 14:37:08 +09001135 linkerDeps = append(linkerDeps, deps.EarlySharedLibsDeps...)
Colin Cross26c34ed2016-09-30 17:10:16 -07001136 linkerDeps = append(linkerDeps, deps.SharedLibsDeps...)
1137 linkerDeps = append(linkerDeps, deps.LateSharedLibsDeps...)
Ivan Lozano0a468a42024-05-13 21:03:34 -04001138
Ivan Lozanofd47b1a2024-05-17 14:13:41 -04001139 if generatedLib := generateRustStaticlib(ctx, deps.RustRlibDeps); generatedLib != nil && !library.buildStubs() {
1140 if ctx.Module().(*Module).WholeRustStaticlib {
1141 deps.WholeStaticLibs = append(deps.WholeStaticLibs, generatedLib)
1142 } else {
1143 deps.StaticLibs = append(deps.StaticLibs, generatedLib)
1144 }
Ivan Lozano0a468a42024-05-13 21:03:34 -04001145 }
1146
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001147 transformObjToDynamicBinary(ctx, objs.objFiles, sharedLibs,
Ivan Lozano0a468a42024-05-13 21:03:34 -04001148 deps.StaticLibs, deps.LateStaticLibs, deps.WholeStaticLibs, linkerDeps, deps.CrtBegin,
1149 deps.CrtEnd, false, builderFlags, outputFile, implicitOutputs, objs.tidyDepFiles)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001150
Dan Willemsen581341d2017-02-09 16:16:31 -08001151 objs.coverageFiles = append(objs.coverageFiles, deps.StaticLibObjs.coverageFiles...)
1152 objs.coverageFiles = append(objs.coverageFiles, deps.WholeStaticLibObjs.coverageFiles...)
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001153 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.StaticLibObjs.sAbiDumpFiles...)
1154 objs.sAbiDumpFiles = append(objs.sAbiDumpFiles, deps.WholeStaticLibObjs.sAbiDumpFiles...)
1155
Chris Parsonsbf4f55f2020-11-23 17:02:44 -05001156 library.coverageOutputFile = transformCoverageFilesToZip(ctx, objs, library.getLibName(ctx))
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001157 library.linkSAbiDumpFiles(ctx, deps, objs, fileName, unstrippedOutputFile)
Dan Willemsen581341d2017-02-09 16:16:31 -08001158
Colin Crossc85750b2022-04-21 12:50:51 -07001159 var transitiveStaticLibrariesForOrdering *android.DepSet[android.Path]
Colin Cross0de8a1e2020-09-18 14:15:30 -07001160 if static := ctx.GetDirectDepsWithTag(staticVariantTag); len(static) > 0 {
Colin Cross313aa542023-12-13 13:47:44 -08001161 s, _ := android.OtherModuleProvider(ctx, static[0], StaticLibraryInfoProvider)
Liz Kammeref6dfea2021-06-08 15:37:09 -04001162 transitiveStaticLibrariesForOrdering = s.TransitiveStaticLibrariesForOrdering
Colin Cross0de8a1e2020-09-18 14:15:30 -07001163 }
1164
Colin Cross40213022023-12-13 15:19:49 -08001165 android.SetProvider(ctx, SharedLibraryInfoProvider, SharedLibraryInfo{
Liz Kammeref6dfea2021-06-08 15:37:09 -04001166 TableOfContents: android.OptionalPathForPath(tocFile),
1167 SharedLibrary: unstrippedOutputFile,
1168 TransitiveStaticLibrariesForOrdering: transitiveStaticLibrariesForOrdering,
1169 Target: ctx.Target(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001170 })
1171
Sam Delmerico75dbca22023-04-20 13:13:25 +00001172 addStubDependencyProviders(ctx)
1173
1174 return unstrippedOutputFile
1175}
1176
1177func addStubDependencyProviders(ctx ModuleContext) {
Colin Cross0de8a1e2020-09-18 14:15:30 -07001178 stubs := ctx.GetDirectDepsWithTag(stubImplDepTag)
1179 if len(stubs) > 0 {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001180 var stubsInfo []SharedStubLibrary
Colin Cross0de8a1e2020-09-18 14:15:30 -07001181 for _, stub := range stubs {
Colin Cross313aa542023-12-13 13:47:44 -08001182 stubInfo, _ := android.OtherModuleProvider(ctx, stub, SharedLibraryInfoProvider)
1183 flagInfo, _ := android.OtherModuleProvider(ctx, stub, FlagExporterInfoProvider)
Chris Parsons3c27ca32020-11-20 12:42:07 -05001184 stubsInfo = append(stubsInfo, SharedStubLibrary{
Colin Cross31076b32020-10-23 17:22:06 -07001185 Version: moduleLibraryInterface(stub).stubsVersion(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001186 SharedLibraryInfo: stubInfo,
1187 FlagExporterInfo: flagInfo,
1188 })
1189 }
Colin Cross40213022023-12-13 15:19:49 -08001190 android.SetProvider(ctx, SharedLibraryStubsProvider, SharedLibraryStubsInfo{
Chris Parsons3c27ca32020-11-20 12:42:07 -05001191 SharedStubLibraries: stubsInfo,
Sam Delmerico75dbca22023-04-20 13:13:25 +00001192 IsLLNDK: ctx.IsLlndk(),
Colin Cross0de8a1e2020-09-18 14:15:30 -07001193 })
1194 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001195}
1196
Jiyong Parkaf6d8952019-01-31 12:21:23 +09001197func (library *libraryDecorator) unstrippedOutputFilePath() android.Path {
1198 return library.unstrippedOutputFile
1199}
1200
Wei Li5f5d2712023-12-11 15:40:29 -08001201func (library *libraryDecorator) strippedAllOutputFilePath() android.Path {
1202 return library.strippedAllOutputFile
1203}
1204
Thiébaud Weksteend4587452020-08-19 14:53:01 +02001205func (library *libraryDecorator) disableStripping() {
1206 library.stripper.StripProperties.Strip.None = BoolPtr(true)
1207}
1208
Pirama Arumuga Nainar65c95ff2019-03-25 10:21:31 -07001209func (library *libraryDecorator) nativeCoverage() bool {
1210 if library.header() || library.buildStubs() {
1211 return false
1212 }
1213 return true
1214}
1215
Jiyong Parkee9a98d2019-08-09 14:44:36 +09001216func (library *libraryDecorator) coverageOutputFilePath() android.OptionalPath {
1217 return library.coverageOutputFile
1218}
1219
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001220func (library *libraryDecorator) exportedIncludeDirsForAbiCheck(ctx ModuleContext) []string {
1221 exportIncludeDirs := library.flagExporter.exportedIncludes(ctx).Strings()
1222 exportIncludeDirs = append(exportIncludeDirs, library.sabi.Properties.ReexportedIncludes...)
Hsin-Yi Chen5f228b02024-04-02 12:38:47 +08001223 exportSystemIncludeDirs := library.flagExporter.exportedSystemIncludes(ctx).Strings()
1224 exportSystemIncludeDirs = append(exportSystemIncludeDirs, library.sabi.Properties.ReexportedSystemIncludes...)
1225 // The ABI checker does not distinguish normal and system headers.
1226 return append(exportIncludeDirs, exportSystemIncludeDirs...)
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001227}
1228
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001229func (library *libraryDecorator) llndkIncludeDirsForAbiCheck(ctx ModuleContext, deps PathDeps) []string {
Hsin-Yi Chen5f228b02024-04-02 12:38:47 +08001230 var includeDirs, systemIncludeDirs []string
1231
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001232 // The ABI checker does not need the preprocess which adds macro guards to function declarations.
Hsin-Yi Chen5f228b02024-04-02 12:38:47 +08001233 preprocessedDirs := android.PathsForModuleSrc(ctx, library.Properties.Llndk.Export_preprocessed_headers).Strings()
1234 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1235 systemIncludeDirs = append(systemIncludeDirs, preprocessedDirs...)
1236 } else {
1237 includeDirs = append(includeDirs, preprocessedDirs...)
1238 }
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001239
1240 if library.Properties.Llndk.Override_export_include_dirs != nil {
1241 includeDirs = append(includeDirs, android.PathsForModuleSrc(
1242 ctx, library.Properties.Llndk.Override_export_include_dirs).Strings()...)
1243 } else {
1244 includeDirs = append(includeDirs, library.flagExporter.exportedIncludes(ctx).Strings()...)
1245 // Ignore library.sabi.Properties.ReexportedIncludes because
1246 // LLNDK does not reexport the implementation's dependencies, such as export_header_libs.
1247 }
1248
Hsin-Yi Chen5f228b02024-04-02 12:38:47 +08001249 systemIncludeDirs = append(systemIncludeDirs,
1250 library.flagExporter.exportedSystemIncludes(ctx).Strings()...)
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001251 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1252 systemIncludeDirs = append(systemIncludeDirs, includeDirs...)
1253 includeDirs = nil
1254 }
1255 // Header libs.
1256 includeDirs = append(includeDirs, deps.LlndkIncludeDirs.Strings()...)
1257 systemIncludeDirs = append(systemIncludeDirs, deps.LlndkSystemIncludeDirs.Strings()...)
1258 // The ABI checker does not distinguish normal and system headers.
1259 return append(includeDirs, systemIncludeDirs...)
1260}
1261
1262func (library *libraryDecorator) linkLlndkSAbiDumpFiles(ctx ModuleContext,
1263 deps PathDeps, sAbiDumpFiles android.Paths, soFile android.Path, libFileName string,
Hsin-Yi Chenf6fc5252024-04-15 15:43:21 +08001264 excludeSymbolVersions, excludeSymbolTags []string,
1265 vendorApiLevel string) android.Path {
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001266 // NDK symbols in version 34 are LLNDK symbols. Those in version 35 are not.
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001267 return transformDumpToLinkedDump(ctx,
1268 sAbiDumpFiles, soFile, libFileName+".llndk",
1269 library.llndkIncludeDirsForAbiCheck(ctx, deps),
1270 android.OptionalPathForModuleSrc(ctx, library.Properties.Llndk.Symbol_file),
1271 append([]string{"*_PLATFORM", "*_PRIVATE"}, excludeSymbolVersions...),
1272 append([]string{"platform-only"}, excludeSymbolTags...),
Hsin-Yi Chenf6fc5252024-04-15 15:43:21 +08001273 []string{"llndk=" + vendorApiLevel}, "34", true /* isLlndk */)
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001274}
1275
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001276func (library *libraryDecorator) linkApexSAbiDumpFiles(ctx ModuleContext,
1277 deps PathDeps, sAbiDumpFiles android.Paths, soFile android.Path, libFileName string,
Hsin-Yi Chenf6fc5252024-04-15 15:43:21 +08001278 excludeSymbolVersions, excludeSymbolTags []string,
1279 sdkVersion string) android.Path {
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001280 return transformDumpToLinkedDump(ctx,
1281 sAbiDumpFiles, soFile, libFileName+".apex",
1282 library.exportedIncludeDirsForAbiCheck(ctx),
1283 android.OptionalPathForModuleSrc(ctx, library.Properties.Stubs.Symbol_file),
1284 append([]string{"*_PLATFORM", "*_PRIVATE"}, excludeSymbolVersions...),
1285 append([]string{"platform-only"}, excludeSymbolTags...),
Hsin-Yi Chenf6fc5252024-04-15 15:43:21 +08001286 []string{"apex", "systemapi"}, sdkVersion, false /* isLlndk */)
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001287}
1288
Hsin-Yi Chen0af4e672022-11-23 14:39:46 +08001289func getRefAbiDumpFile(ctx android.ModuleInstallPathContext,
1290 versionedDumpDir, fileName string) android.OptionalPath {
Mu-Le Leef5ed30b2022-08-30 10:37:21 +00001291
1292 currentArchType := ctx.Arch().ArchType
1293 primaryArchType := ctx.Config().DevicePrimaryArchType()
1294 archName := currentArchType.String()
1295 if currentArchType != primaryArchType {
1296 archName += "_" + primaryArchType.String()
1297 }
1298
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001299 return android.ExistentPathForSource(ctx, versionedDumpDir, archName, "source-based",
Hsin-Yi Chen0af4e672022-11-23 14:39:46 +08001300 fileName+".lsdump")
Mu-Le Leef5ed30b2022-08-30 10:37:21 +00001301}
1302
Hsin-Yi Chen2c4a9772024-02-05 17:37:27 +08001303// Return the previous and current SDK versions for cross-version ABI diff.
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001304func crossVersionAbiDiffSdkVersions(ctx ModuleContext, dumpDir string) (int, int) {
Mu-Le Lee0a9005e2022-07-05 09:49:50 +00001305 sdkVersionInt := ctx.Config().PlatformSdkVersion().FinalInt()
Mu-Le Lee0a9005e2022-07-05 09:49:50 +00001306
1307 if ctx.Config().PlatformSdkFinal() {
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001308 return sdkVersionInt - 1, sdkVersionInt
Mu-Le Lee0a9005e2022-07-05 09:49:50 +00001309 } else {
Mu-Le Lee0a9005e2022-07-05 09:49:50 +00001310 // The platform SDK version can be upgraded before finalization while the corresponding abi dumps hasn't
1311 // been generated. Thus the Cross-Version Check chooses PLATFORM_SDK_VERION - 1 as previous version.
1312 // This situation could be identified by checking the existence of the PLATFORM_SDK_VERION dump directory.
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001313 versionedDumpDir := android.ExistentPathForSource(ctx,
1314 dumpDir, ctx.Config().PlatformSdkVersion().String())
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001315 if versionedDumpDir.Valid() {
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001316 return sdkVersionInt, sdkVersionInt + 1
Mu-Le Lee0a9005e2022-07-05 09:49:50 +00001317 } else {
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001318 return sdkVersionInt - 1, sdkVersionInt
Mu-Le Lee0a9005e2022-07-05 09:49:50 +00001319 }
1320 }
1321}
1322
Hsin-Yi Chen2c4a9772024-02-05 17:37:27 +08001323// Return the SDK version for same-version ABI diff.
1324func currRefAbiDumpSdkVersion(ctx ModuleContext) string {
Hsin-Yi Chen27bafd02024-01-08 18:38:42 +08001325 if ctx.Config().PlatformSdkFinal() {
Hsin-Yi Chena90bd382022-11-10 16:56:27 +08001326 // After sdk finalization, the ABI of the latest API level must be consistent with the source code,
1327 // so choose PLATFORM_SDK_VERSION as the current version.
1328 return ctx.Config().PlatformSdkVersion().String()
1329 } else {
1330 return "current"
1331 }
1332}
1333
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001334// sourceAbiDiff registers a build statement to compare linked sAbi dump files (.lsdump).
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001335func (library *libraryDecorator) sourceAbiDiff(ctx android.ModuleContext,
1336 sourceDump, referenceDump android.Path,
Hsin-Yi Chen6fd28952024-05-02 15:37:30 +08001337 baseName, nameExt string, isLlndk, allowExtensions bool,
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001338 sourceVersion, errorMessage string) {
1339
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001340 extraFlags := []string{"-target-version", sourceVersion}
Hsin-Yi Chen8feb4132022-12-26 15:54:36 +08001341 headerAbiChecker := library.getHeaderAbiCheckerProperties(ctx)
1342 if Bool(headerAbiChecker.Check_all_apis) {
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001343 extraFlags = append(extraFlags, "-check-all-apis")
1344 } else {
1345 extraFlags = append(extraFlags,
1346 "-allow-unreferenced-changes",
1347 "-allow-unreferenced-elf-symbol-changes")
1348 }
Hsin-Yi Chen6fd28952024-05-02 15:37:30 +08001349 if isLlndk {
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001350 extraFlags = append(extraFlags, "-consider-opaque-types-different")
1351 }
1352 if allowExtensions {
1353 extraFlags = append(extraFlags, "-allow-extensions")
1354 }
Hsin-Yi Chen8feb4132022-12-26 15:54:36 +08001355 extraFlags = append(extraFlags, headerAbiChecker.Diff_flags...)
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001356
1357 library.sAbiDiff = append(
1358 library.sAbiDiff,
1359 transformAbiDumpToAbiDiff(ctx, sourceDump, referenceDump,
1360 baseName, nameExt, extraFlags, errorMessage))
1361}
1362
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001363func (library *libraryDecorator) crossVersionAbiDiff(ctx android.ModuleContext,
1364 sourceDump, referenceDump android.Path,
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001365 baseName, nameExt string, isLlndk bool, sourceVersion, prevDumpDir string) {
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001366
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001367 errorMessage := "error: Please follow https://android.googlesource.com/platform/development/+/main/vndk/tools/header-checker/README.md#configure-cross_version-abi-check to resolve the difference between your source code and the ABI dumps in " + prevDumpDir
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001368
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001369 library.sourceAbiDiff(ctx, sourceDump, referenceDump, baseName, nameExt,
Hsin-Yi Chen6fd28952024-05-02 15:37:30 +08001370 isLlndk, true /* allowExtensions */, sourceVersion, errorMessage)
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001371}
1372
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001373func (library *libraryDecorator) sameVersionAbiDiff(ctx android.ModuleContext,
1374 sourceDump, referenceDump android.Path,
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001375 baseName, nameExt string, isLlndk bool, lsdumpTagName string) {
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001376
1377 libName := strings.TrimSuffix(baseName, filepath.Ext(baseName))
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001378 errorMessage := "error: Please update ABI references with: $$ANDROID_BUILD_TOP/development/vndk/tools/header-checker/utils/create_reference_dumps.py --lib " + libName + " --lib-variant " + lsdumpTagName
1379
1380 targetRelease := ctx.Config().Getenv("TARGET_RELEASE")
1381 if targetRelease != "" {
1382 errorMessage += " --release " + targetRelease
1383 }
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001384
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001385 library.sourceAbiDiff(ctx, sourceDump, referenceDump, baseName, nameExt,
Hsin-Yi Chen6fd28952024-05-02 15:37:30 +08001386 isLlndk, false /* allowExtensions */, "current", errorMessage)
Hsin-Yi Chena6ddb142022-10-27 14:55:42 +08001387}
1388
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001389func (library *libraryDecorator) optInAbiDiff(ctx android.ModuleContext,
1390 sourceDump, referenceDump android.Path,
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001391 baseName, nameExt string, refDumpDir string, lsdumpTagName string) {
Hsin-Yi Chenf3630122022-11-17 14:29:43 +08001392
1393 libName := strings.TrimSuffix(baseName, filepath.Ext(baseName))
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001394 errorMessage := "error: Please update ABI references with: $$ANDROID_BUILD_TOP/development/vndk/tools/header-checker/utils/create_reference_dumps.py --lib " + libName + " --lib-variant " + lsdumpTagName + " --ref-dump-dir $$ANDROID_BUILD_TOP/" + refDumpDir
1395
1396 targetRelease := ctx.Config().Getenv("TARGET_RELEASE")
1397 if targetRelease != "" {
1398 errorMessage += " --release " + targetRelease
1399 }
1400
Hsin-Yi Chen8b85d812023-06-29 16:51:27 +08001401 // Most opt-in libraries do not have dumps for all default architectures.
1402 if ctx.Config().HasDeviceProduct() {
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001403 errorMessage += " --product " + ctx.Config().DeviceProduct()
Hsin-Yi Chen8b85d812023-06-29 16:51:27 +08001404 }
Hsin-Yi Chenf3630122022-11-17 14:29:43 +08001405
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001406 library.sourceAbiDiff(ctx, sourceDump, referenceDump, baseName, nameExt,
Hsin-Yi Chen6fd28952024-05-02 15:37:30 +08001407 false /* isLlndk */, false /* allowExtensions */, "current", errorMessage)
Hsin-Yi Chenf3630122022-11-17 14:29:43 +08001408}
1409
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001410func (library *libraryDecorator) linkSAbiDumpFiles(ctx ModuleContext, deps PathDeps, objs Objects, fileName string, soFile android.Path) {
Yo Chiang2bbadfa2020-12-14 11:42:16 +08001411 if library.sabi.shouldCreateSourceAbiDump() {
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001412 exportedIncludeDirs := library.exportedIncludeDirsForAbiCheck(ctx)
Hsin-Yi Chen8feb4132022-12-26 15:54:36 +08001413 headerAbiChecker := library.getHeaderAbiCheckerProperties(ctx)
Hsin-Yi Chen2c4a9772024-02-05 17:37:27 +08001414 currSdkVersion := currRefAbiDumpSdkVersion(ctx)
1415 currVendorVersion := ctx.Config().VendorApiLevel()
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001416
1417 // Generate source dumps.
1418 implDump := transformDumpToLinkedDump(ctx,
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001419 objs.sAbiDumpFiles, soFile, fileName,
1420 exportedIncludeDirs,
Hsin-Yi Chen843c0632023-09-25 15:26:30 +08001421 android.OptionalPathForModuleSrc(ctx, library.symbolFileForAbiCheck(ctx)),
1422 headerAbiChecker.Exclude_symbol_versions,
1423 headerAbiChecker.Exclude_symbol_tags,
Hsin-Yi Chenf6fc5252024-04-15 15:43:21 +08001424 []string{} /* includeSymbolTags */, currSdkVersion, false /* isLlndk */)
Hsin-Yi Chen843c0632023-09-25 15:26:30 +08001425
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001426 var llndkDump, apexVariantDump android.Path
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001427 tags := classifySourceAbiDump(ctx)
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001428 optInTags := []lsdumpTag{}
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001429 for _, tag := range tags {
Hsin-Yi Chenf6fc5252024-04-15 15:43:21 +08001430 if tag == llndkLsdumpTag && currVendorVersion != "" {
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001431 if llndkDump == nil {
1432 // TODO(b/323447559): Evaluate if replacing sAbiDumpFiles with implDump is faster
1433 llndkDump = library.linkLlndkSAbiDumpFiles(ctx,
1434 deps, objs.sAbiDumpFiles, soFile, fileName,
1435 headerAbiChecker.Exclude_symbol_versions,
Hsin-Yi Chenf6fc5252024-04-15 15:43:21 +08001436 headerAbiChecker.Exclude_symbol_tags,
1437 currVendorVersion)
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001438 }
1439 addLsdumpPath(string(tag) + ":" + llndkDump.String())
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001440 } else if tag == apexLsdumpTag {
1441 if apexVariantDump == nil {
1442 apexVariantDump = library.linkApexSAbiDumpFiles(ctx,
1443 deps, objs.sAbiDumpFiles, soFile, fileName,
1444 headerAbiChecker.Exclude_symbol_versions,
1445 headerAbiChecker.Exclude_symbol_tags,
1446 currSdkVersion)
1447 }
1448 addLsdumpPath(string(tag) + ":" + apexVariantDump.String())
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001449 } else {
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001450 if tag.dirName() == "" {
1451 optInTags = append(optInTags, tag)
1452 }
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001453 addLsdumpPath(string(tag) + ":" + implDump.String())
1454 }
1455 }
1456
1457 // Diff source dumps and reference dumps.
1458 for _, tag := range tags {
Hsin-Yi Chen362c1882024-02-06 15:43:17 +08001459 dumpDirName := tag.dirName()
1460 if dumpDirName == "" {
1461 continue
1462 }
1463 dumpDir := filepath.Join("prebuilts", "abi-dumps", dumpDirName)
1464 isLlndk := (tag == llndkLsdumpTag)
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001465 isApex := (tag == apexLsdumpTag)
Hsin-Yi Chen362c1882024-02-06 15:43:17 +08001466 binderBitness := ctx.DeviceConfig().BinderBitness()
1467 nameExt := ""
1468 if isLlndk {
1469 nameExt = "llndk"
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001470 } else if isApex {
1471 nameExt = "apex"
Hsin-Yi Chen362c1882024-02-06 15:43:17 +08001472 }
1473 // Check against the previous version.
Hsin-Yi Chen2c4a9772024-02-05 17:37:27 +08001474 var prevVersion, currVersion string
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001475 sourceDump := implDump
Hsin-Yi Chen2c4a9772024-02-05 17:37:27 +08001476 // If this release config does not define VendorApiLevel, fall back to the old policy.
1477 if isLlndk && currVendorVersion != "" {
1478 prevVersion = ctx.Config().PrevVendorApiLevel()
1479 currVersion = currVendorVersion
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001480 // LLNDK dumps are generated by different rules after trunk stable.
1481 if android.IsTrunkStableVendorApiLevel(prevVersion) {
1482 sourceDump = llndkDump
1483 }
Hsin-Yi Chen2c4a9772024-02-05 17:37:27 +08001484 } else {
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001485 prevVersionInt, currVersionInt := crossVersionAbiDiffSdkVersions(ctx, dumpDir)
1486 prevVersion = strconv.Itoa(prevVersionInt)
1487 currVersion = strconv.Itoa(currVersionInt)
1488 // APEX dumps are generated by different rules after trunk stable.
1489 if isApex && prevVersionInt > 34 {
1490 sourceDump = apexVariantDump
1491 }
Hsin-Yi Chen2c4a9772024-02-05 17:37:27 +08001492 }
Hsin-Yi Chen362c1882024-02-06 15:43:17 +08001493 prevDumpDir := filepath.Join(dumpDir, prevVersion, binderBitness)
1494 prevDumpFile := getRefAbiDumpFile(ctx, prevDumpDir, fileName)
1495 if prevDumpFile.Valid() {
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001496 library.crossVersionAbiDiff(ctx, sourceDump, prevDumpFile.Path(),
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001497 fileName, nameExt+prevVersion, isLlndk, currVersion, prevDumpDir)
Hsin-Yi Chen362c1882024-02-06 15:43:17 +08001498 }
1499 // Check against the current version.
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001500 sourceDump = implDump
Hsin-Yi Chen2c4a9772024-02-05 17:37:27 +08001501 if isLlndk && currVendorVersion != "" {
1502 currVersion = currVendorVersion
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001503 if android.IsTrunkStableVendorApiLevel(currVersion) {
1504 sourceDump = llndkDump
1505 }
Hsin-Yi Chen2c4a9772024-02-05 17:37:27 +08001506 } else {
1507 currVersion = currSdkVersion
Hsin-Yi Chen98da0212024-04-14 19:08:17 +08001508 if isApex && (!ctx.Config().PlatformSdkFinal() ||
1509 ctx.Config().PlatformSdkVersion().FinalInt() > 34) {
1510 sourceDump = apexVariantDump
1511 }
Hsin-Yi Chen2c4a9772024-02-05 17:37:27 +08001512 }
Hsin-Yi Chen362c1882024-02-06 15:43:17 +08001513 currDumpDir := filepath.Join(dumpDir, currVersion, binderBitness)
1514 currDumpFile := getRefAbiDumpFile(ctx, currDumpDir, fileName)
1515 if currDumpFile.Valid() {
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001516 library.sameVersionAbiDiff(ctx, sourceDump, currDumpFile.Path(),
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001517 fileName, nameExt, isLlndk, string(tag))
Hsin-Yi Chen362c1882024-02-06 15:43:17 +08001518 }
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001519 }
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001520
1521 // Assert that a module is tagged with at most one of platformLsdumpTag, productLsdumpTag, or vendorLsdumpTag.
1522 if len(headerAbiChecker.Ref_dump_dirs) > 0 && len(optInTags) != 1 {
1523 ctx.ModuleErrorf("Expect exactly one opt-in lsdump tag when ref_dump_dirs are specified: %s", optInTags)
1524 return
1525 }
Hsin-Yi Chen3d5c6792024-04-22 11:47:57 +08001526 // Ensure that a module tagged with only platformLsdumpTag has ref_dump_dirs.
1527 // Android.bp in vendor projects should be cleaned up before this is enforced for vendorLsdumpTag and productLsdumpTag.
1528 if len(headerAbiChecker.Ref_dump_dirs) == 0 && len(tags) == 1 && tags[0] == platformLsdumpTag {
1529 ctx.ModuleErrorf("header_abi_checker is explicitly enabled, but no ref_dump_dirs are specified.")
1530 }
Hsin-Yi Chenf3630122022-11-17 14:29:43 +08001531 // Check against the opt-in reference dumps.
Hsin-Yi Chen8feb4132022-12-26 15:54:36 +08001532 for i, optInDumpDir := range headerAbiChecker.Ref_dump_dirs {
Hsin-Yi Chenf3630122022-11-17 14:29:43 +08001533 optInDumpDirPath := android.PathForModuleSrc(ctx, optInDumpDir)
1534 // Ref_dump_dirs are not versioned.
1535 // They do not contain subdir for binder bitness because 64-bit binder has been mandatory.
1536 optInDumpFile := getRefAbiDumpFile(ctx, optInDumpDirPath.String(), fileName)
1537 if !optInDumpFile.Valid() {
1538 continue
1539 }
Hsin-Yi Chenaf369882024-03-29 20:10:36 +08001540 library.optInAbiDiff(ctx,
Hsin-Yi Chen64b2d032024-03-29 19:12:35 +08001541 implDump, optInDumpFile.Path(),
Hsin-Yi Chend5919c12024-02-19 15:15:30 +08001542 fileName, "opt"+strconv.Itoa(i), optInDumpDirPath.String(), string(optInTags[0]))
Hsin-Yi Chenf3630122022-11-17 14:29:43 +08001543 }
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08001544 }
1545}
1546
Inseob Kimcc12d902021-05-14 20:15:55 +09001547func processLLNDKHeaders(ctx ModuleContext, srcHeaderDir string, outDir android.ModuleGenPath) (timestamp android.Path, installPaths android.WritablePaths) {
Colin Cross127bb8b2020-12-16 16:46:01 -08001548 srcDir := android.PathForModuleSrc(ctx, srcHeaderDir)
1549 srcFiles := ctx.GlobFiles(filepath.Join(srcDir.String(), "**/*.h"), nil)
1550
Colin Cross127bb8b2020-12-16 16:46:01 -08001551 for _, header := range srcFiles {
1552 headerDir := filepath.Dir(header.String())
1553 relHeaderDir, err := filepath.Rel(srcDir.String(), headerDir)
1554 if err != nil {
1555 ctx.ModuleErrorf("filepath.Rel(%q, %q) failed: %s",
1556 srcDir.String(), headerDir, err)
1557 continue
1558 }
1559
1560 installPaths = append(installPaths, outDir.Join(ctx, relHeaderDir, header.Base()))
1561 }
1562
Inseob Kimcc12d902021-05-14 20:15:55 +09001563 return processHeadersWithVersioner(ctx, srcDir, outDir, srcFiles, installPaths), installPaths
Colin Cross127bb8b2020-12-16 16:46:01 -08001564}
1565
Chris Parsons3c27ca32020-11-20 12:42:07 -05001566// link registers actions to link this library, and sets various fields
1567// on this library to reflect information that should be exported up the build
1568// tree (for example, exported flags and include paths).
Colin Crossb916a382016-07-29 17:28:03 -07001569func (library *libraryDecorator) link(ctx ModuleContext,
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001570 flags Flags, deps PathDeps, objs Objects) android.Path {
Colin Cross4d9c2d12016-07-29 12:48:20 -07001571
Colin Cross127bb8b2020-12-16 16:46:01 -08001572 if ctx.IsLlndk() {
1573 if len(library.Properties.Llndk.Export_preprocessed_headers) > 0 {
1574 // This is the vendor variant of an LLNDK library with preprocessed headers.
1575 genHeaderOutDir := android.PathForModuleGen(ctx, "include")
1576
1577 var timestampFiles android.Paths
1578 for _, dir := range library.Properties.Llndk.Export_preprocessed_headers {
Inseob Kimcc12d902021-05-14 20:15:55 +09001579 timestampFile, installPaths := processLLNDKHeaders(ctx, dir, genHeaderOutDir)
1580 timestampFiles = append(timestampFiles, timestampFile)
1581 library.addExportedGeneratedHeaders(installPaths.Paths()...)
Colin Cross127bb8b2020-12-16 16:46:01 -08001582 }
1583
1584 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1585 library.reexportSystemDirs(genHeaderOutDir)
1586 } else {
1587 library.reexportDirs(genHeaderOutDir)
1588 }
1589
1590 library.reexportDeps(timestampFiles...)
1591 }
1592
Colin Cross0fb7fcd2021-03-02 11:00:07 -08001593 // override the module's export_include_dirs with llndk.override_export_include_dirs
1594 // if it is set.
1595 if override := library.Properties.Llndk.Override_export_include_dirs; override != nil {
Aleks Todorovc9becde2024-06-10 12:51:53 +01001596 library.flagExporter.Properties.Export_include_dirs = proptools.NewConfigurable[[]string](
1597 nil,
1598 []proptools.ConfigurableCase[[]string]{
1599 proptools.NewConfigurableCase[[]string](nil, &override),
1600 },
1601 )
Colin Cross0fb7fcd2021-03-02 11:00:07 -08001602 }
1603
Colin Cross127bb8b2020-12-16 16:46:01 -08001604 if Bool(library.Properties.Llndk.Export_headers_as_system) {
1605 library.flagExporter.Properties.Export_system_include_dirs = append(
1606 library.flagExporter.Properties.Export_system_include_dirs,
Aleks Todorovc9becde2024-06-10 12:51:53 +01001607 library.flagExporter.Properties.Export_include_dirs.GetOrDefault(ctx, nil)...)
1608 library.flagExporter.Properties.Export_include_dirs = proptools.NewConfigurable[[]string](nil, nil)
Colin Cross127bb8b2020-12-16 16:46:01 -08001609 }
1610 }
1611
Colin Cross5271fea2021-04-27 13:06:04 -07001612 if ctx.IsVendorPublicLibrary() {
1613 // override the module's export_include_dirs with vendor_public_library.override_export_include_dirs
1614 // if it is set.
1615 if override := library.Properties.Vendor_public_library.Override_export_include_dirs; override != nil {
Aleks Todorovc9becde2024-06-10 12:51:53 +01001616 library.flagExporter.Properties.Export_include_dirs = proptools.NewConfigurable[[]string](
1617 nil,
1618 []proptools.ConfigurableCase[[]string]{
1619 proptools.NewConfigurableCase[[]string](nil, &override),
1620 },
1621 )
Colin Cross5271fea2021-04-27 13:06:04 -07001622 }
1623 }
1624
Chris Parsons3c27ca32020-11-20 12:42:07 -05001625 // Linking this library consists of linking `deps.Objs` (.o files in dependencies
1626 // of this library), together with `objs` (.o files created by compiling this
1627 // library).
Colin Crossad59e752017-11-16 14:29:11 -08001628 objs = deps.Objs.Copy().Append(objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001629 var out android.Path
Colin Crossa48ab5b2017-02-14 15:28:44 -08001630 if library.static() || library.header() {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001631 out = library.linkStatic(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001632 } else {
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001633 out = library.linkShared(ctx, flags, deps, objs)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001634 }
1635
Chris Parsons3c27ca32020-11-20 12:42:07 -05001636 // Export include paths and flags to be propagated up the tree.
Inseob Kim69378442019-06-03 19:10:47 +09001637 library.exportIncludes(ctx)
1638 library.reexportDirs(deps.ReexportedDirs...)
1639 library.reexportSystemDirs(deps.ReexportedSystemDirs...)
1640 library.reexportFlags(deps.ReexportedFlags...)
1641 library.reexportDeps(deps.ReexportedDeps...)
Inseob Kimd110f872019-12-06 13:15:38 +09001642 library.addExportedGeneratedHeaders(deps.ReexportedGeneratedHeaders...)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001643
Ivan Lozano0a468a42024-05-13 21:03:34 -04001644 if library.static() && len(deps.ReexportedRustRlibDeps) > 0 {
1645 library.reexportRustStaticDeps(deps.ReexportedRustRlibDeps...)
1646 }
1647
Chris Parsons3c27ca32020-11-20 12:42:07 -05001648 // Optionally export aidl headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001649 if Bool(library.Properties.Aidl.Export_aidl_headers) {
Vinh Tran367d89d2023-04-28 11:21:25 -04001650 if library.baseCompiler.hasAidl(deps) {
Vinh Tran09581952023-05-16 16:03:20 -04001651 if library.baseCompiler.hasSrcExt(".aidl") {
1652 dir := android.PathForModuleGen(ctx, "aidl")
1653 library.reexportDirs(dir)
1654 }
1655 if len(deps.AidlLibraryInfos) > 0 {
1656 dir := android.PathForModuleGen(ctx, "aidl_library")
1657 library.reexportDirs(dir)
1658 }
Inseob Kimd110f872019-12-06 13:15:38 +09001659
Paul Duffin33056e82021-02-19 13:49:08 +00001660 library.reexportDeps(library.baseCompiler.aidlOrderOnlyDeps...)
1661 library.addExportedGeneratedHeaders(library.baseCompiler.aidlHeaders...)
Dan Willemsene1240db2016-11-03 14:28:51 -07001662 }
1663 }
1664
Chris Parsons3c27ca32020-11-20 12:42:07 -05001665 // Optionally export proto headers.
Nan Zhang0007d812017-11-07 10:57:05 -08001666 if Bool(library.Properties.Proto.Export_proto_headers) {
Dan Willemsene1240db2016-11-03 14:28:51 -07001667 if library.baseCompiler.hasSrcExt(".proto") {
Jiyong Park74955042019-10-22 20:19:51 +09001668 var includes android.Paths
Colin Cross19878da2019-03-28 14:45:07 -07001669 if flags.proto.CanonicalPathFromRoot {
Jiyong Park74955042019-10-22 20:19:51 +09001670 includes = append(includes, flags.proto.SubDir)
Colin Cross10d22312017-05-03 11:01:58 -07001671 }
Jiyong Park74955042019-10-22 20:19:51 +09001672 includes = append(includes, flags.proto.Dir)
Inseob Kim69378442019-06-03 19:10:47 +09001673 library.reexportDirs(includes...)
Inseob Kimd110f872019-12-06 13:15:38 +09001674
Paul Duffin33056e82021-02-19 13:49:08 +00001675 library.reexportDeps(library.baseCompiler.protoOrderOnlyDeps...)
1676 library.addExportedGeneratedHeaders(library.baseCompiler.protoHeaders...)
Colin Cross0c461f12016-10-20 16:11:43 -07001677 }
1678 }
1679
Inseob Kim07def122020-11-23 14:43:02 +09001680 // If the library is sysprop_library, expose either public or internal header selectively.
Inseob Kim21f26902018-09-06 00:55:20 +09001681 if library.baseCompiler.hasSrcExt(".sysprop") {
Jiyong Park74955042019-10-22 20:19:51 +09001682 dir := android.PathForModuleGen(ctx, "sysprop", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001683 if library.Properties.Sysprop.Platform != nil {
Inseob Kimc0907f12019-02-08 21:00:45 +09001684 isOwnerPlatform := Bool(library.Properties.Sysprop.Platform)
1685
Inseob Kim07def122020-11-23 14:43:02 +09001686 // If the owner is different from the user, expose public header. That is,
1687 // 1) if the user is product (as owner can only be platform / vendor)
Inseob Kim06410042021-01-18 15:23:28 +09001688 // 2) if the owner is platform and the client is vendor
1689 // We don't care Platform -> Vendor dependency as it's already forbidden.
1690 if ctx.Device() && (ctx.ProductSpecific() || (isOwnerPlatform && ctx.inVendor())) {
Jiyong Park74955042019-10-22 20:19:51 +09001691 dir = android.PathForModuleGen(ctx, "sysprop/public", "include")
Inseob Kimc0907f12019-02-08 21:00:45 +09001692 }
1693 }
1694
Paul Duffin37e0de52021-02-19 17:05:39 +00001695 // Make sure to only export headers which are within the include directory.
1696 _, headers := android.FilterPathListPredicate(library.baseCompiler.syspropHeaders, func(path android.Path) bool {
1697 _, isRel := android.MaybeRel(ctx, dir.String(), path.String())
1698 return isRel
1699 })
1700
Chris Parsons3c27ca32020-11-20 12:42:07 -05001701 // Add sysprop-related directories to the exported directories of this library.
Inseob Kim69378442019-06-03 19:10:47 +09001702 library.reexportDirs(dir)
Paul Duffin33056e82021-02-19 13:49:08 +00001703 library.reexportDeps(library.baseCompiler.syspropOrderOnlyDeps...)
Paul Duffin37e0de52021-02-19 17:05:39 +00001704 library.addExportedGeneratedHeaders(headers...)
Inseob Kim21f26902018-09-06 00:55:20 +09001705 }
1706
Chris Parsons3c27ca32020-11-20 12:42:07 -05001707 // Add stub-related flags if this library is a stub library.
Jiyong Park892a98f2020-12-14 09:20:00 +09001708 library.exportVersioningMacroIfNeeded(ctx)
Jiyong Parkda732bd2018-11-02 18:23:15 +09001709
Chris Parsons3c27ca32020-11-20 12:42:07 -05001710 // Propagate a Provider containing information about exported flags, deps, and include paths.
Colin Cross0de8a1e2020-09-18 14:15:30 -07001711 library.flagExporter.setProvider(ctx)
1712
Colin Cross4d9c2d12016-07-29 12:48:20 -07001713 return out
1714}
1715
Jiyong Park892a98f2020-12-14 09:20:00 +09001716func (library *libraryDecorator) exportVersioningMacroIfNeeded(ctx android.BaseModuleContext) {
Colin Cross127bb8b2020-12-16 16:46:01 -08001717 if library.buildStubs() && library.stubsVersion() != "" && !library.skipAPIDefine {
Jiyong Park892a98f2020-12-14 09:20:00 +09001718 name := versioningMacroName(ctx.Module().(*Module).ImplementationModuleName(ctx))
Jooyung Han11b0fbd2021-02-05 02:28:22 +09001719 apiLevel, err := android.ApiLevelFromUser(ctx, library.stubsVersion())
1720 if err != nil {
1721 ctx.ModuleErrorf("Can't export version macro: %s", err.Error())
1722 }
1723 library.reexportFlags("-D" + name + "=" + strconv.Itoa(apiLevel.FinalOrPreviewInt()))
Jiyong Park892a98f2020-12-14 09:20:00 +09001724 }
1725}
1726
Chris Parsons3c27ca32020-11-20 12:42:07 -05001727// buildStatic returns true if this library should be built as a static library.
Colin Crossb916a382016-07-29 17:28:03 -07001728func (library *libraryDecorator) buildStatic() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001729 return library.MutatedProperties.BuildStatic &&
1730 BoolDefault(library.StaticProperties.Static.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001731}
1732
Chris Parsons3c27ca32020-11-20 12:42:07 -05001733// buildShared returns true if this library should be built as a shared library.
Colin Crossb916a382016-07-29 17:28:03 -07001734func (library *libraryDecorator) buildShared() bool {
Colin Crosse1bb5d02019-09-24 14:55:04 -07001735 return library.MutatedProperties.BuildShared &&
1736 BoolDefault(library.SharedProperties.Shared.Enabled, true)
Colin Cross4d9c2d12016-07-29 12:48:20 -07001737}
1738
Dan Willemsen5cb580f2016-09-26 17:33:01 -07001739func (library *libraryDecorator) objs() Objects {
1740 return library.objects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001741}
1742
Colin Cross0de8a1e2020-09-18 14:15:30 -07001743func (library *libraryDecorator) reuseObjs() Objects {
1744 return library.reuseObjects
Colin Cross4d9c2d12016-07-29 12:48:20 -07001745}
1746
Colin Cross26c34ed2016-09-30 17:10:16 -07001747func (library *libraryDecorator) toc() android.OptionalPath {
1748 return library.tocFile
1749}
1750
Jiyong Parkf1194352019-02-25 11:05:47 +09001751func (library *libraryDecorator) installSymlinkToRuntimeApex(ctx ModuleContext, file android.Path) {
1752 dir := library.baseInstaller.installDir(ctx)
1753 dirOnDevice := android.InstallPathToOnDevicePath(ctx, dir)
Florian Mayer95cd6db2023-03-23 17:48:07 -07001754 // libc_hwasan has relative_install_dir set, which would mess up the dir.Base() logic.
1755 // hardcode here because it's the only target, if we have other targets that use this
1756 // we can generalise this.
1757 var target string
1758 if ctx.baseModuleName() == "libc_hwasan" {
1759 target = "/" + filepath.Join("apex", "com.android.runtime", "lib64", "bionic", "hwasan", file.Base())
1760 } else {
1761 base := dir.Base()
1762 target = "/" + filepath.Join("apex", "com.android.runtime", base, "bionic", file.Base())
1763 }
Jiyong Parkf1194352019-02-25 11:05:47 +09001764 ctx.InstallAbsoluteSymlink(dir, file.Base(), target)
Jaewoong Jung18aefc12020-12-21 09:11:10 -08001765 library.postInstallCmds = append(library.postInstallCmds, makeSymlinkCmd(dirOnDevice, file.Base(), target))
Jiyong Parkf1194352019-02-25 11:05:47 +09001766}
1767
Colin Crossb916a382016-07-29 17:28:03 -07001768func (library *libraryDecorator) install(ctx ModuleContext, file android.Path) {
Colin Crossc43ae772017-04-14 15:42:53 -07001769 if library.shared() {
Kiyoung Kim9f26fcf2024-05-27 17:25:52 +09001770 if library.hasStubsVariants() && !ctx.Host() && ctx.directlyInAnyApex() {
Jiyong Parkf1194352019-02-25 11:05:47 +09001771 // Bionic libraries (e.g. libc.so) is installed to the bootstrap subdirectory.
1772 // The original path becomes a symlink to the corresponding file in the
1773 // runtime APEX.
Colin Cross3b19f5d2019-09-17 14:45:31 -07001774 translatedArch := ctx.Target().NativeBridge == android.NativeBridgeEnabled
Colin Cross56a83212020-09-15 18:30:11 -07001775 if InstallToBootstrap(ctx.baseModuleName(), ctx.Config()) && !library.buildStubs() &&
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001776 !translatedArch && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() {
Martin Stjernholm279de572019-09-10 23:18:20 +01001777 if ctx.Device() {
Jiyong Parkc3e2c862019-03-16 01:10:08 +09001778 library.installSymlinkToRuntimeApex(ctx, file)
1779 }
Jiyong Park429660f2019-01-16 22:31:11 +09001780 library.baseInstaller.subDir = "bootstrap"
1781 }
Colin Cross127bb8b2020-12-16 16:46:01 -08001782 } else if ctx.directlyInAnyApex() && ctx.IsLlndk() && !isBionic(ctx.baseModuleName()) {
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001783 // Skip installing LLNDK (non-bionic) libraries moved to APEX.
Colin Crossa9c8c9f2020-12-16 10:20:23 -08001784 ctx.Module().HideFromMake()
Justin Yun8effde42017-06-23 19:24:43 +09001785 }
Przemyslaw Szczepaniake6fc5072019-07-12 14:06:23 +01001786
Colin Cross4d9c2d12016-07-29 12:48:20 -07001787 library.baseInstaller.install(ctx, file)
1788 }
Dan Albertf563d252017-10-13 00:29:00 -07001789
Dan Albert281f22b2017-12-13 15:03:47 -08001790 if Bool(library.Properties.Static_ndk_lib) && library.static() &&
Kiyoung Kimaa394802024-01-08 12:55:45 +09001791 !ctx.InVendorOrProduct() && !ctx.inRamdisk() && !ctx.inVendorRamdisk() && !ctx.inRecovery() && ctx.Device() &&
Jiyong Park7ed9de32018-10-15 22:25:07 +09001792 library.baseLinker.sanitize.isUnsanitizedVariant() &&
Colin Cross95b07f22020-12-16 11:06:50 -08001793 ctx.isForPlatform() && !ctx.isPreventInstall() {
Dan Albert4048bb02023-04-03 20:19:07 +00001794 installPath := getUnversionedLibraryInstallPath(ctx).Join(ctx, file.Base())
Dan Albertf563d252017-10-13 00:29:00 -07001795
1796 ctx.ModuleBuild(pctx, android.ModuleBuildParams{
1797 Rule: android.Cp,
1798 Description: "install " + installPath.Base(),
1799 Output: installPath,
1800 Input: file,
1801 })
1802
Colin Cross0875c522017-11-28 17:34:01 -08001803 library.ndkSysrootPath = installPath
Dan Albertf563d252017-10-13 00:29:00 -07001804 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07001805}
1806
Paul Duffin0cb37b92020-03-04 14:52:46 +00001807func (library *libraryDecorator) everInstallable() bool {
1808 // Only shared and static libraries are installed. Header libraries (which are
1809 // neither static or shared) are not installed.
1810 return library.shared() || library.static()
1811}
1812
Chris Parsons3c27ca32020-11-20 12:42:07 -05001813// static returns true if this library is for a "static' variant.
Colin Crossb916a382016-07-29 17:28:03 -07001814func (library *libraryDecorator) static() bool {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001815 return library.MutatedProperties.VariantIsStatic
Colin Cross4d9c2d12016-07-29 12:48:20 -07001816}
1817
Chris Parsons3c27ca32020-11-20 12:42:07 -05001818// shared returns true if this library is for a "shared' variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001819func (library *libraryDecorator) shared() bool {
1820 return library.MutatedProperties.VariantIsShared
1821}
1822
Chris Parsons3c27ca32020-11-20 12:42:07 -05001823// header returns true if this library is for a header-only variant.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001824func (library *libraryDecorator) header() bool {
Chris Parsons3c27ca32020-11-20 12:42:07 -05001825 // Neither "static" nor "shared" implies this library is header-only.
Colin Crossa48ab5b2017-02-14 15:28:44 -08001826 return !library.static() && !library.shared()
1827}
1828
Chris Parsons3c27ca32020-11-20 12:42:07 -05001829// setStatic marks the library variant as "static".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001830func (library *libraryDecorator) setStatic() {
1831 library.MutatedProperties.VariantIsStatic = true
1832 library.MutatedProperties.VariantIsShared = false
1833}
1834
Chris Parsons3c27ca32020-11-20 12:42:07 -05001835// setShared marks the library variant as "shared".
Colin Crossa48ab5b2017-02-14 15:28:44 -08001836func (library *libraryDecorator) setShared() {
1837 library.MutatedProperties.VariantIsStatic = false
1838 library.MutatedProperties.VariantIsShared = true
Colin Crossb916a382016-07-29 17:28:03 -07001839}
1840
Chris Parsons3c27ca32020-11-20 12:42:07 -05001841// BuildOnlyStatic disables building this library as a shared library.
Colin Crossab3b7322016-12-09 14:46:15 -08001842func (library *libraryDecorator) BuildOnlyStatic() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001843 library.MutatedProperties.BuildShared = false
Colin Crossab3b7322016-12-09 14:46:15 -08001844}
1845
Chris Parsons3c27ca32020-11-20 12:42:07 -05001846// BuildOnlyShared disables building this library as a static library.
Colin Crossab3b7322016-12-09 14:46:15 -08001847func (library *libraryDecorator) BuildOnlyShared() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001848 library.MutatedProperties.BuildStatic = false
Colin Crossab3b7322016-12-09 14:46:15 -08001849}
1850
Chris Parsons3c27ca32020-11-20 12:42:07 -05001851// HeaderOnly disables building this library as a shared or static library;
1852// the library only exists to propagate header file dependencies up the build graph.
Colin Cross5950f382016-12-13 12:50:57 -08001853func (library *libraryDecorator) HeaderOnly() {
Colin Crossa48ab5b2017-02-14 15:28:44 -08001854 library.MutatedProperties.BuildShared = false
1855 library.MutatedProperties.BuildStatic = false
Colin Cross5950f382016-12-13 12:50:57 -08001856}
1857
Colin Cross127bb8b2020-12-16 16:46:01 -08001858// hasLLNDKStubs returns true if this cc_library module has a variant that will build LLNDK stubs.
1859func (library *libraryDecorator) hasLLNDKStubs() bool {
Colin Cross203b4212021-04-26 17:19:41 -07001860 return String(library.Properties.Llndk.Symbol_file) != ""
Colin Cross0fb7fcd2021-03-02 11:00:07 -08001861}
1862
Colin Cross203b4212021-04-26 17:19:41 -07001863// hasLLNDKStubs returns true if this cc_library module has a variant that will build LLNDK stubs.
Colin Cross1f3f1302021-04-26 18:37:44 -07001864func (library *libraryDecorator) hasLLNDKHeaders() bool {
1865 return Bool(library.Properties.Llndk.Llndk_headers)
1866}
1867
Colin Cross5271fea2021-04-27 13:06:04 -07001868// hasVendorPublicLibrary returns true if this cc_library module has a variant that will build
1869// vendor public library stubs.
1870func (library *libraryDecorator) hasVendorPublicLibrary() bool {
1871 return String(library.Properties.Vendor_public_library.Symbol_file) != ""
1872}
1873
Colin Cross0477b422020-10-13 18:43:54 -07001874func (library *libraryDecorator) implementationModuleName(name string) string {
1875 return name
1876}
1877
Jiyong Park7ed9de32018-10-15 22:25:07 +09001878func (library *libraryDecorator) buildStubs() bool {
1879 return library.MutatedProperties.BuildStubs
1880}
1881
Jiyong Parka034b832019-08-27 14:02:19 +09001882func (library *libraryDecorator) symbolFileForAbiCheck(ctx ModuleContext) *string {
Hsin-Yi Chen8feb4132022-12-26 15:54:36 +08001883 if props := library.getHeaderAbiCheckerProperties(ctx); props.Symbol_file != nil {
1884 return props.Symbol_file
Jiyong Parka034b832019-08-27 14:02:19 +09001885 }
Colin Cross31076b32020-10-23 17:22:06 -07001886 if library.hasStubsVariants() && library.Properties.Stubs.Symbol_file != nil {
Jiyong Parka034b832019-08-27 14:02:19 +09001887 return library.Properties.Stubs.Symbol_file
1888 }
Hsin-Yi Chenf1f276c2024-03-11 20:02:34 +08001889 // TODO(b/309880485): Distinguish platform, NDK, LLNDK, and APEX version scripts.
1890 if library.baseLinker.Properties.Version_script != nil {
1891 return library.baseLinker.Properties.Version_script
1892 }
Jiyong Parka034b832019-08-27 14:02:19 +09001893 return nil
1894}
1895
Colin Crossc88c2722020-09-28 17:32:47 -07001896func (library *libraryDecorator) hasStubsVariants() bool {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001897 // Just having stubs.symbol_file is enough to create a stub variant. In that case
1898 // the stub for the future API level is created.
1899 return library.Properties.Stubs.Symbol_file != nil ||
1900 len(library.Properties.Stubs.Versions) > 0
Colin Crossc88c2722020-09-28 17:32:47 -07001901}
1902
Alan Stokes73feba32022-11-14 12:21:24 +00001903func (library *libraryDecorator) isStubsImplementationRequired() bool {
1904 return BoolDefault(library.Properties.Stubs.Implementation_installable, true)
1905}
1906
Colin Crossadd04a82024-05-22 09:57:59 -07001907func (library *libraryDecorator) stubsVersions(ctx android.BaseModuleContext) []string {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001908 if !library.hasStubsVariants() {
1909 return nil
1910 }
1911
Kiyoung Kimaa394802024-01-08 12:55:45 +09001912 if library.hasLLNDKStubs() && ctx.Module().(*Module).InVendorOrProduct() {
Jooyung Han5e8994e2024-03-12 14:12:12 +09001913 // LLNDK libraries only need a single stubs variant (""), which is
1914 // added automatically in createVersionVariations().
1915 return nil
Colin Crossc1b36442021-05-06 13:42:48 -07001916 }
1917
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001918 // Future API level is implicitly added if there isn't
Jooyung Han5e8994e2024-03-12 14:12:12 +09001919 versions := addCurrentVersionIfNotPresent(library.Properties.Stubs.Versions)
1920 normalizeVersions(ctx, versions)
1921 return versions
Sam Delmerico75dbca22023-04-20 13:13:25 +00001922}
1923
1924func addCurrentVersionIfNotPresent(vers []string) []string {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001925 if inList(android.FutureApiLevel.String(), vers) {
1926 return vers
1927 }
1928 // In some cases, people use the raw value "10000" in the versions property.
1929 // We shouldn't add the future API level in that case, otherwise there will
1930 // be two identical versions.
1931 if inList(strconv.Itoa(android.FutureApiLevel.FinalOrFutureInt()), vers) {
1932 return vers
1933 }
1934 return append(vers, android.FutureApiLevel.String())
Colin Crossc88c2722020-09-28 17:32:47 -07001935}
1936
1937func (library *libraryDecorator) setStubsVersion(version string) {
1938 library.MutatedProperties.StubsVersion = version
1939}
1940
Jiyong Park7ed9de32018-10-15 22:25:07 +09001941func (library *libraryDecorator) stubsVersion() string {
1942 return library.MutatedProperties.StubsVersion
1943}
1944
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001945func (library *libraryDecorator) setBuildStubs(isLatest bool) {
Colin Crossc88c2722020-09-28 17:32:47 -07001946 library.MutatedProperties.BuildStubs = true
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001947 library.MutatedProperties.IsLatestVersion = isLatest
Colin Crossc88c2722020-09-28 17:32:47 -07001948}
1949
1950func (library *libraryDecorator) setAllStubsVersions(versions []string) {
1951 library.MutatedProperties.AllStubsVersions = versions
1952}
1953
1954func (library *libraryDecorator) allStubsVersions() []string {
1955 return library.MutatedProperties.AllStubsVersions
1956}
1957
Jooyung Hanad4c1872020-02-27 17:56:44 +09001958func (library *libraryDecorator) isLatestStubVersion() bool {
Jiyong Parkd4a3a132021-03-17 20:21:35 +09001959 return library.MutatedProperties.IsLatestVersion
Jooyung Hanad4c1872020-02-27 17:56:44 +09001960}
1961
Jiyong Parka90ca002019-10-07 15:47:24 +09001962func (library *libraryDecorator) availableFor(what string) bool {
1963 var list []string
1964 if library.static() {
1965 list = library.StaticProperties.Static.Apex_available
1966 } else if library.shared() {
1967 list = library.SharedProperties.Shared.Apex_available
1968 }
1969 if len(list) == 0 {
1970 return false
1971 }
1972 return android.CheckAvailableForApex(what, list)
1973}
1974
Colin Cross1bc94122021-10-28 13:25:54 -07001975func (library *libraryDecorator) installable() *bool {
1976 if library.static() {
1977 return library.StaticProperties.Static.Installable
1978 } else if library.shared() {
1979 return library.SharedProperties.Shared.Installable
1980 }
1981 return nil
1982}
1983
Jingwen Chen8ac7d7d2023-03-20 11:05:16 +00001984func (library *libraryDecorator) makeUninstallable(mod *Module) {
1985 if library.static() && library.buildStatic() && !library.buildStubs() {
1986 // If we're asked to make a static library uninstallable we don't do
1987 // anything since AndroidMkEntries always sets LOCAL_UNINSTALLABLE_MODULE
1988 // for these entries. This is done to still get the make targets for NOTICE
1989 // files from notice_files.mk, which other libraries might depend on.
1990 return
1991 }
1992 mod.ModuleBase.MakeUninstallable()
1993}
1994
Jihoon Kangf78a8902022-09-01 22:47:07 +00001995func (library *libraryDecorator) getPartition() string {
1996 return library.path.Partition()
1997}
1998
Colin Crossceaa5322021-09-28 16:37:50 -07001999func (library *libraryDecorator) getAPIListCoverageXMLPath() android.ModuleOutPath {
2000 return library.apiListCoverageXmlPath
2001}
2002
Inseob Kima1888ce2022-10-04 14:42:02 +09002003func (library *libraryDecorator) overriddenModules() []string {
2004 return library.Properties.Overrides
2005}
2006
2007var _ overridable = (*libraryDecorator)(nil)
2008
Colin Cross571cccf2019-02-04 11:22:08 -08002009var versioningMacroNamesListKey = android.NewOnceKey("versioningMacroNamesList")
2010
Chris Parsons3c27ca32020-11-20 12:42:07 -05002011// versioningMacroNamesList returns a singleton map, where keys are "version macro names",
2012// and values are the module name responsible for registering the version macro name.
2013//
2014// Version macros are used when building against stubs, to provide version information about
2015// the stub. Only stub libraries should have an entry in this list.
2016//
2017// For example, when building against libFoo#ver, __LIBFOO_API__ macro is set to ver so
2018// that headers from libFoo can be conditionally compiled (this may hide APIs
2019// that are not available for the version).
2020//
2021// This map is used to ensure that there aren't conflicts between these version macro names.
Jiyong Parkda732bd2018-11-02 18:23:15 +09002022func versioningMacroNamesList(config android.Config) *map[string]string {
Colin Cross571cccf2019-02-04 11:22:08 -08002023 return config.Once(versioningMacroNamesListKey, func() interface{} {
Jiyong Parkda732bd2018-11-02 18:23:15 +09002024 m := make(map[string]string)
2025 return &m
2026 }).(*map[string]string)
2027}
2028
2029// alphanumeric and _ characters are preserved.
2030// other characters are all converted to _
2031var charsNotForMacro = regexp.MustCompile("[^a-zA-Z0-9_]+")
2032
Chris Parsons3c27ca32020-11-20 12:42:07 -05002033// versioningMacroName returns the canonical version macro name for the given module.
Jiyong Parkda732bd2018-11-02 18:23:15 +09002034func versioningMacroName(moduleName string) string {
2035 macroName := charsNotForMacro.ReplaceAllString(moduleName, "_")
Jooyung Hanb04a4992020-03-13 18:57:35 +09002036 macroName = strings.ToUpper(macroName)
Jiyong Parkda732bd2018-11-02 18:23:15 +09002037 return "__" + macroName + "_API__"
2038}
2039
Chris Parsons3c27ca32020-11-20 12:42:07 -05002040// NewLibrary builds and returns a new Module corresponding to a C++ library.
2041// Individual module implementations which comprise a C++ library (or something like
2042// a C++ library) should call this function, set some fields on the result, and
2043// then call the Init function.
Colin Crossab3b7322016-12-09 14:46:15 -08002044func NewLibrary(hod android.HostOrDeviceSupported) (*Module, *libraryDecorator) {
Colin Cross4d9c2d12016-07-29 12:48:20 -07002045 module := newModule(hod, android.MultilibBoth)
2046
Colin Crossb916a382016-07-29 17:28:03 -07002047 library := &libraryDecorator{
Colin Crossa48ab5b2017-02-14 15:28:44 -08002048 MutatedProperties: LibraryMutatedProperties{
Colin Crossab3b7322016-12-09 14:46:15 -08002049 BuildShared: true,
2050 BuildStatic: true,
Colin Cross4d9c2d12016-07-29 12:48:20 -07002051 },
Colin Crossb916a382016-07-29 17:28:03 -07002052 baseCompiler: NewBaseCompiler(),
Dan Albert61f32122018-07-26 14:00:24 -07002053 baseLinker: NewBaseLinker(module.sanitize),
Colin Crossb916a382016-07-29 17:28:03 -07002054 baseInstaller: NewBaseInstaller("lib", "lib64", InstallInSystem),
Jayant Chowdhary3e231fd2017-02-08 13:45:53 -08002055 sabi: module.sabi,
Colin Cross4d9c2d12016-07-29 12:48:20 -07002056 }
2057
Colin Crossb916a382016-07-29 17:28:03 -07002058 module.compiler = library
2059 module.linker = library
2060 module.installer = library
Colin Cross31076b32020-10-23 17:22:06 -07002061 module.library = library
Colin Crossb916a382016-07-29 17:28:03 -07002062
2063 return module, library
2064}
2065
Colin Cross10d22312017-05-03 11:01:58 -07002066// connects a shared library to a static library in order to reuse its .o files to avoid
2067// compiling source files twice.
2068func reuseStaticLibrary(mctx android.BottomUpMutatorContext, static, shared *Module) {
2069 if staticCompiler, ok := static.compiler.(*libraryDecorator); ok {
2070 sharedCompiler := shared.compiler.(*libraryDecorator)
Dan Willemsen3a26eef2018-12-03 15:25:46 -08002071
2072 // Check libraries in addition to cflags, since libraries may be exporting different
2073 // include directories.
Cole Fauste96c16a2024-06-13 14:51:14 -07002074 if len(staticCompiler.StaticProperties.Static.Cflags.GetOrDefault(mctx, nil)) == 0 &&
2075 len(sharedCompiler.SharedProperties.Shared.Cflags.GetOrDefault(mctx, nil)) == 0 &&
Colin Crosse1bb5d02019-09-24 14:55:04 -07002076 len(staticCompiler.StaticProperties.Static.Whole_static_libs) == 0 &&
2077 len(sharedCompiler.SharedProperties.Shared.Whole_static_libs) == 0 &&
2078 len(staticCompiler.StaticProperties.Static.Static_libs) == 0 &&
2079 len(sharedCompiler.SharedProperties.Shared.Static_libs) == 0 &&
2080 len(staticCompiler.StaticProperties.Static.Shared_libs) == 0 &&
2081 len(sharedCompiler.SharedProperties.Shared.Shared_libs) == 0 &&
Martin Stjernholm10566a02020-03-24 01:19:52 +00002082 // Compare System_shared_libs properties with nil because empty lists are
2083 // semantically significant for them.
Colin Crosse1bb5d02019-09-24 14:55:04 -07002084 staticCompiler.StaticProperties.Static.System_shared_libs == nil &&
2085 sharedCompiler.SharedProperties.Shared.System_shared_libs == nil {
Colin Cross10d22312017-05-03 11:01:58 -07002086
2087 mctx.AddInterVariantDependency(reuseObjTag, shared, static)
2088 sharedCompiler.baseCompiler.Properties.OriginalSrcs =
2089 sharedCompiler.baseCompiler.Properties.Srcs
2090 sharedCompiler.baseCompiler.Properties.Srcs = nil
2091 sharedCompiler.baseCompiler.Properties.Generated_sources = nil
2092 }
Colin Cross0de8a1e2020-09-18 14:15:30 -07002093
2094 // This dep is just to reference static variant from shared variant
2095 mctx.AddInterVariantDependency(staticVariantTag, shared, static)
Colin Cross10d22312017-05-03 11:01:58 -07002096 }
2097}
2098
Chris Parsons3c27ca32020-11-20 12:42:07 -05002099// LinkageMutator adds "static" or "shared" variants for modules depending
2100// on whether the module can be built as a static library or a shared library.
Colin Crosse40b4ea2018-10-02 22:25:58 -07002101func LinkageMutator(mctx android.BottomUpMutatorContext) {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08002102 ccPrebuilt := false
Colin Crossb916a382016-07-29 17:28:03 -07002103 if m, ok := mctx.Module().(*Module); ok && m.linker != nil {
Jaewoong Jung18aefc12020-12-21 09:11:10 -08002104 _, ccPrebuilt = m.linker.(prebuiltLibraryInterface)
Ivan Lozano52767be2019-10-18 14:49:46 -07002105 }
Jaewoong Jung18aefc12020-12-21 09:11:10 -08002106 if ccPrebuilt {
Ivan Lozano52767be2019-10-18 14:49:46 -07002107 library := mctx.Module().(*Module).linker.(prebuiltLibraryInterface)
Colin Cross33b2fb72019-05-14 14:07:01 -07002108
Paul Duffinf5ea9e12020-02-21 10:57:00 +00002109 // Differentiate between header only and building an actual static/shared library
Colin Cross127bb8b2020-12-16 16:46:01 -08002110 buildStatic := library.buildStatic()
2111 buildShared := library.buildShared()
2112 if buildStatic || buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00002113 // Always create both the static and shared variants for prebuilt libraries, and then disable the one
2114 // that is not being used. This allows them to share the name of a cc_library module, which requires that
2115 // all the variants of the cc_library also exist on the prebuilt.
2116 modules := mctx.CreateLocalVariations("static", "shared")
2117 static := modules[0].(*Module)
2118 shared := modules[1].(*Module)
Colin Cross33b2fb72019-05-14 14:07:01 -07002119
Paul Duffinf5ea9e12020-02-21 10:57:00 +00002120 static.linker.(prebuiltLibraryInterface).setStatic()
2121 shared.linker.(prebuiltLibraryInterface).setShared()
Colin Cross33b2fb72019-05-14 14:07:01 -07002122
Colin Cross127bb8b2020-12-16 16:46:01 -08002123 if buildShared {
Colin Cross81ca6cd2020-08-06 17:46:48 -07002124 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08002125 } else if buildStatic {
Colin Cross81ca6cd2020-08-06 17:46:48 -07002126 mctx.AliasVariation("static")
2127 }
2128
Colin Cross127bb8b2020-12-16 16:46:01 -08002129 if !buildStatic {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00002130 static.linker.(prebuiltLibraryInterface).disablePrebuilt()
2131 }
Colin Cross127bb8b2020-12-16 16:46:01 -08002132 if !buildShared {
Paul Duffinf5ea9e12020-02-21 10:57:00 +00002133 shared.linker.(prebuiltLibraryInterface).disablePrebuilt()
2134 }
2135 } else {
2136 // Header only
Colin Crossb916a382016-07-29 17:28:03 -07002137 }
Paul Duffinf5ea9e12020-02-21 10:57:00 +00002138
Ivan Lozano0a468a42024-05-13 21:03:34 -04002139 } else if library, ok := mctx.Module().(LinkableInterface); ok && (library.CcLibraryInterface() || library.RustLibraryInterface()) {
Ivan Lozano2b262972019-11-21 12:30:50 -08002140 // Non-cc.Modules may need an empty variant for their mutators.
2141 variations := []string{}
2142 if library.NonCcVariants() {
2143 variations = append(variations, "")
2144 }
Colin Cross127bb8b2020-12-16 16:46:01 -08002145 isLLNDK := false
2146 if m, ok := mctx.Module().(*Module); ok {
Colin Cross203b4212021-04-26 17:19:41 -07002147 isLLNDK = m.IsLlndk()
Colin Cross127bb8b2020-12-16 16:46:01 -08002148 }
2149 buildStatic := library.BuildStaticVariant() && !isLLNDK
2150 buildShared := library.BuildSharedVariant()
2151 if buildStatic && buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08002152 variations := append([]string{"static", "shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07002153
2154 modules := mctx.CreateLocalVariations(variations...)
2155 static := modules[0].(LinkableInterface)
2156 shared := modules[1].(LinkableInterface)
Ivan Lozano52767be2019-10-18 14:49:46 -07002157 static.SetStatic()
2158 shared.SetShared()
2159
2160 if _, ok := library.(*Module); ok {
2161 reuseStaticLibrary(mctx, static.(*Module), shared.(*Module))
2162 }
Colin Cross81ca6cd2020-08-06 17:46:48 -07002163 mctx.AliasVariation("shared")
Colin Cross127bb8b2020-12-16 16:46:01 -08002164 } else if buildStatic {
Ivan Lozano2b262972019-11-21 12:30:50 -08002165 variations := append([]string{"static"}, variations...)
2166
2167 modules := mctx.CreateLocalVariations(variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07002168 modules[0].(LinkableInterface).SetStatic()
Colin Cross81ca6cd2020-08-06 17:46:48 -07002169 mctx.AliasVariation("static")
Colin Cross127bb8b2020-12-16 16:46:01 -08002170 } else if buildShared {
Ivan Lozano2b262972019-11-21 12:30:50 -08002171 variations := append([]string{"shared"}, variations...)
Ivan Lozano52767be2019-10-18 14:49:46 -07002172
Ivan Lozano2b262972019-11-21 12:30:50 -08002173 modules := mctx.CreateLocalVariations(variations...)
2174 modules[0].(LinkableInterface).SetShared()
Colin Cross81ca6cd2020-08-06 17:46:48 -07002175 mctx.AliasVariation("shared")
Ivan Lozano2b262972019-11-21 12:30:50 -08002176 } else if len(variations) > 0 {
2177 mctx.CreateLocalVariations(variations...)
Colin Cross81ca6cd2020-08-06 17:46:48 -07002178 mctx.AliasVariation(variations[0])
Ivan Lozano2b262972019-11-21 12:30:50 -08002179 }
Ivan Lozanofd47b1a2024-05-17 14:13:41 -04002180 if library.BuildRlibVariant() && library.IsRustFFI() && !buildStatic {
2181 // Rust modules do not build static libs, but rlibs are used as if they
2182 // were via `static_libs`. Thus we need to alias the BuildRlibVariant
2183 // to "static" for Rust FFI libraries.
2184 mctx.CreateAliasVariation("static", "")
2185 }
Colin Crossb916a382016-07-29 17:28:03 -07002186 }
Colin Cross4d9c2d12016-07-29 12:48:20 -07002187}
Jiyong Park7ed9de32018-10-15 22:25:07 +09002188
Chris Parsons3c27ca32020-11-20 12:42:07 -05002189// normalizeVersions modifies `versions` in place, so that each raw version
2190// string becomes its normalized canonical form.
2191// Validates that the versions in `versions` are specified in least to greatest order.
Colin Cross8ff10582023-12-07 13:10:56 -08002192func normalizeVersions(ctx android.BaseModuleContext, versions []string) {
Dan Albertc8060532020-07-22 22:32:17 -07002193 var previous android.ApiLevel
Jooyung Hanad4c1872020-02-27 17:56:44 +09002194 for i, v := range versions {
Dan Albertc8060532020-07-22 22:32:17 -07002195 ver, err := android.ApiLevelFromUser(ctx, v)
Jooyung Hanad4c1872020-02-27 17:56:44 +09002196 if err != nil {
Jooyung Hanaed150d2020-04-02 01:41:41 +09002197 ctx.PropertyErrorf("versions", "%s", err.Error())
2198 return
Jooyung Hanad4c1872020-02-27 17:56:44 +09002199 }
Dan Albertc8060532020-07-22 22:32:17 -07002200 if i > 0 && ver.LessThanOrEqualTo(previous) {
2201 ctx.PropertyErrorf("versions", "not sorted: %v", versions)
2202 }
2203 versions[i] = ver.String()
2204 previous = ver
Jooyung Hanaed150d2020-04-02 01:41:41 +09002205 }
Jooyung Hanad4c1872020-02-27 17:56:44 +09002206}
2207
Colin Crossadd04a82024-05-22 09:57:59 -07002208func perApiVersionVariations(mctx android.BaseModuleContext, minSdkVersion string) []string {
Colin Crossbbc941b2020-09-30 12:27:01 -07002209 from, err := nativeApiLevelFromUser(mctx, minSdkVersion)
2210 if err != nil {
2211 mctx.PropertyErrorf("min_sdk_version", err.Error())
Colin Crossadd04a82024-05-22 09:57:59 -07002212 return []string{""}
Colin Crossbbc941b2020-09-30 12:27:01 -07002213 }
2214
Colin Crossadd04a82024-05-22 09:57:59 -07002215 return ndkLibraryVersions(mctx, from)
Colin Crossbbc941b2020-09-30 12:27:01 -07002216}
2217
Liz Kammer23942242022-04-08 15:41:00 -04002218func canBeOrLinkAgainstVersionVariants(module interface {
Jooyung Han624d35c2020-04-10 12:57:24 +09002219 Host() bool
2220 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07002221 InVendorRamdisk() bool
Jooyung Han624d35c2020-04-10 12:57:24 +09002222}) bool {
Jose Galmes6f843bc2020-12-11 13:36:29 -08002223 return !module.Host() && !module.InRamdisk() && !module.InVendorRamdisk()
Jooyung Han624d35c2020-04-10 12:57:24 +09002224}
2225
Liz Kammer23942242022-04-08 15:41:00 -04002226func canBeVersionVariant(module interface {
Colin Cross3146c5c2020-09-30 15:34:40 -07002227 Host() bool
2228 InRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -07002229 InVendorRamdisk() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07002230 CcLibraryInterface() bool
2231 Shared() bool
Colin Cross3146c5c2020-09-30 15:34:40 -07002232}) bool {
Liz Kammer23942242022-04-08 15:41:00 -04002233 return canBeOrLinkAgainstVersionVariants(module) &&
Colin Crossa717db72020-10-23 14:53:06 -07002234 module.CcLibraryInterface() && module.Shared()
Colin Cross3146c5c2020-09-30 15:34:40 -07002235}
2236
Colin Cross127bb8b2020-12-16 16:46:01 -08002237func moduleLibraryInterface(module blueprint.Module) libraryInterface {
Colin Cross31076b32020-10-23 17:22:06 -07002238 if m, ok := module.(*Module); ok {
2239 return m.library
2240 }
2241 return nil
2242}
2243
Liz Kammer23942242022-04-08 15:41:00 -04002244// setStubsVersions normalizes the versions in the Stubs.Versions property into MutatedProperties.AllStubsVersions.
Colin Crossadd04a82024-05-22 09:57:59 -07002245func setStubsVersions(mctx android.BaseModuleContext, library libraryInterface, module *Module) {
Liz Kammer23942242022-04-08 15:41:00 -04002246 if !library.buildShared() || !canBeVersionVariant(module) {
2247 return
Colin Crossd1f898e2020-08-18 18:35:15 -07002248 }
Liz Kammer23942242022-04-08 15:41:00 -04002249 versions := library.stubsVersions(mctx)
Liz Kammer23942242022-04-08 15:41:00 -04002250 if mctx.Failed() {
2251 return
2252 }
2253 // Set the versions on the pre-mutated module so they can be read by any llndk modules that
2254 // depend on the implementation library and haven't been mutated yet.
2255 library.setAllStubsVersions(versions)
Colin Crossd1f898e2020-08-18 18:35:15 -07002256}
Jooyung Han61b66e92020-03-21 14:21:46 +00002257
Colin Crossadd04a82024-05-22 09:57:59 -07002258// versionTransitionMutator splits a module into the mandatory non-stubs variant
Colin Crossd1f898e2020-08-18 18:35:15 -07002259// (which is unnamed) and zero or more stubs variants.
Colin Crossadd04a82024-05-22 09:57:59 -07002260type versionTransitionMutator struct{}
2261
2262func (versionTransitionMutator) Split(ctx android.BaseModuleContext) []string {
2263 if ctx.Os() != android.Android {
2264 return []string{""}
Liz Kammer23942242022-04-08 15:41:00 -04002265 }
2266
Colin Crossadd04a82024-05-22 09:57:59 -07002267 m, ok := ctx.Module().(*Module)
2268 if library := moduleLibraryInterface(ctx.Module()); library != nil && canBeVersionVariant(m) {
2269 setStubsVersions(ctx, library, m)
Liz Kammer23942242022-04-08 15:41:00 -04002270
Colin Crossadd04a82024-05-22 09:57:59 -07002271 return append(slices.Clone(library.allStubsVersions()), "")
2272 } else if ok && m.SplitPerApiLevel() && m.IsSdkVariant() {
2273 return perApiVersionVariations(ctx, m.MinSdkVersion())
Colin Crossbbc941b2020-09-30 12:27:01 -07002274 }
2275
Colin Crossadd04a82024-05-22 09:57:59 -07002276 return []string{""}
2277}
2278
2279func (versionTransitionMutator) OutgoingTransition(ctx android.OutgoingTransitionContext, sourceVariation string) string {
2280 return ""
2281}
2282
2283func (versionTransitionMutator) IncomingTransition(ctx android.IncomingTransitionContext, incomingVariation string) string {
2284 if ctx.Os() != android.Android {
2285 return ""
2286 }
2287 m, ok := ctx.Module().(*Module)
2288 if library := moduleLibraryInterface(ctx.Module()); library != nil && canBeVersionVariant(m) {
2289 if incomingVariation == "latest" {
2290 latestVersion := ""
2291 versions := library.allStubsVersions()
2292 if len(versions) > 0 {
2293 latestVersion = versions[len(versions)-1]
2294 }
2295 return latestVersion
Colin Crossbbc941b2020-09-30 12:27:01 -07002296 }
Colin Crossadd04a82024-05-22 09:57:59 -07002297 return incomingVariation
2298 } else if ok && m.SplitPerApiLevel() && m.IsSdkVariant() {
2299 // If this module only has variants with versions and the incoming dependency doesn't specify which one
2300 // is needed then assume the latest version.
2301 if incomingVariation == "" {
2302 return android.FutureApiLevel.String()
2303 }
2304 return incomingVariation
2305 }
2306
2307 return ""
2308}
2309
2310func (versionTransitionMutator) Mutate(ctx android.BottomUpMutatorContext, variation string) {
2311 // Optimization: return early if this module can't be affected.
2312 if ctx.Os() != android.Android {
2313 return
2314 }
2315
2316 m, ok := ctx.Module().(*Module)
2317 if library := moduleLibraryInterface(ctx.Module()); library != nil && canBeVersionVariant(m) {
2318 isLLNDK := m.IsLlndk()
2319 isVendorPublicLibrary := m.IsVendorPublicLibrary()
2320 isImportedApiLibrary := m.isImportedApiLibrary()
2321
2322 if variation != "" || isLLNDK || isVendorPublicLibrary || isImportedApiLibrary {
2323 // A stubs or LLNDK stubs variant.
2324 if m.sanitize != nil {
2325 m.sanitize.Properties.ForceDisable = true
2326 }
2327 if m.stl != nil {
2328 m.stl.Properties.Stl = StringPtr("none")
2329 }
2330 m.Properties.PreventInstall = true
2331 lib := moduleLibraryInterface(m)
2332 allStubsVersions := library.allStubsVersions()
2333 isLatest := len(allStubsVersions) > 0 && variation == allStubsVersions[len(allStubsVersions)-1]
2334 lib.setBuildStubs(isLatest)
2335 }
2336 if variation != "" {
2337 // A non-LLNDK stubs module is hidden from make
2338 library.setStubsVersion(variation)
2339 m.Properties.HideFromMake = true
2340 } else {
2341 // A non-LLNDK implementation module has a dependency to all stubs versions
2342 for _, version := range library.allStubsVersions() {
2343 ctx.AddVariationDependencies([]blueprint.Variation{{"version", version}},
2344 stubImplDepTag, ctx.ModuleName())
2345 }
2346 }
2347 } else if ok && m.SplitPerApiLevel() && m.IsSdkVariant() {
2348 m.Properties.Sdk_version = StringPtr(variation)
2349 m.Properties.Min_sdk_version = StringPtr(variation)
Jiyong Park7ed9de32018-10-15 22:25:07 +09002350 }
Jiyong Park7ed9de32018-10-15 22:25:07 +09002351}
Colin Crossd7227f92019-09-05 14:26:33 -07002352
2353// maybeInjectBoringSSLHash adds a rule to run bssl_inject_hash on the output file if the module has the
2354// inject_bssl_hash or if any static library dependencies have inject_bssl_hash set. It returns the output path
2355// that the linked output file should be written to.
2356// TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
2357func maybeInjectBoringSSLHash(ctx android.ModuleContext, outputFile android.ModuleOutPath,
2358 inject *bool, fileName string) android.ModuleOutPath {
2359 // TODO(b/137267623): Remove this in favor of a cc_genrule when they support operating on shared libraries.
2360 injectBoringSSLHash := Bool(inject)
2361 ctx.VisitDirectDeps(func(dep android.Module) {
Colin Cross6e511a92020-07-27 21:26:48 -07002362 if tag, ok := ctx.OtherModuleDependencyTag(dep).(libraryDependencyTag); ok && tag.static() {
Colin Crossd7227f92019-09-05 14:26:33 -07002363 if cc, ok := dep.(*Module); ok {
2364 if library, ok := cc.linker.(*libraryDecorator); ok {
2365 if Bool(library.Properties.Inject_bssl_hash) {
2366 injectBoringSSLHash = true
2367 }
2368 }
2369 }
2370 }
2371 })
2372 if injectBoringSSLHash {
2373 hashedOutputfile := outputFile
2374 outputFile = android.PathForModuleOut(ctx, "unhashed", fileName)
2375
Colin Crossf1a035e2020-11-16 17:32:30 -08002376 rule := android.NewRuleBuilder(pctx, ctx)
Colin Crossd7227f92019-09-05 14:26:33 -07002377 rule.Command().
Colin Crossf1a035e2020-11-16 17:32:30 -08002378 BuiltTool("bssl_inject_hash").
Colin Crossd7227f92019-09-05 14:26:33 -07002379 FlagWithInput("-in-object ", outputFile).
2380 FlagWithOutput("-o ", hashedOutputfile)
Colin Crossf1a035e2020-11-16 17:32:30 -08002381 rule.Build("injectCryptoHash", "inject crypto hash")
Colin Crossd7227f92019-09-05 14:26:33 -07002382 }
2383
2384 return outputFile
2385}