Commit eca1957c authored by Christophe Gisquet's avatar Christophe Gisquet Committed by Michael Niedermayer

hevc: reorder loops

iterate over memory in a more continuous order
Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 2e471e47
...@@ -1453,8 +1453,8 @@ static void hls_prediction_unit(HEVCContext *s, int x0, int y0, ...@@ -1453,8 +1453,8 @@ static void hls_prediction_unit(HEVCContext *s, int x0, int y0,
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 (i = 0; i < nPbW >> s->sps->log2_min_pu_size; i++) 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++)
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 { /* MODE_INTER */
lc->pu.merge_flag = ff_hevc_merge_flag_decode(s); lc->pu.merge_flag = ff_hevc_merge_flag_decode(s);
...@@ -1469,8 +1469,8 @@ static void hls_prediction_unit(HEVCContext *s, int x0, int y0, ...@@ -1469,8 +1469,8 @@ static void hls_prediction_unit(HEVCContext *s, int x0, int y0,
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 (i = 0; i < nPbW >> s->sps->log2_min_pu_size; i++) 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++)
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 { } else {
enum InterPredIdc inter_pred_idc = PRED_L0; enum InterPredIdc inter_pred_idc = PRED_L0;
...@@ -1519,8 +1519,8 @@ static void hls_prediction_unit(HEVCContext *s, int x0, int y0, ...@@ -1519,8 +1519,8 @@ static void hls_prediction_unit(HEVCContext *s, int x0, int y0,
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 (i = 0; i < nPbW >> s->sps->log2_min_pu_size; i++) 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++)
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;
} }
} }
......
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