1*333d2b36SAndroid Build Coastguard Worker// Copyright (C) 2022 The Android Open Source Project 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 filesystem 16*333d2b36SAndroid Build Coastguard Worker 17*333d2b36SAndroid Build Coastguard Workerimport ( 18*333d2b36SAndroid Build Coastguard Worker "fmt" 19*333d2b36SAndroid Build Coastguard Worker 20*333d2b36SAndroid Build Coastguard Worker "github.com/google/blueprint/proptools" 21*333d2b36SAndroid Build Coastguard Worker 22*333d2b36SAndroid Build Coastguard Worker "android/soong/android" 23*333d2b36SAndroid Build Coastguard Worker) 24*333d2b36SAndroid Build Coastguard Worker 25*333d2b36SAndroid Build Coastguard Workertype avbGenVbmetaImage struct { 26*333d2b36SAndroid Build Coastguard Worker android.ModuleBase 27*333d2b36SAndroid Build Coastguard Worker android.DefaultableModuleBase 28*333d2b36SAndroid Build Coastguard Worker 29*333d2b36SAndroid Build Coastguard Worker properties avbGenVbmetaImageProperties 30*333d2b36SAndroid Build Coastguard Worker 31*333d2b36SAndroid Build Coastguard Worker output android.Path 32*333d2b36SAndroid Build Coastguard Worker installDir android.InstallPath 33*333d2b36SAndroid Build Coastguard Worker} 34*333d2b36SAndroid Build Coastguard Worker 35*333d2b36SAndroid Build Coastguard Workertype avbGenVbmetaImageProperties struct { 36*333d2b36SAndroid Build Coastguard Worker // Source file of this image. Can reference a genrule type module with the ":module" syntax. 37*333d2b36SAndroid Build Coastguard Worker Src *string `android:"path,arch_variant"` 38*333d2b36SAndroid Build Coastguard Worker 39*333d2b36SAndroid Build Coastguard Worker // Name of the image partition. Defaults to the name of this module. 40*333d2b36SAndroid Build Coastguard Worker Partition_name *string 41*333d2b36SAndroid Build Coastguard Worker 42*333d2b36SAndroid Build Coastguard Worker // The salt in hex. Required for reproducible builds. 43*333d2b36SAndroid Build Coastguard Worker Salt *string 44*333d2b36SAndroid Build Coastguard Worker} 45*333d2b36SAndroid Build Coastguard Worker 46*333d2b36SAndroid Build Coastguard Worker// The avbGenVbmetaImage generates an unsigned VBMeta image output for the given image. 47*333d2b36SAndroid Build Coastguard Workerfunc avbGenVbmetaImageFactory() android.Module { 48*333d2b36SAndroid Build Coastguard Worker module := &avbGenVbmetaImage{} 49*333d2b36SAndroid Build Coastguard Worker module.AddProperties(&module.properties) 50*333d2b36SAndroid Build Coastguard Worker android.InitAndroidArchModule(module, android.DeviceSupported, android.MultilibFirst) 51*333d2b36SAndroid Build Coastguard Worker android.InitDefaultableModule(module) 52*333d2b36SAndroid Build Coastguard Worker return module 53*333d2b36SAndroid Build Coastguard Worker} 54*333d2b36SAndroid Build Coastguard Worker 55*333d2b36SAndroid Build Coastguard Workerfunc (a *avbGenVbmetaImage) installFileName() string { 56*333d2b36SAndroid Build Coastguard Worker return a.Name() + ".img" 57*333d2b36SAndroid Build Coastguard Worker} 58*333d2b36SAndroid Build Coastguard Worker 59*333d2b36SAndroid Build Coastguard Workerfunc (a *avbGenVbmetaImage) GenerateAndroidBuildActions(ctx android.ModuleContext) { 60*333d2b36SAndroid Build Coastguard Worker builder := android.NewRuleBuilder(pctx, ctx) 61*333d2b36SAndroid Build Coastguard Worker cmd := builder.Command().BuiltTool("avbtool").Text("add_hash_footer") 62*333d2b36SAndroid Build Coastguard Worker cmd.Flag("--dynamic_partition_size") 63*333d2b36SAndroid Build Coastguard Worker cmd.Flag("--do_not_append_vbmeta_image") 64*333d2b36SAndroid Build Coastguard Worker 65*333d2b36SAndroid Build Coastguard Worker partition_name := proptools.StringDefault(a.properties.Partition_name, a.Name()) 66*333d2b36SAndroid Build Coastguard Worker cmd.FlagWithArg("--partition_name ", partition_name) 67*333d2b36SAndroid Build Coastguard Worker 68*333d2b36SAndroid Build Coastguard Worker if a.properties.Src == nil { 69*333d2b36SAndroid Build Coastguard Worker ctx.PropertyErrorf("src", "missing source file") 70*333d2b36SAndroid Build Coastguard Worker return 71*333d2b36SAndroid Build Coastguard Worker } 72*333d2b36SAndroid Build Coastguard Worker input := android.PathForModuleSrc(ctx, proptools.String(a.properties.Src)) 73*333d2b36SAndroid Build Coastguard Worker cmd.FlagWithInput("--image ", input) 74*333d2b36SAndroid Build Coastguard Worker 75*333d2b36SAndroid Build Coastguard Worker if a.properties.Salt == nil { 76*333d2b36SAndroid Build Coastguard Worker ctx.PropertyErrorf("salt", "missing salt value") 77*333d2b36SAndroid Build Coastguard Worker return 78*333d2b36SAndroid Build Coastguard Worker } 79*333d2b36SAndroid Build Coastguard Worker cmd.FlagWithArg("--salt ", proptools.String(a.properties.Salt)) 80*333d2b36SAndroid Build Coastguard Worker 81*333d2b36SAndroid Build Coastguard Worker output := android.PathForModuleOut(ctx, a.installFileName()) 82*333d2b36SAndroid Build Coastguard Worker cmd.FlagWithOutput("--output_vbmeta_image ", output) 83*333d2b36SAndroid Build Coastguard Worker builder.Build("avbGenVbmetaImage", fmt.Sprintf("avbGenVbmetaImage %s", ctx.ModuleName())) 84*333d2b36SAndroid Build Coastguard Worker 85*333d2b36SAndroid Build Coastguard Worker ctx.SetOutputFiles([]android.Path{output}, "") 86*333d2b36SAndroid Build Coastguard Worker a.output = output 87*333d2b36SAndroid Build Coastguard Worker} 88*333d2b36SAndroid Build Coastguard Worker 89*333d2b36SAndroid Build Coastguard Workervar _ android.AndroidMkEntriesProvider = (*avbGenVbmetaImage)(nil) 90*333d2b36SAndroid Build Coastguard Worker 91*333d2b36SAndroid Build Coastguard Worker// Implements android.AndroidMkEntriesProvider 92*333d2b36SAndroid Build Coastguard Workerfunc (a *avbGenVbmetaImage) AndroidMkEntries() []android.AndroidMkEntries { 93*333d2b36SAndroid Build Coastguard Worker return []android.AndroidMkEntries{android.AndroidMkEntries{ 94*333d2b36SAndroid Build Coastguard Worker Class: "ETC", 95*333d2b36SAndroid Build Coastguard Worker OutputFile: android.OptionalPathForPath(a.output), 96*333d2b36SAndroid Build Coastguard Worker ExtraEntries: []android.AndroidMkExtraEntriesFunc{ 97*333d2b36SAndroid Build Coastguard Worker func(ctx android.AndroidMkExtraEntriesContext, entries *android.AndroidMkEntries) { 98*333d2b36SAndroid Build Coastguard Worker entries.SetString("LOCAL_MODULE_PATH", a.installDir.String()) 99*333d2b36SAndroid Build Coastguard Worker entries.SetString("LOCAL_INSTALLED_MODULE_STEM", a.installFileName()) 100*333d2b36SAndroid Build Coastguard Worker }, 101*333d2b36SAndroid Build Coastguard Worker }, 102*333d2b36SAndroid Build Coastguard Worker }} 103*333d2b36SAndroid Build Coastguard Worker} 104*333d2b36SAndroid Build Coastguard Worker 105*333d2b36SAndroid Build Coastguard Workertype avbGenVbmetaImageDefaults struct { 106*333d2b36SAndroid Build Coastguard Worker android.ModuleBase 107*333d2b36SAndroid Build Coastguard Worker android.DefaultsModuleBase 108*333d2b36SAndroid Build Coastguard Worker} 109*333d2b36SAndroid Build Coastguard Worker 110*333d2b36SAndroid Build Coastguard Worker// avb_gen_vbmeta_image_defaults provides a set of properties that can be inherited by other 111*333d2b36SAndroid Build Coastguard Worker// avb_gen_vbmeta_image modules. A module can use the properties from an 112*333d2b36SAndroid Build Coastguard Worker// avb_gen_vbmeta_image_defaults using `defaults: ["<:default_module_name>"]`. Properties of both 113*333d2b36SAndroid Build Coastguard Worker// modules are erged (when possible) by prepending the default module's values to the depending 114*333d2b36SAndroid Build Coastguard Worker// module's values. 115*333d2b36SAndroid Build Coastguard Workerfunc avbGenVbmetaImageDefaultsFactory() android.Module { 116*333d2b36SAndroid Build Coastguard Worker module := &avbGenVbmetaImageDefaults{} 117*333d2b36SAndroid Build Coastguard Worker module.AddProperties(&avbGenVbmetaImageProperties{}) 118*333d2b36SAndroid Build Coastguard Worker android.InitDefaultsModule(module) 119*333d2b36SAndroid Build Coastguard Worker return module 120*333d2b36SAndroid Build Coastguard Worker} 121