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

James Almer jamrial at gmail.com
Sun Nov 12 21:06:37 EET 2017


On 11/12/2017 3:25 PM, Aman Gupta wrote:
> 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
> 

Pushed, thanks


More information about the ffmpeg-devel mailing list