Loading services/core/java/com/android/server/pm/ApexManager.java +15 −3 Original line number Diff line number Diff line Loading @@ -32,6 +32,7 @@ import android.content.pm.PackageInstaller; import android.content.pm.PackageManager; import android.content.pm.PackageParser.PackageParserException; import android.content.pm.parsing.PackageInfoWithoutStateUtils; import android.content.pm.parsing.ParsingPackageUtils; import android.os.Binder; import android.os.Environment; import android.os.RemoteException; Loading @@ -49,6 +50,7 @@ import com.android.internal.util.IndentingPrintWriter; import com.android.internal.util.Preconditions; import com.android.server.pm.parsing.PackageParser2; import com.android.server.pm.parsing.pkg.AndroidPackage; import com.android.server.pm.parsing.pkg.ParsedPackage; import com.android.server.utils.TimingsTraceAndSlog; import com.google.android.collect.Lists; Loading Loading @@ -480,7 +482,7 @@ public abstract class ApexManager { if (allPkgs.length == 0) { return; } int flags = PackageManager.GET_META_DATA final int flags = PackageManager.GET_META_DATA | PackageManager.GET_SIGNING_CERTIFICATES | PackageManager.GET_SIGNATURES; ArrayMap<File, ApexInfo> parsingApexInfo = new ArrayMap<>(); Loading @@ -489,7 +491,7 @@ public abstract class ApexManager { for (ApexInfo ai : allPkgs) { File apexFile = new File(ai.modulePath); parallelPackageParser.submit(apexFile, flags); parallelPackageParser.submit(apexFile, 0); parsingApexInfo.put(apexFile, ai); } Loading @@ -502,8 +504,18 @@ public abstract class ApexManager { ApexInfo ai = parsingApexInfo.get(parseResult.scanFile); if (throwable == null) { // Unfortunately, ParallelPackageParser won't collect certificates for us. We // need to manually collect them here. ParsedPackage pp = parseResult.parsedPackage; try { pp.setSigningDetails( ParsingPackageUtils.collectCertificates(pp, false)); } catch (PackageParserException e) { throw new IllegalStateException( "Unable to collect certificates for " + ai.modulePath, e); } final PackageInfo packageInfo = PackageInfoWithoutStateUtils.generate( parseResult.parsedPackage, ai, flags); pp, ai, flags); if (packageInfo == null) { throw new IllegalStateException("Unable to generate package info: " + ai.modulePath); Loading Loading
services/core/java/com/android/server/pm/ApexManager.java +15 −3 Original line number Diff line number Diff line Loading @@ -32,6 +32,7 @@ import android.content.pm.PackageInstaller; import android.content.pm.PackageManager; import android.content.pm.PackageParser.PackageParserException; import android.content.pm.parsing.PackageInfoWithoutStateUtils; import android.content.pm.parsing.ParsingPackageUtils; import android.os.Binder; import android.os.Environment; import android.os.RemoteException; Loading @@ -49,6 +50,7 @@ import com.android.internal.util.IndentingPrintWriter; import com.android.internal.util.Preconditions; import com.android.server.pm.parsing.PackageParser2; import com.android.server.pm.parsing.pkg.AndroidPackage; import com.android.server.pm.parsing.pkg.ParsedPackage; import com.android.server.utils.TimingsTraceAndSlog; import com.google.android.collect.Lists; Loading Loading @@ -480,7 +482,7 @@ public abstract class ApexManager { if (allPkgs.length == 0) { return; } int flags = PackageManager.GET_META_DATA final int flags = PackageManager.GET_META_DATA | PackageManager.GET_SIGNING_CERTIFICATES | PackageManager.GET_SIGNATURES; ArrayMap<File, ApexInfo> parsingApexInfo = new ArrayMap<>(); Loading @@ -489,7 +491,7 @@ public abstract class ApexManager { for (ApexInfo ai : allPkgs) { File apexFile = new File(ai.modulePath); parallelPackageParser.submit(apexFile, flags); parallelPackageParser.submit(apexFile, 0); parsingApexInfo.put(apexFile, ai); } Loading @@ -502,8 +504,18 @@ public abstract class ApexManager { ApexInfo ai = parsingApexInfo.get(parseResult.scanFile); if (throwable == null) { // Unfortunately, ParallelPackageParser won't collect certificates for us. We // need to manually collect them here. ParsedPackage pp = parseResult.parsedPackage; try { pp.setSigningDetails( ParsingPackageUtils.collectCertificates(pp, false)); } catch (PackageParserException e) { throw new IllegalStateException( "Unable to collect certificates for " + ai.modulePath, e); } final PackageInfo packageInfo = PackageInfoWithoutStateUtils.generate( parseResult.parsedPackage, ai, flags); pp, ai, flags); if (packageInfo == null) { throw new IllegalStateException("Unable to generate package info: " + ai.modulePath); Loading