xref: /aosp_15_r20/external/libvpx/vpx_dsp/mips/idct8x8_msa.c (revision fb1b10ab9aebc7c7068eedab379b749d7e3900be)
1*fb1b10abSAndroid Build Coastguard Worker /*
2*fb1b10abSAndroid Build Coastguard Worker  *  Copyright (c) 2015 The WebM project authors. All Rights Reserved.
3*fb1b10abSAndroid Build Coastguard Worker  *
4*fb1b10abSAndroid Build Coastguard Worker  *  Use of this source code is governed by a BSD-style license
5*fb1b10abSAndroid Build Coastguard Worker  *  that can be found in the LICENSE file in the root of the source
6*fb1b10abSAndroid Build Coastguard Worker  *  tree. An additional intellectual property rights grant can be found
7*fb1b10abSAndroid Build Coastguard Worker  *  in the file PATENTS.  All contributing project authors may
8*fb1b10abSAndroid Build Coastguard Worker  *  be found in the AUTHORS file in the root of the source tree.
9*fb1b10abSAndroid Build Coastguard Worker  */
10*fb1b10abSAndroid Build Coastguard Worker 
11*fb1b10abSAndroid Build Coastguard Worker #include "./vpx_dsp_rtcd.h"
12*fb1b10abSAndroid Build Coastguard Worker #include "vpx_dsp/mips/inv_txfm_msa.h"
13*fb1b10abSAndroid Build Coastguard Worker 
vpx_idct8x8_64_add_msa(const int16_t * input,uint8_t * dst,int32_t dst_stride)14*fb1b10abSAndroid Build Coastguard Worker void vpx_idct8x8_64_add_msa(const int16_t *input, uint8_t *dst,
15*fb1b10abSAndroid Build Coastguard Worker                             int32_t dst_stride) {
16*fb1b10abSAndroid Build Coastguard Worker   v8i16 in0, in1, in2, in3, in4, in5, in6, in7;
17*fb1b10abSAndroid Build Coastguard Worker 
18*fb1b10abSAndroid Build Coastguard Worker   /* load vector elements of 8x8 block */
19*fb1b10abSAndroid Build Coastguard Worker   LD_SH8(input, 8, in0, in1, in2, in3, in4, in5, in6, in7);
20*fb1b10abSAndroid Build Coastguard Worker 
21*fb1b10abSAndroid Build Coastguard Worker   /* rows transform */
22*fb1b10abSAndroid Build Coastguard Worker   TRANSPOSE8x8_SH_SH(in0, in1, in2, in3, in4, in5, in6, in7, in0, in1, in2, in3,
23*fb1b10abSAndroid Build Coastguard Worker                      in4, in5, in6, in7);
24*fb1b10abSAndroid Build Coastguard Worker   /* 1D idct8x8 */
25*fb1b10abSAndroid Build Coastguard Worker   VP9_IDCT8x8_1D(in0, in1, in2, in3, in4, in5, in6, in7, in0, in1, in2, in3,
26*fb1b10abSAndroid Build Coastguard Worker                  in4, in5, in6, in7);
27*fb1b10abSAndroid Build Coastguard Worker   /* columns transform */
28*fb1b10abSAndroid Build Coastguard Worker   TRANSPOSE8x8_SH_SH(in0, in1, in2, in3, in4, in5, in6, in7, in0, in1, in2, in3,
29*fb1b10abSAndroid Build Coastguard Worker                      in4, in5, in6, in7);
30*fb1b10abSAndroid Build Coastguard Worker   /* 1D idct8x8 */
31*fb1b10abSAndroid Build Coastguard Worker   VP9_IDCT8x8_1D(in0, in1, in2, in3, in4, in5, in6, in7, in0, in1, in2, in3,
32*fb1b10abSAndroid Build Coastguard Worker                  in4, in5, in6, in7);
33*fb1b10abSAndroid Build Coastguard Worker   /* final rounding (add 2^4, divide by 2^5) and shift */
34*fb1b10abSAndroid Build Coastguard Worker   SRARI_H4_SH(in0, in1, in2, in3, 5);
35*fb1b10abSAndroid Build Coastguard Worker   SRARI_H4_SH(in4, in5, in6, in7, 5);
36*fb1b10abSAndroid Build Coastguard Worker   /* add block and store 8x8 */
37*fb1b10abSAndroid Build Coastguard Worker   VP9_ADDBLK_ST8x4_UB(dst, dst_stride, in0, in1, in2, in3);
38*fb1b10abSAndroid Build Coastguard Worker   dst += (4 * dst_stride);
39*fb1b10abSAndroid Build Coastguard Worker   VP9_ADDBLK_ST8x4_UB(dst, dst_stride, in4, in5, in6, in7);
40*fb1b10abSAndroid Build Coastguard Worker }
41*fb1b10abSAndroid Build Coastguard Worker 
vpx_idct8x8_12_add_msa(const int16_t * input,uint8_t * dst,int32_t dst_stride)42*fb1b10abSAndroid Build Coastguard Worker void vpx_idct8x8_12_add_msa(const int16_t *input, uint8_t *dst,
43*fb1b10abSAndroid Build Coastguard Worker                             int32_t dst_stride) {
44*fb1b10abSAndroid Build Coastguard Worker   v8i16 in0, in1, in2, in3, in4, in5, in6, in7;
45*fb1b10abSAndroid Build Coastguard Worker   v8i16 s0, s1, s2, s3, s4, s5, s6, s7, k0, k1, k2, k3, m0, m1, m2, m3;
46*fb1b10abSAndroid Build Coastguard Worker   v4i32 tmp0, tmp1, tmp2, tmp3;
47*fb1b10abSAndroid Build Coastguard Worker   v8i16 zero = { 0 };
48*fb1b10abSAndroid Build Coastguard Worker 
49*fb1b10abSAndroid Build Coastguard Worker   /* load vector elements of 8x8 block */
50*fb1b10abSAndroid Build Coastguard Worker   LD_SH8(input, 8, in0, in1, in2, in3, in4, in5, in6, in7);
51*fb1b10abSAndroid Build Coastguard Worker   TRANSPOSE8X4_SH_SH(in0, in1, in2, in3, in0, in1, in2, in3);
52*fb1b10abSAndroid Build Coastguard Worker 
53*fb1b10abSAndroid Build Coastguard Worker   /* stage1 */
54*fb1b10abSAndroid Build Coastguard Worker   ILVL_H2_SH(in3, in0, in2, in1, s0, s1);
55*fb1b10abSAndroid Build Coastguard Worker   k0 = VP9_SET_COSPI_PAIR(cospi_28_64, -cospi_4_64);
56*fb1b10abSAndroid Build Coastguard Worker   k1 = VP9_SET_COSPI_PAIR(cospi_4_64, cospi_28_64);
57*fb1b10abSAndroid Build Coastguard Worker   k2 = VP9_SET_COSPI_PAIR(-cospi_20_64, cospi_12_64);
58*fb1b10abSAndroid Build Coastguard Worker   k3 = VP9_SET_COSPI_PAIR(cospi_12_64, cospi_20_64);
59*fb1b10abSAndroid Build Coastguard Worker   DOTP_SH4_SW(s0, s0, s1, s1, k0, k1, k2, k3, tmp0, tmp1, tmp2, tmp3);
60*fb1b10abSAndroid Build Coastguard Worker   SRARI_W4_SW(tmp0, tmp1, tmp2, tmp3, DCT_CONST_BITS);
61*fb1b10abSAndroid Build Coastguard Worker   PCKEV_H2_SH(zero, tmp0, zero, tmp1, s0, s1);
62*fb1b10abSAndroid Build Coastguard Worker   PCKEV_H2_SH(zero, tmp2, zero, tmp3, s2, s3);
63*fb1b10abSAndroid Build Coastguard Worker   BUTTERFLY_4(s0, s1, s3, s2, s4, s7, s6, s5);
64*fb1b10abSAndroid Build Coastguard Worker 
65*fb1b10abSAndroid Build Coastguard Worker   /* stage2 */
66*fb1b10abSAndroid Build Coastguard Worker   ILVR_H2_SH(in3, in1, in2, in0, s1, s0);
67*fb1b10abSAndroid Build Coastguard Worker   k0 = VP9_SET_COSPI_PAIR(cospi_16_64, cospi_16_64);
68*fb1b10abSAndroid Build Coastguard Worker   k1 = VP9_SET_COSPI_PAIR(cospi_16_64, -cospi_16_64);
69*fb1b10abSAndroid Build Coastguard Worker   k2 = VP9_SET_COSPI_PAIR(cospi_24_64, -cospi_8_64);
70*fb1b10abSAndroid Build Coastguard Worker   k3 = VP9_SET_COSPI_PAIR(cospi_8_64, cospi_24_64);
71*fb1b10abSAndroid Build Coastguard Worker   DOTP_SH4_SW(s0, s0, s1, s1, k0, k1, k2, k3, tmp0, tmp1, tmp2, tmp3);
72*fb1b10abSAndroid Build Coastguard Worker   SRARI_W4_SW(tmp0, tmp1, tmp2, tmp3, DCT_CONST_BITS);
73*fb1b10abSAndroid Build Coastguard Worker   PCKEV_H2_SH(zero, tmp0, zero, tmp1, s0, s1);
74*fb1b10abSAndroid Build Coastguard Worker   PCKEV_H2_SH(zero, tmp2, zero, tmp3, s2, s3);
75*fb1b10abSAndroid Build Coastguard Worker   BUTTERFLY_4(s0, s1, s2, s3, m0, m1, m2, m3);
76*fb1b10abSAndroid Build Coastguard Worker 
77*fb1b10abSAndroid Build Coastguard Worker   /* stage3 */
78*fb1b10abSAndroid Build Coastguard Worker   s0 = __msa_ilvr_h(s6, s5);
79*fb1b10abSAndroid Build Coastguard Worker 
80*fb1b10abSAndroid Build Coastguard Worker   k1 = VP9_SET_COSPI_PAIR(-cospi_16_64, cospi_16_64);
81*fb1b10abSAndroid Build Coastguard Worker   DOTP_SH2_SW(s0, s0, k1, k0, tmp0, tmp1);
82*fb1b10abSAndroid Build Coastguard Worker   SRARI_W2_SW(tmp0, tmp1, DCT_CONST_BITS);
83*fb1b10abSAndroid Build Coastguard Worker   PCKEV_H2_SH(zero, tmp0, zero, tmp1, s2, s3);
84*fb1b10abSAndroid Build Coastguard Worker 
85*fb1b10abSAndroid Build Coastguard Worker   /* stage4 */
86*fb1b10abSAndroid Build Coastguard Worker   BUTTERFLY_8(m0, m1, m2, m3, s4, s2, s3, s7, in0, in1, in2, in3, in4, in5, in6,
87*fb1b10abSAndroid Build Coastguard Worker               in7);
88*fb1b10abSAndroid Build Coastguard Worker   TRANSPOSE4X8_SH_SH(in0, in1, in2, in3, in4, in5, in6, in7, in0, in1, in2, in3,
89*fb1b10abSAndroid Build Coastguard Worker                      in4, in5, in6, in7);
90*fb1b10abSAndroid Build Coastguard Worker   VP9_IDCT8x8_1D(in0, in1, in2, in3, in4, in5, in6, in7, in0, in1, in2, in3,
91*fb1b10abSAndroid Build Coastguard Worker                  in4, in5, in6, in7);
92*fb1b10abSAndroid Build Coastguard Worker 
93*fb1b10abSAndroid Build Coastguard Worker   /* final rounding (add 2^4, divide by 2^5) and shift */
94*fb1b10abSAndroid Build Coastguard Worker   SRARI_H4_SH(in0, in1, in2, in3, 5);
95*fb1b10abSAndroid Build Coastguard Worker   SRARI_H4_SH(in4, in5, in6, in7, 5);
96*fb1b10abSAndroid Build Coastguard Worker 
97*fb1b10abSAndroid Build Coastguard Worker   /* add block and store 8x8 */
98*fb1b10abSAndroid Build Coastguard Worker   VP9_ADDBLK_ST8x4_UB(dst, dst_stride, in0, in1, in2, in3);
99*fb1b10abSAndroid Build Coastguard Worker   dst += (4 * dst_stride);
100*fb1b10abSAndroid Build Coastguard Worker   VP9_ADDBLK_ST8x4_UB(dst, dst_stride, in4, in5, in6, in7);
101*fb1b10abSAndroid Build Coastguard Worker }
102*fb1b10abSAndroid Build Coastguard Worker 
vpx_idct8x8_1_add_msa(const int16_t * input,uint8_t * dst,int32_t dst_stride)103*fb1b10abSAndroid Build Coastguard Worker void vpx_idct8x8_1_add_msa(const int16_t *input, uint8_t *dst,
104*fb1b10abSAndroid Build Coastguard Worker                            int32_t dst_stride) {
105*fb1b10abSAndroid Build Coastguard Worker   int16_t out;
106*fb1b10abSAndroid Build Coastguard Worker   int32_t val;
107*fb1b10abSAndroid Build Coastguard Worker   v8i16 vec;
108*fb1b10abSAndroid Build Coastguard Worker 
109*fb1b10abSAndroid Build Coastguard Worker   out = ROUND_POWER_OF_TWO((input[0] * cospi_16_64), DCT_CONST_BITS);
110*fb1b10abSAndroid Build Coastguard Worker   out = ROUND_POWER_OF_TWO((out * cospi_16_64), DCT_CONST_BITS);
111*fb1b10abSAndroid Build Coastguard Worker   val = ROUND_POWER_OF_TWO(out, 5);
112*fb1b10abSAndroid Build Coastguard Worker   vec = __msa_fill_h(val);
113*fb1b10abSAndroid Build Coastguard Worker 
114*fb1b10abSAndroid Build Coastguard Worker   VP9_ADDBLK_ST8x4_UB(dst, dst_stride, vec, vec, vec, vec);
115*fb1b10abSAndroid Build Coastguard Worker   dst += (4 * dst_stride);
116*fb1b10abSAndroid Build Coastguard Worker   VP9_ADDBLK_ST8x4_UB(dst, dst_stride, vec, vec, vec, vec);
117*fb1b10abSAndroid Build Coastguard Worker }
118