dsputil_mmx.h File Reference
#include <stddef.h>
#include <stdint.h>
#include "libavcodec/dsputil.h"
#include "libavutil/x86/asm.h"
Include dependency graph for dsputil_mmx.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Macros

#define SBUTTERFLY(a, b, t, n, m)
 
#define TRANSPOSE4(a, b, c, d, t)
 
#define MOVQ_WONE(regd)
 

Functions

void ff_dsputilenc_init_mmx (DSPContext *c, AVCodecContext *avctx)
 
void ff_dsputil_init_pix_mmx (DSPContext *c, AVCodecContext *avctx)
 
void ff_add_pixels_clamped_mmx (const int16_t *block, uint8_t *pixels, int line_size)
 
void ff_put_pixels_clamped_mmx (const int16_t *block, uint8_t *pixels, int line_size)
 
void ff_put_signed_pixels_clamped_mmx (const int16_t *block, uint8_t *pixels, int line_size)
 
void ff_avg_pixels8_mmxext (uint8_t *block, const uint8_t *pixels, ptrdiff_t line_size, int h)
 
void ff_put_pixels8_mmxext (uint8_t *block, const uint8_t *pixels, ptrdiff_t line_size, int h)
 
void ff_avg_pixels16_sse2 (uint8_t *block, const uint8_t *pixels, ptrdiff_t line_size, int h)
 
void ff_put_pixels16_sse2 (uint8_t *block, const uint8_t *pixels, ptrdiff_t line_size, int h)
 
void ff_put_cavs_qpel8_mc00_mmxext (uint8_t *dst, uint8_t *src, ptrdiff_t stride)
 
void ff_avg_cavs_qpel8_mc00_mmxext (uint8_t *dst, uint8_t *src, ptrdiff_t stride)
 
void ff_put_cavs_qpel16_mc00_mmxext (uint8_t *dst, uint8_t *src, ptrdiff_t stride)
 
void ff_avg_cavs_qpel16_mc00_mmxext (uint8_t *dst, uint8_t *src, ptrdiff_t stride)
 
void ff_put_vc1_mspel_mc00_mmx (uint8_t *dst, const uint8_t *src, ptrdiff_t stride, int rnd)
 
void ff_put_rv40_qpel8_mc33_mmx (uint8_t *block, uint8_t *pixels, ptrdiff_t stride)
 
void ff_put_rv40_qpel16_mc33_mmx (uint8_t *block, uint8_t *pixels, ptrdiff_t stride)
 
void ff_avg_rv40_qpel8_mc33_mmx (uint8_t *block, uint8_t *pixels, ptrdiff_t stride)
 
void ff_avg_rv40_qpel16_mc33_mmx (uint8_t *block, uint8_t *pixels, ptrdiff_t stride)
 
void ff_mmx_idct (int16_t *block)
 
void ff_mmxext_idct (int16_t *block)
 
void ff_deinterlace_line_mmx (uint8_t *dst, const uint8_t *lum_m4, const uint8_t *lum_m3, const uint8_t *lum_m2, const uint8_t *lum_m1, const uint8_t *lum, int size)
 
void ff_deinterlace_line_inplace_mmx (const uint8_t *lum_m4, const uint8_t *lum_m3, const uint8_t *lum_m2, const uint8_t *lum_m1, const uint8_t *lum, int size)
 

Variables

const uint64_t ff_bone
 
const uint64_t ff_wtwo
 
const xmm_reg ff_pw_3
 
const xmm_reg ff_pw_4
 
const xmm_reg ff_pw_5
 
const xmm_reg ff_pw_8
 
const uint64_t ff_pw_15
 
const xmm_reg ff_pw_16
 
const xmm_reg ff_pw_18
 
const uint64_t ff_pw_20
 
const xmm_reg ff_pw_32
 
const uint64_t ff_pw_42
 
const uint64_t ff_pw_53
 
const xmm_reg ff_pw_64
 
const uint64_t ff_pw_96
 
const uint64_t ff_pw_128
 
const uint64_t ff_pw_255
 
const xmm_reg ff_pb_1
 
const xmm_reg ff_pb_3
 
const uint64_t ff_pb_3F
 
const xmm_reg ff_pb_F8
 
const uint64_t ff_pb_FC
 
const double ff_pd_1 [2]
 
const double ff_pd_2 [2]
 

Macro Definition Documentation

#define MOVQ_WONE (   regd)
Value:
__asm__ volatile ( \
"pcmpeqd %%" #regd ", %%" #regd " \n\t" \
"psrlw $15, %%" #regd ::)

Definition at line 70 of file dsputil_mmx.h.

#define SBUTTERFLY (   a,
  b,
  t,
  n,
  m 
)
Value:
"mov" #m " " #a ", " #t " \n\t" /* abcd */\
"punpckl" #n " " #b ", " #a " \n\t" /* aebf */\
"punpckh" #n " " #b ", " #t " \n\t" /* cgdh */\
window constants for m
#define b
Definition: input.c:42
t
Definition: genspecsines3.m:6

Definition at line 59 of file dsputil_mmx.h.

#define TRANSPOSE4 (   a,
  b,
  c,
  d,
  t 
)
Value:
SBUTTERFLY(a,b,t,wd,q) /* a=aebf t=cgdh */\
SBUTTERFLY(c,d,b,wd,q) /* c=imjn b=kolp */\
SBUTTERFLY(a,c,d,dq,q) /* a=aeim d=bfjn */\
SBUTTERFLY(t,b,c,dq,q) /* t=cgko c=dhlp */
set threshold d
#define b
Definition: input.c:42
t
Definition: genspecsines3.m:6
#define SBUTTERFLY(a, b, t, n, m)
Definition: dsputil_mmx.h:59
static double c[64]

