[avb_footer] Add avb_gen_vbmeta_image to generate vbmeta image
This is the reland of the change aosp/2375848. The build of initrd on linux-x86 that has incorrect format (b/264940248) is disabled in this cl. Bug: 260821553 Test: m microdroid_kernel_signed and inspect the output using `avbtool info_image --image <output>` Change-Id: I3ad2419b7132cde4b2fc34ddfa09ec5ba2166819
This commit is contained in:
parent
57b1e4064b
commit
000e3a396c
5 changed files with 147 additions and 0 deletions
|
@ -13,6 +13,7 @@ bootstrap_go_package {
|
||||||
],
|
],
|
||||||
srcs: [
|
srcs: [
|
||||||
"avb_add_hash_footer.go",
|
"avb_add_hash_footer.go",
|
||||||
|
"avb_gen_vbmeta_image.go",
|
||||||
"bootimg.go",
|
"bootimg.go",
|
||||||
"filesystem.go",
|
"filesystem.go",
|
||||||
"logical_partition.go",
|
"logical_partition.go",
|
||||||
|
|
|
@ -67,6 +67,9 @@ type avbAddHashFooterProperties struct {
|
||||||
|
|
||||||
// List of properties to add to the footer
|
// List of properties to add to the footer
|
||||||
Props []avbProp
|
Props []avbProp
|
||||||
|
|
||||||
|
// Include descriptors from images
|
||||||
|
Include_descriptors_from_images []string `android:"path,arch_variant"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// The AVB footer adds verification information to the image.
|
// The AVB footer adds verification information to the image.
|
||||||
|
@ -116,6 +119,11 @@ func (a *avbAddHashFooter) GenerateAndroidBuildActions(ctx android.ModuleContext
|
||||||
}
|
}
|
||||||
cmd.FlagWithArg("--salt ", proptools.String(a.properties.Salt))
|
cmd.FlagWithArg("--salt ", proptools.String(a.properties.Salt))
|
||||||
|
|
||||||
|
imagePaths := android.PathsForModuleSrc(ctx, a.properties.Include_descriptors_from_images)
|
||||||
|
for _, imagePath := range imagePaths {
|
||||||
|
cmd.FlagWithInput("--include_descriptors_from_image ", imagePath)
|
||||||
|
}
|
||||||
|
|
||||||
for _, prop := range a.properties.Props {
|
for _, prop := range a.properties.Props {
|
||||||
addAvbProp(ctx, cmd, prop)
|
addAvbProp(ctx, cmd, prop)
|
||||||
}
|
}
|
||||||
|
|
108
filesystem/avb_gen_vbmeta_image.go
Normal file
108
filesystem/avb_gen_vbmeta_image.go
Normal file
|
@ -0,0 +1,108 @@
|
||||||
|
// Copyright (C) 2022 The Android Open Source Project
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package filesystem
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"github.com/google/blueprint/proptools"
|
||||||
|
|
||||||
|
"android/soong/android"
|
||||||
|
)
|
||||||
|
|
||||||
|
type avbGenVbmetaImage struct {
|
||||||
|
android.ModuleBase
|
||||||
|
|
||||||
|
properties avbGenVbmetaImageProperties
|
||||||
|
|
||||||
|
output android.OutputPath
|
||||||
|
installDir android.InstallPath
|
||||||
|
}
|
||||||
|
|
||||||
|
type avbGenVbmetaImageProperties struct {
|
||||||
|
// Source file of this image. Can reference a genrule type module with the ":module" syntax.
|
||||||
|
Src *string `android:"path,arch_variant"`
|
||||||
|
|
||||||
|
// Name of the image partition. Defaults to the name of this module.
|
||||||
|
Partition_name *string
|
||||||
|
|
||||||
|
// The salt in hex. Required for reproducible builds.
|
||||||
|
Salt *string
|
||||||
|
}
|
||||||
|
|
||||||
|
// The avbGenVbmetaImage generates an unsigned VBMeta image output for the given image.
|
||||||
|
func avbGenVbmetaImageFactory() android.Module {
|
||||||
|
module := &avbGenVbmetaImage{}
|
||||||
|
module.AddProperties(&module.properties)
|
||||||
|
android.InitAndroidArchModule(module, android.DeviceSupported, android.MultilibFirst)
|
||||||
|
return module
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *avbGenVbmetaImage) installFileName() string {
|
||||||
|
return a.Name() + ".img"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *avbGenVbmetaImage) GenerateAndroidBuildActions(ctx android.ModuleContext) {
|
||||||
|
builder := android.NewRuleBuilder(pctx, ctx)
|
||||||
|
cmd := builder.Command().BuiltTool("avbtool").Text("add_hash_footer")
|
||||||
|
cmd.Flag("--dynamic_partition_size")
|
||||||
|
cmd.Flag("--do_not_append_vbmeta_image")
|
||||||
|
|
||||||
|
partition_name := proptools.StringDefault(a.properties.Partition_name, a.Name())
|
||||||
|
cmd.FlagWithArg("--partition_name ", partition_name)
|
||||||
|
|
||||||
|
if a.properties.Src == nil {
|
||||||
|
ctx.PropertyErrorf("src", "missing source file")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
input := android.PathForModuleSrc(ctx, proptools.String(a.properties.Src))
|
||||||
|
cmd.FlagWithInput("--image ", input)
|
||||||
|
|
||||||
|
if a.properties.Salt == nil {
|
||||||
|
ctx.PropertyErrorf("salt", "missing salt value")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
cmd.FlagWithArg("--salt ", proptools.String(a.properties.Salt))
|
||||||
|
|
||||||
|
a.output = android.PathForModuleOut(ctx, a.installFileName()).OutputPath
|
||||||
|
cmd.FlagWithOutput("--output_vbmeta_image ", a.output)
|
||||||
|
builder.Build("avbGenVbmetaImage", fmt.Sprintf("avbGenVbmetaImage %s", ctx.ModuleName()))
|
||||||
|
}
|
||||||
|
|
||||||
|
var _ android.AndroidMkEntriesProvider = (*avbGenVbmetaImage)(nil)
|
||||||
|
|
||||||
|
// Implements android.AndroidMkEntriesProvider
|
||||||
|
func (a *avbGenVbmetaImage) AndroidMkEntries() []android.AndroidMkEntries {
|
||||||
|
return []android.AndroidMkEntries{android.AndroidMkEntries{
|
||||||
|
Class: "ETC",
|
||||||
|
OutputFile: android.OptionalPathForPath(a.output),
|
||||||
|
ExtraEntries: []android.AndroidMkExtraEntriesFunc{
|
||||||
|
func(ctx android.AndroidMkExtraEntriesContext, entries *android.AndroidMkEntries) {
|
||||||
|
entries.SetString("LOCAL_MODULE_PATH", a.installDir.String())
|
||||||
|
entries.SetString("LOCAL_INSTALLED_MODULE_STEM", a.installFileName())
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
|
var _ android.OutputFileProducer = (*avbGenVbmetaImage)(nil)
|
||||||
|
|
||||||
|
// Implements android.OutputFileProducer
|
||||||
|
func (a *avbGenVbmetaImage) OutputFiles(tag string) (android.Paths, error) {
|
||||||
|
if tag == "" {
|
||||||
|
return []android.Path{a.output}, nil
|
||||||
|
}
|
||||||
|
return nil, fmt.Errorf("unsupported module reference tag %q", tag)
|
||||||
|
}
|
|
@ -35,6 +35,7 @@ func registerBuildComponents(ctx android.RegistrationContext) {
|
||||||
ctx.RegisterModuleType("android_filesystem", filesystemFactory)
|
ctx.RegisterModuleType("android_filesystem", filesystemFactory)
|
||||||
ctx.RegisterModuleType("android_system_image", systemImageFactory)
|
ctx.RegisterModuleType("android_system_image", systemImageFactory)
|
||||||
ctx.RegisterModuleType("avb_add_hash_footer", avbAddHashFooterFactory)
|
ctx.RegisterModuleType("avb_add_hash_footer", avbAddHashFooterFactory)
|
||||||
|
ctx.RegisterModuleType("avb_gen_vbmeta_image", avbGenVbmetaImageFactory)
|
||||||
}
|
}
|
||||||
|
|
||||||
type filesystem struct {
|
type filesystem struct {
|
||||||
|
|
|
@ -126,8 +126,34 @@ func TestFileSystemGathersItemsOnlyInSystemPartition(t *testing.T) {
|
||||||
android.AssertDeepEquals(t, "entries should have foo only", []string{"components/foo"}, module.entries)
|
android.AssertDeepEquals(t, "entries should have foo only", []string{"components/foo"}, module.entries)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestAvbGenVbmetaImage(t *testing.T) {
|
||||||
|
result := fixture.RunTestWithBp(t, `
|
||||||
|
avb_gen_vbmeta_image {
|
||||||
|
name: "input_hashdesc",
|
||||||
|
src: "input.img",
|
||||||
|
partition_name: "input_partition_name",
|
||||||
|
salt: "2222",
|
||||||
|
}`)
|
||||||
|
cmd := result.ModuleForTests("input_hashdesc", "android_arm64_armv8-a").Rule("avbGenVbmetaImage").RuleParams.Command
|
||||||
|
android.AssertStringDoesContain(t, "Can't find correct --partition_name argument",
|
||||||
|
cmd, "--partition_name input_partition_name")
|
||||||
|
android.AssertStringDoesContain(t, "Can't find --do_not_append_vbmeta_image",
|
||||||
|
cmd, "--do_not_append_vbmeta_image")
|
||||||
|
android.AssertStringDoesContain(t, "Can't find --output_vbmeta_image",
|
||||||
|
cmd, "--output_vbmeta_image ")
|
||||||
|
android.AssertStringDoesContain(t, "Can't find --salt argument",
|
||||||
|
cmd, "--salt 2222")
|
||||||
|
}
|
||||||
|
|
||||||
func TestAvbAddHashFooter(t *testing.T) {
|
func TestAvbAddHashFooter(t *testing.T) {
|
||||||
result := fixture.RunTestWithBp(t, `
|
result := fixture.RunTestWithBp(t, `
|
||||||
|
avb_gen_vbmeta_image {
|
||||||
|
name: "input_hashdesc",
|
||||||
|
src: "input.img",
|
||||||
|
partition_name: "input",
|
||||||
|
salt: "2222",
|
||||||
|
}
|
||||||
|
|
||||||
avb_add_hash_footer {
|
avb_add_hash_footer {
|
||||||
name: "myfooter",
|
name: "myfooter",
|
||||||
src: "input.img",
|
src: "input.img",
|
||||||
|
@ -145,6 +171,7 @@ func TestAvbAddHashFooter(t *testing.T) {
|
||||||
file: "value_file",
|
file: "value_file",
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
|
include_descriptors_from_images: ["input_hashdesc"],
|
||||||
}
|
}
|
||||||
`)
|
`)
|
||||||
cmd := result.ModuleForTests("myfooter", "android_arm64_armv8-a").Rule("avbAddHashFooter").RuleParams.Command
|
cmd := result.ModuleForTests("myfooter", "android_arm64_armv8-a").Rule("avbAddHashFooter").RuleParams.Command
|
||||||
|
@ -158,4 +185,6 @@ func TestAvbAddHashFooter(t *testing.T) {
|
||||||
cmd, "--prop 'prop1:value1'")
|
cmd, "--prop 'prop1:value1'")
|
||||||
android.AssertStringDoesContain(t, "Can't find --prop_from_file argument",
|
android.AssertStringDoesContain(t, "Can't find --prop_from_file argument",
|
||||||
cmd, "--prop_from_file 'prop2:value_file'")
|
cmd, "--prop_from_file 'prop2:value_file'")
|
||||||
|
android.AssertStringDoesContain(t, "Can't find --include_descriptors_from_image",
|
||||||
|
cmd, "--include_descriptors_from_image ")
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue