OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CONTENT_RENDERER_MEDIA_AUDIO_RENDERER_MIXER_MANAGER_H_ | 5 #ifndef CONTENT_RENDERER_MEDIA_AUDIO_RENDERER_MIXER_MANAGER_H_ |
6 #define CONTENT_RENDERER_MEDIA_AUDIO_RENDERER_MIXER_MANAGER_H_ | 6 #define CONTENT_RENDERER_MEDIA_AUDIO_RENDERER_MIXER_MANAGER_H_ |
7 | 7 |
8 #include <map> | 8 #include <map> |
9 | 9 |
10 #include "base/synchronization/lock.h" | 10 #include "base/synchronization/lock.h" |
11 #include "content/common/content_export.h" | 11 #include "content/common/content_export.h" |
12 #include "media/audio/audio_parameters.h" | 12 #include "media/audio/audio_parameters.h" |
13 | 13 |
14 namespace media { | 14 namespace media { |
15 class AudioRendererMixer; | 15 class AudioRendererMixer; |
16 class AudioRendererMixerInput; | 16 class AudioRendererMixerInput; |
17 } | 17 } |
18 | 18 |
19 namespace content { | 19 namespace content { |
20 | 20 |
| 21 class RenderView; |
| 22 |
21 // Manages sharing of an AudioRendererMixer among AudioRendererMixerInputs based | 23 // Manages sharing of an AudioRendererMixer among AudioRendererMixerInputs based |
22 // on their AudioParameters configuration. Inputs with the same AudioParameters | 24 // on their AudioParameters configuration. Inputs with the same AudioParameters |
23 // configuration will share a mixer while a new AudioRendererMixer will be | 25 // configuration will share a mixer while a new AudioRendererMixer will be |
24 // lazily created if one with the exact AudioParameters does not exist. | 26 // lazily created if one with the exact AudioParameters does not exist. |
25 // | 27 // |
26 // There should only be one instance of AudioRendererMixerManager per render | 28 // There should only be one instance of AudioRendererMixerManager per render |
27 // thread. | 29 // thread. |
28 // | 30 // |
29 // TODO(dalecurtis): Right now we require AudioParameters to be an exact match | 31 // TODO(dalecurtis): Right now we require AudioParameters to be an exact match |
30 // when we should be able to ignore bits per channel since we're only dealing | 32 // when we should be able to ignore bits per channel since we're only dealing |
31 // with floats. However, bits per channel is currently used to interleave the | 33 // with floats. However, bits per channel is currently used to interleave the |
32 // audio data by AudioDevice::AudioThreadCallback::Process for consumption via | 34 // audio data by AudioDevice::AudioThreadCallback::Process for consumption via |
33 // the shared memory. See http://crbug.com/114700. | 35 // the shared memory. See http://crbug.com/114700. |
34 class CONTENT_EXPORT AudioRendererMixerManager { | 36 class CONTENT_EXPORT AudioRendererMixerManager { |
35 public: | 37 public: |
36 // Construct an instance using the given audio hardware configuration. | 38 // Construct an instance using the given audio hardware configuration. |
37 AudioRendererMixerManager(int hardware_sample_rate, int hardware_buffer_size); | 39 AudioRendererMixerManager(int hardware_sample_rate, int hardware_buffer_size); |
38 ~AudioRendererMixerManager(); | 40 ~AudioRendererMixerManager(); |
39 | 41 |
40 // Creates an AudioRendererMixerInput with the proper callbacks necessary to | 42 // Creates an AudioRendererMixerInput with the proper callbacks necessary to |
41 // retrieve an AudioRendererMixer instance from AudioRendererMixerManager. | 43 // retrieve an AudioRendererMixer instance from AudioRendererMixerManager. |
42 // Caller must ensure AudioRendererMixerManager outlives the returned input. | 44 // Caller must ensure AudioRendererMixerManager outlives the returned input. |
43 media::AudioRendererMixerInput* CreateInput(); | 45 media::AudioRendererMixerInput* CreateInput(RenderView* render_view); |
44 | 46 |
45 private: | 47 private: |
46 friend class AudioRendererMixerManagerTest; | 48 friend class AudioRendererMixerManagerTest; |
47 | 49 |
48 // Returns a mixer instance based on AudioParameters; an existing one if one | 50 // Returns a mixer instance based on AudioParameters; an existing one if one |
49 // with the provided AudioParameters exists or a new one if not. | 51 // with the provided AudioParameters exists or a new one if not. |
50 media::AudioRendererMixer* GetMixer(const media::AudioParameters& params); | 52 media::AudioRendererMixer* GetMixer(RenderView* render_view, |
| 53 const media::AudioParameters& params); |
51 | 54 |
52 // Remove a mixer instance given a mixer if the only other reference is held | 55 // Remove a mixer instance given a mixer if the only other reference is held |
53 // by AudioRendererMixerManager. Every AudioRendererMixer owner must call | 56 // by AudioRendererMixerManager. Every AudioRendererMixer owner must call |
54 // this method when it's done with a mixer. | 57 // this method when it's done with a mixer. |
55 void RemoveMixer(const media::AudioParameters& params); | 58 void RemoveMixer(const media::AudioParameters& params); |
56 | 59 |
57 // Map of AudioParameters to <AudioRendererMixer, Count>. Count allows | 60 // Map of AudioParameters to <AudioRendererMixer, Count>. Count allows |
58 // AudioRendererMixerManager to keep track explicitly (v.s. RefCounted which | 61 // AudioRendererMixerManager to keep track explicitly (v.s. RefCounted which |
59 // is implicit) of the number of outstanding AudioRendererMixers. | 62 // is implicit) of the number of outstanding AudioRendererMixers. |
60 struct AudioRendererMixerReference { | 63 struct AudioRendererMixerReference { |
61 media::AudioRendererMixer* mixer; | 64 media::AudioRendererMixer* mixer; |
62 int ref_count; | 65 int ref_count; |
63 }; | 66 }; |
64 typedef std::map<media::AudioParameters, AudioRendererMixerReference, | 67 typedef std::map<media::AudioParameters, AudioRendererMixerReference, |
65 media::AudioParameters::Compare> AudioRendererMixerMap; | 68 media::AudioParameters::Compare> AudioRendererMixerMap; |
66 AudioRendererMixerMap mixers_; | 69 AudioRendererMixerMap mixers_; |
67 base::Lock mixers_lock_; | 70 base::Lock mixers_lock_; |
68 | 71 |
69 // Audio hardware configuration. Used to construct output AudioParameters for | 72 // Audio hardware configuration. Used to construct output AudioParameters for |
70 // each AudioRendererMixer instance. | 73 // each AudioRendererMixer instance. |
71 int hardware_sample_rate_; | 74 int hardware_sample_rate_; |
72 int hardware_buffer_size_; | 75 int hardware_buffer_size_; |
73 | 76 |
74 DISALLOW_COPY_AND_ASSIGN(AudioRendererMixerManager); | 77 DISALLOW_COPY_AND_ASSIGN(AudioRendererMixerManager); |
75 }; | 78 }; |
76 | 79 |
77 } // namespace content | 80 } // namespace content |
78 | 81 |
79 #endif // CONTENT_RENDERER_MEDIA_AUDIO_RENDERER_MIXER_MANAGER_H_ | 82 #endif // CONTENT_RENDERER_MEDIA_AUDIO_RENDERER_MIXER_MANAGER_H_ |
OLD | NEW |