diff options
| -rw-r--r-- | services/core/java/com/android/server/pm/ApexManager.java | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/services/core/java/com/android/server/pm/ApexManager.java b/services/core/java/com/android/server/pm/ApexManager.java index 1da5bc6c26ee..dc00cb45596c 100644 --- a/services/core/java/com/android/server/pm/ApexManager.java +++ b/services/core/java/com/android/server/pm/ApexManager.java @@ -261,11 +261,12 @@ abstract class ApexManager { mContext.registerReceiver(new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { - populateAllPackagesCacheIfNeeded(); + // Post populateAllPackagesCacheIfNeeded to a background thread, since it's + // expensive to run it in broadcast handler thread. + BackgroundThread.getHandler().post(() -> populateAllPackagesCacheIfNeeded()); mContext.unregisterReceiver(this); } - }, new IntentFilter(Intent.ACTION_BOOT_COMPLETED), /* broadcastPermission */ null, - BackgroundThread.getHandler()); + }, new IntentFilter(Intent.ACTION_BOOT_COMPLETED)); } private void populateAllPackagesCacheIfNeeded() { |