FFmpeg
hevcdsp_mips.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2015 Manojkumar Bhosale (Manojkumar.Bhosale@imgtec.com)
3  *
4  * This file is part of FFmpeg.
5  *
6  * FFmpeg is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * FFmpeg is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with FFmpeg; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  */
20 
21 #ifndef AVCODEC_MIPS_HEVCDSP_MIPS_H
22 #define AVCODEC_MIPS_HEVCDSP_MIPS_H
23 
24 #include "libavcodec/hevc/dsp.h"
25 
26 #define MC(PEL, DIR, WIDTH) \
27 void ff_hevc_put_hevc_##PEL##_##DIR##WIDTH##_8_msa(int16_t *dst, \
28  const uint8_t *src, \
29  ptrdiff_t src_stride, \
30  int height, \
31  intptr_t mx, \
32  intptr_t my, \
33  int width)
34 
35 MC(pel, pixels, 4);
36 MC(pel, pixels, 6);
37 MC(pel, pixels, 8);
38 MC(pel, pixels, 12);
39 MC(pel, pixels, 16);
40 MC(pel, pixels, 24);
41 MC(pel, pixels, 32);
42 MC(pel, pixels, 48);
43 MC(pel, pixels, 64);
44 
45 MC(qpel, h, 4);
46 MC(qpel, h, 8);
47 MC(qpel, h, 12);
48 MC(qpel, h, 16);
49 MC(qpel, h, 24);
50 MC(qpel, h, 32);
51 MC(qpel, h, 48);
52 MC(qpel, h, 64);
53 
54 MC(qpel, v, 4);
55 MC(qpel, v, 8);
56 MC(qpel, v, 12);
57 MC(qpel, v, 16);
58 MC(qpel, v, 24);
59 MC(qpel, v, 32);
60 MC(qpel, v, 48);
61 MC(qpel, v, 64);
62 
63 MC(qpel, hv, 4);
64 MC(qpel, hv, 8);
65 MC(qpel, hv, 12);
66 MC(qpel, hv, 16);
67 MC(qpel, hv, 24);
68 MC(qpel, hv, 32);
69 MC(qpel, hv, 48);
70 MC(qpel, hv, 64);
71 
72 MC(epel, h, 4);
73 MC(epel, h, 6);
74 MC(epel, h, 8);
75 MC(epel, h, 12);
76 MC(epel, h, 16);
77 MC(epel, h, 24);
78 MC(epel, h, 32);
79 MC(epel, h, 48);
80 MC(epel, h, 64);
81 
82 MC(epel, v, 4);
83 MC(epel, v, 6);
84 MC(epel, v, 8);
85 MC(epel, v, 12);
86 MC(epel, v, 16);
87 MC(epel, v, 24);
88 MC(epel, v, 32);
89 MC(epel, v, 48);
90 MC(epel, v, 64);
91 
92 MC(epel, hv, 4);
93 MC(epel, hv, 6);
94 MC(epel, hv, 8);
95 MC(epel, hv, 12);
96 MC(epel, hv, 16);
97 MC(epel, hv, 24);
98 MC(epel, hv, 32);
99 MC(epel, hv, 48);
100 MC(epel, hv, 64);
101 
102 #undef MC
103 
104 #define UNI_MC(PEL, DIR, WIDTH) \
105 void ff_hevc_put_hevc_uni_##PEL##_##DIR##WIDTH##_8_msa(uint8_t *dst, \
106  ptrdiff_t dst_stride, \
107  const uint8_t *src, \
108  ptrdiff_t src_stride, \
109  int height, \
110  intptr_t mx, \
111  intptr_t my, \
112  int width)
113 
114 UNI_MC(pel, pixels, 4);
115 UNI_MC(pel, pixels, 6);
116 UNI_MC(pel, pixels, 8);
117 UNI_MC(pel, pixels, 12);
118 UNI_MC(pel, pixels, 16);
119 UNI_MC(pel, pixels, 24);
120 UNI_MC(pel, pixels, 32);
121 UNI_MC(pel, pixels, 48);
122 UNI_MC(pel, pixels, 64);
123 
124 UNI_MC(qpel, h, 4);
125 UNI_MC(qpel, h, 8);
126 UNI_MC(qpel, h, 12);
127 UNI_MC(qpel, h, 16);
128 UNI_MC(qpel, h, 24);
129 UNI_MC(qpel, h, 32);
130 UNI_MC(qpel, h, 48);
131 UNI_MC(qpel, h, 64);
132 
133 UNI_MC(qpel, v, 4);
134 UNI_MC(qpel, v, 8);
135 UNI_MC(qpel, v, 12);
136 UNI_MC(qpel, v, 16);
137 UNI_MC(qpel, v, 24);
138 UNI_MC(qpel, v, 32);
139 UNI_MC(qpel, v, 48);
140 UNI_MC(qpel, v, 64);
141 
142 UNI_MC(qpel, hv, 4);
143 UNI_MC(qpel, hv, 8);
144 UNI_MC(qpel, hv, 12);
145 UNI_MC(qpel, hv, 16);
146 UNI_MC(qpel, hv, 24);
147 UNI_MC(qpel, hv, 32);
148 UNI_MC(qpel, hv, 48);
149 UNI_MC(qpel, hv, 64);
150 
151 UNI_MC(epel, h, 4);
152 UNI_MC(epel, h, 6);
153 UNI_MC(epel, h, 8);
154 UNI_MC(epel, h, 12);
155 UNI_MC(epel, h, 16);
156 UNI_MC(epel, h, 24);
157 UNI_MC(epel, h, 32);
158 UNI_MC(epel, h, 48);
159 UNI_MC(epel, h, 64);
160 
161 UNI_MC(epel, v, 4);
162 UNI_MC(epel, v, 6);
163 UNI_MC(epel, v, 8);
164 UNI_MC(epel, v, 12);
165 UNI_MC(epel, v, 16);
166 UNI_MC(epel, v, 24);
167 UNI_MC(epel, v, 32);
168 UNI_MC(epel, v, 48);
169 UNI_MC(epel, v, 64);
170 
171 UNI_MC(epel, hv, 4);
172 UNI_MC(epel, hv, 6);
173 UNI_MC(epel, hv, 8);
174 UNI_MC(epel, hv, 12);
175 UNI_MC(epel, hv, 16);
176 UNI_MC(epel, hv, 24);
177 UNI_MC(epel, hv, 32);
178 UNI_MC(epel, hv, 48);
179 UNI_MC(epel, hv, 64);
180 
181 #undef UNI_MC
182 
183 #define UNI_W_MC(PEL, DIR, WIDTH) \
184 void ff_hevc_put_hevc_uni_w_##PEL##_##DIR##WIDTH##_8_msa(uint8_t *dst, \
185  ptrdiff_t \
186  dst_stride, \
187  const uint8_t *src, \
188  ptrdiff_t \
189  src_stride, \
190  int height, \
191  int denom, \
192  int weight, \
193  int offset, \
194  intptr_t mx, \
195  intptr_t my, \
196  int width)
197 
198 UNI_W_MC(pel, pixels, 4);
199 UNI_W_MC(pel, pixels, 6);
200 UNI_W_MC(pel, pixels, 8);
201 UNI_W_MC(pel, pixels, 12);
202 UNI_W_MC(pel, pixels, 16);
203 UNI_W_MC(pel, pixels, 24);
204 UNI_W_MC(pel, pixels, 32);
205 UNI_W_MC(pel, pixels, 48);
206 UNI_W_MC(pel, pixels, 64);
207 
208 UNI_W_MC(qpel, h, 4);
209 UNI_W_MC(qpel, h, 8);
210 UNI_W_MC(qpel, h, 12);
211 UNI_W_MC(qpel, h, 16);
212 UNI_W_MC(qpel, h, 24);
213 UNI_W_MC(qpel, h, 32);
214 UNI_W_MC(qpel, h, 48);
215 UNI_W_MC(qpel, h, 64);
216 
217 UNI_W_MC(qpel, v, 4);
218 UNI_W_MC(qpel, v, 8);
219 UNI_W_MC(qpel, v, 12);
220 UNI_W_MC(qpel, v, 16);
221 UNI_W_MC(qpel, v, 24);
222 UNI_W_MC(qpel, v, 32);
223 UNI_W_MC(qpel, v, 48);
224 UNI_W_MC(qpel, v, 64);
225 
226 UNI_W_MC(qpel, hv, 4);
227 UNI_W_MC(qpel, hv, 8);
228 UNI_W_MC(qpel, hv, 12);
229 UNI_W_MC(qpel, hv, 16);
230 UNI_W_MC(qpel, hv, 24);
231 UNI_W_MC(qpel, hv, 32);
232 UNI_W_MC(qpel, hv, 48);
233 UNI_W_MC(qpel, hv, 64);
234 
235 UNI_W_MC(epel, h, 4);
236 UNI_W_MC(epel, h, 6);
237 UNI_W_MC(epel, h, 8);
238 UNI_W_MC(epel, h, 12);
239 UNI_W_MC(epel, h, 16);
240 UNI_W_MC(epel, h, 24);
241 UNI_W_MC(epel, h, 32);
242 UNI_W_MC(epel, h, 48);
243 UNI_W_MC(epel, h, 64);
244 
245 UNI_W_MC(epel, v, 4);
246 UNI_W_MC(epel, v, 6);
247 UNI_W_MC(epel, v, 8);
248 UNI_W_MC(epel, v, 12);
249 UNI_W_MC(epel, v, 16);
250 UNI_W_MC(epel, v, 24);
251 UNI_W_MC(epel, v, 32);
252 UNI_W_MC(epel, v, 48);
253 UNI_W_MC(epel, v, 64);
254 
255 UNI_W_MC(epel, hv, 4);
256 UNI_W_MC(epel, hv, 6);
257 UNI_W_MC(epel, hv, 8);
258 UNI_W_MC(epel, hv, 12);
259 UNI_W_MC(epel, hv, 16);
260 UNI_W_MC(epel, hv, 24);
261 UNI_W_MC(epel, hv, 32);
262 UNI_W_MC(epel, hv, 48);
263 UNI_W_MC(epel, hv, 64);
264 
265 #undef UNI_W_MC
266 
267 #define BI_MC(PEL, DIR, WIDTH) \
268 void ff_hevc_put_hevc_bi_##PEL##_##DIR##WIDTH##_8_msa(uint8_t *dst, \
269  ptrdiff_t dst_stride, \
270  const uint8_t *src, \
271  ptrdiff_t src_stride, \
272  const int16_t *src_16bit, \
273  int height, \
274  intptr_t mx, \
275  intptr_t my, \
276  int width)
277 
278 BI_MC(pel, pixels, 4);
279 BI_MC(pel, pixels, 6);
280 BI_MC(pel, pixels, 8);
281 BI_MC(pel, pixels, 12);
282 BI_MC(pel, pixels, 16);
283 BI_MC(pel, pixels, 24);
284 BI_MC(pel, pixels, 32);
285 BI_MC(pel, pixels, 48);
286 BI_MC(pel, pixels, 64);
287 
288 BI_MC(qpel, h, 4);
289 BI_MC(qpel, h, 8);
290 BI_MC(qpel, h, 12);
291 BI_MC(qpel, h, 16);
292 BI_MC(qpel, h, 24);
293 BI_MC(qpel, h, 32);
294 BI_MC(qpel, h, 48);
295 BI_MC(qpel, h, 64);
296 
297 BI_MC(qpel, v, 4);
298 BI_MC(qpel, v, 8);
299 BI_MC(qpel, v, 12);
300 BI_MC(qpel, v, 16);
301 BI_MC(qpel, v, 24);
302 BI_MC(qpel, v, 32);
303 BI_MC(qpel, v, 48);
304 BI_MC(qpel, v, 64);
305 
306 BI_MC(qpel, hv, 4);
307 BI_MC(qpel, hv, 8);
308 BI_MC(qpel, hv, 12);
309 BI_MC(qpel, hv, 16);
310 BI_MC(qpel, hv, 24);
311 BI_MC(qpel, hv, 32);
312 BI_MC(qpel, hv, 48);
313 BI_MC(qpel, hv, 64);
314 
315 BI_MC(epel, h, 4);
316 BI_MC(epel, h, 6);
317 BI_MC(epel, h, 8);
318 BI_MC(epel, h, 12);
319 BI_MC(epel, h, 16);
320 BI_MC(epel, h, 24);
321 BI_MC(epel, h, 32);
322 BI_MC(epel, h, 48);
323 BI_MC(epel, h, 64);
324 
325 BI_MC(epel, v, 4);
326 BI_MC(epel, v, 6);
327 BI_MC(epel, v, 8);
328 BI_MC(epel, v, 12);
329 BI_MC(epel, v, 16);
330 BI_MC(epel, v, 24);
331 BI_MC(epel, v, 32);
332 BI_MC(epel, v, 48);
333 BI_MC(epel, v, 64);
334 
335 BI_MC(epel, hv, 4);
336 BI_MC(epel, hv, 6);
337 BI_MC(epel, hv, 8);
338 BI_MC(epel, hv, 12);
339 BI_MC(epel, hv, 16);
340 BI_MC(epel, hv, 24);
341 BI_MC(epel, hv, 32);
342 BI_MC(epel, hv, 48);
343 BI_MC(epel, hv, 64);
344 
345 #undef BI_MC
346 
347 #define BI_W_MC(PEL, DIR, WIDTH) \
348 void ff_hevc_put_hevc_bi_w_##PEL##_##DIR##WIDTH##_8_msa(uint8_t *dst, \
349  ptrdiff_t \
350  dst_stride, \
351  const uint8_t *src, \
352  ptrdiff_t \
353  src_stride, \
354  const int16_t *src_16bit, \
355  int height, \
356  int denom, \
357  int weight0, \
358  int weight1, \
359  int offset0, \
360  int offset1, \
361  intptr_t mx, \
362  intptr_t my, \
363  int width)
364 
365 BI_W_MC(pel, pixels, 4);
366 BI_W_MC(pel, pixels, 6);
367 BI_W_MC(pel, pixels, 8);
368 BI_W_MC(pel, pixels, 12);
369 BI_W_MC(pel, pixels, 16);
370 BI_W_MC(pel, pixels, 24);
371 BI_W_MC(pel, pixels, 32);
372 BI_W_MC(pel, pixels, 48);
373 BI_W_MC(pel, pixels, 64);
374 
375 BI_W_MC(qpel, h, 4);
376 BI_W_MC(qpel, h, 8);
377 BI_W_MC(qpel, h, 12);
378 BI_W_MC(qpel, h, 16);
379 BI_W_MC(qpel, h, 24);
380 BI_W_MC(qpel, h, 32);
381 BI_W_MC(qpel, h, 48);
382 BI_W_MC(qpel, h, 64);
383 
384 BI_W_MC(qpel, v, 4);
385 BI_W_MC(qpel, v, 8);
386 BI_W_MC(qpel, v, 12);
387 BI_W_MC(qpel, v, 16);
388 BI_W_MC(qpel, v, 24);
389 BI_W_MC(qpel, v, 32);
390 BI_W_MC(qpel, v, 48);
391 BI_W_MC(qpel, v, 64);
392 
393 BI_W_MC(qpel, hv, 4);
394 BI_W_MC(qpel, hv, 8);
395 BI_W_MC(qpel, hv, 12);
396 BI_W_MC(qpel, hv, 16);
397 BI_W_MC(qpel, hv, 24);
398 BI_W_MC(qpel, hv, 32);
399 BI_W_MC(qpel, hv, 48);
400 BI_W_MC(qpel, hv, 64);
401 
402 BI_W_MC(epel, h, 4);
403 BI_W_MC(epel, h, 6);
404 BI_W_MC(epel, h, 8);
405 BI_W_MC(epel, h, 12);
406 BI_W_MC(epel, h, 16);
407 BI_W_MC(epel, h, 24);
408 BI_W_MC(epel, h, 32);
409 BI_W_MC(epel, h, 48);
410 BI_W_MC(epel, h, 64);
411 
412 BI_W_MC(epel, v, 4);
413 BI_W_MC(epel, v, 6);
414 BI_W_MC(epel, v, 8);
415 BI_W_MC(epel, v, 12);
416 BI_W_MC(epel, v, 16);
417 BI_W_MC(epel, v, 24);
418 BI_W_MC(epel, v, 32);
419 BI_W_MC(epel, v, 48);
420 BI_W_MC(epel, v, 64);
421 
422 BI_W_MC(epel, hv, 4);
423 BI_W_MC(epel, hv, 6);
424 BI_W_MC(epel, hv, 8);
425 BI_W_MC(epel, hv, 12);
426 BI_W_MC(epel, hv, 16);
427 BI_W_MC(epel, hv, 24);
428 BI_W_MC(epel, hv, 32);
429 BI_W_MC(epel, hv, 48);
430 BI_W_MC(epel, hv, 64);
431 
432 #undef BI_W_MC
433 
435  ptrdiff_t src_stride,
436  int32_t beta, const int32_t *tc,
437  const uint8_t *no_p, const uint8_t *no_q);
438 
440  ptrdiff_t src_stride,
441  int32_t beta, const int32_t *tc,
442  const uint8_t *no_p, const uint8_t *no_q);
443 
445  ptrdiff_t src_stride,
446  const int32_t *tc, const uint8_t *no_p,
447  const uint8_t *no_q);
448 
450  ptrdiff_t src_stride,
451  const int32_t *tc, const uint8_t *no_p,
452  const uint8_t *no_q);
453 
454 void ff_hevc_sao_band_filter_0_8_msa(uint8_t *dst, const uint8_t *src,
455  ptrdiff_t stride_dst, ptrdiff_t stride_src,
456  const int16_t *sao_offset_val, int sao_left_class,
457  int width, int height);
458 
459 void ff_hevc_sao_edge_filter_8_msa(uint8_t *dst, const uint8_t *src,
460  ptrdiff_t stride_dst,
461  const int16_t *sao_offset_val,
462  int eo, int width, int height);
463 
464 void ff_hevc_idct_4x4_msa(int16_t *coeffs, int col_limit);
465 void ff_hevc_idct_8x8_msa(int16_t *coeffs, int col_limit);
466 void ff_hevc_idct_16x16_msa(int16_t *coeffs, int col_limit);
467 void ff_hevc_idct_32x32_msa(int16_t *coeffs, int col_limit);
468 void ff_hevc_idct_dc_4x4_msa(int16_t *coeffs);
469 void ff_hevc_idct_dc_8x8_msa(int16_t *coeffs);
470 void ff_hevc_idct_dc_16x16_msa(int16_t *coeffs);
471 void ff_hevc_idct_dc_32x32_msa(int16_t *coeffs);
472 void ff_hevc_addblk_4x4_msa(uint8_t *dst, const int16_t *pi16Coeffs,
473  ptrdiff_t stride);
474 void ff_hevc_addblk_8x8_msa(uint8_t *dst, const int16_t *pi16Coeffs,
475  ptrdiff_t stride);
476 void ff_hevc_addblk_16x16_msa(uint8_t *dst, const int16_t *pi16Coeffs,
477  ptrdiff_t stride);
478 void ff_hevc_addblk_32x32_msa(uint8_t *dst, const int16_t *pi16Coeffs,
479  ptrdiff_t stride);
480 void ff_hevc_idct_luma_4x4_msa(int16_t *pi16Coeffs);
481 
482 /* Loongson optimization */
483 #define L_MC(PEL, DIR, WIDTH, TYPE) \
484 void ff_hevc_put_hevc_##PEL##_##DIR##WIDTH##_8_##TYPE(int16_t *dst, \
485  const uint8_t *src, \
486  ptrdiff_t src_stride, \
487  int height, \
488  intptr_t mx, \
489  intptr_t my, \
490  int width)
491 L_MC(qpel, h, 4, mmi);
492 L_MC(qpel, h, 8, mmi);
493 L_MC(qpel, h, 12, mmi);
494 L_MC(qpel, h, 16, mmi);
495 L_MC(qpel, h, 24, mmi);
496 L_MC(qpel, h, 32, mmi);
497 L_MC(qpel, h, 48, mmi);
498 L_MC(qpel, h, 64, mmi);
499 
500 L_MC(qpel, hv, 4, mmi);
501 L_MC(qpel, hv, 8, mmi);
502 L_MC(qpel, hv, 12, mmi);
503 L_MC(qpel, hv, 16, mmi);
504 L_MC(qpel, hv, 24, mmi);
505 L_MC(qpel, hv, 32, mmi);
506 L_MC(qpel, hv, 48, mmi);
507 L_MC(qpel, hv, 64, mmi);
508 
509 #define L_BI_MC(PEL, DIR, WIDTH, TYPE) \
510 void ff_hevc_put_hevc_##PEL##_bi_##DIR##WIDTH##_8_##TYPE(uint8_t *dst, \
511  ptrdiff_t dst_stride, \
512  const uint8_t *src, \
513  ptrdiff_t src_stride, \
514  const int16_t *src2, \
515  int height, \
516  intptr_t mx, \
517  intptr_t my, \
518  int width)
519 
520 L_BI_MC(pel, pixels, 8, mmi);
521 L_BI_MC(pel, pixels, 16, mmi);
522 L_BI_MC(pel, pixels, 24, mmi);
523 L_BI_MC(pel, pixels, 32, mmi);
524 L_BI_MC(pel, pixels, 48, mmi);
525 L_BI_MC(pel, pixels, 64, mmi);
526 
527 L_BI_MC(qpel, hv, 4, mmi);
528 L_BI_MC(qpel, hv, 8, mmi);
529 L_BI_MC(qpel, hv, 12, mmi);
530 L_BI_MC(qpel, hv, 16, mmi);
531 L_BI_MC(qpel, hv, 24, mmi);
532 L_BI_MC(qpel, hv, 32, mmi);
533 L_BI_MC(qpel, hv, 48, mmi);
534 L_BI_MC(qpel, hv, 64, mmi);
535 
536 L_BI_MC(qpel, h, 4, mmi);
537 L_BI_MC(qpel, h, 8, mmi);
538 L_BI_MC(qpel, h, 12, mmi);
539 L_BI_MC(qpel, h, 16, mmi);
540 L_BI_MC(qpel, h, 24, mmi);
541 L_BI_MC(qpel, h, 32, mmi);
542 L_BI_MC(qpel, h, 48, mmi);
543 L_BI_MC(qpel, h, 64, mmi);
544 
545 L_BI_MC(epel, hv, 4, mmi);
546 L_BI_MC(epel, hv, 8, mmi);
547 L_BI_MC(epel, hv, 12, mmi);
548 L_BI_MC(epel, hv, 16, mmi);
549 L_BI_MC(epel, hv, 24, mmi);
550 L_BI_MC(epel, hv, 32, mmi);
551 #undef L_BI_MC
552 
553 #define L_UNI_MC(PEL, DIR, WIDTH, TYPE) \
554 void ff_hevc_put_hevc_##PEL##_uni_##DIR##WIDTH##_8_##TYPE(uint8_t *dst, \
555  ptrdiff_t dst_stride, \
556  const uint8_t *src, \
557  ptrdiff_t src_stride, \
558  int height, \
559  intptr_t mx, \
560  intptr_t my, \
561  int width)
562 
563 L_UNI_MC(qpel, hv, 4, mmi);
564 L_UNI_MC(qpel, hv, 8, mmi);
565 L_UNI_MC(qpel, hv, 12, mmi);
566 L_UNI_MC(qpel, hv, 16, mmi);
567 L_UNI_MC(qpel, hv, 24, mmi);
568 L_UNI_MC(qpel, hv, 32, mmi);
569 L_UNI_MC(qpel, hv, 48, mmi);
570 L_UNI_MC(qpel, hv, 64, mmi);
571 #undef L_UNI_MC
572 
573 #endif // #ifndef AVCODEC_MIPS_HEVCDSP_MIPS_H
ff_hevc_addblk_32x32_msa
void ff_hevc_addblk_32x32_msa(uint8_t *dst, const int16_t *pi16Coeffs, ptrdiff_t stride)
Definition: hevc_idct_msa.c:998
ff_hevc_idct_dc_16x16_msa
void ff_hevc_idct_dc_16x16_msa(int16_t *coeffs)
Definition: hevc_idct_msa.c:1013
ff_hevc_loop_filter_luma_h_8_msa
void ff_hevc_loop_filter_luma_h_8_msa(uint8_t *src, ptrdiff_t src_stride, int32_t beta, const int32_t *tc, const uint8_t *no_p, const uint8_t *no_q)
Definition: hevc_lpf_sao_msa.c:2566
BI_MC
#define BI_MC(PEL, DIR, WIDTH)
Definition: hevcdsp_mips.h:267
ff_hevc_sao_band_filter_0_8_msa
void ff_hevc_sao_band_filter_0_8_msa(uint8_t *dst, const uint8_t *src, ptrdiff_t stride_dst, ptrdiff_t stride_src, const int16_t *sao_offset_val, int sao_left_class, int width, int height)
Definition: hevc_lpf_sao_msa.c:2598
ff_hevc_sao_edge_filter_8_msa
void ff_hevc_sao_edge_filter_8_msa(uint8_t *dst, const uint8_t *src, ptrdiff_t stride_dst, const int16_t *sao_offset_val, int eo, int width, int height)
Definition: hevc_lpf_sao_msa.c:2626
MC
#define MC(PEL, DIR, WIDTH)
Definition: hevcdsp_mips.h:26
ff_hevc_idct_32x32_msa
void ff_hevc_idct_32x32_msa(int16_t *coeffs, int col_limit)
Definition: hevc_idct_msa.c:978
ff_hevc_idct_4x4_msa
void ff_hevc_idct_4x4_msa(int16_t *coeffs, int col_limit)
Definition: hevc_idct_msa.c:963
BI_W_MC
#define BI_W_MC(PEL, DIR, WIDTH)
Definition: hevcdsp_mips.h:347
ff_hevc_loop_filter_luma_v_8_msa
void ff_hevc_loop_filter_luma_v_8_msa(uint8_t *src, ptrdiff_t src_stride, int32_t beta, const int32_t *tc, const uint8_t *no_p, const uint8_t *no_q)
Definition: hevc_lpf_sao_msa.c:2574
ff_hevc_addblk_4x4_msa
void ff_hevc_addblk_4x4_msa(uint8_t *dst, const int16_t *pi16Coeffs, ptrdiff_t stride)
Definition: hevc_idct_msa.c:983
ff_hevc_loop_filter_chroma_h_8_msa
void ff_hevc_loop_filter_chroma_h_8_msa(uint8_t *src, ptrdiff_t src_stride, const int32_t *tc, const uint8_t *no_p, const uint8_t *no_q)
Definition: hevc_lpf_sao_msa.c:2582
L_MC
#define L_MC(PEL, DIR, WIDTH, TYPE)
Definition: hevcdsp_mips.h:483
dsp.h
height
#define height
Definition: dsp.h:85
dst
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
Definition: dsp.h:83
ff_hevc_idct_8x8_msa
void ff_hevc_idct_8x8_msa(int16_t *coeffs, int col_limit)
Definition: hevc_idct_msa.c:968
ff_hevc_idct_dc_32x32_msa
void ff_hevc_idct_dc_32x32_msa(int16_t *coeffs)
Definition: hevc_idct_msa.c:1018
ff_hevc_idct_16x16_msa
void ff_hevc_idct_16x16_msa(int16_t *coeffs, int col_limit)
Definition: hevc_idct_msa.c:973
L_UNI_MC
#define L_UNI_MC(PEL, DIR, WIDTH, TYPE)
Definition: hevcdsp_mips.h:553
stride
#define stride
Definition: h264pred_template.c:537
L_BI_MC
#define L_BI_MC(PEL, DIR, WIDTH, TYPE)
Definition: hevcdsp_mips.h:509
ff_hevc_idct_luma_4x4_msa
void ff_hevc_idct_luma_4x4_msa(int16_t *pi16Coeffs)
Definition: hevc_idct_msa.c:1023
UNI_W_MC
#define UNI_W_MC(PEL, DIR, WIDTH)
Definition: hevcdsp_mips.h:183
ff_hevc_addblk_8x8_msa
void ff_hevc_addblk_8x8_msa(uint8_t *dst, const int16_t *pi16Coeffs, ptrdiff_t stride)
Definition: hevc_idct_msa.c:988
UNI_MC
#define UNI_MC(PEL, DIR, WIDTH)
Definition: hevcdsp_mips.h:104
ff_hevc_idct_dc_4x4_msa
void ff_hevc_idct_dc_4x4_msa(int16_t *coeffs)
Definition: hevc_idct_msa.c:1003
int32_t
int32_t
Definition: audioconvert.c:56
ff_hevc_loop_filter_chroma_v_8_msa
void ff_hevc_loop_filter_chroma_v_8_msa(uint8_t *src, ptrdiff_t src_stride, const int32_t *tc, const uint8_t *no_p, const uint8_t *no_q)
Definition: hevc_lpf_sao_msa.c:2590
h
h
Definition: vp9dsp_template.c:2070
width
#define width
Definition: dsp.h:85
ff_hevc_idct_dc_8x8_msa
void ff_hevc_idct_dc_8x8_msa(int16_t *coeffs)
Definition: hevc_idct_msa.c:1008
src
#define src
Definition: vp8dsp.c:248
ff_hevc_addblk_16x16_msa
void ff_hevc_addblk_16x16_msa(uint8_t *dst, const int16_t *pi16Coeffs, ptrdiff_t stride)
Definition: hevc_idct_msa.c:993