diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2005-05-07 11:07:47 +0000 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2005-05-07 11:07:47 +0000 |
commit | 21be92bf4d24d26555aca86d0b38013a0bb70428 (patch) | |
tree | 9b3f9dfa2ef28995d95dbe1fb696cc51ea7cb17e /libavcodec/h264.c | |
parent | 24a9ad7e2c9950e1e24a321eed8059f34096f759 (diff) | |
download | ffmpeg-21be92bf4d24d26555aca86d0b38013a0bb70428.tar.gz |
reverse 1 hunk from 1.96->1.97, fixes decoding of (MR1_BT_A.h264 and MR1_MW_A.264)
Originally committed as revision 4197 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/h264.c')
-rw-r--r-- | libavcodec/h264.c | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/libavcodec/h264.c b/libavcodec/h264.c index 0cd04f923b..a3e21dbfbd 100644 --- a/libavcodec/h264.c +++ b/libavcodec/h264.c @@ -3301,21 +3301,31 @@ static int decode_ref_pic_list_reordering(H264Context *h){ else pred+= abs_diff_pic_num; pred &= h->max_pic_num - 1; - for(i= h->short_ref_count-1; i>=0; i--){ - ref = h->short_ref[i]; - if(ref->data[0] != NULL && ref->frame_num == pred && ref->long_ref == 0) // ignore non existing pictures by testing data[0] pointer + for(i= h->ref_count[list]-1; i>=0; i--){ + if(h->ref_list[list][i].data[0] != NULL && h->ref_list[list][i].pic_id == pred && h->ref_list[list][i].long_ref==0) // ignore non existing pictures by testing data[0] pointer break; } }else{ pic_id= get_ue_golomb(&s->gb); //long_term_pic_idx - ref = h->long_ref[pic_id]; + + for(i= h->ref_count[list]-1; i>=0; i--){ + if(h->ref_list[list][i].pic_id == pic_id && h->ref_list[list][i].long_ref==1) // no need to ignore non existing pictures as non existing pictures have long_ref==0 + break; + } } if (i < 0) { av_log(h->s.avctx, AV_LOG_ERROR, "reference picture missing during reorder\n"); memset(&h->ref_list[list][index], 0, sizeof(Picture)); //FIXME - } else { - h->ref_list[list][index]= *ref; + } else if (i != index) /* this test is not necessary, it is only an optimisation to skip double copy of Picture structure in this case */ { + Picture tmp= h->ref_list[list][i]; + if (i < index) { + i = h->ref_count[list]; + } + for(; i > index; i--){ + h->ref_list[list][i]= h->ref_list[list][i-1]; + } + h->ref_list[list][index]= tmp; } }else{ av_log(h->s.avctx, AV_LOG_ERROR, "illegal reordering_of_pic_nums_idc\n"); |