xref: /aosp_15_r20/build/soong/android/image.go (revision 333d2b3687b3a337dbcca9d65000bca186795e39)
1*333d2b36SAndroid Build Coastguard Worker// Copyright 2019 Google Inc. All rights reserved.
2*333d2b36SAndroid Build Coastguard Worker//
3*333d2b36SAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License");
4*333d2b36SAndroid Build Coastguard Worker// you may not use this file except in compliance with the License.
5*333d2b36SAndroid Build Coastguard Worker// You may obtain a copy of the License at
6*333d2b36SAndroid Build Coastguard Worker//
7*333d2b36SAndroid Build Coastguard Worker//     http://www.apache.org/licenses/LICENSE-2.0
8*333d2b36SAndroid Build Coastguard Worker//
9*333d2b36SAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software
10*333d2b36SAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS,
11*333d2b36SAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*333d2b36SAndroid Build Coastguard Worker// See the License for the specific language governing permissions and
13*333d2b36SAndroid Build Coastguard Worker// limitations under the License.
14*333d2b36SAndroid Build Coastguard Worker
15*333d2b36SAndroid Build Coastguard Workerpackage android
16*333d2b36SAndroid Build Coastguard Worker
17*333d2b36SAndroid Build Coastguard Workertype ImageInterfaceContext interface {
18*333d2b36SAndroid Build Coastguard Worker	ArchModuleContext
19*333d2b36SAndroid Build Coastguard Worker
20*333d2b36SAndroid Build Coastguard Worker	Module() Module
21*333d2b36SAndroid Build Coastguard Worker
22*333d2b36SAndroid Build Coastguard Worker	ModuleErrorf(fmt string, args ...interface{})
23*333d2b36SAndroid Build Coastguard Worker	PropertyErrorf(property, fmt string, args ...interface{})
24*333d2b36SAndroid Build Coastguard Worker
25*333d2b36SAndroid Build Coastguard Worker	DeviceSpecific() bool
26*333d2b36SAndroid Build Coastguard Worker	SocSpecific() bool
27*333d2b36SAndroid Build Coastguard Worker	ProductSpecific() bool
28*333d2b36SAndroid Build Coastguard Worker	SystemExtSpecific() bool
29*333d2b36SAndroid Build Coastguard Worker	Platform() bool
30*333d2b36SAndroid Build Coastguard Worker
31*333d2b36SAndroid Build Coastguard Worker	Config() Config
32*333d2b36SAndroid Build Coastguard Worker}
33*333d2b36SAndroid Build Coastguard Worker
34*333d2b36SAndroid Build Coastguard Worker// ImageInterface is implemented by modules that need to be split by the imageTransitionMutator.
35*333d2b36SAndroid Build Coastguard Workertype ImageInterface interface {
36*333d2b36SAndroid Build Coastguard Worker	// ImageMutatorBegin is called before any other method in the ImageInterface.
37*333d2b36SAndroid Build Coastguard Worker	ImageMutatorBegin(ctx ImageInterfaceContext)
38*333d2b36SAndroid Build Coastguard Worker
39*333d2b36SAndroid Build Coastguard Worker	// VendorVariantNeeded should return true if the module needs a vendor variant (installed on the vendor image).
40*333d2b36SAndroid Build Coastguard Worker	VendorVariantNeeded(ctx ImageInterfaceContext) bool
41*333d2b36SAndroid Build Coastguard Worker
42*333d2b36SAndroid Build Coastguard Worker	// ProductVariantNeeded should return true if the module needs a product variant (installed on the product image).
43*333d2b36SAndroid Build Coastguard Worker	ProductVariantNeeded(ctx ImageInterfaceContext) bool
44*333d2b36SAndroid Build Coastguard Worker
45*333d2b36SAndroid Build Coastguard Worker	// CoreVariantNeeded should return true if the module needs a core variant (installed on the system image).
46*333d2b36SAndroid Build Coastguard Worker	CoreVariantNeeded(ctx ImageInterfaceContext) bool
47*333d2b36SAndroid Build Coastguard Worker
48*333d2b36SAndroid Build Coastguard Worker	// RamdiskVariantNeeded should return true if the module needs a ramdisk variant (installed on the
49*333d2b36SAndroid Build Coastguard Worker	// ramdisk partition).
50*333d2b36SAndroid Build Coastguard Worker	RamdiskVariantNeeded(ctx ImageInterfaceContext) bool
51*333d2b36SAndroid Build Coastguard Worker
52*333d2b36SAndroid Build Coastguard Worker	// VendorRamdiskVariantNeeded should return true if the module needs a vendor ramdisk variant (installed on the
53*333d2b36SAndroid Build Coastguard Worker	// vendor ramdisk partition).
54*333d2b36SAndroid Build Coastguard Worker	VendorRamdiskVariantNeeded(ctx ImageInterfaceContext) bool
55*333d2b36SAndroid Build Coastguard Worker
56*333d2b36SAndroid Build Coastguard Worker	// DebugRamdiskVariantNeeded should return true if the module needs a debug ramdisk variant (installed on the
57*333d2b36SAndroid Build Coastguard Worker	// debug ramdisk partition: $(PRODUCT_OUT)/debug_ramdisk).
58*333d2b36SAndroid Build Coastguard Worker	DebugRamdiskVariantNeeded(ctx ImageInterfaceContext) bool
59*333d2b36SAndroid Build Coastguard Worker
60*333d2b36SAndroid Build Coastguard Worker	// RecoveryVariantNeeded should return true if the module needs a recovery variant (installed on the
61*333d2b36SAndroid Build Coastguard Worker	// recovery partition).
62*333d2b36SAndroid Build Coastguard Worker	RecoveryVariantNeeded(ctx ImageInterfaceContext) bool
63*333d2b36SAndroid Build Coastguard Worker
64*333d2b36SAndroid Build Coastguard Worker	// ExtraImageVariations should return a list of the additional variations needed for the module.  After the
65*333d2b36SAndroid Build Coastguard Worker	// variants are created the SetImageVariation method will be called on each newly created variant with the
66*333d2b36SAndroid Build Coastguard Worker	// its variation.
67*333d2b36SAndroid Build Coastguard Worker	ExtraImageVariations(ctx ImageInterfaceContext) []string
68*333d2b36SAndroid Build Coastguard Worker
69*333d2b36SAndroid Build Coastguard Worker	// SetImageVariation is called for each newly created image variant. The receiver is the original
70*333d2b36SAndroid Build Coastguard Worker	// module, "variation" is the name of the newly created variant. "variation" is set on the receiver.
71*333d2b36SAndroid Build Coastguard Worker	SetImageVariation(ctx ImageInterfaceContext, variation string)
72*333d2b36SAndroid Build Coastguard Worker}
73*333d2b36SAndroid Build Coastguard Worker
74*333d2b36SAndroid Build Coastguard Workerconst (
75*333d2b36SAndroid Build Coastguard Worker	// VendorVariation is the variant name used for /vendor code that does not
76*333d2b36SAndroid Build Coastguard Worker	// compile against the VNDK.
77*333d2b36SAndroid Build Coastguard Worker	VendorVariation string = "vendor"
78*333d2b36SAndroid Build Coastguard Worker
79*333d2b36SAndroid Build Coastguard Worker	// ProductVariation is the variant name used for /product code that does not
80*333d2b36SAndroid Build Coastguard Worker	// compile against the VNDK.
81*333d2b36SAndroid Build Coastguard Worker	ProductVariation string = "product"
82*333d2b36SAndroid Build Coastguard Worker
83*333d2b36SAndroid Build Coastguard Worker	// CoreVariation is the variant used for framework-private libraries, or
84*333d2b36SAndroid Build Coastguard Worker	// SDK libraries. (which framework-private libraries can use), which
85*333d2b36SAndroid Build Coastguard Worker	// will be installed to the system image.
86*333d2b36SAndroid Build Coastguard Worker	CoreVariation string = ""
87*333d2b36SAndroid Build Coastguard Worker
88*333d2b36SAndroid Build Coastguard Worker	// RecoveryVariation means a module to be installed to recovery image.
89*333d2b36SAndroid Build Coastguard Worker	RecoveryVariation string = "recovery"
90*333d2b36SAndroid Build Coastguard Worker
91*333d2b36SAndroid Build Coastguard Worker	// RamdiskVariation means a module to be installed to ramdisk image.
92*333d2b36SAndroid Build Coastguard Worker	RamdiskVariation string = "ramdisk"
93*333d2b36SAndroid Build Coastguard Worker
94*333d2b36SAndroid Build Coastguard Worker	// VendorRamdiskVariation means a module to be installed to vendor ramdisk image.
95*333d2b36SAndroid Build Coastguard Worker	VendorRamdiskVariation string = "vendor_ramdisk"
96*333d2b36SAndroid Build Coastguard Worker
97*333d2b36SAndroid Build Coastguard Worker	// DebugRamdiskVariation means a module to be installed to debug ramdisk image.
98*333d2b36SAndroid Build Coastguard Worker	DebugRamdiskVariation string = "debug_ramdisk"
99*333d2b36SAndroid Build Coastguard Worker)
100*333d2b36SAndroid Build Coastguard Worker
101*333d2b36SAndroid Build Coastguard Workertype imageInterfaceContextAdapter struct {
102*333d2b36SAndroid Build Coastguard Worker	IncomingTransitionContext
103*333d2b36SAndroid Build Coastguard Worker	kind moduleKind
104*333d2b36SAndroid Build Coastguard Worker}
105*333d2b36SAndroid Build Coastguard Worker
106*333d2b36SAndroid Build Coastguard Workervar _ ImageInterfaceContext = (*imageInterfaceContextAdapter)(nil)
107*333d2b36SAndroid Build Coastguard Worker
108*333d2b36SAndroid Build Coastguard Workerfunc (e *imageInterfaceContextAdapter) Platform() bool {
109*333d2b36SAndroid Build Coastguard Worker	return e.kind == platformModule
110*333d2b36SAndroid Build Coastguard Worker}
111*333d2b36SAndroid Build Coastguard Worker
112*333d2b36SAndroid Build Coastguard Workerfunc (e *imageInterfaceContextAdapter) DeviceSpecific() bool {
113*333d2b36SAndroid Build Coastguard Worker	return e.kind == deviceSpecificModule
114*333d2b36SAndroid Build Coastguard Worker}
115*333d2b36SAndroid Build Coastguard Worker
116*333d2b36SAndroid Build Coastguard Workerfunc (e *imageInterfaceContextAdapter) SocSpecific() bool {
117*333d2b36SAndroid Build Coastguard Worker	return e.kind == socSpecificModule
118*333d2b36SAndroid Build Coastguard Worker}
119*333d2b36SAndroid Build Coastguard Worker
120*333d2b36SAndroid Build Coastguard Workerfunc (e *imageInterfaceContextAdapter) ProductSpecific() bool {
121*333d2b36SAndroid Build Coastguard Worker	return e.kind == productSpecificModule
122*333d2b36SAndroid Build Coastguard Worker}
123*333d2b36SAndroid Build Coastguard Worker
124*333d2b36SAndroid Build Coastguard Workerfunc (e *imageInterfaceContextAdapter) SystemExtSpecific() bool {
125*333d2b36SAndroid Build Coastguard Worker	return e.kind == systemExtSpecificModule
126*333d2b36SAndroid Build Coastguard Worker}
127*333d2b36SAndroid Build Coastguard Worker
128*333d2b36SAndroid Build Coastguard Worker// imageMutatorBeginMutator calls ImageMutatorBegin on all modules that may have image variants.
129*333d2b36SAndroid Build Coastguard Worker// This happens right before the imageTransitionMutator runs. It's needed to initialize these
130*333d2b36SAndroid Build Coastguard Worker// modules so that they return the correct results for all the other ImageInterface methods,
131*333d2b36SAndroid Build Coastguard Worker// which the imageTransitionMutator will call. Transition mutators should also not mutate modules
132*333d2b36SAndroid Build Coastguard Worker// (except in their Mutate() function), which this method does, so we run it in a separate mutator
133*333d2b36SAndroid Build Coastguard Worker// first.
134*333d2b36SAndroid Build Coastguard Workerfunc imageMutatorBeginMutator(ctx BottomUpMutatorContext) {
135*333d2b36SAndroid Build Coastguard Worker	if m, ok := ctx.Module().(ImageInterface); ok && ctx.Os() == Android {
136*333d2b36SAndroid Build Coastguard Worker		m.ImageMutatorBegin(ctx)
137*333d2b36SAndroid Build Coastguard Worker	}
138*333d2b36SAndroid Build Coastguard Worker}
139*333d2b36SAndroid Build Coastguard Worker
140*333d2b36SAndroid Build Coastguard Worker// imageTransitionMutator creates variants for modules that implement the ImageInterface that
141*333d2b36SAndroid Build Coastguard Worker// allow them to build differently for each partition (recovery, core, vendor, etc.).
142*333d2b36SAndroid Build Coastguard Workertype imageTransitionMutator struct{}
143*333d2b36SAndroid Build Coastguard Worker
144*333d2b36SAndroid Build Coastguard Workerfunc getImageVariations(ctx ImageInterfaceContext) []string {
145*333d2b36SAndroid Build Coastguard Worker	var variations []string
146*333d2b36SAndroid Build Coastguard Worker
147*333d2b36SAndroid Build Coastguard Worker	if m, ok := ctx.Module().(ImageInterface); ctx.Os() == Android && ok {
148*333d2b36SAndroid Build Coastguard Worker		if m.CoreVariantNeeded(ctx) {
149*333d2b36SAndroid Build Coastguard Worker			variations = append(variations, CoreVariation)
150*333d2b36SAndroid Build Coastguard Worker		}
151*333d2b36SAndroid Build Coastguard Worker		if m.RamdiskVariantNeeded(ctx) {
152*333d2b36SAndroid Build Coastguard Worker			variations = append(variations, RamdiskVariation)
153*333d2b36SAndroid Build Coastguard Worker		}
154*333d2b36SAndroid Build Coastguard Worker		if m.VendorRamdiskVariantNeeded(ctx) {
155*333d2b36SAndroid Build Coastguard Worker			variations = append(variations, VendorRamdiskVariation)
156*333d2b36SAndroid Build Coastguard Worker		}
157*333d2b36SAndroid Build Coastguard Worker		if m.DebugRamdiskVariantNeeded(ctx) {
158*333d2b36SAndroid Build Coastguard Worker			variations = append(variations, DebugRamdiskVariation)
159*333d2b36SAndroid Build Coastguard Worker		}
160*333d2b36SAndroid Build Coastguard Worker		if m.RecoveryVariantNeeded(ctx) {
161*333d2b36SAndroid Build Coastguard Worker			variations = append(variations, RecoveryVariation)
162*333d2b36SAndroid Build Coastguard Worker		}
163*333d2b36SAndroid Build Coastguard Worker		if m.VendorVariantNeeded(ctx) {
164*333d2b36SAndroid Build Coastguard Worker			variations = append(variations, VendorVariation)
165*333d2b36SAndroid Build Coastguard Worker		}
166*333d2b36SAndroid Build Coastguard Worker		if m.ProductVariantNeeded(ctx) {
167*333d2b36SAndroid Build Coastguard Worker			variations = append(variations, ProductVariation)
168*333d2b36SAndroid Build Coastguard Worker		}
169*333d2b36SAndroid Build Coastguard Worker
170*333d2b36SAndroid Build Coastguard Worker		extraVariations := m.ExtraImageVariations(ctx)
171*333d2b36SAndroid Build Coastguard Worker		variations = append(variations, extraVariations...)
172*333d2b36SAndroid Build Coastguard Worker	}
173*333d2b36SAndroid Build Coastguard Worker
174*333d2b36SAndroid Build Coastguard Worker	if len(variations) == 0 {
175*333d2b36SAndroid Build Coastguard Worker		variations = append(variations, "")
176*333d2b36SAndroid Build Coastguard Worker	}
177*333d2b36SAndroid Build Coastguard Worker
178*333d2b36SAndroid Build Coastguard Worker	return variations
179*333d2b36SAndroid Build Coastguard Worker}
180*333d2b36SAndroid Build Coastguard Worker
181*333d2b36SAndroid Build Coastguard Workerfunc (imageTransitionMutator) Split(ctx BaseModuleContext) []string {
182*333d2b36SAndroid Build Coastguard Worker	return getImageVariations(ctx)
183*333d2b36SAndroid Build Coastguard Worker}
184*333d2b36SAndroid Build Coastguard Worker
185*333d2b36SAndroid Build Coastguard Workerfunc (imageTransitionMutator) OutgoingTransition(ctx OutgoingTransitionContext, sourceVariation string) string {
186*333d2b36SAndroid Build Coastguard Worker	return sourceVariation
187*333d2b36SAndroid Build Coastguard Worker}
188*333d2b36SAndroid Build Coastguard Worker
189*333d2b36SAndroid Build Coastguard Workerfunc (imageTransitionMutator) IncomingTransition(ctx IncomingTransitionContext, incomingVariation string) string {
190*333d2b36SAndroid Build Coastguard Worker	if _, ok := ctx.Module().(ImageInterface); ctx.Os() != Android || !ok {
191*333d2b36SAndroid Build Coastguard Worker		return CoreVariation
192*333d2b36SAndroid Build Coastguard Worker	}
193*333d2b36SAndroid Build Coastguard Worker	variations := getImageVariations(&imageInterfaceContextAdapter{
194*333d2b36SAndroid Build Coastguard Worker		IncomingTransitionContext: ctx,
195*333d2b36SAndroid Build Coastguard Worker		kind:                      determineModuleKind(ctx.Module().base(), ctx),
196*333d2b36SAndroid Build Coastguard Worker	})
197*333d2b36SAndroid Build Coastguard Worker	// If there's only 1 possible variation, use that. This is a holdover from when blueprint,
198*333d2b36SAndroid Build Coastguard Worker	// when adding dependencies, would use the only variant of a module regardless of its variations
199*333d2b36SAndroid Build Coastguard Worker	// if only 1 variant existed.
200*333d2b36SAndroid Build Coastguard Worker	if len(variations) == 1 {
201*333d2b36SAndroid Build Coastguard Worker		return variations[0]
202*333d2b36SAndroid Build Coastguard Worker	}
203*333d2b36SAndroid Build Coastguard Worker	return incomingVariation
204*333d2b36SAndroid Build Coastguard Worker}
205*333d2b36SAndroid Build Coastguard Worker
206*333d2b36SAndroid Build Coastguard Workerfunc (imageTransitionMutator) Mutate(ctx BottomUpMutatorContext, variation string) {
207*333d2b36SAndroid Build Coastguard Worker	ctx.Module().base().setImageVariation(variation)
208*333d2b36SAndroid Build Coastguard Worker	if m, ok := ctx.Module().(ImageInterface); ok {
209*333d2b36SAndroid Build Coastguard Worker		m.SetImageVariation(ctx, variation)
210*333d2b36SAndroid Build Coastguard Worker	}
211*333d2b36SAndroid Build Coastguard Worker}
212