summaryrefslogtreecommitdiff
path: root/chromium/media/base/audio_renderer_mixer.h
diff options
context:
space:
mode:
Diffstat (limited to 'chromium/media/base/audio_renderer_mixer.h')
-rw-r--r--chromium/media/base/audio_renderer_mixer.h53
1 files changed, 26 insertions, 27 deletions
diff --git a/chromium/media/base/audio_renderer_mixer.h b/chromium/media/base/audio_renderer_mixer.h
index f81e69a30e3..9c9325a2281 100644
--- a/chromium/media/base/audio_renderer_mixer.h
+++ b/chromium/media/base/audio_renderer_mixer.h
@@ -11,14 +11,18 @@
#include <memory>
#include <string>
+#include "base/containers/flat_map.h"
+#include "base/containers/flat_set.h"
#include "base/macros.h"
#include "base/synchronization/lock.h"
+#include "base/thread_annotations.h"
#include "base/time/time.h"
#include "media/base/audio_converter.h"
#include "media/base/audio_renderer_sink.h"
#include "media/base/loopback_audio_converter.h"
namespace media {
+class AudioRendererMixerInput;
// Mixes a set of AudioConverter::InputCallbacks into a single output stream
// which is funneled into a single shared AudioRendererSink; saving a bundle
@@ -26,11 +30,11 @@ namespace media {
class MEDIA_EXPORT AudioRendererMixer
: public AudioRendererSink::RenderCallback {
public:
- typedef base::Callback<void(int)> UmaLogCallback;
+ using UmaLogCallback = base::RepeatingCallback<void(int)>;
AudioRendererMixer(const AudioParameters& output_params,
scoped_refptr<AudioRendererSink> sink,
- const UmaLogCallback& log_callback);
+ UmaLogCallback log_callback);
~AudioRendererMixer() override;
// Add or remove a mixer input from mixing; called by AudioRendererMixerInput.
@@ -40,29 +44,21 @@ class MEDIA_EXPORT AudioRendererMixer
AudioConverter::InputCallback* input);
// Since errors may occur even when no inputs are playing, an error callback
- // must be registered separately from adding a mixer input. The same callback
- // must be given to both the functions.
- void AddErrorCallback(const base::Closure& error_cb);
- void RemoveErrorCallback(const base::Closure& error_cb);
-
- void set_pause_delay_for_testing(base::TimeDelta delay) {
- pause_delay_ = delay;
- }
-
- OutputDeviceInfo GetOutputDeviceInfo();
+ // must be registered separately from adding a mixer input.
+ void AddErrorCallback(AudioRendererMixerInput* input);
+ void RemoveErrorCallback(AudioRendererMixerInput* input);
// Returns true if called on rendering thread, otherwise false.
bool CurrentThreadIsRenderingThread();
- const AudioParameters& GetOutputParamsForTesting() { return output_params_; };
+ void SetPauseDelayForTesting(base::TimeDelta delay);
+ const AudioParameters& get_output_params_for_testing() const {
+ return output_params_;
+ }
private:
class UMAMaxValueTracker;
- // Maps input sample rate to the dedicated converter.
- using AudioConvertersMap =
- std::map<int, std::unique_ptr<LoopbackAudioConverter>>;
-
// AudioRendererSink::RenderCallback implementation.
int Render(base::TimeDelta delay,
base::TimeTicks delay_timestamp,
@@ -70,7 +66,7 @@ class MEDIA_EXPORT AudioRendererMixer
AudioBus* audio_bus) override;
void OnRenderError() override;
- bool is_master_sample_rate(int sample_rate) {
+ bool is_master_sample_rate(int sample_rate) const {
return sample_rate == output_params_.sample_rate();
}
@@ -84,27 +80,30 @@ class MEDIA_EXPORT AudioRendererMixer
base::Lock lock_;
// List of error callbacks used by this mixer.
- typedef std::list<base::Closure> ErrorCallbackList;
- ErrorCallbackList error_callbacks_;
+ base::flat_set<AudioRendererMixerInput*> error_callbacks_ GUARDED_BY(lock_);
+
+ // Maps input sample rate to the dedicated converter.
+ using AudioConvertersMap =
+ base::flat_map<int, std::unique_ptr<LoopbackAudioConverter>>;
// Each of these converters mixes inputs with a given sample rate and
- // resamples them to the output sample rate. Inputs not reqiuring resampling
+ // resamples them to the output sample rate. Inputs not requiring resampling
// go directly to |master_converter_|.
- AudioConvertersMap converters_;
+ AudioConvertersMap converters_ GUARDED_BY(lock_);
// Master converter which mixes all the outputs from |converters_| as well as
// mixer inputs that are in the output sample rate.
- AudioConverter master_converter_;
+ AudioConverter master_converter_ GUARDED_BY(lock_);
// Handles physical stream pause when no inputs are playing. For latency
// reasons we don't want to immediately pause the physical stream.
- base::TimeDelta pause_delay_;
- base::TimeTicks last_play_time_;
- bool playing_;
+ base::TimeDelta pause_delay_ GUARDED_BY(lock_);
+ base::TimeTicks last_play_time_ GUARDED_BY(lock_);
+ bool playing_ GUARDED_BY(lock_);
// Tracks the maximum number of simultaneous mixer inputs and logs it into
// UMA histogram upon the destruction.
- std::unique_ptr<UMAMaxValueTracker> input_count_tracker_;
+ std::unique_ptr<UMAMaxValueTracker> input_count_tracker_ GUARDED_BY(lock_);
DISALLOW_COPY_AND_ASSIGN(AudioRendererMixer);
};