[FFmpeg-cvslog] h264: move calculating the POC out of h264_slice_header_parse()
Anton Khirnov
git at videolan.org
Wed Jun 29 18:03:29 CEST 2016
ffmpeg | branch: master | Anton Khirnov <anton at khirnov.net> | Thu Apr 14 20:53:59 2016 +0200| [4cec43a9eeb58eb9e581a2d9d25f78e5bfbb0960] | committer: Anton Khirnov
h264: move calculating the POC out of h264_slice_header_parse()
This function does not do any bitstream parsing and it depends on the
current frame being allocated, so this will allow the frame_start() to
be moved out eventually.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=4cec43a9eeb58eb9e581a2d9d25f78e5bfbb0960
---
libavcodec/h264_slice.c | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/libavcodec/h264_slice.c b/libavcodec/h264_slice.c
index 0c38121..3252b38 100644
--- a/libavcodec/h264_slice.c
+++ b/libavcodec/h264_slice.c
@@ -1325,10 +1325,6 @@ static int h264_slice_header_parse(H264Context *h, H264SliceContext *sl)
}
}
- if (!h->setup_finished)
- ff_h264_init_poc(h->cur_pic_ptr->field_poc, &h->cur_pic_ptr->poc,
- sps, &h->poc, h->picture_structure, h->nal_ref_idc);
-
if (pps->redundant_pic_cnt_present)
sl->redundant_pic_count = get_ue_golomb(&sl->gb);
@@ -1446,6 +1442,10 @@ int ff_h264_decode_slice_header(H264Context *h, H264SliceContext *sl)
if (ret < 0)
return ret;
+ if (!h->setup_finished)
+ ff_h264_init_poc(h->cur_pic_ptr->field_poc, &h->cur_pic_ptr->poc,
+ h->ps.sps, &h->poc, h->picture_structure, h->nal_ref_idc);
+
ret = ff_h264_build_ref_list(h, sl);
if (ret < 0)
return ret;
More information about the ffmpeg-cvslog
mailing list