aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJindrich Makovicka <makovick@gmail.com>2011-06-30 09:03:15 +0000
committerAnton Khirnov <anton@khirnov.net>2011-09-11 12:32:56 +0200
commite308a91c9cf3d93188cd30fc5ec7ef2ce0fbfc45 (patch)
treeb8295bfccebb7df975553fa88993a554fb3d6d2c
parent207db36a4fa234f6d5123601cceb96f261588fb7 (diff)
downloadffmpeg-e308a91c9cf3d93188cd30fc5ec7ef2ce0fbfc45.tar.gz
mpegts: fix Continuity Counter error detection
According to MPEG-TS specs, the continuity_counter shall not be incremented when the adaptation_field_control of the packet equals '00' or '10'. Signed-off-by: Jindrich Makovicka <jindrich.makovicka@nangu.tv> Signed-off-by: Anton Khirnov <anton@khirnov.net> (cherry picked from commit 8923cfa328e8eb565aebcfe8672b276fd1c19bf7) Signed-off-by: Anton Khirnov <anton@khirnov.net>
-rw-r--r--libavformat/mpegts.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/libavformat/mpegts.c b/libavformat/mpegts.c
index e9b8b3513a..608cbe710f 100644
--- a/libavformat/mpegts.c
+++ b/libavformat/mpegts.c
@@ -1247,7 +1247,7 @@ static int handle_packet(MpegTSContext *ts, const uint8_t *packet)
{
AVFormatContext *s = ts->stream;
MpegTSFilter *tss;
- int len, pid, cc, cc_ok, afc, is_start;
+ int len, pid, cc, expected_cc, cc_ok, afc, is_start;
const uint8_t *p, *p_end;
int64_t pos;
@@ -1265,7 +1265,8 @@ static int handle_packet(MpegTSContext *ts, const uint8_t *packet)
/* continuity check (currently not used) */
cc = (packet[3] & 0xf);
- cc_ok = (tss->last_cc < 0) || ((((tss->last_cc + 1) & 0x0f) == cc));
+ expected_cc = (packet[3] & 0x10) ? (tss->last_cc + 1) & 0x0f : tss->last_cc;
+ cc_ok = (tss->last_cc < 0) || (expected_cc == cc);
tss->last_cc = cc;
/* skip adaptation field */