blob: 2db83fe9bbf0a490cfedc6d8a52d6f149c0253f2 [file] [log] [blame]
Yaowu Xuc27fc142016-08-22 16:08:15 -07001/*
Yaowu Xu2ab7ff02016-09-02 12:04:54 -07002 * Copyright (c) 2016, Alliance for Open Media. All rights reserved
Yaowu Xuc27fc142016-08-22 16:08:15 -07003 *
Yaowu Xu2ab7ff02016-09-02 12:04:54 -07004 * This source code is subject to the terms of the BSD 2 Clause License and
5 * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
6 * was not distributed with this source code in the LICENSE file, you can
7 * obtain it at www.aomedia.org/license/software. If the Alliance for Open
8 * Media Patent License 1.0 was not distributed with this source code in the
9 * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
Yaowu Xuc27fc142016-08-22 16:08:15 -070010 */
11
Yaowu Xuf883b422016-08-30 14:01:10 -070012#ifndef AV1_COMMON_ONYXC_INT_H_
13#define AV1_COMMON_ONYXC_INT_H_
Yaowu Xuc27fc142016-08-22 16:08:15 -070014
Yaowu Xuf883b422016-08-30 14:01:10 -070015#include "./aom_config.h"
Yaowu Xucaf20232016-10-18 17:15:40 -070016#include "./av1_rtcd.h"
Yaowu Xuf883b422016-08-30 14:01:10 -070017#include "aom/internal/aom_codec_internal.h"
18#include "aom_util/aom_thread.h"
Alex Converseeb780e72016-12-13 12:46:41 -080019#if CONFIG_ANS
20#include "aom_dsp/ans.h"
21#endif
Yaowu Xuc27fc142016-08-22 16:08:15 -070022#include "av1/common/alloccommon.h"
Tom Finegan17ce8b12017-02-08 12:46:31 -080023#include "av1/common/av1_loopfilter.h"
Yaowu Xuc27fc142016-08-22 16:08:15 -070024#include "av1/common/entropy.h"
25#include "av1/common/entropymode.h"
Yaowu Xucaf20232016-10-18 17:15:40 -070026#include "av1/common/entropymv.h"
Yaowu Xuc27fc142016-08-22 16:08:15 -070027#include "av1/common/frame_buffers.h"
Yaowu Xucaf20232016-10-18 17:15:40 -070028#include "av1/common/mv.h"
Yaowu Xuc27fc142016-08-22 16:08:15 -070029#include "av1/common/quant_common.h"
Debargha Mukherjee5cd2ab92016-09-08 15:15:17 -070030#if CONFIG_LOOP_RESTORATION
Yaowu Xuc27fc142016-08-22 16:08:15 -070031#include "av1/common/restoration.h"
Debargha Mukherjee5cd2ab92016-09-08 15:15:17 -070032#endif // CONFIG_LOOP_RESTORATION
Yaowu Xucaf20232016-10-18 17:15:40 -070033#include "av1/common/tile_common.h"
Yushin Cho77bba8d2016-11-04 16:36:56 -070034#include "av1/common/odintrin.h"
35#if CONFIG_PVQ
36#include "av1/common/pvq.h"
37#endif
Luc Trudeaubaeb3752017-04-24 11:19:25 -040038#if CONFIG_CFL
39#include "av1/common/cfl.h"
40#endif
Yaowu Xuc27fc142016-08-22 16:08:15 -070041#ifdef __cplusplus
42extern "C" {
43#endif
44
Jean-Marc Valine5759772017-03-23 18:46:38 -040045#define CDEF_MAX_STRENGTHS 16
46
Yaowu Xuc27fc142016-08-22 16:08:15 -070047#define REF_FRAMES_LOG2 3
48#define REF_FRAMES (1 << REF_FRAMES_LOG2)
49
50// 4 scratch frames for the new frames to support a maximum of 4 cores decoding
51// in parallel, 3 for scaled references on the encoder.
52// TODO(hkuang): Add ondemand frame buffers instead of hardcoding the number
53// of framebuffers.
54// TODO(jkoleszar): These 3 extra references could probably come from the
55// normal reference pool.
56#define FRAME_BUFFERS (REF_FRAMES + 7)
57
Arild Fuldseth (arilfuld)5114b7b2016-11-09 13:32:54 +010058#if CONFIG_REFERENCE_BUFFER
59/* Constant values while waiting for the sequence header */
60#define FRAME_ID_NUMBERS_PRESENT_FLAG 1
61#define FRAME_ID_LENGTH_MINUS7 8 // Allows frame id up to 2^15-1
62#define DELTA_FRAME_ID_LENGTH_MINUS2 12 // Allows frame id deltas up to 2^14-1
63#endif
64
Yaowu Xuc27fc142016-08-22 16:08:15 -070065#if CONFIG_EXT_REFS
66#define FRAME_CONTEXTS_LOG2 3
67#else
68#define FRAME_CONTEXTS_LOG2 2
69#endif
70
71#define FRAME_CONTEXTS (1 << FRAME_CONTEXTS_LOG2)
72
73#define NUM_PING_PONG_BUFFERS 2
74
75typedef enum {
76 SINGLE_REFERENCE = 0,
77 COMPOUND_REFERENCE = 1,
78 REFERENCE_MODE_SELECT = 2,
79 REFERENCE_MODES = 3,
80} REFERENCE_MODE;
81
82typedef enum {
83 RESET_FRAME_CONTEXT_NONE = 0,
84 RESET_FRAME_CONTEXT_CURRENT = 1,
85 RESET_FRAME_CONTEXT_ALL = 2,
86} RESET_FRAME_CONTEXT_MODE;
87
88typedef enum {
89 /**
90 * Update frame context to values resulting from forward probability
91 * updates signaled in the frame header
92 */
93 REFRESH_FRAME_CONTEXT_FORWARD,
94 /**
95 * Update frame context to values resulting from backward probability
96 * updates based on entropy/counts in the decoded frame
97 */
98 REFRESH_FRAME_CONTEXT_BACKWARD,
99} REFRESH_FRAME_CONTEXT_MODE;
100
101typedef struct {
102 int_mv mv[2];
Yaowu Xu4306b6e2016-09-27 12:55:32 -0700103 int_mv pred_mv[2];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700104 MV_REFERENCE_FRAME ref_frame[2];
105} MV_REF;
106
107typedef struct {
108 int ref_count;
109 MV_REF *mvs;
110 int mi_rows;
111 int mi_cols;
Sarah Parkerf1783292017-04-05 11:55:27 -0700112#if CONFIG_GLOBAL_MOTION
113 WarpedMotionParams global_motion[TOTAL_REFS_PER_FRAME];
114#endif // CONFIG_GLOBAL_MOTION
Yaowu Xuf883b422016-08-30 14:01:10 -0700115 aom_codec_frame_buffer_t raw_frame_buffer;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700116 YV12_BUFFER_CONFIG buf;
Fangwen Fu8d164de2016-12-14 13:40:54 -0800117#if CONFIG_TEMPMV_SIGNALING
118 uint8_t intra_only;
119#endif
Yaowu Xuc27fc142016-08-22 16:08:15 -0700120 // The Following variables will only be used in frame parallel decode.
121
122 // frame_worker_owner indicates which FrameWorker owns this buffer. NULL means
123 // that no FrameWorker owns, or is decoding, this buffer.
Yaowu Xuf883b422016-08-30 14:01:10 -0700124 AVxWorker *frame_worker_owner;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700125
126 // row and col indicate which position frame has been decoded to in real
127 // pixel unit. They are reset to -1 when decoding begins and set to INT_MAX
128 // when the frame is fully decoded.
129 int row;
130 int col;
131} RefCntBuffer;
132
133typedef struct BufferPool {
134// Protect BufferPool from being accessed by several FrameWorkers at
135// the same time during frame parallel decode.
136// TODO(hkuang): Try to use atomic variable instead of locking the whole pool.
137#if CONFIG_MULTITHREAD
138 pthread_mutex_t pool_mutex;
139#endif
140
141 // Private data associated with the frame buffer callbacks.
142 void *cb_priv;
143
Yaowu Xuf883b422016-08-30 14:01:10 -0700144 aom_get_frame_buffer_cb_fn_t get_fb_cb;
145 aom_release_frame_buffer_cb_fn_t release_fb_cb;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700146
147 RefCntBuffer frame_bufs[FRAME_BUFFERS];
148
149 // Frame buffers allocated internally by the codec.
150 InternalFrameBufferList int_frame_buffers;
151} BufferPool;
152
Yaowu Xuf883b422016-08-30 14:01:10 -0700153typedef struct AV1Common {
154 struct aom_internal_error_info error;
155 aom_color_space_t color_space;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700156 int color_range;
157 int width;
158 int height;
159 int render_width;
160 int render_height;
161 int last_width;
162 int last_height;
163
164 // TODO(jkoleszar): this implies chroma ss right now, but could vary per
165 // plane. Revisit as part of the future change to YV12_BUFFER_CONFIG to
166 // support additional planes.
167 int subsampling_x;
168 int subsampling_y;
169
Sebastien Alaiwan71e87842017-04-12 16:03:28 +0200170#if CONFIG_HIGHBITDEPTH
Yaowu Xuc27fc142016-08-22 16:08:15 -0700171 // Marks if we need to use 16bit frame buffers (1: yes, 0: no).
172 int use_highbitdepth;
173#endif
Yaowu Xuc27fc142016-08-22 16:08:15 -0700174 YV12_BUFFER_CONFIG *frame_to_show;
175 RefCntBuffer *prev_frame;
176
177 // TODO(hkuang): Combine this with cur_buf in macroblockd.
178 RefCntBuffer *cur_frame;
179
180 int ref_frame_map[REF_FRAMES]; /* maps fb_idx to reference slot */
181
182 // Prepare ref_frame_map for the next frame.
183 // Only used in frame parallel decode.
184 int next_ref_frame_map[REF_FRAMES];
185
186 // TODO(jkoleszar): could expand active_ref_idx to 4, with 0 as intra, and
187 // roll new_fb_idx into it.
188
189 // Each Inter frame can reference INTER_REFS_PER_FRAME buffers
190 RefBuffer frame_refs[INTER_REFS_PER_FRAME];
191
192 int new_fb_idx;
193
194 FRAME_TYPE last_frame_type; /* last frame's frame type for motion search.*/
Yaowu Xuc27fc142016-08-22 16:08:15 -0700195 FRAME_TYPE frame_type;
196
197 int show_frame;
198 int last_show_frame;
199 int show_existing_frame;
200#if CONFIG_EXT_REFS
201 // Flag for a frame used as a reference - not written to the bitstream
202 int is_reference_frame;
203#endif // CONFIG_EXT_REFS
204
205 // Flag signaling that the frame is encoded using only INTRA modes.
206 uint8_t intra_only;
207 uint8_t last_intra_only;
208
209 int allow_high_precision_mv;
210
Alex Conversee46382a2017-05-15 11:40:20 -0700211#if CONFIG_PALETTE || CONFIG_INTRABC
Yaowu Xuc27fc142016-08-22 16:08:15 -0700212 int allow_screen_content_tools;
Alex Conversee46382a2017-05-15 11:40:20 -0700213#endif // CONFIG_PALETTE || CONFIG_INTRABC
Debargha Mukherjee9e2c7a62017-05-23 21:18:42 -0700214#if CONFIG_EXT_INTER
215#if CONFIG_INTERINTRA
216 int allow_interintra_compound;
217#endif // CONFIG_INTERINTRA
218#if CONFIG_WEDGE || CONFIG_COMPOUND_SEGMENT
219 int allow_masked_compound;
220#endif // CONFIG_WEDGE || CONFIG_COMPOUND_SEGMENT
221#endif // CONFIG_EXT_INTER
Yaowu Xuc27fc142016-08-22 16:08:15 -0700222
223 // Flag signaling which frame contexts should be reset to default values.
224 RESET_FRAME_CONTEXT_MODE reset_frame_context;
225
226 // MBs, mb_rows/cols is in 16-pixel units; mi_rows/cols is in
227 // MODE_INFO (8-pixel) units.
228 int MBs;
229 int mb_rows, mi_rows;
230 int mb_cols, mi_cols;
231 int mi_stride;
232
233 /* profile settings */
234 TX_MODE tx_mode;
235
236 int base_qindex;
237 int y_dc_delta_q;
238 int uv_dc_delta_q;
239 int uv_ac_delta_q;
240 int16_t y_dequant[MAX_SEGMENTS][2];
241 int16_t uv_dequant[MAX_SEGMENTS][2];
242
243#if CONFIG_AOM_QM
244 // Global quant matrix tables
Thomas Davies6675adf2017-05-04 17:39:21 +0100245 qm_val_t *giqmatrix[NUM_QM_LEVELS][2][2][TX_SIZES_ALL];
246 qm_val_t *gqmatrix[NUM_QM_LEVELS][2][2][TX_SIZES_ALL];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700247
248 // Local quant matrix tables for each frame
Thomas Davies6675adf2017-05-04 17:39:21 +0100249 qm_val_t *y_iqmatrix[MAX_SEGMENTS][2][TX_SIZES_ALL];
250 qm_val_t *uv_iqmatrix[MAX_SEGMENTS][2][TX_SIZES_ALL];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700251 // Encoder
Thomas Davies6675adf2017-05-04 17:39:21 +0100252 qm_val_t *y_qmatrix[MAX_SEGMENTS][2][TX_SIZES_ALL];
253 qm_val_t *uv_qmatrix[MAX_SEGMENTS][2][TX_SIZES_ALL];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700254
255 int using_qmatrix;
256 int min_qmlevel;
257 int max_qmlevel;
258#endif
259#if CONFIG_NEW_QUANT
260 dequant_val_type_nuq y_dequant_nuq[MAX_SEGMENTS][QUANT_PROFILES][COEF_BANDS];
261 dequant_val_type_nuq uv_dequant_nuq[MAX_SEGMENTS][QUANT_PROFILES][COEF_BANDS];
262#endif
263
264 /* We allocate a MODE_INFO struct for each macroblock, together with
265 an extra row on top and column on the left to simplify prediction. */
266 int mi_alloc_size;
267 MODE_INFO *mip; /* Base of allocated array */
268 MODE_INFO *mi; /* Corresponds to upper left visible macroblock */
269
270 // TODO(agrange): Move prev_mi into encoder structure.
271 // prev_mip and prev_mi will only be allocated in encoder.
272 MODE_INFO *prev_mip; /* MODE_INFO array 'mip' from last decoded frame */
273 MODE_INFO *prev_mi; /* 'mi' from last frame (points into prev_mip) */
274
275 // Separate mi functions between encoder and decoder.
Yaowu Xuf883b422016-08-30 14:01:10 -0700276 int (*alloc_mi)(struct AV1Common *cm, int mi_size);
277 void (*free_mi)(struct AV1Common *cm);
278 void (*setup_mi)(struct AV1Common *cm);
Yaowu Xuc27fc142016-08-22 16:08:15 -0700279
280 // Grid of pointers to 8x8 MODE_INFO structs. Any 8x8 not in the visible
281 // area will be NULL.
282 MODE_INFO **mi_grid_base;
283 MODE_INFO **mi_grid_visible;
284 MODE_INFO **prev_mi_grid_base;
285 MODE_INFO **prev_mi_grid_visible;
286
287 // Whether to use previous frame's motion vectors for prediction.
288 int use_prev_frame_mvs;
289
290 // Persistent mb segment id map used in prediction.
291 int seg_map_idx;
292 int prev_seg_map_idx;
293
294 uint8_t *seg_map_array[NUM_PING_PONG_BUFFERS];
295 uint8_t *last_frame_seg_map;
296 uint8_t *current_frame_seg_map;
297 int seg_map_alloc_size;
298
James Zern7b9407a2016-05-18 23:48:05 -0700299 InterpFilter interp_filter;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700300
301 loop_filter_info_n lf_info;
Fergus Simpsonbc189932017-05-16 17:02:39 -0700302#if CONFIG_FRAME_SUPERRES
303 // The numerator of the superres scale; the denominator is fixed.
304 uint8_t superres_scale_numerator;
305#endif // CONFIG_FRAME_SUPERRES
Yaowu Xuc27fc142016-08-22 16:08:15 -0700306#if CONFIG_LOOP_RESTORATION
Debargha Mukherjeea43a2d92017-01-03 15:14:57 -0800307 RestorationInfo rst_info[MAX_MB_PLANE];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700308 RestorationInternal rst_internal;
309#endif // CONFIG_LOOP_RESTORATION
310
311 // Flag signaling how frame contexts should be updated at the end of
312 // a frame decode
313 REFRESH_FRAME_CONTEXT_MODE refresh_frame_context;
314
315 int ref_frame_sign_bias[TOTAL_REFS_PER_FRAME]; /* Two state 0, 1 */
316
317 struct loopfilter lf;
318 struct segmentation seg;
319
320 int frame_parallel_decode; // frame-based threading.
321
Sarah Parkere68a3e42017-02-16 14:03:24 -0800322#if CONFIG_EXT_TX
323 int reduced_tx_set_used;
324#endif // CONFIG_EXT_TX
325
Yaowu Xuc27fc142016-08-22 16:08:15 -0700326// Context probabilities for reference frame prediction
327#if CONFIG_EXT_REFS
328 MV_REFERENCE_FRAME comp_fwd_ref[FWD_REFS];
329 MV_REFERENCE_FRAME comp_bwd_ref[BWD_REFS];
330#else
331 MV_REFERENCE_FRAME comp_fixed_ref;
332 MV_REFERENCE_FRAME comp_var_ref[COMP_REFS];
333#endif // CONFIG_EXT_REFS
334 REFERENCE_MODE reference_mode;
335
336 FRAME_CONTEXT *fc; /* this frame entropy */
337 FRAME_CONTEXT *frame_contexts; // FRAME_CONTEXTS
Thomas Daede10e1da92017-04-26 13:22:21 -0700338 FRAME_CONTEXT *pre_fc; // Context referenced in this frame
Yaowu Xuc27fc142016-08-22 16:08:15 -0700339 unsigned int frame_context_idx; /* Context to use/update */
340 FRAME_COUNTS counts;
341
Yaowu Xuc27fc142016-08-22 16:08:15 -0700342 unsigned int current_video_frame;
343 BITSTREAM_PROFILE profile;
344
Yaowu Xuf883b422016-08-30 14:01:10 -0700345 // AOM_BITS_8 in profile 0 or 1, AOM_BITS_10 or AOM_BITS_12 in profile 2 or 3.
346 aom_bit_depth_t bit_depth;
347 aom_bit_depth_t dequant_bit_depth; // bit_depth of current dequantizer
Yaowu Xuc27fc142016-08-22 16:08:15 -0700348
349 int error_resilient_mode;
350
351#if !CONFIG_EXT_TILE
352 int log2_tile_cols, log2_tile_rows;
353#endif // !CONFIG_EXT_TILE
354 int tile_cols, tile_rows;
355 int tile_width, tile_height; // In MI units
Yunqing Wangd8cd55f2017-02-27 12:16:00 -0800356#if CONFIG_EXT_TILE
357 unsigned int tile_encoding_mode;
358#endif // CONFIG_EXT_TILE
Yaowu Xuc27fc142016-08-22 16:08:15 -0700359
Fangwen Fu7b9f2b32017-01-17 14:01:52 -0800360#if CONFIG_DEPENDENT_HORZTILES
361 int dependent_horz_tiles;
Fangwen Fu73126c02017-02-08 22:37:47 -0800362#if CONFIG_TILE_GROUPS
363 int tile_group_start_row[MAX_TILE_ROWS][MAX_TILE_COLS];
364 int tile_group_start_col[MAX_TILE_ROWS][MAX_TILE_COLS];
365#endif
Fangwen Fu7b9f2b32017-01-17 14:01:52 -0800366#endif
Ryan Lei9b02b0e2017-01-30 15:52:20 -0800367#if CONFIG_LOOPFILTERING_ACROSS_TILES
Ryan Lei7386eda2016-12-08 21:08:31 -0800368 int loop_filter_across_tiles_enabled;
Ryan Lei9b02b0e2017-01-30 15:52:20 -0800369#endif // CONFIG_LOOPFILTERING_ACROSS_TILES
Ryan Lei7386eda2016-12-08 21:08:31 -0800370
Yaowu Xuc27fc142016-08-22 16:08:15 -0700371 int byte_alignment;
372 int skip_loop_filter;
373
374 // Private data associated with the frame buffer callbacks.
375 void *cb_priv;
Yaowu Xuf883b422016-08-30 14:01:10 -0700376 aom_get_frame_buffer_cb_fn_t get_fb_cb;
377 aom_release_frame_buffer_cb_fn_t release_fb_cb;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700378
379 // Handles memory for the codec.
380 InternalFrameBufferList int_frame_buffers;
381
382 // External BufferPool passed from outside.
383 BufferPool *buffer_pool;
384
385 PARTITION_CONTEXT *above_seg_context;
386 ENTROPY_CONTEXT *above_context[MAX_MB_PLANE];
387#if CONFIG_VAR_TX
388 TXFM_CONTEXT *above_txfm_context;
Jingning Han6e4955d2017-05-30 22:54:48 -0700389 TXFM_CONTEXT *top_txfm_context[MAX_MB_PLANE];
390 TXFM_CONTEXT left_txfm_context[MAX_MB_PLANE][2 * MAX_MIB_SIZE];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700391#endif
392 int above_context_alloc_cols;
393
394 // scratch memory for intraonly/keyframe forward updates from default tables
395 // - this is intentionally not placed in FRAME_CONTEXT since it's reset upon
396 // each keyframe and not used afterwards
Yaowu Xuf883b422016-08-30 14:01:10 -0700397 aom_prob kf_y_prob[INTRA_MODES][INTRA_MODES][INTRA_MODES - 1];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700398#if CONFIG_GLOBAL_MOTION
David Barkercf3d0b02016-11-10 10:14:49 +0000399 WarpedMotionParams global_motion[TOTAL_REFS_PER_FRAME];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700400#endif
401
402 BLOCK_SIZE sb_size; // Size of the superblock used for this frame
403 int mib_size; // Size of the superblock in units of MI blocks
404 int mib_size_log2; // Log 2 of above.
Jean-Marc Valin01435132017-02-18 14:12:53 -0500405#if CONFIG_CDEF
Steinar Midtskogen0c966a52017-04-18 14:38:13 +0200406 int cdef_dering_damping;
407 int cdef_clpf_damping;
Jean-Marc Valin5f5c1322017-03-21 16:20:21 -0400408 int nb_cdef_strengths;
409 int cdef_strengths[CDEF_MAX_STRENGTHS];
Jean-Marc Valine9f77422017-03-22 17:09:51 -0400410 int cdef_uv_strengths[CDEF_MAX_STRENGTHS];
Jean-Marc Valin5f5c1322017-03-21 16:20:21 -0400411 int cdef_bits;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700412#endif
Thomas Davies80188d12016-10-26 16:08:35 -0700413
Arild Fuldseth07441162016-08-15 15:07:52 +0200414#if CONFIG_DELTA_Q
415 int delta_q_present_flag;
Thomas Daviesf6936102016-09-05 16:51:31 +0100416 // Resolution of delta quant
417 int delta_q_res;
Fangwen Fu231fe422017-04-24 17:52:29 -0700418#if CONFIG_EXT_DELTA_Q
419 int delta_lf_present_flag;
420 // Resolution of delta lf level
421 int delta_lf_res;
422#endif
Arild Fuldseth07441162016-08-15 15:07:52 +0200423#endif
Thomas Davies80188d12016-10-26 16:08:35 -0700424#if CONFIG_TILE_GROUPS
425 int num_tg;
426#endif
Arild Fuldseth (arilfuld)5114b7b2016-11-09 13:32:54 +0100427#if CONFIG_REFERENCE_BUFFER
428 int current_frame_id;
429 int ref_frame_id[REF_FRAMES];
430 int valid_for_referencing[REF_FRAMES];
431 int refresh_mask;
432 int invalid_delta_frame_id_minus1;
433#endif
Alex Converseeb780e72016-12-13 12:46:41 -0800434#if CONFIG_ANS && ANS_MAX_SYMBOLS
435 int ans_window_size_log2;
436#endif
Yaowu Xuf883b422016-08-30 14:01:10 -0700437} AV1_COMMON;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700438
Arild Fuldseth (arilfuld)5114b7b2016-11-09 13:32:54 +0100439#if CONFIG_REFERENCE_BUFFER
440/* Initial version of sequence header structure */
441typedef struct SequenceHeader {
442 int frame_id_numbers_present_flag;
443 int frame_id_length_minus7;
444 int delta_frame_id_length_minus2;
445} SequenceHeader;
446#endif
447
Yaowu Xuc27fc142016-08-22 16:08:15 -0700448// TODO(hkuang): Don't need to lock the whole pool after implementing atomic
449// frame reference count.
450static void lock_buffer_pool(BufferPool *const pool) {
451#if CONFIG_MULTITHREAD
452 pthread_mutex_lock(&pool->pool_mutex);
453#else
454 (void)pool;
455#endif
456}
457
458static void unlock_buffer_pool(BufferPool *const pool) {
459#if CONFIG_MULTITHREAD
460 pthread_mutex_unlock(&pool->pool_mutex);
461#else
462 (void)pool;
463#endif
464}
465
Yaowu Xuf883b422016-08-30 14:01:10 -0700466static INLINE YV12_BUFFER_CONFIG *get_ref_frame(AV1_COMMON *cm, int index) {
Yaowu Xuc27fc142016-08-22 16:08:15 -0700467 if (index < 0 || index >= REF_FRAMES) return NULL;
468 if (cm->ref_frame_map[index] < 0) return NULL;
469 assert(cm->ref_frame_map[index] < FRAME_BUFFERS);
470 return &cm->buffer_pool->frame_bufs[cm->ref_frame_map[index]].buf;
471}
472
473static INLINE YV12_BUFFER_CONFIG *get_frame_new_buffer(
Yaowu Xuf883b422016-08-30 14:01:10 -0700474 const AV1_COMMON *const cm) {
Yaowu Xuc27fc142016-08-22 16:08:15 -0700475 return &cm->buffer_pool->frame_bufs[cm->new_fb_idx].buf;
476}
477
Yaowu Xuf883b422016-08-30 14:01:10 -0700478static INLINE int get_free_fb(AV1_COMMON *cm) {
Yaowu Xuc27fc142016-08-22 16:08:15 -0700479 RefCntBuffer *const frame_bufs = cm->buffer_pool->frame_bufs;
480 int i;
481
482 lock_buffer_pool(cm->buffer_pool);
483 for (i = 0; i < FRAME_BUFFERS; ++i)
484 if (frame_bufs[i].ref_count == 0) break;
485
486 if (i != FRAME_BUFFERS) {
487 frame_bufs[i].ref_count = 1;
488 } else {
489 // Reset i to be INVALID_IDX to indicate no free buffer found.
490 i = INVALID_IDX;
491 }
492
493 unlock_buffer_pool(cm->buffer_pool);
494 return i;
495}
496
497static INLINE void ref_cnt_fb(RefCntBuffer *bufs, int *idx, int new_idx) {
498 const int ref_index = *idx;
499
500 if (ref_index >= 0 && bufs[ref_index].ref_count > 0)
501 bufs[ref_index].ref_count--;
502
503 *idx = new_idx;
504
505 bufs[new_idx].ref_count++;
506}
507
Yaowu Xuf883b422016-08-30 14:01:10 -0700508static INLINE int mi_cols_aligned_to_sb(const AV1_COMMON *cm) {
Yaowu Xuc27fc142016-08-22 16:08:15 -0700509 return ALIGN_POWER_OF_TWO(cm->mi_cols, cm->mib_size_log2);
510}
511
Yaowu Xuf883b422016-08-30 14:01:10 -0700512static INLINE int mi_rows_aligned_to_sb(const AV1_COMMON *cm) {
Yaowu Xuc27fc142016-08-22 16:08:15 -0700513 return ALIGN_POWER_OF_TWO(cm->mi_rows, cm->mib_size_log2);
514}
515
Yaowu Xuf883b422016-08-30 14:01:10 -0700516static INLINE int frame_is_intra_only(const AV1_COMMON *const cm) {
Yaowu Xuc27fc142016-08-22 16:08:15 -0700517 return cm->frame_type == KEY_FRAME || cm->intra_only;
518}
519
Yaowu Xuf883b422016-08-30 14:01:10 -0700520static INLINE void av1_init_macroblockd(AV1_COMMON *cm, MACROBLOCKD *xd,
Yushin Cho77bba8d2016-11-04 16:36:56 -0700521#if CONFIG_PVQ
522 tran_low_t *pvq_ref_coeff,
523#endif
Luc Trudeauf8164152017-04-11 16:20:51 -0400524#if CONFIG_CFL
525 CFL_CTX *cfl,
526#endif
Yaowu Xuf883b422016-08-30 14:01:10 -0700527 tran_low_t *dqcoeff) {
Luc Trudeaue2ac9852017-06-05 16:20:01 -0400528 for (int i = 0; i < MAX_MB_PLANE; ++i) {
Yaowu Xuc27fc142016-08-22 16:08:15 -0700529 xd->plane[i].dqcoeff = dqcoeff;
Yushin Cho77bba8d2016-11-04 16:36:56 -0700530#if CONFIG_PVQ
531 xd->plane[i].pvq_ref_coeff = pvq_ref_coeff;
532#endif
Luc Trudeauf8164152017-04-11 16:20:51 -0400533#if CONFIG_CFL
534 xd->cfl = cfl;
Luc Trudeaudac5e392017-06-05 15:52:02 -0400535 cfl_init(cfl, cm);
Luc Trudeauf8164152017-04-11 16:20:51 -0400536#endif
Yaowu Xuc27fc142016-08-22 16:08:15 -0700537 xd->above_context[i] = cm->above_context[i];
538 if (xd->plane[i].plane_type == PLANE_TYPE_Y) {
539 memcpy(xd->plane[i].seg_dequant, cm->y_dequant, sizeof(cm->y_dequant));
540#if CONFIG_AOM_QM
541 memcpy(xd->plane[i].seg_iqmatrix, cm->y_iqmatrix, sizeof(cm->y_iqmatrix));
542#endif
543
544#if CONFIG_NEW_QUANT
545 memcpy(xd->plane[i].seg_dequant_nuq, cm->y_dequant_nuq,
546 sizeof(cm->y_dequant_nuq));
547#endif
548 } else {
549 memcpy(xd->plane[i].seg_dequant, cm->uv_dequant, sizeof(cm->uv_dequant));
550#if CONFIG_AOM_QM
551 memcpy(xd->plane[i].seg_iqmatrix, cm->uv_iqmatrix,
552 sizeof(cm->uv_iqmatrix));
553#endif
554#if CONFIG_NEW_QUANT
555 memcpy(xd->plane[i].seg_dequant_nuq, cm->uv_dequant_nuq,
556 sizeof(cm->uv_dequant_nuq));
557#endif
558 }
Yaowu Xuc27fc142016-08-22 16:08:15 -0700559 }
Luc Trudeaue2ac9852017-06-05 16:20:01 -0400560 xd->fc = cm->fc;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700561 xd->above_seg_context = cm->above_seg_context;
562#if CONFIG_VAR_TX
563 xd->above_txfm_context = cm->above_txfm_context;
564#endif
565 xd->mi_stride = cm->mi_stride;
566 xd->error_info = &cm->error;
567}
568
569static INLINE void set_skip_context(MACROBLOCKD *xd, int mi_row, int mi_col) {
Yaowu Xuc27fc142016-08-22 16:08:15 -0700570 int i;
Jingning Hanf65b89a2017-05-23 16:10:50 -0700571 int row_offset = mi_row;
572 int col_offset = mi_col;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700573 for (i = 0; i < MAX_MB_PLANE; ++i) {
574 struct macroblockd_plane *const pd = &xd->plane[i];
Jingning Han91d9a792017-04-18 12:01:52 -0700575#if CONFIG_CHROMA_SUB8X8
576 if (xd->mi[0]->mbmi.sb_type < BLOCK_8X8) {
577 // Offset the buffer pointer
Jingning Hanf65b89a2017-05-23 16:10:50 -0700578 if (pd->subsampling_y && (mi_row & 0x01)) row_offset = mi_row - 1;
579 if (pd->subsampling_x && (mi_col & 0x01)) col_offset = mi_col - 1;
Jingning Han91d9a792017-04-18 12:01:52 -0700580 }
581#endif
Jingning Hanf65b89a2017-05-23 16:10:50 -0700582 int above_idx = col_offset << (MI_SIZE_LOG2 - tx_size_wide_log2[0]);
583 int left_idx = (row_offset & MAX_MIB_MASK)
Timothy B. Terriberry5e816432017-05-05 13:58:32 -0700584 << (MI_SIZE_LOG2 - tx_size_high_log2[0]);
Yaowu Xuc27fc142016-08-22 16:08:15 -0700585 pd->above_context = &xd->above_context[i][above_idx >> pd->subsampling_x];
586 pd->left_context = &xd->left_context[i][left_idx >> pd->subsampling_y];
587 }
588}
589
590static INLINE int calc_mi_size(int len) {
591 // len is in mi units.
592 return len + MAX_MIB_SIZE;
593}
594
Jingning Hanfaad0e12016-12-07 10:54:57 -0800595static INLINE void set_plane_n4(MACROBLOCKD *const xd, int bw, int bh) {
Jingning Hana6923f72016-07-15 08:50:14 -0700596 int i;
597 for (i = 0; i < MAX_MB_PLANE; i++) {
598 xd->plane[i].n4_w = (bw << 1) >> xd->plane[i].subsampling_x;
599 xd->plane[i].n4_h = (bh << 1) >> xd->plane[i].subsampling_y;
Jingning Hanfaad0e12016-12-07 10:54:57 -0800600
601 xd->plane[i].width = (bw * MI_SIZE) >> xd->plane[i].subsampling_x;
602 xd->plane[i].height = (bh * MI_SIZE) >> xd->plane[i].subsampling_y;
Jingning Hanc20dc8e2017-02-17 15:37:28 -0800603
Jingning Han31b6a4f2017-02-23 11:05:53 -0800604#if !CONFIG_CHROMA_2X2
Jingning Hanc20dc8e2017-02-17 15:37:28 -0800605 xd->plane[i].width = AOMMAX(xd->plane[i].width, 4);
606 xd->plane[i].height = AOMMAX(xd->plane[i].height, 4);
Jingning Han31b6a4f2017-02-23 11:05:53 -0800607#endif
Jingning Hana6923f72016-07-15 08:50:14 -0700608 }
609}
610
Urvang Joshi359dc2b2017-04-27 15:41:47 -0700611static INLINE void set_mi_row_col(MACROBLOCKD *xd, const TileInfo *const tile,
612 int mi_row, int bh, int mi_col, int bw,
Fangwen Fu7b9f2b32017-01-17 14:01:52 -0800613#if CONFIG_DEPENDENT_HORZTILES
Urvang Joshi359dc2b2017-04-27 15:41:47 -0700614 int dependent_horz_tile_flag,
615#endif // CONFIG_DEPENDENT_HORZTILES
Yaowu Xuc27fc142016-08-22 16:08:15 -0700616 int mi_rows, int mi_cols) {
617 xd->mb_to_top_edge = -((mi_row * MI_SIZE) * 8);
618 xd->mb_to_bottom_edge = ((mi_rows - bh - mi_row) * MI_SIZE) * 8;
619 xd->mb_to_left_edge = -((mi_col * MI_SIZE) * 8);
620 xd->mb_to_right_edge = ((mi_cols - bw - mi_col) * MI_SIZE) * 8;
621
Urvang Joshi359dc2b2017-04-27 15:41:47 -0700622#if CONFIG_DEPENDENT_HORZTILES
623 if (dependent_horz_tile_flag) {
624#if CONFIG_TILE_GROUPS
625 xd->up_available = (mi_row > tile->mi_row_start) || !tile->tg_horz_boundary;
626#else
627 xd->up_available = (mi_row > 0);
628#endif // CONFIG_TILE_GROUPS
629 } else {
630#endif // CONFIG_DEPENDENT_HORZTILES
631 // Are edges available for intra prediction?
632 xd->up_available = (mi_row > tile->mi_row_start);
633#if CONFIG_DEPENDENT_HORZTILES
634 }
635#endif // CONFIG_DEPENDENT_HORZTILES
636
Yaowu Xuc27fc142016-08-22 16:08:15 -0700637 xd->left_available = (mi_col > tile->mi_col_start);
Jingning Han3da18d62017-05-02 12:43:58 -0700638#if CONFIG_CHROMA_SUB8X8
639 xd->chroma_up_available = xd->up_available;
640 xd->chroma_left_available = xd->left_available;
641 if (xd->plane[1].subsampling_x && bw < mi_size_wide[BLOCK_8X8])
642 xd->chroma_left_available = (mi_col - 1) > tile->mi_col_start;
643 if (xd->plane[1].subsampling_y && bh < mi_size_high[BLOCK_8X8])
644 xd->chroma_up_available = (mi_row - 1) > tile->mi_row_start;
645#endif
Yaowu Xuc27fc142016-08-22 16:08:15 -0700646 if (xd->up_available) {
647 xd->above_mi = xd->mi[-xd->mi_stride];
648 // above_mi may be NULL in encoder's first pass.
649 xd->above_mbmi = xd->above_mi ? &xd->above_mi->mbmi : NULL;
650 } else {
651 xd->above_mi = NULL;
652 xd->above_mbmi = NULL;
653 }
654
655 if (xd->left_available) {
656 xd->left_mi = xd->mi[-1];
657 // left_mi may be NULL in encoder's first pass.
658 xd->left_mbmi = xd->left_mi ? &xd->left_mi->mbmi : NULL;
659 } else {
660 xd->left_mi = NULL;
661 xd->left_mbmi = NULL;
662 }
663
664 xd->n8_h = bh;
665 xd->n8_w = bw;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700666 xd->is_sec_rect = 0;
667 if (xd->n8_w < xd->n8_h)
668 if (mi_col & (xd->n8_h - 1)) xd->is_sec_rect = 1;
669
670 if (xd->n8_w > xd->n8_h)
671 if (mi_row & (xd->n8_w - 1)) xd->is_sec_rect = 1;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700672}
673
Yaowu Xuf883b422016-08-30 14:01:10 -0700674static INLINE const aom_prob *get_y_mode_probs(const AV1_COMMON *cm,
Yaowu Xuc27fc142016-08-22 16:08:15 -0700675 const MODE_INFO *mi,
676 const MODE_INFO *above_mi,
677 const MODE_INFO *left_mi,
678 int block) {
Yaowu Xuf883b422016-08-30 14:01:10 -0700679 const PREDICTION_MODE above = av1_above_block_mode(mi, above_mi, block);
680 const PREDICTION_MODE left = av1_left_block_mode(mi, left_mi, block);
Yaowu Xuc27fc142016-08-22 16:08:15 -0700681 return cm->kf_y_prob[above][left];
682}
683
Thomas Davies1bfb5ed2017-01-11 15:28:11 +0000684static INLINE aom_cdf_prob *get_y_mode_cdf(FRAME_CONTEXT *tile_ctx,
685 const MODE_INFO *mi,
Thomas9ac55082016-09-23 18:04:17 +0100686 const MODE_INFO *above_mi,
687 const MODE_INFO *left_mi,
688 int block) {
Nathan E. Egge3ef926e2016-09-07 18:20:41 -0400689 const PREDICTION_MODE above = av1_above_block_mode(mi, above_mi, block);
690 const PREDICTION_MODE left = av1_left_block_mode(mi, left_mi, block);
Thomas Davies1bfb5ed2017-01-11 15:28:11 +0000691 return tile_ctx->kf_y_cdf[above][left];
Nathan E. Egge3ef926e2016-09-07 18:20:41 -0400692}
Nathan E. Egge3ef926e2016-09-07 18:20:41 -0400693
Yaowu Xuc27fc142016-08-22 16:08:15 -0700694static INLINE void update_partition_context(MACROBLOCKD *xd, int mi_row,
695 int mi_col, BLOCK_SIZE subsize,
696 BLOCK_SIZE bsize) {
697 PARTITION_CONTEXT *const above_ctx = xd->above_seg_context + mi_col;
698 PARTITION_CONTEXT *const left_ctx =
699 xd->left_seg_context + (mi_row & MAX_MIB_MASK);
700
701#if CONFIG_EXT_PARTITION_TYPES
Jingning Hanc709e1f2016-12-06 14:48:09 -0800702 const int bw = mi_size_wide[bsize];
703 const int bh = mi_size_high[bsize];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700704 memset(above_ctx, partition_context_lookup[subsize].above, bw);
705 memset(left_ctx, partition_context_lookup[subsize].left, bh);
706#else
707 // num_4x4_blocks_wide_lookup[bsize] / 2
Jingning Hanc709e1f2016-12-06 14:48:09 -0800708 const int bs = mi_size_wide[bsize];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700709
710 // update the partition context at the end notes. set partition bits
711 // of block sizes larger than the current one to be one, and partition
712 // bits of smaller block sizes to be zero.
713 memset(above_ctx, partition_context_lookup[subsize].above, bs);
714 memset(left_ctx, partition_context_lookup[subsize].left, bs);
715#endif // CONFIG_EXT_PARTITION_TYPES
716}
717
Jingning Han18c53c82017-02-17 14:49:57 -0800718#if CONFIG_CB4X4
Yaowu Xu4ff59b52017-04-24 12:41:56 -0700719static INLINE int is_chroma_reference(int mi_row, int mi_col, BLOCK_SIZE bsize,
720 int subsampling_x, int subsampling_y) {
Jingning Han31b6a4f2017-02-23 11:05:53 -0800721#if CONFIG_CHROMA_2X2
722 return 1;
723#endif
Jingning Hane2db3872017-04-18 11:50:53 -0700724
725#if CONFIG_CHROMA_SUB8X8
726 const int bw = mi_size_wide[bsize];
727 const int bh = mi_size_high[bsize];
728
729 int ref_pos = ((mi_row & 0x01) || !(bh & 0x01) || !subsampling_y) &&
730 ((mi_col & 0x01) || !(bw & 0x01) || !subsampling_x);
731
732 return ref_pos;
733#else
Jingning Hand3a64432017-04-06 17:04:17 -0700734 int ref_pos = !(((mi_row & 0x01) && subsampling_y) ||
735 ((mi_col & 0x01) && subsampling_x));
736
737 if (bsize >= BLOCK_8X8) ref_pos = 1;
738
739 return ref_pos;
Jingning Hane2db3872017-04-18 11:50:53 -0700740#endif
Jingning Han18c53c82017-02-17 14:49:57 -0800741}
Jingning Han2d2dac22017-04-11 09:41:10 -0700742
Yaowu Xu4ff59b52017-04-24 12:41:56 -0700743static INLINE BLOCK_SIZE scale_chroma_bsize(BLOCK_SIZE bsize, int subsampling_x,
744 int subsampling_y) {
Jingning Han2d2dac22017-04-11 09:41:10 -0700745 BLOCK_SIZE bs = bsize;
746
747 if (bs < BLOCK_8X8) {
748 if (subsampling_x == 1 && subsampling_y == 1)
749 bs = BLOCK_8X8;
750 else if (subsampling_x == 1)
751 bs = BLOCK_8X4;
752 else if (subsampling_y == 1)
753 bs = BLOCK_4X8;
754 }
755
756 return bs;
757}
Jingning Han18c53c82017-02-17 14:49:57 -0800758#endif
759
Yaowu Xuc27fc142016-08-22 16:08:15 -0700760#if CONFIG_EXT_PARTITION_TYPES
761static INLINE void update_ext_partition_context(MACROBLOCKD *xd, int mi_row,
762 int mi_col, BLOCK_SIZE subsize,
763 BLOCK_SIZE bsize,
764 PARTITION_TYPE partition) {
765 if (bsize >= BLOCK_8X8) {
Jingning Han456e0862017-01-19 16:04:26 -0800766 const int hbs = mi_size_wide[bsize] / 2;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700767 BLOCK_SIZE bsize2 = get_subsize(bsize, PARTITION_SPLIT);
768 switch (partition) {
769 case PARTITION_SPLIT:
770 if (bsize != BLOCK_8X8) break;
771 case PARTITION_NONE:
772 case PARTITION_HORZ:
773 case PARTITION_VERT:
774 update_partition_context(xd, mi_row, mi_col, subsize, bsize);
775 break;
776 case PARTITION_HORZ_A:
777 update_partition_context(xd, mi_row, mi_col, bsize2, subsize);
778 update_partition_context(xd, mi_row + hbs, mi_col, subsize, subsize);
779 break;
780 case PARTITION_HORZ_B:
781 update_partition_context(xd, mi_row, mi_col, subsize, subsize);
782 update_partition_context(xd, mi_row + hbs, mi_col, bsize2, subsize);
783 break;
784 case PARTITION_VERT_A:
785 update_partition_context(xd, mi_row, mi_col, bsize2, subsize);
786 update_partition_context(xd, mi_row, mi_col + hbs, subsize, subsize);
787 break;
788 case PARTITION_VERT_B:
789 update_partition_context(xd, mi_row, mi_col, subsize, subsize);
790 update_partition_context(xd, mi_row, mi_col + hbs, bsize2, subsize);
791 break;
792 default: assert(0 && "Invalid partition type");
793 }
794 }
795}
796#endif // CONFIG_EXT_PARTITION_TYPES
797
798static INLINE int partition_plane_context(const MACROBLOCKD *xd, int mi_row,
Alex Converse55c6bde2017-01-12 15:55:31 -0800799 int mi_col,
800#if CONFIG_UNPOISON_PARTITION_CTX
801 int has_rows, int has_cols,
802#endif
803 BLOCK_SIZE bsize) {
804#if CONFIG_UNPOISON_PARTITION_CTX
805 const PARTITION_CONTEXT *above_ctx = xd->above_seg_context + mi_col;
806 const PARTITION_CONTEXT *left_ctx =
807 xd->left_seg_context + (mi_row & MAX_MIB_MASK);
808 // Minimum partition point is 8x8. Offset the bsl accordingly.
809 const int bsl = mi_width_log2_lookup[bsize] - mi_width_log2_lookup[BLOCK_8X8];
810 int above = (*above_ctx >> bsl) & 1, left = (*left_ctx >> bsl) & 1;
811
812 assert(b_width_log2_lookup[bsize] == b_height_log2_lookup[bsize]);
813 assert(bsl >= 0);
814
815 if (has_rows && has_cols)
816 return (left * 2 + above) + bsl * PARTITION_PLOFFSET;
817 else if (has_rows && !has_cols)
818 return PARTITION_CONTEXTS_PRIMARY + bsl;
819 else if (!has_rows && has_cols)
820 return PARTITION_CONTEXTS_PRIMARY + PARTITION_BLOCK_SIZES + bsl;
821 else
Alex Converse2b9d19d2017-04-03 11:11:17 -0700822 return PARTITION_CONTEXTS; // Bogus context, forced SPLIT
Alex Converse55c6bde2017-01-12 15:55:31 -0800823#else
Yaowu Xuc27fc142016-08-22 16:08:15 -0700824 const PARTITION_CONTEXT *above_ctx = xd->above_seg_context + mi_col;
825 const PARTITION_CONTEXT *left_ctx =
826 xd->left_seg_context + (mi_row & MAX_MIB_MASK);
Jingning Hanbcf62ea2016-12-08 16:08:38 -0800827 // Minimum partition point is 8x8. Offset the bsl accordingly.
828 const int bsl = mi_width_log2_lookup[bsize] - mi_width_log2_lookup[BLOCK_8X8];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700829 int above = (*above_ctx >> bsl) & 1, left = (*left_ctx >> bsl) & 1;
830
831 assert(b_width_log2_lookup[bsize] == b_height_log2_lookup[bsize]);
832 assert(bsl >= 0);
833
834 return (left * 2 + above) + bsl * PARTITION_PLOFFSET;
Alex Converse55c6bde2017-01-12 15:55:31 -0800835#endif
Yaowu Xuc27fc142016-08-22 16:08:15 -0700836}
837
Yaowu Xu4ff59b52017-04-24 12:41:56 -0700838static INLINE int max_block_wide(const MACROBLOCKD *xd, BLOCK_SIZE bsize,
839 int plane) {
Jingning Hanf65b8702016-10-31 12:13:20 -0700840 int max_blocks_wide = block_size_wide[bsize];
841 const struct macroblockd_plane *const pd = &xd->plane[plane];
842
843 if (xd->mb_to_right_edge < 0)
844 max_blocks_wide += xd->mb_to_right_edge >> (3 + pd->subsampling_x);
845
846 // Scale the width in the transform block unit.
847 return max_blocks_wide >> tx_size_wide_log2[0];
848}
849
Yaowu Xu4ff59b52017-04-24 12:41:56 -0700850static INLINE int max_block_high(const MACROBLOCKD *xd, BLOCK_SIZE bsize,
851 int plane) {
Jingning Hanf65b8702016-10-31 12:13:20 -0700852 int max_blocks_high = block_size_high[bsize];
853 const struct macroblockd_plane *const pd = &xd->plane[plane];
854
855 if (xd->mb_to_bottom_edge < 0)
856 max_blocks_high += xd->mb_to_bottom_edge >> (3 + pd->subsampling_y);
857
858 // Scale the width in the transform block unit.
859 return max_blocks_high >> tx_size_wide_log2[0];
860}
861
Yaowu Xuf883b422016-08-30 14:01:10 -0700862static INLINE void av1_zero_above_context(AV1_COMMON *const cm,
863 int mi_col_start, int mi_col_end) {
Yaowu Xuc27fc142016-08-22 16:08:15 -0700864 const int width = mi_col_end - mi_col_start;
David Barkerd706ed22017-05-02 14:16:01 +0100865 const int aligned_width = ALIGN_POWER_OF_TWO(width, cm->mib_size_log2);
Yaowu Xuc27fc142016-08-22 16:08:15 -0700866
Timothy B. Terriberry5e816432017-05-05 13:58:32 -0700867 const int offset_y = mi_col_start << (MI_SIZE_LOG2 - tx_size_wide_log2[0]);
Fergus Simpson8c70d912017-05-24 13:05:33 -0700868 const int width_y = aligned_width << (MI_SIZE_LOG2 - tx_size_wide_log2[0]);
Yaowu Xuc27fc142016-08-22 16:08:15 -0700869 const int offset_uv = offset_y >> cm->subsampling_x;
870 const int width_uv = width_y >> cm->subsampling_x;
871
Yaowu Xuf883b422016-08-30 14:01:10 -0700872 av1_zero_array(cm->above_context[0] + offset_y, width_y);
873 av1_zero_array(cm->above_context[1] + offset_uv, width_uv);
874 av1_zero_array(cm->above_context[2] + offset_uv, width_uv);
Yaowu Xuc27fc142016-08-22 16:08:15 -0700875
David Barkerd706ed22017-05-02 14:16:01 +0100876 av1_zero_array(cm->above_seg_context + mi_col_start, aligned_width);
Yaowu Xuc27fc142016-08-22 16:08:15 -0700877
878#if CONFIG_VAR_TX
Jingning Han331662e2017-05-30 17:03:32 -0700879 av1_zero_array(cm->above_txfm_context + (mi_col_start << TX_UNIT_WIDE_LOG2),
880 aligned_width << TX_UNIT_WIDE_LOG2);
Yaowu Xuc27fc142016-08-22 16:08:15 -0700881#endif // CONFIG_VAR_TX
882}
883
Yaowu Xuf883b422016-08-30 14:01:10 -0700884static INLINE void av1_zero_left_context(MACROBLOCKD *const xd) {
885 av1_zero(xd->left_context);
886 av1_zero(xd->left_seg_context);
Yaowu Xuc27fc142016-08-22 16:08:15 -0700887#if CONFIG_VAR_TX
Yaowu Xuf883b422016-08-30 14:01:10 -0700888 av1_zero(xd->left_txfm_context_buffer);
Yaowu Xuc27fc142016-08-22 16:08:15 -0700889#endif
890}
891
892#if CONFIG_VAR_TX
Yaowu Xu4ff59b52017-04-24 12:41:56 -0700893static INLINE TX_SIZE get_min_tx_size(TX_SIZE tx_size) {
Urvang Joshiaffbe5e2017-05-31 16:28:57 -0700894 assert(tx_size < TX_SIZES_ALL);
Jingning Hane67b38a2016-11-04 10:30:00 -0700895 return txsize_sqr_map[tx_size];
896}
897
Jingning Han8b9478a2016-11-01 15:43:23 -0700898static INLINE void set_txfm_ctx(TXFM_CONTEXT *txfm_ctx, uint8_t txs, int len) {
Yaowu Xuc27fc142016-08-22 16:08:15 -0700899 int i;
Jingning Han8b9478a2016-11-01 15:43:23 -0700900 for (i = 0; i < len; ++i) txfm_ctx[i] = txs;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700901}
902
Yaowu Xu4ff59b52017-04-24 12:41:56 -0700903static INLINE void set_txfm_ctxs(TX_SIZE tx_size, int n8_w, int n8_h, int skip,
904 const MACROBLOCKD *xd) {
Jingning Han8b9478a2016-11-01 15:43:23 -0700905 uint8_t bw = tx_size_wide[tx_size];
906 uint8_t bh = tx_size_high[tx_size];
Jingning Han1b1dc932016-11-09 10:55:30 -0800907
908 if (skip) {
Jingning Hanff6ee6a2016-12-07 09:55:21 -0800909 bw = n8_w * MI_SIZE;
910 bh = n8_h * MI_SIZE;
Jingning Han1b1dc932016-11-09 10:55:30 -0800911 }
912
Jingning Han331662e2017-05-30 17:03:32 -0700913 set_txfm_ctx(xd->above_txfm_context, bw, n8_w << TX_UNIT_WIDE_LOG2);
914 set_txfm_ctx(xd->left_txfm_context, bh, n8_h << TX_UNIT_HIGH_LOG2);
Yaowu Xuc27fc142016-08-22 16:08:15 -0700915}
916
917static INLINE void txfm_partition_update(TXFM_CONTEXT *above_ctx,
918 TXFM_CONTEXT *left_ctx,
Jingning Han581d1692017-01-05 16:03:54 -0800919 TX_SIZE tx_size, TX_SIZE txb_size) {
920 BLOCK_SIZE bsize = txsize_to_bsize[txb_size];
Jingning Han331662e2017-05-30 17:03:32 -0700921 int bh = mi_size_high[bsize] << TX_UNIT_HIGH_LOG2;
922 int bw = mi_size_wide[bsize] << TX_UNIT_WIDE_LOG2;
Jingning Han8b9478a2016-11-01 15:43:23 -0700923 uint8_t txw = tx_size_wide[tx_size];
924 uint8_t txh = tx_size_high[tx_size];
Yaowu Xuc27fc142016-08-22 16:08:15 -0700925 int i;
Jingning Han8b9478a2016-11-01 15:43:23 -0700926 for (i = 0; i < bh; ++i) left_ctx[i] = txh;
927 for (i = 0; i < bw; ++i) above_ctx[i] = txw;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700928}
929
Jingning Han6e4955d2017-05-30 22:54:48 -0700930static INLINE TX_SIZE get_sqr_tx_size(int tx_dim) {
931 TX_SIZE tx_size;
932 switch (tx_dim) {
933#if CONFIG_EXT_PARTITION
934 case 128:
935#endif
936 case 64:
937 case 32: tx_size = TX_32X32; break;
938 case 16: tx_size = TX_16X16; break;
939 case 8: tx_size = TX_8X8; break;
940 default: tx_size = TX_4X4;
941 }
942 return tx_size;
943}
944
Yaowu Xuc27fc142016-08-22 16:08:15 -0700945static INLINE int txfm_partition_context(TXFM_CONTEXT *above_ctx,
946 TXFM_CONTEXT *left_ctx,
Yaowu Xu4ff59b52017-04-24 12:41:56 -0700947 BLOCK_SIZE bsize, TX_SIZE tx_size) {
Jingning Han8b9478a2016-11-01 15:43:23 -0700948 const uint8_t txw = tx_size_wide[tx_size];
949 const uint8_t txh = tx_size_high[tx_size];
950 const int above = *above_ctx < txw;
951 const int left = *left_ctx < txh;
Debargha Mukherjee153e1f82016-11-17 09:59:14 -0800952 int category = TXFM_PARTITION_CONTEXTS - 1;
Jingning Han607fa6a2016-10-26 10:46:28 -0700953
Jingning Han0c70a802017-01-10 15:29:45 -0800954 // dummy return, not used by others.
955 if (tx_size <= TX_4X4) return 0;
956
Jingning Han6e4955d2017-05-30 22:54:48 -0700957 TX_SIZE max_tx_size =
958 get_sqr_tx_size(AOMMAX(block_size_wide[bsize], block_size_high[bsize]));
Jingning Han0c70a802017-01-10 15:29:45 -0800959
Debargha Mukherjee153e1f82016-11-17 09:59:14 -0800960 if (max_tx_size >= TX_8X8) {
961 category = (tx_size != max_tx_size && max_tx_size > TX_8X8) +
Debargha Mukherjee932cf692016-11-18 08:14:10 -0800962 (TX_SIZES - 1 - max_tx_size) * 2;
Jingning Hanc8b89362016-11-01 10:28:53 -0700963 }
Debargha Mukherjee153e1f82016-11-17 09:59:14 -0800964 if (category == TXFM_PARTITION_CONTEXTS - 1) return category;
Jingning Hanc8b89362016-11-01 10:28:53 -0700965 return category * 3 + above + left;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700966}
967#endif
968
Yaowu Xuf883b422016-08-30 14:01:10 -0700969static INLINE PARTITION_TYPE get_partition(const AV1_COMMON *const cm,
Yaowu Xu4ff59b52017-04-24 12:41:56 -0700970 int mi_row, int mi_col,
971 BLOCK_SIZE bsize) {
Yaowu Xuc27fc142016-08-22 16:08:15 -0700972 if (mi_row >= cm->mi_rows || mi_col >= cm->mi_cols) {
973 return PARTITION_INVALID;
974 } else {
975 const int offset = mi_row * cm->mi_stride + mi_col;
976 MODE_INFO **mi = cm->mi_grid_visible + offset;
977 const MB_MODE_INFO *const mbmi = &mi[0]->mbmi;
978 const int bsl = b_width_log2_lookup[bsize];
979 const PARTITION_TYPE partition = partition_lookup[bsl][mbmi->sb_type];
980#if !CONFIG_EXT_PARTITION_TYPES
981 return partition;
982#else
Jingning Hanc709e1f2016-12-06 14:48:09 -0800983 const int hbs = mi_size_wide[bsize] / 2;
Yaowu Xuc27fc142016-08-22 16:08:15 -0700984
985 assert(cm->mi_grid_visible[offset] == &cm->mi[offset]);
986
987 if (partition != PARTITION_NONE && bsize > BLOCK_8X8 &&
988 mi_row + hbs < cm->mi_rows && mi_col + hbs < cm->mi_cols) {
989 const BLOCK_SIZE h = get_subsize(bsize, PARTITION_HORZ_A);
990 const BLOCK_SIZE v = get_subsize(bsize, PARTITION_VERT_A);
991 const MB_MODE_INFO *const mbmi_right = &mi[hbs]->mbmi;
992 const MB_MODE_INFO *const mbmi_below = &mi[hbs * cm->mi_stride]->mbmi;
993 if (mbmi->sb_type == h) {
994 return mbmi_below->sb_type == h ? PARTITION_HORZ : PARTITION_HORZ_B;
995 } else if (mbmi->sb_type == v) {
996 return mbmi_right->sb_type == v ? PARTITION_VERT : PARTITION_VERT_B;
997 } else if (mbmi_below->sb_type == h) {
998 return PARTITION_HORZ_A;
999 } else if (mbmi_right->sb_type == v) {
1000 return PARTITION_VERT_A;
1001 } else {
1002 return PARTITION_SPLIT;
1003 }
1004 }
1005
1006 return partition;
1007#endif // !CONFIG_EXT_PARTITION_TYPES
1008 }
1009}
1010
Yaowu Xu4ff59b52017-04-24 12:41:56 -07001011static INLINE void set_sb_size(AV1_COMMON *const cm, BLOCK_SIZE sb_size) {
Yaowu Xuc27fc142016-08-22 16:08:15 -07001012 cm->sb_size = sb_size;
Jingning Hanc709e1f2016-12-06 14:48:09 -08001013 cm->mib_size = mi_size_wide[cm->sb_size];
Jingning Hanbfcd1f12016-12-06 09:09:32 -08001014#if CONFIG_CB4X4
Jingning Hanbfcd1f12016-12-06 09:09:32 -08001015 cm->mib_size_log2 = b_width_log2_lookup[cm->sb_size];
1016#else
Yaowu Xuc27fc142016-08-22 16:08:15 -07001017 cm->mib_size_log2 = mi_width_log2_lookup[cm->sb_size];
Jingning Hanbfcd1f12016-12-06 09:09:32 -08001018#endif
Yaowu Xuc27fc142016-08-22 16:08:15 -07001019}
1020
1021#ifdef __cplusplus
1022} // extern "C"
1023#endif
1024
Yaowu Xuf883b422016-08-30 14:01:10 -07001025#endif // AV1_COMMON_ONYXC_INT_H_