summaryrefslogtreecommitdiff
path: root/libavcodec/x86/videodsp_init.c
diff options
context:
space:
mode:
authorJames Almer <jamrial@gmail.com>2014-06-23 15:51:53 -0300
committerMichael Niedermayer <michaelni@gmx.at>2014-06-26 17:58:57 +0200
commit057d2704e78b52fec357b4fc646c9de37a085413 (patch)
tree060823a1e5b0c8cbad9a12ed34250ce35da4e6b0 /libavcodec/x86/videodsp_init.c
parente18b48c6fdfdc91fe56b1d1a1312b6d486d9fe43 (diff)
downloadffmpeg-057d2704e78b52fec357b4fc646c9de37a085413.tar.gz
x86/videodsp: add emulated_edge_mc_mmxext
This also changes hfix8_mmx and above to use mmx regs instead of gprs, and makes emulated_edge_mc_sse and emulated_edge_mc_sse2 use mmxext hfix and hvar functions instead of mmx where possible. This is mostly in preparation for an ssse3 version. Signed-off-by: James Almer <jamrial@gmail.com> code is about 1 cpu cycle faster approximately Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/x86/videodsp_init.c')
-rw-r--r--libavcodec/x86/videodsp_init.c44
1 files changed, 39 insertions, 5 deletions
diff --git a/libavcodec/x86/videodsp_init.c b/libavcodec/x86/videodsp_init.c
index 3218abdd88..bd61ab461f 100644
--- a/libavcodec/x86/videodsp_init.c
+++ b/libavcodec/x86/videodsp_init.c
@@ -117,15 +117,34 @@ static emu_edge_hfix_func *hfixtbl_mmx[11] = {
};
#endif
extern emu_edge_hvar_func ff_emu_edge_hvar_mmx;
+extern emu_edge_hfix_func ff_emu_edge_hfix4_mmxext;
+extern emu_edge_hfix_func ff_emu_edge_hfix6_mmxext;
+extern emu_edge_hfix_func ff_emu_edge_hfix8_mmxext;
+extern emu_edge_hfix_func ff_emu_edge_hfix10_mmxext;
+extern emu_edge_hfix_func ff_emu_edge_hfix12_mmxext;
+extern emu_edge_hfix_func ff_emu_edge_hfix14_mmxext;
+extern emu_edge_hfix_func ff_emu_edge_hfix16_mmxext;
+extern emu_edge_hfix_func ff_emu_edge_hfix18_mmxext;
+extern emu_edge_hfix_func ff_emu_edge_hfix20_mmxext;
+extern emu_edge_hfix_func ff_emu_edge_hfix22_mmxext;
+#if ARCH_X86_32
+static emu_edge_hfix_func *hfixtbl_mmxext[11] = {
+ ff_emu_edge_hfix2_mmx, ff_emu_edge_hfix4_mmxext, ff_emu_edge_hfix6_mmxext,
+ ff_emu_edge_hfix8_mmxext, ff_emu_edge_hfix10_mmxext, ff_emu_edge_hfix12_mmxext,
+ ff_emu_edge_hfix14_mmxext, ff_emu_edge_hfix16_mmxext, ff_emu_edge_hfix18_mmxext,
+ ff_emu_edge_hfix20_mmxext, ff_emu_edge_hfix22_mmxext
+};
+#endif
+extern emu_edge_hvar_func ff_emu_edge_hvar_mmxext;
extern emu_edge_hfix_func ff_emu_edge_hfix16_sse2;
extern emu_edge_hfix_func ff_emu_edge_hfix18_sse2;
extern emu_edge_hfix_func ff_emu_edge_hfix20_sse2;
extern emu_edge_hfix_func ff_emu_edge_hfix22_sse2;
static emu_edge_hfix_func *hfixtbl_sse2[11] = {
- ff_emu_edge_hfix2_mmx, ff_emu_edge_hfix4_mmx, ff_emu_edge_hfix6_mmx,
- ff_emu_edge_hfix8_mmx, ff_emu_edge_hfix10_mmx, ff_emu_edge_hfix12_mmx,
- ff_emu_edge_hfix14_mmx, ff_emu_edge_hfix16_sse2, ff_emu_edge_hfix18_sse2,
- ff_emu_edge_hfix20_sse2, ff_emu_edge_hfix22_sse2
+ ff_emu_edge_hfix2_mmx, ff_emu_edge_hfix4_mmxext, ff_emu_edge_hfix6_mmxext,
+ ff_emu_edge_hfix8_mmxext, ff_emu_edge_hfix10_mmxext, ff_emu_edge_hfix12_mmxext,
+ ff_emu_edge_hfix14_mmxext, ff_emu_edge_hfix16_sse2, ff_emu_edge_hfix18_sse2,
+ ff_emu_edge_hfix20_sse2, ff_emu_edge_hfix22_sse2
};
extern emu_edge_hvar_func ff_emu_edge_hvar_sse2;
@@ -215,6 +234,17 @@ static av_noinline void emulated_edge_mc_mmx(uint8_t *buf, const uint8_t *src,
hfixtbl_mmx, &ff_emu_edge_hvar_mmx);
}
+static av_noinline void emulated_edge_mc_mmxext(uint8_t *buf, const uint8_t *src,
+ ptrdiff_t buf_stride,
+ ptrdiff_t src_stride,
+ int block_w, int block_h,
+ int src_x, int src_y, int w, int h)
+{
+ emulated_edge_mc(buf, src, buf_stride, src_stride, block_w, block_h,
+ src_x, src_y, w, h, vfixtbl_mmx, &ff_emu_edge_vvar_mmx,
+ hfixtbl_mmxext, &ff_emu_edge_hvar_mmxext);
+}
+
static av_noinline void emulated_edge_mc_sse(uint8_t *buf, const uint8_t *src,
ptrdiff_t buf_stride,
ptrdiff_t src_stride,
@@ -223,7 +253,7 @@ static av_noinline void emulated_edge_mc_sse(uint8_t *buf, const uint8_t *src,
{
emulated_edge_mc(buf, src, buf_stride, src_stride, block_w, block_h,
src_x, src_y, w, h, vfixtbl_sse, &ff_emu_edge_vvar_sse,
- hfixtbl_mmx, &ff_emu_edge_hvar_mmx);
+ hfixtbl_mmxext, &ff_emu_edge_hvar_mmxext);
}
#endif
@@ -258,6 +288,10 @@ av_cold void ff_videodsp_init_x86(VideoDSPContext *ctx, int bpc)
#endif /* ARCH_X86_32 */
if (EXTERNAL_MMXEXT(cpu_flags)) {
ctx->prefetch = ff_prefetch_mmxext;
+#if ARCH_X86_32
+ if (bpc <= 8)
+ ctx->emulated_edge_mc = emulated_edge_mc_mmxext;
+#endif /* ARCH_X86_32 */
}
#if ARCH_X86_32
if (EXTERNAL_SSE(cpu_flags) && bpc <= 8) {