Commit 8e47a99f authored by Rick Kern's avatar Rick Kern

lavc/videotoolbox: fix H.264 hwaccel init issue

Fixes VTDecompressionSessionCreate() error.
Signed-off-by: 's avatarRick Kern <kernrj@gmail.com>
parent 143685a4
...@@ -487,14 +487,41 @@ static CFDictionaryRef videotoolbox_buffer_attributes_create(int width, ...@@ -487,14 +487,41 @@ static CFDictionaryRef videotoolbox_buffer_attributes_create(int width,
return buffer_attributes; return buffer_attributes;
} }
static CMVideoFormatDescriptionRef videotoolbox_format_desc_create(CMVideoCodecType codec_type, static CMVideoFormatDescriptionRef videotoolbox_format_desc_create(AVCodecContext *avctx,
CMVideoCodecType codec_type,
CFDictionaryRef decoder_spec, CFDictionaryRef decoder_spec,
int width, int width,
int height) int height)
{ {
CMFormatDescriptionRef cm_fmt_desc; CMFormatDescriptionRef cm_fmt_desc = NULL;
OSStatus status; int status;
H264Context *h = codec_type == kCMVideoCodecType_H264 ? avctx->priv_data : NULL;
if (h && h->ps.sps->data_size && h->ps.pps->data_size) {
int ps_count = 2;
const uint8_t **ps_data = av_malloc(sizeof(uint8_t*) * ps_count);
size_t *ps_sizes = av_malloc(sizeof(size_t) * ps_count);
ps_data[0] = h->ps.sps->data;
ps_sizes[0] = h->ps.sps->data_size;
ps_data[1] = h->ps.pps->data;
ps_sizes[1] = h->ps.pps->data_size;
status = CMVideoFormatDescriptionCreateFromH264ParameterSets(NULL,
ps_count,
ps_data,
ps_sizes,
4,
&cm_fmt_desc);
av_freep(&ps_sizes);
av_freep(&ps_data);
if (status) {
av_log(avctx, AV_LOG_ERROR, "Error creating H.264 format description: %d\n", status);
return NULL;
}
} else {
status = CMVideoFormatDescriptionCreate(kCFAllocatorDefault, status = CMVideoFormatDescriptionCreate(kCFAllocatorDefault,
codec_type, codec_type,
width, width,
...@@ -502,8 +529,11 @@ static CMVideoFormatDescriptionRef videotoolbox_format_desc_create(CMVideoCodecT ...@@ -502,8 +529,11 @@ static CMVideoFormatDescriptionRef videotoolbox_format_desc_create(CMVideoCodecT
decoder_spec, // Dictionary of extension decoder_spec, // Dictionary of extension
&cm_fmt_desc); &cm_fmt_desc);
if (status) if (status) {
av_log(avctx, AV_LOG_ERROR, "Error creating format description: %d\n", status);
return NULL; return NULL;
}
}
return cm_fmt_desc; return cm_fmt_desc;
} }
...@@ -543,7 +573,8 @@ static int videotoolbox_default_init(AVCodecContext *avctx) ...@@ -543,7 +573,8 @@ static int videotoolbox_default_init(AVCodecContext *avctx)
decoder_spec = videotoolbox_decoder_config_create(videotoolbox->cm_codec_type, avctx); decoder_spec = videotoolbox_decoder_config_create(videotoolbox->cm_codec_type, avctx);
videotoolbox->cm_fmt_desc = videotoolbox_format_desc_create(videotoolbox->cm_codec_type, videotoolbox->cm_fmt_desc = videotoolbox_format_desc_create(avctx,
videotoolbox->cm_codec_type,
decoder_spec, decoder_spec,
avctx->width, avctx->width,
avctx->height); avctx->height);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment