mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-23 07:38:16 +00:00
vtdec: Ignore output loop errors in drain() if we're flushing
In an early non-linked scenario, this was causing a ton of criticals about the queue array, because the output callback would still fire for leftover frames that were still being processed by VT at the time the output loop stopped. This makes sure they're flushed correctly as well. Also renames gst_vtdec_loop to gst_vtdec_output_loop for consistency with related functions. wip Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6411>
This commit is contained in:
parent
bf88fb152d
commit
11c6432cca
1 changed files with 12 additions and 12 deletions
|
@ -80,7 +80,7 @@ static void gst_vtdec_finalize (GObject * object);
|
||||||
|
|
||||||
static gboolean gst_vtdec_start (GstVideoDecoder * decoder);
|
static gboolean gst_vtdec_start (GstVideoDecoder * decoder);
|
||||||
static gboolean gst_vtdec_stop (GstVideoDecoder * decoder);
|
static gboolean gst_vtdec_stop (GstVideoDecoder * decoder);
|
||||||
static void gst_vtdec_loop (GstVtdec * self);
|
static void gst_vtdec_output_loop (GstVtdec * self);
|
||||||
static gboolean gst_vtdec_negotiate (GstVideoDecoder * decoder);
|
static gboolean gst_vtdec_negotiate (GstVideoDecoder * decoder);
|
||||||
static gboolean gst_vtdec_set_format (GstVideoDecoder * decoder,
|
static gboolean gst_vtdec_set_format (GstVideoDecoder * decoder,
|
||||||
GstVideoCodecState * state);
|
GstVideoCodecState * state);
|
||||||
|
@ -234,7 +234,7 @@ gst_vtdec_start (GstVideoDecoder * decoder)
|
||||||
/* Create the output task, but pause it immediately */
|
/* Create the output task, but pause it immediately */
|
||||||
vtdec->pause_task = TRUE;
|
vtdec->pause_task = TRUE;
|
||||||
if (!gst_pad_start_task (GST_VIDEO_DECODER_SRC_PAD (decoder),
|
if (!gst_pad_start_task (GST_VIDEO_DECODER_SRC_PAD (decoder),
|
||||||
(GstTaskFunction) gst_vtdec_loop, vtdec, NULL)) {
|
(GstTaskFunction) gst_vtdec_output_loop, vtdec, NULL)) {
|
||||||
GST_ERROR_OBJECT (vtdec, "failed to start output thread");
|
GST_ERROR_OBJECT (vtdec, "failed to start output thread");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -295,7 +295,7 @@ gst_vtdec_stop (GstVideoDecoder * decoder)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_vtdec_loop (GstVtdec * vtdec)
|
gst_vtdec_output_loop (GstVtdec * vtdec)
|
||||||
{
|
{
|
||||||
GstVideoCodecFrame *frame;
|
GstVideoCodecFrame *frame;
|
||||||
GstFlowReturn ret = GST_FLOW_OK;
|
GstFlowReturn ret = GST_FLOW_OK;
|
||||||
|
@ -340,6 +340,8 @@ gst_vtdec_loop (GstVtdec * vtdec)
|
||||||
GST_LOG_OBJECT (vtdec, "dropping frame %d", frame->system_frame_number);
|
GST_LOG_OBJECT (vtdec, "dropping frame %d", frame->system_frame_number);
|
||||||
gst_video_decoder_drop_frame (decoder, frame);
|
gst_video_decoder_drop_frame (decoder, frame);
|
||||||
} else {
|
} else {
|
||||||
|
GST_TRACE_OBJECT (vtdec, "pushing frame %d",
|
||||||
|
frame->system_frame_number);
|
||||||
ret = gst_video_decoder_finish_frame (decoder, frame);
|
ret = gst_video_decoder_finish_frame (decoder, frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -826,13 +828,9 @@ gst_vtdec_handle_frame (GstVideoDecoder * decoder, GstVideoCodecFrame * frame)
|
||||||
if (task_state == GST_TASK_STOPPED || task_state == GST_TASK_PAUSED) {
|
if (task_state == GST_TASK_STOPPED || task_state == GST_TASK_PAUSED) {
|
||||||
/* Abort if our loop failed to push frames downstream... */
|
/* Abort if our loop failed to push frames downstream... */
|
||||||
if (vtdec->downstream_ret != GST_FLOW_OK) {
|
if (vtdec->downstream_ret != GST_FLOW_OK) {
|
||||||
if (vtdec->downstream_ret == GST_FLOW_FLUSHING)
|
GST_DEBUG_OBJECT (vtdec,
|
||||||
GST_DEBUG_OBJECT (vtdec,
|
"Output loop stopped because of %s, ignoring frame",
|
||||||
"Output loop stopped because of flushing, ignoring frame");
|
gst_flow_get_name (vtdec->downstream_ret));
|
||||||
else
|
|
||||||
GST_WARNING_OBJECT (vtdec,
|
|
||||||
"Output loop stopped with error (%s), leaving",
|
|
||||||
gst_flow_get_name (vtdec->downstream_ret));
|
|
||||||
|
|
||||||
ret = vtdec->downstream_ret;
|
ret = vtdec->downstream_ret;
|
||||||
goto drop;
|
goto drop;
|
||||||
|
@ -1231,7 +1229,7 @@ gst_vtdec_session_output_callback (void *decompression_output_ref_con,
|
||||||
push_anyway = vtdec->is_flushing || vtdec->is_draining;
|
push_anyway = vtdec->is_flushing || vtdec->is_draining;
|
||||||
while (!push_anyway
|
while (!push_anyway
|
||||||
&& gst_queue_array_get_length (vtdec->reorder_queue) >
|
&& gst_queue_array_get_length (vtdec->reorder_queue) >
|
||||||
vtdec->dbp_size * 2) {
|
vtdec->dbp_size * 2 + 1) {
|
||||||
g_cond_wait (&vtdec->queue_cond, &vtdec->queue_mutex);
|
g_cond_wait (&vtdec->queue_cond, &vtdec->queue_mutex);
|
||||||
push_anyway = vtdec->is_flushing || vtdec->is_draining;
|
push_anyway = vtdec->is_flushing || vtdec->is_draining;
|
||||||
}
|
}
|
||||||
|
@ -1256,7 +1254,9 @@ gst_vtdec_drain_decoder (GstVideoDecoder * decoder, gboolean flush)
|
||||||
if (vtdec->session == NULL)
|
if (vtdec->session == NULL)
|
||||||
return GST_FLOW_OK;
|
return GST_FLOW_OK;
|
||||||
|
|
||||||
if (vtdec->downstream_ret != GST_FLOW_OK
|
/* Only early-return here if we're draining (as that needs to output frames).
|
||||||
|
* Flushing doesn't care about errors from downstream. */
|
||||||
|
if (!flush && vtdec->downstream_ret != GST_FLOW_OK
|
||||||
&& vtdec->downstream_ret != GST_FLOW_FLUSHING) {
|
&& vtdec->downstream_ret != GST_FLOW_FLUSHING) {
|
||||||
GST_WARNING_OBJECT (vtdec, "Output loop stopped with error (%s), leaving",
|
GST_WARNING_OBJECT (vtdec, "Output loop stopped with error (%s), leaving",
|
||||||
gst_flow_get_name (vtdec->downstream_ret));
|
gst_flow_get_name (vtdec->downstream_ret));
|
||||||
|
|
Loading…
Reference in a new issue