}
void WallClockTimeSource::StartTicking() {
+ DVLOG(1) << __FUNCTION__;
+ base::AutoLock auto_lock(lock_);
DCHECK(!ticking_);
ticking_ = true;
reference_wall_ticks_ = tick_clock_->NowTicks();
}
void WallClockTimeSource::StopTicking() {
+ DVLOG(1) << __FUNCTION__;
+ base::AutoLock auto_lock(lock_);
DCHECK(ticking_);
- base_time_ = CurrentMediaTime();
+ base_time_ = CurrentMediaTime_Locked();
ticking_ = false;
reference_wall_ticks_ = tick_clock_->NowTicks();
}
void WallClockTimeSource::SetPlaybackRate(float playback_rate) {
+ DVLOG(1) << __FUNCTION__ << "(" << playback_rate << ")";
+ base::AutoLock auto_lock(lock_);
// Estimate current media time using old rate to use as a new base time for
// the new rate.
if (ticking_) {
- base_time_ = CurrentMediaTime();
+ base_time_ = CurrentMediaTime_Locked();
reference_wall_ticks_ = tick_clock_->NowTicks();
}
}
void WallClockTimeSource::SetMediaTime(base::TimeDelta time) {
+ DVLOG(1) << __FUNCTION__ << "(" << time.InMicroseconds() << ")";
+ base::AutoLock auto_lock(lock_);
CHECK(!ticking_);
base_time_ = time;
}
base::TimeDelta WallClockTimeSource::CurrentMediaTime() {
+ base::AutoLock auto_lock(lock_);
+ return CurrentMediaTime_Locked();
+}
+
+base::TimeDelta WallClockTimeSource::CurrentMediaTimeForSyncingVideo() {
+ return CurrentMediaTime();
+}
+
+void WallClockTimeSource::SetTickClockForTesting(
+ scoped_ptr<base::TickClock> tick_clock) {
+ tick_clock_.swap(tick_clock);
+}
+
+base::TimeDelta WallClockTimeSource::CurrentMediaTime_Locked() {
+ lock_.AssertAcquired();
if (!ticking_)
return base_time_;
(now - reference_wall_ticks_).InMicroseconds() * playback_rate_);
}
-void WallClockTimeSource::SetTickClockForTesting(
- scoped_ptr<base::TickClock> tick_clock) {
- tick_clock_.swap(tick_clock);
-}
-
} // namespace media