mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
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. Signed-off-by: Ronald S. Bultje <rsbultje@gmail.com> Signed-off-by: Anton Khirnov <anton@khirnov.net>
This commit is contained in:
parent
c98b928fa7
commit
3803af22d8
@ -2681,9 +2681,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 &&
|
// Shorten frame num gaps so we don't have to allocate reference frames just to throw them away
|
||||||
(h->prev_frame_num+1)%(1<<h->sps.log2_max_frame_num) < (h->frame_num - h->sps.ref_frame_count))
|
if(h->frame_num != h->prev_frame_num) {
|
||||||
h->prev_frame_num = h->frame_num - h->sps.ref_frame_count - 1;
|
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…
Reference in New Issue
Block a user