48 lines
1.5 KiB
C
48 lines
1.5 KiB
C
|
/*
|
||
|
* 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_
|