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