summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2015-01-16 21:36:26 +0100
committerMichael Niedermayer <michaelni@gmx.at>2015-02-13 20:48:09 +0100
commit74c7273b5d5c39c6fb12adbab3e98d71c96df5ad (patch)
tree77368014abd4d04c801cc90072c19b293a283735
parent416501da1aa7818530d758edea9e129797bb07c1 (diff)
downloadffmpeg-74c7273b5d5c39c6fb12adbab3e98d71c96df5ad.tar.gz
avfilter/vf_framepack: Check and update frame_rate
The frame_rate update was missing leaving the output frame rate wrong. Signed-off-by: Michael Niedermayer <michaelni@gmx.at> (cherry picked from commit a46a23d30fea9c8a5570e07ec4d9c9b4eaa6eb4f) Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r--libavfilter/vf_framepack.c13
-rw-r--r--tests/ref/fate/filter-framepack-frameseq26
2 files changed, 25 insertions, 14 deletions
diff --git a/libavfilter/vf_framepack.c b/libavfilter/vf_framepack.c
index 8a7d4e8f32..f5215fed9d 100644
--- a/libavfilter/vf_framepack.c
+++ b/libavfilter/vf_framepack.c
@@ -82,6 +82,7 @@ static int config_output(AVFilterLink *outlink)
int width = ctx->inputs[LEFT]->w;
int height = ctx->inputs[LEFT]->h;
AVRational time_base = ctx->inputs[LEFT]->time_base;
+ AVRational frame_rate = ctx->inputs[LEFT]->frame_rate;
// check size and fps match on the other input
if (width != ctx->inputs[RIGHT]->w ||
@@ -93,11 +94,18 @@ static int config_output(AVFilterLink *outlink)
return AVERROR_INVALIDDATA;
} else if (av_cmp_q(time_base, ctx->inputs[RIGHT]->time_base) != 0) {
av_log(ctx, AV_LOG_ERROR,
- "Left and right framerates differ (%d/%d vs %d/%d).\n",
+ "Left and right time bases differ (%d/%d vs %d/%d).\n",
time_base.num, time_base.den,
ctx->inputs[RIGHT]->time_base.num,
ctx->inputs[RIGHT]->time_base.den);
return AVERROR_INVALIDDATA;
+ } else if (av_cmp_q(frame_rate, ctx->inputs[RIGHT]->frame_rate) != 0) {
+ av_log(ctx, AV_LOG_ERROR,
+ "Left and right framerates differ (%d/%d vs %d/%d).\n",
+ frame_rate.num, frame_rate.den,
+ ctx->inputs[RIGHT]->frame_rate.num,
+ ctx->inputs[RIGHT]->frame_rate.den);
+ return AVERROR_INVALIDDATA;
}
s->pix_desc = av_pix_fmt_desc_get(outlink->format);
@@ -108,6 +116,8 @@ static int config_output(AVFilterLink *outlink)
switch (s->format) {
case AV_STEREO3D_FRAMESEQUENCE:
time_base.den *= 2;
+ frame_rate.num *= 2;
+
s->double_pts = AV_NOPTS_VALUE;
break;
case AV_STEREO3D_COLUMNS:
@@ -126,6 +136,7 @@ static int config_output(AVFilterLink *outlink)
outlink->w = width;
outlink->h = height;
outlink->time_base = time_base;
+ outlink->frame_rate= frame_rate;
return 0;
}
diff --git a/tests/ref/fate/filter-framepack-frameseq b/tests/ref/fate/filter-framepack-frameseq
index c3d2a15e8e..83c08a0324 100644
--- a/tests/ref/fate/filter-framepack-frameseq
+++ b/tests/ref/fate/filter-framepack-frameseq
@@ -1,16 +1,16 @@
-#tb 0: 1/25
+#tb 0: 1/50
0, 0, 0, 1, 152064, 0x05b789ef
0, 1, 1, 1, 152064, 0x05b789ef
0, 2, 2, 1, 152064, 0x4bb46551
-0, 3, 3, 1, 152064, 0x9dddf64a
-0, 4, 4, 1, 152064, 0x2a8380b0
-0, 5, 5, 1, 152064, 0x4de3b652
-0, 6, 6, 1, 152064, 0xedb5a8e6
-0, 7, 7, 1, 152064, 0xe20f7c23
-0, 8, 8, 1, 152064, 0x5ab58bac
-0, 9, 9, 1, 152064, 0x1f1b8026
-0, 10, 10, 1, 152064, 0x91373915
-0, 11, 11, 1, 152064, 0x02344760
-0, 12, 12, 1, 152064, 0x30f5fcd5
-0, 13, 13, 1, 152064, 0xc711ad61
-0, 14, 14, 1, 152064, 0x24eca223
+0, 3, 3, 1, 152064, 0x4bb46551
+0, 4, 4, 1, 152064, 0x9dddf64a
+0, 5, 5, 1, 152064, 0x9dddf64a
+0, 6, 6, 1, 152064, 0x2a8380b0
+0, 7, 7, 1, 152064, 0x2a8380b0
+0, 8, 8, 1, 152064, 0x4de3b652
+0, 9, 9, 1, 152064, 0x4de3b652
+0, 10, 10, 1, 152064, 0xedb5a8e6
+0, 11, 11, 1, 152064, 0xedb5a8e6
+0, 12, 12, 1, 152064, 0xe20f7c23
+0, 13, 13, 1, 152064, 0xe20f7c23
+0, 14, 14, 1, 152064, 0x5ab58bac