aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLuca Barbato <lu_zero@gentoo.org>2014-08-25 12:11:32 +0200
committerLuca Barbato <lu_zero@gentoo.org>2014-09-03 02:38:03 +0200
commit7968059e5c3cd8f91407f379c11bbf71a1b84c74 (patch)
tree67020bbd49c14dbd1a839374d98ecf2fa48ae953
parent94f084324e648876508bed546d950762f10b875e (diff)
downloadffmpeg-7968059e5c3cd8f91407f379c11bbf71a1b84c74.tar.gz
mpegts: Allow custom max resync size
-rw-r--r--libavformat/mpegts.c24
1 files changed, 22 insertions, 2 deletions
diff --git a/libavformat/mpegts.c b/libavformat/mpegts.c
index dced5370e4..b2ba9f74e2 100644
--- a/libavformat/mpegts.c
+++ b/libavformat/mpegts.c
@@ -126,6 +126,8 @@ struct MpegTSContext {
/** to detect seek */
int64_t last_pos;
+ int resync_size;
+
/******************************************/
/* private mpegts data */
/* scan context */
@@ -137,7 +139,23 @@ struct MpegTSContext {
MpegTSFilter *pids[NB_PID_MAX];
};
+#define MPEGTS_OPTIONS \
+ { "resync_size", "Size limit for looking up a new syncronization.", offsetof(MpegTSContext, resync_size), AV_OPT_TYPE_INT, { .i64 = MAX_RESYNC_SIZE}, 0, INT_MAX, AV_OPT_FLAG_DECODING_PARAM }
+
static const AVOption options[] = {
+ MPEGTS_OPTIONS,
+ { NULL },
+};
+
+static const AVClass mpegts_class = {
+ .class_name = "mpegts demuxer",
+ .item_name = av_default_item_name,
+ .option = options,
+ .version = LIBAVUTIL_VERSION_INT,
+};
+
+static const AVOption raw_options[] = {
+ MPEGTS_OPTIONS,
{ "compute_pcr", "Compute exact PCR for each transport stream packet.",
offsetof(MpegTSContext, mpeg2ts_compute_pcr), AV_OPT_TYPE_INT,
{ .i64 = 0 }, 0, 1, AV_OPT_FLAG_DECODING_PARAM },
@@ -151,7 +169,7 @@ static const AVOption options[] = {
static const AVClass mpegtsraw_class = {
.class_name = "mpegtsraw demuxer",
.item_name = av_default_item_name,
- .option = options,
+ .option = raw_options,
.version = LIBAVUTIL_VERSION_INT,
};
@@ -1805,10 +1823,11 @@ static int handle_packet(MpegTSContext *ts, const uint8_t *packet)
* get_packet_size() ?) */
static int mpegts_resync(AVFormatContext *s)
{
+ MpegTSContext *ts = s->priv_data;
AVIOContext *pb = s->pb;
int c, i;
- for (i = 0; i < MAX_RESYNC_SIZE; i++) {
+ for (i = 0; i < ts->resync_size; i++) {
c = avio_r8(pb);
if (pb->eof_reached)
return AVERROR_EOF;
@@ -2285,6 +2304,7 @@ AVInputFormat ff_mpegts_demuxer = {
.read_seek = read_seek,
.read_timestamp = mpegts_get_pcr,
.flags = AVFMT_SHOW_IDS | AVFMT_TS_DISCONT,
+ .priv_class = &mpegts_class,
};
AVInputFormat ff_mpegtsraw_demuxer = {