1ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang/*
2ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang *  Copyright (c) 2010 The WebM project authors. All Rights Reserved.
3ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang *
4ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang *  Use of this source code is governed by a BSD-style license
5ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang *  that can be found in the LICENSE file in the root of the source
6ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang *  tree. An additional intellectual property rights grant can be found
7ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang *  in the file PATENTS.  All contributing project authors may
8ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang *  be found in the AUTHORS file in the root of the source tree.
9ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang */
10ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
115ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang
125ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang#include "./vp9_rtcd.h"
13ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang#include "./vpx_config.h"
147ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#include "./vpx_dsp_rtcd.h"
155ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang
167ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#include "vpx_dsp/quantize.h"
175ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang#include "vpx_mem/vpx_mem.h"
187ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#include "vpx_ports/mem.h"
195ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang
205ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang#include "vp9/common/vp9_idct.h"
21ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang#include "vp9/common/vp9_reconinter.h"
22ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang#include "vp9/common/vp9_reconintra.h"
237ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#include "vp9/common/vp9_scan.h"
24ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
255ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang#include "vp9/encoder/vp9_encodemb.h"
26ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian#include "vp9/encoder/vp9_rd.h"
275ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang#include "vp9/encoder/vp9_tokenize.h"
28ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
292ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanianstruct optimize_ctx {
302ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  ENTROPY_CONTEXT ta[MAX_MB_PLANE][16];
312ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  ENTROPY_CONTEXT tl[MAX_MB_PLANE][16];
322ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian};
332ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian
342ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanianvoid vp9_subtract_plane(MACROBLOCK *x, BLOCK_SIZE bsize, int plane) {
35ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  struct macroblock_plane *const p = &x->plane[plane];
362ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const struct macroblockd_plane *const pd = &x->e_mbd.plane[plane];
372ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const BLOCK_SIZE plane_bsize = get_plane_block_size(bsize, pd);
382ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const int bw = 4 * num_4x4_blocks_wide_lookup[plane_bsize];
392ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const int bh = 4 * num_4x4_blocks_high_lookup[plane_bsize];
40ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
417ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#if CONFIG_VP9_HIGHBITDEPTH
427ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  if (x->e_mbd.cur_buf->flags & YV12_FLAG_HIGHBITDEPTH) {
437ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    vpx_highbd_subtract_block(bh, bw, p->src_diff, bw, p->src.buf,
447ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                              p->src.stride, pd->dst.buf, pd->dst.stride,
457ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                              x->e_mbd.bd);
467ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    return;
477ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  }
487ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#endif  // CONFIG_VP9_HIGHBITDEPTH
497ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  vpx_subtract_block(bh, bw, p->src_diff, bw, p->src.buf, p->src.stride,
50ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang                     pd->dst.buf, pd->dst.stride);
51ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang}
52ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
535ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang#define RDTRUNC(RM, DM, R, D) ((128 + (R) * (RM)) & 0xFF)
54ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
55ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramaniantypedef struct vp9_token_state {
56ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  int           rate;
57ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  int           error;
58ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  int           next;
597ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  int16_t       token;
607ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  int16_t       qc;
61ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian} vp9_token_state;
62ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
635ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang// TODO(jimbankoski): experiment to find optimal RD numbers.
64ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanianstatic const int plane_rd_mult[PLANE_TYPES] = { 4, 2 };
65ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
66ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang#define UPDATE_RD_COST()\
67ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang{\
68ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  rd_cost0 = RDCOST(rdmult, rddiv, rate0, error0);\
69ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  rd_cost1 = RDCOST(rdmult, rddiv, rate1, error1);\
70ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  if (rd_cost0 == rd_cost1) {\
71ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    rd_cost0 = RDTRUNC(rdmult, rddiv, rate0, error0);\
72ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    rd_cost1 = RDTRUNC(rdmult, rddiv, rate1, error1);\
73ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  }\
74ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang}
75ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
76ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang// This function is a place holder for now but may ultimately need
77ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang// to scan previous tokens to work out the correct context.
7891037db265ecdd914a26e056cf69207b4f50924ehkuangstatic int trellis_get_coeff_context(const int16_t *scan,
7991037db265ecdd914a26e056cf69207b4f50924ehkuang                                     const int16_t *nb,
80ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang                                     int idx, int token,
8191037db265ecdd914a26e056cf69207b4f50924ehkuang                                     uint8_t *token_cache) {
82ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  int bak = token_cache[scan[idx]], pt;
83ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  token_cache[scan[idx]] = vp9_pt_energy_class[token];
8491037db265ecdd914a26e056cf69207b4f50924ehkuang  pt = get_coef_context(nb, token_cache, idx + 1);
85ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  token_cache[scan[idx]] = bak;
86ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  return pt;
87ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang}
88ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
89ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanianstatic int optimize_b(MACROBLOCK *mb, int plane, int block,
90ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                      TX_SIZE tx_size, int ctx) {
91ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  MACROBLOCKD *const xd = &mb->e_mbd;
92ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  struct macroblock_plane *const p = &mb->plane[plane];
93ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  struct macroblockd_plane *const pd = &xd->plane[plane];
944fb68e5dd4e93c7599dc905d861de11ac39c5585hkuang  const int ref = is_inter_block(&xd->mi[0]->mbmi);
95ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  vp9_token_state tokens[1025][2];
96ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  unsigned best_index[1025][2];
97ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  uint8_t token_cache[1024];
987ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  const tran_low_t *const coeff = BLOCK_OFFSET(mb->plane[plane].coeff, block);
997ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const qcoeff = BLOCK_OFFSET(p->qcoeff, block);
1007ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const dqcoeff = BLOCK_OFFSET(pd->dqcoeff, block);
101ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const int eob = p->eobs[block];
102ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const PLANE_TYPE type = pd->plane_type;
1035ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang  const int default_eob = 16 << (tx_size << 1);
104ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  const int mul = 1 + (tx_size == TX_32X32);
1051184aebb761cbeac9124c37189a80a1a58f04b6bhkuang  const int16_t *dequant_ptr = pd->dequant;
1065ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang  const uint8_t *const band_translate = get_band_translate(tx_size);
107ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const scan_order *const so = get_scan(xd, tx_size, type, block);
108ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const int16_t *const scan = so->scan;
109ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const int16_t *const nb = so->neighbors;
110ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  int next = eob, sz = 0;
111ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  int64_t rdmult = mb->rdmult * plane_rd_mult[type], rddiv = mb->rddiv;
112ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  int64_t rd_cost0, rd_cost1;
1137ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  int rate0, rate1, error0, error1;
1147ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  int16_t t0, t1;
1157ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  EXTRABIT e0;
116ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  int best, band, pt, i, final_eob;
1177ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#if CONFIG_VP9_HIGHBITDEPTH
1187ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  const int16_t *cat6_high_cost = vp9_get_high_cost_table(xd->bd);
1197ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#else
1207ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  const int16_t *cat6_high_cost = vp9_get_high_cost_table(8);
1217ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#endif
122ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
123ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  assert((!type && !plane) || (type && plane));
124ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  assert(eob <= default_eob);
125ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
126ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  /* Now set up a Viterbi trellis to evaluate alternative roundings. */
127ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  if (!ref)
128ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    rdmult = (rdmult * 9) >> 4;
129ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian
130ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  /* Initialize the sentinel node of the trellis. */
131ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  tokens[eob][0].rate = 0;
132ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  tokens[eob][0].error = 0;
133ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  tokens[eob][0].next = default_eob;
1342ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  tokens[eob][0].token = EOB_TOKEN;
135ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  tokens[eob][0].qc = 0;
136ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  tokens[eob][1] = tokens[eob][0];
137ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian
138ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  for (i = 0; i < eob; i++)
139ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    token_cache[scan[i]] =
1407ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vp9_pt_energy_class[vp9_get_token(qcoeff[scan[i]])];
141ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
142ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  for (i = eob; i-- > 0;) {
143ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    int base_bits, d2, dx;
144ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    const int rc = scan[i];
145ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    int x = qcoeff[rc];
146ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    /* Only add a trellis state for non-zero coefficients. */
147ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    if (x) {
148ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      int shortcut = 0;
149ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      error0 = tokens[next][0].error;
150ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      error1 = tokens[next][1].error;
151ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      /* Evaluate the first possibility for this state. */
152ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      rate0 = tokens[next][0].rate;
153ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      rate1 = tokens[next][1].rate;
1547ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vp9_get_token_extra(x, &t0, &e0);
155ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      /* Consider both possible successor states. */
156ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      if (next < default_eob) {
1579b35249446b07f40ac5fcc3205f2c048616efacchkuang        band = band_translate[i + 1];
15891037db265ecdd914a26e056cf69207b4f50924ehkuang        pt = trellis_get_coeff_context(scan, nb, i, t0, token_cache);
159ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian        rate0 += mb->token_costs[tx_size][type][ref][band][0][pt]
160ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                                [tokens[next][0].token];
161ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian        rate1 += mb->token_costs[tx_size][type][ref][band][0][pt]
162ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                                [tokens[next][1].token];
163ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      }
164ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      UPDATE_RD_COST();
165ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      /* And pick the best. */
166ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      best = rd_cost1 < rd_cost0;
1677ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      base_bits = vp9_get_cost(t0, e0, cat6_high_cost);
1682ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      dx = mul * (dqcoeff[rc] - coeff[rc]);
1697ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#if CONFIG_VP9_HIGHBITDEPTH
1707ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      if (xd->cur_buf->flags & YV12_FLAG_HIGHBITDEPTH) {
1717ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        dx >>= xd->bd - 8;
1727ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      }
1737ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#endif  // CONFIG_VP9_HIGHBITDEPTH
174ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      d2 = dx * dx;
175ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      tokens[i][0].rate = base_bits + (best ? rate1 : rate0);
176ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      tokens[i][0].error = d2 + (best ? error1 : error0);
177ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      tokens[i][0].next = next;
178ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      tokens[i][0].token = t0;
179ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      tokens[i][0].qc = x;
180ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      best_index[i][0] = best;
181ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
182ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      /* Evaluate the second possibility for this state. */
183ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      rate0 = tokens[next][0].rate;
184ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      rate1 = tokens[next][1].rate;
185ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
186ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      if ((abs(x) * dequant_ptr[rc != 0] > abs(coeff[rc]) * mul) &&
187ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian          (abs(x) * dequant_ptr[rc != 0] < abs(coeff[rc]) * mul +
188ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                                               dequant_ptr[rc != 0]))
189ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        shortcut = 1;
190ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      else
191ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        shortcut = 0;
192ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
193ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      if (shortcut) {
194ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        sz = -(x < 0);
195ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        x -= 2 * sz + 1;
196ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      }
197ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
198ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      /* Consider both possible successor states. */
199ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      if (!x) {
200ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        /* If we reduced this coefficient to zero, check to see if
201ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang         *  we need to move the EOB back here.
202ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang         */
2032ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian        t0 = tokens[next][0].token == EOB_TOKEN ? EOB_TOKEN : ZERO_TOKEN;
2042ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian        t1 = tokens[next][1].token == EOB_TOKEN ? EOB_TOKEN : ZERO_TOKEN;
2057ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        e0 = 0;
206ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      } else {
2077ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vp9_get_token_extra(x, &t0, &e0);
2087ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        t1 = t0;
209ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      }
210ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      if (next < default_eob) {
2119b35249446b07f40ac5fcc3205f2c048616efacchkuang        band = band_translate[i + 1];
2122ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian        if (t0 != EOB_TOKEN) {
21391037db265ecdd914a26e056cf69207b4f50924ehkuang          pt = trellis_get_coeff_context(scan, nb, i, t0, token_cache);
214f3bed9137f66ef693bd406e43b17e9a1114f1e14hkuang          rate0 += mb->token_costs[tx_size][type][ref][band][!x][pt]
21591037db265ecdd914a26e056cf69207b4f50924ehkuang                                  [tokens[next][0].token];
216ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        }
2172ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian        if (t1 != EOB_TOKEN) {
21891037db265ecdd914a26e056cf69207b4f50924ehkuang          pt = trellis_get_coeff_context(scan, nb, i, t1, token_cache);
219f3bed9137f66ef693bd406e43b17e9a1114f1e14hkuang          rate1 += mb->token_costs[tx_size][type][ref][band][!x][pt]
22091037db265ecdd914a26e056cf69207b4f50924ehkuang                                  [tokens[next][1].token];
221ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        }
222ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      }
223ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
224ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      UPDATE_RD_COST();
225ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      /* And pick the best. */
226ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      best = rd_cost1 < rd_cost0;
2277ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      base_bits = vp9_get_cost(t0, e0, cat6_high_cost);
228ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
229ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      if (shortcut) {
2307ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#if CONFIG_VP9_HIGHBITDEPTH
2317ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        if (xd->cur_buf->flags & YV12_FLAG_HIGHBITDEPTH) {
2327ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          dx -= ((dequant_ptr[rc != 0] >> (xd->bd - 8)) + sz) ^ sz;
2337ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        } else {
2347ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          dx -= (dequant_ptr[rc != 0] + sz) ^ sz;
2357ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        }
2367ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#else
237ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        dx -= (dequant_ptr[rc != 0] + sz) ^ sz;
2387ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#endif  // CONFIG_VP9_HIGHBITDEPTH
239ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        d2 = dx * dx;
240ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      }
241ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      tokens[i][1].rate = base_bits + (best ? rate1 : rate0);
242ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      tokens[i][1].error = d2 + (best ? error1 : error0);
243ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      tokens[i][1].next = next;
244ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      tokens[i][1].token = best ? t1 : t0;
245ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      tokens[i][1].qc = x;
246ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      best_index[i][1] = best;
247ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      /* Finally, make this the new head of the trellis. */
248ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      next = i;
2495ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang    } else {
2505ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang      /* There's no choice to make for a zero coefficient, so we don't
2515ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang       *  add a new trellis node, but we do need to update the costs.
2525ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang       */
2539b35249446b07f40ac5fcc3205f2c048616efacchkuang      band = band_translate[i + 1];
254ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      t0 = tokens[next][0].token;
255ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      t1 = tokens[next][1].token;
256ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      /* Update the cost of each path if we're past the EOB token. */
2572ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      if (t0 != EOB_TOKEN) {
258ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        tokens[next][0].rate +=
259f3bed9137f66ef693bd406e43b17e9a1114f1e14hkuang            mb->token_costs[tx_size][type][ref][band][1][0][t0];
260ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        tokens[next][0].token = ZERO_TOKEN;
261ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      }
2622ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      if (t1 != EOB_TOKEN) {
263ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        tokens[next][1].rate +=
264f3bed9137f66ef693bd406e43b17e9a1114f1e14hkuang            mb->token_costs[tx_size][type][ref][band][1][0][t1];
265ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang        tokens[next][1].token = ZERO_TOKEN;
266ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      }
26791037db265ecdd914a26e056cf69207b4f50924ehkuang      best_index[i][0] = best_index[i][1] = 0;
268ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      /* Don't update next, because we didn't add a new node. */
269ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    }
270ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  }
271ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
272ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  /* Now pick the best path through the whole trellis. */
2739b35249446b07f40ac5fcc3205f2c048616efacchkuang  band = band_translate[i + 1];
274ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  rate0 = tokens[next][0].rate;
275ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  rate1 = tokens[next][1].rate;
276ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  error0 = tokens[next][0].error;
277ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  error1 = tokens[next][1].error;
278ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  t0 = tokens[next][0].token;
279ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  t1 = tokens[next][1].token;
280ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  rate0 += mb->token_costs[tx_size][type][ref][band][0][ctx][t0];
281ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  rate1 += mb->token_costs[tx_size][type][ref][band][0][ctx][t1];
282ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  UPDATE_RD_COST();
283ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  best = rd_cost1 < rd_cost0;
284ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  final_eob = -1;
2857ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  memset(qcoeff, 0, sizeof(*qcoeff) * (16 << (tx_size * 2)));
2867ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  memset(dqcoeff, 0, sizeof(*dqcoeff) * (16 << (tx_size * 2)));
287ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  for (i = next; i < eob; i = next) {
288ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    const int x = tokens[i][best].qc;
289ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    const int rc = scan[i];
290ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    if (x) {
291ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      final_eob = i;
292ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    }
293ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian
2942ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian    qcoeff[rc] = x;
2952ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian    dqcoeff[rc] = (x * dequant_ptr[rc != 0]) / mul;
296ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
297ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    next = tokens[i][best].next;
298ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    best = best_index[i][best];
299ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  }
300ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  final_eob++;
301ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
3022ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  mb->plane[plane].eobs[block] = final_eob;
303ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  return final_eob;
304ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang}
305ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
3062ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanianstatic INLINE void fdct32x32(int rd_transform,
3077ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                             const int16_t *src, tran_low_t *dst,
3087ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                             int src_stride) {
3097ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  if (rd_transform)
3107ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    vpx_fdct32x32_rd(src, dst, src_stride);
3117ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  else
3127ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    vpx_fdct32x32(src, dst, src_stride);
3137ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian}
3147ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian
3157ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#if CONFIG_VP9_HIGHBITDEPTH
3167ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanianstatic INLINE void highbd_fdct32x32(int rd_transform, const int16_t *src,
3177ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                    tran_low_t *dst, int src_stride) {
3182ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  if (rd_transform)
3197ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    vpx_highbd_fdct32x32_rd(src, dst, src_stride);
3202ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  else
3217ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    vpx_highbd_fdct32x32(src, dst, src_stride);
322ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang}
3237ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#endif  // CONFIG_VP9_HIGHBITDEPTH
324ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
325ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanianvoid vp9_xform_quant_fp(MACROBLOCK *x, int plane, int block,
326ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                        BLOCK_SIZE plane_bsize, TX_SIZE tx_size) {
327ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  MACROBLOCKD *const xd = &x->e_mbd;
328ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const struct macroblock_plane *const p = &x->plane[plane];
329ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const struct macroblockd_plane *const pd = &xd->plane[plane];
330ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const scan_order *const scan_order = &vp9_default_scan_orders[tx_size];
3317ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const coeff = BLOCK_OFFSET(p->coeff, block);
3327ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const qcoeff = BLOCK_OFFSET(p->qcoeff, block);
3337ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const dqcoeff = BLOCK_OFFSET(pd->dqcoeff, block);
334ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  uint16_t *const eob = &p->eobs[block];
335ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const int diff_stride = 4 * num_4x4_blocks_wide_lookup[plane_bsize];
336ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  int i, j;
337ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const int16_t *src_diff;
338ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  txfrm_block_to_raster_xy(plane_bsize, tx_size, block, &i, &j);
339ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  src_diff = &p->src_diff[4 * (j * diff_stride + i)];
340ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian
3417ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#if CONFIG_VP9_HIGHBITDEPTH
3427ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  if (xd->cur_buf->flags & YV12_FLAG_HIGHBITDEPTH) {
3437ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    switch (tx_size) {
3447ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_32X32:
3457ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        highbd_fdct32x32(x->use_lp32x32fdct, src_diff, coeff, diff_stride);
3467ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vp9_highbd_quantize_fp_32x32(coeff, 1024, x->skip_block, p->zbin,
3477ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                     p->round_fp, p->quant_fp, p->quant_shift,
3487ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                     qcoeff, dqcoeff, pd->dequant,
3497ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                     eob, scan_order->scan,
3507ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                     scan_order->iscan);
3517ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
3527ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_16X16:
3537ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_fdct16x16(src_diff, coeff, diff_stride);
3547ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vp9_highbd_quantize_fp(coeff, 256, x->skip_block, p->zbin, p->round_fp,
3557ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               p->quant_fp, p->quant_shift, qcoeff, dqcoeff,
3567ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               pd->dequant, eob,
3577ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               scan_order->scan, scan_order->iscan);
3587ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
3597ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_8X8:
3607ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_fdct8x8(src_diff, coeff, diff_stride);
3617ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vp9_highbd_quantize_fp(coeff, 64, x->skip_block, p->zbin, p->round_fp,
3627ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               p->quant_fp, p->quant_shift, qcoeff, dqcoeff,
3637ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               pd->dequant, eob,
3647ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               scan_order->scan, scan_order->iscan);
3657ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
3667ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_4X4:
3677ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        x->fwd_txm4x4(src_diff, coeff, diff_stride);
3687ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vp9_highbd_quantize_fp(coeff, 16, x->skip_block, p->zbin, p->round_fp,
3697ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               p->quant_fp, p->quant_shift, qcoeff, dqcoeff,
3707ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               pd->dequant, eob,
3717ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               scan_order->scan, scan_order->iscan);
3727ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
3737ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      default:
3747ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        assert(0);
3757ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    }
3767ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    return;
3777ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  }
3787ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#endif  // CONFIG_VP9_HIGHBITDEPTH
3797ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian
380ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  switch (tx_size) {
381ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    case TX_32X32:
382ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      fdct32x32(x->use_lp32x32fdct, src_diff, coeff, diff_stride);
383ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      vp9_quantize_fp_32x32(coeff, 1024, x->skip_block, p->zbin, p->round_fp,
384ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                            p->quant_fp, p->quant_shift, qcoeff, dqcoeff,
3857ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                            pd->dequant, eob, scan_order->scan,
386ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                            scan_order->iscan);
387ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
388ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    case TX_16X16:
3897ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_fdct16x16(src_diff, coeff, diff_stride);
390ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      vp9_quantize_fp(coeff, 256, x->skip_block, p->zbin, p->round_fp,
391ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                      p->quant_fp, p->quant_shift, qcoeff, dqcoeff,
3927ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                      pd->dequant, eob,
393ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                      scan_order->scan, scan_order->iscan);
394ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
395ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    case TX_8X8:
3967ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vp9_fdct8x8_quant(src_diff, diff_stride, coeff, 64,
3977ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                        x->skip_block, p->zbin, p->round_fp,
3987ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                        p->quant_fp, p->quant_shift, qcoeff, dqcoeff,
3997ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                        pd->dequant, eob,
4007ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                        scan_order->scan, scan_order->iscan);
401ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
402ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    case TX_4X4:
403ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      x->fwd_txm4x4(src_diff, coeff, diff_stride);
404ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      vp9_quantize_fp(coeff, 16, x->skip_block, p->zbin, p->round_fp,
405ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                      p->quant_fp, p->quant_shift, qcoeff, dqcoeff,
4067ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                      pd->dequant, eob,
407ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                      scan_order->scan, scan_order->iscan);
408ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
409ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    default:
410ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      assert(0);
411ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
412ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  }
413ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian}
414ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian
415ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanianvoid vp9_xform_quant_dc(MACROBLOCK *x, int plane, int block,
416ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                        BLOCK_SIZE plane_bsize, TX_SIZE tx_size) {
417ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  MACROBLOCKD *const xd = &x->e_mbd;
418ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const struct macroblock_plane *const p = &x->plane[plane];
419ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const struct macroblockd_plane *const pd = &xd->plane[plane];
4207ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const coeff = BLOCK_OFFSET(p->coeff, block);
4217ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const qcoeff = BLOCK_OFFSET(p->qcoeff, block);
4227ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const dqcoeff = BLOCK_OFFSET(pd->dqcoeff, block);
423ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  uint16_t *const eob = &p->eobs[block];
424ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const int diff_stride = 4 * num_4x4_blocks_wide_lookup[plane_bsize];
425ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  int i, j;
426ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  const int16_t *src_diff;
427ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian
428ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  txfrm_block_to_raster_xy(plane_bsize, tx_size, block, &i, &j);
429ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  src_diff = &p->src_diff[4 * (j * diff_stride + i)];
430ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian
4317ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#if CONFIG_VP9_HIGHBITDEPTH
4327ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  if (xd->cur_buf->flags & YV12_FLAG_HIGHBITDEPTH) {
4337ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    switch (tx_size) {
4347ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_32X32:
4357ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_fdct32x32_1(src_diff, coeff, diff_stride);
4367ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_quantize_dc_32x32(coeff, x->skip_block, p->round,
4377ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                     p->quant_fp[0], qcoeff, dqcoeff,
4387ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                     pd->dequant[0], eob);
4397ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
4407ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_16X16:
4417ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_fdct16x16_1(src_diff, coeff, diff_stride);
4427ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_quantize_dc(coeff, 256, x->skip_block, p->round,
4437ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               p->quant_fp[0], qcoeff, dqcoeff,
4447ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               pd->dequant[0], eob);
4457ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
4467ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_8X8:
4477ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_fdct8x8_1(src_diff, coeff, diff_stride);
4487ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_quantize_dc(coeff, 64, x->skip_block, p->round,
4497ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               p->quant_fp[0], qcoeff, dqcoeff,
4507ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               pd->dequant[0], eob);
4517ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
4527ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_4X4:
4537ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        x->fwd_txm4x4(src_diff, coeff, diff_stride);
4547ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_quantize_dc(coeff, 16, x->skip_block, p->round,
4557ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               p->quant_fp[0], qcoeff, dqcoeff,
4567ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               pd->dequant[0], eob);
4577ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
4587ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      default:
4597ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        assert(0);
4607ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    }
4617ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    return;
4627ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  }
4637ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#endif  // CONFIG_VP9_HIGHBITDEPTH
4647ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian
465ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  switch (tx_size) {
466ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    case TX_32X32:
4677ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_fdct32x32_1(src_diff, coeff, diff_stride);
4687ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_quantize_dc_32x32(coeff, x->skip_block, p->round,
469ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                            p->quant_fp[0], qcoeff, dqcoeff,
470ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                            pd->dequant[0], eob);
471ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
472ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    case TX_16X16:
4737ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_fdct16x16_1(src_diff, coeff, diff_stride);
4747ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_quantize_dc(coeff, 256, x->skip_block, p->round,
475ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                     p->quant_fp[0], qcoeff, dqcoeff,
476ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                     pd->dequant[0], eob);
477ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
478ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    case TX_8X8:
4797ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_fdct8x8_1(src_diff, coeff, diff_stride);
4807ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_quantize_dc(coeff, 64, x->skip_block, p->round,
481ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                      p->quant_fp[0], qcoeff, dqcoeff,
482ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                      pd->dequant[0], eob);
483ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
484ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    case TX_4X4:
485ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      x->fwd_txm4x4(src_diff, coeff, diff_stride);
4867ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_quantize_dc(coeff, 16, x->skip_block, p->round,
487ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                      p->quant_fp[0], qcoeff, dqcoeff,
488ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian                      pd->dequant[0], eob);
489ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
490ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    default:
491ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      assert(0);
492ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
493ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  }
494ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian}
495ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian
4962ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanianvoid vp9_xform_quant(MACROBLOCK *x, int plane, int block,
4972ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                     BLOCK_SIZE plane_bsize, TX_SIZE tx_size) {
4982ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  MACROBLOCKD *const xd = &x->e_mbd;
4992ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const struct macroblock_plane *const p = &x->plane[plane];
5002ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const struct macroblockd_plane *const pd = &xd->plane[plane];
5012ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const scan_order *const scan_order = &vp9_default_scan_orders[tx_size];
5027ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const coeff = BLOCK_OFFSET(p->coeff, block);
5037ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const qcoeff = BLOCK_OFFSET(p->qcoeff, block);
5047ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const dqcoeff = BLOCK_OFFSET(pd->dqcoeff, block);
5052ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  uint16_t *const eob = &p->eobs[block];
5062ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const int diff_stride = 4 * num_4x4_blocks_wide_lookup[plane_bsize];
5072ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  int i, j;
5082ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const int16_t *src_diff;
5092ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  txfrm_block_to_raster_xy(plane_bsize, tx_size, block, &i, &j);
5102ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  src_diff = &p->src_diff[4 * (j * diff_stride + i)];
511ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
5127ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#if CONFIG_VP9_HIGHBITDEPTH
5137ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  if (xd->cur_buf->flags & YV12_FLAG_HIGHBITDEPTH) {
5147ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian     switch (tx_size) {
5157ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_32X32:
5167ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        highbd_fdct32x32(x->use_lp32x32fdct, src_diff, coeff, diff_stride);
5177ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_quantize_b_32x32(coeff, 1024, x->skip_block, p->zbin,
5187ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                    p->round, p->quant, p->quant_shift, qcoeff,
5197ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                    dqcoeff, pd->dequant, eob,
5207ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                    scan_order->scan, scan_order->iscan);
5217ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
5227ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_16X16:
5237ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_fdct16x16(src_diff, coeff, diff_stride);
5247ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_quantize_b(coeff, 256, x->skip_block, p->zbin, p->round,
5257ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                              p->quant, p->quant_shift, qcoeff, dqcoeff,
5267ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                              pd->dequant, eob,
5277ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                              scan_order->scan, scan_order->iscan);
5287ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
5297ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_8X8:
5307ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_fdct8x8(src_diff, coeff, diff_stride);
5317ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_quantize_b(coeff, 64, x->skip_block, p->zbin, p->round,
5327ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                              p->quant, p->quant_shift, qcoeff, dqcoeff,
5337ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                              pd->dequant, eob,
5347ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                              scan_order->scan, scan_order->iscan);
5357ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
5367ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_4X4:
5377ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        x->fwd_txm4x4(src_diff, coeff, diff_stride);
5387ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_highbd_quantize_b(coeff, 16, x->skip_block, p->zbin, p->round,
5397ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                              p->quant, p->quant_shift, qcoeff, dqcoeff,
5407ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                              pd->dequant, eob,
5417ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                              scan_order->scan, scan_order->iscan);
5427ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
5437ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      default:
5447ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        assert(0);
5457ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    }
5467ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    return;
5477ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  }
5487ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#endif  // CONFIG_VP9_HIGHBITDEPTH
5497ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian
55091037db265ecdd914a26e056cf69207b4f50924ehkuang  switch (tx_size) {
551ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_32X32:
5522ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      fdct32x32(x->use_lp32x32fdct, src_diff, coeff, diff_stride);
5537ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_quantize_b_32x32(coeff, 1024, x->skip_block, p->zbin, p->round,
55491037db265ecdd914a26e056cf69207b4f50924ehkuang                           p->quant, p->quant_shift, qcoeff, dqcoeff,
5557ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                           pd->dequant, eob, scan_order->scan,
5562ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                           scan_order->iscan);
557ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
558ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_16X16:
5597ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_fdct16x16(src_diff, coeff, diff_stride);
5607ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_quantize_b(coeff, 256, x->skip_block, p->zbin, p->round,
56191037db265ecdd914a26e056cf69207b4f50924ehkuang                     p->quant, p->quant_shift, qcoeff, dqcoeff,
5627ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                     pd->dequant, eob,
5632ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                     scan_order->scan, scan_order->iscan);
564ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
565ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_8X8:
5667ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_fdct8x8(src_diff, coeff, diff_stride);
5677ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_quantize_b(coeff, 64, x->skip_block, p->zbin, p->round,
56891037db265ecdd914a26e056cf69207b4f50924ehkuang                     p->quant, p->quant_shift, qcoeff, dqcoeff,
5697ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                     pd->dequant, eob,
5702ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                     scan_order->scan, scan_order->iscan);
571ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
572ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_4X4:
5732ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      x->fwd_txm4x4(src_diff, coeff, diff_stride);
5747ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      vpx_quantize_b(coeff, 16, x->skip_block, p->zbin, p->round,
57591037db265ecdd914a26e056cf69207b4f50924ehkuang                     p->quant, p->quant_shift, qcoeff, dqcoeff,
5767ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                     pd->dequant, eob,
5772ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                     scan_order->scan, scan_order->iscan);
578ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
579ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    default:
580ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      assert(0);
581ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
582ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  }
583ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang}
584ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
5851184aebb761cbeac9124c37189a80a1a58f04b6bhkuangstatic void encode_block(int plane, int block, BLOCK_SIZE plane_bsize,
5861184aebb761cbeac9124c37189a80a1a58f04b6bhkuang                         TX_SIZE tx_size, void *arg) {
587ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  struct encode_b_args *const args = arg;
588ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  MACROBLOCK *const x = args->x;
589ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  MACROBLOCKD *const xd = &x->e_mbd;
5905ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang  struct optimize_ctx *const ctx = args->ctx;
5912ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  struct macroblock_plane *const p = &x->plane[plane];
592ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  struct macroblockd_plane *const pd = &xd->plane[plane];
5937ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const dqcoeff = BLOCK_OFFSET(pd->dqcoeff, block);
5949b35249446b07f40ac5fcc3205f2c048616efacchkuang  int i, j;
5959b35249446b07f40ac5fcc3205f2c048616efacchkuang  uint8_t *dst;
5962ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  ENTROPY_CONTEXT *a, *l;
5979b35249446b07f40ac5fcc3205f2c048616efacchkuang  txfrm_block_to_raster_xy(plane_bsize, tx_size, block, &i, &j);
5989b35249446b07f40ac5fcc3205f2c048616efacchkuang  dst = &pd->dst.buf[4 * j * pd->dst.stride + 4 * i];
5992ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  a = &ctx->ta[plane][i];
6002ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  l = &ctx->tl[plane][j];
6015ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang
6025ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang  // TODO(jingning): per transformed block zero forcing only enabled for
6035ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang  // luma component. will integrate chroma components as well.
6045ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang  if (x->zcoeff_blk[tx_size][block] && plane == 0) {
6052ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian    p->eobs[block] = 0;
6062ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian    *a = *l = 0;
6075ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang    return;
6085ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang  }
6095ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang
610ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  if (!x->skip_recode) {
6117ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    if (x->quant_fp) {
6127ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      // Encoding process for rtc mode
6137ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      if (x->skip_txfm[0] == SKIP_TXFM_AC_DC && plane == 0) {
6147ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        // skip forward transform
6157ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        p->eobs[block] = 0;
6167ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        *a = *l = 0;
6177ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        return;
6187ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      } else {
619ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian        vp9_xform_quant_fp(x, plane, block, plane_bsize, tx_size);
6207ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      }
621ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    } else {
6227ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      if (max_txsize_lookup[plane_bsize] == tx_size) {
6237ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        int txfm_blk_index = (plane << 2) + (block >> (tx_size << 1));
6247ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        if (x->skip_txfm[txfm_blk_index] == SKIP_TXFM_NONE) {
6257ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          // full forward transform and quantization
6267ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vp9_xform_quant(x, plane, block, plane_bsize, tx_size);
6277ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        } else if (x->skip_txfm[txfm_blk_index] == SKIP_TXFM_AC_ONLY) {
6287ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          // fast path forward transform and quantization
6297ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vp9_xform_quant_dc(x, plane, block, plane_bsize, tx_size);
6307ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        } else {
6317ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          // skip forward transform
6327ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          p->eobs[block] = 0;
6337ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          *a = *l = 0;
6347ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          return;
6357ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        }
6367ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      } else {
6377ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vp9_xform_quant(x, plane, block, plane_bsize, tx_size);
6387ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      }
639ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    }
640ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  }
641ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
6429b35249446b07f40ac5fcc3205f2c048616efacchkuang  if (x->optimize && (!x->skip_recode || !x->skip_optimize)) {
643ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    const int ctx = combine_entropy_contexts(*a, *l);
644ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    *a = *l = optimize_b(x, plane, block, tx_size, ctx) > 0;
6459b35249446b07f40ac5fcc3205f2c048616efacchkuang  } else {
6462ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian    *a = *l = p->eobs[block] > 0;
6479b35249446b07f40ac5fcc3205f2c048616efacchkuang  }
648ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
6492ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  if (p->eobs[block])
6502ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian    *(args->skip) = 0;
6512ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian
6522ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  if (x->skip_encode || p->eobs[block] == 0)
65391037db265ecdd914a26e056cf69207b4f50924ehkuang    return;
6547ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#if CONFIG_VP9_HIGHBITDEPTH
6557ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  if (xd->cur_buf->flags & YV12_FLAG_HIGHBITDEPTH) {
6567ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    switch (tx_size) {
6577ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_32X32:
6587ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vp9_highbd_idct32x32_add(dqcoeff, dst, pd->dst.stride,
6597ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                 p->eobs[block], xd->bd);
6607ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
6617ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_16X16:
6627ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vp9_highbd_idct16x16_add(dqcoeff, dst, pd->dst.stride,
6637ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                 p->eobs[block], xd->bd);
6647ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
6657ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_8X8:
6667ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vp9_highbd_idct8x8_add(dqcoeff, dst, pd->dst.stride,
6677ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                               p->eobs[block], xd->bd);
6687ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
6697ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_4X4:
6707ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        // this is like vp9_short_idct4x4 but has a special case around eob<=1
6717ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        // which is significant (not just an optimization) for the lossless
6727ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        // case.
6737ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        x->highbd_itxm_add(dqcoeff, dst, pd->dst.stride,
6747ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                           p->eobs[block], xd->bd);
6757ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
6767ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      default:
6777ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        assert(0 && "Invalid transform size");
6787ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    }
6797ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    return;
6807ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  }
6817ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#endif  // CONFIG_VP9_HIGHBITDEPTH
68291037db265ecdd914a26e056cf69207b4f50924ehkuang
6831184aebb761cbeac9124c37189a80a1a58f04b6bhkuang  switch (tx_size) {
684ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_32X32:
6852ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      vp9_idct32x32_add(dqcoeff, dst, pd->dst.stride, p->eobs[block]);
686ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
687ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_16X16:
6882ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      vp9_idct16x16_add(dqcoeff, dst, pd->dst.stride, p->eobs[block]);
689ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
690ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_8X8:
6912ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      vp9_idct8x8_add(dqcoeff, dst, pd->dst.stride, p->eobs[block]);
692ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
693ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_4X4:
69491037db265ecdd914a26e056cf69207b4f50924ehkuang      // this is like vp9_short_idct4x4 but has a special case around eob<=1
69591037db265ecdd914a26e056cf69207b4f50924ehkuang      // which is significant (not just an optimization) for the lossless
69691037db265ecdd914a26e056cf69207b4f50924ehkuang      // case.
697ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      x->itxm_add(dqcoeff, dst, pd->dst.stride, p->eobs[block]);
698ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
6991184aebb761cbeac9124c37189a80a1a58f04b6bhkuang    default:
7002ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      assert(0 && "Invalid transform size");
701ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
702ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  }
703ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang}
704ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
7055ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuangstatic void encode_block_pass1(int plane, int block, BLOCK_SIZE plane_bsize,
7065ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang                               TX_SIZE tx_size, void *arg) {
7072ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  MACROBLOCK *const x = (MACROBLOCK *)arg;
7085ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang  MACROBLOCKD *const xd = &x->e_mbd;
7092ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  struct macroblock_plane *const p = &x->plane[plane];
7105ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang  struct macroblockd_plane *const pd = &xd->plane[plane];
7117ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *const dqcoeff = BLOCK_OFFSET(pd->dqcoeff, block);
7122ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  int i, j;
7132ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  uint8_t *dst;
7142ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  txfrm_block_to_raster_xy(plane_bsize, tx_size, block, &i, &j);
7152ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  dst = &pd->dst.buf[4 * j * pd->dst.stride + 4 * i];
7165ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang
7172ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  vp9_xform_quant(x, plane, block, plane_bsize, tx_size);
7185ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang
7197ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  if (p->eobs[block] > 0) {
7207ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#if CONFIG_VP9_HIGHBITDEPTH
7217ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    if (xd->cur_buf->flags & YV12_FLAG_HIGHBITDEPTH) {
7227ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian       x->highbd_itxm_add(dqcoeff, dst, pd->dst.stride, p->eobs[block], xd->bd);
7237ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian       return;
7247ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    }
7257ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#endif  // CONFIG_VP9_HIGHBITDEPTH
726ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian    x->itxm_add(dqcoeff, dst, pd->dst.stride, p->eobs[block]);
7277ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  }
7285ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang}
7295ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang
7302ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanianvoid vp9_encode_sby_pass1(MACROBLOCK *x, BLOCK_SIZE bsize) {
7312ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  vp9_subtract_plane(x, bsize, 0);
7322ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  vp9_foreach_transformed_block_in_plane(&x->e_mbd, bsize, 0,
7332ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                                         encode_block_pass1, x);
734ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang}
735ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
7361184aebb761cbeac9124c37189a80a1a58f04b6bhkuangvoid vp9_encode_sb(MACROBLOCK *x, BLOCK_SIZE bsize) {
737ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  MACROBLOCKD *const xd = &x->e_mbd;
738ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  struct optimize_ctx ctx;
7394fb68e5dd4e93c7599dc905d861de11ac39c5585hkuang  MB_MODE_INFO *mbmi = &xd->mi[0]->mbmi;
7402ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  struct encode_b_args arg = {x, &ctx, &mbmi->skip};
7412ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  int plane;
7422ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian
7437ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  mbmi->skip = 1;
7447ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian
7457ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  if (x->skip)
7467ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    return;
7477ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian
7482ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  for (plane = 0; plane < MAX_MB_PLANE; ++plane) {
7492ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian    if (!x->skip_recode)
7502ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      vp9_subtract_plane(x, bsize, plane);
7512ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian
7522ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian    if (x->optimize && (!x->skip_recode || !x->skip_optimize)) {
7532ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      const struct macroblockd_plane* const pd = &xd->plane[plane];
754ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      const TX_SIZE tx_size = plane ? get_uv_tx_size(mbmi, pd) : mbmi->tx_size;
7552ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian      vp9_get_entropy_contexts(bsize, tx_size, pd,
7562ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                               ctx.ta[plane], ctx.tl[plane]);
7572ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian    }
758f3bed9137f66ef693bd406e43b17e9a1114f1e14hkuang
7592ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian    vp9_foreach_transformed_block_in_plane(xd, bsize, plane, encode_block,
7602ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                                           &arg);
761f3bed9137f66ef693bd406e43b17e9a1114f1e14hkuang  }
762ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang}
763ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
7647ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanianvoid vp9_encode_block_intra(int plane, int block, BLOCK_SIZE plane_bsize,
7657ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                            TX_SIZE tx_size, void *arg) {
766ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  struct encode_b_args* const args = arg;
767ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  MACROBLOCK *const x = args->x;
768ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  MACROBLOCKD *const xd = &x->e_mbd;
7694fb68e5dd4e93c7599dc905d861de11ac39c5585hkuang  MB_MODE_INFO *mbmi = &xd->mi[0]->mbmi;
770ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  struct macroblock_plane *const p = &x->plane[plane];
771ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  struct macroblockd_plane *const pd = &xd->plane[plane];
7727ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *coeff = BLOCK_OFFSET(p->coeff, block);
7737ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *qcoeff = BLOCK_OFFSET(p->qcoeff, block);
7747ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  tran_low_t *dqcoeff = BLOCK_OFFSET(pd->dqcoeff, block);
7752ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const scan_order *scan_order;
7767ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  TX_TYPE tx_type = DCT_DCT;
777ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian  PREDICTION_MODE mode;
7787ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  const int bwl = b_width_log2_lookup[plane_bsize];
7792ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const int diff_stride = 4 * (1 << bwl);
78091037db265ecdd914a26e056cf69207b4f50924ehkuang  uint8_t *src, *dst;
78191037db265ecdd914a26e056cf69207b4f50924ehkuang  int16_t *src_diff;
7822ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  uint16_t *eob = &p->eobs[block];
7832ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const int src_stride = p->src.stride;
7842ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const int dst_stride = pd->dst.stride;
7852ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  int i, j;
7862ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  txfrm_block_to_raster_xy(plane_bsize, tx_size, block, &i, &j);
7872ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  dst = &pd->dst.buf[4 * (j * dst_stride + i)];
7882ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  src = &p->src.buf[4 * (j * src_stride + i)];
7892ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  src_diff = &p->src_diff[4 * (j * diff_stride + i)];
790ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
7917ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  if (tx_size == TX_4X4) {
7927ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    tx_type = get_tx_type_4x4(pd->plane_type, xd, block);
7937ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    scan_order = &vp9_scan_orders[TX_4X4][tx_type];
7947ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    mode = plane == 0 ? get_y_mode(xd->mi[0], block) : mbmi->uv_mode;
7957ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  } else {
7967ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    mode = plane == 0 ? mbmi->mode : mbmi->uv_mode;
7977ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    if (tx_size == TX_32X32) {
7987ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      scan_order = &vp9_default_scan_orders[TX_32X32];
7997ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    } else {
8007ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      tx_type = get_tx_type(pd->plane_type, xd);
8017ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      scan_order = &vp9_scan_orders[tx_size][tx_type];
8027ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    }
8037ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  }
8047ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian
8057ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  vp9_predict_intra_block(xd, bwl, tx_size, mode, x->skip_encode ? src : dst,
8067ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                          x->skip_encode ? src_stride : dst_stride,
8077ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                          dst, dst_stride, i, j, plane);
8087ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian
8097ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#if CONFIG_VP9_HIGHBITDEPTH
8107ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  if (xd->cur_buf->flags & YV12_FLAG_HIGHBITDEPTH) {
8117ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    switch (tx_size) {
8127ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_32X32:
8137ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        if (!x->skip_recode) {
8147ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vpx_highbd_subtract_block(32, 32, src_diff, diff_stride,
8157ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                    src, src_stride, dst, dst_stride, xd->bd);
8167ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          highbd_fdct32x32(x->use_lp32x32fdct, src_diff, coeff, diff_stride);
8177ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vpx_highbd_quantize_b_32x32(coeff, 1024, x->skip_block, p->zbin,
8187ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                      p->round, p->quant, p->quant_shift,
8197ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                      qcoeff, dqcoeff, pd->dequant, eob,
8207ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                      scan_order->scan, scan_order->iscan);
8217ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        }
8227ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        if (!x->skip_encode && *eob) {
8237ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vp9_highbd_idct32x32_add(dqcoeff, dst, dst_stride, *eob, xd->bd);
8247ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        }
8257ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
8267ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_16X16:
8277ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        if (!x->skip_recode) {
8287ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vpx_highbd_subtract_block(16, 16, src_diff, diff_stride,
8297ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                    src, src_stride, dst, dst_stride, xd->bd);
8307ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          if (tx_type == DCT_DCT)
8317ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian            vpx_highbd_fdct16x16(src_diff, coeff, diff_stride);
8327ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          else
8337ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian            vp9_highbd_fht16x16(src_diff, coeff, diff_stride, tx_type);
8347ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vpx_highbd_quantize_b(coeff, 256, x->skip_block, p->zbin, p->round,
8357ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                p->quant, p->quant_shift, qcoeff, dqcoeff,
8367ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                pd->dequant, eob,
8377ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                scan_order->scan, scan_order->iscan);
8387ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        }
8397ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        if (!x->skip_encode && *eob) {
8407ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vp9_highbd_iht16x16_add(tx_type, dqcoeff, dst, dst_stride,
8417ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                  *eob, xd->bd);
8427ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        }
8437ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
8447ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_8X8:
8457ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        if (!x->skip_recode) {
8467ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vpx_highbd_subtract_block(8, 8, src_diff, diff_stride,
8477ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                    src, src_stride, dst, dst_stride, xd->bd);
8487ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          if (tx_type == DCT_DCT)
8497ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian            vpx_highbd_fdct8x8(src_diff, coeff, diff_stride);
8507ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          else
8517ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian            vp9_highbd_fht8x8(src_diff, coeff, diff_stride, tx_type);
8527ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vpx_highbd_quantize_b(coeff, 64, x->skip_block, p->zbin, p->round,
8537ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                p->quant, p->quant_shift, qcoeff, dqcoeff,
8547ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                pd->dequant, eob,
8557ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                scan_order->scan, scan_order->iscan);
8567ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        }
8577ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        if (!x->skip_encode && *eob) {
8587ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vp9_highbd_iht8x8_add(tx_type, dqcoeff, dst, dst_stride, *eob,
8597ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                xd->bd);
8607ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        }
8617ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
8627ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      case TX_4X4:
8637ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        if (!x->skip_recode) {
8647ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vpx_highbd_subtract_block(4, 4, src_diff, diff_stride,
8657ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                    src, src_stride, dst, dst_stride, xd->bd);
8667ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          if (tx_type != DCT_DCT)
8677ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian            vp9_highbd_fht4x4(src_diff, coeff, diff_stride, tx_type);
8687ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          else
8697ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian            x->fwd_txm4x4(src_diff, coeff, diff_stride);
8707ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          vpx_highbd_quantize_b(coeff, 16, x->skip_block, p->zbin, p->round,
8717ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                p->quant, p->quant_shift, qcoeff, dqcoeff,
8727ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                pd->dequant, eob,
8737ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                scan_order->scan, scan_order->iscan);
8747ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        }
8757ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian
8767ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        if (!x->skip_encode && *eob) {
8777ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          if (tx_type == DCT_DCT) {
8787ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian            // this is like vp9_short_idct4x4 but has a special case around
8797ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian            // eob<=1 which is significant (not just an optimization) for the
8807ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian            // lossless case.
8817ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian            x->highbd_itxm_add(dqcoeff, dst, dst_stride, *eob, xd->bd);
8827ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          } else {
8837ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian            vp9_highbd_iht4x4_16_add(dqcoeff, dst, dst_stride, tx_type, xd->bd);
8847ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian          }
8857ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        }
8867ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        break;
8877ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      default:
8887ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        assert(0);
8897ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        return;
8907ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    }
8917ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    if (*eob)
8927ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian      *(args->skip) = 0;
8937ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian    return;
8947ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  }
8957ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian#endif  // CONFIG_VP9_HIGHBITDEPTH
8967ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian
89791037db265ecdd914a26e056cf69207b4f50924ehkuang  switch (tx_size) {
898ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_32X32:
8999b35249446b07f40ac5fcc3205f2c048616efacchkuang      if (!x->skip_recode) {
9007ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_subtract_block(32, 32, src_diff, diff_stride,
9012ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                           src, src_stride, dst, dst_stride);
9022ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian        fdct32x32(x->use_lp32x32fdct, src_diff, coeff, diff_stride);
9037ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_quantize_b_32x32(coeff, 1024, x->skip_block, p->zbin, p->round,
9049b35249446b07f40ac5fcc3205f2c048616efacchkuang                             p->quant, p->quant_shift, qcoeff, dqcoeff,
9057ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                             pd->dequant, eob, scan_order->scan,
9062ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                             scan_order->iscan);
9079b35249446b07f40ac5fcc3205f2c048616efacchkuang      }
90891037db265ecdd914a26e056cf69207b4f50924ehkuang      if (!x->skip_encode && *eob)
9092ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian        vp9_idct32x32_add(dqcoeff, dst, dst_stride, *eob);
910ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
911ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_16X16:
9129b35249446b07f40ac5fcc3205f2c048616efacchkuang      if (!x->skip_recode) {
9137ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_subtract_block(16, 16, src_diff, diff_stride,
9142ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                           src, src_stride, dst, dst_stride);
9152ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian        vp9_fht16x16(src_diff, coeff, diff_stride, tx_type);
9167ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_quantize_b(coeff, 256, x->skip_block, p->zbin, p->round,
9179b35249446b07f40ac5fcc3205f2c048616efacchkuang                       p->quant, p->quant_shift, qcoeff, dqcoeff,
9187ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                       pd->dequant, eob, scan_order->scan,
9192ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                       scan_order->iscan);
9209b35249446b07f40ac5fcc3205f2c048616efacchkuang      }
9215ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang      if (!x->skip_encode && *eob)
9222ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian        vp9_iht16x16_add(tx_type, dqcoeff, dst, dst_stride, *eob);
923ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
924ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_8X8:
9259b35249446b07f40ac5fcc3205f2c048616efacchkuang      if (!x->skip_recode) {
9267ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_subtract_block(8, 8, src_diff, diff_stride,
9272ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                           src, src_stride, dst, dst_stride);
9282ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian        vp9_fht8x8(src_diff, coeff, diff_stride, tx_type);
9297ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_quantize_b(coeff, 64, x->skip_block, p->zbin, p->round, p->quant,
9309b35249446b07f40ac5fcc3205f2c048616efacchkuang                       p->quant_shift, qcoeff, dqcoeff,
9317ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                       pd->dequant, eob, scan_order->scan,
9322ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                       scan_order->iscan);
9339b35249446b07f40ac5fcc3205f2c048616efacchkuang      }
9345ae7ac49f08a179e4f054d99fcfc9dce78d26e58hkuang      if (!x->skip_encode && *eob)
9352ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian        vp9_iht8x8_add(tx_type, dqcoeff, dst, dst_stride, *eob);
936ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
937ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang    case TX_4X4:
9389b35249446b07f40ac5fcc3205f2c048616efacchkuang      if (!x->skip_recode) {
9397ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_subtract_block(4, 4, src_diff, diff_stride,
9402ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                           src, src_stride, dst, dst_stride);
9419b35249446b07f40ac5fcc3205f2c048616efacchkuang        if (tx_type != DCT_DCT)
9422ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian          vp9_fht4x4(src_diff, coeff, diff_stride, tx_type);
9439b35249446b07f40ac5fcc3205f2c048616efacchkuang        else
9442ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian          x->fwd_txm4x4(src_diff, coeff, diff_stride);
9457ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian        vpx_quantize_b(coeff, 16, x->skip_block, p->zbin, p->round, p->quant,
9469b35249446b07f40ac5fcc3205f2c048616efacchkuang                       p->quant_shift, qcoeff, dqcoeff,
9477ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                       pd->dequant, eob, scan_order->scan,
9482ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian                       scan_order->iscan);
9499b35249446b07f40ac5fcc3205f2c048616efacchkuang      }
9509b35249446b07f40ac5fcc3205f2c048616efacchkuang
95191037db265ecdd914a26e056cf69207b4f50924ehkuang      if (!x->skip_encode && *eob) {
95291037db265ecdd914a26e056cf69207b4f50924ehkuang        if (tx_type == DCT_DCT)
95391037db265ecdd914a26e056cf69207b4f50924ehkuang          // this is like vp9_short_idct4x4 but has a special case around eob<=1
95491037db265ecdd914a26e056cf69207b4f50924ehkuang          // which is significant (not just an optimization) for the lossless
95591037db265ecdd914a26e056cf69207b4f50924ehkuang          // case.
956ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian          x->itxm_add(dqcoeff, dst, dst_stride, *eob);
95791037db265ecdd914a26e056cf69207b4f50924ehkuang        else
9582ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian          vp9_iht4x4_16_add(dqcoeff, dst, dst_stride, tx_type);
95991037db265ecdd914a26e056cf69207b4f50924ehkuang      }
960ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang      break;
96191037db265ecdd914a26e056cf69207b4f50924ehkuang    default:
96291037db265ecdd914a26e056cf69207b4f50924ehkuang      assert(0);
963ba6c59e9d7d7013b3906b6f4230b663422681848Vignesh Venkatasubramanian      break;
964ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang  }
9652ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  if (*eob)
9662ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian    *(args->skip) = 0;
967ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang}
968ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang
9692ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanianvoid vp9_encode_intra_block_plane(MACROBLOCK *x, BLOCK_SIZE bsize, int plane) {
9702ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian  const MACROBLOCKD *const xd = &x->e_mbd;
9714fb68e5dd4e93c7599dc905d861de11ac39c5585hkuang  struct encode_b_args arg = {x, NULL, &xd->mi[0]->mbmi.skip};
9722ec72e65689c948e92b826ae1e867bf369e72f13Vignesh Venkatasubramanian
9737ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian  vp9_foreach_transformed_block_in_plane(xd, bsize, plane,
9747ce0a1d1337c01056ba24006efab21f00e179e04Vignesh Venkatasubramanian                                         vp9_encode_block_intra, &arg);
975ba164dffc5a6795bce97fae02b51ccf3330e15e4hkuang}
976