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/filters/audio_renderer_impl.h" | 5 #include "media/filters/audio_renderer_impl.h" |
6 | 6 |
7 #include <math.h> | 7 #include <math.h> |
8 | 8 |
9 #include <algorithm> | 9 #include <algorithm> |
10 | 10 |
(...skipping 129 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
140 } | 140 } |
141 | 141 |
142 void AudioRendererImpl::DoFlush_Locked() { | 142 void AudioRendererImpl::DoFlush_Locked() { |
143 DCHECK(task_runner_->BelongsToCurrentThread()); | 143 DCHECK(task_runner_->BelongsToCurrentThread()); |
144 lock_.AssertAcquired(); | 144 lock_.AssertAcquired(); |
145 | 145 |
146 DCHECK(!pending_read_); | 146 DCHECK(!pending_read_); |
147 DCHECK_EQ(state_, kPaused); | 147 DCHECK_EQ(state_, kPaused); |
148 | 148 |
149 if (decrypting_demuxer_stream_) { | 149 if (decrypting_demuxer_stream_) { |
150 decrypting_demuxer_stream_->Reset(BindToCurrentLoop( | 150 decrypting_demuxer_stream_->Reset( |
151 base::Bind(&AudioRendererImpl::ResetDecoder, weak_this_))); | 151 base::Bind(&AudioRendererImpl::ResetDecoder, weak_this_)); |
152 return; | 152 return; |
153 } | 153 } |
154 | 154 |
155 ResetDecoder(); | 155 ResetDecoder(); |
156 } | 156 } |
157 | 157 |
158 void AudioRendererImpl::ResetDecoder() { | 158 void AudioRendererImpl::ResetDecoder() { |
159 DCHECK(task_runner_->BelongsToCurrentThread()); | 159 DCHECK(task_runner_->BelongsToCurrentThread()); |
160 decoder_->Reset(BindToCurrentLoop( | 160 decoder_->Reset(base::Bind(&AudioRendererImpl::ResetDecoderDone, weak_this_)); |
161 base::Bind(&AudioRendererImpl::ResetDecoderDone, weak_this_))); | |
162 } | 161 } |
163 | 162 |
164 void AudioRendererImpl::ResetDecoderDone() { | 163 void AudioRendererImpl::ResetDecoderDone() { |
165 base::AutoLock auto_lock(lock_); | 164 DCHECK(task_runner_->BelongsToCurrentThread()); |
166 if (state_ == kStopped) | 165 { |
167 return; | 166 base::AutoLock auto_lock(lock_); |
167 if (state_ == kStopped) | |
168 return; | |
168 | 169 |
169 DCHECK_EQ(state_, kPaused); | 170 DCHECK_EQ(state_, kPaused); |
170 DCHECK(!flush_cb_.is_null()); | 171 DCHECK(!flush_cb_.is_null()); |
171 | 172 |
172 audio_time_buffered_ = kNoTimestamp(); | 173 audio_time_buffered_ = kNoTimestamp(); |
173 current_time_ = kNoTimestamp(); | 174 current_time_ = kNoTimestamp(); |
174 received_end_of_stream_ = false; | 175 received_end_of_stream_ = false; |
175 rendered_end_of_stream_ = false; | 176 rendered_end_of_stream_ = false; |
176 preroll_aborted_ = false; | 177 preroll_aborted_ = false; |
177 | 178 |
178 earliest_end_time_ = now_cb_.Run(); | 179 earliest_end_time_ = now_cb_.Run(); |
179 splicer_->Reset(); | 180 splicer_->Reset(); |
180 algorithm_->FlushBuffers(); | 181 algorithm_->FlushBuffers(); |
181 | 182 } |
182 base::ResetAndReturn(&flush_cb_).Run(); | 183 base::ResetAndReturn(&flush_cb_).Run(); |
183 } | 184 } |
184 | 185 |
185 void AudioRendererImpl::Stop(const base::Closure& callback) { | 186 void AudioRendererImpl::Stop(const base::Closure& callback) { |
186 DCHECK(task_runner_->BelongsToCurrentThread()); | 187 DCHECK(task_runner_->BelongsToCurrentThread()); |
187 DCHECK(!callback.is_null()); | 188 DCHECK(!callback.is_null()); |
188 | 189 |
189 // TODO(scherkus): Consider invalidating |weak_factory_| and replacing | 190 // TODO(scherkus): Consider invalidating |weak_factory_| and replacing |
190 // task-running guards that check |state_| with DCHECK(). | 191 // task-running guards that check |state_| with DCHECK(). |
191 | 192 |
192 if (sink_) { | 193 if (sink_) { |
193 sink_->Stop(); | 194 sink_->Stop(); |
194 sink_ = NULL; | 195 sink_ = NULL; |
195 } | 196 } |
196 | 197 |
198 if (state_ == kUninitialized) { | |
DaleCurtis
2014/01/21 22:20:26
If uninitialized there shouldn't be any reason to
| |
199 decoder_selector_->Abort(); | |
200 callback.Run(); | |
201 return; | |
202 } | |
203 | |
197 { | 204 { |
198 base::AutoLock auto_lock(lock_); | 205 base::AutoLock auto_lock(lock_); |
206 if (state_ == kStopped) | |
207 return; | |
208 | |
199 ChangeState_Locked(kStopped); | 209 ChangeState_Locked(kStopped); |
200 algorithm_.reset(NULL); | 210 algorithm_.reset(); |
201 init_cb_.Reset(); | |
202 underflow_cb_.Reset(); | 211 underflow_cb_.Reset(); |
203 time_cb_.Reset(); | 212 time_cb_.Reset(); |
204 flush_cb_.Reset(); | 213 flush_cb_.Reset(); |
205 } | 214 } |
206 | 215 |
216 if (decoder_) { | |
217 decoder_->Stop(callback); | |
218 return; | |
219 } | |
220 | |
207 callback.Run(); | 221 callback.Run(); |
208 } | 222 } |
209 | 223 |
210 void AudioRendererImpl::Preroll(base::TimeDelta time, | 224 void AudioRendererImpl::Preroll(base::TimeDelta time, |
211 const PipelineStatusCB& cb) { | 225 const PipelineStatusCB& cb) { |
212 DCHECK(task_runner_->BelongsToCurrentThread()); | 226 DCHECK(task_runner_->BelongsToCurrentThread()); |
213 | 227 |
214 base::AutoLock auto_lock(lock_); | 228 base::AutoLock auto_lock(lock_); |
215 DCHECK(!sink_playing_); | 229 DCHECK(!sink_playing_); |
216 DCHECK_EQ(state_, kPaused); | 230 DCHECK_EQ(state_, kPaused); |
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
263 void AudioRendererImpl::OnDecoderSelected( | 277 void AudioRendererImpl::OnDecoderSelected( |
264 scoped_ptr<AudioDecoder> decoder, | 278 scoped_ptr<AudioDecoder> decoder, |
265 scoped_ptr<DecryptingDemuxerStream> decrypting_demuxer_stream) { | 279 scoped_ptr<DecryptingDemuxerStream> decrypting_demuxer_stream) { |
266 DCHECK(task_runner_->BelongsToCurrentThread()); | 280 DCHECK(task_runner_->BelongsToCurrentThread()); |
267 | 281 |
268 base::AutoLock auto_lock(lock_); | 282 base::AutoLock auto_lock(lock_); |
269 scoped_ptr<AudioDecoderSelector> deleter(decoder_selector_.Pass()); | 283 scoped_ptr<AudioDecoderSelector> deleter(decoder_selector_.Pass()); |
270 | 284 |
271 if (state_ == kStopped) { | 285 if (state_ == kStopped) { |
272 DCHECK(!sink_); | 286 DCHECK(!sink_); |
287 base::ResetAndReturn(&init_cb_).Run(PIPELINE_ERROR_ABORT); | |
273 return; | 288 return; |
274 } | 289 } |
275 | 290 |
276 if (!decoder) { | 291 if (!decoder) { |
277 base::ResetAndReturn(&init_cb_).Run(DECODER_ERROR_NOT_SUPPORTED); | 292 base::ResetAndReturn(&init_cb_).Run(DECODER_ERROR_NOT_SUPPORTED); |
278 return; | 293 return; |
279 } | 294 } |
280 | 295 |
281 decoder_ = decoder.Pass(); | 296 decoder_ = decoder.Pass(); |
282 decrypting_demuxer_stream_ = decrypting_demuxer_stream.Pass(); | 297 decrypting_demuxer_stream_ = decrypting_demuxer_stream.Pass(); |
(...skipping 417 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
700 } | 715 } |
701 } | 716 } |
702 | 717 |
703 void AudioRendererImpl::ChangeState_Locked(State new_state) { | 718 void AudioRendererImpl::ChangeState_Locked(State new_state) { |
704 DVLOG(1) << __FUNCTION__ << " : " << state_ << " -> " << new_state; | 719 DVLOG(1) << __FUNCTION__ << " : " << state_ << " -> " << new_state; |
705 lock_.AssertAcquired(); | 720 lock_.AssertAcquired(); |
706 state_ = new_state; | 721 state_ = new_state; |
707 } | 722 } |
708 | 723 |
709 } // namespace media | 724 } // namespace media |
OLD | NEW |