Commit a7b365ae authored by Anton Khirnov's avatar Anton Khirnov

hevc: reduce code duplication in hls_prediction_unit()

parent de1f8ead
...@@ -1652,88 +1652,73 @@ static void hls_prediction_unit(HEVCContext *s, int x0, int y0, ...@@ -1652,88 +1652,73 @@ static void hls_prediction_unit(HEVCContext *s, int x0, int y0,
int x_pu, y_pu; int x_pu, y_pu;
int i, j; int i, j;
if (SAMPLE_CTB(s->skip_flag, x_cb, y_cb)) { int skip_flag = SAMPLE_CTB(s->skip_flag, x_cb, y_cb);
if (!skip_flag)
lc->pu.merge_flag = ff_hevc_merge_flag_decode(s);
if (skip_flag || lc->pu.merge_flag) {
if (s->sh.max_num_merge_cand > 1) if (s->sh.max_num_merge_cand > 1)
merge_idx = ff_hevc_merge_idx_decode(s); merge_idx = ff_hevc_merge_idx_decode(s);
else else
merge_idx = 0; merge_idx = 0;
ff_hevc_luma_mv_merge_mode(s, x0, y0, ff_hevc_luma_mv_merge_mode(s, x0, y0, nPbW, nPbH, log2_cb_size,
1 << log2_cb_size, partIdx, merge_idx, &current_mv);
1 << log2_cb_size,
log2_cb_size, partIdx,
merge_idx, &current_mv);
x_pu = x0 >> s->sps->log2_min_pu_size; x_pu = x0 >> s->sps->log2_min_pu_size;
y_pu = y0 >> s->sps->log2_min_pu_size; y_pu = y0 >> s->sps->log2_min_pu_size;
for (j = 0; j < nPbH >> s->sps->log2_min_pu_size; j++) for (j = 0; j < nPbH >> s->sps->log2_min_pu_size; j++)
for (i = 0; i < nPbW >> s->sps->log2_min_pu_size; i++) for (i = 0; i < nPbW >> s->sps->log2_min_pu_size; i++)
tab_mvf[(y_pu + j) * min_pu_width + x_pu + i] = current_mv; tab_mvf[(y_pu + j) * min_pu_width + x_pu + i] = current_mv;
} else { /* MODE_INTER */ } else {
lc->pu.merge_flag = ff_hevc_merge_flag_decode(s); enum InterPredIdc inter_pred_idc = PRED_L0;
if (lc->pu.merge_flag) { ff_hevc_set_neighbour_available(s, x0, y0, nPbW, nPbH);
if (s->sh.max_num_merge_cand > 1) if (s->sh.slice_type == B_SLICE)
merge_idx = ff_hevc_merge_idx_decode(s); inter_pred_idc = ff_hevc_inter_pred_idc_decode(s, nPbW, nPbH);
else
merge_idx = 0; if (inter_pred_idc != PRED_L1) {
if (s->sh.nb_refs[L0]) {
ff_hevc_luma_mv_merge_mode(s, x0, y0, nPbW, nPbH, log2_cb_size, ref_idx[0] = ff_hevc_ref_idx_lx_decode(s, s->sh.nb_refs[L0]);
partIdx, merge_idx, &current_mv); current_mv.ref_idx[0] = ref_idx[0];
x_pu = x0 >> s->sps->log2_min_pu_size;
y_pu = y0 >> s->sps->log2_min_pu_size;
for (j = 0; j < nPbH >> s->sps->log2_min_pu_size; j++)
for (i = 0; i < nPbW >> s->sps->log2_min_pu_size; i++)
tab_mvf[(y_pu + j) * min_pu_width + x_pu + i] = current_mv;
} else {
enum InterPredIdc inter_pred_idc = PRED_L0;
ff_hevc_set_neighbour_available(s, x0, y0, nPbW, nPbH);
if (s->sh.slice_type == B_SLICE)
inter_pred_idc = ff_hevc_inter_pred_idc_decode(s, nPbW, nPbH);
if (inter_pred_idc != PRED_L1) {
if (s->sh.nb_refs[L0]) {
ref_idx[0] = ff_hevc_ref_idx_lx_decode(s, s->sh.nb_refs[L0]);
current_mv.ref_idx[0] = ref_idx[0];
}
current_mv.pred_flag[0] = 1;
hls_mvd_coding(s, x0, y0, 0);
mvp_flag[0] = ff_hevc_mvp_lx_flag_decode(s);
ff_hevc_luma_mv_mvp_mode(s, x0, y0, nPbW, nPbH, log2_cb_size,
partIdx, merge_idx, &current_mv,
mvp_flag[0], 0);
current_mv.mv[0].x += lc->pu.mvd.x;
current_mv.mv[0].y += lc->pu.mvd.y;
} }
current_mv.pred_flag[0] = 1;
if (inter_pred_idc != PRED_L0) { hls_mvd_coding(s, x0, y0, 0);
if (s->sh.nb_refs[L1]) { mvp_flag[0] = ff_hevc_mvp_lx_flag_decode(s);
ref_idx[1] = ff_hevc_ref_idx_lx_decode(s, s->sh.nb_refs[L1]); ff_hevc_luma_mv_mvp_mode(s, x0, y0, nPbW, nPbH, log2_cb_size,
current_mv.ref_idx[1] = ref_idx[1]; partIdx, merge_idx, &current_mv,
} mvp_flag[0], 0);
current_mv.mv[0].x += lc->pu.mvd.x;
if (s->sh.mvd_l1_zero_flag == 1 && inter_pred_idc == PRED_BI) { current_mv.mv[0].y += lc->pu.mvd.y;
AV_ZERO32(&lc->pu.mvd); }
} else {
hls_mvd_coding(s, x0, y0, 1); if (inter_pred_idc != PRED_L0) {
} if (s->sh.nb_refs[L1]) {
ref_idx[1] = ff_hevc_ref_idx_lx_decode(s, s->sh.nb_refs[L1]);
current_mv.pred_flag[1] = 1; current_mv.ref_idx[1] = ref_idx[1];
mvp_flag[1] = ff_hevc_mvp_lx_flag_decode(s);
ff_hevc_luma_mv_mvp_mode(s, x0, y0, nPbW, nPbH, log2_cb_size,
partIdx, merge_idx, &current_mv,
mvp_flag[1], 1);
current_mv.mv[1].x += lc->pu.mvd.x;
current_mv.mv[1].y += lc->pu.mvd.y;
} }
x_pu = x0 >> s->sps->log2_min_pu_size; if (s->sh.mvd_l1_zero_flag == 1 && inter_pred_idc == PRED_BI) {
y_pu = y0 >> s->sps->log2_min_pu_size; AV_ZERO32(&lc->pu.mvd);
} else {
hls_mvd_coding(s, x0, y0, 1);
}
for(j = 0; j < nPbH >> s->sps->log2_min_pu_size; j++) current_mv.pred_flag[1] = 1;
for (i = 0; i < nPbW >> s->sps->log2_min_pu_size; i++) mvp_flag[1] = ff_hevc_mvp_lx_flag_decode(s);
tab_mvf[(y_pu + j) * min_pu_width + x_pu + i] = current_mv; ff_hevc_luma_mv_mvp_mode(s, x0, y0, nPbW, nPbH, log2_cb_size,
partIdx, merge_idx, &current_mv,
mvp_flag[1], 1);
current_mv.mv[1].x += lc->pu.mvd.x;
current_mv.mv[1].y += lc->pu.mvd.y;
} }
x_pu = x0 >> s->sps->log2_min_pu_size;
y_pu = y0 >> s->sps->log2_min_pu_size;
for(j = 0; j < nPbH >> s->sps->log2_min_pu_size; j++)
for (i = 0; i < nPbW >> s->sps->log2_min_pu_size; i++)
tab_mvf[(y_pu + j) * min_pu_width + x_pu + i] = current_mv;
} }
if (current_mv.pred_flag[0]) { if (current_mv.pred_flag[0]) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment