Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(37)

Side by Side Diff: webrtc/modules/audio_processing/echo_cancellation_impl.h

Issue 1410833002: Lock scheme #4: Introduced the render sample queue for the aec and aecm (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@aec_error_report_CL
Patch Set: Changes in response to latest reviewer comments Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #ifndef WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_ 11 #ifndef WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_
12 #define WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_ 12 #define WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_
13 13
14 #include "webrtc/base/scoped_ptr.h"
15 #include "webrtc/common_audio/swap_queue.h"
14 #include "webrtc/modules/audio_processing/include/audio_processing.h" 16 #include "webrtc/modules/audio_processing/include/audio_processing.h"
15 #include "webrtc/modules/audio_processing/processing_component.h" 17 #include "webrtc/modules/audio_processing/processing_component.h"
16 18
17 namespace webrtc { 19 namespace webrtc {
18 20
19 class AudioBuffer; 21 class AudioBuffer;
20 class CriticalSectionWrapper; 22 class CriticalSectionWrapper;
21 23
24 // Functor to use when supplying a verifier function for the queue item
hlundin-webrtc 2015/11/06 07:05:13 I'm not sure, but isn't there a risk you'll get mu
peah-webrtc 2015/11/06 10:44:20 Good point! It works as it is, but I instead creat
25 // verifcation.
26 class AecRenderQueueItemVerifier {
27 public:
28 explicit AecRenderQueueItemVerifier(size_t minimum_capacity)
29 : minimum_capacity_(minimum_capacity) {}
30
31 bool operator()(const std::vector<float>& v) const {
32 return v.capacity() >= minimum_capacity_;
33 }
34
35 private:
36 size_t minimum_capacity_;
37 };
38
22 class EchoCancellationImpl : public EchoCancellation, 39 class EchoCancellationImpl : public EchoCancellation,
23 public ProcessingComponent { 40 public ProcessingComponent {
24 public: 41 public:
25 EchoCancellationImpl(const AudioProcessing* apm, 42 EchoCancellationImpl(const AudioProcessing* apm,
26 CriticalSectionWrapper* crit); 43 CriticalSectionWrapper* crit);
27 virtual ~EchoCancellationImpl(); 44 virtual ~EchoCancellationImpl();
28 45
29 int ProcessRenderAudio(const AudioBuffer* audio); 46 int ProcessRenderAudio(const AudioBuffer* audio);
30 int ProcessCaptureAudio(AudioBuffer* audio); 47 int ProcessCaptureAudio(AudioBuffer* audio);
31 48
32 // EchoCancellation implementation. 49 // EchoCancellation implementation.
33 bool is_enabled() const override; 50 bool is_enabled() const override;
34 int stream_drift_samples() const override; 51 int stream_drift_samples() const override;
35 SuppressionLevel suppression_level() const override; 52 SuppressionLevel suppression_level() const override;
36 bool is_drift_compensation_enabled() const override; 53 bool is_drift_compensation_enabled() const override;
37 54
38 // ProcessingComponent implementation. 55 // ProcessingComponent implementation.
39 int Initialize() override; 56 int Initialize() override;
40 void SetExtraOptions(const Config& config) override; 57 void SetExtraOptions(const Config& config) override;
41 58
42 bool is_delay_agnostic_enabled() const; 59 bool is_delay_agnostic_enabled() const;
43 bool is_extended_filter_enabled() const; 60 bool is_extended_filter_enabled() const;
44 61
62 // Reads render side data that has been queued on the render call.
63 void ReadQueuedRenderData();
64
45 private: 65 private:
66 static const size_t kAllowedValuesOfSamplesPerFrame1 = 80;
67 static const size_t kAllowedValuesOfSamplesPerFrame2 = 160;
68 // TODO(peah): Decrease this once we properly handle hugely unbalanced
69 // reverse and forward call numbers.
70 static const size_t kMaxNumFramesToBuffer = 100;
71
46 // EchoCancellation implementation. 72 // EchoCancellation implementation.
47 int Enable(bool enable) override; 73 int Enable(bool enable) override;
48 int enable_drift_compensation(bool enable) override; 74 int enable_drift_compensation(bool enable) override;
49 void set_stream_drift_samples(int drift) override; 75 void set_stream_drift_samples(int drift) override;
50 int set_suppression_level(SuppressionLevel level) override; 76 int set_suppression_level(SuppressionLevel level) override;
51 int enable_metrics(bool enable) override; 77 int enable_metrics(bool enable) override;
52 bool are_metrics_enabled() const override; 78 bool are_metrics_enabled() const override;
53 bool stream_has_echo() const override; 79 bool stream_has_echo() const override;
54 int GetMetrics(Metrics* metrics) override; 80 int GetMetrics(Metrics* metrics) override;
55 int enable_delay_logging(bool enable) override; 81 int enable_delay_logging(bool enable) override;
56 bool is_delay_logging_enabled() const override; 82 bool is_delay_logging_enabled() const override;
57 int GetDelayMetrics(int* median, int* std) override; 83 int GetDelayMetrics(int* median, int* std) override;
58 int GetDelayMetrics(int* median, 84 int GetDelayMetrics(int* median,
59 int* std, 85 int* std,
60 float* fraction_poor_delays) override; 86 float* fraction_poor_delays) override;
61 struct AecCore* aec_core() const override; 87 struct AecCore* aec_core() const override;
62 88
63 // ProcessingComponent implementation. 89 // ProcessingComponent implementation.
64 void* CreateHandle() const override; 90 void* CreateHandle() const override;
65 int InitializeHandle(void* handle) const override; 91 int InitializeHandle(void* handle) const override;
66 int ConfigureHandle(void* handle) const override; 92 int ConfigureHandle(void* handle) const override;
67 void DestroyHandle(void* handle) const override; 93 void DestroyHandle(void* handle) const override;
68 int num_handles_required() const override; 94 int num_handles_required() const override;
69 int GetHandleError(void* handle) const override; 95 int GetHandleError(void* handle) const override;
70 96
97 void AllocateRenderQueue();
98
71 const AudioProcessing* apm_; 99 const AudioProcessing* apm_;
72 CriticalSectionWrapper* crit_; 100 CriticalSectionWrapper* crit_;
73 bool drift_compensation_enabled_; 101 bool drift_compensation_enabled_;
74 bool metrics_enabled_; 102 bool metrics_enabled_;
75 SuppressionLevel suppression_level_; 103 SuppressionLevel suppression_level_;
76 int stream_drift_samples_; 104 int stream_drift_samples_;
77 bool was_stream_drift_set_; 105 bool was_stream_drift_set_;
78 bool stream_has_echo_; 106 bool stream_has_echo_;
79 bool delay_logging_enabled_; 107 bool delay_logging_enabled_;
80 bool extended_filter_enabled_; 108 bool extended_filter_enabled_;
81 bool delay_agnostic_enabled_; 109 bool delay_agnostic_enabled_;
110
111 size_t render_queue_element_max_size_;
112 std::vector<float> render_queue_buffer_;
113 std::vector<float> capture_queue_buffer_;
114 rtc::scoped_ptr<SwapQueue<std::vector<float>, AecRenderQueueItemVerifier>>
115 render_signal_queue_;
82 }; 116 };
83 117
84 } // namespace webrtc 118 } // namespace webrtc
85 119
86 #endif // WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_ 120 #endif // WEBRTC_MODULES_AUDIO_PROCESSING_ECHO_CANCELLATION_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698