[FFmpeg-devel] [PATCH 3/3] cbs_h2645: Allocate all internal buffers with padding
Aman Gupta
ffmpeg at tmm1.net
Wed Oct 17 03:40:35 EEST 2018
On Tue, Oct 16, 2018 at 2:08 PM Mark Thompson <sw at jkqxz.net> wrote:
> Any of these buffers (for both H.264 and H.265) might reasonably be
> parsed using the bitstream reader, so include padding on all of them.
> ---
> This seems simpler than adding it to specific cases as problems are found.
>
>
Entire patchset looks great to me. Thanks for cleaning up my mess.
Aman
>
> libavcodec/cbs_h2645.c | 3 ++-
> libavcodec/cbs_h264_syntax_template.c | 2 +-
> 2 files changed, 3 insertions(+), 2 deletions(-)
>
> diff --git a/libavcodec/cbs_h2645.c b/libavcodec/cbs_h2645.c
> index a1b92c87ce..e55bd00183 100644
> --- a/libavcodec/cbs_h2645.c
> +++ b/libavcodec/cbs_h2645.c
> @@ -319,7 +319,8 @@ static int cbs_h2645_read_more_rbsp_data(GetBitContext
> *gbc)
> #define byte_alignment(rw) (get_bits_count(rw) % 8)
>
> #define allocate(name, size) do { \
> - name ## _ref = av_buffer_allocz(size); \
> + name ## _ref = av_buffer_allocz(size + \
> + AV_INPUT_BUFFER_PADDING_SIZE); \
> if (!name ## _ref) \
> return AVERROR(ENOMEM); \
> name = name ## _ref->data; \
> diff --git a/libavcodec/cbs_h264_syntax_template.c
> b/libavcodec/cbs_h264_syntax_template.c
> index 7d0ce5918a..9e29132fec 100644
> --- a/libavcodec/cbs_h264_syntax_template.c
> +++ b/libavcodec/cbs_h264_syntax_template.c
> @@ -718,7 +718,7 @@ static int
> FUNC(sei_user_data_registered)(CodedBitstreamContext *ctx, RWContext
> *payload_size = i + current->data_length;
> #endif
>
> - allocate(current->data, current->data_length +
> AV_INPUT_BUFFER_PADDING_SIZE);
> + allocate(current->data, current->data_length);
> for (j = 0; j < current->data_length; j++)
> xu(8, itu_t_t35_payload_byte[i], current->data[j], 0x00, 0xff, 1,
> i + j);
>
> --
> 2.19.1
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel at ffmpeg.org
> http://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
More information about the ffmpeg-devel
mailing list