summaryrefslogtreecommitdiff
path: root/src/libffmpeg/libavcodec/dsputil.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/libffmpeg/libavcodec/dsputil.h')
-rw-r--r--src/libffmpeg/libavcodec/dsputil.h59
1 files changed, 43 insertions, 16 deletions
diff --git a/src/libffmpeg/libavcodec/dsputil.h b/src/libffmpeg/libavcodec/dsputil.h
index e401065a0..182b1e706 100644
--- a/src/libffmpeg/libavcodec/dsputil.h
+++ b/src/libffmpeg/libavcodec/dsputil.h
@@ -67,19 +67,53 @@ int pix_abs16x16_x2_c(UINT8 *blk1, UINT8 *blk2, int lx, int h);
int pix_abs16x16_y2_c(UINT8 *blk1, UINT8 *blk2, int lx, int h);
int pix_abs16x16_xy2_c(UINT8 *blk1, UINT8 *blk2, int lx, int h);
+#if defined (SIMPLE_IDCT) && defined (ARCH_X86)
+static inline int block_permute_op(int j)
+{
+static const int table[64]={
+ 0x00, 0x08, 0x01, 0x09, 0x04, 0x0C, 0x05, 0x0D,
+ 0x10, 0x18, 0x11, 0x19, 0x14, 0x1C, 0x15, 0x1D,
+ 0x02, 0x0A, 0x03, 0x0B, 0x06, 0x0E, 0x07, 0x0F,
+ 0x12, 0x1A, 0x13, 0x1B, 0x16, 0x1E, 0x17, 0x1F,
+ 0x20, 0x28, 0x21, 0x29, 0x24, 0x2C, 0x25, 0x2D,
+ 0x30, 0x38, 0x31, 0x39, 0x34, 0x3C, 0x35, 0x3D,
+ 0x22, 0x2A, 0x23, 0x2B, 0x26, 0x2E, 0x27, 0x2F,
+ 0x32, 0x3A, 0x33, 0x3B, 0x36, 0x3E, 0x37, 0x3F,
+};
+
+ return table[j];
+}
+#elif defined (SIMPLE_IDCT)
+static inline int block_permute_op(int j)
+{
+ return j;
+}
+#else
static inline int block_permute_op(int j)
{
return (j & 0x38) | ((j & 6) >> 1) | ((j & 1) << 2);
}
+#endif
void block_permute(INT16 *block);
#if defined(ARCH_X86)
+#define HAVE_MMX 1
+
#include "xineutils.h"
extern int mm_flags;
+#define mm_support() xine_mm_accel()
+
+#if 0
+static inline void emms(void)
+{
+ __asm __volatile ("emms;":::"memory");
+}
+#endif
+
#define emms_c() \
{\
if (mm_flags & MM_MMX)\
@@ -92,36 +126,29 @@ void dsputil_init_mmx(void);
#elif defined(ARCH_ARMV4L)
+#define emms_c()
+
/* This is to use 4 bytes read to the IDCT pointers for some 'zero'
line ptimizations */
#define __align8 __attribute__ ((aligned (4)))
void dsputil_init_armv4l(void);
-#endif
-
-
-
-#if defined(HAVE_MLIB)
+#elif defined(HAVE_MLIB)
+
+#define emms_c()
/* SPARC/VIS IDCT needs 8-byte aligned DCT blocks */
#define __align8 __attribute__ ((aligned (8)))
-void dsputil_init_mlib(void);
+void dsputil_init_mlib(void);
-#endif /* HAVE_MLIB */
+#else
+#define emms_c()
-/*
- * provide empty defaults, if the target specific accelerated dsputils did
- * not define these:
- */
-#ifndef __align8
-#define __align8
-#endif
+#define __align8
-#ifndef emms_c
-#define emms_c()
#endif
#endif