xref: /aosp_15_r20/external/libvpx/vp8/common/invtrans.h (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 #ifndef VPX_VP8_COMMON_INVTRANS_H_
12*fb1b10abSAndroid Build Coastguard Worker #define VPX_VP8_COMMON_INVTRANS_H_
13*fb1b10abSAndroid Build Coastguard Worker 
14*fb1b10abSAndroid Build Coastguard Worker #include "./vpx_config.h"
15*fb1b10abSAndroid Build Coastguard Worker #include "vp8_rtcd.h"
16*fb1b10abSAndroid Build Coastguard Worker #include "blockd.h"
17*fb1b10abSAndroid Build Coastguard Worker #include "onyxc_int.h"
18*fb1b10abSAndroid Build Coastguard Worker 
19*fb1b10abSAndroid Build Coastguard Worker #if CONFIG_MULTITHREAD
20*fb1b10abSAndroid Build Coastguard Worker #include "vpx_mem/vpx_mem.h"
21*fb1b10abSAndroid Build Coastguard Worker #endif
22*fb1b10abSAndroid Build Coastguard Worker 
23*fb1b10abSAndroid Build Coastguard Worker #ifdef __cplusplus
24*fb1b10abSAndroid Build Coastguard Worker extern "C" {
25*fb1b10abSAndroid Build Coastguard Worker #endif
26*fb1b10abSAndroid Build Coastguard Worker 
eob_adjust(char * eobs,short * diff)27*fb1b10abSAndroid Build Coastguard Worker static void eob_adjust(char *eobs, short *diff) {
28*fb1b10abSAndroid Build Coastguard Worker   /* eob adjust.... the idct can only skip if both the dc and eob are zero */
29*fb1b10abSAndroid Build Coastguard Worker   int js;
30*fb1b10abSAndroid Build Coastguard Worker   for (js = 0; js < 16; ++js) {
31*fb1b10abSAndroid Build Coastguard Worker     if ((eobs[js] == 0) && (diff[0] != 0)) eobs[js]++;
32*fb1b10abSAndroid Build Coastguard Worker     diff += 16;
33*fb1b10abSAndroid Build Coastguard Worker   }
34*fb1b10abSAndroid Build Coastguard Worker }
35*fb1b10abSAndroid Build Coastguard Worker 
vp8_inverse_transform_mby(MACROBLOCKD * xd)36*fb1b10abSAndroid Build Coastguard Worker static INLINE void vp8_inverse_transform_mby(MACROBLOCKD *xd) {
37*fb1b10abSAndroid Build Coastguard Worker   short *DQC = xd->dequant_y1;
38*fb1b10abSAndroid Build Coastguard Worker 
39*fb1b10abSAndroid Build Coastguard Worker   if (xd->mode_info_context->mbmi.mode != SPLITMV) {
40*fb1b10abSAndroid Build Coastguard Worker     /* do 2nd order transform on the dc block */
41*fb1b10abSAndroid Build Coastguard Worker     if (xd->eobs[24] > 1) {
42*fb1b10abSAndroid Build Coastguard Worker       vp8_short_inv_walsh4x4(&xd->block[24].dqcoeff[0], xd->qcoeff);
43*fb1b10abSAndroid Build Coastguard Worker     } else {
44*fb1b10abSAndroid Build Coastguard Worker       vp8_short_inv_walsh4x4_1(&xd->block[24].dqcoeff[0], xd->qcoeff);
45*fb1b10abSAndroid Build Coastguard Worker     }
46*fb1b10abSAndroid Build Coastguard Worker     eob_adjust(xd->eobs, xd->qcoeff);
47*fb1b10abSAndroid Build Coastguard Worker 
48*fb1b10abSAndroid Build Coastguard Worker     DQC = xd->dequant_y1_dc;
49*fb1b10abSAndroid Build Coastguard Worker   }
50*fb1b10abSAndroid Build Coastguard Worker   vp8_dequant_idct_add_y_block(xd->qcoeff, DQC, xd->dst.y_buffer,
51*fb1b10abSAndroid Build Coastguard Worker                                xd->dst.y_stride, xd->eobs);
52*fb1b10abSAndroid Build Coastguard Worker }
53*fb1b10abSAndroid Build Coastguard Worker #ifdef __cplusplus
54*fb1b10abSAndroid Build Coastguard Worker }  // extern "C"
55*fb1b10abSAndroid Build Coastguard Worker #endif
56*fb1b10abSAndroid Build Coastguard Worker 
57*fb1b10abSAndroid Build Coastguard Worker #endif  // VPX_VP8_COMMON_INVTRANS_H_
58