]> git.sesse.net Git - ffmpeg/commitdiff
lavfi/lut: add direct path.
authorClément Bœsch <ubitux@gmail.com>
Wed, 17 Apr 2013 10:07:46 +0000 (12:07 +0200)
committerClément Bœsch <ubitux@gmail.com>
Wed, 17 Apr 2013 17:18:08 +0000 (19:18 +0200)
libavfilter/vf_lut.c
tests/fate/filter.mak

index 76db0f31db348f1dfdafa3e04394512f3864010c..be497ac14faaffb9f6871e75678da3d4173d03f4 100644 (file)
@@ -260,14 +260,20 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
     AVFilterLink *outlink = ctx->outputs[0];
     AVFrame *out;
     uint8_t *inrow, *outrow, *inrow0, *outrow0;
-    int i, j, plane;
+    int i, j, plane, direct = 0;
 
+    if (av_frame_is_writable(in)) {
+        direct = 1;
+        out = in;
+    } else {
+        /* TODO reindent */
     out = ff_get_video_buffer(outlink, outlink->w, outlink->h);
     if (!out) {
         av_frame_free(&in);
         return AVERROR(ENOMEM);
     }
     av_frame_copy_props(out, in);
+    }
 
     if (lut->is_rgb) {
         /* packed */
@@ -316,7 +322,9 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
         }
     }
 
-    av_frame_free(&in);
+    if (!direct)
+        av_frame_free(&in);
+
     return ff_filter_frame(outlink, out);
 }
 
index f973ce04436b320e7a85c6b1ea7e991914403b77..7b9890b542b25366f6ebbd41f748b0aee4f753c1 100644 (file)
@@ -79,8 +79,8 @@ fate-filter-join: CMD = md5 -i $(SRC1) -i $(SRC2) -filter_complex join=channel_l
 fate-filter-join: CMP = oneline
 fate-filter-join: REF = 38fa1b18b0c46d77df6f17bfc4f078dd
 
-FATE_FILTER_VSYNTH-$(CONFIG_NEGATE_FILTER) += fate-filter-negate
-fate-filter-negate: CMD = framecrc -c:v pgmyuv -i $(SRC) -vf negate
+FATE_FILTER_VSYNTH-$(call ALLYES, NEGATE_FILTER PERMS_FILTER) += fate-filter-negate
+fate-filter-negate: CMD = framecrc -c:v pgmyuv -i $(SRC) -vf perms=random,negate
 
 FATE_FILTER_VSYNTH-$(CONFIG_HISTOGRAM_FILTER) += fate-filter-histogram-levels
 fate-filter-histogram-levels: CMD = framecrc -c:v pgmyuv -i $(SRC) -vf histogram -flags +bitexact -sws_flags +accurate_rnd+bitexact