# HG changeset patch # User michael # Date 1216436037 0 # Node ID 033d10927d45c2f1f0e75280c5e004180fc7e26e # Parent 4d3c6cd510031b5c4f234b99ef234f65bd938d22 Remove delayed_output_pic, I do not understand what this variable was good for. It is simpler and might be faster now. diff -r 4d3c6cd51003 -r 033d10927d45 h264.c --- a/h264.c Sat Jul 19 02:44:17 2008 +0000 +++ b/h264.c Sat Jul 19 02:53:57 2008 +0000 @@ -3269,15 +3269,11 @@ if (pic->reference &= refmask) { return 0; } else { - if(pic == h->delayed_output_pic) - pic->reference=DELAYED_PIC_REF; - else{ for(i = 0; h->delayed_pic[i]; i++) if(pic == h->delayed_pic[i]){ pic->reference=DELAYED_PIC_REF; break; } - } return 1; } } @@ -3312,9 +3308,7 @@ h->delayed_pic[i]->reference= 0; h->delayed_pic[i]= NULL; } - if(h->delayed_output_pic) - h->delayed_output_pic->reference= 0; - h->delayed_output_pic= NULL; + h->outputed_poc= INT_MIN; idr(h); if(h->s.current_picture_ptr) h->s.current_picture_ptr->reference= 0; @@ -7783,7 +7777,6 @@ if(!(s->flags2 & CODEC_FLAG2_CHUNKS) || (s->mb_y >= s->mb_height && s->mb_height)){ Picture *out = s->current_picture_ptr; Picture *cur = s->current_picture_ptr; - Picture *prev = h->delayed_output_pic; int i, pics, cross_idr, out_of_order, out_idx; s->mb_y= 0; @@ -7860,21 +7853,21 @@ out_idx = i; } - out_of_order = !cross_idr && prev && out->poc < prev->poc; - - if(prev && pics <= s->avctx->has_b_frames || out_of_order) - out = prev; + out_of_order = !cross_idr && out->poc < h->outputed_poc; + + if(pics <= s->avctx->has_b_frames || out_of_order) + out = NULL; if(h->sps.bitstream_restriction_flag && s->avctx->has_b_frames >= h->sps.num_reorder_frames) { } else if((out_of_order && pics-1 == s->avctx->has_b_frames && pics < 15) || (s->low_delay && - ((!cross_idr && prev && out->poc > prev->poc + 2) + ((!cross_idr && out && out->poc > h->outputed_poc + 2) || cur->pict_type == FF_B_TYPE))) { s->low_delay = 0; s->avctx->has_b_frames++; - out = prev; + out= NULL; } if(out_of_order || pics > s->avctx->has_b_frames){ @@ -7882,13 +7875,12 @@ h->delayed_pic[i] = h->delayed_pic[i+1]; } - if(prev == out) - *data_size = 0; - else + if(out){ *data_size = sizeof(AVFrame); - if(prev && prev != out && prev->reference == DELAYED_PIC_REF) - prev->reference = 0; - h->delayed_output_pic = out; + + out->reference &= ~DELAYED_PIC_REF; + h->outputed_poc = out->poc; + } #endif if(out) diff -r 4d3c6cd51003 -r 033d10927d45 h264.h --- a/h264.h Sat Jul 19 02:44:17 2008 +0000 +++ b/h264.h Sat Jul 19 02:53:57 2008 +0000 @@ -337,7 +337,7 @@ Reordered version of default_ref_list according to picture reordering in slice header */ Picture *delayed_pic[MAX_DELAYED_PIC_COUNT+2]; //FIXME size? - Picture *delayed_output_pic; + int outputed_poc; /** * memory management control operations buffer.