Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "webkit/glue/media/buffered_data_source.h" | 5 #include "webkit/glue/media/buffered_data_source.h" |
| 6 | 6 |
| 7 #include "media/base/filter_host.h" | 7 #include "media/base/filter_host.h" |
| 8 #include "net/base/net_errors.h" | 8 #include "net/base/net_errors.h" |
| 9 #include "webkit/glue/media/web_data_source_factory.h" | 9 #include "webkit/glue/media/web_data_source_factory.h" |
| 10 #include "webkit/glue/webkit_glue.h" | 10 #include "webkit/glue/webkit_glue.h" |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 57 read_position_(0), | 57 read_position_(0), |
| 58 read_size_(0), | 58 read_size_(0), |
| 59 read_buffer_(NULL), | 59 read_buffer_(NULL), |
| 60 read_attempts_(0), | 60 read_attempts_(0), |
| 61 intermediate_read_buffer_(new uint8[kInitialReadBufferSize]), | 61 intermediate_read_buffer_(new uint8[kInitialReadBufferSize]), |
| 62 intermediate_read_buffer_size_(kInitialReadBufferSize), | 62 intermediate_read_buffer_size_(kInitialReadBufferSize), |
| 63 render_loop_(render_loop), | 63 render_loop_(render_loop), |
| 64 stop_signal_received_(false), | 64 stop_signal_received_(false), |
| 65 stopped_on_render_loop_(false), | 65 stopped_on_render_loop_(false), |
| 66 media_is_paused_(true), | 66 media_is_paused_(true), |
| 67 media_has_played_(false), | |
| 68 preload_(media::PRELOAD_METADATA), | |
| 67 using_range_request_(true) { | 69 using_range_request_(true) { |
| 68 } | 70 } |
| 69 | 71 |
| 70 BufferedDataSource::~BufferedDataSource() { | 72 BufferedDataSource::~BufferedDataSource() { |
| 71 } | 73 } |
| 72 | 74 |
| 73 // A factory method to create BufferedResourceLoader using the read parameters. | 75 // A factory method to create BufferedResourceLoader using the read parameters. |
| 74 // This method can be overrided to inject mock BufferedResourceLoader object | 76 // This method can be overrided to inject mock BufferedResourceLoader object |
| 75 // for testing purpose. | 77 // for testing purpose. |
| 76 BufferedResourceLoader* BufferedDataSource::CreateResourceLoader( | 78 BufferedResourceLoader* BufferedDataSource::CreateResourceLoader( |
| (...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 147 render_loop_->PostTask(FROM_HERE, | 149 render_loop_->PostTask(FROM_HERE, |
| 148 NewRunnableMethod(this, &BufferedDataSource::CleanupTask)); | 150 NewRunnableMethod(this, &BufferedDataSource::CleanupTask)); |
| 149 } | 151 } |
| 150 | 152 |
| 151 void BufferedDataSource::SetPlaybackRate(float playback_rate) { | 153 void BufferedDataSource::SetPlaybackRate(float playback_rate) { |
| 152 render_loop_->PostTask(FROM_HERE, | 154 render_loop_->PostTask(FROM_HERE, |
| 153 NewRunnableMethod(this, &BufferedDataSource::SetPlaybackRateTask, | 155 NewRunnableMethod(this, &BufferedDataSource::SetPlaybackRateTask, |
| 154 playback_rate)); | 156 playback_rate)); |
| 155 } | 157 } |
| 156 | 158 |
| 159 void BufferedDataSource::SetPreload(media::Preload preload) { | |
| 160 render_loop_->PostTask(FROM_HERE, | |
| 161 NewRunnableMethod(this, &BufferedDataSource::SetPreloadTask, | |
| 162 preload)); | |
| 163 } | |
| 164 | |
| 165 BufferedResourceLoader::DeferStrategy | |
| 166 BufferedDataSource::ChooseDeferStrategy() { | |
|
acolwell GONE FROM CHROMIUM
2011/03/25 23:08:14
Remove the indent. I looked at the style rules and
vrk (LEFT CHROMIUM)
2011/03/29 00:53:00
Yeah, it looked weird to me, too; I just made it t
| |
| 167 // If the user indicates preload=metadata, then just load exactly | |
| 168 // what is needed for starting the pipeline and prerolling frames. | |
| 169 if (preload_ == media::PRELOAD_METADATA && !media_has_played_) | |
| 170 return BufferedResourceLoader::ReadThenDefer; | |
| 171 | |
| 172 // In general, we want to try to buffer the entire video when the video | |
| 173 // is paused. But we don't want to do this if the video hasn't played yet | |
| 174 // and preload!=auto. | |
| 175 if (media_is_paused_ && | |
| 176 (preload_ == media::PRELOAD_AUTO || media_has_played_)) { | |
| 177 return BufferedResourceLoader::NeverDefer; | |
| 178 } | |
| 179 | |
| 180 // When the video is playing, regardless of preload state, we buffer up | |
| 181 // to a hard limit and enable/disable deferring when the buffer is | |
| 182 // depleted/full. | |
| 183 return BufferedResourceLoader::ThresholdDefer; | |
| 184 } | |
| 185 | |
| 157 ///////////////////////////////////////////////////////////////////////////// | 186 ///////////////////////////////////////////////////////////////////////////// |
| 158 // media::DataSource implementation. | 187 // media::DataSource implementation. |
| 159 void BufferedDataSource::Read(int64 position, size_t size, uint8* data, | 188 void BufferedDataSource::Read(int64 position, size_t size, uint8* data, |
| 160 media::DataSource::ReadCallback* read_callback) { | 189 media::DataSource::ReadCallback* read_callback) { |
| 161 DCHECK(read_callback); | 190 DCHECK(read_callback); |
| 162 | 191 |
| 163 { | 192 { |
| 164 base::AutoLock auto_lock(lock_); | 193 base::AutoLock auto_lock(lock_); |
| 165 DCHECK(!read_callback_.get()); | 194 DCHECK(!read_callback_.get()); |
| 166 | 195 |
| (...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 309 return; | 338 return; |
| 310 | 339 |
| 311 { | 340 { |
| 312 // If there's no outstanding read then return early. | 341 // If there's no outstanding read then return early. |
| 313 base::AutoLock auto_lock(lock_); | 342 base::AutoLock auto_lock(lock_); |
| 314 if (!read_callback_.get()) | 343 if (!read_callback_.get()) |
| 315 return; | 344 return; |
| 316 } | 345 } |
| 317 | 346 |
| 318 loader_ = CreateResourceLoader(read_position_, kPositionNotSpecified); | 347 loader_ = CreateResourceLoader(read_position_, kPositionNotSpecified); |
| 319 loader_->SetAllowDefer(!media_is_paused_); | 348 BufferedResourceLoader::DeferStrategy strategy = ChooseDeferStrategy(); |
| 349 loader_->SetDeferStrategy(strategy); | |
| 320 loader_->Start( | 350 loader_->Start( |
| 321 NewCallback(this, &BufferedDataSource::PartialReadStartCallback), | 351 NewCallback(this, &BufferedDataSource::PartialReadStartCallback), |
| 322 NewCallback(this, &BufferedDataSource::NetworkEventCallback), | 352 NewCallback(this, &BufferedDataSource::NetworkEventCallback), |
| 323 frame_); | 353 frame_); |
| 324 } | 354 } |
| 325 | 355 |
| 326 void BufferedDataSource::WatchDogTask() { | 356 void BufferedDataSource::WatchDogTask() { |
| 327 DCHECK(MessageLoop::current() == render_loop_); | 357 DCHECK(MessageLoop::current() == render_loop_); |
| 328 if (stopped_on_render_loop_) | 358 if (stopped_on_render_loop_) |
| 329 return; | 359 return; |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 345 if (read_attempts_ >= kReadTrials) | 375 if (read_attempts_ >= kReadTrials) |
| 346 return; | 376 return; |
| 347 | 377 |
| 348 ++read_attempts_; | 378 ++read_attempts_; |
| 349 read_submitted_time_ = base::Time::Now(); | 379 read_submitted_time_ = base::Time::Now(); |
| 350 | 380 |
| 351 // Stops the current loader and creates a new resource loader and | 381 // Stops the current loader and creates a new resource loader and |
| 352 // retry the request. | 382 // retry the request. |
| 353 loader_->Stop(); | 383 loader_->Stop(); |
| 354 loader_ = CreateResourceLoader(read_position_, kPositionNotSpecified); | 384 loader_ = CreateResourceLoader(read_position_, kPositionNotSpecified); |
| 355 loader_->SetAllowDefer(!media_is_paused_); | 385 BufferedResourceLoader::DeferStrategy strategy = ChooseDeferStrategy(); |
| 386 loader_->SetDeferStrategy(strategy); | |
| 356 loader_->Start( | 387 loader_->Start( |
| 357 NewCallback(this, &BufferedDataSource::PartialReadStartCallback), | 388 NewCallback(this, &BufferedDataSource::PartialReadStartCallback), |
| 358 NewCallback(this, &BufferedDataSource::NetworkEventCallback), | 389 NewCallback(this, &BufferedDataSource::NetworkEventCallback), |
| 359 frame_); | 390 frame_); |
| 360 } | 391 } |
| 361 | 392 |
| 362 void BufferedDataSource::SetPlaybackRateTask(float playback_rate) { | 393 void BufferedDataSource::SetPlaybackRateTask(float playback_rate) { |
| 363 DCHECK(MessageLoop::current() == render_loop_); | 394 DCHECK(MessageLoop::current() == render_loop_); |
| 364 DCHECK(loader_.get()); | 395 DCHECK(loader_.get()); |
| 365 | 396 |
| 366 bool previously_paused = media_is_paused_; | 397 bool previously_paused = media_is_paused_; |
| 367 media_is_paused_ = (playback_rate == 0.0); | 398 media_is_paused_ = (playback_rate == 0.0); |
| 368 | 399 |
| 369 // Disallow deferring data when we are pausing, allow deferring data | 400 if (!media_has_played_ && previously_paused && !media_is_paused_) |
| 370 // when we resume playing. | 401 media_has_played_ = true; |
| 371 if (previously_paused && !media_is_paused_) { | 402 |
| 372 loader_->SetAllowDefer(true); | 403 BufferedResourceLoader::DeferStrategy strategy = ChooseDeferStrategy(); |
| 373 } else if (!previously_paused && media_is_paused_) { | 404 loader_->SetDeferStrategy(strategy); |
| 374 loader_->SetAllowDefer(false); | 405 loader_->UpdateDeferBehavior(); |
|
acolwell GONE FROM CHROMIUM
2011/03/25 23:08:14
SetDeferStrategy() doesn't update the behavior? Wh
vrk (LEFT CHROMIUM)
2011/03/29 00:53:00
Good idea, done!
| |
| 375 } | 406 } |
| 407 | |
| 408 void BufferedDataSource::SetPreloadTask(media::Preload preload) { | |
| 409 DCHECK(MessageLoop::current() == render_loop_); | |
| 410 preload_ = preload; | |
| 376 } | 411 } |
| 377 | 412 |
| 378 // This method is the place where actual read happens, |loader_| must be valid | 413 // This method is the place where actual read happens, |loader_| must be valid |
| 379 // prior to make this method call. | 414 // prior to make this method call. |
| 380 void BufferedDataSource::ReadInternal() { | 415 void BufferedDataSource::ReadInternal() { |
| 381 DCHECK(MessageLoop::current() == render_loop_); | 416 DCHECK(MessageLoop::current() == render_loop_); |
| 382 DCHECK(loader_); | 417 DCHECK(loader_); |
| 383 | 418 |
| 384 // First we prepare the intermediate read buffer for BufferedResourceLoader | 419 // First we prepare the intermediate read buffer for BufferedResourceLoader |
| 385 // to write to. | 420 // to write to. |
| (...skipping 269 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 655 | 690 |
| 656 if (streaming_) { | 691 if (streaming_) { |
| 657 filter_host->SetStreaming(true); | 692 filter_host->SetStreaming(true); |
| 658 } else { | 693 } else { |
| 659 filter_host->SetTotalBytes(total_bytes_); | 694 filter_host->SetTotalBytes(total_bytes_); |
| 660 filter_host->SetBufferedBytes(buffered_bytes_); | 695 filter_host->SetBufferedBytes(buffered_bytes_); |
| 661 } | 696 } |
| 662 } | 697 } |
| 663 | 698 |
| 664 } // namespace webkit_glue | 699 } // namespace webkit_glue |
| OLD | NEW |