Revert "Remove APM-internal usage of EchoControlMobile"
This reverts commit 2fbb83b16b4c2c1712cbe898ca3ba42d6da3e96f. Reason for revert: Speculative revert over failing Chromium bot: https://ci.chromium.org/p/chromium/builders/luci.chromium.webrtc.fyi/WebRTC%20Chromium%20FYI%20Android%20Tests%20%28dbg%29%20%28M%20Nexus5X%29/117 Original change's description: > Remove APM-internal usage of EchoControlMobile > > This is a sibling CL to a similar one for EchoCancellation: > https://webrtc-review.googlesource.com/c/src/+/97603 > > - EchoControlMobileImpl will no longer inherit EchoControlMobile. > - Removes usage of AudioProcessing::echo_control_mobile() inside most of > the audio processing module and unit tests. > > The CL breaks audioproc_f backwards compatibility: It can no longer > use all recorded settings (comfort noise, routing mode), but prints an > error message when unsupported settings are encountered. > > Tested: audioproc_f with .wav and aecdump inputs. > Bug: webrtc:9535 > Change-Id: I63c3c81bcaf44021315978e1a0f3e42173b988ce > Reviewed-on: https://webrtc-review.googlesource.com/101621 > Reviewed-by: Alex Loiko <aleloi@webrtc.org> > Commit-Queue: Sam Zackrisson <saza@webrtc.org> > Cr-Commit-Position: refs/heads/master@{#24888} TBR=saza@webrtc.org,aleloi@webrtc.org Change-Id: I1f8a27ac291f2cdc16c8daa32e399b74d489dbb9 No-Presubmit: true No-Tree-Checks: true No-Try: true Bug: webrtc:9535 Reviewed-on: https://webrtc-review.googlesource.com/102642 Reviewed-by: Sam Zackrisson <saza@webrtc.org> Commit-Queue: Sam Zackrisson <saza@webrtc.org> Cr-Commit-Position: refs/heads/master@{#24895}
This commit is contained in:

committed by
Commit Bot

parent
ee05e90297
commit
05a7004442
@ -24,60 +24,21 @@ namespace webrtc {
|
||||
|
||||
class AudioBuffer;
|
||||
|
||||
class EchoControlMobileImpl {
|
||||
class EchoControlMobileImpl : public EchoControlMobile {
|
||||
public:
|
||||
EchoControlMobileImpl(rtc::CriticalSection* crit_render,
|
||||
rtc::CriticalSection* crit_capture);
|
||||
|
||||
~EchoControlMobileImpl();
|
||||
|
||||
int Enable(bool enable);
|
||||
bool is_enabled() const;
|
||||
|
||||
// Recommended settings for particular audio routes. In general, the louder
|
||||
// the echo is expected to be, the higher this value should be set. The
|
||||
// preferred setting may vary from device to device.
|
||||
enum RoutingMode {
|
||||
kQuietEarpieceOrHeadset,
|
||||
kEarpiece,
|
||||
kLoudEarpiece,
|
||||
kSpeakerphone,
|
||||
kLoudSpeakerphone
|
||||
};
|
||||
|
||||
// Sets echo control appropriate for the audio routing |mode| on the device.
|
||||
// It can and should be updated during a call if the audio routing changes.
|
||||
int set_routing_mode(RoutingMode mode);
|
||||
RoutingMode routing_mode() const;
|
||||
|
||||
// Comfort noise replaces suppressed background noise to maintain a
|
||||
// consistent signal level.
|
||||
int enable_comfort_noise(bool enable);
|
||||
bool is_comfort_noise_enabled() const;
|
||||
|
||||
// A typical use case is to initialize the component with an echo path from a
|
||||
// previous call. The echo path is retrieved using |GetEchoPath()|, typically
|
||||
// at the end of a call. The data can then be stored for later use as an
|
||||
// initializer before the next call, using |SetEchoPath()|.
|
||||
//
|
||||
// Controlling the echo path this way requires the data |size_bytes| to match
|
||||
// the internal echo path size. This size can be acquired using
|
||||
// |echo_path_size_bytes()|. |SetEchoPath()| causes an entire reset, worth
|
||||
// noting if it is to be called during an ongoing call.
|
||||
//
|
||||
// It is possible that version incompatibilities may result in a stored echo
|
||||
// path of the incorrect size. In this case, the stored path should be
|
||||
// discarded.
|
||||
int SetEchoPath(const void* echo_path, size_t size_bytes);
|
||||
int GetEchoPath(void* echo_path, size_t size_bytes) const;
|
||||
|
||||
// The returned path size is guaranteed not to change for the lifetime of
|
||||
// the application.
|
||||
static size_t echo_path_size_bytes();
|
||||
~EchoControlMobileImpl() override;
|
||||
|
||||
void ProcessRenderAudio(rtc::ArrayView<const int16_t> packed_render_audio);
|
||||
int ProcessCaptureAudio(AudioBuffer* audio, int stream_delay_ms);
|
||||
|
||||
// EchoControlMobile implementation.
|
||||
bool is_enabled() const override;
|
||||
RoutingMode routing_mode() const override;
|
||||
bool is_comfort_noise_enabled() const override;
|
||||
|
||||
void Initialize(int sample_rate_hz,
|
||||
size_t num_reverse_channels,
|
||||
size_t num_output_channels);
|
||||
@ -94,6 +55,13 @@ class EchoControlMobileImpl {
|
||||
class Canceller;
|
||||
struct StreamProperties;
|
||||
|
||||
// EchoControlMobile implementation.
|
||||
int Enable(bool enable) override;
|
||||
int set_routing_mode(RoutingMode mode) override;
|
||||
int enable_comfort_noise(bool enable) override;
|
||||
int SetEchoPath(const void* echo_path, size_t size_bytes) override;
|
||||
int GetEchoPath(void* echo_path, size_t size_bytes) const override;
|
||||
|
||||
int Configure();
|
||||
|
||||
rtc::CriticalSection* const crit_render_ RTC_ACQUIRED_BEFORE(crit_capture_);
|
||||
|
Reference in New Issue
Block a user