Commit e621a98b authored by jbr's avatar jbr

improve ac3_probe by counting consecutive frames

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@8441 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent ee09800c
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/ */
#include "avformat.h" #include "avformat.h"
#include "ac3.h"
#ifdef CONFIG_MUXERS #ifdef CONFIG_MUXERS
/* simple formats */ /* simple formats */
...@@ -408,18 +409,33 @@ static int h261_probe(AVProbeData *p) ...@@ -408,18 +409,33 @@ static int h261_probe(AVProbeData *p)
static int ac3_probe(AVProbeData *p) static int ac3_probe(AVProbeData *p)
{ {
int score=0; int max_frames, first_frames, frames;
uint8_t *buf, *buf2, *end;
AC3HeaderInfo hdr;
if(p->buf_size < 6) if(p->buf_size < 7)
return 0; return 0;
if((p->buf[0] == 0x0B) && (p->buf[1] == 0x77) && // sync word max_frames = 0;
((p->buf[4] >> 6) != 3) && // fscod buf = p->buf;
((p->buf[5] >> 3) <= 16)) { // bsid end = buf + FFMIN(4096, p->buf_size - 7);
score = AVPROBE_SCORE_MAX / 2 + 10;
} for(; buf < end; buf++) {
buf2 = buf;
return score; for(frames = 0; buf2 < end; frames++) {
if(ff_ac3_parse_header(buf2, &hdr) < 0)
break;
buf2 += hdr.frame_size;
}
max_frames = FFMAX(max_frames, frames);
if(buf == p->buf)
first_frames = frames;
}
if (first_frames>=3) return AVPROBE_SCORE_MAX * 3 / 4;
else if(max_frames>=3) return AVPROBE_SCORE_MAX / 2;
else if(max_frames>=1) return 1;
else return 0;
} }
AVInputFormat shorten_demuxer = { AVInputFormat shorten_demuxer = {
......
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