mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 00:28:21 +00:00
vp[89]enc: Reset the encoder when flushing
https://bugzilla.gnome.org/show_bug.cgi?id=745704
This commit is contained in:
parent
db3ade5bfb
commit
a52e432fda
2 changed files with 71 additions and 16 deletions
|
@ -370,6 +370,7 @@ static gboolean gst_vp8_enc_stop (GstVideoEncoder * encoder);
|
||||||
static gboolean gst_vp8_enc_set_format (GstVideoEncoder *
|
static gboolean gst_vp8_enc_set_format (GstVideoEncoder *
|
||||||
video_encoder, GstVideoCodecState * state);
|
video_encoder, GstVideoCodecState * state);
|
||||||
static GstFlowReturn gst_vp8_enc_finish (GstVideoEncoder * video_encoder);
|
static GstFlowReturn gst_vp8_enc_finish (GstVideoEncoder * video_encoder);
|
||||||
|
static gboolean gst_vp8_enc_flush (GstVideoEncoder * video_encoder);
|
||||||
static GstFlowReturn gst_vp8_enc_drain (GstVideoEncoder * video_encoder);
|
static GstFlowReturn gst_vp8_enc_drain (GstVideoEncoder * video_encoder);
|
||||||
static GstFlowReturn gst_vp8_enc_handle_frame (GstVideoEncoder *
|
static GstFlowReturn gst_vp8_enc_handle_frame (GstVideoEncoder *
|
||||||
video_encoder, GstVideoCodecFrame * frame);
|
video_encoder, GstVideoCodecFrame * frame);
|
||||||
|
@ -429,6 +430,7 @@ gst_vp8_enc_class_init (GstVP8EncClass * klass)
|
||||||
video_encoder_class->stop = gst_vp8_enc_stop;
|
video_encoder_class->stop = gst_vp8_enc_stop;
|
||||||
video_encoder_class->handle_frame = gst_vp8_enc_handle_frame;
|
video_encoder_class->handle_frame = gst_vp8_enc_handle_frame;
|
||||||
video_encoder_class->set_format = gst_vp8_enc_set_format;
|
video_encoder_class->set_format = gst_vp8_enc_set_format;
|
||||||
|
video_encoder_class->flush = gst_vp8_enc_flush;
|
||||||
video_encoder_class->finish = gst_vp8_enc_finish;
|
video_encoder_class->finish = gst_vp8_enc_finish;
|
||||||
video_encoder_class->pre_push = gst_vp8_enc_pre_push;
|
video_encoder_class->pre_push = gst_vp8_enc_pre_push;
|
||||||
video_encoder_class->sink_event = gst_vp8_enc_sink_event;
|
video_encoder_class->sink_event = gst_vp8_enc_sink_event;
|
||||||
|
@ -1415,15 +1417,9 @@ gst_vp8_enc_start (GstVideoEncoder * video_encoder)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static void
|
||||||
gst_vp8_enc_stop (GstVideoEncoder * video_encoder)
|
gst_vp8_enc_destroy_encoder (GstVP8Enc * encoder)
|
||||||
{
|
{
|
||||||
GstVP8Enc *encoder;
|
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (video_encoder, "stop");
|
|
||||||
|
|
||||||
encoder = GST_VP8_ENC (video_encoder);
|
|
||||||
|
|
||||||
g_mutex_lock (&encoder->encoder_lock);
|
g_mutex_lock (&encoder->encoder_lock);
|
||||||
if (encoder->inited) {
|
if (encoder->inited) {
|
||||||
vpx_codec_destroy (&encoder->encoder);
|
vpx_codec_destroy (&encoder->encoder);
|
||||||
|
@ -1441,6 +1437,18 @@ gst_vp8_enc_stop (GstVideoEncoder * video_encoder)
|
||||||
encoder->cfg.rc_twopass_stats_in.sz = 0;
|
encoder->cfg.rc_twopass_stats_in.sz = 0;
|
||||||
}
|
}
|
||||||
g_mutex_unlock (&encoder->encoder_lock);
|
g_mutex_unlock (&encoder->encoder_lock);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gst_vp8_enc_stop (GstVideoEncoder * video_encoder)
|
||||||
|
{
|
||||||
|
GstVP8Enc *encoder;
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (video_encoder, "stop");
|
||||||
|
|
||||||
|
encoder = GST_VP8_ENC (video_encoder);
|
||||||
|
|
||||||
|
gst_vp8_enc_destroy_encoder (encoder);
|
||||||
|
|
||||||
gst_tag_setter_reset_tags (GST_TAG_SETTER (encoder));
|
gst_tag_setter_reset_tags (GST_TAG_SETTER (encoder));
|
||||||
|
|
||||||
|
@ -1917,6 +1925,25 @@ gst_vp8_enc_drain (GstVideoEncoder * video_encoder)
|
||||||
return GST_FLOW_OK;
|
return GST_FLOW_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gst_vp8_enc_flush (GstVideoEncoder * video_encoder)
|
||||||
|
{
|
||||||
|
GstVP8Enc *encoder;
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (video_encoder, "flush");
|
||||||
|
|
||||||
|
encoder = GST_VP8_ENC (video_encoder);
|
||||||
|
|
||||||
|
gst_vp8_enc_destroy_encoder (encoder);
|
||||||
|
if (encoder->input_state) {
|
||||||
|
gst_video_codec_state_ref (encoder->input_state);
|
||||||
|
gst_vp8_enc_set_format (video_encoder, encoder->input_state);
|
||||||
|
gst_video_codec_state_unref (encoder->input_state);
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
static GstFlowReturn
|
static GstFlowReturn
|
||||||
gst_vp8_enc_finish (GstVideoEncoder * video_encoder)
|
gst_vp8_enc_finish (GstVideoEncoder * video_encoder)
|
||||||
{
|
{
|
||||||
|
|
|
@ -346,6 +346,8 @@ static gboolean gst_vp9_enc_stop (GstVideoEncoder * encoder);
|
||||||
static gboolean gst_vp9_enc_set_format (GstVideoEncoder *
|
static gboolean gst_vp9_enc_set_format (GstVideoEncoder *
|
||||||
video_encoder, GstVideoCodecState * state);
|
video_encoder, GstVideoCodecState * state);
|
||||||
static GstFlowReturn gst_vp9_enc_finish (GstVideoEncoder * video_encoder);
|
static GstFlowReturn gst_vp9_enc_finish (GstVideoEncoder * video_encoder);
|
||||||
|
static gboolean gst_vp9_enc_flush (GstVideoEncoder * video_encoder);
|
||||||
|
static GstFlowReturn gst_vp9_enc_drain (GstVideoEncoder * video_encoder);
|
||||||
static GstFlowReturn gst_vp9_enc_handle_frame (GstVideoEncoder *
|
static GstFlowReturn gst_vp9_enc_handle_frame (GstVideoEncoder *
|
||||||
video_encoder, GstVideoCodecFrame * frame);
|
video_encoder, GstVideoCodecFrame * frame);
|
||||||
static GstFlowReturn gst_vp9_enc_drain (GstVideoEncoder * video_encoder);
|
static GstFlowReturn gst_vp9_enc_drain (GstVideoEncoder * video_encoder);
|
||||||
|
@ -405,6 +407,7 @@ gst_vp9_enc_class_init (GstVP9EncClass * klass)
|
||||||
video_encoder_class->stop = gst_vp9_enc_stop;
|
video_encoder_class->stop = gst_vp9_enc_stop;
|
||||||
video_encoder_class->handle_frame = gst_vp9_enc_handle_frame;
|
video_encoder_class->handle_frame = gst_vp9_enc_handle_frame;
|
||||||
video_encoder_class->set_format = gst_vp9_enc_set_format;
|
video_encoder_class->set_format = gst_vp9_enc_set_format;
|
||||||
|
video_encoder_class->flush = gst_vp9_enc_flush;
|
||||||
video_encoder_class->finish = gst_vp9_enc_finish;
|
video_encoder_class->finish = gst_vp9_enc_finish;
|
||||||
video_encoder_class->sink_event = gst_vp9_enc_sink_event;
|
video_encoder_class->sink_event = gst_vp9_enc_sink_event;
|
||||||
video_encoder_class->propose_allocation = gst_vp9_enc_propose_allocation;
|
video_encoder_class->propose_allocation = gst_vp9_enc_propose_allocation;
|
||||||
|
@ -1392,15 +1395,9 @@ gst_vp9_enc_start (GstVideoEncoder * video_encoder)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static void
|
||||||
gst_vp9_enc_stop (GstVideoEncoder * video_encoder)
|
gst_vp9_enc_destroy_encoder (GstVP9Enc * encoder)
|
||||||
{
|
{
|
||||||
GstVP9Enc *encoder;
|
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (video_encoder, "stop");
|
|
||||||
|
|
||||||
encoder = GST_VP9_ENC (video_encoder);
|
|
||||||
|
|
||||||
g_mutex_lock (&encoder->encoder_lock);
|
g_mutex_lock (&encoder->encoder_lock);
|
||||||
if (encoder->inited) {
|
if (encoder->inited) {
|
||||||
vpx_codec_destroy (&encoder->encoder);
|
vpx_codec_destroy (&encoder->encoder);
|
||||||
|
@ -1418,6 +1415,18 @@ gst_vp9_enc_stop (GstVideoEncoder * video_encoder)
|
||||||
encoder->cfg.rc_twopass_stats_in.sz = 0;
|
encoder->cfg.rc_twopass_stats_in.sz = 0;
|
||||||
}
|
}
|
||||||
g_mutex_unlock (&encoder->encoder_lock);
|
g_mutex_unlock (&encoder->encoder_lock);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gst_vp9_enc_stop (GstVideoEncoder * video_encoder)
|
||||||
|
{
|
||||||
|
GstVP9Enc *encoder;
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (video_encoder, "stop");
|
||||||
|
|
||||||
|
encoder = GST_VP9_ENC (video_encoder);
|
||||||
|
|
||||||
|
gst_vp9_enc_destroy_encoder (encoder);
|
||||||
|
|
||||||
gst_tag_setter_reset_tags (GST_TAG_SETTER (encoder));
|
gst_tag_setter_reset_tags (GST_TAG_SETTER (encoder));
|
||||||
|
|
||||||
|
@ -1856,6 +1865,25 @@ gst_vp9_enc_drain (GstVideoEncoder * video_encoder)
|
||||||
return GST_FLOW_OK;
|
return GST_FLOW_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gst_vp9_enc_flush (GstVideoEncoder * video_encoder)
|
||||||
|
{
|
||||||
|
GstVP9Enc *encoder;
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (video_encoder, "flush");
|
||||||
|
|
||||||
|
encoder = GST_VP9_ENC (video_encoder);
|
||||||
|
|
||||||
|
gst_vp9_enc_destroy_encoder (encoder);
|
||||||
|
if (encoder->input_state) {
|
||||||
|
gst_video_codec_state_ref (encoder->input_state);
|
||||||
|
gst_vp9_enc_set_format (video_encoder, encoder->input_state);
|
||||||
|
gst_video_codec_state_unref (encoder->input_state);
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
static GstFlowReturn
|
static GstFlowReturn
|
||||||
gst_vp9_enc_finish (GstVideoEncoder * video_encoder)
|
gst_vp9_enc_finish (GstVideoEncoder * video_encoder)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue