Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 525fad6c authored by Hui Yu's avatar Hui Yu Committed by Android (Google) Code Review
Browse files

Merge "Deferred BOOT_COMPLETED broadcast does not mean queue is not idle." into tm-dev

parents ccdd4e74 78002782
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -15093,7 +15093,7 @@ public class ActivityManagerService extends IActivityManager.Stub
    @GuardedBy("this")
    final boolean canGcNowLocked() {
        for (BroadcastQueue q : mBroadcastQueues) {
            if (!q.mParallelBroadcasts.isEmpty() || !q.mDispatcher.isEmpty()) {
            if (!q.mParallelBroadcasts.isEmpty() || !q.mDispatcher.isIdle()) {
                return false;
            }
        }
+15 −3
Original line number Diff line number Diff line
@@ -511,13 +511,25 @@ public class BroadcastDispatcher {
     * Standard contents-are-empty check
     */
    public boolean isEmpty() {
        synchronized (mLock) {
            return isIdle()
                    && getBootCompletedBroadcastsUidsSize(Intent.ACTION_LOCKED_BOOT_COMPLETED) == 0
                    && getBootCompletedBroadcastsUidsSize(Intent.ACTION_BOOT_COMPLETED) == 0;
        }
    }

    /**
     * Have less check than {@link #isEmpty()}.
     * The dispatcher is considered as idle even with deferred LOCKED_BOOT_COMPLETED/BOOT_COMPLETED
     * broadcasts because those can be deferred until the first time the uid's process is started.
     * @return
     */
    public boolean isIdle() {
        synchronized (mLock) {
            return mCurrentBroadcast == null
                    && mOrderedBroadcasts.isEmpty()
                    && isDeferralsListEmpty(mDeferredBroadcasts)
                    && isDeferralsListEmpty(mAlarmBroadcasts)
                    && getBootCompletedBroadcastsUidsSize(Intent.ACTION_LOCKED_BOOT_COMPLETED) == 0
                    && getBootCompletedBroadcastsUidsSize(Intent.ACTION_BOOT_COMPLETED) == 0;
                    && isDeferralsListEmpty(mAlarmBroadcasts);
        }
    }

+1 −1
Original line number Diff line number Diff line
@@ -2218,7 +2218,7 @@ public final class BroadcastQueue {
    }

    boolean isIdle() {
        return mParallelBroadcasts.isEmpty() && mDispatcher.isEmpty()
        return mParallelBroadcasts.isEmpty() && mDispatcher.isIdle()
                && (mPendingBroadcast == null);
    }