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