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

Unified Diff: content/renderer/media/audio_renderer_mixer_manager.h

Issue 1942803002: Caching AudioOutputDevice instances in mixer manager (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: lambda, weak_ptr and other fixes Created 4 years, 7 months 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 side-by-side diff with in-line comments
Download patch
Index: content/renderer/media/audio_renderer_mixer_manager.h
diff --git a/content/renderer/media/audio_renderer_mixer_manager.h b/content/renderer/media/audio_renderer_mixer_manager.h
index 20a1aa59eaf3db3d8e65c0ef805dfe98c16e5e9e..6dec29eaa4686ad524ec74ff4729529abfd3d610 100644
--- a/content/renderer/media/audio_renderer_mixer_manager.h
+++ b/content/renderer/media/audio_renderer_mixer_manager.h
@@ -6,25 +6,26 @@
#define CONTENT_RENDERER_MEDIA_AUDIO_RENDERER_MIXER_MANAGER_H_
#include <map>
+#include <memory>
#include <string>
-#include <utility>
#include "base/macros.h"
#include "base/synchronization/lock.h"
#include "content/common/content_export.h"
#include "media/audio/audio_device_description.h"
#include "media/base/audio_parameters.h"
+#include "media/base/audio_renderer_mixer_pool.h"
#include "media/base/output_device_info.h"
#include "url/origin.h"
namespace media {
-class AudioHardwareConfig;
class AudioRendererMixer;
class AudioRendererMixerInput;
class AudioRendererSink;
}
namespace content {
+class AudioRendererSinkCache;
// Manages sharing of an AudioRendererMixer among AudioRendererMixerInputs based
// on their AudioParameters configuration. Inputs with the same AudioParameters
@@ -39,10 +40,12 @@ namespace content {
// with floats. However, bits per channel is currently used to interleave the
// audio data by AudioOutputDevice::AudioThreadCallback::Process for consumption
// via the shared memory. See http://crbug.com/114700.
-class CONTENT_EXPORT AudioRendererMixerManager {
+class CONTENT_EXPORT AudioRendererMixerManager
+ : public media::AudioRendererMixerPool {
public:
- AudioRendererMixerManager();
- ~AudioRendererMixerManager();
+ ~AudioRendererMixerManager() final;
+
+ static std::unique_ptr<AudioRendererMixerManager> Create();
// Creates an AudioRendererMixerInput with the proper callbacks necessary to
// retrieve an AudioRendererMixer instance from AudioRendererMixerManager.
@@ -60,19 +63,31 @@ class CONTENT_EXPORT AudioRendererMixerManager {
// Returns a mixer instance based on AudioParameters; an existing one if one
Guido Urdaneta 2016/05/25 13:33:13 Since GetMixer and ReturnMixer are now implementat
o1ka 2016/05/25 14:52:11 This comment contains implementation details not e
Guido Urdaneta 2016/05/25 15:44:09 I think the comments at the top of the class toget
o1ka 2016/05/26 09:00:27 Done.
// with the provided AudioParameters exists or a new one if not.
- media::AudioRendererMixer* GetMixer(int source_render_frame_id,
- const media::AudioParameters& params,
- const std::string& device_id,
- const url::Origin& security_origin,
- media::OutputDeviceStatus* device_status);
+ media::AudioRendererMixer* GetMixer(
+ int source_render_frame_id,
+ const media::AudioParameters& params,
+ const std::string& device_id,
+ const url::Origin& security_origin,
+ media::OutputDeviceStatus* device_status) final;
// Remove a mixer instance given a mixer if the only other reference is held
// by AudioRendererMixerManager. Every AudioRendererMixer owner must call
// this method when it's done with a mixer.
- void RemoveMixer(int source_render_frame_id,
+ void ReturnMixer(int source_render_frame_id,
const media::AudioParameters& params,
const std::string& device_id,
- const url::Origin& security_origin);
+ const url::Origin& security_origin) final;
+
+ // Returns output device information. This call goes to the sink cache.
Guido Urdaneta 2016/05/25 13:33:13 Nit: So far, the sink cache has not been mentioned
o1ka 2016/05/25 14:52:11 changed to |sink_cache_| which is mentioned here.
+ media::OutputDeviceInfo GetOutputDeviceInfo(
+ int source_render_frame_id,
+ int session_id,
+ const std::string& device_id,
+ const url::Origin& security_origin) final;
+
+ protected:
+ explicit AudioRendererMixerManager(
+ std::unique_ptr<AudioRendererSinkCache> sink_cache);
private:
friend class AudioRendererMixerManagerTest;
@@ -127,14 +142,20 @@ class CONTENT_EXPORT AudioRendererMixerManager {
struct AudioRendererMixerReference {
media::AudioRendererMixer* mixer;
int ref_count;
+ // Mixer sink pointer, to remove a sink from cache upon mixer destruction.
+ const media::AudioRendererSink* sink_ptr;
Guido Urdaneta 2016/05/25 13:33:13 What about adding a sink() getter to ARM, so that
o1ka 2016/05/25 14:52:11 We've already been there at PS7 :) changed accordi
Guido Urdaneta 2016/05/25 15:44:09 Acknowledged.
};
- typedef std::map<MixerKey, AudioRendererMixerReference, MixerKeyCompare>
- AudioRendererMixerMap;
+
+ using AudioRendererMixerMap =
+ std::map<MixerKey, AudioRendererMixerReference, MixerKeyCompare>;
// Active mixers.
AudioRendererMixerMap mixers_;
base::Lock mixers_lock_;
+ // Mixer sink cache.
+ const std::unique_ptr<AudioRendererSinkCache> sink_cache_;
+
DISALLOW_COPY_AND_ASSIGN(AudioRendererMixerManager);
};

Powered by Google App Engine
This is Rietveld 408576698