diff options
Diffstat (limited to 'filesystem/filesystem.go')
| -rw-r--r-- | filesystem/filesystem.go | 159 | 
1 files changed, 129 insertions, 30 deletions
| diff --git a/filesystem/filesystem.go b/filesystem/filesystem.go index 357ec32ba..0ce31b293 100644 --- a/filesystem/filesystem.go +++ b/filesystem/filesystem.go @@ -79,7 +79,7 @@ type filesystem struct {  }  type filesystemBuilder interface { -	BuildLinkerConfigFile(ctx android.ModuleContext, builder *android.RuleBuilder, rebasedDir android.OutputPath) +	BuildLinkerConfigFile(ctx android.ModuleContext, builder *android.RuleBuilder, rebasedDir android.OutputPath, fullInstallPaths *[]FullInstallPathInfo)  	// Function that filters PackagingSpec in PackagingBase.GatherPackagingSpecs()  	FilterPackagingSpec(spec android.PackagingSpec) bool  	// Function that modifies PackagingSpec in PackagingBase.GatherPackagingSpecs() to customize. @@ -119,7 +119,7 @@ type FilesystemProperties struct {  	Avb_algorithm *string  	// Hash algorithm used for avbtool (for descriptors). This is passed as hash_algorithm to -	// avbtool. Default used by avbtool is sha1. +	// avbtool. Default is sha256.  	Avb_hash_algorithm *string  	// The security patch passed to as the com.android.build.<type>.security_patch avb property. @@ -389,6 +389,34 @@ type FilesystemInfo struct {  	BuildImagePropFileDeps android.Paths  	// Packaging specs to be installed on the system_other image, for the initial boot's dexpreopt.  	SpecsForSystemOther map[string]android.PackagingSpec + +	FullInstallPaths []FullInstallPathInfo +} + +// FullInstallPathInfo contains information about the "full install" paths of all the files +// inside this partition. The full install paths are the files installed in +// out/target/product/<device>/<partition>. This is essentially legacy behavior, maintained for +// tools like adb sync and adevice, but we should update them to query the build system for the +// installed files no matter where they are. +type FullInstallPathInfo struct { +	// RequiresFullInstall tells us if the origional module did the install to FullInstallPath +	// already. If it's false, the android_device module needs to emit the install rule. +	RequiresFullInstall bool +	// The "full install" paths for the files in this filesystem. This is the paths in the +	// out/target/product/<device>/<partition> folder. They're not used by this filesystem, +	// but can be depended on by the top-level android_device module to cause the staging +	// directories to be built. +	FullInstallPath android.InstallPath + +	// The file that's copied to FullInstallPath. May be nil if SymlinkTarget is set or IsDir is +	// true. +	SourcePath android.Path + +	// The target of the symlink, if this file is a symlink. +	SymlinkTarget string + +	// If this file is a directory. Only used for empty directories, which are mostly mount points. +	IsDir bool  }  var FilesystemProvider = blueprint.NewProvider[FilesystemInfo]() @@ -441,6 +469,13 @@ func (f *filesystem) FilterPackagingSpec(ps android.PackagingSpec) bool {  	if ps.SkipInstall() {  		return false  	} +	// "apex" is a fake partition used to install files in out/target/product/<device>/apex/. +	// Don't include these files in the partition. We should also look into removing the following +	// TODO to check the PackagingSpec's partition against this filesystem's partition for all +	// modules, not just autogenerated ones, which will fix this as well. +	if ps.Partition() == "apex" { +		return false +	}  	if proptools.Bool(f.properties.Is_auto_generated) { // TODO (spandandas): Remove this.  		pt := f.PartitionType()  		return ps.Partition() == pt || strings.HasPrefix(ps.Partition(), pt+"/") @@ -485,13 +520,23 @@ func (f *filesystem) GenerateAndroidBuildActions(ctx android.ModuleContext) {  	// Wipe the root dir to get rid of leftover files from prior builds  	builder.Command().Textf("rm -rf %s && mkdir -p %s", rootDir, rootDir)  	specs := f.gatherFilteredPackagingSpecs(ctx) -	f.entries = f.copyPackagingSpecs(ctx, builder, specs, rootDir, rebasedDir) -	f.buildNonDepsFiles(ctx, builder, rootDir) -	f.buildFsverityMetadataFiles(ctx, builder, specs, rootDir, rebasedDir) -	f.buildEventLogtagsFile(ctx, builder, rebasedDir) -	f.buildAconfigFlagsFiles(ctx, builder, specs, rebasedDir) -	f.filesystemBuilder.BuildLinkerConfigFile(ctx, builder, rebasedDir) +	var fullInstallPaths []FullInstallPathInfo +	for _, spec := range specs { +		fullInstallPaths = append(fullInstallPaths, FullInstallPathInfo{ +			FullInstallPath:     spec.FullInstallPath(), +			RequiresFullInstall: spec.RequiresFullInstall(), +			SourcePath:          spec.SrcPath(), +			SymlinkTarget:       spec.ToGob().SymlinkTarget, +		}) +	} + +	f.entries = f.copyPackagingSpecs(ctx, builder, specs, rootDir, rebasedDir) +	f.buildNonDepsFiles(ctx, builder, rootDir, rebasedDir, &fullInstallPaths) +	f.buildFsverityMetadataFiles(ctx, builder, specs, rootDir, rebasedDir, &fullInstallPaths) +	f.buildEventLogtagsFile(ctx, builder, rebasedDir, &fullInstallPaths) +	f.buildAconfigFlagsFiles(ctx, builder, specs, rebasedDir, &fullInstallPaths) +	f.filesystemBuilder.BuildLinkerConfigFile(ctx, builder, rebasedDir, &fullInstallPaths)  	var mapFile android.Path  	var outputHermetic android.Path @@ -531,6 +576,7 @@ func (f *filesystem) GenerateAndroidBuildActions(ctx android.ModuleContext) {  		BuildImagePropFile:     buildImagePropFile,  		BuildImagePropFileDeps: buildImagePropFileDeps,  		SpecsForSystemOther:    f.systemOtherFiles(ctx), +		FullInstallPaths:       fullInstallPaths,  	}  	android.SetProvider(ctx, FilesystemProvider, fsInfo) @@ -645,11 +691,36 @@ func validatePartitionType(ctx android.ModuleContext, p partition) {  // Copy extra files/dirs that are not from the `deps` property to `rootDir`, checking for conflicts with files  // already in `rootDir`. -func (f *filesystem) buildNonDepsFiles(ctx android.ModuleContext, builder *android.RuleBuilder, rootDir android.OutputPath) { +func (f *filesystem) buildNonDepsFiles( +	ctx android.ModuleContext, +	builder *android.RuleBuilder, +	rootDir android.OutputPath, +	rebasedDir android.OutputPath, +	fullInstallPaths *[]FullInstallPathInfo, +) { +	rebasedPrefix, err := filepath.Rel(rootDir.String(), rebasedDir.String()) +	if err != nil || strings.HasPrefix(rebasedPrefix, "../") { +		panic("rebasedDir could not be made relative to rootDir") +	} +	if !strings.HasSuffix(rebasedPrefix, "/") { +		rebasedPrefix += "/" +	} +	if rebasedPrefix == "./" { +		rebasedPrefix = "" +	} +  	// create dirs and symlinks  	for _, dir := range f.properties.Dirs.GetOrDefault(ctx, nil) {  		// OutputPath.Join verifies dir  		builder.Command().Text("mkdir -p").Text(rootDir.Join(ctx, dir).String()) +		// Only add the fullInstallPath logic for files in the rebased dir. The root dir +		// is harder to install to. +		if strings.HasPrefix(dir, rebasedPrefix) { +			*fullInstallPaths = append(*fullInstallPaths, FullInstallPathInfo{ +				FullInstallPath: android.PathForModuleInPartitionInstall(ctx, f.PartitionType(), strings.TrimPrefix(dir, rebasedPrefix)), +				IsDir:           true, +			}) +		}  	}  	for _, symlink := range f.properties.Symlinks { @@ -672,6 +743,14 @@ func (f *filesystem) buildNonDepsFiles(ctx android.ModuleContext, builder *andro  		builder.Command().Text("mkdir -p").Text(filepath.Dir(dst.String()))  		builder.Command().Text("ln -sf").Text(proptools.ShellEscape(target)).Text(dst.String())  		f.appendToEntry(ctx, dst) +		// Only add the fullInstallPath logic for files in the rebased dir. The root dir +		// is harder to install to. +		if strings.HasPrefix(name, rebasedPrefix) { +			*fullInstallPaths = append(*fullInstallPaths, FullInstallPathInfo{ +				FullInstallPath: android.PathForModuleInPartitionInstall(ctx, f.PartitionType(), strings.TrimPrefix(name, rebasedPrefix)), +				SymlinkTarget:   target, +			}) +		}  	}  	// https://cs.android.com/android/platform/superproject/main/+/main:build/make/core/Makefile;l=2835;drc=b186569ef00ff2f2a1fab28aedc75ebc32bcd67b @@ -738,22 +817,23 @@ func (f *filesystem) buildImageUsingBuildImage(  		Output(output).  		Text(rootDir.String()) // directory where to find fs_config_files|dirs +	// TODO (b/393203512): Re-enable hermetic img file creation for target_files.zip  	// Add an additional cmd to create a hermetic img file. This will contain pinned timestamps e.g. -	propFilePinnedTimestamp := android.PathForModuleOut(ctx, "for_target_files", "prop") -	builder.Command().Textf("cat").Input(propFile).Flag(">").Output(propFilePinnedTimestamp). -		Textf(" && echo use_fixed_timestamp=true >> %s", propFilePinnedTimestamp). -		Textf(" && echo block_list=%s >> %s", f.getMapFile(ctx).String(), propFilePinnedTimestamp) // mapfile will be an implicit output - -	outputHermetic := android.PathForModuleOut(ctx, "for_target_files", f.installFileName()) -	builder.Command(). -		Textf("PATH=%s:$PATH", strings.Join(pathToolDirs, ":")). -		BuiltTool("build_image"). -		Text(rootDir.String()). // input directory -		Flag(propFilePinnedTimestamp.String()). -		Implicits(toolDeps). -		Implicit(fec). -		Output(outputHermetic). -		Text(rootDir.String()) // directory where to find fs_config_files|dirs +	//propFilePinnedTimestamp := android.PathForModuleOut(ctx, "for_target_files", "prop") +	//builder.Command().Textf("cat").Input(propFile).Flag(">").Output(propFilePinnedTimestamp). +	//	Textf(" && echo use_fixed_timestamp=true >> %s", propFilePinnedTimestamp). +	//	Textf(" && echo block_list=%s >> %s", f.getMapFile(ctx).String(), propFilePinnedTimestamp) // mapfile will be an implicit output + +	//outputHermetic := android.PathForModuleOut(ctx, "for_target_files", f.installFileName()) +	//builder.Command(). +	//	Textf("PATH=%s:$PATH", strings.Join(pathToolDirs, ":")). +	//	BuiltTool("build_image"). +	//	Text(rootDir.String()). // input directory +	//	Flag(propFilePinnedTimestamp.String()). +	//	Implicits(toolDeps). +	//	Implicit(fec). +	//	Output(outputHermetic). +	//	Text(rootDir.String()) // directory where to find fs_config_files|dirs  	if f.properties.Partition_size != nil {  		assertMaxImageSize(builder, output, *f.properties.Partition_size, false) @@ -762,7 +842,7 @@ func (f *filesystem) buildImageUsingBuildImage(  	// rootDir is not deleted. Might be useful for quick inspection.  	builder.Build("build_filesystem_image", fmt.Sprintf("Creating filesystem %s", f.BaseModuleName())) -	return output, outputHermetic, propFile, toolDeps +	return output, nil, propFile, toolDeps  }  func (f *filesystem) buildFileContexts(ctx android.ModuleContext) android.Path { @@ -823,9 +903,8 @@ func (f *filesystem) buildPropFile(ctx android.ModuleContext) (android.Path, and  		if !proptools.BoolDefault(f.properties.Use_fec, true) {  			avb_add_hashtree_footer_args += " --do_not_generate_fec"  		} -		if hashAlgorithm := proptools.String(f.properties.Avb_hash_algorithm); hashAlgorithm != "" { -			avb_add_hashtree_footer_args += " --hash_algorithm " + hashAlgorithm -		} +		hashAlgorithm := proptools.StringDefault(f.properties.Avb_hash_algorithm, "sha256") +		avb_add_hashtree_footer_args += " --hash_algorithm " + hashAlgorithm  		if f.properties.Rollback_index != nil {  			rollbackIndex := proptools.Int(f.properties.Rollback_index)  			if rollbackIndex < 0 { @@ -1018,7 +1097,12 @@ var validPartitions = []string{  	"recovery",  } -func (f *filesystem) buildEventLogtagsFile(ctx android.ModuleContext, builder *android.RuleBuilder, rebasedDir android.OutputPath) { +func (f *filesystem) buildEventLogtagsFile( +	ctx android.ModuleContext, +	builder *android.RuleBuilder, +	rebasedDir android.OutputPath, +	fullInstallPaths *[]FullInstallPathInfo, +) {  	if !proptools.Bool(f.properties.Build_logtags) {  		return  	} @@ -1028,10 +1112,20 @@ func (f *filesystem) buildEventLogtagsFile(ctx android.ModuleContext, builder *a  	builder.Command().Text("mkdir").Flag("-p").Text(etcPath.String())  	builder.Command().Text("cp").Input(android.MergedLogtagsPath(ctx)).Text(eventLogtagsPath.String()) +	*fullInstallPaths = append(*fullInstallPaths, FullInstallPathInfo{ +		FullInstallPath: android.PathForModuleInPartitionInstall(ctx, f.PartitionType(), "etc", "event-log-tags"), +		SourcePath:      android.MergedLogtagsPath(ctx), +	}) +  	f.appendToEntry(ctx, eventLogtagsPath)  } -func (f *filesystem) BuildLinkerConfigFile(ctx android.ModuleContext, builder *android.RuleBuilder, rebasedDir android.OutputPath) { +func (f *filesystem) BuildLinkerConfigFile( +	ctx android.ModuleContext, +	builder *android.RuleBuilder, +	rebasedDir android.OutputPath, +	fullInstallPaths *[]FullInstallPathInfo, +) {  	if !proptools.Bool(f.properties.Linker_config.Gen_linker_config) {  		return  	} @@ -1042,6 +1136,11 @@ func (f *filesystem) BuildLinkerConfigFile(ctx android.ModuleContext, builder *a  	output := rebasedDir.Join(ctx, "etc", "linker.config.pb")  	builder.Command().Text("cp").Input(intermediateOutput).Output(output) +	*fullInstallPaths = append(*fullInstallPaths, FullInstallPathInfo{ +		FullInstallPath: android.PathForModuleInPartitionInstall(ctx, f.PartitionType(), "etc", "linker.config.pb"), +		SourcePath:      intermediateOutput, +	}) +  	f.appendToEntry(ctx, output)  } |