[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