[FFmpeg-cvslog] h264: update the current bit depth/chroma type in init_slice_header()

Anton Khirnov git at videolan.org
Wed Apr 29 13:55:51 CEST 2015


ffmpeg | branch: master | Anton Khirnov <anton at khirnov.net> | Sun Apr 12 19:13:56 2015 +0200| [c9ccbc7333eddd025ebbde5cc4f27d68a950c623] | committer: Anton Khirnov

h264: update the current bit depth/chroma type in init_slice_header()

With frame threading, it is currently only updated in the context where
the change occurs, but not in any other contexts.

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=c9ccbc7333eddd025ebbde5cc4f27d68a950c623
---

 libavcodec/h264_slice.c |    7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)

diff --git a/libavcodec/h264_slice.c b/libavcodec/h264_slice.c
index a760068..92fc51e 100644
--- a/libavcodec/h264_slice.c
+++ b/libavcodec/h264_slice.c
@@ -1014,6 +1014,8 @@ static int h264_slice_header_init(H264Context *h, int reinit)
 
     h->avctx->bits_per_raw_sample = h->sps.bit_depth_luma;
     h->pixel_shift                = h->sps.bit_depth_luma > 8;
+    h->chroma_format_idc          = h->sps.chroma_format_idc;
+    h->bit_depth_luma             = h->sps.bit_depth_luma;
 
     ff_h264dsp_init(&h->h264dsp, h->sps.bit_depth_luma,
                     h->sps.chroma_format_idc);
@@ -1158,11 +1160,8 @@ int ff_h264_decode_slice_header(H264Context *h, H264SliceContext *sl)
         h->sps = *h->sps_buffers[h->pps.sps_id];
 
         if (h->bit_depth_luma    != h->sps.bit_depth_luma ||
-            h->chroma_format_idc != h->sps.chroma_format_idc) {
-            h->bit_depth_luma    = h->sps.bit_depth_luma;
-            h->chroma_format_idc = h->sps.chroma_format_idc;
+            h->chroma_format_idc != h->sps.chroma_format_idc)
             needs_reinit         = 1;
-        }
 
         if (h->flags & CODEC_FLAG_LOW_DELAY ||
             (h->sps.bitstream_restriction_flag &&



More information about the ffmpeg-cvslog mailing list