summaryrefslogtreecommitdiff
path: root/libavfilter/vf_blend.c
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2015-10-02 17:22:42 +0200
committerPaul B Mahol <onemda@gmail.com>2015-10-03 21:26:17 +0200
commit9762554dd0e9116d28169f602380e7ccd2949ac5 (patch)
treec5f53a415850a401820097985d7f95522137d669 /libavfilter/vf_blend.c
parent061b67fb50e2d5aab790d193ef93342e0312ddb2 (diff)
avfilter/vf_blend: add x86 SIMD for some modes
Signed-off-by: Paul B Mahol <onemda@gmail.com>
Diffstat (limited to 'libavfilter/vf_blend.c')
-rw-r--r--libavfilter/vf_blend.c100
1 files changed, 29 insertions, 71 deletions
diff --git a/libavfilter/vf_blend.c b/libavfilter/vf_blend.c
index f6a649b0ba..b19eb6b1a2 100644
--- a/libavfilter/vf_blend.c
+++ b/libavfilter/vf_blend.c
@@ -28,69 +28,12 @@
#include "internal.h"
#include "dualinput.h"
#include "video.h"
+#include "blend.h"
#define TOP 0
#define BOTTOM 1
-enum BlendMode {
- BLEND_UNSET = -1,
- BLEND_NORMAL,
- BLEND_ADDITION,
- BLEND_AND,
- BLEND_AVERAGE,
- BLEND_BURN,
- BLEND_DARKEN,
- BLEND_DIFFERENCE,
- BLEND_DIFFERENCE128,
- BLEND_DIVIDE,
- BLEND_DODGE,
- BLEND_EXCLUSION,
- BLEND_HARDLIGHT,
- BLEND_LIGHTEN,
- BLEND_MULTIPLY,
- BLEND_NEGATION,
- BLEND_OR,
- BLEND_OVERLAY,
- BLEND_PHOENIX,
- BLEND_PINLIGHT,
- BLEND_REFLECT,
- BLEND_SCREEN,
- BLEND_SOFTLIGHT,
- BLEND_SUBTRACT,
- BLEND_VIVIDLIGHT,
- BLEND_XOR,
- BLEND_HARDMIX,
- BLEND_LINEARLIGHT,
- BLEND_GLOW,
- BLEND_ADDITION128,
- BLEND_NB
-};
-
-static const char *const var_names[] = { "X", "Y", "W", "H", "SW", "SH", "T", "N", "A", "B", "TOP", "BOTTOM", NULL };
-enum { VAR_X, VAR_Y, VAR_W, VAR_H, VAR_SW, VAR_SH, VAR_T, VAR_N, VAR_A, VAR_B, VAR_TOP, VAR_BOTTOM, VAR_VARS_NB };
-
-typedef struct FilterParams {
- enum BlendMode mode;
- double opacity;
- AVExpr *e;
- char *expr_str;
- void (*blend)(const uint8_t *top, int top_linesize,
- const uint8_t *bottom, int bottom_linesize,
- uint8_t *dst, int dst_linesize,
- int width, int start, int end,
- struct FilterParams *param, double *values);
-} FilterParams;
-
-typedef struct ThreadData {
- const AVFrame *top, *bottom;
- AVFrame *dst;
- AVFilterLink *inlink;
- int plane;
- int w, h;
- FilterParams *param;
-} ThreadData;
-
-typedef struct {
+typedef struct BlendContext {
const AVClass *class;
FFDualInputContext dinput;
int hsub, vsub; ///< chroma subsampling values
@@ -104,6 +47,18 @@ typedef struct {
AVFrame *prev_frame; /* only used with tblend */
} BlendContext;
+static const char *const var_names[] = { "X", "Y", "W", "H", "SW", "SH", "T", "N", "A", "B", "TOP", "BOTTOM", NULL };
+enum { VAR_X, VAR_Y, VAR_W, VAR_H, VAR_SW, VAR_SH, VAR_T, VAR_N, VAR_A, VAR_B, VAR_TOP, VAR_BOTTOM, VAR_VARS_NB };
+
+typedef struct ThreadData {
+ const AVFrame *top, *bottom;
+ AVFrame *dst;
+ AVFilterLink *inlink;
+ int plane;
+ int w, h;
+ FilterParams *param;
+} ThreadData;
+
#define COMMON_OPTIONS \
{ "c0_mode", "set component #0 blend mode", OFFSET(params[0].mode), AV_OPT_TYPE_INT, {.i64=0}, 0, BLEND_NB-1, FLAGS, "mode"},\
{ "c1_mode", "set component #1 blend mode", OFFSET(params[1].mode), AV_OPT_TYPE_INT, {.i64=0}, 0, BLEND_NB-1, FLAGS, "mode"},\
@@ -162,9 +117,9 @@ static const AVOption blend_options[] = {
AVFILTER_DEFINE_CLASS(blend);
-static void blend_normal(const uint8_t *top, int top_linesize,
- const uint8_t *bottom, int bottom_linesize,
- uint8_t *dst, int dst_linesize,
+static void blend_normal(const uint8_t *top, ptrdiff_t top_linesize,
+ const uint8_t *bottom, ptrdiff_t bottom_linesize,
+ uint8_t *dst, ptrdiff_t dst_linesize,
int width, int start, int end,
FilterParams *param, double *values)
{
@@ -172,9 +127,9 @@ static void blend_normal(const uint8_t *top, int top_linesize,
}
#define DEFINE_BLEND8(name, expr) \
-static void blend_## name##_8bit(const uint8_t *top, int top_linesize, \
- const uint8_t *bottom, int bottom_linesize, \
- uint8_t *dst, int dst_linesize, \
+static void blend_## name##_8bit(const uint8_t *top, ptrdiff_t top_linesize, \
+ const uint8_t *bottom, ptrdiff_t bottom_linesize, \
+ uint8_t *dst, ptrdiff_t dst_linesize, \
int width, int start, int end, \
FilterParams *param, double *values) \
{ \
@@ -192,9 +147,9 @@ static void blend_## name##_8bit(const uint8_t *top, int top_linesize, \
}
#define DEFINE_BLEND16(name, expr) \
-static void blend_## name##_16bit(const uint8_t *_top, int top_linesize, \
- const uint8_t *_bottom, int bottom_linesize, \
- uint8_t *_dst, int dst_linesize, \
+static void blend_## name##_16bit(const uint8_t *_top, ptrdiff_t top_linesize, \
+ const uint8_t *_bottom, ptrdiff_t bottom_linesize, \
+ uint8_t *_dst, ptrdiff_t dst_linesize, \
int width, int start, int end, \
FilterParams *param, double *values) \
{ \
@@ -294,9 +249,9 @@ DEFINE_BLEND16(vividlight, (A < 32768) ? BURN(2 * A, B) : DODGE(2 * (A - 32768),
DEFINE_BLEND16(linearlight,av_clip_uint16((B < 32768) ? B + 2 * A - 65535 : B + 2 * (A - 32768)))
#define DEFINE_BLEND_EXPR(type, name, div) \
-static void blend_expr_## name(const uint8_t *_top, int top_linesize, \
- const uint8_t *_bottom, int bottom_linesize, \
- uint8_t *_dst, int dst_linesize, \
+static void blend_expr_## name(const uint8_t *_top, ptrdiff_t top_linesize, \
+ const uint8_t *_bottom, ptrdiff_t bottom_linesize, \
+ uint8_t *_dst, ptrdiff_t dst_linesize, \
int width, int start, int end, \
FilterParams *param, double *values) \
{ \
@@ -515,6 +470,9 @@ static int config_output(AVFilterLink *outlink)
case BLEND_XOR: param->blend = is_16bit ? blend_xor_16bit : blend_xor_8bit; break;
}
+ if (ARCH_X86)
+ ff_blend_init_x86(param, is_16bit);
+
if (s->all_expr && !param->expr_str) {
param->expr_str = av_strdup(s->all_expr);
if (!param->expr_str)