1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
/*
* (C) 2010-2014 see Authors.txt
*
* This file is part of MPC-HC.
*
* MPC-HC is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* MPC-HC is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
#include "stdafx.h"
#include "SyncClock.h"
CSyncClockFilter::CSyncClockFilter(LPUNKNOWN pUnk, HRESULT* phr)
: CBaseFilter(NAME("SyncClock"), nullptr, &m_Lock, CLSID_NULL)
, m_Clock(static_cast<IBaseFilter*>(this), phr)
{
}
CSyncClockFilter::~CSyncClockFilter()
{
}
STDMETHODIMP CSyncClockFilter::AdjustClock(double adjustment)
{
m_Clock.adjustment = adjustment;
return S_OK;
}
STDMETHODIMP CSyncClockFilter::SetBias(double bias)
{
m_Clock.bias = bias;
return S_OK;
}
STDMETHODIMP CSyncClockFilter::GetBias(double* bias)
{
*bias = m_Clock.bias;
return S_OK;
}
STDMETHODIMP CSyncClockFilter::GetStartTime(REFERENCE_TIME* startTime)
{
*startTime = m_tStart;
return S_OK;
}
STDMETHODIMP CSyncClockFilter::NonDelegatingQueryInterface(REFIID riid, void** ppv)
{
CheckPointer(ppv, E_POINTER);
if (riid == IID_IReferenceClock) {
return GetInterface(static_cast<IReferenceClock*>(&m_Clock), ppv);
} else if (riid == IID_ISyncClock) {
return GetInterface(static_cast<ISyncClock*>(this), ppv);
} else {
return CBaseFilter::NonDelegatingQueryInterface(riid, ppv);
}
}
int CSyncClockFilter::GetPinCount()
{
return 0;
}
CBasePin* CSyncClockFilter::GetPin(int i)
{
UNREFERENCED_PARAMETER(i);
return nullptr;
}
// CSyncClock methods
CSyncClock::CSyncClock(LPUNKNOWN pUnk, HRESULT* phr)
: CBaseReferenceClock(NAME("SyncClock"), pUnk, phr)
, adjustment(1.0)
, bias(1.0)
, m_rtPrivateTime(GetTicks100ns())
, m_llPerfFrequency(0)
, m_rtPrevTime(m_rtPrivateTime)
, m_pCurrentRefClock(0)
, m_pPrevRefClock(0)
{
QueryPerformanceFrequency((LARGE_INTEGER*)&m_llPerfFrequency);
}
REFERENCE_TIME CSyncClock::GetPrivateTime()
{
CAutoLock cObjectLock(this);
REFERENCE_TIME rtTime = GetTicks100ns();
REFERENCE_TIME delta = rtTime - m_rtPrevTime;
// We ignore that rtTime may wrap around. Not gonna happen too often
m_rtPrevTime = rtTime;
delta = (REFERENCE_TIME)((double)delta * adjustment * bias);
m_rtPrivateTime = m_rtPrivateTime + delta;
return m_rtPrivateTime;
}
REFERENCE_TIME CSyncClock::GetTicks100ns()
{
LONGLONG i64Ticks100ns;
if (m_llPerfFrequency != 0) {
QueryPerformanceCounter((LARGE_INTEGER*)&i64Ticks100ns);
i64Ticks100ns = LONGLONG((double(i64Ticks100ns) * 10000000) / double(m_llPerfFrequency) + 0.5);
return (REFERENCE_TIME)i64Ticks100ns;
}
return 0;
}
|