summaryrefslogtreecommitdiffstats
path: root/services/java/com
diff options
context:
space:
mode:
authorJeff Hamilton <jham@android.com>2010-05-25 22:10:18 -0500
committerJeff Hamilton <jham@android.com>2010-05-26 14:02:56 -0500
commitacf8474b6843215c6ee5da5e58630de0afa2be60 (patch)
tree7201a8431e664a6fb4070daf00e18aef2035bdcf /services/java/com
parent7e5e3745cf0103219a13071fbd488c3c01da85d9 (diff)
downloadframeworks_base-acf8474b6843215c6ee5da5e58630de0afa2be60.zip
frameworks_base-acf8474b6843215c6ee5da5e58630de0afa2be60.tar.gz
frameworks_base-acf8474b6843215c6ee5da5e58630de0afa2be60.tar.bz2
Don't enforce broadcast timeouts for PRE_BOOT_COMPLETED broadcasts.
They're designed to handle one time upgrade code, which may take a significant amount of time. Third party code cannot receive this broadcast so the timing should be able to be kept under control. Bug: 2713849 Change-Id: I3733b6530198bebd9b8c2ba6f9f27a7999336b8d
Diffstat (limited to 'services/java/com')
-rw-r--r--services/java/com/android/server/am/ActivityManagerService.java18
1 files changed, 14 insertions, 4 deletions
diff --git a/services/java/com/android/server/am/ActivityManagerService.java b/services/java/com/android/server/am/ActivityManagerService.java
index 022eccf..61ab197 100644
--- a/services/java/com/android/server/am/ActivityManagerService.java
+++ b/services/java/com/android/server/am/ActivityManagerService.java
@@ -1106,7 +1106,12 @@ public final class ActivityManagerService extends ActivityManagerNative implemen
mHandler.sendMessageDelayed(nmsg, BROADCAST_TIMEOUT);
return;
}
- broadcastTimeout();
+ // Only process broadcast timeouts if the system is ready. That way
+ // PRE_BOOT_COMPLETED broadcasts can't timeout as they are intended
+ // to do heavy lifting for system up
+ if (mSystemReady) {
+ broadcastTimeout();
+ }
} break;
case PAUSE_TIMEOUT_MSG: {
IBinder token = (IBinder)msg.obj;
@@ -13116,10 +13121,15 @@ public final class ActivityManagerService extends ActivityManagerNative implemen
// Ensure that even if something goes awry with the timeout
// detection, we catch "hung" broadcasts here, discard them,
- // and continue to make progress.
+ // and continue to make progress.
+ //
+ // This is only done if the system is ready so that PRE_BOOT_COMPLETED
+ // receivers don't get executed with with timeouts. They're intended for
+ // one time heavy lifting after system upgrades and can take
+ // significant amounts of time.
int numReceivers = (r.receivers != null) ? r.receivers.size() : 0;
- long now = SystemClock.uptimeMillis();
- if (r.dispatchTime > 0) {
+ if (mSystemReady && r.dispatchTime > 0) {
+ long now = SystemClock.uptimeMillis();
if ((numReceivers > 0) &&
(now > r.dispatchTime + (2*BROADCAST_TIMEOUT*numReceivers))) {
Slog.w(TAG, "Hung broadcast discarded after timeout failure:"