diff options
-rw-r--r-- | xbmc/cores/VideoPlayer/VideoPlayer.cpp | 50 | ||||
-rw-r--r-- | xbmc/cores/VideoPlayer/VideoPlayer.h | 10 |
2 files changed, 36 insertions, 24 deletions
diff --git a/xbmc/cores/VideoPlayer/VideoPlayer.cpp b/xbmc/cores/VideoPlayer/VideoPlayer.cpp index 790edb7d20..6730a43ba2 100644 --- a/xbmc/cores/VideoPlayer/VideoPlayer.cpp +++ b/xbmc/cores/VideoPlayer/VideoPlayer.cpp @@ -1802,14 +1802,16 @@ void CVideoPlayer::ProcessAudioID3Data(CDemuxStream* pStream, DemuxPacket* pPack m_VideoPlayerAudioID3->SendMessage(std::make_shared<CDVDMsgDemuxerPacket>(pPacket, drop)); } -bool CVideoPlayer::GetCachingTimes(double& level, double& delay, double& offset) +CacheInfo CVideoPlayer::GetCachingTimes() { + CacheInfo info{}; + if (!m_pInputStream || !m_pDemuxer) - return false; + return info; XFILE::SCacheStatus status; if (!m_pInputStream->GetCacheStatus(&status)) - return false; + return info; const uint64_t& cached = status.forward; const uint32_t& currate = status.currate; @@ -1820,34 +1822,36 @@ bool CVideoPlayer::GetCachingTimes(double& level, double& delay, double& offset) int64_t remain = length - m_pInputStream->Seek(0, SEEK_CUR); if (length <= 0 || remain < 0) - return false; + return info; double play_sbp = DVD_MSEC_TO_TIME(m_pDemuxer->GetStreamLength()) / length; double queued = 1000.0 * GetQueueTime() / play_sbp; - delay = 0.0; - level = 0.0; - offset = (cached + queued) / length; + info.delay = 0.0; + info.level = 0.0; + info.offset = (cached + queued) / length; + info.valid = true; if (currate == 0) - return true; + return info; double cache_sbp = 1.1 * (double)DVD_TIME_BASE / currate; /* underestimate by 10 % */ double play_left = play_sbp * (remain + queued); /* time to play out all remaining bytes */ double cache_left = cache_sbp * (remain - cached); /* time to cache the remaining bytes */ double cache_need = std::max(0.0, remain - play_left / cache_sbp); /* bytes needed until play_left == cache_left */ - delay = cache_left - play_left; + info.delay = cache_left - play_left; if (lowrate > 0) { + // buffer is full & our read rate is too low CLog::Log(LOGDEBUG, "Readrate {} was too low with {} required", lowrate, maxrate); - level = -1.0; /* buffer is full & our read rate is too low */ + info.level = -1.0; } else - level = (cached + queued) / (cache_need + queued); + info.level = (cached + queued) / (cache_need + queued); - return true; + return info; } void CVideoPlayer::HandlePlaySpeed() @@ -1861,15 +1865,15 @@ void CVideoPlayer::HandlePlaySpeed() if (m_caching == CACHESTATE_FULL) { - double level, delay, offset; - if (GetCachingTimes(level, delay, offset)) + CacheInfo cache = GetCachingTimes(); + if (cache.valid) { - if (level < 0.0) + if (cache.level < 0.0) { CGUIDialogKaiToast::QueueNotification(g_localizeStrings.Get(21454), g_localizeStrings.Get(21455)); SetCaching(CACHESTATE_INIT); } - if (level >= 1.0) + if (cache.level >= 1.0) SetCaching(CACHESTATE_INIT); } else @@ -3068,8 +3072,8 @@ void CVideoPlayer::SetCaching(ECacheState state) { if(state == CACHESTATE_FLUSH) { - double level, delay, offset; - if(GetCachingTimes(level, delay, offset)) + CacheInfo cache = GetCachingTimes(); + if (cache.valid) state = CACHESTATE_FULL; else state = CACHESTATE_INIT; @@ -4902,12 +4906,12 @@ void CVideoPlayer::UpdatePlayState(double timeout) else state.caching = false; - double level, delay, offset; - if (GetCachingTimes(level, delay, offset)) + CacheInfo cache = GetCachingTimes(); + if (cache.valid) { - state.cache_delay = std::max(0.0, delay); - state.cache_level = std::max(0.0, std::min(1.0, level)); - state.cache_offset = offset; + state.cache_delay = std::max(0.0, cache.delay); + state.cache_level = std::max(0.0, std::min(1.0, cache.level)); + state.cache_offset = cache.offset; } else { diff --git a/xbmc/cores/VideoPlayer/VideoPlayer.h b/xbmc/cores/VideoPlayer/VideoPlayer.h index e40fb7aea6..b0373df7ac 100644 --- a/xbmc/cores/VideoPlayer/VideoPlayer.h +++ b/xbmc/cores/VideoPlayer/VideoPlayer.h @@ -237,6 +237,14 @@ protected: // main class //------------------------------------------------------------------------------ +struct CacheInfo +{ + double level; + double delay; + double offset; + bool valid; +}; + class CProcessInfo; class CJobQueue; @@ -421,7 +429,7 @@ protected: void SetCaching(ECacheState state); double GetQueueTime(); - bool GetCachingTimes(double& play_left, double& cache_left, double& file_offset); + CacheInfo GetCachingTimes(); void FlushBuffers(double pts, bool accurate, bool sync); |