Merge "Create an installation rule to copy vdex to common arch device directory" into main am: acfa26b5ba
				
					
				
			Original change: https://android-review.googlesource.com/c/platform/build/soong/+/3200722 Change-Id: I25a5681cdec7fa2e105a251503041b38d25cf917 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
		| @@ -943,20 +943,17 @@ func packageFileForTargetImage(ctx android.ModuleContext, image *bootImageVarian | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	for _, install := range image.vdexInstalls { | 	for _, install := range image.vdexInstalls { | ||||||
| 		if image.target.Arch.ArchType.Name != ctx.DeviceConfig().DeviceArch() { | 		installPath, relDir, name := getModuleInstallPathInfo(ctx, install.To) | ||||||
| 			// Note that the vdex files are identical between architectures. If the target image is | 		if name == "" { | ||||||
| 			// not for the primary architecture create symlinks to share the vdex of the primary | 			continue | ||||||
| 			// architecture with the other architectures. | 		} | ||||||
| 			// | 		// Note that the vdex files are identical between architectures. Copy the vdex to a no arch directory | ||||||
| 			// Assuming that the install path has the architecture name with it, replace the | 		// and create symlinks for both the primary and secondary arches. | ||||||
| 			// architecture name with the primary architecture name to find the source vdex file. | 		ctx.InstallSymlink(installPath.Join(ctx, relDir), name, installPath.Join(ctx, "framework", name)) | ||||||
| 			installPath, relDir, name := getModuleInstallPathInfo(ctx, install.To) | 		if image.target.Arch.ArchType.Name == ctx.DeviceConfig().DeviceArch() { | ||||||
| 			if name != "" { | 			// Copy the vdex from the primary arch to the no-arch directory | ||||||
| 				srcRelDir := strings.Replace(relDir, image.target.Arch.ArchType.Name, ctx.DeviceConfig().DeviceArch(), 1) | 			// e.g. /system/framework/$bootjar.vdex | ||||||
| 				ctx.InstallSymlink(installPath.Join(ctx, relDir), name, installPath.Join(ctx, srcRelDir, name)) | 			ctx.InstallFile(installPath.Join(ctx, "framework"), name, install.From) | ||||||
| 			} |  | ||||||
| 		} else { |  | ||||||
| 			packageFile(ctx, install) |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user