There is a deadlock if any thread from the pool tries to push
a new task while other thread is waiting for the pool of threads
to finish. With this patch the thread will get an error when it
tries to add a new task while the taskpool is being cleaned up.
static void
default_cleanup (GstTaskPool * pool)
{
+ GThreadPool *pool_;
+
GST_OBJECT_LOCK (pool);
- if (pool->pool) {
+ pool_ = pool->pool;
+ pool->pool = NULL;
+ GST_OBJECT_UNLOCK (pool);
+
+ if (pool_) {
/* Shut down all the threads, we still process the ones scheduled
* because the unref happens in the thread function.
* Also wait for currently running ones to finish. */
- g_thread_pool_free (pool->pool, FALSE, TRUE);
- pool->pool = NULL;
+ g_thread_pool_free (pool_, FALSE, TRUE);
}
- GST_OBJECT_UNLOCK (pool);
}
static gpointer