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(). This is the only method | |
198 // called on the audio device thread. For other methods, thread safety | |
199 // should be enforced by the caller. See the lock in AudioRendererMixer. | |
o1ka
2016/03/16 14:31:18
It's not quite clear to me how the lock in AudioRe
chcunningham
2016/03/17 17:59:45
Woops! AudioRendererMixer should have been WebAudi
| |
200 { | |
201 base::AutoLock auto_lock(volume_lock_); | |
202 return frames_filled > 0 ? volume_ : 0; | |
203 } | |
194 } | 204 } |
195 | 205 |
196 void AudioRendererMixerInput::OnRenderError() { | 206 void AudioRendererMixerInput::OnRenderError() { |
197 callback_->OnRenderError(); | 207 callback_->OnRenderError(); |
198 } | 208 } |
199 | 209 |
200 } // namespace media | 210 } // namespace media |
OLD | NEW |