| 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 "media/base/audio_renderer_mixer_input.h" | 5 #include "media/base/audio_renderer_mixer_input.h" |
| 6 | 6 |
| 7 #include <cmath> | 7 #include <cmath> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/callback_helpers.h" | 10 #include "base/callback_helpers.h" |
| (...skipping 14 matching lines...) Expand all Loading... |
| 25 remove_mixer_cb_(remove_mixer_cb), | 25 remove_mixer_cb_(remove_mixer_cb), |
| 26 get_hardware_params_cb_(get_hardware_params_cb), | 26 get_hardware_params_cb_(get_hardware_params_cb), |
| 27 device_id_(device_id), | 27 device_id_(device_id), |
| 28 security_origin_(security_origin), | 28 security_origin_(security_origin), |
| 29 mixer_(nullptr), | 29 mixer_(nullptr), |
| 30 callback_(nullptr), | 30 callback_(nullptr), |
| 31 error_cb_(base::Bind(&AudioRendererMixerInput::OnRenderError, | 31 error_cb_(base::Bind(&AudioRendererMixerInput::OnRenderError, |
| 32 base::Unretained(this))) {} | 32 base::Unretained(this))) {} |
| 33 | 33 |
| 34 AudioRendererMixerInput::~AudioRendererMixerInput() { | 34 AudioRendererMixerInput::~AudioRendererMixerInput() { |
| 35 DCHECK(!started_); |
| 35 DCHECK(!mixer_); | 36 DCHECK(!mixer_); |
| 36 } | 37 } |
| 37 | 38 |
| 38 void AudioRendererMixerInput::Initialize( | 39 void AudioRendererMixerInput::Initialize( |
| 39 const AudioParameters& params, | 40 const AudioParameters& params, |
| 40 AudioRendererSink::RenderCallback* callback) { | 41 AudioRendererSink::RenderCallback* callback) { |
| 42 DCHECK(!started_); |
| 41 DCHECK(!mixer_); | 43 DCHECK(!mixer_); |
| 42 DCHECK(callback); | 44 DCHECK(callback); |
| 43 | 45 |
| 44 params_ = params; | 46 params_ = params; |
| 45 callback_ = callback; | 47 callback_ = callback; |
| 46 } | 48 } |
| 47 | 49 |
| 48 void AudioRendererMixerInput::Start() { | 50 void AudioRendererMixerInput::Start() { |
| 49 DCHECK(!started_); | 51 DCHECK(!started_); |
| 50 DCHECK(!mixer_); | 52 DCHECK(!mixer_); |
| (...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 99 | 101 |
| 100 void AudioRendererMixerInput::Pause() { | 102 void AudioRendererMixerInput::Pause() { |
| 101 if (!playing_ || !mixer_) | 103 if (!playing_ || !mixer_) |
| 102 return; | 104 return; |
| 103 | 105 |
| 104 mixer_->RemoveMixerInput(params_, this); | 106 mixer_->RemoveMixerInput(params_, this); |
| 105 playing_ = false; | 107 playing_ = false; |
| 106 } | 108 } |
| 107 | 109 |
| 108 bool AudioRendererMixerInput::SetVolume(double volume) { | 110 bool AudioRendererMixerInput::SetVolume(double volume) { |
| 111 base::AutoLock auto_lock(volume_lock_); |
| 109 volume_ = volume; | 112 volume_ = volume; |
| 110 return true; | 113 return true; |
| 111 } | 114 } |
| 112 | 115 |
| 113 OutputDevice* AudioRendererMixerInput::GetOutputDevice() { | 116 OutputDevice* AudioRendererMixerInput::GetOutputDevice() { |
| 114 return this; | 117 return this; |
| 115 } | 118 } |
| 116 | 119 |
| 117 void AudioRendererMixerInput::SwitchOutputDevice( | 120 void AudioRendererMixerInput::SwitchOutputDevice( |
| 118 const std::string& device_id, | 121 const std::string& device_id, |
| (...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 183 params_.GetMicrosecondsPerFrame()); | 186 params_.GetMicrosecondsPerFrame()); |
| 184 | 187 |
| 185 int frames_filled = callback_->Render(audio_bus, frames_delayed, 0); | 188 int frames_filled = callback_->Render(audio_bus, frames_delayed, 0); |
| 186 | 189 |
| 187 // AudioConverter expects unfilled frames to be zeroed. | 190 // AudioConverter expects unfilled frames to be zeroed. |
| 188 if (frames_filled < audio_bus->frames()) { | 191 if (frames_filled < audio_bus->frames()) { |
| 189 audio_bus->ZeroFramesPartial( | 192 audio_bus->ZeroFramesPartial( |
| 190 frames_filled, audio_bus->frames() - frames_filled); | 193 frames_filled, audio_bus->frames() - frames_filled); |
| 191 } | 194 } |
| 192 | 195 |
| 193 return frames_filled > 0 ? volume_ : 0; | 196 // We're reading |volume_| from the audio device thread and must avoid racing |
| 197 // with the main/media thread calls to SetVolume(). See thread safety comment |
| 198 // in the header file. |
| 199 { |
| 200 base::AutoLock auto_lock(volume_lock_); |
| 201 return frames_filled > 0 ? volume_ : 0; |
| 202 } |
| 194 } | 203 } |
| 195 | 204 |
| 196 void AudioRendererMixerInput::OnRenderError() { | 205 void AudioRendererMixerInput::OnRenderError() { |
| 197 callback_->OnRenderError(); | 206 callback_->OnRenderError(); |
| 198 } | 207 } |
| 199 | 208 |
| 200 } // namespace media | 209 } // namespace media |
| OLD | NEW |