Commit 9e11d27c authored by Thomas Guillem's avatar Thomas Guillem Committed by Aman Gupta

avcodec/videotoolboxenc: split initialization

Split vtenc_init() into vtenc_init() (VTEncContext initialization) and
vtenc_configure_encoder() (creates the vt session).

This commit will allow to restart the vt session while encoding.
Signed-off-by: 's avatarAman Gupta <aman@tmm1.net>
parent ce2330bd
...@@ -1262,19 +1262,16 @@ static int vtenc_create_encoder(AVCodecContext *avctx, ...@@ -1262,19 +1262,16 @@ static int vtenc_create_encoder(AVCodecContext *avctx,
return 0; return 0;
} }
static av_cold int vtenc_init(AVCodecContext *avctx) static int vtenc_configure_encoder(AVCodecContext *avctx)
{ {
CFMutableDictionaryRef enc_info; CFMutableDictionaryRef enc_info;
CFMutableDictionaryRef pixel_buffer_info; CFMutableDictionaryRef pixel_buffer_info;
CMVideoCodecType codec_type; CMVideoCodecType codec_type;
VTEncContext *vtctx = avctx->priv_data; VTEncContext *vtctx = avctx->priv_data;
CFStringRef profile_level; CFStringRef profile_level;
CFBooleanRef has_b_frames_cfbool;
CFNumberRef gamma_level = NULL; CFNumberRef gamma_level = NULL;
int status; int status;
pthread_once(&once_ctrl, loadVTEncSymbols);
codec_type = get_cm_codec_type(avctx->codec_id); codec_type = get_cm_codec_type(avctx->codec_id);
if (!codec_type) { if (!codec_type) {
av_log(avctx, AV_LOG_ERROR, "Error: no mapping for AVCodecID %d\n", avctx->codec_id); av_log(avctx, AV_LOG_ERROR, "Error: no mapping for AVCodecID %d\n", avctx->codec_id);
...@@ -1304,8 +1301,6 @@ static av_cold int vtenc_init(AVCodecContext *avctx) ...@@ -1304,8 +1301,6 @@ static av_cold int vtenc_init(AVCodecContext *avctx)
if (!get_vt_hevc_profile_level(avctx, &profile_level)) return AVERROR(EINVAL); if (!get_vt_hevc_profile_level(avctx, &profile_level)) return AVERROR(EINVAL);
} }
vtctx->session = NULL;
enc_info = CFDictionaryCreateMutable( enc_info = CFDictionaryCreateMutable(
kCFAllocatorDefault, kCFAllocatorDefault,
20, 20,
...@@ -1335,8 +1330,6 @@ static av_cold int vtenc_init(AVCodecContext *avctx) ...@@ -1335,8 +1330,6 @@ static av_cold int vtenc_init(AVCodecContext *avctx)
pixel_buffer_info = NULL; pixel_buffer_info = NULL;
} }
pthread_mutex_init(&vtctx->lock, NULL);
pthread_cond_init(&vtctx->cv_sample_sent, NULL);
vtctx->dts_delta = vtctx->has_b_frames ? -1 : 0; vtctx->dts_delta = vtctx->has_b_frames ? -1 : 0;
get_cv_transfer_function(avctx, &vtctx->transfer_function, &gamma_level); get_cv_transfer_function(avctx, &vtctx->transfer_function, &gamma_level);
...@@ -1363,8 +1356,32 @@ static av_cold int vtenc_init(AVCodecContext *avctx) ...@@ -1363,8 +1356,32 @@ static av_cold int vtenc_init(AVCodecContext *avctx)
pixel_buffer_info, pixel_buffer_info,
&vtctx->session); &vtctx->session);
if (status < 0) init_cleanup:
goto init_cleanup; if (gamma_level)
CFRelease(gamma_level);
if (pixel_buffer_info)
CFRelease(pixel_buffer_info);
CFRelease(enc_info);
return status;
}
static av_cold int vtenc_init(AVCodecContext *avctx)
{
VTEncContext *vtctx = avctx->priv_data;
CFBooleanRef has_b_frames_cfbool;
int status;
pthread_once(&once_ctrl, loadVTEncSymbols);
pthread_mutex_init(&vtctx->lock, NULL);
pthread_cond_init(&vtctx->cv_sample_sent, NULL);
vtctx->session = NULL;
status = vtenc_configure_encoder(avctx);
if (status) return status;
status = VTSessionCopyProperty(vtctx->session, status = VTSessionCopyProperty(vtctx->session,
kVTCompressionPropertyKey_AllowFrameReordering, kVTCompressionPropertyKey_AllowFrameReordering,
...@@ -1378,16 +1395,7 @@ static av_cold int vtenc_init(AVCodecContext *avctx) ...@@ -1378,16 +1395,7 @@ static av_cold int vtenc_init(AVCodecContext *avctx)
} }
avctx->has_b_frames = vtctx->has_b_frames; avctx->has_b_frames = vtctx->has_b_frames;
init_cleanup: return 0;
if (gamma_level)
CFRelease(gamma_level);
if (pixel_buffer_info)
CFRelease(pixel_buffer_info);
CFRelease(enc_info);
return status;
} }
static void vtenc_get_frame_info(CMSampleBufferRef buffer, bool *is_key_frame) static void vtenc_get_frame_info(CMSampleBufferRef buffer, bool *is_key_frame)
......
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