FFmpeg
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
Macros | Functions
vp9dsp_init.h File Reference
#include "libavcodec/vp9dsp.h"

Go to the source code of this file.

Macros

#define cat(a, bpp, b)   a##bpp##b
 
#define decl_fpel_func(avg, sz, bpp, opt)
 
#define decl_mc_func(avg, sz, dir, opt, type, f_sz, bpp)
 
#define decl_mc_funcs(sz, opt, type, fsz, bpp)
 
#define decl_ipred_fn(type, sz, bpp, opt)
 
#define decl_ipred_fns(type, bpp, opt4, opt8_16_32)
 
#define decl_itxfm_func(typea, typeb, size, bpp, opt)
 
#define decl_itxfm_funcs(size, bpp, opt)
 
#define mc_rep_func(avg, sz, hsz, hszb, dir, opt, type, f_sz, bpp)
 
#define mc_rep_funcs(sz, hsz, hszb, opt, type, fsz, bpp)
 
#define filter_8tap_1d_fn(op, sz, f, f_opt, fname, dir, dvar, bpp, opt)
 
#define filters_8tap_1d_fn(op, sz, dir, dvar, bpp, opt, f_opt)
 
#define filters_8tap_1d_fn2(op, sz, bpp, opt, f_opt)
 
#define filters_8tap_1d_fn3(op, bpp, opt4, opt8, f_opt)
 
#define filter_8tap_2d_fn(op, sz, f, f_opt, fname, align, bpp, bytes, opt)
 
#define filters_8tap_2d_fn(op, sz, align, bpp, bytes, opt, f_opt)
 
#define filters_8tap_2d_fn2(op, align, bpp, bytes, opt4, opt8, f_opt)
 
#define init_fpel_func(idx1, idx2, sz, type, bpp, opt)
 
#define init_subpel1(idx1, idx2, idxh, idxv, sz, dir, type, bpp, opt)
 
#define init_subpel2(idx1, idx2, sz, type, bpp, opt)
 
#define init_subpel3_32_64(idx, type, bpp, opt)
 
#define init_subpel3_8to64(idx, type, bpp, opt)
 
#define init_subpel3(idx, type, bpp, opt)
 
#define init_ipred_func(type, enum, sz, bpp, opt)
 
#define init_8_16_32_ipred_funcs(type, enum, bpp, opt)
 
#define init_ipred_funcs(type, enum, bpp, opt)
 

Functions

void ff_vp9dsp_init_10bpp_x86 (VP9DSPContext *dsp, int bitexact)
 
void ff_vp9dsp_init_12bpp_x86 (VP9DSPContext *dsp, int bitexact)
 
void ff_vp9dsp_init_16bpp_x86 (VP9DSPContext *dsp)
 

Macro Definition Documentation

#define cat (   a,
  bpp,
  b 
)    a##bpp##b
#define decl_fpel_func (   avg,
  sz,
  bpp,
  opt 
)
Value:
void ff_vp9_##avg##sz##bpp##_##opt(uint8_t *dst, ptrdiff_t dst_stride, \
const uint8_t *src, ptrdiff_t src_stride, \
int h, int mx, int my)
#define src
Definition: vp8dsp.c:254
uint8_t
#define _
#define avg(a, b, c, d)

Definition at line 31 of file vp9dsp_init.h.

#define decl_mc_func (   avg,
  sz,
  dir,
  opt,
  type,
  f_sz,
  bpp 
)
Value:
void ff_vp9_##avg##_8tap_1d_##dir##_##sz##_##bpp##_##opt(uint8_t *dst, ptrdiff_t dst_stride, \
const uint8_t *src, ptrdiff_t src_stride, \
int h, const type (*filter)[f_sz])
#define src
Definition: vp8dsp.c:254
static void filter(int16_t *output, ptrdiff_t out_stride, int16_t *low, ptrdiff_t low_stride, int16_t *high, ptrdiff_t high_stride, int len, int clip)
Definition: cfhd.c:153
uint8_t
#define _
GLint GLenum type
Definition: opengl_enc.c:105
#define avg(a, b, c, d)

Definition at line 36 of file vp9dsp_init.h.

#define decl_mc_funcs (   sz,
  opt,
  type,
  fsz,
  bpp 
)
Value:
decl_mc_func(put, sz, h, opt, type, fsz, bpp); \
decl_mc_func(avg, sz, h, opt, type, fsz, bpp); \
decl_mc_func(put, sz, v, opt, type, fsz, bpp); \
decl_mc_func(avg, sz, v, opt, type, fsz, bpp)
#define decl_mc_func(avg, sz, dir, opt, type, f_sz, bpp)
Definition: vp9dsp_init.h:36
GLint GLenum type
Definition: opengl_enc.c:105
#define avg(a, b, c, d)

