From a8ba34d2994f9b85af885d66da5ca8ef6d8094f2 Mon Sep 17 00:00:00 2001 From: Dmitry Kovalev Date: Fri, 3 Jan 2014 12:50:57 -0800 Subject: [PATCH] Pre planes configuration cleanup. Change-Id: I1d50f8701d9c9dedb84387a773a3e9b4daaad720 --- vp9/encoder/vp9_encodeframe.c | 18 ++++++------------ 1 file changed, 6 insertions(+), 12 deletions(-) diff --git a/vp9/encoder/vp9_encodeframe.c b/vp9/encoder/vp9_encodeframe.c index dd81993dc..5d15124df 100644 --- a/vp9/encoder/vp9_encodeframe.c +++ b/vp9/encoder/vp9_encodeframe.c @@ -2583,20 +2583,14 @@ static void encode_superblock(VP9_COMP *cpi, TOKENEXTRA **t, int output_enabled, if (output_enabled) sum_intra_stats(cm, mi); } else { - int idx = cm->ref_frame_map[get_ref_frame_idx(cpi, mbmi->ref_frame[0])]; - YV12_BUFFER_CONFIG *ref_fb = &cm->yv12_fb[idx]; - YV12_BUFFER_CONFIG *second_ref_fb = NULL; - if (has_second_ref(mbmi)) { - idx = cm->ref_frame_map[get_ref_frame_idx(cpi, mbmi->ref_frame[1])]; - second_ref_fb = &cm->yv12_fb[idx]; + int ref; + const int is_compound = has_second_ref(mbmi); + for (ref = 0; ref < 1 + is_compound; ++ref) { + YV12_BUFFER_CONFIG *cfg = &cm->yv12_fb[cm->ref_frame_map[ + get_ref_frame_idx(cpi, mbmi->ref_frame[ref])]]; + setup_pre_planes(xd, ref, cfg, mi_row, mi_col, xd->scale_factors[ref]); } - assert(cm->frame_type != KEY_FRAME); - - setup_pre_planes(xd, 0, ref_fb, mi_row, mi_col, xd->scale_factors[0]); - setup_pre_planes(xd, 1, second_ref_fb, mi_row, mi_col, - xd->scale_factors[1]); - vp9_build_inter_predictors_sb(xd, mi_row, mi_col, MAX(bsize, BLOCK_8X8)); }