diff options
author | Janne Grunau <janne-libav@jannau.net> | 2011-10-27 17:41:40 +0200 |
---|---|---|
committer | Janne Grunau <janne-libav@jannau.net> | 2011-10-27 18:47:34 +0200 |
commit | cf543c6574faa196bb7d2f04f2811269e9ec50c0 (patch) | |
tree | 4ccc162dcf07fae66008508437a6bfbf22920074 | |
parent | c4b97fbdfabb9d252a13c9c1f7bc8e1c2e9e43c5 (diff) | |
download | ffmpeg-cf543c6574faa196bb7d2f04f2811269e9ec50c0.tar.gz |
iv8: assemble packets to return complete frames
-rw-r--r-- | libavformat/iv8.c | 71 |
1 files changed, 47 insertions, 24 deletions
diff --git a/libavformat/iv8.c b/libavformat/iv8.c index c1ddd0fdb7..d036636f6b 100644 --- a/libavformat/iv8.c +++ b/libavformat/iv8.c @@ -55,33 +55,56 @@ static int read_header(AVFormatContext *s, AVFormatParameters *ap) static int read_packet(AVFormatContext *s, AVPacket *pkt) { - int ret, size, pts, type; -retry: - type= avio_rb16(s->pb); // 257 or 258 - size= avio_rb16(s->pb); - - avio_rb16(s->pb); //some flags, 0x80 indicates end of frame - avio_rb16(s->pb); //packet number - pts=avio_rb32(s->pb); - avio_rb32(s->pb); //6A 13 E3 88 - - size -= 12; - if(size<1) - return -1; - - if(type==258){ - avio_skip(s->pb, size); - goto retry; + int ret, size, pts, type, flags; + int first_pkt = 0; + int frame_complete = 0; + + while (!frame_complete) { + + type = avio_rb16(s->pb); // 257 or 258 + size = avio_rb16(s->pb); + flags = avio_rb16(s->pb); //some flags, 0x80 indicates end of frame + avio_rb16(s->pb); //packet number + pts = avio_rb32(s->pb); + avio_rb32(s->pb); //6A 13 E3 88 + + frame_complete = flags & 0x80; + + size -= 12; + if (size < 1) + return -1; + + if (type == 258) { + avio_skip(s->pb, size); + frame_complete = 0; + continue; + } + + if (!first_pkt) { + ret = av_get_packet(s->pb, pkt, size); + if (ret < 0) + return ret; + first_pkt = 1; + pkt->pts = pts; + pkt->pos -= 16; + } else { + ret = av_append_packet(s->pb, pkt, size); + if (ret < 0) { + av_log(s, AV_LOG_ERROR, "failed to grow packet\n"); + av_free_packet(pkt); + return ret; + } + } + if (ret < size) { + av_log(s, AV_LOG_ERROR, "Truncated packet! Read %d of %d bytes\n", + ret, size); + pkt->flags |= AV_PKT_FLAG_CORRUPT; + break; + } } - - ret= av_get_packet(s->pb, pkt, size); - - pkt->pts= pts; - pkt->pos-=16; - pkt->stream_index = 0; - return ret; + return 0; } AVInputFormat ff_iv8_demuxer = { |