Definition at line 41 of file vp9dsp_init.h.

#define decl_ipred_fn (   type,
  sz,
  bpp,
  opt 
)
Value:
void ff_vp9_ipred_##type##_##sz##x##sz##_##bpp##_##opt(uint8_t *dst, \
ptrdiff_t stride, \
const uint8_t *l, \
const uint8_t *a)
uint8_t
#define _
GLint GLenum type
Definition: opengl_enc.c:105
GLint GLenum GLboolean GLsizei stride
Definition: opengl_enc.c:105

Definition at line 47 of file vp9dsp_init.h.

#define decl_ipred_fns (   type,
  bpp,
  opt4,
  opt8_16_32 
)
Value:
decl_ipred_fn(type, 4, bpp, opt4); \
decl_ipred_fn(type, 8, bpp, opt8_16_32); \
decl_ipred_fn(type, 16, bpp, opt8_16_32); \
decl_ipred_fn(type, 32, bpp, opt8_16_32)
#define decl_ipred_fn(type, sz, bpp, opt)
Definition: vp9dsp_init.h:47
GLint GLenum type
Definition: opengl_enc.c:105

Definition at line 53 of file vp9dsp_init.h.

#define decl_itxfm_func (   typea,
  typeb,
  size,
  bpp,
  opt 
)
Value:
void cat(ff_vp9_##typea##_##typeb##_##size##x##size##_add_, bpp, _##opt)(uint8_t *dst, \
ptrdiff_t stride, \
int16_t *block, \
int eob)
static int16_t block[64]
Definition: dct.c:115
uint8_t
ptrdiff_t size
Definition: opengl_enc.c:101
#define _
#define cat(a, bpp, b)
Definition: vp9dsp_init.h:29
int
#define stride

Definition at line 59 of file vp9dsp_init.h.

#define decl_itxfm_funcs (   size,
  bpp,
  opt 
)
Value:
decl_itxfm_func(iadst, idct, size, bpp, opt); \
decl_itxfm_func(idct, iadst, size, bpp, opt); \
decl_itxfm_func(iadst, iadst, size, bpp, opt)
static void idct(int16_t block[64])
Definition: 4xm.c:163
ptrdiff_t size
Definition: opengl_enc.c:101
#define decl_itxfm_func(typea, typeb, size, bpp, opt)
Definition: vp9dsp_init.h:59

Definition at line 65 of file vp9dsp_init.h.

#define mc_rep_func (   avg,
  sz,
  hsz,
  hszb,
  dir,
  opt,
  type,
  f_sz,
  bpp 
)
Value:
static av_always_inline void \
ff_vp9_##avg##_8tap_1d_##dir##_##sz##_##bpp##_##opt(uint8_t *dst, ptrdiff_t dst_stride, \
const uint8_t *src, ptrdiff_t src_stride, \
int h, const type (*filter)[f_sz]) \
{ \
ff_vp9_##avg##_8tap_1d_##dir##_##hsz##_##bpp##_##opt(dst, dst_stride, src, \
src_stride, h, filter); \
ff_vp9_##avg##_8tap_1d_##dir##_##hsz##_##bpp##_##opt(dst + hszb, dst_stride, src + hszb, \
src_stride, h, filter); \
}
#define src
Definition: vp8dsp.c:254
static void filter(int16_t *output, ptrdiff_t out_stride, int16_t *low, ptrdiff_t low_stride, int16_t *high, ptrdiff_t high_stride, int len, int clip)
Definition: cfhd.c:153
uint8_t
#define _
GLint GLenum type
Definition: opengl_enc.c:105
#define avg(a, b, c, d)
#define av_always_inline
Definition: attributes.h:39

Definition at line 71 of file vp9dsp_init.h.

#define mc_rep_funcs (   sz,
  hsz,
  hszb,
  opt,
  type,
  fsz,
  bpp 
)
Value:
mc_rep_func(put, sz, hsz, hszb, h, opt, type, fsz, bpp) \
mc_rep_func(avg, sz, hsz, hszb, h, opt, type, fsz, bpp) \
mc_rep_func(put, sz, hsz, hszb, v, opt, type, fsz, bpp) \
mc_rep_func(avg, sz, hsz, hszb, v, opt, type, fsz, bpp)
GLint GLenum type
Definition: opengl_enc.c:105
#define mc_rep_func(avg, sz, hsz, hszb, dir, opt, type, f_sz, bpp)
Definition: vp9dsp_init.h:71
#define avg(a, b, c, d)

