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 Workerstatic 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 Workerstatic 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