Chromium Code Reviews| 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 #include "content/renderer/media/audio_renderer_mixer_manager.h" | 5 #include "content/renderer/media/audio_renderer_mixer_manager.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "content/renderer/media/audio_device_factory.h" | 9 #include "content/renderer/media/audio_device_factory.h" |
| 10 #include "content/renderer/media/renderer_audio_output_device.h" | |
| 10 #include "media/base/audio_renderer_mixer.h" | 11 #include "media/base/audio_renderer_mixer.h" |
| 11 #include "media/base/audio_renderer_mixer_input.h" | 12 #include "media/base/audio_renderer_mixer_input.h" |
| 12 | 13 |
| 13 namespace content { | 14 namespace content { |
| 14 | 15 |
| 15 AudioRendererMixerManager::AudioRendererMixerManager(int hardware_sample_rate, | 16 AudioRendererMixerManager::AudioRendererMixerManager(int hardware_sample_rate, |
| 16 int hardware_buffer_size) | 17 int hardware_buffer_size) |
| 17 : hardware_sample_rate_(hardware_sample_rate), | 18 : hardware_sample_rate_(hardware_sample_rate), |
| 18 hardware_buffer_size_(hardware_buffer_size) { | 19 hardware_buffer_size_(hardware_buffer_size), |
| 20 sink_for_testing_(NULL) { | |
|
DaleCurtis
2012/12/03 18:52:03
Are these changes still necessary?
miu
2012/12/03 20:20:51
Yes. AudioDeviceFactory::NewOutputDevice() now re
| |
| 19 } | 21 } |
| 20 | 22 |
| 21 AudioRendererMixerManager::~AudioRendererMixerManager() { | 23 AudioRendererMixerManager::~AudioRendererMixerManager() { |
| 22 DCHECK(mixers_.empty()); | 24 DCHECK(mixers_.empty()); |
| 23 } | 25 } |
| 24 | 26 |
| 25 media::AudioRendererMixerInput* AudioRendererMixerManager::CreateInput() { | 27 media::AudioRendererMixerInput* AudioRendererMixerManager::CreateInput() { |
| 26 return new media::AudioRendererMixerInput( | 28 return new media::AudioRendererMixerInput( |
| 27 base::Bind( | 29 base::Bind( |
| 28 &AudioRendererMixerManager::GetMixer, base::Unretained(this)), | 30 &AudioRendererMixerManager::GetMixer, base::Unretained(this)), |
| 29 base::Bind( | 31 base::Bind( |
| 30 &AudioRendererMixerManager::RemoveMixer, base::Unretained(this))); | 32 &AudioRendererMixerManager::RemoveMixer, base::Unretained(this))); |
| 31 } | 33 } |
| 32 | 34 |
| 35 void AudioRendererMixerManager::SetAudioRendererSinkForTesting( | |
| 36 media::AudioRendererSink* sink) { | |
| 37 sink_for_testing_ = sink; | |
| 38 } | |
| 39 | |
| 33 media::AudioRendererMixer* AudioRendererMixerManager::GetMixer( | 40 media::AudioRendererMixer* AudioRendererMixerManager::GetMixer( |
| 34 const media::AudioParameters& params) { | 41 const media::AudioParameters& params) { |
| 35 base::AutoLock auto_lock(mixers_lock_); | 42 base::AutoLock auto_lock(mixers_lock_); |
| 36 | 43 |
| 37 AudioRendererMixerMap::iterator it = mixers_.find(params); | 44 AudioRendererMixerMap::iterator it = mixers_.find(params); |
| 38 if (it != mixers_.end()) { | 45 if (it != mixers_.end()) { |
| 39 it->second.ref_count++; | 46 it->second.ref_count++; |
| 40 return it->second.mixer; | 47 return it->second.mixer; |
| 41 } | 48 } |
| 42 | 49 |
| 43 // Create output parameters based on the audio hardware configuration for | 50 // Create output parameters based on the audio hardware configuration for |
| 44 // passing on to the output sink. Force to 16-bit output for now since we | 51 // passing on to the output sink. Force to 16-bit output for now since we |
| 45 // know that works well for WebAudio and WebRTC. | 52 // know that works well for WebAudio and WebRTC. |
| 46 media::AudioParameters output_params( | 53 media::AudioParameters output_params( |
| 47 media::AudioParameters::AUDIO_PCM_LOW_LATENCY, params.channel_layout(), | 54 media::AudioParameters::AUDIO_PCM_LOW_LATENCY, params.channel_layout(), |
| 48 hardware_sample_rate_, 16, hardware_buffer_size_); | 55 hardware_sample_rate_, 16, hardware_buffer_size_); |
| 49 | 56 |
| 50 // If we've created invalid output parameters, simply pass on the input params | 57 // If we've created invalid output parameters, simply pass on the input params |
| 51 // and let the browser side handle automatic fallback. | 58 // and let the browser side handle automatic fallback. |
| 52 if (!output_params.IsValid()) | 59 if (!output_params.IsValid()) |
| 53 output_params = params; | 60 output_params = params; |
| 54 | 61 |
| 55 media::AudioRendererMixer* mixer = new media::AudioRendererMixer( | 62 media::AudioRendererMixer* mixer = new media::AudioRendererMixer( |
| 56 params, output_params, AudioDeviceFactory::NewOutputDevice()); | 63 params, output_params, |
| 64 sink_for_testing_ ? | |
| 65 sink_for_testing_ : | |
| 66 AudioDeviceFactory::NewOutputDevice()); | |
| 57 | 67 |
| 58 AudioRendererMixerReference mixer_reference = { mixer, 1 }; | 68 AudioRendererMixerReference mixer_reference = { mixer, 1 }; |
| 59 mixers_[params] = mixer_reference; | 69 mixers_[params] = mixer_reference; |
| 60 return mixer; | 70 return mixer; |
| 61 } | 71 } |
| 62 | 72 |
| 63 void AudioRendererMixerManager::RemoveMixer( | 73 void AudioRendererMixerManager::RemoveMixer( |
| 64 const media::AudioParameters& params) { | 74 const media::AudioParameters& params) { |
| 65 base::AutoLock auto_lock(mixers_lock_); | 75 base::AutoLock auto_lock(mixers_lock_); |
| 66 | 76 |
| 67 AudioRendererMixerMap::iterator it = mixers_.find(params); | 77 AudioRendererMixerMap::iterator it = mixers_.find(params); |
| 68 DCHECK(it != mixers_.end()); | 78 DCHECK(it != mixers_.end()); |
| 69 | 79 |
| 70 // Only remove the mixer if AudioRendererMixerManager is the last owner. | 80 // Only remove the mixer if AudioRendererMixerManager is the last owner. |
| 71 it->second.ref_count--; | 81 it->second.ref_count--; |
| 72 if (it->second.ref_count == 0) { | 82 if (it->second.ref_count == 0) { |
| 73 delete it->second.mixer; | 83 delete it->second.mixer; |
| 74 mixers_.erase(it); | 84 mixers_.erase(it); |
| 75 } | 85 } |
| 76 } | 86 } |
| 77 | 87 |
| 78 } // namespace content | 88 } // namespace content |
| OLD | NEW |