diff options
author | Klaus Schmidinger <vdr@tvdr.de> | 2011-06-11 11:40:18 +0200 |
---|---|---|
committer | Klaus Schmidinger <vdr@tvdr.de> | 2011-06-11 11:40:18 +0200 |
commit | c90e87d71f9fba5e6fb92700d70c0ca7664c4289 (patch) | |
tree | a75959c95ffa8c8e4fe95ef5e4a602a9039ad0cc | |
parent | b226ab46d6de31746665997fe79c165521e793af (diff) | |
download | vdr-c90e87d71f9fba5e6fb92700d70c0ca7664c4289.tar.gz vdr-c90e87d71f9fba5e6fb92700d70c0ca7664c4289.tar.bz2 |
The frame detector now only starts collecting PTS values after it has seen the first I-frame
-rw-r--r-- | CONTRIBUTORS | 2 | ||||
-rw-r--r-- | HISTORY | 3 | ||||
-rw-r--r-- | 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 <frostworks@gmx.de> for adding cRecordingInfo::GetEvent() @@ -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). @@ -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) { |