xref: /aosp_15_r20/build/soong/filesystem/avb_gen_vbmeta_image.go (revision 333d2b3687b3a337dbcca9d65000bca186795e39)
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