playsink: avoid crashing on the way out when needed chain missing
This commit is contained in:
parent
eae16a78b9
commit
948e4d50a6
@ -2217,6 +2217,8 @@ gst_play_sink_reconfigure (GstPlaySink * playsink)
|
|||||||
|
|
||||||
if (!playsink->videochain)
|
if (!playsink->videochain)
|
||||||
playsink->videochain = gen_video_chain (playsink, raw, async);
|
playsink->videochain = gen_video_chain (playsink, raw, async);
|
||||||
|
if (!playsink->videochain)
|
||||||
|
goto no_chain;
|
||||||
|
|
||||||
if (!playsink->video_sinkpad_stream_synchronizer) {
|
if (!playsink->video_sinkpad_stream_synchronizer) {
|
||||||
GstIterator *it;
|
GstIterator *it;
|
||||||
@ -2241,6 +2243,8 @@ gst_play_sink_reconfigure (GstPlaySink * playsink)
|
|||||||
if (!playsink->videodeinterlacechain)
|
if (!playsink->videodeinterlacechain)
|
||||||
playsink->videodeinterlacechain =
|
playsink->videodeinterlacechain =
|
||||||
gen_video_deinterlace_chain (playsink);
|
gen_video_deinterlace_chain (playsink);
|
||||||
|
if (!playsink->videodeinterlacechain)
|
||||||
|
goto no_chain;
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (playsink, "adding video deinterlace chain");
|
GST_DEBUG_OBJECT (playsink, "adding video deinterlace chain");
|
||||||
|
|
||||||
@ -2574,6 +2578,15 @@ gst_play_sink_reconfigure (GstPlaySink * playsink)
|
|||||||
GST_PLAY_SINK_UNLOCK (playsink);
|
GST_PLAY_SINK_UNLOCK (playsink);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
|
/* ERRORS */
|
||||||
|
no_chain:
|
||||||
|
{
|
||||||
|
/* gen_ chain already posted error */
|
||||||
|
GST_DEBUG_OBJECT (playsink, "failed to setup chain");
|
||||||
|
GST_PLAY_SINK_UNLOCK (playsink);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user