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

Side by Side Diff: media/base/wall_clock_time_source.cc

Issue 1160853006: Improve audio/video sync during underflow, reduce underflow frequency. (Closed) Base URL: http://chromium.googlesource.com/chromium/src.git@master
Patch Set: Comments. Created 5 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
« no previous file with comments | « media/base/wall_clock_time_source.h ('k') | media/base/wall_clock_time_source_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/wall_clock_time_source.h" 5 #include "media/base/wall_clock_time_source.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 8
9 namespace media { 9 namespace media {
10 10
11 WallClockTimeSource::WallClockTimeSource() 11 WallClockTimeSource::WallClockTimeSource()
12 : tick_clock_(&default_tick_clock_), ticking_(false), playback_rate_(1.0) { 12 : tick_clock_(&default_tick_clock_), ticking_(false), playback_rate_(1.0) {
13 } 13 }
14 14
15 WallClockTimeSource::~WallClockTimeSource() { 15 WallClockTimeSource::~WallClockTimeSource() {
16 } 16 }
17 17
18 void WallClockTimeSource::StartTicking() { 18 void WallClockTimeSource::StartTicking() {
19 DVLOG(1) << __FUNCTION__; 19 DVLOG(1) << __FUNCTION__;
20 base::AutoLock auto_lock(lock_); 20 base::AutoLock auto_lock(lock_);
21 DCHECK(!ticking_); 21 DCHECK(!ticking_);
22 ticking_ = true; 22 ticking_ = true;
23 reference_wall_ticks_ = tick_clock_->NowTicks(); 23 reference_time_ = tick_clock_->NowTicks();
24 } 24 }
25 25
26 void WallClockTimeSource::StopTicking() { 26 void WallClockTimeSource::StopTicking() {
27 DVLOG(1) << __FUNCTION__; 27 DVLOG(1) << __FUNCTION__;
28 base::AutoLock auto_lock(lock_); 28 base::AutoLock auto_lock(lock_);
29 DCHECK(ticking_); 29 DCHECK(ticking_);
30 base_time_ = CurrentMediaTime_Locked(); 30 base_timestamp_ = CurrentMediaTime_Locked();
31 ticking_ = false; 31 ticking_ = false;
32 reference_wall_ticks_ = tick_clock_->NowTicks(); 32 reference_time_ = tick_clock_->NowTicks();
33 } 33 }
34 34
35 void WallClockTimeSource::SetPlaybackRate(double playback_rate) { 35 void WallClockTimeSource::SetPlaybackRate(double playback_rate) {
36 DVLOG(1) << __FUNCTION__ << "(" << playback_rate << ")"; 36 DVLOG(1) << __FUNCTION__ << "(" << playback_rate << ")";
37 base::AutoLock auto_lock(lock_); 37 base::AutoLock auto_lock(lock_);
38 // Estimate current media time using old rate to use as a new base time for 38 // Estimate current media time using old rate to use as a new base time for
39 // the new rate. 39 // the new rate.
40 if (ticking_) { 40 if (ticking_) {
41 base_time_ = CurrentMediaTime_Locked(); 41 base_timestamp_ = CurrentMediaTime_Locked();
42 reference_wall_ticks_ = tick_clock_->NowTicks(); 42 reference_time_ = tick_clock_->NowTicks();
43 } 43 }
44 44
45 playback_rate_ = playback_rate; 45 playback_rate_ = playback_rate;
46 } 46 }
47 47
48 void WallClockTimeSource::SetMediaTime(base::TimeDelta time) { 48 void WallClockTimeSource::SetMediaTime(base::TimeDelta time) {
49 DVLOG(1) << __FUNCTION__ << "(" << time.InMicroseconds() << ")"; 49 DVLOG(1) << __FUNCTION__ << "(" << time.InMicroseconds() << ")";
50 base::AutoLock auto_lock(lock_); 50 base::AutoLock auto_lock(lock_);
51 CHECK(!ticking_); 51 CHECK(!ticking_);
52 base_time_ = time; 52 base_timestamp_ = time;
53 } 53 }
54 54
55 base::TimeDelta WallClockTimeSource::CurrentMediaTime() { 55 base::TimeDelta WallClockTimeSource::CurrentMediaTime() {
56 base::AutoLock auto_lock(lock_); 56 base::AutoLock auto_lock(lock_);
57 return CurrentMediaTime_Locked(); 57 return CurrentMediaTime_Locked();
58 } 58 }
59 59
60 bool WallClockTimeSource::GetWallClockTimes( 60 bool WallClockTimeSource::GetWallClockTimes(
61 const std::vector<base::TimeDelta>& media_timestamps, 61 const std::vector<base::TimeDelta>& media_timestamps,
62 std::vector<base::TimeTicks>* wall_clock_times) { 62 std::vector<base::TimeTicks>* wall_clock_times) {
63 base::AutoLock auto_lock(lock_); 63 base::AutoLock auto_lock(lock_);
64 if (!ticking_ || !playback_rate_) 64 DCHECK(wall_clock_times->empty());
65 return false;
66 65
67 DCHECK(wall_clock_times->empty()); 66 if (media_timestamps.empty()) {
68 wall_clock_times->reserve(media_timestamps.size()); 67 wall_clock_times->push_back(reference_time_);
69 for (const auto& media_timestamp : media_timestamps) { 68 } else {
70 wall_clock_times->push_back( 69 // When playback is paused (rate is zero), assume a rate of 1.0.
71 reference_wall_ticks_ + 70 const double playback_rate = playback_rate_ ? playback_rate_ : 1.0;
72 base::TimeDelta::FromMicroseconds( 71
73 (media_timestamp - base_time_).InMicroseconds() / playback_rate_)); 72 wall_clock_times->reserve(media_timestamps.size());
73 for (const auto& media_timestamp : media_timestamps) {
74 wall_clock_times->push_back(reference_time_ +
75 (media_timestamp - base_timestamp_) /
76 playback_rate);
77 }
74 } 78 }
75 return true; 79
80 return playback_rate_ && ticking_;
76 } 81 }
77 82
78 base::TimeDelta WallClockTimeSource::CurrentMediaTime_Locked() { 83 base::TimeDelta WallClockTimeSource::CurrentMediaTime_Locked() {
79 lock_.AssertAcquired(); 84 lock_.AssertAcquired();
80 if (!ticking_ || !playback_rate_) 85 if (!ticking_ || !playback_rate_)
81 return base_time_; 86 return base_timestamp_;
82 87
83 base::TimeTicks now = tick_clock_->NowTicks(); 88 base::TimeTicks now = tick_clock_->NowTicks();
84 return base_time_ + 89 return base_timestamp_ +
85 base::TimeDelta::FromMicroseconds( 90 base::TimeDelta::FromMicroseconds(
86 (now - reference_wall_ticks_).InMicroseconds() * playback_rate_); 91 (now - reference_time_).InMicroseconds() * playback_rate_);
87 } 92 }
88 93
89 } // namespace media 94 } // namespace media
OLDNEW
« no previous file with comments | « media/base/wall_clock_time_source.h ('k') | media/base/wall_clock_time_source_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698