Mercurial > libavcodec.hg
changeset 7393:309c59802769 libavcodec
Merge oddly duplicated remove_long/remove_long_at_index() function.
author | michael |
---|---|
date | Fri, 25 Jul 2008 12:56:58 +0000 |
parents | 95787edebd24 |
children | 4ac8769cbb01 |
files | h264.c |
diffstat | 1 files changed, 11 insertions(+), 19 deletions(-) [+] |
line wrap: on
line diff
--- a/h264.c Fri Jul 25 12:34:39 2008 +0000 +++ b/h264.c Fri Jul 25 12:56:58 2008 +0000 @@ -61,7 +61,7 @@ static void svq3_add_idct_c(uint8_t *dst, DCTELEM *block, int stride, int qp, int dc); static void filter_mb( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8_t *img_cb, uint8_t *img_cr, unsigned int linesize, unsigned int uvlinesize); static void filter_mb_fast( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8_t *img_cb, uint8_t *img_cr, unsigned int linesize, unsigned int uvlinesize); -static void remove_long_at_index(H264Context *h, int i); +static Picture * remove_long(H264Context *h, int i); static av_always_inline uint32_t pack16to32(int a, int b){ #ifdef WORDS_BIGENDIAN @@ -3299,7 +3299,7 @@ for(i=0; i<16; i++){ if (h->long_ref[i] != NULL) { unreference_pic(h, h->long_ref[i], 0); - remove_long_at_index(h, i); + remove_long(h, i); } } assert(h->long_ref_count==0); @@ -3390,27 +3390,19 @@ /** * Remove a picture from the long term reference list by its index in - * that list. This does no checking on the provided index; it is assumed - * to be valid. The removed entry is set to NULL. Other entries are unaffected. - * @param i index into h->long_ref of picture to remove. - */ -static void remove_long_at_index(H264Context *h, int i){ - assert(h->long_ref[i]->long_ref == 1); - h->long_ref[i]->long_ref= 0; - h->long_ref[i]= NULL; - h->long_ref_count--; -} - -/** - * + * that list. * @return the removed picture or NULL if an error occurs */ static Picture * remove_long(H264Context *h, int i){ Picture *pic; pic= h->long_ref[i]; - if (pic) - remove_long_at_index(h, i); + if (pic){ + assert(h->long_ref[i]->long_ref == 1); + h->long_ref[i]->long_ref= 0; + h->long_ref[i]= NULL; + h->long_ref_count--; + } return pic; } @@ -3497,7 +3489,7 @@ pic = h->long_ref[j]; if (pic) { if (unreference_pic(h, pic, structure ^ PICT_FRAME)) - remove_long_at_index(h, j); + remove_long(h, j); } else if(s->avctx->debug&FF_DEBUG_MMCO) av_log(h->s.avctx, AV_LOG_DEBUG, "mmco: unref long failure\n"); break; @@ -3599,7 +3591,7 @@ assert(i < 16); pic = h->long_ref[i]; - remove_long_at_index(h, i); + remove_long(h, i); } else { pic = h->short_ref[h->short_ref_count - 1]; remove_short_at_index(h, h->short_ref_count - 1);