Definition at line 64 of file dsputil_mmx.h.

Function Documentation

void ff_add_pixels_clamped_mmx ( const int16_t *  block,
uint8_t pixels,
int  line_size 
)
void ff_avg_cavs_qpel16_mc00_mmxext ( uint8_t dst,
uint8_t src,
ptrdiff_t  stride 
)

Referenced by DECLARE_ALIGNED().

void ff_avg_cavs_qpel8_mc00_mmxext ( uint8_t dst,
uint8_t src,
ptrdiff_t  stride 
)

Referenced by DECLARE_ALIGNED().

void ff_avg_pixels16_sse2 ( uint8_t block,
const uint8_t pixels,
ptrdiff_t  line_size,
int  h 
)

Referenced by DECLARE_ALIGNED().

void ff_avg_pixels8_mmxext ( uint8_t block,
const uint8_t pixels,
ptrdiff_t  line_size,
int  h 
)
void ff_avg_rv40_qpel16_mc33_mmx ( uint8_t block,
uint8_t pixels,
ptrdiff_t  stride 
)
void ff_avg_rv40_qpel8_mc33_mmx ( uint8_t block,
uint8_t pixels,
ptrdiff_t  stride 
)
void ff_deinterlace_line_inplace_mmx ( const uint8_t lum_m4,
const uint8_t lum_m3,
const uint8_t lum_m2,
const uint8_t lum_m1,
const uint8_t lum,
int  size 
)
void ff_deinterlace_line_mmx ( uint8_t dst,
const uint8_t lum_m4,
const uint8_t lum_m3,
const uint8_t lum_m2,
const uint8_t lum_m1,
const uint8_t lum,
int  size 
)
void ff_dsputil_init_pix_mmx ( DSPContext c,
AVCodecContext avctx 
)

Definition at line 435 of file x86/motion_est.c.

Referenced by hadamard_func().

void ff_dsputilenc_init_mmx ( DSPContext c,
AVCodecContext avctx 
)

Referenced by ff_dsputil_init_mmx().

void ff_mmx_idct ( int16_t *  block)
void ff_mmxext_idct ( int16_t *  block)
void ff_put_cavs_qpel16_mc00_mmxext ( uint8_t dst,
uint8_t src,
ptrdiff_t  stride 
)

Referenced by DECLARE_ALIGNED().

void ff_put_cavs_qpel8_mc00_mmxext ( uint8_t dst,
uint8_t src,
ptrdiff_t  stride 
)

Referenced by DECLARE_ALIGNED().

void ff_put_pixels16_sse2 ( uint8_t block,
const uint8_t pixels,
ptrdiff_t  line_size,
int  h 
)

Referenced by DECLARE_ALIGNED().

void ff_put_pixels8_mmxext ( uint8_t block,
const uint8_t pixels,
ptrdiff_t  line_size,
int  h 
)

Referenced by DECLARE_ALIGNED().

void ff_put_pixels_clamped_mmx ( const int16_t *  block,
uint8_t pixels,
int  line_size 
)
void ff_put_rv40_qpel16_mc33_mmx ( uint8_t block,
uint8_t pixels,
ptrdiff_t  stride 
)
void ff_put_rv40_qpel8_mc33_mmx ( uint8_t block,
uint8_t pixels,
ptrdiff_t  stride 
)
void ff_put_signed_pixels_clamped_mmx ( const int16_t *  block,
uint8_t pixels,
int  line_size 
)
void ff_put_vc1_mspel_mc00_mmx ( uint8_t dst,
const uint8_t src,
ptrdiff_t  stride,
int  rnd 
)

Referenced by DECLARE_ALIGNED().

Variable Documentation

const uint64_t ff_bone
const xmm_reg ff_pb_1

Referenced by DECLARE_ALIGNED().

const xmm_reg ff_pb_3

Referenced by DECLARE_ALIGNED().

const uint64_t ff_pb_3F
const xmm_reg ff_pb_F8
const uint64_t ff_pb_FC
const double ff_pd_1[2]
const double ff_pd_2[2]

Referenced by DECLARE_ALIGNED().

const uint64_t ff_pw_128
const uint64_t ff_pw_15

Referenced by DECLARE_ALIGNED().

const xmm_reg ff_pw_16

Referenced by DECLARE_ALIGNED().

const xmm_reg ff_pw_18

Referenced by DECLARE_ALIGNED().

const uint64_t ff_pw_20
const uint64_t ff_pw_255
const xmm_reg ff_pw_3

Referenced by DECLARE_ALIGNED().

const xmm_reg ff_pw_32

Referenced by DECLARE_ALIGNED().

const xmm_reg ff_pw_4

Referenced by DECLARE_ALIGNED().

const uint64_t ff_pw_42
const xmm_reg ff_pw_5

Referenced by DECLARE_ALIGNED().

const uint64_t ff_pw_53
const xmm_reg ff_pw_64

Referenced by DECLARE_ALIGNED().

const xmm_reg ff_pw_8

Referenced by DECLARE_ALIGNED().

const uint64_t ff_pw_96
const uint64_t ff_wtwo