[FFmpeg-cvslog] avformat: add common mechanism for skipping samples at the start of file
wm4
git at videolan.org
Wed Apr 22 14:31:42 CEST 2015
ffmpeg | branch: master | wm4 <nfxjfg at googlemail.com> | Wed Apr 22 12:24:36 2015 +0200| [7dd8bf53bdb5669a7c65822417fe29036435b40f] | committer: Michael Niedermayer
avformat: add common mechanism for skipping samples at the start of file
This makes using the generic indexing code with mp3 easier at a later
point.
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=7dd8bf53bdb5669a7c65822417fe29036435b40f
---
libavformat/avformat.h | 9 +++++++++
libavformat/utils.c | 4 ++++
2 files changed, 13 insertions(+)
diff --git a/libavformat/avformat.h b/libavformat/avformat.h
index 514e646..c2f798d 100644
--- a/libavformat/avformat.h
+++ b/libavformat/avformat.h
@@ -1083,6 +1083,15 @@ typedef struct AVStream {
int skip_samples;
/**
+ * If not 0, the number of samples that should be skipped from the start of
+ * the stream (the samples are removed from packets with pts==0, which also
+ * assumes negative timestamps do not happen).
+ * Intended for use with formats such as mp3 with ad-hoc gapless audio
+ * support.
+ */
+ int64_t start_skip_samples;
+
+ /**
* If not 0, the first audio sample that should be discarded from the stream.
* This is broken by design (needs global sample count), but can't be
* avoided for broken by design formats such as mp3 with ad-hoc gapless
diff --git a/libavformat/utils.c b/libavformat/utils.c
index 950b3c6..2f6122d 100644
--- a/libavformat/utils.c
+++ b/libavformat/utils.c
@@ -1416,6 +1416,8 @@ static int read_frame_internal(AVFormatContext *s, AVPacket *pkt)
sample < st->last_discard_sample)
discard_padding = FFMIN(end_sample - st->first_discard_sample, duration);
}
+ if (st->start_skip_samples && (pkt->pts == 0 || pkt->pts == RELATIVE_TS_BASE))
+ st->skip_samples = st->start_skip_samples;
if (st->skip_samples || discard_padding) {
uint8_t *p = av_packet_new_side_data(pkt, AV_PKT_DATA_SKIP_SAMPLES, 10);
if (p) {
@@ -1645,6 +1647,8 @@ void ff_read_frame_flush(AVFormatContext *s)
if (s->internal->inject_global_side_data)
st->inject_global_side_data = 1;
+
+ st->skip_samples = 0;
}
}
More information about the ffmpeg-cvslog
mailing list