Definition at line 83 of file vp9dsp_init.h.

#define filter_8tap_1d_fn (   op,
  sz,
  f,
  f_opt,
  fname,
  dir,
  dvar,
  bpp,
  opt 
)
Value:
static void op##_8tap_##fname##_##sz##dir##_##bpp##_##opt(uint8_t *dst, ptrdiff_t dst_stride, \
const uint8_t *src, ptrdiff_t src_stride, \
int h, int mx, int my) \
{ \
ff_vp9_##op##_8tap_1d_##dir##_##sz##_##bpp##_##opt(dst, dst_stride, src, src_stride, \
h, ff_filters_##f_opt[f][dvar - 1]); \
}
#define src
Definition: vp8dsp.c:254
uint8_t
#define f(width, name)
Definition: cbs_vp9.c:255
#define _
static int op(uint8_t **dst, const uint8_t *dst_end, GetByteContext *gb, int pixel, int count, int *x, int width, int linesize)
Perform decode operation.
Definition: anm.c:78

Definition at line 89 of file vp9dsp_init.h.

#define filters_8tap_1d_fn (   op,
  sz,
  dir,
  dvar,
  bpp,
  opt,
  f_opt 
)
Value:
filter_8tap_1d_fn(op, sz, FILTER_8TAP_REGULAR, f_opt, regular, dir, dvar, bpp, opt) \
filter_8tap_1d_fn(op, sz, FILTER_8TAP_SHARP, f_opt, sharp, dir, dvar, bpp, opt) \
filter_8tap_1d_fn(op, sz, FILTER_8TAP_SMOOTH, f_opt, smooth, dir, dvar, bpp, opt)
static int op(uint8_t **dst, const uint8_t *dst_end, GetByteContext *gb, int pixel, int count, int *x, int width, int linesize)
Perform decode operation.
Definition: anm.c:78
#define filter_8tap_1d_fn(op, sz, f, f_opt, fname, dir, dvar, bpp, opt)
Definition: vp9dsp_init.h:89

Definition at line 98 of file vp9dsp_init.h.

#define filters_8tap_1d_fn2 (   op,
  sz,
  bpp,
  opt,
  f_opt 
)
Value:
filters_8tap_1d_fn(op, sz, h, mx, bpp, opt, f_opt) \
filters_8tap_1d_fn(op, sz, v, my, bpp, opt, f_opt)
static int op(uint8_t **dst, const uint8_t *dst_end, GetByteContext *gb, int pixel, int count, int *x, int width, int linesize)
Perform decode operation.
Definition: anm.c:78
#define filters_8tap_1d_fn(op, sz, dir, dvar, bpp, opt, f_opt)
Definition: vp9dsp_init.h:98

Definition at line 103 of file vp9dsp_init.h.

#define filters_8tap_1d_fn3 (   op,
  bpp,
  opt4,
  opt8,
  f_opt 
)
Value:
filters_8tap_1d_fn2(op, 64, bpp, opt8, f_opt) \
filters_8tap_1d_fn2(op, 32, bpp, opt8, f_opt) \
filters_8tap_1d_fn2(op, 16, bpp, opt8, f_opt) \
filters_8tap_1d_fn2(op, 8, bpp, opt8, f_opt) \
filters_8tap_1d_fn2(op, 4, bpp, opt4, f_opt)
#define filters_8tap_1d_fn2(op, sz, bpp, opt, f_opt)
Definition: vp9dsp_init.h:103
static int op(uint8_t **dst, const uint8_t *dst_end, GetByteContext *gb, int pixel, int count, int *x, int width, int linesize)
Perform decode operation.
Definition: anm.c:78

Definition at line 107 of file vp9dsp_init.h.

#define filter_8tap_2d_fn (   op,
  sz,
  f,
  f_opt,
  fname,
  align,
  bpp,
  bytes,
  opt 
)
Value:
static void op##_8tap_##fname##_##sz##hv_##bpp##_##opt(uint8_t *dst, ptrdiff_t dst_stride, \
const uint8_t *src, ptrdiff_t src_stride, \
int h, int mx, int my) \
{ \
LOCAL_ALIGNED_##align(uint8_t, temp, [71 * 64 * bytes]); \
ff_vp9_put_8tap_1d_h_##sz##_##bpp##_##opt(temp, 64 * bytes, src - 3 * src_stride, \
src_stride, h + 7, \
ff_filters_##f_opt[f][mx - 1]); \
ff_vp9_##op##_8tap_1d_v_##sz##_##bpp##_##opt(dst, dst_stride, temp + 3 * bytes * 64, \
64 * bytes, h, \
ff_filters_##f_opt[f][my - 1]); \
}
else temp
Definition: vf_mcdeint.c:256
#define src
Definition: vp8dsp.c:254
uint8_t
#define f(width, name)
Definition: cbs_vp9.c:255
#define _
const AVS_VideoInfo int align
Definition: avisynth_c.h:795
static int op(uint8_t **dst, const uint8_t *dst_end, GetByteContext *gb, int pixel, int count, int *x, int width, int linesize)
Perform decode operation.
Definition: anm.c:78

