Commit f7df9c22 authored by kostya's avatar kostya

Split RV3/4 deblock pattern into horizontal and vertical parts

during calculating.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@15794 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 7fe00274
...@@ -1082,19 +1082,23 @@ static int is_mv_diff_gt_3(int16_t (*motion_val)[2], int step) ...@@ -1082,19 +1082,23 @@ static int is_mv_diff_gt_3(int16_t (*motion_val)[2], int step)
static int rv34_set_deblock_coef(RV34DecContext *r) static int rv34_set_deblock_coef(RV34DecContext *r)
{ {
MpegEncContext *s = &r->s; MpegEncContext *s = &r->s;
int mvmask = 0, i, j; int hmvmask = 0, vmvmask = 0, i, j;
int midx = s->mb_x * 2 + s->mb_y * 2 * s->b8_stride; int midx = s->mb_x * 2 + s->mb_y * 2 * s->b8_stride;
int16_t (*motion_val)[2] = s->current_picture_ptr->motion_val[0][midx]; int16_t (*motion_val)[2] = s->current_picture_ptr->motion_val[0][midx];
for(j = 0; j < 16; j += 8){ for(j = 0; j < 16; j += 8){
for(i = 0; i < 2; i++){ for(i = 0; i < 2; i++){
if(is_mv_diff_gt_3(motion_val + i, 1)) if(is_mv_diff_gt_3(motion_val + i, 1))
mvmask |= 0x11 << (j + i*2); vmvmask |= 0x11 << (j + i*2);
if(is_mv_diff_gt_3(motion_val + i, s->b8_stride)) if(is_mv_diff_gt_3(motion_val + i, s->b8_stride))
mvmask |= 0x03 << (j + i*2); hmvmask |= 0x03 << (j + i*2);
} }
motion_val += s->b8_stride; motion_val += s->b8_stride;
} }
return mvmask; if(s->first_slice_line)
hmvmask &= ~0x000F;
if(!s->mb_x)
vmvmask &= ~0x1111;
return hmvmask | vmvmask; //XXX: should be stored separately for RV3
} }
static int rv34_decode_macroblock(RV34DecContext *r, int8_t *intra_types) static int rv34_decode_macroblock(RV34DecContext *r, int8_t *intra_types)
......
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