| 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 <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| 11 #include "build/build_config.h" | 11 #include "build/build_config.h" |
| 12 #include "content/renderer/media/audio_device_factory.h" | 12 #include "content/renderer/media/audio_device_factory.h" |
| 13 #include "media/audio/audio_output_device.h" | 13 #include "media/audio/audio_manager_base.h" |
| 14 #include "media/base/audio_hardware_config.h" | 14 #include "media/base/audio_hardware_config.h" |
| 15 #include "media/base/audio_renderer_mixer.h" | 15 #include "media/base/audio_renderer_mixer.h" |
| 16 #include "media/base/audio_renderer_mixer_input.h" | 16 #include "media/base/audio_renderer_mixer_input.h" |
| 17 | 17 |
| 18 namespace content { | 18 namespace content { |
| 19 | 19 |
| 20 AudioRendererMixerManager::AudioRendererMixerManager() {} | 20 AudioRendererMixerManager::AudioRendererMixerManager() {} |
| 21 | 21 |
| 22 AudioRendererMixerManager::~AudioRendererMixerManager() { | 22 AudioRendererMixerManager::~AudioRendererMixerManager() { |
| 23 // References to AudioRendererMixers may be owned by garbage collected | 23 // References to AudioRendererMixers may be owned by garbage collected |
| 24 // objects. During process shutdown they may be leaked, so, transitively, | 24 // objects. During process shutdown they may be leaked, so, transitively, |
| 25 // |mixers_| may leak (i.e., may be non-empty at this time) as well. | 25 // |mixers_| may leak (i.e., may be non-empty at this time) as well. |
| 26 } | 26 } |
| 27 | 27 |
| 28 media::AudioRendererMixerInput* AudioRendererMixerManager::CreateInput( | 28 media::AudioRendererMixerInput* AudioRendererMixerManager::CreateInput( |
| 29 int source_render_frame_id, | 29 int source_render_frame_id, |
| 30 int session_id, |
| 30 const std::string& device_id, | 31 const std::string& device_id, |
| 31 const url::Origin& security_origin) { | 32 const url::Origin& security_origin) { |
| 33 // base::Unretained() is safe since AudioRendererMixerManager lives on the |
| 34 // renderer thread and is destroyed on renderer thread destruction. |
| 32 return new media::AudioRendererMixerInput( | 35 return new media::AudioRendererMixerInput( |
| 33 base::Bind(&AudioRendererMixerManager::GetMixer, base::Unretained(this), | 36 base::Bind(&AudioRendererMixerManager::GetMixer, base::Unretained(this), |
| 34 source_render_frame_id), | 37 source_render_frame_id), |
| 35 base::Bind(&AudioRendererMixerManager::RemoveMixer, | 38 base::Bind(&AudioRendererMixerManager::RemoveMixer, |
| 36 base::Unretained(this), source_render_frame_id), | 39 base::Unretained(this), source_render_frame_id), |
| 37 device_id, | 40 // TODO(olka) remove the dependency on AudioManagerBase, |
| 41 // https://crbug.com/02581 |
| 42 media::AudioManagerBase::UseSessionIdToSelectDevice(session_id, device_id) |
| 43 ? AudioDeviceFactory::GetOutputDeviceInfo( |
| 44 source_render_frame_id, session_id, device_id, security_origin) |
| 45 .device_id() |
| 46 : device_id, |
| 38 security_origin); | 47 security_origin); |
| 39 } | 48 } |
| 40 | 49 |
| 41 media::AudioRendererMixer* AudioRendererMixerManager::GetMixer( | 50 media::AudioRendererMixer* AudioRendererMixerManager::GetMixer( |
| 42 int source_render_frame_id, | 51 int source_render_frame_id, |
| 43 const media::AudioParameters& params, | 52 const media::AudioParameters& params, |
| 44 const std::string& device_id, | 53 const std::string& device_id, |
| 45 const url::Origin& security_origin, | 54 const url::Origin& security_origin, |
| 46 media::OutputDeviceStatus* device_status) { | 55 media::OutputDeviceStatus* device_status) { |
| 47 // Effects are not passed through to output creation, so ensure none are set. | 56 // Effects are not passed through to output creation, so ensure none are set. |
| (...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 132 const std::string& device_id, | 141 const std::string& device_id, |
| 133 const url::Origin& security_origin) | 142 const url::Origin& security_origin) |
| 134 : source_render_frame_id(source_render_frame_id), | 143 : source_render_frame_id(source_render_frame_id), |
| 135 params(params), | 144 params(params), |
| 136 device_id(device_id), | 145 device_id(device_id), |
| 137 security_origin(security_origin) {} | 146 security_origin(security_origin) {} |
| 138 | 147 |
| 139 AudioRendererMixerManager::MixerKey::MixerKey(const MixerKey& other) = default; | 148 AudioRendererMixerManager::MixerKey::MixerKey(const MixerKey& other) = default; |
| 140 | 149 |
| 141 } // namespace content | 150 } // namespace content |
| OLD | NEW |