blob: e2674d90cae4051b732bb4ab513eb87e42a2b6bd [file] [log] [blame]
/*
* Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
// The TimeScheduler class keeps track of periodic events. It is non-drifting
// and keeps track of any missed periods so that it is possible to catch up.
// (compare to a metronome)
#ifndef WEBRTC_MODULES_AUDIO_CONFERENCE_MIXER_SOURCE_TIME_SCHEDULER_H_
#define WEBRTC_MODULES_AUDIO_CONFERENCE_MIXER_SOURCE_TIME_SCHEDULER_H_
#include "tick_util.h"
namespace webrtc {
class CriticalSectionWrapper;
class TimeScheduler
{
public:
TimeScheduler(const WebRtc_UWord32 periodicityInMs);
~TimeScheduler();
// Signal that a periodic event has been triggered.
WebRtc_Word32 UpdateScheduler();
// Set updateTimeInMs to the amount of time until UpdateScheduler() should
// be called. This time will never be negative.
WebRtc_Word32 TimeToNextUpdate(WebRtc_Word32& updateTimeInMS) const;
private:
CriticalSectionWrapper* _crit;
bool _isStarted;
TickTime _lastPeriodMark;
WebRtc_UWord32 _periodicityInMs;
WebRtc_Word64 _periodicityInTicks;
WebRtc_UWord32 _missedPeriods;
};
} // namespace webrtc
#endif // WEBRTC_MODULES_AUDIO_CONFERENCE_MIXER_SOURCE_TIME_SCHEDULER_H_