[FFmpeg-devel] [PATCH] h264: make H264ParamSets sps const

Hendrik Leppkes h.leppkes at gmail.com
Tue Jun 21 16:29:47 CEST 2016


On Tue, Jun 21, 2016 at 4:20 PM, Benoit Fouet <benoit.fouet at free.fr> wrote:
> Hi,
>
>
> On 21/06/2016 14:52, Hendrik Leppkes wrote:
>>
>> On Tue, Jun 21, 2016 at 2:40 PM, Clément Bœsch <u at pkh.me> wrote:
>>>
>>> On Tue, Jun 21, 2016 at 02:34:33PM +0200, Benoit Fouet wrote:
>>>>
>>>> Hi,
>>>>
>>>> Unless I totally missed something, the FIXME in H264ParamSets structure
>>>> should be fixed by attached patch.
>>>>
>>>> --
>>>> Ben
>>>>
>>>>  From 28ae10498f81070539bdb8f40236326743350101 Mon Sep 17 00:00:00 2001
>>>> From: Benoit Fouet <benoit.fouet at free.fr>
>>>> Date: Tue, 21 Jun 2016 14:17:13 +0200
>>>> Subject: [PATCH] h264: make H264ParamSets sps const
>>>>
>>>> ---
>>>>   libavcodec/h264.h       | 3 +--
>>>>   libavcodec/h264_slice.c | 2 +-
>>>>   2 files changed, 2 insertions(+), 3 deletions(-)
>>>>
>>>> diff --git a/libavcodec/h264.h b/libavcodec/h264.h
>>>> index c4d2921..b809ee5 100644
>>>> --- a/libavcodec/h264.h
>>>> +++ b/libavcodec/h264.h
>>>> @@ -234,8 +234,7 @@ typedef struct H264ParamSets {
>>>>       AVBufferRef *sps_ref;
>>>>       /* currently active parameters sets */
>>>>       const PPS *pps;
>>>> -    // FIXME this should properly be const
>>>> -    SPS *sps;
>>>> +    const SPS *sps;
>>>>   } H264ParamSets;
>>>>
>>>>   /**
>>>> diff --git a/libavcodec/h264_slice.c b/libavcodec/h264_slice.c
>>>> index 6e7b940..da7f9dd 100644
>>>> --- a/libavcodec/h264_slice.c
>>>> +++ b/libavcodec/h264_slice.c
>>>> @@ -873,7 +873,7 @@ static enum AVPixelFormat
>>>> get_pixel_format(H264Context *h, int force_callback)
>>>>   /* export coded and cropped frame dimensions to AVCodecContext */
>>>>   static int init_dimensions(H264Context *h)
>>>>   {
>>>> -    SPS *sps = h->ps.sps;
>>>> +    SPS *sps = (SPS*)h->ps.sps_ref->data;
>>>>       int width  = h->width  - (sps->crop_right + sps->crop_left);
>>>>       int height = h->height - (sps->crop_top   + sps->crop_bottom);
>>>>       av_assert0(sps->crop_right + sps->crop_left < (unsigned)h->width);
>>>
>>> So it's not actually const, right?
>>>
>> Indeed, the FIXME wasn't just there because someone forgot to write
>> "const" in front of it, but because it was used in some parts as
>> not-const.
>
>
> OK, right... Thanks for reminding me of reading the code better before
> sending a patch.
>
> As far as I can see, the only place where this constness is not preserved is
> in the init_dimensions function (in h264_slice), in a dead part of the code,
> as crop is asserted at the beginning of the very same function.
> Please correct me if I've missed other places.
>

If anything the asserts should probably be removed, because bad files
should never be able to trigger assertions, and the existing check
remain.

- Hendrik


More information about the ffmpeg-devel mailing list