diff options
| author | Jeff Sharkey <jsharkey@android.com> | 2014-08-27 17:58:37 +0000 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2014-08-27 17:58:38 +0000 |
| commit | a9bdc43ec2b8862db579aaced357184b7496468f (patch) | |
| tree | 95259ab6fbf4808598b53255a59e99a981058b48 | |
| parent | d1caf731e400a052bee2a7251bf0b985081227c3 (diff) | |
| parent | c5212217403696f81d2db220a1d9b22872600275 (diff) | |
| download | frameworks_base-a9bdc43ec2b8862db579aaced357184b7496468f.zip frameworks_base-a9bdc43ec2b8862db579aaced357184b7496468f.tar.gz frameworks_base-a9bdc43ec2b8862db579aaced357184b7496468f.tar.bz2 | |
Merge "Recreate lib symlink after deleting app data." into lmp-dev
| -rw-r--r-- | services/core/java/com/android/server/pm/PackageManagerService.java | 29 |
1 files changed, 21 insertions, 8 deletions
diff --git a/services/core/java/com/android/server/pm/PackageManagerService.java b/services/core/java/com/android/server/pm/PackageManagerService.java index c230434..89878ef 100644 --- a/services/core/java/com/android/server/pm/PackageManagerService.java +++ b/services/core/java/com/android/server/pm/PackageManagerService.java @@ -11051,34 +11051,34 @@ public class PackageManagerService extends IPackageManager.Stub { Slog.w(TAG, "Attempt to delete null packageName."); return false; } - PackageParser.Package p; + PackageParser.Package pkg; boolean dataOnly = false; final int appId; synchronized (mPackages) { - p = mPackages.get(packageName); - if (p == null) { + pkg = mPackages.get(packageName); + if (pkg == null) { dataOnly = true; PackageSetting ps = mSettings.mPackages.get(packageName); if ((ps == null) || (ps.pkg == null)) { Slog.w(TAG, "Package named '" + packageName + "' doesn't exist."); return false; } - p = ps.pkg; + pkg = ps.pkg; } if (!dataOnly) { // need to check this only for fully installed applications - if (p == null) { + if (pkg == null) { Slog.w(TAG, "Package named '" + packageName + "' doesn't exist."); return false; } - final ApplicationInfo applicationInfo = p.applicationInfo; + final ApplicationInfo applicationInfo = pkg.applicationInfo; if (applicationInfo == null) { Slog.w(TAG, "Package " + packageName + " has no applicationInfo."); return false; } } - if (p != null && p.applicationInfo != null) { - appId = p.applicationInfo.uid; + if (pkg != null && pkg.applicationInfo != null) { + appId = pkg.applicationInfo.uid; } else { appId = -1; } @@ -11090,6 +11090,19 @@ public class PackageManagerService extends IPackageManager.Stub { return false; } removeKeystoreDataIfNeeded(userId, appId); + + // Create a native library symlink only if we have native libraries + // and if the native libraries are 32 bit libraries. We do not provide + // this symlink for 64 bit libraries. + if (pkg != null && pkg.applicationInfo.primaryCpuAbi != null && + !VMRuntime.is64BitAbi(pkg.applicationInfo.primaryCpuAbi)) { + final String nativeLibPath = pkg.applicationInfo.nativeLibraryDir; + if (mInstaller.linkNativeLibraryDirectory(pkg.packageName, nativeLibPath, userId) < 0) { + Slog.w(TAG, "Failed linking native library dir"); + return false; + } + } + return true; } |
