1 /*
2  *  Copyright (c) 2015 The WebM project authors. All Rights Reserved.
3  *
4  *  Use of this source code is governed by a BSD-style license
5  *  that can be found in the LICENSE file in the root of the source
6  *  tree. An additional intellectual property rights grant can be found
7  *  in the file PATENTS.  All contributing project authors may
8  *  be found in the AUTHORS file in the root of the source tree.
9  */
10 
11 #ifndef VPX_VPX_DSP_MIPS_FWD_TXFM_MSA_H_
12 #define VPX_VPX_DSP_MIPS_FWD_TXFM_MSA_H_
13 
14 #include "vpx_dsp/mips/txfm_macros_msa.h"
15 #include "vpx_dsp/txfm_common.h"
16 
17 #define VP9_FDCT4(in0, in1, in2, in3, out0, out1, out2, out3)                  \
18   {                                                                            \
19     v8i16 cnst0_m, cnst1_m, cnst2_m, cnst3_m;                                  \
20     v8i16 vec0_m, vec1_m, vec2_m, vec3_m;                                      \
21     v4i32 vec4_m, vec5_m, vec6_m, vec7_m;                                      \
22     v8i16 coeff_m = {                                                          \
23       cospi_16_64, -cospi_16_64, cospi_8_64, cospi_24_64, -cospi_8_64, 0, 0, 0 \
24     };                                                                         \
25                                                                                \
26     BUTTERFLY_4(in0, in1, in2, in3, vec0_m, vec1_m, vec2_m, vec3_m);           \
27     ILVR_H2_SH(vec1_m, vec0_m, vec3_m, vec2_m, vec0_m, vec2_m);                \
28     SPLATI_H2_SH(coeff_m, 0, 1, cnst0_m, cnst1_m);                             \
29     cnst1_m = __msa_ilvev_h(cnst1_m, cnst0_m);                                 \
30     vec5_m = __msa_dotp_s_w(vec0_m, cnst1_m);                                  \
31                                                                                \
32     SPLATI_H2_SH(coeff_m, 4, 3, cnst2_m, cnst3_m);                             \
33     cnst2_m = __msa_ilvev_h(cnst3_m, cnst2_m);                                 \
34     vec7_m = __msa_dotp_s_w(vec2_m, cnst2_m);                                  \
35                                                                                \
36     vec4_m = __msa_dotp_s_w(vec0_m, cnst0_m);                                  \
37     cnst2_m = __msa_splati_h(coeff_m, 2);                                      \
38     cnst2_m = __msa_ilvev_h(cnst2_m, cnst3_m);                                 \
39     vec6_m = __msa_dotp_s_w(vec2_m, cnst2_m);                                  \
40                                                                                \
41     SRARI_W4_SW(vec4_m, vec5_m, vec6_m, vec7_m, DCT_CONST_BITS);               \
42     PCKEV_H4_SH(vec4_m, vec4_m, vec5_m, vec5_m, vec6_m, vec6_m, vec7_m,        \
43                 vec7_m, out0, out2, out1, out3);                               \
44   }
45 
46 #define SRLI_AVE_S_4V_H(in0, in1, in2, in3, in4, in5, in6, in7)              \
47   {                                                                          \
48     v8i16 vec0_m, vec1_m, vec2_m, vec3_m, vec4_m, vec5_m, vec6_m, vec7_m;    \
49                                                                              \
50     SRLI_H4_SH(in0, in1, in2, in3, vec0_m, vec1_m, vec2_m, vec3_m, 15);      \
51     SRLI_H4_SH(in4, in5, in6, in7, vec4_m, vec5_m, vec6_m, vec7_m, 15);      \
52     AVE_SH4_SH(vec0_m, in0, vec1_m, in1, vec2_m, in2, vec3_m, in3, in0, in1, \
53                in2, in3);                                                    \
54     AVE_SH4_SH(vec4_m, in4, vec5_m, in5, vec6_m, in6, vec7_m, in7, in4, in5, \
55                in6, in7);                                                    \
56   }
57 
58 #define VP9_FDCT8(in0, in1, in2, in3, in4, in5, in6, in7, out0, out1, out2,  \
59                   out3, out4, out5, out6, out7)                              \
60   {                                                                          \
61     v8i16 s0_m, s1_m, s2_m, s3_m, s4_m, s5_m, s6_m;                          \
62     v8i16 s7_m, x0_m, x1_m, x2_m, x3_m;                                      \
63     v8i16 coeff_m = { cospi_16_64, -cospi_16_64, cospi_8_64,  cospi_24_64,   \
64                       cospi_4_64,  cospi_28_64,  cospi_12_64, cospi_20_64 }; \
65                                                                              \
66     /* FDCT stage1 */                                                        \
67     BUTTERFLY_8(in0, in1, in2, in3, in4, in5, in6, in7, s0_m, s1_m, s2_m,    \
68                 s3_m, s4_m, s5_m, s6_m, s7_m);                               \
69     BUTTERFLY_4(s0_m, s1_m, s2_m, s3_m, x0_m, x1_m, x2_m, x3_m);             \
70     ILVL_H2_SH(x1_m, x0_m, x3_m, x2_m, s0_m, s2_m);                          \
71     ILVR_H2_SH(x1_m, x0_m, x3_m, x2_m, s1_m, s3_m);                          \
72     SPLATI_H2_SH(coeff_m, 0, 1, x0_m, x1_m);                                 \
73     x1_m = __msa_ilvev_h(x1_m, x0_m);                                        \
74     out4 = DOT_SHIFT_RIGHT_PCK_H(s0_m, s1_m, x1_m);                          \
75                                                                              \
76     SPLATI_H2_SH(coeff_m, 2, 3, x2_m, x3_m);                                 \
77     x2_m = -x2_m;                                                            \
78     x2_m = __msa_ilvev_h(x3_m, x2_m);                                        \
79     out6 = DOT_SHIFT_RIGHT_PCK_H(s2_m, s3_m, x2_m);                          \
80                                                                              \
81     out0 = DOT_SHIFT_RIGHT_PCK_H(s0_m, s1_m, x0_m);                          \
82     x2_m = __msa_splati_h(coeff_m, 2);                                       \
83     x2_m = __msa_ilvev_h(x2_m, x3_m);                                        \
84     out2 = DOT_SHIFT_RIGHT_PCK_H(s2_m, s3_m, x2_m);                          \
85                                                                              \
86     /* stage2 */                                                             \
87     ILVRL_H2_SH(s5_m, s6_m, s1_m, s0_m);                                     \
88                                                                              \
89     s6_m = DOT_SHIFT_RIGHT_PCK_H(s0_m, s1_m, x0_m);                          \
90     s5_m = DOT_SHIFT_RIGHT_PCK_H(s0_m, s1_m, x1_m);                          \
91                                                                              \
92     /* stage3 */                                                             \
93     BUTTERFLY_4(s4_m, s7_m, s6_m, s5_m, x0_m, x3_m, x2_m, x1_m);             \
94                                                                              \
95     /* stage4 */                                                             \
96     ILVL_H2_SH(x3_m, x0_m, x2_m, x1_m, s4_m, s6_m);                          \
97     ILVR_H2_SH(x3_m, x0_m, x2_m, x1_m, s5_m, s7_m);                          \
98                                                                              \
99     SPLATI_H2_SH(coeff_m, 4, 5, x0_m, x1_m);                                 \
100     x1_m = __msa_ilvev_h(x0_m, x1_m);                                        \
101     out1 = DOT_SHIFT_RIGHT_PCK_H(s4_m, s5_m, x1_m);                          \
102                                                                              \
103     SPLATI_H2_SH(coeff_m, 6, 7, x2_m, x3_m);                                 \
104     x2_m = __msa_ilvev_h(x3_m, x2_m);                                        \
105     out5 = DOT_SHIFT_RIGHT_PCK_H(s6_m, s7_m, x2_m);                          \
106                                                                              \
107     x1_m = __msa_splati_h(coeff_m, 5);                                       \
108     x0_m = -x0_m;                                                            \
109     x0_m = __msa_ilvev_h(x1_m, x0_m);                                        \
110     out7 = DOT_SHIFT_RIGHT_PCK_H(s4_m, s5_m, x0_m);                          \
111                                                                              \
112     x2_m = __msa_splati_h(coeff_m, 6);                                       \
113     x3_m = -x3_m;                                                            \
114     x2_m = __msa_ilvev_h(x2_m, x3_m);                                        \
115     out3 = DOT_SHIFT_RIGHT_PCK_H(s6_m, s7_m, x2_m);                          \
116   }
117 
118 #define FDCT8x16_EVEN(in0, in1, in2, in3, in4, in5, in6, in7, out0, out1,    \
119                       out2, out3, out4, out5, out6, out7)                    \
120   {                                                                          \
121     v8i16 s0_m, s1_m, s2_m, s3_m, s4_m, s5_m, s6_m, s7_m;                    \
122     v8i16 x0_m, x1_m, x2_m, x3_m;                                            \
123     v8i16 coeff_m = { cospi_16_64, -cospi_16_64, cospi_8_64,  cospi_24_64,   \
124                       cospi_4_64,  cospi_28_64,  cospi_12_64, cospi_20_64 }; \
125                                                                              \
126     /* FDCT stage1 */                                                        \
127     BUTTERFLY_8(in0, in1, in2, in3, in4, in5, in6, in7, s0_m, s1_m, s2_m,    \
128                 s3_m, s4_m, s5_m, s6_m, s7_m);                               \
129     BUTTERFLY_4(s0_m, s1_m, s2_m, s3_m, x0_m, x1_m, x2_m, x3_m);             \
130     ILVL_H2_SH(x1_m, x0_m, x3_m, x2_m, s0_m, s2_m);                          \
131     ILVR_H2_SH(x1_m, x0_m, x3_m, x2_m, s1_m, s3_m);                          \
132     SPLATI_H2_SH(coeff_m, 0, 1, x0_m, x1_m);                                 \
133     x1_m = __msa_ilvev_h(x1_m, x0_m);                                        \
134     out4 = DOT_SHIFT_RIGHT_PCK_H(s0_m, s1_m, x1_m);                          \
135                                                                              \
136     SPLATI_H2_SH(coeff_m, 2, 3, x2_m, x3_m);                                 \
137     x2_m = -x2_m;                                                            \
138     x2_m = __msa_ilvev_h(x3_m, x2_m);                                        \
139     out6 = DOT_SHIFT_RIGHT_PCK_H(s2_m, s3_m, x2_m);                          \
140                                                                              \
141     out0 = DOT_SHIFT_RIGHT_PCK_H(s0_m, s1_m, x0_m);                          \
142     x2_m = __msa_splati_h(coeff_m, 2);                                       \
143     x2_m = __msa_ilvev_h(x2_m, x3_m);                                        \
144     out2 = DOT_SHIFT_RIGHT_PCK_H(s2_m, s3_m, x2_m);                          \
145                                                                              \
146     /* stage2 */                                                             \
147     ILVRL_H2_SH(s5_m, s6_m, s1_m, s0_m);                                     \
148                                                                              \
149     s6_m = DOT_SHIFT_RIGHT_PCK_H(s0_m, s1_m, x0_m);                          \
150     s5_m = DOT_SHIFT_RIGHT_PCK_H(s0_m, s1_m, x1_m);                          \
151                                                                              \
152     /* stage3 */                                                             \
153     BUTTERFLY_4(s4_m, s7_m, s6_m, s5_m, x0_m, x3_m, x2_m, x1_m);             \
154                                                                              \
155     /* stage4 */                                                             \
156     ILVL_H2_SH(x3_m, x0_m, x2_m, x1_m, s4_m, s6_m);                          \
157     ILVR_H2_SH(x3_m, x0_m, x2_m, x1_m, s5_m, s7_m);                          \
158                                                                              \
159     SPLATI_H2_SH(coeff_m, 4, 5, x0_m, x1_m);                                 \
160     x1_m = __msa_ilvev_h(x0_m, x1_m);                                        \
161     out1 = DOT_SHIFT_RIGHT_PCK_H(s4_m, s5_m, x1_m);                          \
162                                                                              \
163     SPLATI_H2_SH(coeff_m, 6, 7, x2_m, x3_m);                                 \
164     x2_m = __msa_ilvev_h(x3_m, x2_m);                                        \
165     out5 = DOT_SHIFT_RIGHT_PCK_H(s6_m, s7_m, x2_m);                          \
166                                                                              \
167     x1_m = __msa_splati_h(coeff_m, 5);                                       \
168     x0_m = -x0_m;                                                            \
169     x0_m = __msa_ilvev_h(x1_m, x0_m);                                        \
170     out7 = DOT_SHIFT_RIGHT_PCK_H(s4_m, s5_m, x0_m);                          \
171                                                                              \
172     x2_m = __msa_splati_h(coeff_m, 6);                                       \
173     x3_m = -x3_m;                                                            \
174     x2_m = __msa_ilvev_h(x2_m, x3_m);                                        \
175     out3 = DOT_SHIFT_RIGHT_PCK_H(s6_m, s7_m, x2_m);                          \
176   }
177 
178 #define FDCT8x16_ODD(input0, input1, input2, input3, input4, input5, input6,   \
179                      input7, out1, out3, out5, out7, out9, out11, out13,       \
180                      out15)                                                    \
181   {                                                                            \
182     v8i16 stp21_m, stp22_m, stp23_m, stp24_m, stp25_m, stp26_m;                \
183     v8i16 stp30_m, stp31_m, stp32_m, stp33_m, stp34_m, stp35_m;                \
184     v8i16 stp36_m, stp37_m, vec0_m, vec1_m;                                    \
185     v8i16 vec2_m, vec3_m, vec4_m, vec5_m, vec6_m;                              \
186     v8i16 cnst0_m, cnst1_m, cnst4_m, cnst5_m;                                  \
187     v8i16 coeff_m = { cospi_16_64, -cospi_16_64, cospi_8_64,  cospi_24_64,     \
188                       -cospi_8_64, -cospi_24_64, cospi_12_64, cospi_20_64 };   \
189     v8i16 coeff1_m = { cospi_2_64,  cospi_30_64, cospi_14_64, cospi_18_64,     \
190                        cospi_10_64, cospi_22_64, cospi_6_64,  cospi_26_64 };   \
191     v8i16 coeff2_m = {                                                         \
192       -cospi_2_64, -cospi_10_64, -cospi_18_64, -cospi_26_64, 0, 0, 0, 0        \
193     };                                                                         \
194                                                                                \
195     /* stp 1 */                                                                \
196     ILVL_H2_SH(input2, input5, input3, input4, vec2_m, vec4_m);                \
197     ILVR_H2_SH(input2, input5, input3, input4, vec3_m, vec5_m);                \
198                                                                                \
199     cnst4_m = __msa_splati_h(coeff_m, 0);                                      \
200     stp25_m = DOT_SHIFT_RIGHT_PCK_H(vec2_m, vec3_m, cnst4_m);                  \
201                                                                                \
202     cnst5_m = __msa_splati_h(coeff_m, 1);                                      \
203     cnst5_m = __msa_ilvev_h(cnst5_m, cnst4_m);                                 \
204     stp22_m = DOT_SHIFT_RIGHT_PCK_H(vec2_m, vec3_m, cnst5_m);                  \
205     stp24_m = DOT_SHIFT_RIGHT_PCK_H(vec4_m, vec5_m, cnst4_m);                  \
206     stp23_m = DOT_SHIFT_RIGHT_PCK_H(vec4_m, vec5_m, cnst5_m);                  \
207                                                                                \
208     /* stp2 */                                                                 \
209     BUTTERFLY_4(input0, input1, stp22_m, stp23_m, stp30_m, stp31_m, stp32_m,   \
210                 stp33_m);                                                      \
211     BUTTERFLY_4(input7, input6, stp25_m, stp24_m, stp37_m, stp36_m, stp35_m,   \
212                 stp34_m);                                                      \
213                                                                                \
214     ILVL_H2_SH(stp36_m, stp31_m, stp35_m, stp32_m, vec2_m, vec4_m);            \
215     ILVR_H2_SH(stp36_m, stp31_m, stp35_m, stp32_m, vec3_m, vec5_m);            \
216                                                                                \
217     SPLATI_H2_SH(coeff_m, 2, 3, cnst0_m, cnst1_m);                             \
218     cnst0_m = __msa_ilvev_h(cnst0_m, cnst1_m);                                 \
219     stp26_m = DOT_SHIFT_RIGHT_PCK_H(vec2_m, vec3_m, cnst0_m);                  \
220                                                                                \
221     cnst0_m = __msa_splati_h(coeff_m, 4);                                      \
222     cnst1_m = __msa_ilvev_h(cnst1_m, cnst0_m);                                 \
223     stp21_m = DOT_SHIFT_RIGHT_PCK_H(vec2_m, vec3_m, cnst1_m);                  \
224                                                                                \
225     SPLATI_H2_SH(coeff_m, 5, 2, cnst0_m, cnst1_m);                             \
226     cnst1_m = __msa_ilvev_h(cnst0_m, cnst1_m);                                 \
227     stp25_m = DOT_SHIFT_RIGHT_PCK_H(vec4_m, vec5_m, cnst1_m);                  \
228                                                                                \
229     cnst0_m = __msa_splati_h(coeff_m, 3);                                      \
230     cnst1_m = __msa_ilvev_h(cnst1_m, cnst0_m);                                 \
231     stp22_m = DOT_SHIFT_RIGHT_PCK_H(vec4_m, vec5_m, cnst1_m);                  \
232                                                                                \
233     /* stp4 */                                                                 \
234     BUTTERFLY_4(stp30_m, stp37_m, stp26_m, stp21_m, vec6_m, vec2_m, vec4_m,    \
235                 vec5_m);                                                       \
236     BUTTERFLY_4(stp33_m, stp34_m, stp25_m, stp22_m, stp21_m, stp23_m, stp24_m, \
237                 stp31_m);                                                      \
238                                                                                \
239     ILVRL_H2_SH(vec2_m, vec6_m, vec1_m, vec0_m);                               \
240     SPLATI_H2_SH(coeff1_m, 0, 1, cnst0_m, cnst1_m);                            \
241     cnst0_m = __msa_ilvev_h(cnst0_m, cnst1_m);                                 \
242                                                                                \
243     out1 = DOT_SHIFT_RIGHT_PCK_H(vec0_m, vec1_m, cnst0_m);                     \
244                                                                                \
245     cnst0_m = __msa_splati_h(coeff2_m, 0);                                     \
246     cnst0_m = __msa_ilvev_h(cnst1_m, cnst0_m);                                 \
247     out15 = DOT_SHIFT_RIGHT_PCK_H(vec0_m, vec1_m, cnst0_m);                    \
248                                                                                \
249     ILVRL_H2_SH(vec4_m, vec5_m, vec1_m, vec0_m);                               \
250     SPLATI_H2_SH(coeff1_m, 2, 3, cnst0_m, cnst1_m);                            \
251     cnst1_m = __msa_ilvev_h(cnst1_m, cnst0_m);                                 \
252                                                                                \
253     out9 = DOT_SHIFT_RIGHT_PCK_H(vec0_m, vec1_m, cnst1_m);                     \
254                                                                                \
255     cnst1_m = __msa_splati_h(coeff2_m, 2);                                     \
256     cnst0_m = __msa_ilvev_h(cnst0_m, cnst1_m);                                 \
257     out7 = DOT_SHIFT_RIGHT_PCK_H(vec0_m, vec1_m, cnst0_m);                     \
258                                                                                \
259     ILVRL_H2_SH(stp23_m, stp21_m, vec1_m, vec0_m);                             \
260     SPLATI_H2_SH(coeff1_m, 4, 5, cnst0_m, cnst1_m);                            \
261     cnst0_m = __msa_ilvev_h(cnst0_m, cnst1_m);                                 \
262     out5 = DOT_SHIFT_RIGHT_PCK_H(vec0_m, vec1_m, cnst0_m);                     \
263                                                                                \
264     cnst0_m = __msa_splati_h(coeff2_m, 1);                                     \
265     cnst0_m = __msa_ilvev_h(cnst1_m, cnst0_m);                                 \
266     out11 = DOT_SHIFT_RIGHT_PCK_H(vec0_m, vec1_m, cnst0_m);                    \
267                                                                                \
268     ILVRL_H2_SH(stp24_m, stp31_m, vec1_m, vec0_m);                             \
269     SPLATI_H2_SH(coeff1_m, 6, 7, cnst0_m, cnst1_m);                            \
270     cnst1_m = __msa_ilvev_h(cnst1_m, cnst0_m);                                 \
271                                                                                \
272     out13 = DOT_SHIFT_RIGHT_PCK_H(vec0_m, vec1_m, cnst1_m);                    \
273                                                                                \
274     cnst1_m = __msa_splati_h(coeff2_m, 3);                                     \
275     cnst0_m = __msa_ilvev_h(cnst0_m, cnst1_m);                                 \
276     out3 = DOT_SHIFT_RIGHT_PCK_H(vec0_m, vec1_m, cnst0_m);                     \
277   }
278 
279 #define FDCT_POSTPROC_2V_NEG_H(vec0, vec1) \
280   {                                        \
281     v8i16 tp0_m, tp1_m;                    \
282     v8i16 one_m = __msa_ldi_h(1);          \
283                                            \
284     tp0_m = __msa_clti_s_h(vec0, 0);       \
285     tp1_m = __msa_clti_s_h(vec1, 0);       \
286     vec0 += 1;                             \
287     vec1 += 1;                             \
288     tp0_m = one_m & tp0_m;                 \
289     tp1_m = one_m & tp1_m;                 \
290     vec0 += tp0_m;                         \
291     vec1 += tp1_m;                         \
292     vec0 >>= 2;                            \
293     vec1 >>= 2;                            \
294   }
295 
296 #define FDCT32_POSTPROC_NEG_W(vec)   \
297   {                                  \
298     v4i32 temp_m;                    \
299     v4i32 one_m = __msa_ldi_w(1);    \
300                                      \
301     temp_m = __msa_clti_s_w(vec, 0); \
302     vec += 1;                        \
303     temp_m = one_m & temp_m;         \
304     vec += temp_m;                   \
305     vec >>= 2;                       \
306   }
307 
308 #define FDCT32_POSTPROC_2V_POS_H(vec0, vec1)        \
309   {                                                 \
310     v8i16 tp0_m, tp1_m;                             \
311     v8i16 one = __msa_ldi_h(1);                     \
312                                                     \
313     tp0_m = __msa_clei_s_h(vec0, 0);                \
314     tp1_m = __msa_clei_s_h(vec1, 0);                \
315     tp0_m = (v8i16)__msa_xori_b((v16u8)tp0_m, 255); \
316     tp1_m = (v8i16)__msa_xori_b((v16u8)tp1_m, 255); \
317     vec0 += 1;                                      \
318     vec1 += 1;                                      \
319     tp0_m = one & tp0_m;                            \
320     tp1_m = one & tp1_m;                            \
321     vec0 += tp0_m;                                  \
322     vec1 += tp1_m;                                  \
323     vec0 >>= 2;                                     \
324     vec1 >>= 2;                                     \
325   }
326 
327 #define DOTP_CONST_PAIR_W(reg0_left, reg1_left, reg0_right, reg1_right, \
328                           const0, const1, out0, out1, out2, out3)       \
329   {                                                                     \
330     v4i32 s0_m, s1_m, s2_m, s3_m, s4_m, s5_m, s6_m, s7_m;               \
331     v2i64 tp0_m, tp1_m, tp2_m, tp3_m;                                   \
332     v4i32 k0_m = __msa_fill_w((int32_t)const0);                         \
333                                                                         \
334     s0_m = __msa_fill_w((int32_t)const1);                               \
335     k0_m = __msa_ilvev_w(s0_m, k0_m);                                   \
336                                                                         \
337     ILVRL_W2_SW(-reg1_left, reg0_left, s1_m, s0_m);                     \
338     ILVRL_W2_SW(reg0_left, reg1_left, s3_m, s2_m);                      \
339     ILVRL_W2_SW(-reg1_right, reg0_right, s5_m, s4_m);                   \
340     ILVRL_W2_SW(reg0_right, reg1_right, s7_m, s6_m);                    \
341                                                                         \
342     DOTP_SW2_SD(s0_m, s1_m, k0_m, k0_m, tp0_m, tp1_m);                  \
343     DOTP_SW2_SD(s4_m, s5_m, k0_m, k0_m, tp2_m, tp3_m);                  \
344     tp0_m = __msa_srari_d(tp0_m, DCT_CONST_BITS);                       \
345     tp1_m = __msa_srari_d(tp1_m, DCT_CONST_BITS);                       \
346     tp2_m = __msa_srari_d(tp2_m, DCT_CONST_BITS);                       \
347     tp3_m = __msa_srari_d(tp3_m, DCT_CONST_BITS);                       \
348     out0 = __msa_pckev_w((v4i32)tp0_m, (v4i32)tp1_m);                   \
349     out1 = __msa_pckev_w((v4i32)tp2_m, (v4i32)tp3_m);                   \
350                                                                         \
351     DOTP_SW2_SD(s2_m, s3_m, k0_m, k0_m, tp0_m, tp1_m);                  \
352     DOTP_SW2_SD(s6_m, s7_m, k0_m, k0_m, tp2_m, tp3_m);                  \
353     tp0_m = __msa_srari_d(tp0_m, DCT_CONST_BITS);                       \
354     tp1_m = __msa_srari_d(tp1_m, DCT_CONST_BITS);                       \
355     tp2_m = __msa_srari_d(tp2_m, DCT_CONST_BITS);                       \
356     tp3_m = __msa_srari_d(tp3_m, DCT_CONST_BITS);                       \
357     out2 = __msa_pckev_w((v4i32)tp0_m, (v4i32)tp1_m);                   \
358     out3 = __msa_pckev_w((v4i32)tp2_m, (v4i32)tp3_m);                   \
359   }
360 
361 void fdct8x16_1d_column(const int16_t *input, int16_t *tmp_ptr,
362                         int32_t src_stride);
363 void fdct16x8_1d_row(int16_t *input, int16_t *output);
364 #endif  // VPX_VPX_DSP_MIPS_FWD_TXFM_MSA_H_
365