Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(250)

Side by Side Diff: media/filters/audio_renderer_impl.cc

Issue 140823012: Reland: Add Stop() to AudioDecoder. (https://codereview.chromium.org/126793002/) (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
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
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
OLDNEW
« no previous file with comments | « media/filters/audio_decoder_selector_unittest.cc ('k') | media/filters/audio_renderer_impl_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698