Browse Source

h264: Complexify frame num gap shortening code

By observation it did not seem to handle prev_frame_num > frame_num.
This does not affect any files I have.
(cherry picked from commit 43c0092a80)
tags/n0.8
Alexander Strange Michael Niedermayer 14 years ago
parent
commit
33eac92a3c
1 changed files with 14 additions and 3 deletions
  1. +14
    -3
      libavcodec/h264.c

+ 14
- 3
libavcodec/h264.c View File

@@ -2133,9 +2133,20 @@ static int decode_slice_header(H264Context *h, H264Context *h0){
h->mb_field_decoding_flag= s->picture_structure != PICT_FRAME; h->mb_field_decoding_flag= s->picture_structure != PICT_FRAME;


if(h0->current_slice == 0){ if(h0->current_slice == 0){
if(h->frame_num != h->prev_frame_num &&
(h->prev_frame_num+1)%(1<<h->sps.log2_max_frame_num) < (h->frame_num - h->sps.ref_frame_count))
h->prev_frame_num = h->frame_num - h->sps.ref_frame_count - 1;
// Shorten frame num gaps so we don't have to allocate reference frames just to throw them away
if(h->frame_num != h->prev_frame_num) {
int unwrap_prev_frame_num = h->prev_frame_num, max_frame_num = 1<<h->sps.log2_max_frame_num;

if (unwrap_prev_frame_num > h->frame_num) unwrap_prev_frame_num -= max_frame_num;

if ((h->frame_num - unwrap_prev_frame_num) > h->sps.ref_frame_count) {
unwrap_prev_frame_num = (h->frame_num - h->sps.ref_frame_count) - 1;
if (unwrap_prev_frame_num < 0)
unwrap_prev_frame_num += max_frame_num;

h->prev_frame_num = unwrap_prev_frame_num;
}
}


while(h->frame_num != h->prev_frame_num && while(h->frame_num != h->prev_frame_num &&
h->frame_num != (h->prev_frame_num+1)%(1<<h->sps.log2_max_frame_num)){ h->frame_num != (h->prev_frame_num+1)%(1<<h->sps.log2_max_frame_num)){


Loading…
Cancel
Save