Definition at line 114 of file vp9dsp_init.h.

#define filters_8tap_2d_fn (   op,
  sz,
  align,
  bpp,
  bytes,
  opt,
  f_opt 
)
Value:
filter_8tap_2d_fn(op, sz, FILTER_8TAP_REGULAR, f_opt, regular, align, bpp, bytes, opt) \
filter_8tap_2d_fn(op, sz, FILTER_8TAP_SHARP, f_opt, sharp, align, bpp, bytes, opt) \
filter_8tap_2d_fn(op, sz, FILTER_8TAP_SMOOTH, f_opt, smooth, align, bpp, bytes, opt)
#define filter_8tap_2d_fn(op, sz, f, f_opt, fname, align, bpp, bytes, opt)
Definition: vp9dsp_init.h:114
const AVS_VideoInfo int align
Definition: avisynth_c.h:795
static int op(uint8_t **dst, const uint8_t *dst_end, GetByteContext *gb, int pixel, int count, int *x, int width, int linesize)
Perform decode operation.
Definition: anm.c:78

Definition at line 128 of file vp9dsp_init.h.

#define filters_8tap_2d_fn2 (   op,
  align,
  bpp,
  bytes,
  opt4,
  opt8,
  f_opt 
)
Value:
filters_8tap_2d_fn(op, 64, align, bpp, bytes, opt8, f_opt) \
filters_8tap_2d_fn(op, 32, align, bpp, bytes, opt8, f_opt) \
filters_8tap_2d_fn(op, 16, align, bpp, bytes, opt8, f_opt) \
filters_8tap_2d_fn(op, 8, align, bpp, bytes, opt8, f_opt) \
filters_8tap_2d_fn(op, 4, align, bpp, bytes, opt4, f_opt)
const AVS_VideoInfo int align
Definition: avisynth_c.h:795
#define filters_8tap_2d_fn(op, sz, align, bpp, bytes, opt, f_opt)
Definition: vp9dsp_init.h:128
static int op(uint8_t **dst, const uint8_t *dst_end, GetByteContext *gb, int pixel, int count, int *x, int width, int linesize)
Perform decode operation.
Definition: anm.c:78

Definition at line 133 of file vp9dsp_init.h.

#define init_fpel_func (   idx1,
  idx2,
  sz,
  type,
  bpp,
  opt 
)
Value:
dsp->mc[idx1][FILTER_8TAP_SMOOTH ][idx2][0][0] = \
dsp->mc[idx1][FILTER_8TAP_REGULAR][idx2][0][0] = \
dsp->mc[idx1][FILTER_8TAP_SHARP ][idx2][0][0] = \
dsp->mc[idx1][FILTER_BILINEAR ][idx2][0][0] = ff_vp9_##type##sz##bpp##_##opt
#define _
GLint GLenum type
Definition: opengl_enc.c:105

Definition at line 140 of file vp9dsp_init.h.

Referenced by ff_vp9dsp_init_16bpp_x86(), and ff_vp9dsp_init_x86().

#define init_subpel1 (   idx1,
  idx2,
  idxh,
  idxv,
  sz,
  dir,
  type,
  bpp,
  opt 
)
Value:
dsp->mc[idx1][FILTER_8TAP_SMOOTH ][idx2][idxh][idxv] = \
type##_8tap_smooth_##sz##dir##_##bpp##_##opt; \
dsp->mc[idx1][FILTER_8TAP_REGULAR][idx2][idxh][idxv] = \
type##_8tap_regular_##sz##dir##_##bpp##_##opt; \
dsp->mc[idx1][FILTER_8TAP_SHARP ][idx2][idxh][idxv] = \
type##_8tap_sharp_##sz##dir##_##bpp##_##opt
#define _
GLint GLenum type
Definition: opengl_enc.c:105

Definition at line 146 of file vp9dsp_init.h.

