From c90e87d71f9fba5e6fb92700d70c0ca7664c4289 Mon Sep 17 00:00:00 2001 From: Klaus Schmidinger Date: Sat, 11 Jun 2011 11:40:18 +0200 Subject: [PATCH] The frame detector now only starts collecting PTS values after it has seen the first I-frame --- CONTRIBUTORS | 2 ++ HISTORY | 3 +++ remux.c | 4 ++-- 3 files changed, 7 insertions(+), 2 deletions(-) diff --git a/CONTRIBUTORS b/CONTRIBUTORS index 5abb1085..2bc2eb83 100644 --- a/CONTRIBUTORS +++ b/CONTRIBUTORS @@ -2572,6 +2572,8 @@ Derek Kelly (user.vdr@gmail.com) for reporting a problem where the frame rate was not detected correctly for testing the implementation of FE_CAN_TURBO_FEC for reporting unjustified log entries about changed channel pids + for reporting a problem with the frame detector in case it gets MaxPtsValues values + and stops analyzing even though the incoming data is still garbage Marcel Unbehaun for adding cRecordingInfo::GetEvent() diff --git a/HISTORY b/HISTORY index c65c0e0f..5064596e 100644 --- a/HISTORY +++ b/HISTORY @@ -6634,3 +6634,6 @@ Video Disk Recorder Revision History channel is being received with. - Fixed detecting frames in case the Picture Start Code or Access Unit Delimiter extends over TS packet boundaries (reported by Johan Andersson). +- The frame detector now only starts collecting PTS values after it has seen the + first I-frame, otherwise it might get MaxPtsValues values and stop analyzing + even though the incoming data is still garbage (reported by Derek Kelly). diff --git a/remux.c b/remux.c index a62c36cd..a6c3c25e 100644 --- a/remux.c +++ b/remux.c @@ -4,7 +4,7 @@ * See the main source file 'vdr.c' for copyright information and * how to reach the author. * - * $Id: remux.c 2.54 2011/06/11 11:20:06 kls Exp $ + * $Id: remux.c 2.55 2011/06/11 11:35:18 kls Exp $ */ #include "remux.h" @@ -840,7 +840,7 @@ int cFrameDetector::Analyze(const uchar *Data, int Length) // frame rate unknown, so collect a sequence of PTS values: if (numPtsValues < MaxPtsValues && numIFrames < 2) { // collect a sequence containing at least two I-frames const uchar *Pes = Data + TsPayloadOffset(Data); - if (PesHasPts(Pes)) { + if (numIFrames && PesHasPts(Pes)) { ptsValues[numPtsValues] = PesGetPts(Pes); // check for rollover: if (numPtsValues && ptsValues[numPtsValues - 1] > 0xF0000000 && ptsValues[numPtsValues] < 0x10000000) {