webrtc/sdk
Brian Dai ef53a7fc0b Reset IO thread checker when iOS audio unit stops
In AudioDeviceIOS, when we call Stop() on the VoiceProcessingAudioUnit,
we do not always detach the I/O thread checker in preparation for a new
start. This means that if we start up the VoiceProcessingAudioUnit - and
subsequently a new AURemoteIO thread to deal with I/O operations - the
DCHECK in OnDeliverRecordedData and OnGetPlayoutData will fail. Note
that we want to detach the I/O thread checker regardless of whether
Stop() returns with a success status or not. The success status is
dictated by the iOS function AudioOutputUnitStop. The documentation of
this function does not guarantee that the audio unit will not stop in
the case the function returns with an error code. That is to say, it is
possible the audio unit stops even if the function Stop() returns false.
Therefore, it is safer to prepare the I/O thread checker for a new start
in either case.

Change-Id: Iee50a2457959aff2e6089e9a664c649dc4dbbbd6
Bug: webrtc:12382
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/202945
Reviewed-by: Henrik Andreassson <henrika@webrtc.org>
Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org>
Commit-Queue: Mirko Bonadei <mbonadei@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#33063}
2021-01-23 10:22:58 +00:00
..
android Remove unused function VideoDecoder::PrefersLateDecoding. 2021-01-18 14:17:57 +00:00
objc Reset IO thread checker when iOS audio unit stops 2021-01-23 10:22:58 +00:00
BUILD.gn Reland "Refactor rtc_base build targets." 2021-01-15 17:00:05 +00:00
media_constraints.cc Remove deprecated code related to AEC2 2019-08-07 10:09:36 +00:00
media_constraints.h Remove deprecated code related to AEC2 2019-08-07 10:09:36 +00:00
media_constraints_unittest.cc Move MediaConstraintsInterface to sdk/, and make it a concrete class 2019-02-14 12:07:07 +00:00
OWNERS Remove wildcard ownership for build files. 2020-02-19 14:05:46 +00:00