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/ffmpeg_audio_decoder.h" | 5 #include "media/filters/ffmpeg_audio_decoder.h" |
6 | 6 |
7 #include "base/callback_helpers.h" | 7 #include "base/callback_helpers.h" |
8 #include "base/single_thread_task_runner.h" | 8 #include "base/single_thread_task_runner.h" |
9 #include "media/base/audio_buffer.h" | 9 #include "media/base/audio_buffer.h" |
10 #include "media/base/audio_bus.h" | 10 #include "media/base/audio_bus.h" |
(...skipping 117 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
128 FFmpegAudioDecoder::FFmpegAudioDecoder( | 128 FFmpegAudioDecoder::FFmpegAudioDecoder( |
129 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, | 129 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, |
130 const LogCB& log_cb) | 130 const LogCB& log_cb) |
131 : task_runner_(task_runner), | 131 : task_runner_(task_runner), |
132 state_(kUninitialized), | 132 state_(kUninitialized), |
133 av_sample_format_(0), | 133 av_sample_format_(0), |
134 log_cb_(log_cb) { | 134 log_cb_(log_cb) { |
135 } | 135 } |
136 | 136 |
137 FFmpegAudioDecoder::~FFmpegAudioDecoder() { | 137 FFmpegAudioDecoder::~FFmpegAudioDecoder() { |
138 DCHECK_EQ(state_, kUninitialized); | 138 DCHECK(task_runner_->BelongsToCurrentThread()); |
139 DCHECK(!codec_context_); | 139 |
140 DCHECK(!av_frame_); | 140 if (state_ != kUninitialized) { |
| 141 ReleaseFFmpegResources(); |
| 142 ResetTimestampState(); |
| 143 } |
141 } | 144 } |
142 | 145 |
143 void FFmpegAudioDecoder::Initialize(const AudioDecoderConfig& config, | 146 void FFmpegAudioDecoder::Initialize(const AudioDecoderConfig& config, |
144 const PipelineStatusCB& status_cb, | 147 const PipelineStatusCB& status_cb, |
145 const OutputCB& output_cb) { | 148 const OutputCB& output_cb) { |
146 DCHECK(task_runner_->BelongsToCurrentThread()); | 149 DCHECK(task_runner_->BelongsToCurrentThread()); |
147 DCHECK(!config.is_encrypted()); | 150 DCHECK(!config.is_encrypted()); |
148 | 151 |
149 FFmpegGlue::InitializeFFmpeg(); | 152 FFmpegGlue::InitializeFFmpeg(); |
150 | 153 |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
185 | 188 |
186 void FFmpegAudioDecoder::Reset(const base::Closure& closure) { | 189 void FFmpegAudioDecoder::Reset(const base::Closure& closure) { |
187 DCHECK(task_runner_->BelongsToCurrentThread()); | 190 DCHECK(task_runner_->BelongsToCurrentThread()); |
188 | 191 |
189 avcodec_flush_buffers(codec_context_.get()); | 192 avcodec_flush_buffers(codec_context_.get()); |
190 state_ = kNormal; | 193 state_ = kNormal; |
191 ResetTimestampState(); | 194 ResetTimestampState(); |
192 task_runner_->PostTask(FROM_HERE, closure); | 195 task_runner_->PostTask(FROM_HERE, closure); |
193 } | 196 } |
194 | 197 |
195 void FFmpegAudioDecoder::Stop() { | |
196 DCHECK(task_runner_->BelongsToCurrentThread()); | |
197 | |
198 if (state_ == kUninitialized) | |
199 return; | |
200 | |
201 ReleaseFFmpegResources(); | |
202 ResetTimestampState(); | |
203 state_ = kUninitialized; | |
204 } | |
205 | |
206 void FFmpegAudioDecoder::DecodeBuffer( | 198 void FFmpegAudioDecoder::DecodeBuffer( |
207 const scoped_refptr<DecoderBuffer>& buffer, | 199 const scoped_refptr<DecoderBuffer>& buffer, |
208 const DecodeCB& decode_cb) { | 200 const DecodeCB& decode_cb) { |
209 DCHECK(task_runner_->BelongsToCurrentThread()); | 201 DCHECK(task_runner_->BelongsToCurrentThread()); |
210 DCHECK_NE(state_, kUninitialized); | 202 DCHECK_NE(state_, kUninitialized); |
211 DCHECK_NE(state_, kDecodeFinished); | 203 DCHECK_NE(state_, kDecodeFinished); |
212 DCHECK_NE(state_, kError); | 204 DCHECK_NE(state_, kError); |
213 DCHECK(buffer); | 205 DCHECK(buffer); |
214 | 206 |
215 // Make sure we are notified if http://crbug.com/49709 returns. Issue also | 207 // Make sure we are notified if http://crbug.com/49709 returns. Issue also |
(...skipping 176 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
392 | 384 |
393 ResetTimestampState(); | 385 ResetTimestampState(); |
394 return true; | 386 return true; |
395 } | 387 } |
396 | 388 |
397 void FFmpegAudioDecoder::ResetTimestampState() { | 389 void FFmpegAudioDecoder::ResetTimestampState() { |
398 discard_helper_->Reset(config_.codec_delay()); | 390 discard_helper_->Reset(config_.codec_delay()); |
399 } | 391 } |
400 | 392 |
401 } // namespace media | 393 } // namespace media |
OLD | NEW |