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

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

Issue 113611: Handle end of stream for media... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 11 years, 6 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 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/filter_host.h" 5 #include "media/base/filter_host.h"
6 #include "media/filters/audio_renderer_base.h" 6 #include "media/filters/audio_renderer_base.h"
7 7
8 namespace media { 8 namespace media {
9 9
10 // The maximum size of the queue, which also acts as the number of initial reads 10 // The maximum size of the queue, which also acts as the number of initial reads
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after
64 } 64 }
65 65
66 // Defer initialization until all scheduled reads have completed. 66 // Defer initialization until all scheduled reads have completed.
67 return OnInitialize(decoder_->media_format()); 67 return OnInitialize(decoder_->media_format());
68 } 68 }
69 69
70 void AudioRendererBase::OnReadComplete(Buffer* buffer_in) { 70 void AudioRendererBase::OnReadComplete(Buffer* buffer_in) {
71 bool initialization_complete = false; 71 bool initialization_complete = false;
72 { 72 {
73 AutoLock auto_lock(lock_); 73 AutoLock auto_lock(lock_);
74 if (!stopped_) { 74 // If we have stopped don't enqueue, same for end of stream buffer since
75 // it has no data.
76 if (!stopped_ && !buffer_in->IsEndOfStream()) {
75 queue_.push_back(buffer_in); 77 queue_.push_back(buffer_in);
76 DCHECK(queue_.size() <= max_queue_size_); 78 DCHECK(queue_.size() <= max_queue_size_);
77 } 79 }
78 80
79 // See if we're finally initialized. 81 if (!initialized_) {
80 // TODO(scherkus): handle end of stream cases where we'll never reach max 82 // We have completed the initialization when we preroll enough and hit
81 // queue size. 83 // the target queue size or the stream has ended.
82 if (!initialized_ && queue_.size() == max_queue_size_) { 84 if (queue_.size() == max_queue_size_ || buffer_in->IsEndOfStream())
83 initialization_complete = true; 85 initialization_complete = true;
84 } 86 }
85 } 87 }
86 88
87 if (initialization_complete) { 89 if (initialization_complete) {
88 initialized_ = true; 90 if (queue_.empty()) {
89 host_->InitializationComplete(); 91 // If we say we have initialized but buffer queue is empty, raise an
92 // error.
93 host_->Error(PIPELINE_ERROR_NO_DATA);
94 } else {
95 initialized_ = true;
96 host_->InitializationComplete();
97 }
90 } 98 }
91 } 99 }
92 100
93 // TODO(scherkus): clean up FillBuffer().. it's overly complex!! 101 // TODO(scherkus): clean up FillBuffer().. it's overly complex!!
94 size_t AudioRendererBase::FillBuffer(uint8* dest, size_t dest_len, 102 size_t AudioRendererBase::FillBuffer(uint8* dest, size_t dest_len,
95 float rate) { 103 float rate) {
96 size_t buffers_released = 0; 104 size_t buffers_released = 0;
97 size_t dest_written = 0; 105 size_t dest_written = 0;
98 base::TimeDelta last_fill_buffer_time; 106 base::TimeDelta last_fill_buffer_time;
99 { 107 {
(...skipping 109 matching lines...) Expand 10 before | Expand all | Expand 10 after
209 // TODO(scherkus): might be handy to support NULL parameters. 217 // TODO(scherkus): might be handy to support NULL parameters.
210 std::string mime_type; 218 std::string mime_type;
211 return media_format.GetAsString(MediaFormat::kMimeType, &mime_type) && 219 return media_format.GetAsString(MediaFormat::kMimeType, &mime_type) &&
212 media_format.GetAsInteger(MediaFormat::kChannels, channels_out) && 220 media_format.GetAsInteger(MediaFormat::kChannels, channels_out) &&
213 media_format.GetAsInteger(MediaFormat::kSampleRate, sample_rate_out) && 221 media_format.GetAsInteger(MediaFormat::kSampleRate, sample_rate_out) &&
214 media_format.GetAsInteger(MediaFormat::kSampleBits, sample_bits_out) && 222 media_format.GetAsInteger(MediaFormat::kSampleBits, sample_bits_out) &&
215 mime_type.compare(mime_type::kUncompressedAudio) == 0; 223 mime_type.compare(mime_type::kUncompressedAudio) == 0;
216 } 224 }
217 225
218 } // namespace media 226 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698