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

Commit 546f200b authored by Kweku Adams's avatar Kweku Adams Committed by Automerger Merge Worker
Browse files

Merge "Offload initial headless app query to handler thread." into rvc-dev am:...

Merge "Offload initial headless app query to handler thread." into rvc-dev am: bcdd5c53 am: bd27badf am: a97f6aca am: b9cffac6

Original change: https://googleplex-android-review.googlesource.com/c/platform/frameworks/base/+/11708142

Change-Id: Ia9abd3ac89fe67a00f1b0e5753daf5fbb4c74182
parents 265b4da4 b9cffac6
Loading
Loading
Loading
Loading
+33 −17
Original line number Diff line number Diff line
@@ -232,7 +232,7 @@ public class AppStandbyController implements AppStandbyInternal {
     * Set of system apps that are headless (don't have any declared activities, enabled or
     * disabled). Presence in this map indicates that the app is a headless system app.
     */
    @GuardedBy("mAppIdleLock")
    @GuardedBy("mHeadlessSystemApps")
    private final ArrayMap<String, Boolean> mHeadlessSystemApps = new ArrayMap<>();

    private final CountDownLatch mAdminDataAvailableLatch = new CountDownLatch(1);
@@ -478,7 +478,8 @@ public class AppStandbyController implements AppStandbyInternal {
                userFileExists = mAppIdleHistory.userFileExists(UserHandle.USER_SYSTEM);
            }

            loadHeadlessSystemAppCache();
            // Offload to handler thread to avoid boottime impact.
            mHandler.post(this::loadHeadlessSystemAppCache);

            if (mPendingInitializeDefaults || !userFileExists) {
                initializeDefaultsForSystemApps(UserHandle.USER_SYSTEM);
@@ -1152,8 +1153,10 @@ public class AppStandbyController implements AppStandbyInternal {
    }

    private boolean isHeadlessSystemApp(String packageName) {
        synchronized (mHeadlessSystemApps) {
            return mHeadlessSystemApps.containsKey(packageName);
        }
    }

    @Override
    public boolean isAppIdleFiltered(String packageName, int appId, int userId,
@@ -1728,19 +1731,24 @@ public class AppStandbyController implements AppStandbyInternal {
                    userId);
            evaluateSystemAppException(pi);
        } catch (PackageManager.NameNotFoundException e) {
            synchronized (mHeadlessSystemApps) {
                mHeadlessSystemApps.remove(packageName);
            }
        }
    }

    private void evaluateSystemAppException(@Nullable PackageInfo pkgInfo) {
        if (pkgInfo.applicationInfo != null && pkgInfo.applicationInfo.isSystemApp()) {
            synchronized (mAppIdleLock) {
    /** Returns true if the exception status changed. */
    private boolean evaluateSystemAppException(@Nullable PackageInfo pkgInfo) {
        if (pkgInfo == null || pkgInfo.applicationInfo == null
                || !pkgInfo.applicationInfo.isSystemApp()) {
            return false;
        }
        synchronized (mHeadlessSystemApps) {
            if (pkgInfo.activities == null || pkgInfo.activities.length == 0) {
                // Headless system app.
                    mHeadlessSystemApps.put(pkgInfo.packageName, true);
                return mHeadlessSystemApps.put(pkgInfo.packageName, true) == null;
            } else {
                    mHeadlessSystemApps.remove(pkgInfo.packageName);
                }
                return mHeadlessSystemApps.remove(pkgInfo.packageName) != null;
            }
        }
    }
@@ -1785,7 +1793,12 @@ public class AppStandbyController implements AppStandbyInternal {
                UserHandle.USER_SYSTEM);
        final int packageCount = packages.size();
        for (int i = 0; i < packageCount; i++) {
            evaluateSystemAppException(packages.get(i));
            PackageInfo pkgInfo = packages.get(i);
            if (pkgInfo != null && evaluateSystemAppException(pkgInfo)) {
                mHandler.obtainMessage(MSG_CHECK_PACKAGE_IDLE_STATE,
                        UserHandle.USER_SYSTEM, -1, pkgInfo.packageName)
                    .sendToTarget();
            }
        }
    }

@@ -1881,10 +1894,13 @@ public class AppStandbyController implements AppStandbyInternal {
        pw.println();

        pw.println("mHeadlessSystemApps=[");
        synchronized (mHeadlessSystemApps) {
            for (int i = mHeadlessSystemApps.size() - 1; i >= 0; --i) {
                pw.print("  ");
                pw.print(mHeadlessSystemApps.keyAt(i));
                pw.println(",");
            }
        }
        pw.println("]");
        pw.println();
    }