diff --git a/ChangeLog b/ChangeLog index fa10f1973..67a5c4206 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Mon Aug 13 14:18:22 2007 Tim Janik + + * glib/gthread.c (g_thread_create_full): prevent linking a freed + GThread structure into global thread list in error cases. + 2007-08-08 Matthias Clasen * glib/gmarkup.c (append_escaped_text): Handle restricted diff --git a/glib/gthread.c b/glib/gthread.c index fe9f25d9a..5468e596f 100644 --- a/glib/gthread.c +++ b/glib/gthread.c @@ -579,7 +579,7 @@ g_thread_cleanup (gpointer data) /* Just to make sure, this isn't used any more */ g_system_thread_assign (thread->system_thread, zero_thread); - g_free (thread); + g_free (thread); } } } @@ -662,8 +662,11 @@ g_thread_create_full (GThreadFunc func, G_THREAD_UF (thread_create, (g_thread_create_proxy, result, stack_size, joinable, bound, priority, &result->system_thread, &local_error)); - result->next = g_thread_all_threads; - g_thread_all_threads = result; + if (!local_error) + { + result->next = g_thread_all_threads; + g_thread_all_threads = result; + } G_UNLOCK (g_thread); if (local_error)