Merge \"Fix deadlock b/w ActivityManagerService and MediaSessionService\"

am: 4eea3a7f88

Change-Id: I499c69fd3890ada652213c0510df3b884223a5df
This commit is contained in:
Shibin George
2016-06-23 00:20:35 +00:00
committed by android-build-merger

View File

@@ -890,13 +890,24 @@ public class MediaSessionService extends SystemService implements Monitor {
} }
return; return;
} }
try {
String packageName = getContext().getOpPackageName(); // Execute mAudioService.adjustSuggestedStreamVolume() on
mAudioService.adjustSuggestedStreamVolume(direction, suggestedStream, // handler thread of MediaSessionService.
flags, packageName, TAG); // This will release the MediaSessionService.mLock sooner and avoid
} catch (RemoteException e) { // a potential deadlock between MediaSessionService.mLock and
Log.e(TAG, "Error adjusting default volume.", e); // ActivityManagerService lock.
} mHandler.post(new Runnable() {
@Override
public void run() {
try {
String packageName = getContext().getOpPackageName();
mAudioService.adjustSuggestedStreamVolume(direction, suggestedStream,
flags, packageName, TAG);
} catch (RemoteException e) {
Log.e(TAG, "Error adjusting default volume.", e);
}
}
});
} else { } else {
session.adjustVolume(direction, flags, getContext().getPackageName(), session.adjustVolume(direction, flags, getContext().getPackageName(),
UserHandle.myUserId(), true); UserHandle.myUserId(), true);