Merge "Prevent modifying mAudioPolicies during iteration"
This commit is contained in:
commit
aded52644c
@ -1517,6 +1517,7 @@ public class AudioService extends IAudioService.Stub
|
|||||||
}
|
}
|
||||||
|
|
||||||
synchronized (mAudioPolicies) {
|
synchronized (mAudioPolicies) {
|
||||||
|
ArrayList<AudioPolicyProxy> invalidProxies = new ArrayList<>();
|
||||||
for (AudioPolicyProxy policy : mAudioPolicies.values()) {
|
for (AudioPolicyProxy policy : mAudioPolicies.values()) {
|
||||||
final int status = policy.connectMixes();
|
final int status = policy.connectMixes();
|
||||||
if (status != AudioSystem.SUCCESS) {
|
if (status != AudioSystem.SUCCESS) {
|
||||||
@ -1524,7 +1525,7 @@ public class AudioService extends IAudioService.Stub
|
|||||||
Log.e(TAG, "onAudioServerDied: error "
|
Log.e(TAG, "onAudioServerDied: error "
|
||||||
+ AudioSystem.audioSystemErrorToString(status)
|
+ AudioSystem.audioSystemErrorToString(status)
|
||||||
+ " when connecting mixes for policy " + policy.toLogFriendlyString());
|
+ " when connecting mixes for policy " + policy.toLogFriendlyString());
|
||||||
policy.release();
|
invalidProxies.add(policy);
|
||||||
} else {
|
} else {
|
||||||
final int deviceAffinitiesStatus = policy.setupDeviceAffinities();
|
final int deviceAffinitiesStatus = policy.setupDeviceAffinities();
|
||||||
if (deviceAffinitiesStatus != AudioSystem.SUCCESS) {
|
if (deviceAffinitiesStatus != AudioSystem.SUCCESS) {
|
||||||
@ -1532,10 +1533,12 @@ public class AudioService extends IAudioService.Stub
|
|||||||
+ AudioSystem.audioSystemErrorToString(deviceAffinitiesStatus)
|
+ AudioSystem.audioSystemErrorToString(deviceAffinitiesStatus)
|
||||||
+ " when connecting device affinities for policy "
|
+ " when connecting device affinities for policy "
|
||||||
+ policy.toLogFriendlyString());
|
+ policy.toLogFriendlyString());
|
||||||
policy.release();
|
invalidProxies.add(policy);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
invalidProxies.forEach((policy) -> policy.release());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Restore capture policies
|
// Restore capture policies
|
||||||
|
Loading…
x
Reference in New Issue
Block a user