[SCM] libav/experimental: DV: use data_offset to fix seeking in badly cut files where the first complete frame does not start at position 0.

siretart at users.alioth.debian.org siretart at users.alioth.debian.org
Sun Jun 30 17:19:28 UTC 2013


The following commit has been merged in the experimental branch:
commit fe9d2edbdbceed1c1328a5f65f3b3ce29f679b4f
Author: Reimar Döffinger <Reimar.Doeffinger at gmx.de>
Date:   Sat Nov 27 14:40:12 2010 +0000

    DV: use data_offset to fix seeking in badly cut files where the first
    complete frame does not start at position 0.
    
    Originally committed as revision 25833 to svn://svn.ffmpeg.org/ffmpeg/trunk

diff --git a/libavformat/dv.c b/libavformat/dv.c
index b6f9c6a..d7f54d6 100644
--- a/libavformat/dv.c
+++ b/libavformat/dv.c
@@ -370,7 +370,7 @@ static int64_t dv_frame_offset(AVFormatContext *s, DVDemuxContext *c,
     // FIXME: sys may be wrong if last dv_read_packet() failed (buffer is junk)
     const DVprofile* sys = ff_dv_codec_profile(c->vst->codec);
     int64_t offset;
-    int64_t size = url_fsize(s->pb);
+    int64_t size = url_fsize(s->pb) - s->data_offset;
     int64_t max_offset = ((size-1) / sys->frame_size) * sys->frame_size;
 
     offset = sys->frame_size * timestamp;
@@ -378,7 +378,7 @@ static int64_t dv_frame_offset(AVFormatContext *s, DVDemuxContext *c,
     if (size >= 0 && offset > max_offset) offset = max_offset;
     else if (offset < 0) offset = 0;
 
-    return offset;
+    return offset + s->data_offset;
 }
 
 void dv_offset_reset(DVDemuxContext *c, int64_t frame_offset)

-- 
Libav/FFmpeg packaging



More information about the pkg-multimedia-commits mailing list