[FFmpeg-devel] [PATCH 1/3] h264_ps: change decode_scaling_matrices so that it takes

Benoit Fouet benoit.fouet at free.fr
Tue Jun 28 09:23:14 CEST 2016


Hi,

On 27/06/2016 18:31, Michael Niedermayer wrote:
> On Mon, Jun 27, 2016 at 02:38:50PM +0200, Benoit Fouet wrote:
>>   h264_ps.c |   11 +++++++----
>>   1 file changed, 7 insertions(+), 4 deletions(-)
>> ea8cc471972e1dbaa4f4f03cd7a5fe92a3b848e9  0001-h264_ps-change-decode_scaling_matrices-so-that-it-ta.patch
>>  From c2606da98ecd04762305734f4f45ca8eaf266459 Mon Sep 17 00:00:00 2001
>> From: Benoit Fouet <benoit.fouet at free.fr>
>> Date: Mon, 27 Jun 2016 12:00:39 +0200
>> Subject: [PATCH 1/3] h264_ps: change decode_scaling_matrices so that it takes
>>   const {s,p}ps
>>
>> In order to be able to make SPS const in H264ParamSets,
>> modify decode_scaling_matrices so that it returns if the scaling
>> matrix are present in the SPS, instead of altering the input SPS
>> structure.
>> ---
>>   libavcodec/h264_ps.c | 11 +++++++----
>>   1 file changed, 7 insertions(+), 4 deletions(-)
> please document the return value
> LGTM otherwise

See if attached patch is OK in that regard.

Thanks,

-- 
Ben

-------------- next part --------------
From 67e714cbdabcb9ed808e8b10c70bbdf670cf3c2d Mon Sep 17 00:00:00 2001
From: Benoit Fouet <benoit.fouet at free.fr>
Date: Mon, 27 Jun 2016 12:00:39 +0200
Subject: [PATCH 1/3] h264_ps: change decode_scaling_matrices so that it takes
 const {s,p}ps

In order to be able to make SPS const in H264ParamSets,
modify decode_scaling_matrices so that it returns if the scaling
matrix are present in the SPS, instead of altering the input SPS
structure.
---
 libavcodec/h264_ps.c | 12 ++++++++----
 1 file changed, 8 insertions(+), 4 deletions(-)

diff --git a/libavcodec/h264_ps.c b/libavcodec/h264_ps.c
index 943d953..2f166c5 100644
--- a/libavcodec/h264_ps.c
+++ b/libavcodec/h264_ps.c
@@ -265,8 +265,9 @@ static void decode_scaling_list(GetBitContext *gb, uint8_t *factors, int size,
         }
 }
 
-static void decode_scaling_matrices(GetBitContext *gb, SPS *sps,
-                                    PPS *pps, int is_sps,
+/* returns non zero if the provided SPS scaling matrix has been filled */
+static int decode_scaling_matrices(GetBitContext *gb, const SPS *sps,
+                                    const PPS *pps, int is_sps,
                                     uint8_t(*scaling_matrix4)[16],
                                     uint8_t(*scaling_matrix8)[64])
 {
@@ -277,8 +278,9 @@ static void decode_scaling_matrices(GetBitContext *gb, SPS *sps,
         fallback_sps ? sps->scaling_matrix8[0] : default_scaling8[0],
         fallback_sps ? sps->scaling_matrix8[3] : default_scaling8[1]
     };
+    int ret = 0;
     if (get_bits1(gb)) {
-        sps->scaling_matrix_present |= is_sps;
+        ret = is_sps;
         decode_scaling_list(gb, scaling_matrix4[0], 16, default_scaling4[0], fallback[0]);        // Intra, Y
         decode_scaling_list(gb, scaling_matrix4[1], 16, default_scaling4[0], scaling_matrix4[0]); // Intra, Cr
         decode_scaling_list(gb, scaling_matrix4[2], 16, default_scaling4[0], scaling_matrix4[1]); // Intra, Cb
@@ -296,6 +298,8 @@ static void decode_scaling_matrices(GetBitContext *gb, SPS *sps,
             }
         }
     }
+
+    return ret;
 }
 
 void ff_h264_ps_uninit(H264ParamSets *ps)
@@ -401,7 +405,7 @@ int ff_h264_decode_seq_parameter_set(GetBitContext *gb, AVCodecContext *avctx,
             goto fail;
         }
         sps->transform_bypass = get_bits1(gb);
-        decode_scaling_matrices(gb, sps, NULL, 1,
+        sps->scaling_matrix_present |= decode_scaling_matrices(gb, sps, NULL, 1,
                                 sps->scaling_matrix4, sps->scaling_matrix8);
     } else {
         sps->chroma_format_idc = 1;
-- 
2.9.0.37.g6d523a3



More information about the ffmpeg-devel mailing list