diff options
Diffstat (limited to 'filesystem/filesystem.go')
| -rw-r--r-- | filesystem/filesystem.go | 78 | 
1 files changed, 35 insertions, 43 deletions
| diff --git a/filesystem/filesystem.go b/filesystem/filesystem.go index 7336d3535..ad19cc6e0 100644 --- a/filesystem/filesystem.go +++ b/filesystem/filesystem.go @@ -464,18 +464,34 @@ func (f *filesystem) GenerateAndroidBuildActions(ctx android.ModuleContext) {  		ctx.PropertyErrorf("include_files_of", "include_files_of is only supported for cpio and compressed cpio filesystem types.")  	} -	var rootDir android.OutputPath -	var rebasedDir android.OutputPath +	rootDir := android.PathForModuleOut(ctx, f.rootDirString()).OutputPath +	rebasedDir := rootDir +	if f.properties.Base_dir != nil { +		rebasedDir = rootDir.Join(ctx, *f.properties.Base_dir) +	} +	builder := android.NewRuleBuilder(pctx, ctx) + +	// 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 mapFile android.Path  	var outputHermetic android.Path  	switch f.fsType(ctx) {  	case ext4Type, erofsType, f2fsType: -		f.output, outputHermetic, rootDir, rebasedDir = f.buildImageUsingBuildImage(ctx) +		f.output, outputHermetic = f.buildImageUsingBuildImage(ctx, builder, rootDir, rebasedDir)  		mapFile = f.getMapFile(ctx)  	case compressedCpioType: -		f.output, rootDir, rebasedDir = f.buildCpioImage(ctx, true) +		f.output = f.buildCpioImage(ctx, builder, rootDir, true)  	case cpioType: -		f.output, rootDir, rebasedDir = f.buildCpioImage(ctx, false) +		f.output = f.buildCpioImage(ctx, builder, rootDir, false)  	default:  		return  	} @@ -649,24 +665,12 @@ func (f *filesystem) rootDirString() string {  	return f.partitionName()  } -func (f *filesystem) buildImageUsingBuildImage(ctx android.ModuleContext) (android.Path, android.Path, android.OutputPath, android.OutputPath) { -	rootDir := android.PathForModuleOut(ctx, f.rootDirString()).OutputPath -	rebasedDir := rootDir -	if f.properties.Base_dir != nil { -		rebasedDir = rootDir.Join(ctx, *f.properties.Base_dir) -	} -	builder := android.NewRuleBuilder(pctx, ctx) -	// 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) - +func (f *filesystem) buildImageUsingBuildImage( +	ctx android.ModuleContext, +	builder *android.RuleBuilder, +	rootDir android.OutputPath, +	rebasedDir android.OutputPath, +) (android.Path, android.Path) {  	// run host_init_verifier  	// Ideally we should have a concept of pluggable linters that verify the generated image.  	// While such concept is not implement this will do. @@ -717,7 +721,7 @@ func (f *filesystem) buildImageUsingBuildImage(ctx android.ModuleContext) (andro  	// 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, rootDir, rebasedDir +	return output, outputHermetic  }  func (f *filesystem) buildFileContexts(ctx android.ModuleContext) android.Path { @@ -911,7 +915,12 @@ func includeFilesRootDir(ctx android.ModuleContext) (rootDirs android.Paths, par  	return rootDirs, partitions  } -func (f *filesystem) buildCpioImage(ctx android.ModuleContext, compressed bool) (android.Path, android.OutputPath, android.OutputPath) { +func (f *filesystem) buildCpioImage( +	ctx android.ModuleContext, +	builder *android.RuleBuilder, +	rootDir android.OutputPath, +	compressed bool, +) android.Path {  	if proptools.Bool(f.properties.Use_avb) {  		ctx.PropertyErrorf("use_avb", "signing compresed cpio image using avbtool is not supported."+  			"Consider adding this to bootimg module and signing the entire boot image.") @@ -921,23 +930,6 @@ func (f *filesystem) buildCpioImage(ctx android.ModuleContext, compressed bool)  		ctx.PropertyErrorf("file_contexts", "file_contexts is not supported for compressed cpio image.")  	} -	rootDir := android.PathForModuleOut(ctx, f.rootDirString()).OutputPath -	rebasedDir := rootDir -	if f.properties.Base_dir != nil { -		rebasedDir = rootDir.Join(ctx, *f.properties.Base_dir) -	} -	builder := android.NewRuleBuilder(pctx, ctx) -	// 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) -  	rootDirs, partitions := includeFilesRootDir(ctx)  	output := android.PathForModuleOut(ctx, f.installFileName()) @@ -967,7 +959,7 @@ func (f *filesystem) buildCpioImage(ctx android.ModuleContext, compressed bool)  	// rootDir is not deleted. Might be useful for quick inspection.  	builder.Build("build_cpio_image", fmt.Sprintf("Creating filesystem %s", f.BaseModuleName())) -	return output, rootDir, rebasedDir +	return output  }  var validPartitions = []string{ |