blob: 0b1147ef2c8501a4ced251f75293166b46288b64 [file] [log] [blame]
Inseob Kimde5744a2020-12-02 13:14:28 +09001// Copyright 2020 The Android Open Source Project
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.
14package cc
15
16// This file defines snapshot prebuilt modules, e.g. vendor snapshot and recovery snapshot. Such
17// snapshot modules will override original source modules with setting BOARD_VNDK_VERSION, with
18// snapshot mutators and snapshot information maps which are also defined in this file.
19
20import (
Justin DeMartino383bfb32021-02-24 10:49:43 -080021 "path/filepath"
Inseob Kimde5744a2020-12-02 13:14:28 +090022 "strings"
Inseob Kimde5744a2020-12-02 13:14:28 +090023
24 "android/soong/android"
Jose Galmes6f843bc2020-12-11 13:36:29 -080025
Colin Crosse0edaf92021-01-11 17:31:17 -080026 "github.com/google/blueprint"
Inseob Kimde5744a2020-12-02 13:14:28 +090027)
28
29// Defines the specifics of different images to which the snapshot process is applicable, e.g.,
30// vendor, recovery, ramdisk.
31type snapshotImage interface {
Jose Galmes6f843bc2020-12-11 13:36:29 -080032 // Returns true if a snapshot should be generated for this image.
33 shouldGenerateSnapshot(ctx android.SingletonContext) bool
34
Inseob Kimde5744a2020-12-02 13:14:28 +090035 // Function that returns true if the module is included in this image.
36 // Using a function return instead of a value to prevent early
37 // evalution of a function that may be not be defined.
Ivan Lozanod7586b62021-04-01 09:49:36 -040038 inImage(m LinkableInterface) func() bool
Inseob Kimde5744a2020-12-02 13:14:28 +090039
Justin Yune09ac172021-01-20 19:49:01 +090040 // Returns true if the module is private and must not be included in the
41 // snapshot. For example VNDK-private modules must return true for the
42 // vendor snapshots. But false for the recovery snapshots.
Ivan Lozanod7586b62021-04-01 09:49:36 -040043 private(m LinkableInterface) bool
Inseob Kimde5744a2020-12-02 13:14:28 +090044
45 // Returns true if a dir under source tree is an SoC-owned proprietary
46 // directory, such as device/, vendor/, etc.
47 //
48 // For a given snapshot (e.g., vendor, recovery, etc.) if
Justin DeMartino383bfb32021-02-24 10:49:43 -080049 // isProprietaryPath(dir, deviceConfig) returns true, then the module in dir
50 // will be built from sources.
51 isProprietaryPath(dir string, deviceConfig android.DeviceConfig) bool
Inseob Kimde5744a2020-12-02 13:14:28 +090052
53 // Whether to include VNDK in the snapshot for this image.
54 includeVndk() bool
55
56 // Whether a given module has been explicitly excluded from the
57 // snapshot, e.g., using the exclude_from_vendor_snapshot or
58 // exclude_from_recovery_snapshot properties.
Ivan Lozanod7586b62021-04-01 09:49:36 -040059 excludeFromSnapshot(m LinkableInterface) bool
Jose Galmes6f843bc2020-12-11 13:36:29 -080060
Jose Galmes6f843bc2020-12-11 13:36:29 -080061 // Returns true if the build is using a snapshot for this image.
62 isUsingSnapshot(cfg android.DeviceConfig) bool
63
Colin Crosse0edaf92021-01-11 17:31:17 -080064 // Returns a version of which the snapshot should be used in this target.
65 // This will only be meaningful when isUsingSnapshot is true.
66 targetSnapshotVersion(cfg android.DeviceConfig) string
Inseob Kim7cf14652021-01-06 23:06:52 +090067
68 // Whether to exclude a given module from the directed snapshot or not.
69 // If the makefile variable DIRECTED_{IMAGE}_SNAPSHOT is true, directed snapshot is turned on,
70 // and only modules listed in {IMAGE}_SNAPSHOT_MODULES will be captured.
71 excludeFromDirectedSnapshot(cfg android.DeviceConfig, name string) bool
Colin Crosse0edaf92021-01-11 17:31:17 -080072
73 // The image variant name for this snapshot image.
74 // For example, recovery snapshot image will return "recovery", and vendor snapshot image will
75 // return "vendor." + version.
76 imageVariantName(cfg android.DeviceConfig) string
77
78 // The variant suffix for snapshot modules. For example, vendor snapshot modules will have
79 // ".vendor" as their suffix.
80 moduleNameSuffix() string
Inseob Kimde5744a2020-12-02 13:14:28 +090081}
82
83type vendorSnapshotImage struct{}
84type recoverySnapshotImage struct{}
85
Justin DeMartino383bfb32021-02-24 10:49:43 -080086type directoryMap map[string]bool
87
88var (
89 // Modules under following directories are ignored. They are OEM's and vendor's
90 // proprietary modules(device/, kernel/, vendor/, and hardware/).
91 defaultDirectoryExcludedMap = directoryMap{
92 "device": true,
93 "hardware": true,
94 "kernel": true,
95 "vendor": true,
96 }
97
98 // Modules under following directories are included as they are in AOSP,
99 // although hardware/ and kernel/ are normally for vendor's own.
100 defaultDirectoryIncludedMap = directoryMap{
101 "kernel/configs": true,
102 "kernel/prebuilts": true,
103 "kernel/tests": true,
104 "hardware/interfaces": true,
105 "hardware/libhardware": true,
106 "hardware/libhardware_legacy": true,
107 "hardware/ril": true,
108 }
109)
110
Colin Crosse0edaf92021-01-11 17:31:17 -0800111func (vendorSnapshotImage) init(ctx android.RegistrationContext) {
112 ctx.RegisterSingletonType("vendor-snapshot", VendorSnapshotSingleton)
113 ctx.RegisterModuleType("vendor_snapshot", vendorSnapshotFactory)
114 ctx.RegisterModuleType("vendor_snapshot_shared", VendorSnapshotSharedFactory)
115 ctx.RegisterModuleType("vendor_snapshot_static", VendorSnapshotStaticFactory)
116 ctx.RegisterModuleType("vendor_snapshot_header", VendorSnapshotHeaderFactory)
117 ctx.RegisterModuleType("vendor_snapshot_binary", VendorSnapshotBinaryFactory)
118 ctx.RegisterModuleType("vendor_snapshot_object", VendorSnapshotObjectFactory)
Inseob Kime9aec6a2021-01-05 20:03:22 +0900119
Colin Crosse0edaf92021-01-11 17:31:17 -0800120 ctx.RegisterSingletonType("vendor-fake-snapshot", VendorFakeSnapshotSingleton)
Inseob Kimde5744a2020-12-02 13:14:28 +0900121}
122
Jose Galmes6f843bc2020-12-11 13:36:29 -0800123func (vendorSnapshotImage) shouldGenerateSnapshot(ctx android.SingletonContext) bool {
124 // BOARD_VNDK_VERSION must be set to 'current' in order to generate a snapshot.
125 return ctx.DeviceConfig().VndkVersion() == "current"
126}
127
Ivan Lozanod7586b62021-04-01 09:49:36 -0400128func (vendorSnapshotImage) inImage(m LinkableInterface) func() bool {
Ivan Lozano3968d8f2020-12-14 11:27:52 -0500129 return m.InVendor
Inseob Kimde5744a2020-12-02 13:14:28 +0900130}
131
Ivan Lozanod7586b62021-04-01 09:49:36 -0400132func (vendorSnapshotImage) private(m LinkableInterface) bool {
Justin Yune09ac172021-01-20 19:49:01 +0900133 return m.IsVndkPrivate()
Inseob Kimde5744a2020-12-02 13:14:28 +0900134}
135
Justin DeMartino383bfb32021-02-24 10:49:43 -0800136func isDirectoryExcluded(dir string, excludedMap directoryMap, includedMap directoryMap) bool {
137 if dir == "." || dir == "/" {
138 return false
139 }
140 if includedMap[dir] {
141 return false
142 } else if excludedMap[dir] {
143 return true
144 } else if defaultDirectoryIncludedMap[dir] {
145 return false
146 } else if defaultDirectoryExcludedMap[dir] {
147 return true
148 } else {
149 return isDirectoryExcluded(filepath.Dir(dir), excludedMap, includedMap)
150 }
151}
152
153func (vendorSnapshotImage) isProprietaryPath(dir string, deviceConfig android.DeviceConfig) bool {
154 return isDirectoryExcluded(dir, deviceConfig.VendorSnapshotDirsExcludedMap(), deviceConfig.VendorSnapshotDirsIncludedMap())
Inseob Kimde5744a2020-12-02 13:14:28 +0900155}
156
157// vendor snapshot includes static/header libraries with vndk: {enabled: true}.
158func (vendorSnapshotImage) includeVndk() bool {
159 return true
160}
161
Ivan Lozanod7586b62021-04-01 09:49:36 -0400162func (vendorSnapshotImage) excludeFromSnapshot(m LinkableInterface) bool {
Inseob Kimde5744a2020-12-02 13:14:28 +0900163 return m.ExcludeFromVendorSnapshot()
164}
165
Jose Galmes6f843bc2020-12-11 13:36:29 -0800166func (vendorSnapshotImage) isUsingSnapshot(cfg android.DeviceConfig) bool {
167 vndkVersion := cfg.VndkVersion()
168 return vndkVersion != "current" && vndkVersion != ""
169}
170
Colin Crosse0edaf92021-01-11 17:31:17 -0800171func (vendorSnapshotImage) targetSnapshotVersion(cfg android.DeviceConfig) string {
172 return cfg.VndkVersion()
Jose Galmes6f843bc2020-12-11 13:36:29 -0800173}
174
Inseob Kim7cf14652021-01-06 23:06:52 +0900175// returns true iff a given module SHOULD BE EXCLUDED, false if included
176func (vendorSnapshotImage) excludeFromDirectedSnapshot(cfg android.DeviceConfig, name string) bool {
177 // If we're using full snapshot, not directed snapshot, capture every module
178 if !cfg.DirectedVendorSnapshot() {
179 return false
180 }
181 // Else, checks if name is in VENDOR_SNAPSHOT_MODULES.
182 return !cfg.VendorSnapshotModules()[name]
183}
184
Colin Crosse0edaf92021-01-11 17:31:17 -0800185func (vendorSnapshotImage) imageVariantName(cfg android.DeviceConfig) string {
186 return VendorVariationPrefix + cfg.VndkVersion()
187}
188
189func (vendorSnapshotImage) moduleNameSuffix() string {
Ivan Lozanoe6d30982021-02-05 10:57:43 -0500190 return VendorSuffix
Colin Crosse0edaf92021-01-11 17:31:17 -0800191}
192
193func (recoverySnapshotImage) init(ctx android.RegistrationContext) {
194 ctx.RegisterSingletonType("recovery-snapshot", RecoverySnapshotSingleton)
195 ctx.RegisterModuleType("recovery_snapshot", recoverySnapshotFactory)
196 ctx.RegisterModuleType("recovery_snapshot_shared", RecoverySnapshotSharedFactory)
197 ctx.RegisterModuleType("recovery_snapshot_static", RecoverySnapshotStaticFactory)
198 ctx.RegisterModuleType("recovery_snapshot_header", RecoverySnapshotHeaderFactory)
199 ctx.RegisterModuleType("recovery_snapshot_binary", RecoverySnapshotBinaryFactory)
200 ctx.RegisterModuleType("recovery_snapshot_object", RecoverySnapshotObjectFactory)
Inseob Kimde5744a2020-12-02 13:14:28 +0900201}
202
Jose Galmes6f843bc2020-12-11 13:36:29 -0800203func (recoverySnapshotImage) shouldGenerateSnapshot(ctx android.SingletonContext) bool {
204 // RECOVERY_SNAPSHOT_VERSION must be set to 'current' in order to generate a
205 // snapshot.
206 return ctx.DeviceConfig().RecoverySnapshotVersion() == "current"
207}
208
Ivan Lozanod7586b62021-04-01 09:49:36 -0400209func (recoverySnapshotImage) inImage(m LinkableInterface) func() bool {
Inseob Kimde5744a2020-12-02 13:14:28 +0900210 return m.InRecovery
211}
212
Justin Yune09ac172021-01-20 19:49:01 +0900213// recovery snapshot does not have private libraries.
Ivan Lozanod7586b62021-04-01 09:49:36 -0400214func (recoverySnapshotImage) private(m LinkableInterface) bool {
Justin Yune09ac172021-01-20 19:49:01 +0900215 return false
Inseob Kimde5744a2020-12-02 13:14:28 +0900216}
217
Justin DeMartino383bfb32021-02-24 10:49:43 -0800218func (recoverySnapshotImage) isProprietaryPath(dir string, deviceConfig android.DeviceConfig) bool {
219 return isDirectoryExcluded(dir, deviceConfig.RecoverySnapshotDirsExcludedMap(), deviceConfig.RecoverySnapshotDirsIncludedMap())
Inseob Kimde5744a2020-12-02 13:14:28 +0900220}
221
222// recovery snapshot does NOT treat vndk specially.
223func (recoverySnapshotImage) includeVndk() bool {
224 return false
225}
226
Ivan Lozanod7586b62021-04-01 09:49:36 -0400227func (recoverySnapshotImage) excludeFromSnapshot(m LinkableInterface) bool {
Inseob Kimde5744a2020-12-02 13:14:28 +0900228 return m.ExcludeFromRecoverySnapshot()
229}
230
Jose Galmes6f843bc2020-12-11 13:36:29 -0800231func (recoverySnapshotImage) isUsingSnapshot(cfg android.DeviceConfig) bool {
232 recoverySnapshotVersion := cfg.RecoverySnapshotVersion()
233 return recoverySnapshotVersion != "current" && recoverySnapshotVersion != ""
234}
235
Colin Crosse0edaf92021-01-11 17:31:17 -0800236func (recoverySnapshotImage) targetSnapshotVersion(cfg android.DeviceConfig) string {
237 return cfg.RecoverySnapshotVersion()
Jose Galmes6f843bc2020-12-11 13:36:29 -0800238}
239
Inseob Kim7cf14652021-01-06 23:06:52 +0900240func (recoverySnapshotImage) excludeFromDirectedSnapshot(cfg android.DeviceConfig, name string) bool {
Jose Galmes4c6895e2021-02-09 07:44:30 -0800241 // If we're using full snapshot, not directed snapshot, capture every module
242 if !cfg.DirectedRecoverySnapshot() {
243 return false
244 }
245 // Else, checks if name is in RECOVERY_SNAPSHOT_MODULES.
246 return !cfg.RecoverySnapshotModules()[name]
Inseob Kim7cf14652021-01-06 23:06:52 +0900247}
248
Colin Crosse0edaf92021-01-11 17:31:17 -0800249func (recoverySnapshotImage) imageVariantName(cfg android.DeviceConfig) string {
250 return android.RecoveryVariation
251}
252
253func (recoverySnapshotImage) moduleNameSuffix() string {
254 return recoverySuffix
255}
256
Inseob Kimde5744a2020-12-02 13:14:28 +0900257var vendorSnapshotImageSingleton vendorSnapshotImage
258var recoverySnapshotImageSingleton recoverySnapshotImage
259
260func init() {
Colin Crosse0edaf92021-01-11 17:31:17 -0800261 vendorSnapshotImageSingleton.init(android.InitRegistrationContext)
262 recoverySnapshotImageSingleton.init(android.InitRegistrationContext)
Inseob Kimde5744a2020-12-02 13:14:28 +0900263}
264
265const (
Colin Crosse0edaf92021-01-11 17:31:17 -0800266 snapshotHeaderSuffix = "_header."
267 snapshotSharedSuffix = "_shared."
268 snapshotStaticSuffix = "_static."
269 snapshotBinarySuffix = "_binary."
270 snapshotObjectSuffix = "_object."
Inseob Kimde5744a2020-12-02 13:14:28 +0900271)
272
Colin Crosse0edaf92021-01-11 17:31:17 -0800273type SnapshotProperties struct {
274 Header_libs []string `android:"arch_variant"`
275 Static_libs []string `android:"arch_variant"`
276 Shared_libs []string `android:"arch_variant"`
277 Vndk_libs []string `android:"arch_variant"`
278 Binaries []string `android:"arch_variant"`
279 Objects []string `android:"arch_variant"`
280}
281
282type snapshot struct {
283 android.ModuleBase
284
285 properties SnapshotProperties
286
287 baseSnapshot baseSnapshotDecorator
288
289 image snapshotImage
290}
291
292func (s *snapshot) ImageMutatorBegin(ctx android.BaseModuleContext) {
293 cfg := ctx.DeviceConfig()
294 if !s.image.isUsingSnapshot(cfg) || s.image.targetSnapshotVersion(cfg) != s.baseSnapshot.version() {
295 s.Disable()
296 }
297}
298
299func (s *snapshot) CoreVariantNeeded(ctx android.BaseModuleContext) bool {
300 return false
301}
302
303func (s *snapshot) RamdiskVariantNeeded(ctx android.BaseModuleContext) bool {
304 return false
305}
306
307func (s *snapshot) VendorRamdiskVariantNeeded(ctx android.BaseModuleContext) bool {
308 return false
309}
310
Inseob Kim08758f02021-04-08 21:13:22 +0900311func (s *snapshot) DebugRamdiskVariantNeeded(ctx android.BaseModuleContext) bool {
312 return false
313}
314
Colin Crosse0edaf92021-01-11 17:31:17 -0800315func (s *snapshot) RecoveryVariantNeeded(ctx android.BaseModuleContext) bool {
316 return false
317}
318
319func (s *snapshot) ExtraImageVariations(ctx android.BaseModuleContext) []string {
320 return []string{s.image.imageVariantName(ctx.DeviceConfig())}
321}
322
323func (s *snapshot) SetImageVariation(ctx android.BaseModuleContext, variation string, module android.Module) {
324}
325
326func (s *snapshot) GenerateAndroidBuildActions(ctx android.ModuleContext) {
327 // Nothing, the snapshot module is only used to forward dependency information in DepsMutator.
328}
329
Justin Yun07b9f862021-02-26 14:00:03 +0900330func getSnapshotNameSuffix(moduleSuffix, version, arch string) string {
331 versionSuffix := version
332 if arch != "" {
333 versionSuffix += "." + arch
334 }
335 return moduleSuffix + versionSuffix
336}
Colin Crosse0edaf92021-01-11 17:31:17 -0800337
Justin Yun07b9f862021-02-26 14:00:03 +0900338func (s *snapshot) DepsMutator(ctx android.BottomUpMutatorContext) {
339 collectSnapshotMap := func(names []string, snapshotSuffix, moduleSuffix string) map[string]string {
Colin Crosse0edaf92021-01-11 17:31:17 -0800340 snapshotMap := make(map[string]string)
Justin Yun48138672021-02-25 18:21:27 +0900341 for _, name := range names {
342 snapshotMap[name] = name +
Justin Yun07b9f862021-02-26 14:00:03 +0900343 getSnapshotNameSuffix(snapshotSuffix+moduleSuffix,
Jose Galmesf9523ed2021-04-06 19:48:10 -0700344 s.baseSnapshot.version(),
345 ctx.DeviceConfig().Arches()[0].ArchType.String())
Colin Crosse0edaf92021-01-11 17:31:17 -0800346 }
347 return snapshotMap
348 }
349
350 snapshotSuffix := s.image.moduleNameSuffix()
Justin Yun07b9f862021-02-26 14:00:03 +0900351 headers := collectSnapshotMap(s.properties.Header_libs, snapshotSuffix, snapshotHeaderSuffix)
352 binaries := collectSnapshotMap(s.properties.Binaries, snapshotSuffix, snapshotBinarySuffix)
353 objects := collectSnapshotMap(s.properties.Objects, snapshotSuffix, snapshotObjectSuffix)
354 staticLibs := collectSnapshotMap(s.properties.Static_libs, snapshotSuffix, snapshotStaticSuffix)
355 sharedLibs := collectSnapshotMap(s.properties.Shared_libs, snapshotSuffix, snapshotSharedSuffix)
356 vndkLibs := collectSnapshotMap(s.properties.Vndk_libs, "", vndkSuffix)
Colin Crosse0edaf92021-01-11 17:31:17 -0800357 for k, v := range vndkLibs {
358 sharedLibs[k] = v
359 }
Justin Yun07b9f862021-02-26 14:00:03 +0900360
Colin Crosse0edaf92021-01-11 17:31:17 -0800361 ctx.SetProvider(SnapshotInfoProvider, SnapshotInfo{
362 HeaderLibs: headers,
363 Binaries: binaries,
364 Objects: objects,
365 StaticLibs: staticLibs,
366 SharedLibs: sharedLibs,
367 })
368}
369
370type SnapshotInfo struct {
371 HeaderLibs, Binaries, Objects, StaticLibs, SharedLibs map[string]string
372}
373
374var SnapshotInfoProvider = blueprint.NewMutatorProvider(SnapshotInfo{}, "deps")
375
376var _ android.ImageInterface = (*snapshot)(nil)
377
378func vendorSnapshotFactory() android.Module {
379 return snapshotFactory(vendorSnapshotImageSingleton)
380}
381
382func recoverySnapshotFactory() android.Module {
383 return snapshotFactory(recoverySnapshotImageSingleton)
384}
385
386func snapshotFactory(image snapshotImage) android.Module {
387 snapshot := &snapshot{}
388 snapshot.image = image
389 snapshot.AddProperties(
390 &snapshot.properties,
391 &snapshot.baseSnapshot.baseProperties)
392 android.InitAndroidArchModule(snapshot, android.DeviceSupported, android.MultilibBoth)
393 return snapshot
394}
395
Inseob Kimde5744a2020-12-02 13:14:28 +0900396type baseSnapshotDecoratorProperties struct {
397 // snapshot version.
398 Version string
399
400 // Target arch name of the snapshot (e.g. 'arm64' for variant 'aosp_arm64')
401 Target_arch string
Jose Galmes6f843bc2020-12-11 13:36:29 -0800402
Colin Crossa8890802021-01-22 14:06:33 -0800403 // Suffix to be added to the module name when exporting to Android.mk, e.g. ".vendor".
Inseob Kim1b6fb872021-04-05 13:37:02 +0900404 Androidmk_suffix string `blueprint:"mutated"`
Colin Crossa8890802021-01-22 14:06:33 -0800405
Jose Galmes6f843bc2020-12-11 13:36:29 -0800406 // Suffix to be added to the module name, e.g., vendor_shared,
407 // recovery_shared, etc.
Colin Crosse0edaf92021-01-11 17:31:17 -0800408 ModuleSuffix string `blueprint:"mutated"`
Inseob Kimde5744a2020-12-02 13:14:28 +0900409}
410
411// baseSnapshotDecorator provides common basic functions for all snapshot modules, such as snapshot
412// version, snapshot arch, etc. It also adds a special suffix to Soong module name, so it doesn't
413// collide with source modules. e.g. the following example module,
414//
415// vendor_snapshot_static {
416// name: "libbase",
417// arch: "arm64",
418// version: 30,
419// ...
420// }
421//
422// will be seen as "libbase.vendor_static.30.arm64" by Soong.
423type baseSnapshotDecorator struct {
424 baseProperties baseSnapshotDecoratorProperties
Inseob Kim1b6fb872021-04-05 13:37:02 +0900425 image snapshotImage
Inseob Kimde5744a2020-12-02 13:14:28 +0900426}
427
428func (p *baseSnapshotDecorator) Name(name string) string {
429 return name + p.NameSuffix()
430}
431
432func (p *baseSnapshotDecorator) NameSuffix() string {
Justin Yun07b9f862021-02-26 14:00:03 +0900433 return getSnapshotNameSuffix(p.moduleSuffix(), p.version(), p.arch())
Inseob Kimde5744a2020-12-02 13:14:28 +0900434}
435
436func (p *baseSnapshotDecorator) version() string {
437 return p.baseProperties.Version
438}
439
440func (p *baseSnapshotDecorator) arch() string {
441 return p.baseProperties.Target_arch
442}
443
Colin Crosse0edaf92021-01-11 17:31:17 -0800444func (p *baseSnapshotDecorator) moduleSuffix() string {
445 return p.baseProperties.ModuleSuffix
Jose Galmes6f843bc2020-12-11 13:36:29 -0800446}
447
Inseob Kimde5744a2020-12-02 13:14:28 +0900448func (p *baseSnapshotDecorator) isSnapshotPrebuilt() bool {
449 return true
450}
451
Colin Crossa8890802021-01-22 14:06:33 -0800452func (p *baseSnapshotDecorator) snapshotAndroidMkSuffix() string {
453 return p.baseProperties.Androidmk_suffix
454}
455
Inseob Kim1b6fb872021-04-05 13:37:02 +0900456func (p *baseSnapshotDecorator) setSnapshotAndroidMkSuffix(ctx android.ModuleContext) {
457 if ctx.OtherModuleDependencyVariantExists([]blueprint.Variation{
458 {Mutator: "image", Variation: android.CoreVariation},
459 }, ctx.Module().(*Module).BaseModuleName()) {
460 p.baseProperties.Androidmk_suffix = p.image.moduleNameSuffix()
461 } else {
462 p.baseProperties.Androidmk_suffix = ""
463 }
464}
465
Inseob Kimde5744a2020-12-02 13:14:28 +0900466// Call this with a module suffix after creating a snapshot module, such as
467// vendorSnapshotSharedSuffix, recoverySnapshotBinarySuffix, etc.
Inseob Kim1b6fb872021-04-05 13:37:02 +0900468func (p *baseSnapshotDecorator) init(m *Module, image snapshotImage, moduleSuffix string) {
469 p.image = image
470 p.baseProperties.ModuleSuffix = image.moduleNameSuffix() + moduleSuffix
Inseob Kimde5744a2020-12-02 13:14:28 +0900471 m.AddProperties(&p.baseProperties)
472 android.AddLoadHook(m, func(ctx android.LoadHookContext) {
473 vendorSnapshotLoadHook(ctx, p)
474 })
475}
476
477// vendorSnapshotLoadHook disables snapshots if it's not BOARD_VNDK_VERSION.
478// As vendor snapshot is only for vendor, such modules won't be used at all.
479func vendorSnapshotLoadHook(ctx android.LoadHookContext, p *baseSnapshotDecorator) {
480 if p.version() != ctx.DeviceConfig().VndkVersion() {
481 ctx.Module().Disable()
482 return
483 }
484}
485
486//
487// Module definitions for snapshots of libraries (shared, static, header).
488//
489// Modules (vendor|recovery)_snapshot_(shared|static|header) are defined here. Shared libraries and
490// static libraries have their prebuilt library files (.so for shared, .a for static) as their src,
491// which can be installed or linked against. Also they export flags needed when linked, such as
492// include directories, c flags, sanitize dependency information, etc.
493//
494// These modules are auto-generated by development/vendor_snapshot/update.py.
495type snapshotLibraryProperties struct {
496 // Prebuilt file for each arch.
497 Src *string `android:"arch_variant"`
498
499 // list of directories that will be added to the include path (using -I).
500 Export_include_dirs []string `android:"arch_variant"`
501
502 // list of directories that will be added to the system path (using -isystem).
503 Export_system_include_dirs []string `android:"arch_variant"`
504
505 // list of flags that will be used for any module that links against this module.
506 Export_flags []string `android:"arch_variant"`
507
508 // Whether this prebuilt needs to depend on sanitize ubsan runtime or not.
509 Sanitize_ubsan_dep *bool `android:"arch_variant"`
510
511 // Whether this prebuilt needs to depend on sanitize minimal runtime or not.
512 Sanitize_minimal_dep *bool `android:"arch_variant"`
513}
514
515type snapshotSanitizer interface {
Ivan Lozano3968d8f2020-12-14 11:27:52 -0500516 isSanitizerEnabled(t SanitizerType) bool
517 setSanitizerVariation(t SanitizerType, enabled bool)
Inseob Kimde5744a2020-12-02 13:14:28 +0900518}
519
520type snapshotLibraryDecorator struct {
521 baseSnapshotDecorator
522 *libraryDecorator
523 properties snapshotLibraryProperties
524 sanitizerProperties struct {
525 CfiEnabled bool `blueprint:"mutated"`
526
527 // Library flags for cfi variant.
528 Cfi snapshotLibraryProperties `android:"arch_variant"`
529 }
Inseob Kimde5744a2020-12-02 13:14:28 +0900530}
531
532func (p *snapshotLibraryDecorator) linkerFlags(ctx ModuleContext, flags Flags) Flags {
533 p.libraryDecorator.libName = strings.TrimSuffix(ctx.ModuleName(), p.NameSuffix())
534 return p.libraryDecorator.linkerFlags(ctx, flags)
535}
536
537func (p *snapshotLibraryDecorator) matchesWithDevice(config android.DeviceConfig) bool {
538 arches := config.Arches()
539 if len(arches) == 0 || arches[0].ArchType.String() != p.arch() {
540 return false
541 }
542 if !p.header() && p.properties.Src == nil {
543 return false
544 }
545 return true
546}
547
548// cc modules' link functions are to link compiled objects into final binaries.
549// As snapshots are prebuilts, this just returns the prebuilt binary after doing things which are
550// done by normal library decorator, e.g. exporting flags.
551func (p *snapshotLibraryDecorator) link(ctx ModuleContext, flags Flags, deps PathDeps, objs Objects) android.Path {
Inseob Kim1b6fb872021-04-05 13:37:02 +0900552 p.setSnapshotAndroidMkSuffix(ctx)
553
Inseob Kimde5744a2020-12-02 13:14:28 +0900554 if p.header() {
555 return p.libraryDecorator.link(ctx, flags, deps, objs)
556 }
557
558 if p.sanitizerProperties.CfiEnabled {
559 p.properties = p.sanitizerProperties.Cfi
560 }
561
562 if !p.matchesWithDevice(ctx.DeviceConfig()) {
563 return nil
564 }
565
Inseob Kimdd0295d2021-04-12 21:09:59 +0900566 // Flags specified directly to this module.
Inseob Kimde5744a2020-12-02 13:14:28 +0900567 p.libraryDecorator.reexportDirs(android.PathsForModuleSrc(ctx, p.properties.Export_include_dirs)...)
568 p.libraryDecorator.reexportSystemDirs(android.PathsForModuleSrc(ctx, p.properties.Export_system_include_dirs)...)
569 p.libraryDecorator.reexportFlags(p.properties.Export_flags...)
570
Inseob Kimdd0295d2021-04-12 21:09:59 +0900571 // Flags reexported from dependencies. (e.g. vndk_prebuilt_shared)
572 p.libraryDecorator.reexportDirs(deps.ReexportedDirs...)
573 p.libraryDecorator.reexportSystemDirs(deps.ReexportedSystemDirs...)
574 p.libraryDecorator.reexportFlags(deps.ReexportedFlags...)
575 p.libraryDecorator.reexportDeps(deps.ReexportedDeps...)
576 p.libraryDecorator.addExportedGeneratedHeaders(deps.ReexportedGeneratedHeaders...)
577
Inseob Kimde5744a2020-12-02 13:14:28 +0900578 in := android.PathForModuleSrc(ctx, *p.properties.Src)
579 p.unstrippedOutputFile = in
580
581 if p.shared() {
582 libName := in.Base()
583 builderFlags := flagsToBuilderFlags(flags)
584
585 // Optimize out relinking against shared libraries whose interface hasn't changed by
586 // depending on a table of contents file instead of the library itself.
587 tocFile := android.PathForModuleOut(ctx, libName+".toc")
588 p.tocFile = android.OptionalPathForPath(tocFile)
589 transformSharedObjectToToc(ctx, in, tocFile, builderFlags)
590
591 ctx.SetProvider(SharedLibraryInfoProvider, SharedLibraryInfo{
592 SharedLibrary: in,
593 UnstrippedSharedLibrary: p.unstrippedOutputFile,
Colin Cross2df81772021-01-26 11:00:18 -0800594 Target: ctx.Target(),
Inseob Kimde5744a2020-12-02 13:14:28 +0900595
596 TableOfContents: p.tocFile,
597 })
598 }
599
600 if p.static() {
601 depSet := android.NewDepSetBuilder(android.TOPOLOGICAL).Direct(in).Build()
602 ctx.SetProvider(StaticLibraryInfoProvider, StaticLibraryInfo{
603 StaticLibrary: in,
604
605 TransitiveStaticLibrariesForOrdering: depSet,
606 })
607 }
608
609 p.libraryDecorator.flagExporter.setProvider(ctx)
610
611 return in
612}
613
614func (p *snapshotLibraryDecorator) install(ctx ModuleContext, file android.Path) {
615 if p.matchesWithDevice(ctx.DeviceConfig()) && (p.shared() || p.static()) {
616 p.baseInstaller.install(ctx, file)
617 }
618}
619
620func (p *snapshotLibraryDecorator) nativeCoverage() bool {
621 return false
622}
623
Ivan Lozano3968d8f2020-12-14 11:27:52 -0500624func (p *snapshotLibraryDecorator) isSanitizerEnabled(t SanitizerType) bool {
Inseob Kimde5744a2020-12-02 13:14:28 +0900625 switch t {
626 case cfi:
627 return p.sanitizerProperties.Cfi.Src != nil
628 default:
629 return false
630 }
631}
632
Ivan Lozano3968d8f2020-12-14 11:27:52 -0500633func (p *snapshotLibraryDecorator) setSanitizerVariation(t SanitizerType, enabled bool) {
Inseob Kimde5744a2020-12-02 13:14:28 +0900634 if !enabled {
635 return
636 }
637 switch t {
638 case cfi:
639 p.sanitizerProperties.CfiEnabled = true
640 default:
641 return
642 }
643}
644
Inseob Kim1b6fb872021-04-05 13:37:02 +0900645func snapshotLibraryFactory(image snapshotImage, moduleSuffix string) (*Module, *snapshotLibraryDecorator) {
Inseob Kimde5744a2020-12-02 13:14:28 +0900646 module, library := NewLibrary(android.DeviceSupported)
647
648 module.stl = nil
649 module.sanitize = nil
650 library.disableStripping()
651
652 prebuilt := &snapshotLibraryDecorator{
653 libraryDecorator: library,
654 }
655
656 prebuilt.baseLinker.Properties.No_libcrt = BoolPtr(true)
657 prebuilt.baseLinker.Properties.Nocrt = BoolPtr(true)
658
659 // Prevent default system libs (libc, libm, and libdl) from being linked
660 if prebuilt.baseLinker.Properties.System_shared_libs == nil {
661 prebuilt.baseLinker.Properties.System_shared_libs = []string{}
662 }
663
664 module.compiler = nil
665 module.linker = prebuilt
666 module.installer = prebuilt
667
Inseob Kim1b6fb872021-04-05 13:37:02 +0900668 prebuilt.init(module, image, moduleSuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900669 module.AddProperties(
670 &prebuilt.properties,
671 &prebuilt.sanitizerProperties,
672 )
673
674 return module, prebuilt
675}
676
677// vendor_snapshot_shared is a special prebuilt shared library which is auto-generated by
678// development/vendor_snapshot/update.py. As a part of vendor snapshot, vendor_snapshot_shared
679// overrides the vendor variant of the cc shared library with the same name, if BOARD_VNDK_VERSION
680// is set.
681func VendorSnapshotSharedFactory() android.Module {
Inseob Kim1b6fb872021-04-05 13:37:02 +0900682 module, prebuilt := snapshotLibraryFactory(vendorSnapshotImageSingleton, snapshotSharedSuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900683 prebuilt.libraryDecorator.BuildOnlyShared()
684 return module.Init()
685}
686
687// recovery_snapshot_shared is a special prebuilt shared library which is auto-generated by
688// development/vendor_snapshot/update.py. As a part of recovery snapshot, recovery_snapshot_shared
689// overrides the recovery variant of the cc shared library with the same name, if BOARD_VNDK_VERSION
690// is set.
691func RecoverySnapshotSharedFactory() android.Module {
Inseob Kim1b6fb872021-04-05 13:37:02 +0900692 module, prebuilt := snapshotLibraryFactory(recoverySnapshotImageSingleton, snapshotSharedSuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900693 prebuilt.libraryDecorator.BuildOnlyShared()
694 return module.Init()
695}
696
697// vendor_snapshot_static is a special prebuilt static library which is auto-generated by
698// development/vendor_snapshot/update.py. As a part of vendor snapshot, vendor_snapshot_static
699// overrides the vendor variant of the cc static library with the same name, if BOARD_VNDK_VERSION
700// is set.
701func VendorSnapshotStaticFactory() android.Module {
Inseob Kim1b6fb872021-04-05 13:37:02 +0900702 module, prebuilt := snapshotLibraryFactory(vendorSnapshotImageSingleton, snapshotStaticSuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900703 prebuilt.libraryDecorator.BuildOnlyStatic()
704 return module.Init()
705}
706
707// recovery_snapshot_static is a special prebuilt static library which is auto-generated by
708// development/vendor_snapshot/update.py. As a part of recovery snapshot, recovery_snapshot_static
709// overrides the recovery variant of the cc static library with the same name, if BOARD_VNDK_VERSION
710// is set.
711func RecoverySnapshotStaticFactory() android.Module {
Inseob Kim1b6fb872021-04-05 13:37:02 +0900712 module, prebuilt := snapshotLibraryFactory(recoverySnapshotImageSingleton, snapshotStaticSuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900713 prebuilt.libraryDecorator.BuildOnlyStatic()
714 return module.Init()
715}
716
717// vendor_snapshot_header is a special header library which is auto-generated by
718// development/vendor_snapshot/update.py. As a part of vendor snapshot, vendor_snapshot_header
719// overrides the vendor variant of the cc header library with the same name, if BOARD_VNDK_VERSION
720// is set.
721func VendorSnapshotHeaderFactory() android.Module {
Inseob Kim1b6fb872021-04-05 13:37:02 +0900722 module, prebuilt := snapshotLibraryFactory(vendorSnapshotImageSingleton, snapshotHeaderSuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900723 prebuilt.libraryDecorator.HeaderOnly()
724 return module.Init()
725}
726
727// recovery_snapshot_header is a special header library which is auto-generated by
728// development/vendor_snapshot/update.py. As a part of recovery snapshot, recovery_snapshot_header
729// overrides the recovery variant of the cc header library with the same name, if BOARD_VNDK_VERSION
730// is set.
731func RecoverySnapshotHeaderFactory() android.Module {
Inseob Kim1b6fb872021-04-05 13:37:02 +0900732 module, prebuilt := snapshotLibraryFactory(recoverySnapshotImageSingleton, snapshotHeaderSuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900733 prebuilt.libraryDecorator.HeaderOnly()
734 return module.Init()
735}
736
737var _ snapshotSanitizer = (*snapshotLibraryDecorator)(nil)
738
739//
740// Module definitions for snapshots of executable binaries.
741//
742// Modules (vendor|recovery)_snapshot_binary are defined here. They have their prebuilt executable
743// binaries (e.g. toybox, sh) as their src, which can be installed.
744//
745// These modules are auto-generated by development/vendor_snapshot/update.py.
746type snapshotBinaryProperties struct {
747 // Prebuilt file for each arch.
748 Src *string `android:"arch_variant"`
749}
750
751type snapshotBinaryDecorator struct {
752 baseSnapshotDecorator
753 *binaryDecorator
Colin Crossa8890802021-01-22 14:06:33 -0800754 properties snapshotBinaryProperties
Inseob Kimde5744a2020-12-02 13:14:28 +0900755}
756
757func (p *snapshotBinaryDecorator) matchesWithDevice(config android.DeviceConfig) bool {
758 if config.DeviceArch() != p.arch() {
759 return false
760 }
761 if p.properties.Src == nil {
762 return false
763 }
764 return true
765}
766
767// cc modules' link functions are to link compiled objects into final binaries.
768// As snapshots are prebuilts, this just returns the prebuilt binary
769func (p *snapshotBinaryDecorator) link(ctx ModuleContext, flags Flags, deps PathDeps, objs Objects) android.Path {
Inseob Kim1b6fb872021-04-05 13:37:02 +0900770 p.setSnapshotAndroidMkSuffix(ctx)
771
Inseob Kimde5744a2020-12-02 13:14:28 +0900772 if !p.matchesWithDevice(ctx.DeviceConfig()) {
773 return nil
774 }
775
776 in := android.PathForModuleSrc(ctx, *p.properties.Src)
777 p.unstrippedOutputFile = in
778 binName := in.Base()
779
Inseob Kimde5744a2020-12-02 13:14:28 +0900780 // use cpExecutable to make it executable
781 outputFile := android.PathForModuleOut(ctx, binName)
782 ctx.Build(pctx, android.BuildParams{
783 Rule: android.CpExecutable,
784 Description: "prebuilt",
785 Output: outputFile,
786 Input: in,
787 })
788
789 return outputFile
790}
791
792func (p *snapshotBinaryDecorator) nativeCoverage() bool {
793 return false
794}
795
796// vendor_snapshot_binary is a special prebuilt executable binary which is auto-generated by
797// development/vendor_snapshot/update.py. As a part of vendor snapshot, vendor_snapshot_binary
798// overrides the vendor variant of the cc binary with the same name, if BOARD_VNDK_VERSION is set.
799func VendorSnapshotBinaryFactory() android.Module {
Inseob Kim1b6fb872021-04-05 13:37:02 +0900800 return snapshotBinaryFactory(vendorSnapshotImageSingleton, snapshotBinarySuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900801}
802
803// recovery_snapshot_binary is a special prebuilt executable binary which is auto-generated by
804// development/vendor_snapshot/update.py. As a part of recovery snapshot, recovery_snapshot_binary
805// overrides the recovery variant of the cc binary with the same name, if BOARD_VNDK_VERSION is set.
806func RecoverySnapshotBinaryFactory() android.Module {
Inseob Kim1b6fb872021-04-05 13:37:02 +0900807 return snapshotBinaryFactory(recoverySnapshotImageSingleton, snapshotBinarySuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900808}
809
Inseob Kim1b6fb872021-04-05 13:37:02 +0900810func snapshotBinaryFactory(image snapshotImage, moduleSuffix string) android.Module {
Inseob Kimde5744a2020-12-02 13:14:28 +0900811 module, binary := NewBinary(android.DeviceSupported)
812 binary.baseLinker.Properties.No_libcrt = BoolPtr(true)
813 binary.baseLinker.Properties.Nocrt = BoolPtr(true)
814
815 // Prevent default system libs (libc, libm, and libdl) from being linked
816 if binary.baseLinker.Properties.System_shared_libs == nil {
817 binary.baseLinker.Properties.System_shared_libs = []string{}
818 }
819
820 prebuilt := &snapshotBinaryDecorator{
821 binaryDecorator: binary,
822 }
823
824 module.compiler = nil
825 module.sanitize = nil
826 module.stl = nil
827 module.linker = prebuilt
828
Inseob Kim1b6fb872021-04-05 13:37:02 +0900829 prebuilt.init(module, image, moduleSuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900830 module.AddProperties(&prebuilt.properties)
831 return module.Init()
832}
833
834//
835// Module definitions for snapshots of object files (*.o).
836//
837// Modules (vendor|recovery)_snapshot_object are defined here. They have their prebuilt object
838// files (*.o) as their src.
839//
840// These modules are auto-generated by development/vendor_snapshot/update.py.
841type vendorSnapshotObjectProperties struct {
842 // Prebuilt file for each arch.
843 Src *string `android:"arch_variant"`
844}
845
846type snapshotObjectLinker struct {
847 baseSnapshotDecorator
848 objectLinker
Colin Crossa8890802021-01-22 14:06:33 -0800849 properties vendorSnapshotObjectProperties
Inseob Kimde5744a2020-12-02 13:14:28 +0900850}
851
852func (p *snapshotObjectLinker) matchesWithDevice(config android.DeviceConfig) bool {
853 if config.DeviceArch() != p.arch() {
854 return false
855 }
856 if p.properties.Src == nil {
857 return false
858 }
859 return true
860}
861
862// cc modules' link functions are to link compiled objects into final binaries.
863// As snapshots are prebuilts, this just returns the prebuilt binary
864func (p *snapshotObjectLinker) link(ctx ModuleContext, flags Flags, deps PathDeps, objs Objects) android.Path {
Inseob Kim1b6fb872021-04-05 13:37:02 +0900865 p.setSnapshotAndroidMkSuffix(ctx)
866
Inseob Kimde5744a2020-12-02 13:14:28 +0900867 if !p.matchesWithDevice(ctx.DeviceConfig()) {
868 return nil
869 }
870
Inseob Kimde5744a2020-12-02 13:14:28 +0900871 return android.PathForModuleSrc(ctx, *p.properties.Src)
872}
873
874func (p *snapshotObjectLinker) nativeCoverage() bool {
875 return false
876}
877
878// vendor_snapshot_object is a special prebuilt compiled object file which is auto-generated by
879// development/vendor_snapshot/update.py. As a part of vendor snapshot, vendor_snapshot_object
880// overrides the vendor variant of the cc object with the same name, if BOARD_VNDK_VERSION is set.
881func VendorSnapshotObjectFactory() android.Module {
882 module := newObject()
883
884 prebuilt := &snapshotObjectLinker{
885 objectLinker: objectLinker{
886 baseLinker: NewBaseLinker(nil),
887 },
888 }
889 module.linker = prebuilt
890
Inseob Kim1b6fb872021-04-05 13:37:02 +0900891 prebuilt.init(module, vendorSnapshotImageSingleton, snapshotObjectSuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900892 module.AddProperties(&prebuilt.properties)
893 return module.Init()
894}
895
896// recovery_snapshot_object is a special prebuilt compiled object file which is auto-generated by
897// development/vendor_snapshot/update.py. As a part of recovery snapshot, recovery_snapshot_object
898// overrides the recovery variant of the cc object with the same name, if BOARD_VNDK_VERSION is set.
899func RecoverySnapshotObjectFactory() android.Module {
900 module := newObject()
901
902 prebuilt := &snapshotObjectLinker{
903 objectLinker: objectLinker{
904 baseLinker: NewBaseLinker(nil),
905 },
906 }
907 module.linker = prebuilt
908
Inseob Kim1b6fb872021-04-05 13:37:02 +0900909 prebuilt.init(module, recoverySnapshotImageSingleton, snapshotObjectSuffix)
Inseob Kimde5744a2020-12-02 13:14:28 +0900910 module.AddProperties(&prebuilt.properties)
911 return module.Init()
912}
913
914type snapshotInterface interface {
915 matchesWithDevice(config android.DeviceConfig) bool
Colin Crossa8890802021-01-22 14:06:33 -0800916 isSnapshotPrebuilt() bool
917 version() string
918 snapshotAndroidMkSuffix() string
Inseob Kimde5744a2020-12-02 13:14:28 +0900919}
920
921var _ snapshotInterface = (*vndkPrebuiltLibraryDecorator)(nil)
922var _ snapshotInterface = (*snapshotLibraryDecorator)(nil)
923var _ snapshotInterface = (*snapshotBinaryDecorator)(nil)
924var _ snapshotInterface = (*snapshotObjectLinker)(nil)