| Index: webrtc/modules/audio_processing/gain_control_impl.h
|
| diff --git a/webrtc/modules/audio_processing/gain_control_impl.h b/webrtc/modules/audio_processing/gain_control_impl.h
|
| index 0584b034ef3f9ddb6a696c65cc7d7985fa435e57..e81c3f2abf67d4473a67da7bcf9354c9eee07e0a 100644
|
| --- a/webrtc/modules/audio_processing/gain_control_impl.h
|
| +++ b/webrtc/modules/audio_processing/gain_control_impl.h
|
| @@ -13,6 +13,7 @@
|
|
|
| #include <vector>
|
|
|
| +#include "webrtc/base/criticalsection.h"
|
| #include "webrtc/base/scoped_ptr.h"
|
| #include "webrtc/base/thread_checker.h"
|
| #include "webrtc/common_audio/swap_queue.h"
|
| @@ -22,28 +23,35 @@
|
| namespace webrtc {
|
|
|
| class AudioBuffer;
|
| -class CriticalSectionWrapper;
|
|
|
| class GainControlImpl : public GainControl,
|
| public ProcessingComponent {
|
| public:
|
| GainControlImpl(const AudioProcessing* apm,
|
| - CriticalSectionWrapper* crit,
|
| + rtc::CriticalSection* crit_render,
|
| + rtc::CriticalSection* crit_capture,
|
| const rtc::ThreadChecker* render_thread_checker,
|
| const rtc::ThreadChecker* capture_thread_checker);
|
| virtual ~GainControlImpl();
|
|
|
| + // Called with the render lock held.
|
| int ProcessRenderAudio(AudioBuffer* audio);
|
| + // Called with the render lock held.
|
| int AnalyzeCaptureAudio(AudioBuffer* audio);
|
| + // Called with the render lock held.
|
| int ProcessCaptureAudio(AudioBuffer* audio);
|
|
|
| // ProcessingComponent implementation.
|
| int Initialize() override;
|
|
|
| // GainControl implementation.
|
| + // Acquires the capture lock.
|
| bool is_enabled() const override;
|
| + // Acquires the capture lock.
|
| int stream_analog_level() override;
|
| + // Acquires the capture lock.
|
| bool is_limiter_enabled() const override;
|
| + // Acquires the capture lock.
|
| Mode mode() const override;
|
|
|
| // Reads render side data that has been queued on the render call.
|
| @@ -51,20 +59,33 @@ class GainControlImpl : public GainControl,
|
|
|
| private:
|
| // GainControl implementation.
|
| + // Aquires both the render and capture locks.
|
| int Enable(bool enable) override;
|
| + // Acquires the capture lock.
|
| int set_stream_analog_level(int level) override;
|
| + // Acquires both the render and capture locks.
|
| int set_mode(Mode mode) override;
|
| + // Acquires the capture lock.
|
| int set_target_level_dbfs(int level) override;
|
| + // Acquires the capture lock.
|
| int target_level_dbfs() const override;
|
| + // Acquires the capture lock.
|
| int set_compression_gain_db(int gain) override;
|
| + // Acquires the capture lock.
|
| int compression_gain_db() const override;
|
| + // Acquires the capture lock.
|
| int enable_limiter(bool enable) override;
|
| + // Acquires the capture lock.
|
| int set_analog_level_limits(int minimum, int maximum) override;
|
| + // Acquires the capture lock.
|
| int analog_level_minimum() const override;
|
| + // Acquires the capture lock.
|
| int analog_level_maximum() const override;
|
| + // Acquires the capture lock.
|
| bool stream_is_saturated() const override;
|
|
|
| // ProcessingComponent implementation.
|
| + // Called with both locks held.
|
| void* CreateHandle() const override;
|
| int InitializeHandle(void* handle) const override;
|
| int ConfigureHandle(void* handle) const override;
|
| @@ -75,7 +96,8 @@ class GainControlImpl : public GainControl,
|
| void AllocateRenderQueue();
|
|
|
| const AudioProcessing* apm_;
|
| - CriticalSectionWrapper* crit_;
|
| + rtc::CriticalSection* const crit_render_;
|
| + rtc::CriticalSection* const crit_capture_;
|
| const rtc::ThreadChecker* const render_thread_checker_;
|
| const rtc::ThreadChecker* const capture_thread_checker_;
|
| Mode mode_;
|
|
|