Move the installation rules of boot images to soong
This CL adds moves the installation rules of boot images to soong. This will eventually allow us to build devices by skipping `katiBuild` and moving straight to `katiPackaging` Details 1. Drop `no_full_install` from dex_bootjars singleton. This ensures that the files installed by this singleton module does not get skipped when generating the soong installs file (out/soong/installs-*) 2. Replace PackageFile with InstallFile. This registers the installation rules for both make-built and soong-built images (e.g. aosp_cf_system_x86_64) 3. Implement `AndroidMkEntries` for dex_bootjars singleton. OutputFile needs to be non-nil so that this module does not get elided when generating out/soong/Android-*. `OutputFile` was abritrarily set to one of the many files installed by this singleton. Test: no diff in target/product/vsoc_x86_64/obj/PACKAGING/system_intermediates/file_list.txt (top of stack) Bug: 355700341 Bug: 355703904 Change-Id: I3531defa6bba58ef78f6d66e881502a8222fc229
This commit is contained in:
@@ -491,6 +491,11 @@ type dexpreoptBootJars struct {
|
||||
// Build path to a config file that Soong writes for Make (to be used in makefiles that install
|
||||
// the default boot image).
|
||||
dexpreoptConfigForMake android.WritablePath
|
||||
|
||||
// Build path to the boot framework profile.
|
||||
// This is used as the `OutputFile` in `AndroidMkEntries`.
|
||||
// A non-nil value ensures that this singleton module does not get skipped in AndroidMkEntries processing.
|
||||
bootFrameworkProfile android.WritablePath
|
||||
}
|
||||
|
||||
func (dbj *dexpreoptBootJars) DepsMutator(ctx android.BottomUpMutatorContext) {
|
||||
@@ -603,7 +608,8 @@ func (d *dexpreoptBootJars) GenerateAndroidBuildActions(ctx android.ModuleContex
|
||||
installs := generateBootImage(ctx, config)
|
||||
profileInstalls = append(profileInstalls, installs...)
|
||||
if config == d.defaultBootImage {
|
||||
_, installs := bootFrameworkProfileRule(ctx, config)
|
||||
bootProfile, installs := bootFrameworkProfileRule(ctx, config)
|
||||
d.bootFrameworkProfile = bootProfile
|
||||
profileInstalls = append(profileInstalls, installs...)
|
||||
}
|
||||
}
|
||||
@@ -613,7 +619,7 @@ func (d *dexpreoptBootJars) GenerateAndroidBuildActions(ctx android.ModuleContex
|
||||
profileLicenseMetadataFile: android.OptionalPathForPath(ctx.LicenseMetadataFile()),
|
||||
})
|
||||
for _, install := range profileInstalls {
|
||||
packageFile(ctx, install)
|
||||
installFile(ctx, install)
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -939,7 +945,7 @@ func packageFileForTargetImage(ctx android.ModuleContext, image *bootImageVarian
|
||||
}
|
||||
|
||||
for _, install := range image.installs {
|
||||
packageFile(ctx, install)
|
||||
installFile(ctx, install)
|
||||
}
|
||||
|
||||
for _, install := range image.vdexInstalls {
|
||||
@@ -1231,7 +1237,7 @@ func bootImageProfileRule(ctx android.ModuleContext, image *bootImageConfig) (an
|
||||
|
||||
profile := bootImageProfileRuleCommon(ctx, image.name, image.dexPathsDeps.Paths(), image.getAnyAndroidVariant().dexLocationsDeps)
|
||||
|
||||
if image == defaultBootImageConfig(ctx) {
|
||||
if image == defaultBootImageConfig(ctx) && profile != nil {
|
||||
rule := android.NewRuleBuilder(pctx, ctx)
|
||||
rule.Install(profile, "/system/etc/boot-image.prof")
|
||||
return profile, rule.Installs()
|
||||
@@ -1377,3 +1383,12 @@ func (d *dexpreoptBootJars) MakeVars(ctx android.MakeVarsContext) {
|
||||
ctx.Strict("DEXPREOPT_IMAGE_NAMES", strings.Join(getImageNames(), " "))
|
||||
}
|
||||
}
|
||||
|
||||
// Add one of the outputs in `OutputFile`
|
||||
// This ensures that this singleton module does not get skipped when writing out/soong/Android-*.mk
|
||||
func (d *dexpreoptBootJars) AndroidMkEntries() []android.AndroidMkEntries {
|
||||
return []android.AndroidMkEntries{{
|
||||
Class: "ETC",
|
||||
OutputFile: android.OptionalPathForPath(d.bootFrameworkProfile),
|
||||
}}
|
||||
}
|
||||
|
Reference in New Issue
Block a user