blob: 9010a1a893a53830be72299b913c88063c9979f4 [file] [log] [blame]
Paul Duffin2f6bc092019-12-13 10:40:56 +00001// Copyright 2019 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 (
18 "path/filepath"
Paul Duffin2f6bc092019-12-13 10:40:56 +000019
20 "android/soong/android"
Martin Stjernholmcd07bce2020-03-10 22:37:59 +000021
Paul Duffin2f6bc092019-12-13 10:40:56 +000022 "github.com/google/blueprint"
Paul Duffin13f02712020-03-06 12:30:43 +000023 "github.com/google/blueprint/proptools"
Paul Duffin2f6bc092019-12-13 10:40:56 +000024)
25
26// This file contains support for using cc library modules within an sdk.
27
Paul Duffina0843f62019-12-13 19:50:38 +000028var sharedLibrarySdkMemberType = &librarySdkMemberType{
29 SdkMemberTypeBase: android.SdkMemberTypeBase{
Martin Stjernholmcaa47d72020-07-11 04:52:24 +010030 PropertyName: "native_shared_libs",
31 SupportsSdk: true,
32 HostOsDependent: true,
Paul Duffina0843f62019-12-13 19:50:38 +000033 },
34 prebuiltModuleType: "cc_prebuilt_library_shared",
35 linkTypes: []string{"shared"},
36}
37
38var staticLibrarySdkMemberType = &librarySdkMemberType{
39 SdkMemberTypeBase: android.SdkMemberTypeBase{
Martin Stjernholmcaa47d72020-07-11 04:52:24 +010040 PropertyName: "native_static_libs",
41 SupportsSdk: true,
42 HostOsDependent: true,
Paul Duffina0843f62019-12-13 19:50:38 +000043 },
44 prebuiltModuleType: "cc_prebuilt_library_static",
45 linkTypes: []string{"static"},
46}
47
Paul Duffin9b76c0b2020-03-12 10:24:35 +000048var staticAndSharedLibrarySdkMemberType = &librarySdkMemberType{
49 SdkMemberTypeBase: android.SdkMemberTypeBase{
Martin Stjernholmcaa47d72020-07-11 04:52:24 +010050 PropertyName: "native_libs",
51 SupportsSdk: true,
52 HostOsDependent: true,
Paul Duffin9b76c0b2020-03-12 10:24:35 +000053 },
54 prebuiltModuleType: "cc_prebuilt_library",
55 linkTypes: []string{"static", "shared"},
56}
57
Paul Duffin255f18e2019-12-13 11:22:16 +000058func init() {
59 // Register sdk member types.
Paul Duffina0843f62019-12-13 19:50:38 +000060 android.RegisterSdkMemberType(sharedLibrarySdkMemberType)
61 android.RegisterSdkMemberType(staticLibrarySdkMemberType)
Paul Duffin9b76c0b2020-03-12 10:24:35 +000062 android.RegisterSdkMemberType(staticAndSharedLibrarySdkMemberType)
Paul Duffin2f6bc092019-12-13 10:40:56 +000063}
64
65type librarySdkMemberType struct {
Paul Duffin255f18e2019-12-13 11:22:16 +000066 android.SdkMemberTypeBase
67
Paul Duffin2f6bc092019-12-13 10:40:56 +000068 prebuiltModuleType string
69
Martin Stjernholmcd07bce2020-03-10 22:37:59 +000070 noOutputFiles bool // True if there are no srcs files.
71
72 // The set of link types supported. A set of "static", "shared", or nil to
73 // skip link type variations.
Paul Duffin2f6bc092019-12-13 10:40:56 +000074 linkTypes []string
75}
76
77func (mt *librarySdkMemberType) AddDependencies(mctx android.BottomUpMutatorContext, dependencyTag blueprint.DependencyTag, names []string) {
78 targets := mctx.MultiTargets()
79 for _, lib := range names {
80 for _, target := range targets {
81 name, version := StubsLibNameAndVersion(lib)
82 if version == "" {
Colin Crossd1f898e2020-08-18 18:35:15 -070083 version = "latest"
Paul Duffin2f6bc092019-12-13 10:40:56 +000084 }
Colin Cross42507332020-08-21 16:15:23 -070085 variations := target.Variations()
86 if mctx.Device() {
87 variations = append(variations,
Colin Cross3146c5c2020-09-30 15:34:40 -070088 blueprint.Variation{Mutator: "image", Variation: android.CoreVariation})
Colin Cross42507332020-08-21 16:15:23 -070089 }
Paul Duffin91756d22020-02-21 16:29:57 +000090 if mt.linkTypes == nil {
Colin Cross42507332020-08-21 16:15:23 -070091 mctx.AddFarVariationDependencies(variations, dependencyTag, name)
Paul Duffin91756d22020-02-21 16:29:57 +000092 } else {
93 for _, linkType := range mt.linkTypes {
Colin Cross42507332020-08-21 16:15:23 -070094 libVariations := append(variations,
95 blueprint.Variation{Mutator: "link", Variation: linkType})
Colin Crossa717db72020-10-23 14:53:06 -070096 if mctx.Device() && linkType == "shared" {
97 libVariations = append(libVariations,
98 blueprint.Variation{Mutator: "version", Variation: version})
99 }
Colin Cross42507332020-08-21 16:15:23 -0700100 mctx.AddFarVariationDependencies(libVariations, dependencyTag, name)
Paul Duffin91756d22020-02-21 16:29:57 +0000101 }
Paul Duffin2f6bc092019-12-13 10:40:56 +0000102 }
103 }
104 }
105}
106
107func (mt *librarySdkMemberType) IsInstance(module android.Module) bool {
Paul Duffina0843f62019-12-13 19:50:38 +0000108 // Check the module to see if it can be used with this module type.
109 if m, ok := module.(*Module); ok {
110 for _, allowableMemberType := range m.sdkMemberTypes {
111 if allowableMemberType == mt {
112 return true
113 }
114 }
115 }
116
117 return false
Paul Duffin2f6bc092019-12-13 10:40:56 +0000118}
119
Paul Duffin3a4eb502020-03-19 16:11:18 +0000120func (mt *librarySdkMemberType) AddPrebuiltModule(ctx android.SdkMemberContext, member android.SdkMember) android.BpModule {
121 pbm := ctx.SnapshotBuilder().AddPrebuiltModule(member, mt.prebuiltModuleType)
Paul Duffin0c394f32020-03-05 14:09:58 +0000122
123 ccModule := member.Variants()[0].(*Module)
124
Paul Duffind6abaa72020-09-07 16:39:22 +0100125 if proptools.Bool(ccModule.Properties.Recovery_available) {
126 pbm.AddProperty("recovery_available", true)
127 }
128
Paul Duffind1edbd42020-08-13 19:45:31 +0100129 if proptools.Bool(ccModule.VendorProperties.Vendor_available) {
130 pbm.AddProperty("vendor_available", true)
131 }
132
Justin Yunebcf0c52021-01-08 18:00:19 +0900133 if proptools.Bool(ccModule.VendorProperties.Odm_available) {
134 pbm.AddProperty("odm_available", true)
135 }
136
Justin Yun63e9ec72020-10-29 16:49:43 +0900137 if proptools.Bool(ccModule.VendorProperties.Product_available) {
138 pbm.AddProperty("product_available", true)
139 }
140
Paul Duffin0c394f32020-03-05 14:09:58 +0000141 sdkVersion := ccModule.SdkVersion()
142 if sdkVersion != "" {
143 pbm.AddProperty("sdk_version", sdkVersion)
144 }
Paul Duffin2f6bc092019-12-13 10:40:56 +0000145
Paul Duffin13f02712020-03-06 12:30:43 +0000146 stl := ccModule.stl.Properties.Stl
147 if stl != nil {
Paul Duffin0174d8d2020-03-11 18:42:08 +0000148 pbm.AddProperty("stl", proptools.String(stl))
Paul Duffin13f02712020-03-06 12:30:43 +0000149 }
Martin Stjernholm47ed3522020-06-17 22:52:25 +0100150
151 if lib, ok := ccModule.linker.(*libraryDecorator); ok {
152 uhs := lib.Properties.Unique_host_soname
153 if uhs != nil {
154 pbm.AddProperty("unique_host_soname", proptools.Bool(uhs))
155 }
156 }
157
Paul Duffin0174d8d2020-03-11 18:42:08 +0000158 return pbm
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000159}
Paul Duffin2f6bc092019-12-13 10:40:56 +0000160
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000161func (mt *librarySdkMemberType) CreateVariantPropertiesStruct() android.SdkMemberProperties {
162 return &nativeLibInfoProperties{memberType: mt}
Paul Duffin2f6bc092019-12-13 10:40:56 +0000163}
164
Liz Kammerb6a55bf2021-04-12 15:42:51 -0400165func isBazelOutDirectory(p android.Path) bool {
166 _, bazel := p.(android.BazelOutPath)
167 return bazel
168}
169
Paul Duffin2f6bc092019-12-13 10:40:56 +0000170func isGeneratedHeaderDirectory(p android.Path) bool {
171 _, gen := p.(android.WritablePath)
Liz Kammerb6a55bf2021-04-12 15:42:51 -0400172 // TODO(b/183213331): Here we assume that bazel-based headers are not generated; we need
173 // to support generated headers in mixed builds.
174 return gen && !isBazelOutDirectory(p)
Paul Duffin2f6bc092019-12-13 10:40:56 +0000175}
176
Paul Duffin64f54b02020-02-20 14:33:54 +0000177type includeDirsProperty struct {
178 // Accessor to retrieve the paths
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000179 pathsGetter func(libInfo *nativeLibInfoProperties) android.Paths
Paul Duffin64f54b02020-02-20 14:33:54 +0000180
181 // The name of the property in the prebuilt library, "" means there is no property.
182 propertyName string
183
184 // The directory within the snapshot directory into which items should be copied.
185 snapshotDir string
186
187 // True if the items on the path should be copied.
188 copy bool
189
190 // True if the paths represent directories, files if they represent files.
191 dirs bool
Paul Duffin74fc1902020-01-23 11:45:03 +0000192}
193
Paul Duffin64f54b02020-02-20 14:33:54 +0000194var includeDirProperties = []includeDirsProperty{
195 {
196 // ExportedIncludeDirs lists directories that contains some header files to be
197 // copied into a directory in the snapshot. The snapshot directories must be added to
198 // the export_include_dirs property in the prebuilt module in the snapshot.
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000199 pathsGetter: func(libInfo *nativeLibInfoProperties) android.Paths { return libInfo.ExportedIncludeDirs },
Paul Duffin64f54b02020-02-20 14:33:54 +0000200 propertyName: "export_include_dirs",
201 snapshotDir: nativeIncludeDir,
202 copy: true,
203 dirs: true,
204 },
205 {
206 // ExportedSystemIncludeDirs lists directories that contains some system header files to
207 // be copied into a directory in the snapshot. The snapshot directories must be added to
208 // the export_system_include_dirs property in the prebuilt module in the snapshot.
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000209 pathsGetter: func(libInfo *nativeLibInfoProperties) android.Paths { return libInfo.ExportedSystemIncludeDirs },
Paul Duffin64f54b02020-02-20 14:33:54 +0000210 propertyName: "export_system_include_dirs",
211 snapshotDir: nativeIncludeDir,
212 copy: true,
213 dirs: true,
214 },
215 {
Paul Duffin7a7d0672021-02-17 12:17:40 +0000216 // ExportedGeneratedIncludeDirs lists directories that contains some header files
217 // that are explicitly listed in the ExportedGeneratedHeaders property. So, the contents
Paul Duffin64f54b02020-02-20 14:33:54 +0000218 // of these directories do not need to be copied, but these directories do need adding to
219 // the export_include_dirs property in the prebuilt module in the snapshot.
Paul Duffin7a7d0672021-02-17 12:17:40 +0000220 pathsGetter: func(libInfo *nativeLibInfoProperties) android.Paths { return libInfo.ExportedGeneratedIncludeDirs },
Paul Duffin64f54b02020-02-20 14:33:54 +0000221 propertyName: "export_include_dirs",
222 snapshotDir: nativeGeneratedIncludeDir,
223 copy: false,
224 dirs: true,
225 },
226 {
Paul Duffin7a7d0672021-02-17 12:17:40 +0000227 // ExportedGeneratedHeaders lists header files that are in one of the directories
228 // specified in ExportedGeneratedIncludeDirs must be copied into the snapshot.
229 // As they are in a directory in ExportedGeneratedIncludeDirs they do not need adding to a
Paul Duffin64f54b02020-02-20 14:33:54 +0000230 // property in the prebuilt module in the snapshot.
Paul Duffin7a7d0672021-02-17 12:17:40 +0000231 pathsGetter: func(libInfo *nativeLibInfoProperties) android.Paths { return libInfo.ExportedGeneratedHeaders },
Paul Duffin64f54b02020-02-20 14:33:54 +0000232 propertyName: "",
233 snapshotDir: nativeGeneratedIncludeDir,
234 copy: true,
235 dirs: false,
236 },
237}
238
239// Add properties that may, or may not, be arch specific.
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000240func addPossiblyArchSpecificProperties(sdkModuleContext android.ModuleContext, builder android.SnapshotBuilder, libInfo *nativeLibInfoProperties, outputProperties android.BpPropertySet) {
241
Martin Stjernholmb0249572020-09-15 02:32:35 +0100242 outputProperties.AddProperty("sanitize", &libInfo.Sanitize)
Martin Stjernholmfbb486f2020-08-21 18:43:51 +0100243
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000244 // Copy the generated library to the snapshot and add a reference to it in the .bp module.
245 if libInfo.outputFile != nil {
246 nativeLibraryPath := nativeLibraryPathFor(libInfo)
247 builder.CopyToSnapshot(libInfo.outputFile, nativeLibraryPath)
248 outputProperties.AddProperty("srcs", []string{nativeLibraryPath})
249 }
Paul Duffin64f54b02020-02-20 14:33:54 +0000250
Paul Duffin13f02712020-03-06 12:30:43 +0000251 if len(libInfo.SharedLibs) > 0 {
252 outputProperties.AddPropertyWithTag("shared_libs", libInfo.SharedLibs, builder.SdkMemberReferencePropertyTag(false))
253 }
254
Martin Stjernholm10566a02020-03-24 01:19:52 +0000255 // SystemSharedLibs needs to be propagated if it's a list, even if it's empty,
256 // so check for non-nil instead of nonzero length.
257 if libInfo.SystemSharedLibs != nil {
Paul Duffin13f02712020-03-06 12:30:43 +0000258 outputProperties.AddPropertyWithTag("system_shared_libs", libInfo.SystemSharedLibs, builder.SdkMemberReferencePropertyTag(false))
259 }
260
Paul Duffin64f54b02020-02-20 14:33:54 +0000261 // Map from property name to the include dirs to add to the prebuilt module in the snapshot.
262 includeDirs := make(map[string][]string)
263
264 // Iterate over each include directory property, copying files and collating property
265 // values where necessary.
266 for _, propertyInfo := range includeDirProperties {
267 // Calculate the base directory in the snapshot into which the files will be copied.
Paul Duffin42dd4e62021-02-22 11:35:24 +0000268 // lib.archType is "" for common properties.
Paul Duffined62b9c2020-06-16 16:12:50 +0100269 targetDir := filepath.Join(libInfo.OsPrefix(), libInfo.archType, propertyInfo.snapshotDir)
Paul Duffin64f54b02020-02-20 14:33:54 +0000270
271 propertyName := propertyInfo.propertyName
272
273 // Iterate over each path in one of the include directory properties.
274 for _, path := range propertyInfo.pathsGetter(libInfo) {
Paul Duffin42dd4e62021-02-22 11:35:24 +0000275 inputPath := path.String()
276
277 // Map the input path to a snapshot relative path. The mapping is independent of the module
278 // that references them so that if multiple modules within the same snapshot export the same
279 // header files they end up in the same place in the snapshot and so do not get duplicated.
280 targetRelativePath := inputPath
281 if isGeneratedHeaderDirectory(path) {
282 // Remove everything up to the .intermediates/ from the generated output directory to
283 // leave a module relative path.
284 base := android.PathForIntermediates(sdkModuleContext, "")
285 targetRelativePath = android.Rel(sdkModuleContext, base.String(), inputPath)
286 }
287
288 snapshotRelativePath := filepath.Join(targetDir, targetRelativePath)
Paul Duffin64f54b02020-02-20 14:33:54 +0000289
290 // Copy the files/directories when necessary.
291 if propertyInfo.copy {
292 if propertyInfo.dirs {
293 // When copying a directory glob and copy all the headers within it.
294 // TODO(jiyong) copy headers having other suffixes
Paul Duffin42dd4e62021-02-22 11:35:24 +0000295 headers, _ := sdkModuleContext.GlobWithDeps(inputPath+"/**/*.h", nil)
Paul Duffin64f54b02020-02-20 14:33:54 +0000296 for _, file := range headers {
297 src := android.PathForSource(sdkModuleContext, file)
Paul Duffin42dd4e62021-02-22 11:35:24 +0000298
299 // The destination path in the snapshot is constructed from the snapshot relative path
300 // of the input directory and the input directory relative path of the header file.
301 inputRelativePath := android.Rel(sdkModuleContext, inputPath, file)
302 dest := filepath.Join(snapshotRelativePath, inputRelativePath)
Paul Duffin64f54b02020-02-20 14:33:54 +0000303 builder.CopyToSnapshot(src, dest)
304 }
305 } else {
Paul Duffin42dd4e62021-02-22 11:35:24 +0000306 // Otherwise, just copy the file to its snapshot relative path.
307 builder.CopyToSnapshot(path, snapshotRelativePath)
Paul Duffin64f54b02020-02-20 14:33:54 +0000308 }
309 }
310
311 // Only directories are added to a property.
312 if propertyInfo.dirs {
Paul Duffin42dd4e62021-02-22 11:35:24 +0000313 includeDirs[propertyName] = append(includeDirs[propertyName], snapshotRelativePath)
Paul Duffin64f54b02020-02-20 14:33:54 +0000314 }
315 }
Paul Duffin74fc1902020-01-23 11:45:03 +0000316 }
Paul Duffin64f54b02020-02-20 14:33:54 +0000317
318 // Add the collated include dir properties to the output.
Colin Cross2c033612020-09-11 15:44:31 -0700319 for _, property := range android.SortedStringKeys(includeDirs) {
320 outputProperties.AddProperty(property, includeDirs[property])
Paul Duffin74fc1902020-01-23 11:45:03 +0000321 }
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100322
Martin Stjernholm618b6712020-09-24 16:53:04 +0100323 if len(libInfo.StubsVersions) > 0 {
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100324 stubsSet := outputProperties.AddPropertySet("stubs")
Martin Stjernholm618b6712020-09-24 16:53:04 +0100325 stubsSet.AddProperty("versions", libInfo.StubsVersions)
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100326 }
Paul Duffin74fc1902020-01-23 11:45:03 +0000327}
328
Paul Duffin2f6bc092019-12-13 10:40:56 +0000329const (
330 nativeIncludeDir = "include"
331 nativeGeneratedIncludeDir = "include_gen"
332 nativeStubDir = "lib"
333)
334
335// path to the native library. Relative to <sdk_root>/<api_dir>
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000336func nativeLibraryPathFor(lib *nativeLibInfoProperties) string {
Paul Duffina04c1072020-03-02 10:16:35 +0000337 return filepath.Join(lib.OsPrefix(), lib.archType,
Paul Duffin2f6bc092019-12-13 10:40:56 +0000338 nativeStubDir, lib.outputFile.Base())
339}
340
Paul Duffin2f6bc092019-12-13 10:40:56 +0000341// nativeLibInfoProperties represents properties of a native lib
342//
343// The exported (capitalized) fields will be examined and may be changed during common value extraction.
344// The unexported fields will be left untouched.
345type nativeLibInfoProperties struct {
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000346 android.SdkMemberPropertiesBase
347
348 memberType *librarySdkMemberType
349
Paul Duffin2f6bc092019-12-13 10:40:56 +0000350 // archType is not exported as if set (to a non default value) it is always arch specific.
351 // This is "" for common properties.
352 archType string
353
Paul Duffin5efd1982020-02-20 14:33:54 +0000354 // The list of possibly common exported include dirs.
355 //
356 // This field is exported as its contents may not be arch specific.
Paul Duffin864e1b42020-05-06 10:23:19 +0100357 ExportedIncludeDirs android.Paths `android:"arch_variant"`
Paul Duffin2f6bc092019-12-13 10:40:56 +0000358
Paul Duffin5efd1982020-02-20 14:33:54 +0000359 // The list of arch specific exported generated include dirs.
360 //
Paul Duffin7a7d0672021-02-17 12:17:40 +0000361 // This field is exported as its contents may not be arch specific, e.g. protos.
362 ExportedGeneratedIncludeDirs android.Paths `android:"arch_variant"`
Paul Duffin5efd1982020-02-20 14:33:54 +0000363
364 // The list of arch specific exported generated header files.
365 //
Paul Duffin7a7d0672021-02-17 12:17:40 +0000366 // This field is exported as its contents may not be arch specific, e.g. protos.
367 ExportedGeneratedHeaders android.Paths `android:"arch_variant"`
Paul Duffin2f6bc092019-12-13 10:40:56 +0000368
Paul Duffin5efd1982020-02-20 14:33:54 +0000369 // The list of possibly common exported system include dirs.
370 //
371 // This field is exported as its contents may not be arch specific.
Paul Duffin864e1b42020-05-06 10:23:19 +0100372 ExportedSystemIncludeDirs android.Paths `android:"arch_variant"`
Paul Duffin5efd1982020-02-20 14:33:54 +0000373
374 // The list of possibly common exported flags.
375 //
376 // This field is exported as its contents may not be arch specific.
Paul Duffin864e1b42020-05-06 10:23:19 +0100377 ExportedFlags []string `android:"arch_variant"`
Paul Duffin5efd1982020-02-20 14:33:54 +0000378
Paul Duffin13f02712020-03-06 12:30:43 +0000379 // The set of shared libraries
380 //
381 // This field is exported as its contents may not be arch specific.
Paul Duffin864e1b42020-05-06 10:23:19 +0100382 SharedLibs []string `android:"arch_variant"`
Paul Duffin13f02712020-03-06 12:30:43 +0000383
Martin Stjernholm10566a02020-03-24 01:19:52 +0000384 // The set of system shared libraries. Note nil and [] are semantically
385 // distinct - see BaseLinkerProperties.System_shared_libs.
Paul Duffin13f02712020-03-06 12:30:43 +0000386 //
387 // This field is exported as its contents may not be arch specific.
Paul Duffin864e1b42020-05-06 10:23:19 +0100388 SystemSharedLibs []string `android:"arch_variant"`
Paul Duffin13f02712020-03-06 12:30:43 +0000389
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100390 // The specific stubs version for the lib variant, or empty string if stubs
391 // are not in use.
Paul Duffin7a1f7f32020-05-04 15:32:08 +0100392 //
Martin Stjernholm618b6712020-09-24 16:53:04 +0100393 // Marked 'ignored-on-host' as the AllStubsVersions() from which this is
394 // initialized is not set on host and the stubs.versions property which this
395 // is written to does not vary by arch so cannot be android specific.
396 StubsVersions []string `sdk:"ignored-on-host"`
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100397
Martin Stjernholmb0249572020-09-15 02:32:35 +0100398 // Value of SanitizeProperties.Sanitize. Several - but not all - of these
399 // affect the expanded variants. All are propagated to avoid entangling the
400 // sanitizer logic with the snapshot generation.
401 Sanitize SanitizeUserProps `android:"arch_variant"`
Martin Stjernholmfbb486f2020-08-21 18:43:51 +0100402
Paul Duffin2f6bc092019-12-13 10:40:56 +0000403 // outputFile is not exported as it is always arch specific.
404 outputFile android.Path
405}
406
Paul Duffin3a4eb502020-03-19 16:11:18 +0000407func (p *nativeLibInfoProperties) PopulateFromVariant(ctx android.SdkMemberContext, variant android.Module) {
Martin Stjernholm59e0c7a2020-10-28 23:38:33 +0000408 addOutputFile := true
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000409 ccModule := variant.(*Module)
410
Martin Stjernholm59e0c7a2020-10-28 23:38:33 +0000411 if s := ccModule.sanitize; s != nil {
412 // We currently do not capture sanitizer flags for libs with sanitizers
413 // enabled, because they may vary among variants that cannot be represented
414 // in the input blueprint files. In particular, sanitizerDepsMutator enables
415 // various sanitizers on dependencies, but in many cases only on static
416 // ones, and we cannot specify sanitizer flags at the link type level (i.e.
417 // in StaticOrSharedProperties).
418 if s.isUnsanitizedVariant() {
419 // This still captures explicitly disabled sanitizers, which may be
420 // necessary to avoid cyclic dependencies.
421 p.Sanitize = s.Properties.Sanitize
422 } else {
423 // Do not add the output file to the snapshot if we don't represent it
424 // properly.
425 addOutputFile = false
426 }
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000427 }
428
Colin Cross0de8a1e2020-09-18 14:15:30 -0700429 exportedInfo := ctx.SdkModuleContext().OtherModuleProvider(variant, FlagExporterInfoProvider).(FlagExporterInfo)
430
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000431 // Separate out the generated include dirs (which are arch specific) from the
432 // include dirs (which may not be).
433 exportedIncludeDirs, exportedGeneratedIncludeDirs := android.FilterPathListPredicate(
Colin Cross0de8a1e2020-09-18 14:15:30 -0700434 exportedInfo.IncludeDirs, isGeneratedHeaderDirectory)
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000435
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000436 p.archType = ccModule.Target().Arch.ArchType.String()
Paul Duffin9b76c0b2020-03-12 10:24:35 +0000437
438 // Make sure that the include directories are unique.
439 p.ExportedIncludeDirs = android.FirstUniquePaths(exportedIncludeDirs)
Paul Duffin7a7d0672021-02-17 12:17:40 +0000440 p.ExportedGeneratedIncludeDirs = android.FirstUniquePaths(exportedGeneratedIncludeDirs)
Paul Duffinab5467d2020-06-18 16:31:04 +0100441
442 // Take a copy before filtering out duplicates to avoid changing the slice owned by the
443 // ccModule.
Colin Cross0de8a1e2020-09-18 14:15:30 -0700444 dirs := append(android.Paths(nil), exportedInfo.SystemIncludeDirs...)
Paul Duffinab5467d2020-06-18 16:31:04 +0100445 p.ExportedSystemIncludeDirs = android.FirstUniquePaths(dirs)
Paul Duffin9b76c0b2020-03-12 10:24:35 +0000446
Colin Cross0de8a1e2020-09-18 14:15:30 -0700447 p.ExportedFlags = exportedInfo.Flags
Paul Duffin13f02712020-03-06 12:30:43 +0000448 if ccModule.linker != nil {
449 specifiedDeps := specifiedDeps{}
450 specifiedDeps = ccModule.linker.linkerSpecifiedDeps(specifiedDeps)
451
Colin Cross31076b32020-10-23 17:22:06 -0700452 if lib := ccModule.library; lib != nil {
453 if !lib.hasStubsVariants() {
454 // Propagate dynamic dependencies for implementation libs, but not stubs.
455 p.SharedLibs = specifiedDeps.sharedLibs
456 } else {
457 // TODO(b/169373910): 1. Only output the specific version (from
458 // ccModule.StubsVersion()) if the module is versioned. 2. Ensure that all
459 // the versioned stub libs are retained in the prebuilt tree; currently only
460 // the stub corresponding to ccModule.StubsVersion() is.
461 p.StubsVersions = lib.allStubsVersions()
462 }
Martin Stjernholmcc330d62020-04-21 20:45:35 +0100463 }
Paul Duffin13f02712020-03-06 12:30:43 +0000464 p.SystemSharedLibs = specifiedDeps.systemSharedLibs
465 }
Paul Duffin7a7d0672021-02-17 12:17:40 +0000466 p.ExportedGeneratedHeaders = exportedInfo.GeneratedHeaders
Martin Stjernholmc5dd4f72020-04-01 20:38:01 +0100467
Martin Stjernholm59e0c7a2020-10-28 23:38:33 +0000468 if !p.memberType.noOutputFiles && addOutputFile {
469 p.outputFile = getRequiredMemberOutputFile(ctx, ccModule)
Martin Stjernholmfbb486f2020-08-21 18:43:51 +0100470 }
Paul Duffin88f2fbe2020-02-27 16:00:53 +0000471}
472
Paul Duffin712993c2020-05-05 14:11:57 +0100473func getRequiredMemberOutputFile(ctx android.SdkMemberContext, ccModule *Module) android.Path {
474 var path android.Path
475 outputFile := ccModule.OutputFile()
476 if outputFile.Valid() {
477 path = outputFile.Path()
478 } else {
479 ctx.SdkModuleContext().ModuleErrorf("member variant %s does not have a valid output file", ccModule)
480 }
481 return path
482}
483
Paul Duffin3a4eb502020-03-19 16:11:18 +0000484func (p *nativeLibInfoProperties) AddToPropertySet(ctx android.SdkMemberContext, propertySet android.BpPropertySet) {
485 addPossiblyArchSpecificProperties(ctx.SdkModuleContext(), ctx.SnapshotBuilder(), p, propertySet)
Paul Duffin2f6bc092019-12-13 10:40:56 +0000486}