xref: /aosp_15_r20/external/libvpx/vp8/common/dequantize.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 "vp8/common/blockd.h"
14*fb1b10abSAndroid Build Coastguard Worker #include "vpx_mem/vpx_mem.h"
15*fb1b10abSAndroid Build Coastguard Worker 
vp8_dequantize_b_c(BLOCKD * d,short * DQC)16*fb1b10abSAndroid Build Coastguard Worker void vp8_dequantize_b_c(BLOCKD *d, short *DQC) {
17*fb1b10abSAndroid Build Coastguard Worker   int i;
18*fb1b10abSAndroid Build Coastguard Worker   short *DQ = d->dqcoeff;
19*fb1b10abSAndroid Build Coastguard Worker   short *Q = d->qcoeff;
20*fb1b10abSAndroid Build Coastguard Worker 
21*fb1b10abSAndroid Build Coastguard Worker   for (i = 0; i < 16; ++i) {
22*fb1b10abSAndroid Build Coastguard Worker     DQ[i] = Q[i] * DQC[i];
23*fb1b10abSAndroid Build Coastguard Worker   }
24*fb1b10abSAndroid Build Coastguard Worker }
25*fb1b10abSAndroid Build Coastguard Worker 
vp8_dequant_idct_add_c(short * input,short * dq,unsigned char * dest,int stride)26*fb1b10abSAndroid Build Coastguard Worker void vp8_dequant_idct_add_c(short *input, short *dq, unsigned char *dest,
27*fb1b10abSAndroid Build Coastguard Worker                             int stride) {
28*fb1b10abSAndroid Build Coastguard Worker   int i;
29*fb1b10abSAndroid Build Coastguard Worker 
30*fb1b10abSAndroid Build Coastguard Worker   for (i = 0; i < 16; ++i) {
31*fb1b10abSAndroid Build Coastguard Worker     input[i] = dq[i] * input[i];
32*fb1b10abSAndroid Build Coastguard Worker   }
33*fb1b10abSAndroid Build Coastguard Worker 
34*fb1b10abSAndroid Build Coastguard Worker   vp8_short_idct4x4llm_c(input, dest, stride, dest, stride);
35*fb1b10abSAndroid Build Coastguard Worker 
36*fb1b10abSAndroid Build Coastguard Worker   memset(input, 0, 32);
37*fb1b10abSAndroid Build Coastguard Worker }
38