Merge "DO NOT MERGE: Clean up when recycling a pid with a pending launch" into mnc-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
b51e98becb
@@ -3375,6 +3375,15 @@ public final class ActivityManagerService extends ActivityManagerNative
|
|||||||
app.killedByAm = false;
|
app.killedByAm = false;
|
||||||
checkTime(startTime, "startProcess: starting to update pids map");
|
checkTime(startTime, "startProcess: starting to update pids map");
|
||||||
synchronized (mPidsSelfLocked) {
|
synchronized (mPidsSelfLocked) {
|
||||||
|
ProcessRecord oldApp;
|
||||||
|
// If there is already an app occupying that pid that hasn't been cleaned up
|
||||||
|
if ((oldApp = mPidsSelfLocked.get(startResult.pid)) != null && !app.isolated) {
|
||||||
|
// Clean up anything relating to this pid first
|
||||||
|
Slog.w(TAG, "Reusing pid " + startResult.pid
|
||||||
|
+ " while app is still mapped to it");
|
||||||
|
cleanUpApplicationRecordLocked(oldApp, false, false, -1,
|
||||||
|
true /*replacingPid*/);
|
||||||
|
}
|
||||||
this.mPidsSelfLocked.put(startResult.pid, app);
|
this.mPidsSelfLocked.put(startResult.pid, app);
|
||||||
if (isActivityProcess) {
|
if (isActivityProcess) {
|
||||||
Message msg = mHandler.obtainMessage(PROC_START_TIMEOUT_MSG);
|
Message msg = mHandler.obtainMessage(PROC_START_TIMEOUT_MSG);
|
||||||
@@ -4515,7 +4524,8 @@ public final class ActivityManagerService extends ActivityManagerNative
|
|||||||
private final void handleAppDiedLocked(ProcessRecord app,
|
private final void handleAppDiedLocked(ProcessRecord app,
|
||||||
boolean restarting, boolean allowRestart) {
|
boolean restarting, boolean allowRestart) {
|
||||||
int pid = app.pid;
|
int pid = app.pid;
|
||||||
boolean kept = cleanUpApplicationRecordLocked(app, restarting, allowRestart, -1);
|
boolean kept = cleanUpApplicationRecordLocked(app, restarting, allowRestart, -1,
|
||||||
|
false /*replacingPid*/);
|
||||||
if (!kept && !restarting) {
|
if (!kept && !restarting) {
|
||||||
removeLruProcessLocked(app);
|
removeLruProcessLocked(app);
|
||||||
if (pid > 0) {
|
if (pid > 0) {
|
||||||
@@ -15441,7 +15451,8 @@ public final class ActivityManagerService extends ActivityManagerNative
|
|||||||
* app that was passed in must remain on the process lists.
|
* app that was passed in must remain on the process lists.
|
||||||
*/
|
*/
|
||||||
private final boolean cleanUpApplicationRecordLocked(ProcessRecord app,
|
private final boolean cleanUpApplicationRecordLocked(ProcessRecord app,
|
||||||
boolean restarting, boolean allowRestart, int index) {
|
boolean restarting, boolean allowRestart, int index, boolean replacingPid) {
|
||||||
|
Slog.d(TAG, "cleanUpApplicationRecord -- " + app.pid);
|
||||||
if (index >= 0) {
|
if (index >= 0) {
|
||||||
removeLruProcessLocked(app);
|
removeLruProcessLocked(app);
|
||||||
ProcessList.remove(app.pid);
|
ProcessList.remove(app.pid);
|
||||||
@@ -15571,7 +15582,9 @@ public final class ActivityManagerService extends ActivityManagerNative
|
|||||||
if (!app.persistent || app.isolated) {
|
if (!app.persistent || app.isolated) {
|
||||||
if (DEBUG_PROCESSES || DEBUG_CLEANUP) Slog.v(TAG_CLEANUP,
|
if (DEBUG_PROCESSES || DEBUG_CLEANUP) Slog.v(TAG_CLEANUP,
|
||||||
"Removing non-persistent process during cleanup: " + app);
|
"Removing non-persistent process during cleanup: " + app);
|
||||||
removeProcessNameLocked(app.processName, app.uid);
|
if (!replacingPid) {
|
||||||
|
removeProcessNameLocked(app.processName, app.uid);
|
||||||
|
}
|
||||||
if (mHeavyWeightProcess == app) {
|
if (mHeavyWeightProcess == app) {
|
||||||
mHandler.sendMessage(mHandler.obtainMessage(CANCEL_HEAVY_NOTIFICATION_MSG,
|
mHandler.sendMessage(mHandler.obtainMessage(CANCEL_HEAVY_NOTIFICATION_MSG,
|
||||||
mHeavyWeightProcess.userId, 0));
|
mHeavyWeightProcess.userId, 0));
|
||||||
@@ -19402,7 +19415,7 @@ public final class ActivityManagerService extends ActivityManagerNative
|
|||||||
// Ignore exceptions.
|
// Ignore exceptions.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
cleanUpApplicationRecordLocked(app, false, true, -1);
|
cleanUpApplicationRecordLocked(app, false, true, -1, false /*replacingPid*/);
|
||||||
mRemovedProcesses.remove(i);
|
mRemovedProcesses.remove(i);
|
||||||
|
|
||||||
if (app.persistent) {
|
if (app.persistent) {
|
||||||
|
|||||||
@@ -291,6 +291,11 @@ public final class BroadcastQueue {
|
|||||||
boolean didSomething = false;
|
boolean didSomething = false;
|
||||||
final BroadcastRecord br = mPendingBroadcast;
|
final BroadcastRecord br = mPendingBroadcast;
|
||||||
if (br != null && br.curApp.pid == app.pid) {
|
if (br != null && br.curApp.pid == app.pid) {
|
||||||
|
if (br.curApp != app) {
|
||||||
|
Slog.e(TAG, "App mismatch when sending pending broadcast to "
|
||||||
|
+ app.processName + ", intended target is " + br.curApp.processName);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
try {
|
try {
|
||||||
mPendingBroadcast = null;
|
mPendingBroadcast = null;
|
||||||
processCurBroadcastLocked(br, app);
|
processCurBroadcastLocked(br, app);
|
||||||
|
|||||||
Reference in New Issue
Block a user