msdkh264enc: Configure parser and SEI array only if it's required

This commit is contained in:
Seungha Yang 2020-03-31 20:51:15 +09:00 committed by GStreamer Merge Bot
parent 206fe1534d
commit 71cf93c361
2 changed files with 43 additions and 38 deletions

View file

@ -94,6 +94,27 @@ gst_msdkh264enc_frame_packing_get_type (void)
#define gst_msdkh264enc_parent_class parent_class #define gst_msdkh264enc_parent_class parent_class
G_DEFINE_TYPE (GstMsdkH264Enc, gst_msdkh264enc, GST_TYPE_MSDKENC); G_DEFINE_TYPE (GstMsdkH264Enc, gst_msdkh264enc, GST_TYPE_MSDKENC);
static void
gst_msdkh264enc_insert_sei (GstMsdkH264Enc * thiz, GstVideoCodecFrame * frame,
GstMemory * sei_mem)
{
GstBuffer *new_buffer;
if (!thiz->parser)
thiz->parser = gst_h264_nal_parser_new ();
new_buffer = gst_h264_parser_insert_sei (thiz->parser,
frame->output_buffer, sei_mem);
if (!new_buffer) {
GST_WARNING_OBJECT (thiz, "Cannot insert SEI nal into AU buffer");
return;
}
gst_buffer_unref (frame->output_buffer);
frame->output_buffer = new_buffer;
}
static void static void
gst_msdkh264enc_add_cc (GstMsdkH264Enc * thiz, GstVideoCodecFrame * frame) gst_msdkh264enc_add_cc (GstMsdkH264Enc * thiz, GstVideoCodecFrame * frame)
{ {
@ -101,9 +122,9 @@ gst_msdkh264enc_add_cc (GstMsdkH264Enc * thiz, GstVideoCodecFrame * frame)
gpointer iter = NULL; gpointer iter = NULL;
GstBuffer *in_buf = frame->input_buffer; GstBuffer *in_buf = frame->input_buffer;
GstMemory *mem = NULL; GstMemory *mem = NULL;
GstBuffer *new_buffer = NULL;
g_array_set_size (thiz->extra_sei, 0); if (thiz->cc_sei_array)
g_array_set_size (thiz->cc_sei_array, 0);
while ((cc_meta = while ((cc_meta =
(GstVideoCaptionMeta *) gst_buffer_iterate_meta_filtered (in_buf, (GstVideoCaptionMeta *) gst_buffer_iterate_meta_filtered (in_buf,
@ -144,13 +165,20 @@ gst_msdkh264enc_add_cc (GstMsdkH264Enc * thiz, GstVideoCodecFrame * frame)
rud->data = data; rud->data = data;
g_array_append_val (thiz->extra_sei, sei); if (!thiz->cc_sei_array) {
thiz->cc_sei_array =
g_array_new (FALSE, FALSE, sizeof (GstH264SEIMessage));
g_array_set_clear_func (thiz->cc_sei_array,
(GDestroyNotify) gst_h264_sei_clear);
} }
if (!thiz->extra_sei->len) g_array_append_val (thiz->cc_sei_array, sei);
}
if (!thiz->cc_sei_array || !thiz->cc_sei_array->len)
return; return;
mem = gst_h264_create_sei_memory (4, thiz->extra_sei); mem = gst_h264_create_sei_memory (4, thiz->cc_sei_array);
if (!mem) { if (!mem) {
GST_WARNING_OBJECT (thiz, "Cannot create SEI nal unit"); GST_WARNING_OBJECT (thiz, "Cannot create SEI nal unit");
@ -158,19 +186,10 @@ gst_msdkh264enc_add_cc (GstMsdkH264Enc * thiz, GstVideoCodecFrame * frame)
} }
GST_DEBUG_OBJECT (thiz, GST_DEBUG_OBJECT (thiz,
"Inserting %d closed caption SEI message(s)", thiz->extra_sei->len); "Inserting %d closed caption SEI message(s)", thiz->cc_sei_array->len);
new_buffer = gst_h264_parser_insert_sei (thiz->parser, gst_msdkh264enc_insert_sei (thiz, frame, mem);
frame->output_buffer, mem);
gst_memory_unref (mem); gst_memory_unref (mem);
if (!new_buffer) {
GST_WARNING_OBJECT (thiz, "Cannot insert SEI nal into AU buffer");
return;
}
gst_buffer_unref (frame->output_buffer);
frame->output_buffer = new_buffer;
} }
static GstFlowReturn static GstFlowReturn
@ -179,25 +198,13 @@ gst_msdkh264enc_pre_push (GstVideoEncoder * encoder, GstVideoCodecFrame * frame)
GstMsdkH264Enc *thiz = GST_MSDKH264ENC (encoder); GstMsdkH264Enc *thiz = GST_MSDKH264ENC (encoder);
if (GST_VIDEO_CODEC_FRAME_IS_SYNC_POINT (frame) && thiz->frame_packing_sei) { if (GST_VIDEO_CODEC_FRAME_IS_SYNC_POINT (frame) && thiz->frame_packing_sei) {
GstBuffer *new_buffer = NULL;
/* Insert frame packing SEI /* Insert frame packing SEI
* FIXME: This assumes it does not exist in the stream, which is not * FIXME: This assumes it does not exist in the stream, which is not
* going to be true anymore once this is fixed: * going to be true anymore once this is fixed:
* https://github.com/Intel-Media-SDK/MediaSDK/issues/13 * https://github.com/Intel-Media-SDK/MediaSDK/issues/13
*/ */
new_buffer = gst_h264_parser_insert_sei (thiz->parser,
frame->output_buffer, thiz->frame_packing_sei);
if (new_buffer) {
GST_DEBUG_OBJECT (thiz, "Inserting SEI Frame Packing for multiview"); GST_DEBUG_OBJECT (thiz, "Inserting SEI Frame Packing for multiview");
gst_msdkh264enc_insert_sei (thiz, frame, thiz->frame_packing_sei);
gst_buffer_unref (frame->output_buffer);
frame->output_buffer = new_buffer;
} else {
GST_WARNING_OBJECT (thiz,
"Cannot insert frame packing SEI intu AU buffer");
}
} }
gst_msdkh264enc_add_cc (thiz, frame); gst_msdkh264enc_add_cc (thiz, frame);
@ -284,7 +291,7 @@ gst_msdkh264enc_set_format (GstMsdkEnc * encoder)
GstH264FramePacking *frame_packing; GstH264FramePacking *frame_packing;
GArray *array = g_array_new (FALSE, FALSE, sizeof (GstH264SEIMessage)); GArray *array = g_array_new (FALSE, FALSE, sizeof (GstH264SEIMessage));
g_array_set_clear_func (thiz->extra_sei, g_array_set_clear_func (thiz->cc_sei_array,
(GDestroyNotify) gst_h264_sei_clear); (GDestroyNotify) gst_h264_sei_clear);
GST_DEBUG_OBJECT (thiz, GST_DEBUG_OBJECT (thiz,
@ -487,8 +494,10 @@ gst_msdkh264enc_finalize (GObject * object)
{ {
GstMsdkH264Enc *thiz = GST_MSDKH264ENC (object); GstMsdkH264Enc *thiz = GST_MSDKH264ENC (object);
if (thiz->parser)
gst_h264_nal_parser_free (thiz->parser); gst_h264_nal_parser_free (thiz->parser);
g_array_unref (thiz->extra_sei); if (thiz->cc_sei_array)
g_array_unref (thiz->cc_sei_array);
G_OBJECT_CLASS (parent_class)->finalize (object); G_OBJECT_CLASS (parent_class)->finalize (object);
} }
@ -674,8 +683,4 @@ gst_msdkh264enc_init (GstMsdkH264Enc * thiz)
thiz->trellis = PROP_TRELLIS_DEFAULT; thiz->trellis = PROP_TRELLIS_DEFAULT;
thiz->max_slice_size = PROP_MAX_SLICE_SIZE_DEFAULT; thiz->max_slice_size = PROP_MAX_SLICE_SIZE_DEFAULT;
thiz->b_pyramid = PROP_B_PYRAMID_DEFAULT; thiz->b_pyramid = PROP_B_PYRAMID_DEFAULT;
thiz->parser = gst_h264_nal_parser_new ();
thiz->extra_sei = g_array_new (FALSE, FALSE, sizeof (GstH264SEIMessage));
g_array_set_clear_func (thiz->extra_sei, (GDestroyNotify) gst_h264_sei_clear);
} }

View file

@ -71,7 +71,7 @@ struct _GstMsdkH264Enc
guint b_pyramid; guint b_pyramid;
GstH264NalParser *parser; GstH264NalParser *parser;
GArray *extra_sei; GArray *cc_sei_array;
GstMemory *frame_packing_sei; GstMemory *frame_packing_sei;
}; };