From bf814a9aa3b8b47f06a8e2dfa54597769a76c69c Mon Sep 17 00:00:00 2001 From: Benjamin Berg Date: Tue, 13 Oct 2020 15:09:43 +0200 Subject: [PATCH] gmain: Fix possible locking issue in source unref When unref'ing child sources, the lock is already held. But instead of passing TRUE to g_source_unref_internal it currently passes whether the lock was already held outside of the current invocation. Just pass TRUE to fix this possible issue. --- glib/gmain.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/glib/gmain.c b/glib/gmain.c index 675ff3886..acbd0d4f0 100644 --- a/glib/gmain.c +++ b/glib/gmain.c @@ -2293,7 +2293,7 @@ g_source_unref_internal (GSource *source, g_slist_remove (source->priv->child_sources, child_source); child_source->priv->parent_source = NULL; - g_source_unref_internal (child_source, context, have_lock); + g_source_unref_internal (child_source, context, TRUE); } g_slice_free (GSourcePrivate, source->priv);