[FFmpeg-devel] [PATCH] videotoolbox: add frame_params support

Aman Gupta ffmpeg at tmm1.net
Sun Nov 12 20:25:48 EET 2017


On Sat, Nov 11, 2017 at 9:02 PM, James Almer <jamrial at gmail.com> wrote:

> From: wm4 <nfxjfg at googlemail.com>
>
> Allows decoding with API users which require this API.
> ---
>  libavcodec/videotoolbox.c | 19 +++++++++++++++++++
>  1 file changed, 19 insertions(+)
>
> diff --git a/libavcodec/videotoolbox.c b/libavcodec/videotoolbox.c
> index ecb2502c1f..f0790e7353 100644
> --- a/libavcodec/videotoolbox.c
> +++ b/libavcodec/videotoolbox.c
> @@ -947,6 +947,19 @@ fail:
>      return err;
>  }
>
> +static int videotoolbox_frame_params(AVCodecContext *avctx,
> +                                     AVBufferRef *hw_frames_ctx)
> +{
> +    AVHWFramesContext *frames_ctx = (AVHWFramesContext*)hw_frames_
> ctx->data;
> +
> +    frames_ctx->format            = AV_PIX_FMT_VIDEOTOOLBOX;
> +    frames_ctx->width             = avctx->coded_width;
> +    frames_ctx->height            = avctx->coded_height;
> +    frames_ctx->sw_format         = AV_PIX_FMT_NV12;
> +
> +    return 0;
> +}
> +
>  AVHWAccel ff_h263_videotoolbox_hwaccel = {
>      .name           = "h263_videotoolbox",
>      .type           = AVMEDIA_TYPE_VIDEO,
> @@ -956,6 +969,7 @@ AVHWAccel ff_h263_videotoolbox_hwaccel = {
>      .start_frame    = videotoolbox_mpeg_start_frame,
>      .decode_slice   = videotoolbox_mpeg_decode_slice,
>      .end_frame      = videotoolbox_mpeg_end_frame,
> +    .frame_params   = videotoolbox_frame_params,
>      .init           = videotoolbox_common_init,
>      .uninit         = videotoolbox_uninit,
>      .priv_data_size = sizeof(VTContext),
> @@ -970,6 +984,7 @@ AVHWAccel ff_hevc_videotoolbox_hwaccel = {
>      .start_frame    = ff_videotoolbox_h264_start_frame,
>      .decode_slice   = ff_videotoolbox_h264_decode_slice,
>      .end_frame      = videotoolbox_hevc_end_frame,
> +    .frame_params   = videotoolbox_frame_params,
>      .init           = videotoolbox_common_init,
>      .uninit         = ff_videotoolbox_uninit,
>      .priv_data_size = sizeof(VTContext),
> @@ -984,6 +999,7 @@ AVHWAccel ff_h264_videotoolbox_hwaccel = {
>      .start_frame    = ff_videotoolbox_h264_start_frame,
>      .decode_slice   = ff_videotoolbox_h264_decode_slice,
>      .end_frame      = videotoolbox_h264_end_frame,
> +    .frame_params   = videotoolbox_frame_params,
>      .init           = videotoolbox_common_init,
>      .uninit         = videotoolbox_uninit,
>      .priv_data_size = sizeof(VTContext),
> @@ -998,6 +1014,7 @@ AVHWAccel ff_mpeg1_videotoolbox_hwaccel = {
>      .start_frame    = videotoolbox_mpeg_start_frame,
>      .decode_slice   = videotoolbox_mpeg_decode_slice,
>      .end_frame      = videotoolbox_mpeg_end_frame,
> +    .frame_params   = videotoolbox_frame_params,
>      .init           = videotoolbox_common_init,
>      .uninit         = videotoolbox_uninit,
>      .priv_data_size = sizeof(VTContext),
> @@ -1012,6 +1029,7 @@ AVHWAccel ff_mpeg2_videotoolbox_hwaccel = {
>      .start_frame    = videotoolbox_mpeg_start_frame,
>      .decode_slice   = videotoolbox_mpeg_decode_slice,
>      .end_frame      = videotoolbox_mpeg_end_frame,
> +    .frame_params   = videotoolbox_frame_params,
>      .init           = videotoolbox_common_init,
>      .uninit         = videotoolbox_uninit,
>      .priv_data_size = sizeof(VTContext),
> @@ -1026,6 +1044,7 @@ AVHWAccel ff_mpeg4_videotoolbox_hwaccel = {
>      .start_frame    = videotoolbox_mpeg_start_frame,
>      .decode_slice   = videotoolbox_mpeg_decode_slice,
>      .end_frame      = videotoolbox_mpeg_end_frame,
> +    .frame_params   = videotoolbox_frame_params,
>      .init           = videotoolbox_common_init,
>      .uninit         = videotoolbox_uninit,
>      .priv_data_size = sizeof(VTContext),
>

LGTM


> --
> 2.14.2
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel at ffmpeg.org
> http://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>


More information about the ffmpeg-devel mailing list