home
products
contribute
download
documentation
forum
Home
Forums
New posts
Search forums
What's new
New posts
All posts
Latest activity
Members
Registered members
Current visitors
Donate
Log in
Register
What's new
Search
Search
Search titles only
By:
New posts
Search forums
Search titles only
By:
Menu
Log in
Register
Navigation
Install the app
Install
More options
Contact us
Close Menu
Forums
MediaPortal 1
Development
General Development (no feature request here!)
MediaPortal Audio renderer - better video playback quality
Contact us
RSS
JavaScript is disabled. For a better experience, please enable JavaScript in your browser before proceeding.
You are using an out of date browser. It may not display this or other websites correctly.
You should upgrade or use an
alternative browser
.
Reply to thread
Message
<blockquote data-quote="tourettes" data-source="post: 662571" data-attributes="member: 10858"><p>davidf, something to be analyzed. As attachements two logs, one from HTPC where the drifting happens and one from the dev PC where I haven't spotted any drifting.</p><p></p><p>[code]</p><p>REFERENCE_TIME CSyncClock::GetPrivateTime()</p><p>{</p><p> CAutoLock cObjectLock(this);</p><p></p><p> UINT64 qpcNow = GetCurrentTimestamp();</p><p></p><p> DWORD dwTime = timeGetTime();</p><p></p><p> UINT64 hwClock(0);</p><p> UINT64 hwQpc(0);</p><p></p><p> UINT64 hwClockEnd(0);</p><p> UINT64 hwQpcEnd(0);</p><p></p><p> HRESULT hr = m_pAudioRenderer->AudioClock(hwClock, hwQpc);</p><p></p><p> if (hr == S_OK)</p><p> {</p><p> if (m_dStartQpcHW == 0)</p><p> m_dStartQpcHW = hwQpc;</p><p></p><p> if (m_dStartTimeHW == 0)</p><p> m_dStartTimeHW = hwClock;</p><p></p><p> if (m_dStartTimeSystem == 0)</p><p> m_dStartTimeSystem = dwTime;</p><p></p><p> if (m_dStartTimeCorrected == 0)</p><p> m_dStartTimeCorrected = m_rtPrivateTime;</p><p></p><p> m_dDurationHW = (hwClock - m_dStartTimeHW) / 10000;</p><p> m_dDurationSystem = (dwTime - m_dStartTimeSystem); </p><p> m_dDurationCorrected = (m_rtPrivateTime - m_dStartTimeCorrected) / 10000;</p><p></p><p> //if (hwQpc < m_dPrevQpcHW)</p><p> //Log("%I64d", hwQpc - m_dPrevQpcHW);</p><p></p><p> if (m_dPrevTimeHW > hwClock)</p><p> {</p><p> m_dStartTimeHW = m_dPrevTimeHW = hwClock;</p><p> m_dStartQpcHW = m_dPrevQpcHW = hwQpc;</p><p> m_dStartTimeSystem = dwTime;</p><p> m_dStartTimeCorrected = m_rtPrivateTime;</p><p> m_llDeltaError = 0;</p><p> overallCorrection = 0;</p><p> }</p><p> else</p><p> {</p><p> double clockDiff = hwClock - m_dStartTimeHW;</p><p> double qpcDiff = hwQpc - m_dStartQpcHW;</p><p></p><p> if (clockDiff > 0 && qpcDiff > 0)</p><p> m_dSystemClockMultiplier = clockDiff / qpcDiff;</p><p></p><p> if (m_dSystemClockMultiplier < 0.95 || m_dSystemClockMultiplier > 1.05)</p><p> m_dSystemClockMultiplier = 1.0;</p><p></p><p> m_dPrevTimeHW = hwClock;</p><p> m_dPrevQpcHW = hwQpc;</p><p> }</p><p> }</p><p> else</p><p> {</p><p> //Log("AudioClock() returned error (0x%08x)");</p><p> }</p><p></p><p> REFERENCE_TIME delta = REFERENCE_TIME(dwTime) - REFERENCE_TIME(m_dwPrevSystemTime);</p><p> REFERENCE_TIME deltaOrig = delta;</p><p></p><p> if (dwTime < m_dwPrevSystemTime)</p><p> {</p><p> delta += REFERENCE_TIME(UINT_MAX) + 1;</p><p> }</p><p></p><p> m_dwPrevSystemTime = dwTime;</p><p> delta = (REFERENCE_TIME)(delta * (UNITS / MILLISECONDS));</p><p> double dAdjustment;</p><p> if (m_bHWBasedRefClock)</p><p> {</p><p> dAdjustment = m_dAdjustment * m_dBias / m_dSystemClockMultiplier;</p><p> }</p><p> else</p><p> {</p><p> dAdjustment = m_dAdjustment * m_dBias;</p><p> }</p><p> double ddelta= ((double) delta)*dAdjustment;</p><p> delta = (REFERENCE_TIME) ddelta;</p><p> m_ddeltaError += ddelta - delta;</p><p> if (m_ddeltaError>1.0)</p><p> {</p><p> delta--;</p><p> m_ddeltaError-=1.0;</p><p> overallCorrection += 1.0;</p><p> }</p><p> </p><p> if (hwQpc - m_dStartQpcHW > 600000000)</p><p> {</p><p> Log("mul: %.10f de: %6I64d de.orig: %6I64d de.err: %.10f bias: %.10f adj: %.10f hwQpc: %I64d hwClock: %I64d", </p><p> m_dSystemClockMultiplier, delta, deltaOrig * 10000, m_ddeltaError, m_dBias, m_dAdjustment, hwQpc, hwClock);</p><p> }</p><p></p><p> m_rtPrivateTime = m_rtPrivateTime + delta;</p><p></p><p> return m_rtPrivateTime;</p><p>}</p><p>[/code]</p></blockquote><p></p>
[QUOTE="tourettes, post: 662571, member: 10858"] davidf, something to be analyzed. As attachements two logs, one from HTPC where the drifting happens and one from the dev PC where I haven't spotted any drifting. [code] REFERENCE_TIME CSyncClock::GetPrivateTime() { CAutoLock cObjectLock(this); UINT64 qpcNow = GetCurrentTimestamp(); DWORD dwTime = timeGetTime(); UINT64 hwClock(0); UINT64 hwQpc(0); UINT64 hwClockEnd(0); UINT64 hwQpcEnd(0); HRESULT hr = m_pAudioRenderer->AudioClock(hwClock, hwQpc); if (hr == S_OK) { if (m_dStartQpcHW == 0) m_dStartQpcHW = hwQpc; if (m_dStartTimeHW == 0) m_dStartTimeHW = hwClock; if (m_dStartTimeSystem == 0) m_dStartTimeSystem = dwTime; if (m_dStartTimeCorrected == 0) m_dStartTimeCorrected = m_rtPrivateTime; m_dDurationHW = (hwClock - m_dStartTimeHW) / 10000; m_dDurationSystem = (dwTime - m_dStartTimeSystem); m_dDurationCorrected = (m_rtPrivateTime - m_dStartTimeCorrected) / 10000; //if (hwQpc < m_dPrevQpcHW) //Log("%I64d", hwQpc - m_dPrevQpcHW); if (m_dPrevTimeHW > hwClock) { m_dStartTimeHW = m_dPrevTimeHW = hwClock; m_dStartQpcHW = m_dPrevQpcHW = hwQpc; m_dStartTimeSystem = dwTime; m_dStartTimeCorrected = m_rtPrivateTime; m_llDeltaError = 0; overallCorrection = 0; } else { double clockDiff = hwClock - m_dStartTimeHW; double qpcDiff = hwQpc - m_dStartQpcHW; if (clockDiff > 0 && qpcDiff > 0) m_dSystemClockMultiplier = clockDiff / qpcDiff; if (m_dSystemClockMultiplier < 0.95 || m_dSystemClockMultiplier > 1.05) m_dSystemClockMultiplier = 1.0; m_dPrevTimeHW = hwClock; m_dPrevQpcHW = hwQpc; } } else { //Log("AudioClock() returned error (0x%08x)"); } REFERENCE_TIME delta = REFERENCE_TIME(dwTime) - REFERENCE_TIME(m_dwPrevSystemTime); REFERENCE_TIME deltaOrig = delta; if (dwTime < m_dwPrevSystemTime) { delta += REFERENCE_TIME(UINT_MAX) + 1; } m_dwPrevSystemTime = dwTime; delta = (REFERENCE_TIME)(delta * (UNITS / MILLISECONDS)); double dAdjustment; if (m_bHWBasedRefClock) { dAdjustment = m_dAdjustment * m_dBias / m_dSystemClockMultiplier; } else { dAdjustment = m_dAdjustment * m_dBias; } double ddelta= ((double) delta)*dAdjustment; delta = (REFERENCE_TIME) ddelta; m_ddeltaError += ddelta - delta; if (m_ddeltaError>1.0) { delta--; m_ddeltaError-=1.0; overallCorrection += 1.0; } if (hwQpc - m_dStartQpcHW > 600000000) { Log("mul: %.10f de: %6I64d de.orig: %6I64d de.err: %.10f bias: %.10f adj: %.10f hwQpc: %I64d hwClock: %I64d", m_dSystemClockMultiplier, delta, deltaOrig * 10000, m_ddeltaError, m_dBias, m_dAdjustment, hwQpc, hwClock); } m_rtPrivateTime = m_rtPrivateTime + delta; return m_rtPrivateTime; } [/code] [/QUOTE]
Insert quotes…
Verification
Post reply
Forums
MediaPortal 1
Development
General Development (no feature request here!)
MediaPortal Audio renderer - better video playback quality
Contact us
RSS
Top
Bottom