Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/blink/multibuffer_data_source.h" | 5 #include "media/blink/multibuffer_data_source.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/callback_helpers.h" | 10 #include "base/callback_helpers.h" |
| (...skipping 549 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 560 // magnitude and clamp to prevent overflow. | 560 // magnitude and clamp to prevent overflow. |
| 561 double playback_rate = playback_rate_; | 561 double playback_rate = playback_rate_; |
| 562 | 562 |
| 563 playback_rate = std::max(playback_rate, 1.0); | 563 playback_rate = std::max(playback_rate, 1.0); |
| 564 playback_rate = std::min(playback_rate, kMaxPlaybackRate); | 564 playback_rate = std::min(playback_rate, kMaxPlaybackRate); |
| 565 | 565 |
| 566 int64_t bytes_per_second = (bitrate / 8.0) * playback_rate; | 566 int64_t bytes_per_second = (bitrate / 8.0) * playback_rate; |
| 567 | 567 |
| 568 int64_t preload = clamp(kTargetSecondsBufferedAhead * bytes_per_second, | 568 int64_t preload = clamp(kTargetSecondsBufferedAhead * bytes_per_second, |
| 569 kMinBufferPreload, kMaxBufferPreload); | 569 kMinBufferPreload, kMaxBufferPreload); |
| 570 int64_t preload_high = preload + kPreloadHighExtra; | |
| 570 int64_t back_buffer = clamp(kTargetSecondsBufferedBehind * bytes_per_second, | 571 int64_t back_buffer = clamp(kTargetSecondsBufferedBehind * bytes_per_second, |
| 571 kMinBufferPreload, kMaxBufferPreload); | 572 kMinBufferPreload, kMaxBufferSize - preload_high); |
|
DaleCurtis
2016/05/04 21:39:32
Seems like the subtraction could go negative?
hubbe
2016/05/04 21:55:06
Adding a static assert to make sure it cannot.
| |
| 572 int64_t pin_forwards = kMaxBufferSize - back_buffer; | 573 int64_t buffer_size = |
| 573 DCHECK_LE(preload + kPreloadHighExtra, pin_forwards); | 574 std::min((kTargetSecondsBufferedAhead + kTargetSecondsBufferedBehind) * |
| 574 reader_->SetMaxBuffer(back_buffer, preload + kPreloadHighExtra); | 575 bytes_per_second, |
| 576 kMaxBufferSize); | |
| 577 reader_->SetMaxBuffer(buffer_size); | |
| 578 reader_->SetPinRange(back_buffer, kMaxBufferPreload); | |
| 575 | 579 |
| 576 if (preload_ == METADATA) { | 580 if (preload_ == METADATA) { |
| 577 reader_->SetPreload(0, 0); | 581 reader_->SetPreload(0, 0); |
| 578 } else { | 582 } else { |
| 579 reader_->SetPreload(preload + kPreloadHighExtra, preload); | 583 reader_->SetPreload(preload_high, preload); |
| 580 } | 584 } |
| 581 } | 585 } |
| 582 | 586 |
| 583 } // namespace media | 587 } // namespace media |
| OLD | NEW |