[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