Commit e01b19de authored by Michael Niedermayer's avatar Michael Niedermayer

avformat/mpegts: Fix probing of mpegts with invalid ASC

Fixes Ticket5566
Signed-off-by: 's avatarMichael Niedermayer <michael@niedermayer.cc>
parent a2e6c785
...@@ -542,13 +542,16 @@ static int analyze(const uint8_t *buf, int size, int packet_size, ...@@ -542,13 +542,16 @@ static int analyze(const uint8_t *buf, int size, int packet_size,
memset(stat, 0, packet_size * sizeof(*stat)); memset(stat, 0, packet_size * sizeof(*stat));
for (i = 0; i < size - 3; i++) { for (i = 0; i < size - 3; i++) {
if (buf[i] == 0x47 && if (buf[i] == 0x47) {
(!probe || (buf[i + 3] & 0x30))) { int pid = AV_RB16(buf+1) & 0x1FFF;
int x = i % packet_size; int asc = buf[i + 3] & 0x30;
stat[x]++; if (!probe || pid == 0x1FFF || asc) {
stat_all++; int x = i % packet_size;
if (stat[x] > best_score) { stat[x]++;
best_score = stat[x]; stat_all++;
if (stat[x] > best_score) {
best_score = stat[x];
}
} }
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment