FFmpeg
h264dsp_init_mips.c
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2015 Parag Salasakar (Parag.Salasakar@imgtec.com)
3  * Copyright (c) 2015 Zhou Xiaoyong <zhouxiaoyong@loongson.cn>
4  *
5  * This file is part of FFmpeg.
6  *
7  * FFmpeg is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * FFmpeg is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with FFmpeg; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21 
22 #include "h264dsp_mips.h"
23 
24 #if HAVE_MSA
25 static av_cold void h264dsp_init_msa(H264DSPContext *c,
26  const int bit_depth,
27  const int chroma_format_idc)
28 {
29  if (8 == bit_depth) {
30  c->h264_v_loop_filter_luma = ff_h264_v_lpf_luma_inter_msa;
31  c->h264_h_loop_filter_luma = ff_h264_h_lpf_luma_inter_msa;
32  c->h264_h_loop_filter_luma_mbaff =
34  c->h264_v_loop_filter_luma_intra = ff_h264_v_lpf_luma_intra_msa;
35  c->h264_h_loop_filter_luma_intra = ff_h264_h_lpf_luma_intra_msa;
36  c->h264_h_loop_filter_luma_mbaff_intra =
38  c->h264_v_loop_filter_chroma = ff_h264_v_lpf_chroma_inter_msa;
39 
40  if (chroma_format_idc <= 1)
41  c->h264_h_loop_filter_chroma = ff_h264_h_lpf_chroma_inter_msa;
42  else
43  c->h264_h_loop_filter_chroma =
45 
46  if (chroma_format_idc > 1)
47  c->h264_h_loop_filter_chroma_mbaff =
49 
50  c->h264_v_loop_filter_chroma_intra =
52 
53  if (chroma_format_idc <= 1)
54  c->h264_h_loop_filter_chroma_intra =
56 
57  /* Weighted MC */
58  c->weight_h264_pixels_tab[0] = ff_weight_h264_pixels16_8_msa;
59  c->weight_h264_pixels_tab[1] = ff_weight_h264_pixels8_8_msa;
60  c->weight_h264_pixels_tab[2] = ff_weight_h264_pixels4_8_msa;
61 
62  c->biweight_h264_pixels_tab[0] = ff_biweight_h264_pixels16_8_msa;
63  c->biweight_h264_pixels_tab[1] = ff_biweight_h264_pixels8_8_msa;
64  c->biweight_h264_pixels_tab[2] = ff_biweight_h264_pixels4_8_msa;
65 
66  c->h264_idct_add = ff_h264_idct_add_msa;
67  c->h264_idct8_add = ff_h264_idct8_addblk_msa;
68  c->h264_idct_dc_add = ff_h264_idct4x4_addblk_dc_msa;
69  c->h264_idct8_dc_add = ff_h264_idct8_dc_addblk_msa;
70  c->h264_idct_add16 = ff_h264_idct_add16_msa;
71  c->h264_idct8_add4 = ff_h264_idct8_add4_msa;
72 
73  if (chroma_format_idc <= 1)
74  c->h264_idct_add8 = ff_h264_idct_add8_msa;
75  else
76  c->h264_idct_add8 = ff_h264_idct_add8_422_msa;
77 
78  c->h264_idct_add16intra = ff_h264_idct_add16_intra_msa;
79  c->h264_luma_dc_dequant_idct = ff_h264_deq_idct_luma_dc_msa;
80  } // if (8 == bit_depth)
81 }
82 #endif // #if HAVE_MSA
83 
84 #if HAVE_MMI
85 static av_cold void h264dsp_init_mmi(H264DSPContext * c, const int bit_depth,
86  const int chroma_format_idc)
87 {
88  if (bit_depth == 8) {
89  c->h264_add_pixels4_clear = ff_h264_add_pixels4_8_mmi;
90  c->h264_idct_add = ff_h264_idct_add_8_mmi;
91  c->h264_idct8_add = ff_h264_idct8_add_8_mmi;
92  c->h264_idct_dc_add = ff_h264_idct_dc_add_8_mmi;
93  c->h264_idct8_dc_add = ff_h264_idct8_dc_add_8_mmi;
94  c->h264_idct_add16 = ff_h264_idct_add16_8_mmi;
95  c->h264_idct_add16intra = ff_h264_idct_add16intra_8_mmi;
96  c->h264_idct8_add4 = ff_h264_idct8_add4_8_mmi;
97 
98  if (chroma_format_idc <= 1)
99  c->h264_idct_add8 = ff_h264_idct_add8_8_mmi;
100  else
101  c->h264_idct_add8 = ff_h264_idct_add8_422_8_mmi;
102 
103  c->h264_luma_dc_dequant_idct = ff_h264_luma_dc_dequant_idct_8_mmi;
104 
105  if (chroma_format_idc <= 1)
106  c->h264_chroma_dc_dequant_idct =
108  else
109  c->h264_chroma_dc_dequant_idct =
111 
112  c->weight_h264_pixels_tab[0] = ff_h264_weight_pixels16_8_mmi;
113  c->weight_h264_pixels_tab[1] = ff_h264_weight_pixels8_8_mmi;
114  c->weight_h264_pixels_tab[2] = ff_h264_weight_pixels4_8_mmi;
115 
116  c->biweight_h264_pixels_tab[0] = ff_h264_biweight_pixels16_8_mmi;
117  c->biweight_h264_pixels_tab[1] = ff_h264_biweight_pixels8_8_mmi;
118  c->biweight_h264_pixels_tab[2] = ff_h264_biweight_pixels4_8_mmi;
119 
120  c->h264_v_loop_filter_chroma = ff_deblock_v_chroma_8_mmi;
121  c->h264_v_loop_filter_chroma_intra = ff_deblock_v_chroma_intra_8_mmi;
122 
123  if (chroma_format_idc <= 1) {
124  c->h264_h_loop_filter_chroma =
126  c->h264_h_loop_filter_chroma_intra =
128  }
129 
130  c->h264_v_loop_filter_luma = ff_deblock_v_luma_8_mmi;
131  c->h264_v_loop_filter_luma_intra = ff_deblock_v_luma_intra_8_mmi;
132  c->h264_h_loop_filter_luma = ff_deblock_h_luma_8_mmi;
133  c->h264_h_loop_filter_luma_intra = ff_deblock_h_luma_intra_8_mmi;
134  }
135 }
136 #endif /* HAVE_MMI */
137 
139  const int chroma_format_idc)
140 {
141 #if HAVE_MMI
142  h264dsp_init_mmi(c, bit_depth, chroma_format_idc);
143 #endif /* HAVE_MMI */
144 #if HAVE_MSA
145  h264dsp_init_msa(c, bit_depth, chroma_format_idc);
146 #endif // #if HAVE_MSA
147 }
ff_h264_weight_pixels8_8_mmi
void ff_h264_weight_pixels8_8_mmi(uint8_t *block, ptrdiff_t stride, int height, int log2_denom, int weight, int offset)
Definition: h264dsp_mmi.c:1277
ff_h264_idct_add8_422_msa
void ff_h264_idct_add8_422_msa(uint8_t **dst, const int32_t *blk_offset, int16_t *block, int32_t dst_stride, const uint8_t nnzc[15 *8])
Definition: h264idct_msa.c:414
bit_depth
static void bit_depth(AudioStatsContext *s, uint64_t mask, uint64_t imask, AVRational *depth)
Definition: af_astats.c:226
ff_h264_idct_add_8_mmi
void ff_h264_idct_add_8_mmi(uint8_t *dst, int16_t *block, int stride)
Definition: h264dsp_mmi.c:80
ff_deblock_v_luma_intra_8_mmi
void ff_deblock_v_luma_intra_8_mmi(uint8_t *pix, int stride, int alpha, int beta)
Definition: h264dsp_mmi.c:2252
ff_biweight_h264_pixels8_8_msa
void ff_biweight_h264_pixels8_8_msa(uint8_t *dst, uint8_t *src, ptrdiff_t stride, int height, int log2_denom, int weightd, int weights, int offset)
Definition: h264dsp_msa.c:2568
ff_h264_h_loop_filter_luma_mbaff_msa
void ff_h264_h_loop_filter_luma_mbaff_msa(uint8_t *src, int32_t stride, int32_t alpha, int32_t beta, int8_t *tc0)
Definition: h264dsp_msa.c:2314
ff_h264_biweight_pixels8_8_mmi
void ff_h264_biweight_pixels8_8_mmi(uint8_t *dst, uint8_t *src, ptrdiff_t stride, int height, int log2_denom, int weightd, int weights, int offset)
Definition: h264dsp_mmi.c:1320
ff_h264_idct_add16_8_mmi
void ff_h264_idct_add16_8_mmi(uint8_t *dst, const int *block_offset, int16_t *block, int stride, const uint8_t nnzc[15 *8])
Definition: h264dsp_mmi.c:785
ff_h264dsp_init_mips
av_cold void ff_h264dsp_init_mips(H264DSPContext *c, const int bit_depth, const int chroma_format_idc)
Definition: h264dsp_init_mips.c:138
ff_biweight_h264_pixels16_8_msa
void ff_biweight_h264_pixels16_8_msa(uint8_t *dst, uint8_t *src, ptrdiff_t stride, int height, int log2_denom, int weightd, int weights, int offset)
Definition: h264dsp_msa.c:2455
ff_weight_h264_pixels8_8_msa
void ff_weight_h264_pixels8_8_msa(uint8_t *src, ptrdiff_t stride, int height, int log2_denom, int weight, int offset)
Definition: h264dsp_msa.c:2429
ff_h264_h_lpf_chroma_inter_msa
void ff_h264_h_lpf_chroma_inter_msa(uint8_t *src, int stride, int alpha, int beta, int8_t *tc0)
Definition: h264dsp_msa.c:2221
ff_h264_idct4x4_addblk_dc_msa
void ff_h264_idct4x4_addblk_dc_msa(uint8_t *dst, int16_t *src, int32_t dst_stride)
Definition: h264idct_msa.c:320
ff_h264_biweight_pixels16_8_mmi
void ff_h264_biweight_pixels16_8_mmi(uint8_t *dst, uint8_t *src, ptrdiff_t stride, int height, int log2_denom, int weightd, int weights, int offset)
Definition: h264dsp_mmi.c:1206
ff_h264_luma_dc_dequant_idct_8_mmi
void ff_h264_luma_dc_dequant_idct_8_mmi(int16_t *output, int16_t *input, int qmul)
Definition: h264dsp_mmi.c:876
ff_h264_deq_idct_luma_dc_msa
void ff_h264_deq_idct_luma_dc_msa(int16_t *dst, int16_t *src, int32_t de_q_val)
Definition: h264idct_msa.c:467
ff_deblock_h_chroma_8_mmi
void ff_deblock_h_chroma_8_mmi(uint8_t *pix, int stride, int alpha, int beta, int8_t *tc0)
Definition: h264dsp_mmi.c:1970
ff_h264_v_lpf_luma_intra_msa
void ff_h264_v_lpf_luma_intra_msa(uint8_t *src, int stride, int alpha, int beta)
Definition: h264dsp_msa.c:2273
ff_h264_idct8_add4_8_mmi
void ff_h264_idct8_add4_8_mmi(uint8_t *dst, const int *block_offset, int16_t *block, int stride, const uint8_t nnzc[15 *8])
Definition: h264dsp_mmi.c:815
av_cold
#define av_cold
Definition: attributes.h:84
ff_h264_idct8_dc_add_8_mmi
void ff_h264_idct8_dc_add_8_mmi(uint8_t *dst, int16_t *block, int stride)
Definition: h264dsp_mmi.c:700
ff_h264_weight_pixels16_8_mmi
void ff_h264_weight_pixels16_8_mmi(uint8_t *block, ptrdiff_t stride, int height, int log2_denom, int weight, int offset)
Definition: h264dsp_mmi.c:1150
ff_h264_biweight_pixels4_8_mmi
void ff_h264_biweight_pixels4_8_mmi(uint8_t *dst, uint8_t *src, ptrdiff_t stride, int height, int log2_denom, int weightd, int weights, int offset)
Definition: h264dsp_mmi.c:1410
ff_h264_idct_add8_msa
void ff_h264_idct_add8_msa(uint8_t **dst, const int32_t *blk_offset, int16_t *block, int32_t dst_stride, const uint8_t nnzc[15 *8])
Definition: h264idct_msa.c:393
ff_h264_idct8_dc_addblk_msa
void ff_h264_idct8_dc_addblk_msa(uint8_t *dst, int16_t *src, int32_t dst_stride)
Definition: h264idct_msa.c:342
ff_h264_v_lpf_luma_inter_msa
void ff_h264_v_lpf_luma_inter_msa(uint8_t *src, int stride, int alpha, int beta, int8_t *tc0)
Definition: h264dsp_msa.c:2198
ff_h264_weight_pixels4_8_mmi
void ff_h264_weight_pixels4_8_mmi(uint8_t *block, ptrdiff_t stride, int height, int log2_denom, int weight, int offset)
Definition: h264dsp_mmi.c:1372
h264dsp_mips.h
ff_h264_idct8_add_8_mmi
void ff_h264_idct8_add_8_mmi(uint8_t *dst, int16_t *block, int stride)
Definition: h264dsp_mmi.c:177
ff_h264_idct_add_msa
void ff_h264_idct_add_msa(uint8_t *dst, int16_t *src, int32_t dst_stride)
Definition: h264idct_msa.c:273
ff_weight_h264_pixels16_8_msa
void ff_weight_h264_pixels16_8_msa(uint8_t *src, ptrdiff_t stride, int height, int log2_denom, int weight, int offset)
Definition: h264dsp_msa.c:2331
ff_h264_h_loop_filter_chroma422_msa
void ff_h264_h_loop_filter_chroma422_msa(uint8_t *src, int32_t stride, int32_t alpha, int32_t beta, int8_t *tc0)
Definition: h264dsp_msa.c:2297
c
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
Definition: undefined.txt:32
ff_h264_h_lpf_chroma_intra_msa
void ff_h264_h_lpf_chroma_intra_msa(uint8_t *src, int stride, int alpha, int beta)
Definition: h264dsp_msa.c:2281
H264DSPContext
Context for storing H.264 DSP functions.
Definition: h264dsp.h:42
ff_deblock_v_chroma_8_mmi
void ff_deblock_v_chroma_8_mmi(uint8_t *pix, ptrdiff_t stride, int alpha, int beta, int8_t *tc0)
Definition: h264dsp_mmi.c:1808
ff_biweight_h264_pixels4_8_msa
void ff_biweight_h264_pixels4_8_msa(uint8_t *dst, uint8_t *src, ptrdiff_t stride, int height, int log2_denom, int weightd, int weights, int offset)
Definition: h264dsp_msa.c:2585
ff_h264_add_pixels4_8_mmi
void ff_h264_add_pixels4_8_mmi(uint8_t *_dst, int16_t *_src, int stride)
Definition: h264dsp_mmi.c:30
ff_deblock_v_chroma_intra_8_mmi
void ff_deblock_v_chroma_intra_8_mmi(uint8_t *pix, int stride, int alpha, int beta)
Definition: h264dsp_mmi.c:1892
ff_h264_idct_add8_422_8_mmi
void ff_h264_idct_add8_422_8_mmi(uint8_t **dest, const int *block_offset, int16_t *block, int stride, const uint8_t nnzc[15 *8])
Definition: h264dsp_mmi.c:848
ff_deblock_h_luma_intra_8_mmi
void ff_deblock_h_luma_intra_8_mmi(uint8_t *pix, int stride, int alpha, int beta)
Definition: h264dsp_mmi.c:2478
ff_h264_v_lpf_chroma_intra_msa
void ff_h264_v_lpf_chroma_intra_msa(uint8_t *src, int stride, int alpha, int beta)
Definition: h264dsp_msa.c:2289
ff_h264_idct8_addblk_msa
void ff_h264_idct8_addblk_msa(uint8_t *dst, int16_t *src, int32_t dst_stride)
Definition: h264idct_msa.c:314
ff_h264_v_lpf_chroma_inter_msa
void ff_h264_v_lpf_chroma_inter_msa(uint8_t *src, int stride, int alpha, int beta, int8_t *tc0)
Definition: h264dsp_msa.c:2243
ff_weight_h264_pixels4_8_msa
void ff_weight_h264_pixels4_8_msa(uint8_t *src, ptrdiff_t stride, int height, int log2_denom, int weight, int offset)
Definition: h264dsp_msa.c:2442
ff_deblock_h_chroma_intra_8_mmi
void ff_deblock_h_chroma_intra_8_mmi(uint8_t *pix, int stride, int alpha, int beta)
Definition: h264dsp_mmi.c:2110
ff_deblock_v_luma_8_mmi
void ff_deblock_v_luma_8_mmi(uint8_t *pix, int stride, int alpha, int beta, int8_t *tc0)
Definition: h264dsp_mmi.c:2243
ff_h264_idct_add16intra_8_mmi
void ff_h264_idct_add16intra_8_mmi(uint8_t *dst, const int *block_offset, int16_t *block, int stride, const uint8_t nnzc[15 *8])
Definition: h264dsp_mmi.c:802
ff_h264_idct_dc_add_8_mmi
void ff_h264_idct_dc_add_8_mmi(uint8_t *dst, int16_t *block, int stride)
Definition: h264dsp_mmi.c:656
ff_deblock_h_luma_8_mmi
void ff_deblock_h_luma_8_mmi(uint8_t *pix, int stride, int alpha, int beta, int8_t *tc0)
Definition: h264dsp_mmi.c:2259
ff_h264_idct_add16_msa
void ff_h264_idct_add16_msa(uint8_t *dst, const int32_t *blk_offset, int16_t *block, int32_t stride, const uint8_t nnzc[15 *8])
Definition: h264idct_msa.c:348
ff_h264_h_loop_filter_luma_mbaff_intra_msa
void ff_h264_h_loop_filter_luma_mbaff_intra_msa(uint8_t *src, int stride, int alpha, int beta)
ff_h264_h_loop_filter_chroma422_mbaff_msa
void ff_h264_h_loop_filter_chroma422_mbaff_msa(uint8_t *src, int32_t stride, int32_t alpha, int32_t beta, int8_t *tc0)
Definition: h264dsp_msa.c:2305
ff_h264_chroma422_dc_dequant_idct_8_mmi
void ff_h264_chroma422_dc_dequant_idct_8_mmi(int16_t *block, int qmul)
Definition: h264dsp_mmi.c:1103
ff_h264_idct_add8_8_mmi
void ff_h264_idct_add8_8_mmi(uint8_t **dest, const int *block_offset, int16_t *block, int stride, const uint8_t nnzc[15 *8])
Definition: h264dsp_mmi.c:832
ff_h264_idct8_add4_msa
void ff_h264_idct8_add4_msa(uint8_t *dst, const int *blk_offset, int16_t *blk, int dst_stride, const uint8_t nnzc[15 *8])
ff_h264_chroma_dc_dequant_idct_8_mmi
void ff_h264_chroma_dc_dequant_idct_8_mmi(int16_t *block, int qmul)
Definition: h264dsp_mmi.c:1136
ff_h264_h_lpf_luma_inter_msa
void ff_h264_h_lpf_luma_inter_msa(uint8_t *src, int stride, int alpha, int beta, int8_t *tc0)
Definition: h264dsp_msa.c:2176
ff_h264_h_lpf_luma_intra_msa
void ff_h264_h_lpf_luma_intra_msa(uint8_t *src, int stride, int alpha, int beta)
Definition: h264dsp_msa.c:2265
ff_h264_idct_add16_intra_msa
void ff_h264_idct_add16_intra_msa(uint8_t *dst, const int32_t *blk_offset, int16_t *block, int32_t dst_stride, const uint8_t nnzc[15 *8])
Definition: h264idct_msa.c:448