From dc4ed3b14158b5b0a1e12f3e05119906523f2fc2 Mon Sep 17 00:00:00 2001 From: =?utf8?q?M=C3=A5ns=20Rullg=C3=A5rd?= Date: Mon, 5 Jun 2006 22:41:14 +0000 Subject: [PATCH] probe for mpeg audio Originally committed as revision 5457 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavformat/mp3.c | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/libavformat/mp3.c b/libavformat/mp3.c index f09bfeb..37bb325 100644 --- a/libavformat/mp3.c +++ b/libavformat/mp3.c @@ -240,6 +240,32 @@ static void id3_create_tag(AVFormatContext *s, uint8_t *buf) } /* mp3 read */ + +static int mp3_read_probe(AVProbeData *p) +{ + int d; + + if(p->buf_size < 4) + return 0; + + if(p->buf[0] == 'I' && p->buf[1] == 'D' && p->buf[2] == '3' && + p->buf[3] < 5) + return AVPROBE_SCORE_MAX; + + if(p->buf[0] != 0xff) + return 0; + + d = p->buf[1]; + if((d & 0xe0) != 0xe0 || ((d & 0x18) == 0x08 || (d & 0x06) == 0)) + return 0; + + d = p->buf[2]; + if((d & 0xf0) == 0xf0 || (d & 0x0c) == 0x0c) + return 0; + + return AVPROBE_SCORE_MAX; +} + static int mp3_read_header(AVFormatContext *s, AVFormatParameters *ap) { @@ -346,7 +372,7 @@ AVInputFormat mp3_iformat = { "mp3", "MPEG audio", 0, - NULL, + mp3_read_probe, mp3_read_header, mp3_read_packet, mp3_read_close, -- 2.7.4