34 void ff_avg_pixels4_mmxext(uint8_t *
dst,
const uint8_t *
src, ptrdiff_t
stride);
35 void ff_put_pixels4x4_l2_mmxext(uint8_t *
dst,
const uint8_t *
src1,
const uint8_t *
src2,
37 void ff_avg_pixels4x4_l2_mmxext(uint8_t *
dst,
const uint8_t *
src1,
const uint8_t *
src2,
39 #define ff_put_pixels4x4_l2_mmxext(dst, src1, src2, dststride, src1stride) \
40 ff_put_pixels4x4_l2_mmxext((dst), (src1), (src2), (dststride))
41 #define ff_avg_pixels4x4_l2_mmxext(dst, src1, src2, dststride, src1stride) \
42 ff_avg_pixels4x4_l2_mmxext((dst), (src1), (src2), (dststride))
43 #define ff_put_pixels8x8_l2_sse2 ff_put_pixels8x8_l2_mmxext
44 #define ff_avg_pixels8x8_l2_sse2 ff_avg_pixels8x8_l2_mmxext
46 #define DEF_QPEL(OPNAME)\
47 void ff_ ## OPNAME ## _h264_qpel4_h_lowpass_mmxext(uint8_t *dst, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride);\
48 void ff_ ## OPNAME ## _h264_qpel8_h_lowpass_ssse3(uint8_t *dst, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride);\
49 void ff_ ## OPNAME ## _h264_qpel4_h_lowpass_l2_mmxext(uint8_t *dst, const uint8_t *src, const uint8_t *src2, ptrdiff_t dstStride, ptrdiff_t src2Stride);\
50 void ff_ ## OPNAME ## _h264_qpel8_h_lowpass_l2_sse2(uint8_t *dst, const uint8_t *src, const uint8_t *src2, ptrdiff_t dstStride, ptrdiff_t src2Stride);\
51 void ff_ ## OPNAME ## _h264_qpel16_h_lowpass_l2_sse2(uint8_t *dst, const uint8_t *src, const uint8_t *src2, ptrdiff_t dstStride, ptrdiff_t src2Stride);\
52 void ff_ ## OPNAME ## _h264_qpel8_h_lowpass_l2_ssse3(uint8_t *dst, const uint8_t *src, const uint8_t *src2, ptrdiff_t dstStride, ptrdiff_t src2Stride);\
53 void ff_ ## OPNAME ## _h264_qpel4_v_lowpass_mmxext(uint8_t *dst, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride);\
54 void ff_ ## OPNAME ## _h264_qpel8or16_v_lowpass_sse2(uint8_t *dst, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride, int h);\
55 void ff_ ## OPNAME ## _h264_qpel4_hv_lowpass_h_mmxext(int16_t *tmp, uint8_t *dst, ptrdiff_t dstStride);\
56 void ff_ ## OPNAME ## _h264_qpel8or16_hv1_lowpass_op_sse2(const uint8_t *src, int16_t *tmp, ptrdiff_t srcStride, int size);\
57 void ff_ ## OPNAME ## _h264_qpel8_hv2_lowpass_sse2(uint8_t *dst, int16_t *tmp, ptrdiff_t dstStride);\
58 void ff_ ## OPNAME ## _h264_qpel16_hv2_lowpass_sse2(uint8_t *dst, int16_t *tmp, ptrdiff_t dstStride);\
59 void ff_ ## OPNAME ## _h264_qpel8_hv2_lowpass_ssse3(uint8_t *dst, int16_t *tmp, ptrdiff_t dstStride);\
60 void ff_ ## OPNAME ## _h264_qpel16_hv2_lowpass_ssse3(uint8_t *dst, int16_t *tmp, ptrdiff_t dstStride);\
61 void ff_ ## OPNAME ## _pixels4_l2_shift5_mmxext(uint8_t *dst, const int16_t *src16, const uint8_t *src8, ptrdiff_t dstStride);\
62 void ff_ ## OPNAME ## _pixels8_l2_shift5_sse2(uint8_t *dst, const int16_t *src16, const uint8_t *src8, ptrdiff_t dstStride);\
63 void ff_ ## OPNAME ## _pixels16_l2_shift5_sse2(uint8_t *dst, const int16_t *src16, const uint8_t *src8, ptrdiff_t dstStride);\
65 void ff_put_h264_qpel4_hv_lowpass_v_mmxext(
const uint8_t *
src, int16_t *
tmp, ptrdiff_t srcStride);
70 #define QPEL_H264(OPNAME, MMX)\
71 static av_always_inline void OPNAME ## h264_qpel4_hv_lowpass_ ## MMX(uint8_t *dst, int16_t *tmp, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride)\
73 src -= 2*srcStride+2;\
74 ff_put_h264_qpel4_hv_lowpass_v_mmxext(src, tmp, srcStride);\
75 ff_ ## OPNAME ## h264_qpel4_hv_lowpass_h_mmxext(tmp, dst, dstStride);\
78 #define QPEL_H264_H16(OPNAME, EXT) \
79 static av_always_inline void ff_ ## OPNAME ## h264_qpel16_h_lowpass_l2_ ## EXT(uint8_t *dst, const uint8_t *src, const uint8_t *src2, ptrdiff_t dstStride, ptrdiff_t src2Stride)\
81 ff_ ## OPNAME ## h264_qpel8_h_lowpass_l2_ ## EXT(dst , src , src2 , dstStride, src2Stride);\
82 ff_ ## OPNAME ## h264_qpel8_h_lowpass_l2_ ## EXT(dst+8, src+8, src2+8, dstStride, src2Stride);\
85 src2 += 8*src2Stride;\
86 ff_ ## OPNAME ## h264_qpel8_h_lowpass_l2_ ## EXT(dst , src , src2 , dstStride, src2Stride);\
87 ff_ ## OPNAME ## h264_qpel8_h_lowpass_l2_ ## EXT(dst+8, src+8, src2+8, dstStride, src2Stride);\
92 #define QPEL_H264_H16_XMM(OPNAME, MMX)\
94 void ff_avg_h264_qpel16_h_lowpass_l2_ssse3(uint8_t *
dst,
const uint8_t *
src,
const uint8_t *
src2, ptrdiff_t dstStride, ptrdiff_t src2Stride);
95 void ff_put_h264_qpel16_h_lowpass_l2_ssse3(uint8_t *
dst,
const uint8_t *
src,
const uint8_t *
src2, ptrdiff_t dstStride, ptrdiff_t src2Stride);
98 #define QPEL_H264_H16_XMM(OPNAME, EXT) QPEL_H264_H16(OPNAME, EXT)
101 #define QPEL_H264_H_XMM(OPNAME, MMX)\
102 QPEL_H264_H16_XMM(OPNAME, MMX)\
103 static av_always_inline void ff_ ## OPNAME ## h264_qpel16_h_lowpass_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride)\
105 ff_ ## OPNAME ## h264_qpel8_h_lowpass_ ## MMX(dst , src , dstStride, srcStride);\
106 ff_ ## OPNAME ## h264_qpel8_h_lowpass_ ## MMX(dst+8, src+8, dstStride, srcStride);\
109 ff_ ## OPNAME ## h264_qpel8_h_lowpass_ ## MMX(dst , src , dstStride, srcStride);\
110 ff_ ## OPNAME ## h264_qpel8_h_lowpass_ ## MMX(dst+8, src+8, dstStride, srcStride);\
113 #define QPEL_H264_V_XMM(OPNAME, XMM, XMM2)\
114 static av_always_inline void ff_ ## OPNAME ## h264_qpel8_v_lowpass_ ## XMM(uint8_t *dst, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride)\
116 ff_ ## OPNAME ## h264_qpel8or16_v_lowpass_ ## XMM2(dst , src , dstStride, srcStride, 8);\
118 static av_always_inline void ff_ ## OPNAME ## h264_qpel16_v_lowpass_ ## XMM(uint8_t *dst, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride)\
120 ff_ ## OPNAME ## h264_qpel8or16_v_lowpass_ ## XMM2(dst , src , dstStride, srcStride, 16);\
121 ff_ ## OPNAME ## h264_qpel8or16_v_lowpass_ ## XMM2(dst+8, src+8, dstStride, srcStride, 16);\
130 src -= 2*srcStride+2;
132 ff_put_h264_qpel8or16_hv1_lowpass_op_sse2(
src,
tmp, srcStride,
size);
138 #define QPEL_H264_HV_XMM(OPNAME, MMX)\
139 static av_always_inline void OPNAME ## h264_qpel8_hv_lowpass_ ## MMX(uint8_t *dst, int16_t *tmp, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride)\
141 put_h264_qpel8or16_hv1_lowpass_sse2(tmp, src, srcStride, 8);\
142 ff_ ## OPNAME ## h264_qpel8_hv2_lowpass_ ## MMX(dst, tmp, dstStride);\
144 static av_always_inline void OPNAME ## h264_qpel16_hv_lowpass_ ## MMX(uint8_t *dst, int16_t *tmp, const uint8_t *src, ptrdiff_t dstStride, ptrdiff_t srcStride)\
146 put_h264_qpel8or16_hv1_lowpass_sse2(tmp, src, srcStride, 16);\
147 ff_ ## OPNAME ## h264_qpel16_hv2_lowpass_ ## MMX(dst, tmp, dstStride);\
150 #define H264_MC_V_H_HV(OPNAME, SIZE, MMX, ALIGN, SHIFT5_EXT) \
151 H264_MC_V(OPNAME, SIZE, MMX, ALIGN, SHIFT5_EXT)\
152 H264_MC_H(OPNAME, SIZE, MMX, ALIGN, SHIFT5_EXT)\
153 H264_MC_HV(OPNAME, SIZE, MMX, ALIGN, SHIFT5_EXT)\
155 #define H264_MC_H(OPNAME, SIZE, MMX, ALIGN, UNUSED) \
156 static void OPNAME ## h264_qpel ## SIZE ## _mc10_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
158 ff_ ## OPNAME ## h264_qpel ## SIZE ## _h_lowpass_l2_ ## MMX(dst, src, src, stride, stride);\
161 static void OPNAME ## h264_qpel ## SIZE ## _mc20_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
163 ff_ ## OPNAME ## h264_qpel ## SIZE ## _h_lowpass_ ## MMX(dst, src, stride, stride);\
166 static void OPNAME ## h264_qpel ## SIZE ## _mc30_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
168 ff_ ## OPNAME ## h264_qpel ## SIZE ## _h_lowpass_l2_ ## MMX(dst, src, src+1, stride, stride);\
171 #define H264_MC_V(OPNAME, SIZE, MMX, ALIGN, UNUSED) \
172 static void OPNAME ## h264_qpel ## SIZE ## _mc01_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
174 LOCAL_ALIGNED(ALIGN, uint8_t, temp, [SIZE*SIZE]);\
175 ff_put_h264_qpel ## SIZE ## _v_lowpass_ ## MMX(temp, src, SIZE, stride);\
176 ff_ ## OPNAME ## pixels ## SIZE ## x ## SIZE ## _l2_ ## MMX(dst, src, temp, stride, stride);\
179 static void OPNAME ## h264_qpel ## SIZE ## _mc02_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
181 ff_ ## OPNAME ## h264_qpel ## SIZE ## _v_lowpass_ ## MMX(dst, src, stride, stride);\
184 static void OPNAME ## h264_qpel ## SIZE ## _mc03_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
186 LOCAL_ALIGNED(ALIGN, uint8_t, temp, [SIZE*SIZE]);\
187 ff_put_h264_qpel ## SIZE ## _v_lowpass_ ## MMX(temp, src, SIZE, stride);\
188 ff_ ## OPNAME ## pixels ## SIZE ## x ## SIZE ## _l2_ ## MMX(dst, src+stride, temp, stride, stride);\
191 #define H264_MC_HV(OPNAME, SIZE, MMX, ALIGN, SHIFT5_EXT) \
192 static void OPNAME ## h264_qpel ## SIZE ## _mc11_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
194 LOCAL_ALIGNED(ALIGN, uint8_t, temp, [SIZE*SIZE]);\
195 ff_put_h264_qpel ## SIZE ## _v_lowpass_ ## MMX(temp, src, SIZE, stride);\
196 ff_ ## OPNAME ## h264_qpel ## SIZE ## _h_lowpass_l2_ ## MMX(dst, src, temp, stride, SIZE);\
199 static void OPNAME ## h264_qpel ## SIZE ## _mc31_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
201 LOCAL_ALIGNED(ALIGN, uint8_t, temp, [SIZE*SIZE]);\
202 ff_put_h264_qpel ## SIZE ## _v_lowpass_ ## MMX(temp, src+1, SIZE, stride);\
203 ff_ ## OPNAME ## h264_qpel ## SIZE ## _h_lowpass_l2_ ## MMX(dst, src, temp, stride, SIZE);\
206 static void OPNAME ## h264_qpel ## SIZE ## _mc13_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
208 LOCAL_ALIGNED(ALIGN, uint8_t, temp, [SIZE*SIZE]);\
209 ff_put_h264_qpel ## SIZE ## _v_lowpass_ ## MMX(temp, src, SIZE, stride);\
210 ff_ ## OPNAME ## h264_qpel ## SIZE ## _h_lowpass_l2_ ## MMX(dst, src+stride, temp, stride, SIZE);\
213 static void OPNAME ## h264_qpel ## SIZE ## _mc33_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
215 LOCAL_ALIGNED(ALIGN, uint8_t, temp, [SIZE*SIZE]);\
216 ff_put_h264_qpel ## SIZE ## _v_lowpass_ ## MMX(temp, src+1, SIZE, stride);\
217 ff_ ## OPNAME ## h264_qpel ## SIZE ## _h_lowpass_l2_ ## MMX(dst, src+stride, temp, stride, SIZE);\
220 static void OPNAME ## h264_qpel ## SIZE ## _mc22_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
222 LOCAL_ALIGNED(ALIGN, uint16_t, temp, [SIZE*(SIZE<8?12:24)]);\
223 OPNAME ## h264_qpel ## SIZE ## _hv_lowpass_ ## MMX(dst, temp, src, stride, stride);\
226 static void OPNAME ## h264_qpel ## SIZE ## _mc21_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
228 LOCAL_ALIGNED(ALIGN, uint8_t, temp, [SIZE*(SIZE<8?12:24)*2 + SIZE*SIZE]);\
229 uint8_t * const halfHV= temp;\
230 int16_t * const halfV= (int16_t*)(temp + SIZE*SIZE);\
231 av_assert2(((uintptr_t)temp & 7) == 0);\
232 put_h264_qpel ## SIZE ## _hv_lowpass_ ## MMX(halfHV, halfV, src, SIZE, stride);\
233 ff_ ## OPNAME ## h264_qpel ## SIZE ## _h_lowpass_l2_ ## MMX(dst, src, halfHV, stride, SIZE);\
236 static void OPNAME ## h264_qpel ## SIZE ## _mc23_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
238 LOCAL_ALIGNED(ALIGN, uint8_t, temp, [SIZE*(SIZE<8?12:24)*2 + SIZE*SIZE]);\
239 uint8_t * const halfHV= temp;\
240 int16_t * const halfV= (int16_t*)(temp + SIZE*SIZE);\
241 av_assert2(((uintptr_t)temp & 7) == 0);\
242 put_h264_qpel ## SIZE ## _hv_lowpass_ ## MMX(halfHV, halfV, src, SIZE, stride);\
243 ff_ ## OPNAME ## h264_qpel ## SIZE ## _h_lowpass_l2_ ## MMX(dst, src+stride, halfHV, stride, SIZE);\
246 static void OPNAME ## h264_qpel ## SIZE ## _mc12_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
248 LOCAL_ALIGNED(ALIGN, uint8_t, temp, [SIZE*(SIZE<8?12:24)*2 + SIZE*SIZE]);\
249 uint8_t * const halfHV= temp;\
250 int16_t * const halfV= (int16_t*)(temp + SIZE*SIZE);\
251 av_assert2(((uintptr_t)temp & 7) == 0);\
252 put_h264_qpel ## SIZE ## _hv_lowpass_ ## MMX(halfHV, halfV, src, SIZE, stride);\
253 ff_ ## OPNAME ## pixels ## SIZE ## _l2_shift5_ ## SHIFT5_EXT(dst, halfV+2, halfHV, stride);\
256 static void OPNAME ## h264_qpel ## SIZE ## _mc32_ ## MMX(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)\
258 LOCAL_ALIGNED(ALIGN, uint8_t, temp, [SIZE*(SIZE<8?12:24)*2 + SIZE*SIZE]);\
259 uint8_t * const halfHV= temp;\
260 int16_t * const halfV= (int16_t*)(temp + SIZE*SIZE);\
261 av_assert2(((uintptr_t)temp & 7) == 0);\
262 put_h264_qpel ## SIZE ## _hv_lowpass_ ## MMX(halfHV, halfV, src, SIZE, stride);\
263 ff_ ## OPNAME ## pixels ## SIZE ## _l2_shift5_ ## SHIFT5_EXT(dst, halfV+3, halfHV, stride);\
266 #define H264_MC(QPEL, SIZE, MMX, ALIGN, SHIFT5_EXT)\
267 QPEL(put_, SIZE, MMX, ALIGN, SHIFT5_EXT) \
268 QPEL(avg_, SIZE, MMX, ALIGN, SHIFT5_EXT) \
270 #define H264_MC_816(QPEL, XMM, SHIFT5_EXT)\
271 QPEL(put_, 8, XMM, 16, SHIFT5_EXT)\
272 QPEL(put_, 16,XMM, 16, SHIFT5_EXT)\
273 QPEL(avg_, 8, XMM, 16, SHIFT5_EXT)\
274 QPEL(avg_, 16,XMM, 16, SHIFT5_EXT)\
276 QPEL_H264(put_, mmxext)
277 QPEL_H264(avg_, mmxext)
278 QPEL_H264_V_XMM(put_, sse2, sse2)
279 QPEL_H264_V_XMM(avg_, sse2, sse2)
280 QPEL_H264_HV_XMM(put_, sse2)
281 QPEL_H264_HV_XMM(avg_, sse2)
282 QPEL_H264_H_XMM(put_, ssse3)
283 QPEL_H264_H_XMM(avg_, ssse3)
284 QPEL_H264_V_XMM(put_, ssse3, sse2)
285 QPEL_H264_HV_XMM(put_, ssse3)
286 QPEL_H264_HV_XMM(avg_, ssse3)
288 H264_MC(H264_MC_V_H_HV, 4, mmxext, 8, mmxext)
289 H264_MC_816(H264_MC_V, sse2, sse2)
290 H264_MC_816(H264_MC_HV, sse2, sse2)
291 H264_MC_816(H264_MC_H, ssse3, sse2)
292 H264_MC_816(H264_MC_HV, ssse3, sse2)
296 #define LUMA_MC_OP(OP, NUM, DEPTH, TYPE, OPT) \
297 void ff_ ## OP ## _h264_qpel ## NUM ## _ ## TYPE ## _ ## DEPTH ## _ ## OPT \
298 (uint8_t *dst, const uint8_t *src, ptrdiff_t stride);
300 #define LUMA_MC_4(DEPTH, TYPE, OPT) \
301 LUMA_MC_OP(put, 4, DEPTH, TYPE, OPT) \
302 LUMA_MC_OP(avg, 4, DEPTH, TYPE, OPT)
304 #define LUMA_MC_816(DEPTH, TYPE, OPT) \
305 LUMA_MC_OP(put, 8, DEPTH, TYPE, OPT) \
306 LUMA_MC_OP(avg, 8, DEPTH, TYPE, OPT) \
307 LUMA_MC_OP(put, 16, DEPTH, TYPE, OPT) \
308 LUMA_MC_OP(avg, 16, DEPTH, TYPE, OPT)
310 LUMA_MC_4(10, mc00, mmxext)
311 LUMA_MC_4(10, mc10, mmxext)
312 LUMA_MC_4(10, mc20, mmxext)
313 LUMA_MC_4(10, mc30, mmxext)
314 LUMA_MC_4(10, mc01, mmxext)
315 LUMA_MC_4(10, mc11, mmxext)
316 LUMA_MC_4(10, mc21, mmxext)
317 LUMA_MC_4(10, mc31, mmxext)
318 LUMA_MC_4(10, mc02, mmxext)
319 LUMA_MC_4(10, mc12, mmxext)
320 LUMA_MC_4(10, mc22, mmxext)
321 LUMA_MC_4(10, mc32, mmxext)
322 LUMA_MC_4(10, mc03, mmxext)
323 LUMA_MC_4(10, mc13, mmxext)
324 LUMA_MC_4(10, mc23, mmxext)
325 LUMA_MC_4(10, mc33, mmxext)
327 LUMA_MC_816(10, mc00, sse2)
328 LUMA_MC_816(10, mc10, sse2)
329 LUMA_MC_816(10, mc10, ssse3_cache64)
330 LUMA_MC_816(10, mc20, sse2)
331 LUMA_MC_816(10, mc20, ssse3_cache64)
332 LUMA_MC_816(10, mc30, sse2)
333 LUMA_MC_816(10, mc30, ssse3_cache64)
334 LUMA_MC_816(10, mc01, sse2)
335 LUMA_MC_816(10, mc11, sse2)
336 LUMA_MC_816(10, mc21, sse2)
337 LUMA_MC_816(10, mc31, sse2)
338 LUMA_MC_816(10, mc02, sse2)
339 LUMA_MC_816(10, mc12, sse2)
340 LUMA_MC_816(10, mc22, sse2)
341 LUMA_MC_816(10, mc32, sse2)
342 LUMA_MC_816(10, mc03, sse2)
343 LUMA_MC_816(10, mc13, sse2)
344 LUMA_MC_816(10, mc23, sse2)
345 LUMA_MC_816(10, mc33, sse2)
349 #define SET_QPEL_FUNCS_1PP(PFX, IDX, SIZE, CPU, PREFIX) \
351 c->PFX ## _pixels_tab[IDX][ 1] = PREFIX ## PFX ## SIZE ## _mc10_ ## CPU; \
352 c->PFX ## _pixels_tab[IDX][ 2] = PREFIX ## PFX ## SIZE ## _mc20_ ## CPU; \
353 c->PFX ## _pixels_tab[IDX][ 3] = PREFIX ## PFX ## SIZE ## _mc30_ ## CPU; \
354 c->PFX ## _pixels_tab[IDX][ 4] = PREFIX ## PFX ## SIZE ## _mc01_ ## CPU; \
355 c->PFX ## _pixels_tab[IDX][ 5] = PREFIX ## PFX ## SIZE ## _mc11_ ## CPU; \
356 c->PFX ## _pixels_tab[IDX][ 6] = PREFIX ## PFX ## SIZE ## _mc21_ ## CPU; \
357 c->PFX ## _pixels_tab[IDX][ 7] = PREFIX ## PFX ## SIZE ## _mc31_ ## CPU; \
358 c->PFX ## _pixels_tab[IDX][ 8] = PREFIX ## PFX ## SIZE ## _mc02_ ## CPU; \
359 c->PFX ## _pixels_tab[IDX][ 9] = PREFIX ## PFX ## SIZE ## _mc12_ ## CPU; \
360 c->PFX ## _pixels_tab[IDX][10] = PREFIX ## PFX ## SIZE ## _mc22_ ## CPU; \
361 c->PFX ## _pixels_tab[IDX][11] = PREFIX ## PFX ## SIZE ## _mc32_ ## CPU; \
362 c->PFX ## _pixels_tab[IDX][12] = PREFIX ## PFX ## SIZE ## _mc03_ ## CPU; \
363 c->PFX ## _pixels_tab[IDX][13] = PREFIX ## PFX ## SIZE ## _mc13_ ## CPU; \
364 c->PFX ## _pixels_tab[IDX][14] = PREFIX ## PFX ## SIZE ## _mc23_ ## CPU; \
365 c->PFX ## _pixels_tab[IDX][15] = PREFIX ## PFX ## SIZE ## _mc33_ ## CPU; \
367 #define SET_QPEL_FUNCS(PFX, IDX, SIZE, CPU, PREFIX) \
369 c->PFX ## _pixels_tab[IDX][ 0] = PREFIX ## PFX ## SIZE ## _mc00_ ## CPU; \
370 SET_QPEL_FUNCS_1PP(PFX, IDX, SIZE, CPU, PREFIX); \
373 #define H264_QPEL_FUNCS(x, y, CPU) \
375 c->put_h264_qpel_pixels_tab[0][x + y * 4] = put_h264_qpel16_mc ## x ## y ## _ ## CPU; \
376 c->put_h264_qpel_pixels_tab[1][x + y * 4] = put_h264_qpel8_mc ## x ## y ## _ ## CPU; \
377 c->avg_h264_qpel_pixels_tab[0][x + y * 4] = avg_h264_qpel16_mc ## x ## y ## _ ## CPU; \
378 c->avg_h264_qpel_pixels_tab[1][x + y * 4] = avg_h264_qpel8_mc ## x ## y ## _ ## CPU; \
381 #define H264_QPEL_FUNCS_10(x, y, CPU) \
383 c->put_h264_qpel_pixels_tab[0][x + y * 4] = ff_put_h264_qpel16_mc ## x ## y ## _10_ ## CPU; \
384 c->put_h264_qpel_pixels_tab[1][x + y * 4] = ff_put_h264_qpel8_mc ## x ## y ## _10_ ## CPU; \
385 c->avg_h264_qpel_pixels_tab[0][x + y * 4] = ff_avg_h264_qpel16_mc ## x ## y ## _10_ ## CPU; \
386 c->avg_h264_qpel_pixels_tab[1][x + y * 4] = ff_avg_h264_qpel8_mc ## x ## y ## _10_ ## CPU; \
396 if (!high_bit_depth) {
400 c->avg_h264_qpel_pixels_tab[2][0] = ff_avg_pixels4_mmxext;
408 if (!high_bit_depth) {
437 if (!high_bit_depth) {