Merge "Move SchedulingPolicyService init code to SystemServerInitThreadPool" into pi-dev
diff --git a/services/core/java/com/android/server/os/SchedulingPolicyService.java b/services/core/java/com/android/server/os/SchedulingPolicyService.java
index c64e745..5cbe1a1 100644
--- a/services/core/java/com/android/server/os/SchedulingPolicyService.java
+++ b/services/core/java/com/android/server/os/SchedulingPolicyService.java
@@ -24,6 +24,8 @@
import android.os.RemoteException;
import android.util.Log;
+import com.android.server.SystemServerInitThreadPool;
+
/**
* The implementation of the scheduling policy service interface.
*
@@ -62,11 +64,18 @@
// (Note that if mediaserver thinks we're in boosted state before the crash,
// the state could go out of sync temporarily until mediaserver enables/disable
// boost next time, but this won't be a big issue.)
- int[] nativePids = Process.getPidsForCommands(MEDIA_PROCESS_NAMES);
- if (nativePids != null && nativePids.length == 1) {
- mBoostedPid = nativePids[0];
- disableCpusetBoost(nativePids[0]);
- }
+ SystemServerInitThreadPool.get().submit(() -> {
+ synchronized (mDeathRecipient) {
+ // only do this if we haven't already got a request to boost.
+ if (mBoostedPid == -1) {
+ int[] nativePids = Process.getPidsForCommands(MEDIA_PROCESS_NAMES);
+ if (nativePids != null && nativePids.length == 1) {
+ mBoostedPid = nativePids[0];
+ disableCpusetBoost(nativePids[0]);
+ }
+ }
+ }
+ }, TAG + ".<init>");
}
// TODO(b/35196900) We should pass the period in time units, rather
@@ -107,7 +116,9 @@
// Request to move media.codec process between SP_FOREGROUND and SP_TOP_APP.
public int requestCpusetBoost(boolean enable, IBinder client) {
- if (!isPermitted()) {
+ // Can only allow mediaserver to call this.
+ if (Binder.getCallingPid() != Process.myPid() &&
+ Binder.getCallingUid() != Process.MEDIA_UID) {
return PackageManager.PERMISSION_DENIED;
}
@@ -201,7 +212,6 @@
switch (Binder.getCallingUid()) {
case Process.AUDIOSERVER_UID: // fastcapture, fastmixer
- case Process.MEDIA_UID: // mediaserver
case Process.CAMERASERVER_UID: // camera high frame rate recording
case Process.BLUETOOTH_UID: // Bluetooth audio playback
return true;