[FFmpeg-devel] [PATCH] ffmpeg: fix accurate seeking with -copyts

Rodger Combs rodger.combs at gmail.com
Sun Nov 23 22:40:44 CET 2014


---
 ffmpeg.h        |  1 +
 ffmpeg_filter.c | 22 ++++++++++++++++++++--
 2 files changed, 21 insertions(+), 2 deletions(-)

diff --git a/ffmpeg.h b/ffmpeg.h
index 1ace8be..8107fe7 100644
--- a/ffmpeg.h
+++ b/ffmpeg.h
@@ -483,6 +483,7 @@ extern int do_deinterlace;
 extern int do_hex_dump;
 extern int do_pkt_dump;
 extern int copy_ts;
+extern int start_at_zero;
 extern int copy_tb;
 extern int debug_ts;
 extern int exit_on_error;
diff --git a/ffmpeg_filter.c b/ffmpeg_filter.c
index 1e44d2c..d209c6d 100644
--- a/ffmpeg_filter.c
+++ b/ffmpeg_filter.c
@@ -641,6 +641,7 @@ static int configure_input_video_filter(FilterGraph *fg, InputFilter *ifilter,
     AVBPrint args;
     char name[255];
     int ret, pad_idx = 0;
+    int64_t tsoffset = 0;
 
     if (ist->dec_ctx->codec_type == AVMEDIA_TYPE_AUDIO) {
         av_log(NULL, AV_LOG_ERROR, "Cannot connect video filter to audio input\n");
@@ -725,8 +726,16 @@ static int configure_input_video_filter(FilterGraph *fg, InputFilter *ifilter,
 
     snprintf(name, sizeof(name), "trim for input stream %d:%d",
              ist->file_index, ist->st->index);
+    if (copy_ts) {
+        tsoffset = f->start_time == AV_NOPTS_VALUE ? 0 : f->start_time;
+        if (!start_at_zero && f->ctx->start_time != AV_NOPTS_VALUE)
+            tsoffset += f->ctx->start_time;
+    }
     ret = insert_trim(((f->start_time == AV_NOPTS_VALUE) || !f->accurate_seek) ?
-                      AV_NOPTS_VALUE : 0, f->recording_time, &last_filter, &pad_idx, name);
+                      AV_NOPTS_VALUE : f->start_time + tsoffset,
+                      (f->recording_time == INT64_MAX) ? INT64_MAX :
+                      f->recording_time + tsoffset,
+                      &last_filter, &pad_idx, name);
     if (ret < 0)
         return ret;
 
@@ -745,6 +754,7 @@ static int configure_input_audio_filter(FilterGraph *fg, InputFilter *ifilter,
     AVBPrint args;
     char name[255];
     int ret, pad_idx = 0;
+    int64_t tsoffset = 0;
 
     if (ist->dec_ctx->codec_type != AVMEDIA_TYPE_AUDIO) {
         av_log(NULL, AV_LOG_ERROR, "Cannot connect audio filter to non audio input\n");
@@ -827,8 +837,16 @@ static int configure_input_audio_filter(FilterGraph *fg, InputFilter *ifilter,
 
     snprintf(name, sizeof(name), "trim for input stream %d:%d",
              ist->file_index, ist->st->index);
+    if (copy_ts) {
+        tsoffset = f->start_time == AV_NOPTS_VALUE ? 0 : f->start_time;
+        if (!start_at_zero && f->ctx->start_time != AV_NOPTS_VALUE)
+            tsoffset += f->ctx->start_time;
+    }
     ret = insert_trim(((f->start_time == AV_NOPTS_VALUE) || !f->accurate_seek) ?
-                      AV_NOPTS_VALUE : 0, f->recording_time, &last_filter, &pad_idx, name);
+                      AV_NOPTS_VALUE : f->start_time + tsoffset,
+                      (f->recording_time == INT64_MAX) ? INT64_MAX :
+                      f->recording_time + tsoffset,
+                      &last_filter, &pad_idx, name);
     if (ret < 0)
         return ret;
 
-- 
1.9.1



More information about the ffmpeg-devel mailing list