[FFmpeg-cvslog] ffmpeg: send EOF pts to filters.
Nicolas George
git at videolan.org
Fri Sep 8 11:35:06 EEST 2017
ffmpeg | branch: master | Nicolas George <george at nsup.org> | Thu Apr 6 10:40:12 2017 +0200| [8043d8eb3bf5e93709212850feb3441b9ec41b25] | committer: Nicolas George
ffmpeg: send EOF pts to filters.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=8043d8eb3bf5e93709212850feb3441b9ec41b25
---
ffmpeg.c | 10 +++++++---
1 file changed, 7 insertions(+), 3 deletions(-)
diff --git a/ffmpeg.c b/ffmpeg.c
index b95addd277..1d248bc269 100644
--- a/ffmpeg.c
+++ b/ffmpeg.c
@@ -2223,14 +2223,14 @@ static int ifilter_send_frame(InputFilter *ifilter, AVFrame *frame)
return 0;
}
-static int ifilter_send_eof(InputFilter *ifilter)
+static int ifilter_send_eof(InputFilter *ifilter, int64_t pts)
{
int i, j, ret;
ifilter->eof = 1;
if (ifilter->filter) {
- ret = av_buffersrc_add_frame_flags(ifilter->filter, NULL, AV_BUFFERSRC_FLAG_PUSH);
+ ret = av_buffersrc_close(ifilter->filter, pts, AV_BUFFERSRC_FLAG_PUSH);
if (ret < 0)
return ret;
} else {
@@ -2581,8 +2581,12 @@ out:
static int send_filter_eof(InputStream *ist)
{
int i, ret;
+ /* TODO keep pts also in stream time base to avoid converting back */
+ int64_t pts = av_rescale_q_rnd(ist->pts, AV_TIME_BASE_Q, ist->st->time_base,
+ AV_ROUND_NEAR_INF | AV_ROUND_PASS_MINMAX);
+
for (i = 0; i < ist->nb_filters; i++) {
- ret = ifilter_send_eof(ist->filters[i]);
+ ret = ifilter_send_eof(ist->filters[i], pts);
if (ret < 0)
return ret;
}
More information about the ffmpeg-cvslog
mailing list