Signed-off-by: Mans Rullgard <mans@mansr.com>tags/n1.0
@@ -31,42 +31,6 @@ | |||||
#undef NDEBUG | #undef NDEBUG | ||||
#include <assert.h> | #include <assert.h> | ||||
typedef struct { | |||||
/** | |||||
* 0: send 1 frame for each frame | |||||
* 1: send 1 frame for each field | |||||
* 2: like 0 but skips spatial interlacing check | |||||
* 3: like 1 but skips spatial interlacing check | |||||
*/ | |||||
int mode; | |||||
/** | |||||
* 0: top field first | |||||
* 1: bottom field first | |||||
* -1: auto-detection | |||||
*/ | |||||
int parity; | |||||
int frame_pending; | |||||
/** | |||||
* 0: deinterlace all frames | |||||
* 1: only deinterlace frames marked as interlaced | |||||
*/ | |||||
int auto_enable; | |||||
AVFilterBufferRef *cur; | |||||
AVFilterBufferRef *next; | |||||
AVFilterBufferRef *prev; | |||||
AVFilterBufferRef *out; | |||||
void (*filter_line)(uint8_t *dst, | |||||
uint8_t *prev, uint8_t *cur, uint8_t *next, | |||||
int w, int prefs, int mrefs, int parity, int mode); | |||||
const AVPixFmtDescriptor *csp; | |||||
int eof; | |||||
} YADIFContext; | |||||
#define CHECK(j)\ | #define CHECK(j)\ | ||||
{ int score = FFABS(cur[mrefs-1+(j)] - cur[prefs-1-(j)])\ | { int score = FFABS(cur[mrefs-1+(j)] - cur[prefs-1-(j)])\ | ||||
+ FFABS(cur[mrefs +(j)] - cur[prefs -(j)])\ | + FFABS(cur[mrefs +(j)] - cur[prefs -(j)])\ | ||||
@@ -397,7 +361,6 @@ static int query_formats(AVFilterContext *ctx) | |||||
static av_cold int init(AVFilterContext *ctx, const char *args) | static av_cold int init(AVFilterContext *ctx, const char *args) | ||||
{ | { | ||||
YADIFContext *yadif = ctx->priv; | YADIFContext *yadif = ctx->priv; | ||||
int cpu_flags = av_get_cpu_flags(); | |||||
yadif->mode = 0; | yadif->mode = 0; | ||||
yadif->parity = -1; | yadif->parity = -1; | ||||
@@ -407,12 +370,9 @@ static av_cold int init(AVFilterContext *ctx, const char *args) | |||||
if (args) sscanf(args, "%d:%d:%d", &yadif->mode, &yadif->parity, &yadif->auto_enable); | if (args) sscanf(args, "%d:%d:%d", &yadif->mode, &yadif->parity, &yadif->auto_enable); | ||||
yadif->filter_line = filter_line_c; | yadif->filter_line = filter_line_c; | ||||
if (HAVE_SSSE3 && cpu_flags & AV_CPU_FLAG_SSSE3) | |||||
yadif->filter_line = ff_yadif_filter_line_ssse3; | |||||
else if (HAVE_SSE && cpu_flags & AV_CPU_FLAG_SSE2) | |||||
yadif->filter_line = ff_yadif_filter_line_sse2; | |||||
else if (HAVE_MMX && cpu_flags & AV_CPU_FLAG_MMX) | |||||
yadif->filter_line = ff_yadif_filter_line_mmx; | |||||
if (HAVE_MMX) | |||||
ff_yadif_init_x86(yadif); | |||||
av_log(ctx, AV_LOG_VERBOSE, "mode:%d parity:%d auto_enable:%d\n", yadif->mode, yadif->parity, yadif->auto_enable); | av_log(ctx, AV_LOG_VERBOSE, "mode:%d parity:%d auto_enable:%d\n", yadif->mode, yadif->parity, yadif->auto_enable); | ||||
@@ -18,6 +18,7 @@ | |||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | ||||
*/ | */ | ||||
#include "libavutil/attributes.h" | |||||
#include "libavutil/cpu.h" | #include "libavutil/cpu.h" | ||||
#include "libavutil/x86_cpu.h" | #include "libavutil/x86_cpu.h" | ||||
#include "libavcodec/x86/dsputil_mmx.h" | #include "libavcodec/x86/dsputil_mmx.h" | ||||
@@ -47,3 +48,15 @@ DECLARE_ASM_CONST(16, const xmm_reg, pw_1) = {0x0001000100010001ULL, 0x000100010 | |||||
#define RENAME(a) a ## _mmx | #define RENAME(a) a ## _mmx | ||||
#include "yadif_template.c" | #include "yadif_template.c" | ||||
#endif | #endif | ||||
av_cold void ff_yadif_init_x86(YADIFContext *yadif) | |||||
{ | |||||
int cpu_flags = av_get_cpu_flags(); | |||||
if (HAVE_MMX && cpu_flags & AV_CPU_FLAG_MMX) | |||||
yadif->filter_line = yadif_filter_line_mmx; | |||||
if (HAVE_SSE && cpu_flags & AV_CPU_FLAG_SSE2) | |||||
yadif->filter_line = yadif_filter_line_sse2; | |||||
if (HAVE_SSSE3 && cpu_flags & AV_CPU_FLAG_SSSE3) | |||||
yadif->filter_line = yadif_filter_line_ssse3; | |||||
} |
@@ -103,9 +103,9 @@ | |||||
"por "MM"5, "MM"3 \n\t"\ | "por "MM"5, "MM"3 \n\t"\ | ||||
MOVQ" "MM"3, "MM"1 \n\t" | MOVQ" "MM"3, "MM"1 \n\t" | ||||
void RENAME(ff_yadif_filter_line)(uint8_t *dst, | |||||
uint8_t *prev, uint8_t *cur, uint8_t *next, | |||||
int w, int prefs, int mrefs, int parity, int mode) | |||||
static void RENAME(yadif_filter_line)(uint8_t *dst, uint8_t *prev, uint8_t *cur, | |||||
uint8_t *next, int w, int prefs, | |||||
int mrefs, int parity, int mode) | |||||
{ | { | ||||
DECLARE_ALIGNED(16, uint8_t, tmp0)[16]; | DECLARE_ALIGNED(16, uint8_t, tmp0)[16]; | ||||
DECLARE_ALIGNED(16, uint8_t, tmp1)[16]; | DECLARE_ALIGNED(16, uint8_t, tmp1)[16]; | ||||
@@ -19,18 +19,45 @@ | |||||
#ifndef AVFILTER_YADIF_H | #ifndef AVFILTER_YADIF_H | ||||
#define AVFILTER_YADIF_H | #define AVFILTER_YADIF_H | ||||
#include "libavutil/pixdesc.h" | |||||
#include "avfilter.h" | #include "avfilter.h" | ||||
void ff_yadif_filter_line_mmx(uint8_t *dst, | |||||
uint8_t *prev, uint8_t *cur, uint8_t *next, | |||||
int w, int prefs, int mrefs, int parity, int mode); | |||||
typedef struct { | |||||
/** | |||||
* 0: send 1 frame for each frame | |||||
* 1: send 1 frame for each field | |||||
* 2: like 0 but skips spatial interlacing check | |||||
* 3: like 1 but skips spatial interlacing check | |||||
*/ | |||||
int mode; | |||||
void ff_yadif_filter_line_sse2(uint8_t *dst, | |||||
uint8_t *prev, uint8_t *cur, uint8_t *next, | |||||
int w, int prefs, int mrefs, int parity, int mode); | |||||
/** | |||||
* 0: top field first | |||||
* 1: bottom field first | |||||
* -1: auto-detection | |||||
*/ | |||||
int parity; | |||||
void ff_yadif_filter_line_ssse3(uint8_t *dst, | |||||
uint8_t *prev, uint8_t *cur, uint8_t *next, | |||||
int w, int prefs, int mrefs, int parity, int mode); | |||||
int frame_pending; | |||||
/** | |||||
* 0: deinterlace all frames | |||||
* 1: only deinterlace frames marked as interlaced | |||||
*/ | |||||
int auto_enable; | |||||
AVFilterBufferRef *cur; | |||||
AVFilterBufferRef *next; | |||||
AVFilterBufferRef *prev; | |||||
AVFilterBufferRef *out; | |||||
void (*filter_line)(uint8_t *dst, | |||||
uint8_t *prev, uint8_t *cur, uint8_t *next, | |||||
int w, int prefs, int mrefs, int parity, int mode); | |||||
const AVPixFmtDescriptor *csp; | |||||
int eof; | |||||
} YADIFContext; | |||||
void ff_yadif_init_x86(YADIFContext *yadif); | |||||
#endif /* AVFILTER_YADIF_H */ | #endif /* AVFILTER_YADIF_H */ |