gallium/u_queue: fix a crash with atexit handlers
authorGrazvydas Ignotas <notasas@gmail.com>
Sun, 26 Feb 2017 00:44:06 +0000 (02:44 +0200)
committerMarek Olšák <marek.olsak@amd.com>
Mon, 27 Feb 2017 13:49:15 +0000 (14:49 +0100)
Commit 4aea8fe ("gallium/u_queue: fix random crashes when the app calls
exit()") added a atexit handler which calls
util_queue_killall_and_wait() for each queue to stop the threads.
However the app is also free to use atexit handlers to clean up things,
leading to util_queue_destroy() call which will also call
util_queue_killall_and_wait() for the same queue again, causing threads
being joined twice, and that is undefined. This happens with libglut,
for example. A simple fix is to just set num_threads to 0 as there are
no more valid threads after util_queue_killall_and_wait() returns.

Fixes: 4aea8fe "gallium/u_queue: fix random crashes when the app calls exit()"
Signed-off-by: Grazvydas Ignotas <notasas@gmail.com>
Signed-off-by: Marek Olšák <marek.olsak@amd.com>
src/gallium/auxiliary/util/u_queue.c

index 386dc4a9946bcfc2e48caed106a32e84d78884de..c51b6213c8c7b119c0b4530111f3860d7705d816 100644 (file)
@@ -272,6 +272,7 @@ util_queue_killall_and_wait(struct util_queue *queue)
 
    for (i = 0; i < queue->num_threads; i++)
       pipe_thread_wait(queue->threads[i]);
+   queue->num_threads = 0;
 }
 
 void