aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/wav.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2006-06-28 10:51:56 +0000
committerMichael Niedermayer <michaelni@gmx.at>2006-06-28 10:51:56 +0000
commitb582d7ba4dc8d774fbeab0f5ae9b5aae66d9a4de (patch)
tree095e32f1c558fb9d235ed8755ff8a07cd9dc25f3 /libavformat/wav.c
parente71bcc37986c7bd7f31c93e2cee3ddd18b4e9416 (diff)
downloadffmpeg-b582d7ba4dc8d774fbeab0f5ae9b5aae66d9a4de.tar.gz
dont read over the end of a data chunk and at the end search for the next
Originally committed as revision 5537 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/wav.c')
-rw-r--r--libavformat/wav.c18
1 files changed, 16 insertions, 2 deletions
diff --git a/libavformat/wav.c b/libavformat/wav.c
index 2b215c4b2b..b53cee133a 100644
--- a/libavformat/wav.c
+++ b/libavformat/wav.c
@@ -203,6 +203,7 @@ int wav_codec_get_id(unsigned int tag, int bps)
#ifdef CONFIG_MUXERS
typedef struct {
offset_t data;
+ offset_t data_end;
} WAVContext;
static int wav_write_header(AVFormatContext *s)
@@ -304,6 +305,7 @@ static int wav_read_header(AVFormatContext *s,
unsigned int tag;
ByteIOContext *pb = &s->pb;
AVStream *st;
+ WAVContext *wav = s->priv_data;
/* check RIFF header */
tag = get_le32(pb);
@@ -331,6 +333,7 @@ static int wav_read_header(AVFormatContext *s,
size = find_tag(pb, MKTAG('d', 'a', 't', 'a'));
if (size < 0)
return -1;
+ wav->data_end= url_ftell(pb) + size;
return 0;
}
@@ -339,19 +342,30 @@ static int wav_read_header(AVFormatContext *s,
static int wav_read_packet(AVFormatContext *s,
AVPacket *pkt)
{
- int ret, size;
+ int ret, size, left;
AVStream *st;
+ WAVContext *wav = s->priv_data;
if (url_feof(&s->pb))
return AVERROR_IO;
st = s->streams[0];
+ left= wav->data_end - url_ftell(&s->pb);
+ if(left <= 0){
+ left = find_tag(&(s->pb), MKTAG('d', 'a', 't', 'a'));
+ if (left < 0) {
+ return AVERROR_IO;
+ }
+ wav->data_end= url_ftell(&s->pb) + left;
+ }
+
size = MAX_SIZE;
if (st->codec->block_align > 1) {
if (size < st->codec->block_align)
size = st->codec->block_align;
size = (size / st->codec->block_align) * st->codec->block_align;
}
+ size= FFMIN(size, left);
if (av_new_packet(pkt, size))
return AVERROR_IO;
pkt->stream_index = 0;
@@ -393,7 +407,7 @@ static int wav_read_seek(AVFormatContext *s,
static AVInputFormat wav_iformat = {
"wav",
"wav format",
- 0,
+ sizeof(WAVContext),
wav_probe,
wav_read_header,
wav_read_packet,