# HG changeset patch # User michael # Date 1266275047 0 # Node ID cc70f8c44019a4928affbfa72479ea911ad294f0 # Parent d1a855cb0a0cc3454be7c0c6470d5996cf28e7f4 Drop compute_mb_neighbors() and move fill_decode_neighbors() up to take its role. Should be faster as this is a strict code removial. diff -r d1a855cb0a0c -r cc70f8c44019 h264_cabac.c --- a/h264_cabac.c Mon Feb 15 22:07:02 2010 +0000 +++ b/h264_cabac.c Mon Feb 15 23:04:07 2010 +0000 @@ -1182,32 +1182,6 @@ #endif } -static inline void compute_mb_neighbors(H264Context *h) -{ - MpegEncContext * const s = &h->s; - const int mb_xy = h->mb_xy; - h->top_mb_xy = mb_xy - s->mb_stride; - h->left_mb_xy[0] = mb_xy - 1; - if(FRAME_MBAFF){ - const int pair_xy = s->mb_x + (s->mb_y & ~1)*s->mb_stride; - const int top_pair_xy = pair_xy - s->mb_stride; - const int top_mb_field_flag = IS_INTERLACED(s->current_picture.mb_type[top_pair_xy]); - const int left_mb_field_flag = IS_INTERLACED(s->current_picture.mb_type[pair_xy-1]); - const int curr_mb_field_flag = MB_FIELD; - const int bottom = (s->mb_y & 1); - - if (curr_mb_field_flag && (bottom || top_mb_field_flag)){ - h->top_mb_xy -= s->mb_stride; - } - if (!left_mb_field_flag == curr_mb_field_flag) { - h->left_mb_xy[0] = pair_xy - 1; - } - } else if (FIELD_PICTURE) { - h->top_mb_xy -= s->mb_stride; - } - return; -} - /** * decodes a macroblock * @returns 0 if OK, AC_ERROR / DC_ERROR / MV_ERROR if an error is noticed @@ -1257,7 +1231,7 @@ h->prev_mb_skipped = 0; - compute_mb_neighbors(h); + fill_decode_neighbors(h, -(MB_FIELD)); if( h->slice_type_nos == FF_B_TYPE ) { const int mba_xy = h->left_mb_xy[0]; @@ -1365,7 +1339,6 @@ h->ref_count[1] <<= 1; } - fill_decode_neighbors(h, mb_type); fill_decode_caches(h, mb_type); if( IS_INTRA( mb_type ) ) {