diff options
author | Reimar Döffinger <Reimar.Doeffinger@gmx.de> | 2008-06-28 09:01:16 +0000 |
---|---|---|
committer | Reimar Döffinger <Reimar.Doeffinger@gmx.de> | 2008-06-28 09:01:16 +0000 |
commit | ddca6ab678bb7f4abd17b040a059b9b79630ff48 (patch) | |
tree | 0d245a475f4ef5c0029639004a8e67ed7aaa9c64 /libavformat/mtv.c | |
parent | 34bfe875d51b138abe8f5537c90d5ab2c9366312 (diff) | |
download | ffmpeg-ddca6ab678bb7f4abd17b040a059b9b79630ff48.tar.gz |
Change mtv_read_packet so it does not break after seeking (displaying a shifted image).
Originally committed as revision 14020 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/mtv.c')
-rw-r--r-- | libavformat/mtv.c | 20 |
1 files changed, 8 insertions, 12 deletions
diff --git a/libavformat/mtv.c b/libavformat/mtv.c index 7f99bd65bd..d97b9cdd85 100644 --- a/libavformat/mtv.c +++ b/libavformat/mtv.c @@ -46,9 +46,7 @@ typedef struct MTVDemuxContext { unsigned int img_height; // unsigned int img_segment_size; ///< size of image segment unsigned int video_fps; // - unsigned int audio_subsegments; ///< audio subsegments on one segment - - uint8_t audio_packet_count; + unsigned int full_segment_size; } MTVDemuxContext; @@ -67,6 +65,7 @@ static int mtv_read_header(AVFormatContext *s, AVFormatParameters *ap) MTVDemuxContext *mtv = s->priv_data; ByteIOContext *pb = s->pb; AVStream *st; + unsigned int audio_subsegments; url_fskip(pb, 3); @@ -81,15 +80,14 @@ static int mtv_read_header(AVFormatContext *s, AVFormatParameters *ap) mtv->img_height = get_le16(pb); mtv->img_segment_size = get_le16(pb); url_fskip(pb, 4); - mtv->audio_subsegments = get_le16(pb); - mtv->video_fps = (mtv->audio_br / 4) / mtv->audio_subsegments; + audio_subsegments = get_le16(pb); + mtv->full_segment_size = + audio_subsegments * (MTV_AUDIO_PADDING_SIZE + MTV_ASUBCHUNK_DATA_SIZE) + + mtv->img_segment_size; + mtv->video_fps = (mtv->audio_br / 4) / audio_subsegments; /* FIXME Add sanity check here */ - /* first packet is always audio*/ - - mtv->audio_packet_count = 1; - /* all systems go! init decoders */ /* video - raw rgb565 */ @@ -139,7 +137,7 @@ static int mtv_read_packet(AVFormatContext *s, AVPacket *pkt) ret = 0; - if(mtv->audio_subsegments >= mtv->audio_packet_count) + if((url_ftell(pb) - s->data_offset + mtv->img_segment_size) % mtv->full_segment_size) { url_fskip(pb, MTV_AUDIO_PADDING_SIZE); @@ -147,7 +145,6 @@ static int mtv_read_packet(AVFormatContext *s, AVPacket *pkt) if(ret != MTV_ASUBCHUNK_DATA_SIZE) return AVERROR(EIO); - mtv->audio_packet_count++; pkt->pos -= MTV_AUDIO_PADDING_SIZE; pkt->stream_index = AUDIO_SID; @@ -168,7 +165,6 @@ static int mtv_read_packet(AVFormatContext *s, AVPacket *pkt) for(i=0;i<mtv->img_segment_size/2;i++) *((uint16_t *)pkt->data+i) = bswap_16(*((uint16_t *)pkt->data+i)); #endif - mtv->audio_packet_count = 1; pkt->stream_index = VIDEO_SID; } |