xref: /aosp_15_r20/external/libvpx/vp8/common/idct_blk.c (revision fb1b10ab9aebc7c7068eedab379b749d7e3900be)
1*fb1b10abSAndroid Build Coastguard Worker /*
2*fb1b10abSAndroid Build Coastguard Worker  *  Copyright (c) 2010 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_config.h"
12*fb1b10abSAndroid Build Coastguard Worker #include "vp8_rtcd.h"
13*fb1b10abSAndroid Build Coastguard Worker #include "vpx_mem/vpx_mem.h"
14*fb1b10abSAndroid Build Coastguard Worker 
vp8_dequant_idct_add_y_block_c(short * q,short * dq,unsigned char * dst,int stride,char * eobs)15*fb1b10abSAndroid Build Coastguard Worker void vp8_dequant_idct_add_y_block_c(short *q, short *dq, unsigned char *dst,
16*fb1b10abSAndroid Build Coastguard Worker                                     int stride, char *eobs) {
17*fb1b10abSAndroid Build Coastguard Worker   int i, j;
18*fb1b10abSAndroid Build Coastguard Worker 
19*fb1b10abSAndroid Build Coastguard Worker   for (i = 0; i < 4; ++i) {
20*fb1b10abSAndroid Build Coastguard Worker     for (j = 0; j < 4; ++j) {
21*fb1b10abSAndroid Build Coastguard Worker       if (*eobs++ > 1) {
22*fb1b10abSAndroid Build Coastguard Worker         vp8_dequant_idct_add_c(q, dq, dst, stride);
23*fb1b10abSAndroid Build Coastguard Worker       } else {
24*fb1b10abSAndroid Build Coastguard Worker         vp8_dc_only_idct_add_c(q[0] * dq[0], dst, stride, dst, stride);
25*fb1b10abSAndroid Build Coastguard Worker         memset(q, 0, 2 * sizeof(q[0]));
26*fb1b10abSAndroid Build Coastguard Worker       }
27*fb1b10abSAndroid Build Coastguard Worker 
28*fb1b10abSAndroid Build Coastguard Worker       q += 16;
29*fb1b10abSAndroid Build Coastguard Worker       dst += 4;
30*fb1b10abSAndroid Build Coastguard Worker     }
31*fb1b10abSAndroid Build Coastguard Worker 
32*fb1b10abSAndroid Build Coastguard Worker     dst += 4 * stride - 16;
33*fb1b10abSAndroid Build Coastguard Worker   }
34*fb1b10abSAndroid Build Coastguard Worker }
35*fb1b10abSAndroid Build Coastguard Worker 
vp8_dequant_idct_add_uv_block_c(short * q,short * dq,unsigned char * dst_u,unsigned char * dst_v,int stride,char * eobs)36*fb1b10abSAndroid Build Coastguard Worker void vp8_dequant_idct_add_uv_block_c(short *q, short *dq, unsigned char *dst_u,
37*fb1b10abSAndroid Build Coastguard Worker                                      unsigned char *dst_v, int stride,
38*fb1b10abSAndroid Build Coastguard Worker                                      char *eobs) {
39*fb1b10abSAndroid Build Coastguard Worker   int i, j;
40*fb1b10abSAndroid Build Coastguard Worker 
41*fb1b10abSAndroid Build Coastguard Worker   for (i = 0; i < 2; ++i) {
42*fb1b10abSAndroid Build Coastguard Worker     for (j = 0; j < 2; ++j) {
43*fb1b10abSAndroid Build Coastguard Worker       if (*eobs++ > 1) {
44*fb1b10abSAndroid Build Coastguard Worker         vp8_dequant_idct_add_c(q, dq, dst_u, stride);
45*fb1b10abSAndroid Build Coastguard Worker       } else {
46*fb1b10abSAndroid Build Coastguard Worker         vp8_dc_only_idct_add_c(q[0] * dq[0], dst_u, stride, dst_u, stride);
47*fb1b10abSAndroid Build Coastguard Worker         memset(q, 0, 2 * sizeof(q[0]));
48*fb1b10abSAndroid Build Coastguard Worker       }
49*fb1b10abSAndroid Build Coastguard Worker 
50*fb1b10abSAndroid Build Coastguard Worker       q += 16;
51*fb1b10abSAndroid Build Coastguard Worker       dst_u += 4;
52*fb1b10abSAndroid Build Coastguard Worker     }
53*fb1b10abSAndroid Build Coastguard Worker 
54*fb1b10abSAndroid Build Coastguard Worker     dst_u += 4 * stride - 8;
55*fb1b10abSAndroid Build Coastguard Worker   }
56*fb1b10abSAndroid Build Coastguard Worker 
57*fb1b10abSAndroid Build Coastguard Worker   for (i = 0; i < 2; ++i) {
58*fb1b10abSAndroid Build Coastguard Worker     for (j = 0; j < 2; ++j) {
59*fb1b10abSAndroid Build Coastguard Worker       if (*eobs++ > 1) {
60*fb1b10abSAndroid Build Coastguard Worker         vp8_dequant_idct_add_c(q, dq, dst_v, stride);
61*fb1b10abSAndroid Build Coastguard Worker       } else {
62*fb1b10abSAndroid Build Coastguard Worker         vp8_dc_only_idct_add_c(q[0] * dq[0], dst_v, stride, dst_v, stride);
63*fb1b10abSAndroid Build Coastguard Worker         memset(q, 0, 2 * sizeof(q[0]));
64*fb1b10abSAndroid Build Coastguard Worker       }
65*fb1b10abSAndroid Build Coastguard Worker 
66*fb1b10abSAndroid Build Coastguard Worker       q += 16;
67*fb1b10abSAndroid Build Coastguard Worker       dst_v += 4;
68*fb1b10abSAndroid Build Coastguard Worker     }
69*fb1b10abSAndroid Build Coastguard Worker 
70*fb1b10abSAndroid Build Coastguard Worker     dst_v += 4 * stride - 8;
71*fb1b10abSAndroid Build Coastguard Worker   }
72*fb1b10abSAndroid Build Coastguard Worker }
73