#define init_subpel2 (   idx1,
  idx2,
  sz,
  type,
  bpp,
  opt 
)
Value:
init_subpel1(idx1, idx2, 1, 1, sz, hv, type, bpp, opt); \
init_subpel1(idx1, idx2, 0, 1, sz, v, type, bpp, opt); \
init_subpel1(idx1, idx2, 1, 0, sz, h, type, bpp, opt)
#define init_subpel1(idx1, idx2, idxh, idxv, sz, dir, type, bpp, opt)
Definition: vp9dsp_init.h:146
GLint GLenum type
Definition: opengl_enc.c:105

Definition at line 154 of file vp9dsp_init.h.

#define init_subpel3_32_64 (   idx,
  type,
  bpp,
  opt 
)
Value:
init_subpel2(0, idx, 64, type, bpp, opt); \
init_subpel2(1, idx, 32, type, bpp, opt)
#define init_subpel2(idx1, idx2, sz, type, bpp, opt)
Definition: vp9dsp_init.h:154
GLint GLenum type
Definition: opengl_enc.c:105

Definition at line 159 of file vp9dsp_init.h.

Referenced by ff_vp9dsp_init_x86(), and INIT_FUNC().

#define init_subpel3_8to64 (   idx,
  type,
  bpp,
  opt 
)
Value:
init_subpel3_32_64(idx, type, bpp, opt); \
init_subpel2(2, idx, 16, type, bpp, opt); \
init_subpel2(3, idx, 8, type, bpp, opt)
#define init_subpel3_32_64(idx, type, bpp, opt)
Definition: vp9dsp_init.h:159
#define init_subpel2(idx1, idx2, sz, type, bpp, opt)
Definition: vp9dsp_init.h:154
GLint GLenum type
Definition: opengl_enc.c:105

Definition at line 163 of file vp9dsp_init.h.

Referenced by ff_vp9dsp_init_x86().

#define init_subpel3 (   idx,
  type,
  bpp,
  opt 
)
Value:
init_subpel3_8to64(idx, type, bpp, opt); \
init_subpel2(4, idx, 4, type, bpp, opt)
#define init_subpel2(idx1, idx2, sz, type, bpp, opt)
Definition: vp9dsp_init.h:154
GLint GLenum type
Definition: opengl_enc.c:105
#define init_subpel3_8to64(idx, type, bpp, opt)
Definition: vp9dsp_init.h:163

Definition at line 168 of file vp9dsp_init.h.

#define init_ipred_func (   type,
  enum,
  sz,
  bpp,
  opt 
)
Value:
dsp->intra_pred[TX_##sz##X##sz][enum##_PRED] = \
cat(ff_vp9_ipred_##type##_##sz##x##sz##_, bpp, _##opt)
#define _
#define cat(a, bpp, b)
Definition: vp9dsp_init.h:29
GLint GLenum type
Definition: opengl_enc.c:105

Definition at line 172 of file vp9dsp_init.h.

Referenced by ff_vp9dsp_init_16bpp_x86(), and INIT_FUNC().

#define init_8_16_32_ipred_funcs (   type,
  enum,
  bpp,
  opt 
)
Value:
init_ipred_func(type, enum, 8, bpp, opt); \
init_ipred_func(type, enum, 16, bpp, opt); \
init_ipred_func(type, enum, 32, bpp, opt)
#define init_ipred_func(type, enum, sz, bpp, opt)
Definition: vp9dsp_init.h:172
GLint GLenum type
Definition: opengl_enc.c:105

Definition at line 176 of file vp9dsp_init.h.

Referenced by ff_vp9dsp_init_16bpp_x86(), and INIT_FUNC().

#define init_ipred_funcs (   type,
  enum,
  bpp,
  opt 
)
Value:
init_ipred_func(type, enum, 4, bpp, opt); \
#define init_ipred_func(type, enum, sz, bpp, opt)
Definition: vp9dsp_init.h:172
GLint GLenum type
Definition: opengl_enc.c:105
#define init_8_16_32_ipred_funcs(type, enum, bpp, opt)
Definition: vp9dsp_init.h:176

Definition at line 181 of file vp9dsp_init.h.

Referenced by ff_vp9dsp_init_16bpp_x86().

Function Documentation

void ff_vp9dsp_init_10bpp_x86 ( VP9DSPContext dsp,
int  bitexact 
)

Referenced by ff_vp9dsp_init_x86().

void ff_vp9dsp_init_12bpp_x86 ( VP9DSPContext dsp,
int  bitexact 
)

Referenced by ff_vp9dsp_init_x86().

void ff_vp9dsp_init_16bpp_x86 ( VP9DSPContext dsp)

Definition at line 72 of file vp9dsp_init_16bpp.c.

Referenced by INIT_FUNC().