multiqueue: fix potential crash on shutdown

The mq we get out of the weak ref might be NULL if we're
shutting down, which could cause assertion failures or
crashes.

It might also cause miscompilations where the compiler just
optimises away the NULL check because it jumps to a code path
that then dereferences the pointer which clearly isn't going
to work. Seems like something like this happens with gcc 11.

Fixes #1262

Co-authored-by: Doug Nazar <nazard@nazar.ca>
Co-authored-by: Sebastian Dröge <sebastian@centricular.com>
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/2600>
This commit is contained in:
Tim-Philipp Müller 2022-06-14 17:29:31 +01:00
parent a192577bea
commit 94069a7414

View file

@ -2102,7 +2102,7 @@ gst_multi_queue_loop (GstPad * pad)
srcpad = g_weak_ref_get (&sq->srcpad);
if (!mq || !srcpad)
goto out_flushing;
goto done;
next:
GST_DEBUG_OBJECT (mq, "SingleQueue %d : trying to pop an object", sq->id);
@ -2419,7 +2419,7 @@ gst_multi_queue_chain (GstPad * pad, GstObject * parent, GstBuffer * buffer)
mq = g_weak_ref_get (&sq->mqueue);
if (!mq)
goto flushing;
goto done;
/* if eos, we are always full, so avoid hanging incoming indefinitely */
if (sq->is_eos)