Merge "[framework] Add check that classpath is up to date to getDexOptNeeded"
am: 945b1dc43e
Change-Id: Ib9865f950f595ab840ceb3afd60ad52d33cb5c01
This commit is contained in:
@@ -553,7 +553,7 @@ public class ZygoteInit {
|
||||
try {
|
||||
dexoptNeeded = DexFile.getDexOptNeeded(
|
||||
classPathElement, instructionSet, systemServerFilter,
|
||||
false /* newProfile */, false /* downgrade */);
|
||||
null /* classLoaderContext */, false /* newProfile */, false /* downgrade */);
|
||||
} catch (FileNotFoundException ignored) {
|
||||
// Do not add to the classpath.
|
||||
Log.w(TAG, "Missing classpath element for system server: " + classPathElement);
|
||||
|
||||
@@ -209,9 +209,10 @@ public class PackageDexOptimizer {
|
||||
*/
|
||||
@GuardedBy("mInstallLock")
|
||||
private int dexOptPath(PackageParser.Package pkg, String path, String isa,
|
||||
String compilerFilter, boolean profileUpdated, String sharedLibrariesPath,
|
||||
String compilerFilter, boolean profileUpdated, String classLoaderContext,
|
||||
int dexoptFlags, int uid, CompilerStats.PackageStats packageStats, boolean downgrade) {
|
||||
int dexoptNeeded = getDexoptNeeded(path, isa, compilerFilter, profileUpdated, downgrade);
|
||||
int dexoptNeeded = getDexoptNeeded(path, isa, compilerFilter, classLoaderContext,
|
||||
profileUpdated, downgrade);
|
||||
if (Math.abs(dexoptNeeded) == DexFile.NO_DEXOPT_NEEDED) {
|
||||
return DEX_OPT_SKIPPED;
|
||||
}
|
||||
@@ -224,8 +225,8 @@ public class PackageDexOptimizer {
|
||||
Log.i(TAG, "Running dexopt (dexoptNeeded=" + dexoptNeeded + ") on: " + path
|
||||
+ " pkg=" + pkg.applicationInfo.packageName + " isa=" + isa
|
||||
+ " dexoptFlags=" + printDexoptFlags(dexoptFlags)
|
||||
+ " target-filter=" + compilerFilter + " oatDir=" + oatDir
|
||||
+ " sharedLibraries=" + sharedLibrariesPath);
|
||||
+ " targetFilter=" + compilerFilter + " oatDir=" + oatDir
|
||||
+ " classLoaderContext=" + classLoaderContext);
|
||||
|
||||
try {
|
||||
long startTime = System.currentTimeMillis();
|
||||
@@ -234,7 +235,7 @@ public class PackageDexOptimizer {
|
||||
// installd only uses downgrade flag for secondary dex files and ignores it for
|
||||
// primary dex files.
|
||||
mInstaller.dexopt(path, uid, pkg.packageName, isa, dexoptNeeded, oatDir, dexoptFlags,
|
||||
compilerFilter, pkg.volumeUuid, sharedLibrariesPath, pkg.applicationInfo.seInfo,
|
||||
compilerFilter, pkg.volumeUuid, classLoaderContext, pkg.applicationInfo.seInfo,
|
||||
false /* downgrade*/);
|
||||
|
||||
if (packageStats != null) {
|
||||
@@ -442,11 +443,11 @@ public class PackageDexOptimizer {
|
||||
* configuration (isa, compiler filter, profile).
|
||||
*/
|
||||
private int getDexoptNeeded(String path, String isa, String compilerFilter,
|
||||
boolean newProfile, boolean downgrade) {
|
||||
String classLoaderContext, boolean newProfile, boolean downgrade) {
|
||||
int dexoptNeeded;
|
||||
try {
|
||||
dexoptNeeded = DexFile.getDexOptNeeded(path, isa, compilerFilter, newProfile,
|
||||
downgrade);
|
||||
dexoptNeeded = DexFile.getDexOptNeeded(path, isa, compilerFilter, classLoaderContext,
|
||||
newProfile, downgrade);
|
||||
} catch (IOException ioe) {
|
||||
Slog.w(TAG, "IOException reading apk: " + path, ioe);
|
||||
return DEX_OPT_FAILED;
|
||||
|
||||
Reference in New Issue
Block a user