aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-09-11 04:55:58 +0200
committerMichael Niedermayer <michaelni@gmx.at>2014-10-03 03:40:59 +0200
commit9c57328b8192982b0c394ff5fd45a0b6863efbfd (patch)
tree2c6e055c9412c4f58a553c97319c200e3c99812a
parent6952f6f39b5ed1b93bf879a8517c87702406ed49 (diff)
downloadffmpeg-9c57328b8192982b0c394ff5fd45a0b6863efbfd.tar.gz
ffmpeg: Do av_buffersink_set_frame_size() when reconfiguring the filtergraph not just when changing audio resample parameters
Fixes Ticket3562 Signed-off-by: Michael Niedermayer <michaelni@gmx.at> (cherry picked from commit 16de4d927e8bd1308694217af6027265700b3694) Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r--ffmpeg.c8
-rw-r--r--ffmpeg_filter.c10
2 files changed, 10 insertions, 8 deletions
diff --git a/ffmpeg.c b/ffmpeg.c
index 0dcdcfdff1..3015ca85b3 100644
--- a/ffmpeg.c
+++ b/ffmpeg.c
@@ -1799,18 +1799,10 @@ static int decode_audio(InputStream *ist, AVPacket *pkt, int *got_output)
for (i = 0; i < nb_filtergraphs; i++)
if (ist_in_filtergraph(filtergraphs[i], ist)) {
FilterGraph *fg = filtergraphs[i];
- int j;
if (configure_filtergraph(fg) < 0) {
av_log(NULL, AV_LOG_FATAL, "Error reinitializing filters!\n");
exit_program(1);
}
- for (j = 0; j < fg->nb_outputs; j++) {
- OutputStream *ost = fg->outputs[j]->ost;
- if (ost->enc->type == AVMEDIA_TYPE_AUDIO &&
- !(ost->enc->capabilities & CODEC_CAP_VARIABLE_FRAME_SIZE))
- av_buffersink_set_frame_size(ost->filter->filter,
- ost->enc_ctx->frame_size);
- }
}
}
diff --git a/ffmpeg_filter.c b/ffmpeg_filter.c
index 50ee422c6c..7b75e6fe5e 100644
--- a/ffmpeg_filter.c
+++ b/ffmpeg_filter.c
@@ -919,6 +919,16 @@ int configure_filtergraph(FilterGraph *fg)
}
fg->reconfiguration = 1;
+
+ for (i = 0; i < fg->nb_outputs; i++) {
+ OutputStream *ost = fg->outputs[i]->ost;
+ if (ost &&
+ ost->enc->type == AVMEDIA_TYPE_AUDIO &&
+ !(ost->enc->capabilities & CODEC_CAP_VARIABLE_FRAME_SIZE))
+ av_buffersink_set_frame_size(ost->filter->filter,
+ ost->enc_ctx->frame_size);
+ }
+
return 0;
}