Commit 296cd9c4 authored by Michael Niedermayer's avatar Michael Niedermayer

avformat/mpegts: Improve probe heuristic by considering the overall frequency of 0x47 headers

Fixes Ticket3939
Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent b96d864f
...@@ -511,9 +511,9 @@ static void mpegts_close_filter(MpegTSContext *ts, MpegTSFilter *filter) ...@@ -511,9 +511,9 @@ static void mpegts_close_filter(MpegTSContext *ts, MpegTSFilter *filter)
static int analyze(const uint8_t *buf, int size, int packet_size, int *index) static int analyze(const uint8_t *buf, int size, int packet_size, int *index)
{ {
int stat[TS_MAX_PACKET_SIZE]; int stat[TS_MAX_PACKET_SIZE];
int stat_all = 0;
int i; int i;
int best_score = 0; int best_score = 0;
int best_score2 = 0;
memset(stat, 0, packet_size * sizeof(*stat)); memset(stat, 0, packet_size * sizeof(*stat));
...@@ -521,17 +521,16 @@ static int analyze(const uint8_t *buf, int size, int packet_size, int *index) ...@@ -521,17 +521,16 @@ static int analyze(const uint8_t *buf, int size, int packet_size, int *index)
if (buf[i] == 0x47 && !(buf[i + 1] & 0x80) && buf[i + 3] != 0x47) { if (buf[i] == 0x47 && !(buf[i + 1] & 0x80) && buf[i + 3] != 0x47) {
int x = i % packet_size; int x = i % packet_size;
stat[x]++; stat[x]++;
stat_all++;
if (stat[x] > best_score) { if (stat[x] > best_score) {
best_score = stat[x]; best_score = stat[x];
if (index) if (index)
*index = x; *index = x;
} else if (stat[x] > best_score2) {
best_score2 = stat[x];
} }
} }
} }
return best_score - best_score2; return best_score - FFMAX(stat_all - 10*best_score, 0)/10;
} }
/* autodetect fec presence. Must have at least 1024 bytes */ /* autodetect fec presence. Must have at least 1024 bytes */
......
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