From a959f0ea7a2c27e38f26bdb526d7b4c49cc37f86 Mon Sep 17 00:00:00 2001 From: Baptiste Coudurier Date: Mon, 15 May 2006 12:38:33 +0000 Subject: fix pcm_s24be demuxing, simplify Originally committed as revision 5381 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavformat/aiff.c | 23 +++-------------------- 1 file changed, 3 insertions(+), 20 deletions(-) diff --git a/libavformat/aiff.c b/libavformat/aiff.c index adf4be7f2f..00dc7c12b7 100644 --- a/libavformat/aiff.c +++ b/libavformat/aiff.c @@ -399,37 +399,20 @@ got_sound: static int aiff_read_packet(AVFormatContext *s, AVPacket *pkt) { - offset_t pos; - int res, size; + AVStream *st = s->streams[0]; + int res; /* End of stream may be reached */ if (url_feof(&s->pb)) return AVERROR_IO; - /* Need to know if reached the end sound data */ - size = MAX_SIZE; - if (s->file_size) { - pos = url_ftell (&s->pb) - s->file_size; - if (pos >= s->file_size) - size = 0; - else if (pos + MAX_SIZE >= s->file_size) - size = s->file_size - pos; - } - /* Now for that packet */ - res = av_get_packet (&s->pb, pkt, MAX_SIZE); + res = av_get_packet(&s->pb, pkt, (MAX_SIZE / st->codec->block_align) * st->codec->block_align); if (res < 0) return res; /* Only one stream in an AIFF file */ pkt->stream_index = 0; - - /* Finaly fix the read to a block */ - if (size <= res) - pkt->size = size - (size % s->streams[0]->codec->block_align); - else - pkt->size = res - (res % s->streams[0]->codec->block_align); - return 0; } -- cgit v1.2.3