From 8d10f9989019972487c7208aa5a8d7923dafad21 Mon Sep 17 00:00:00 2001 From: anoll Date: Tue, 6 May 2014 09:52:38 +0200 Subject: [PATCH] 8042428: CompileQueue::free_all() code is incorrect Summary: Free task after getting next pointer of freelist. Reviewed-by: kvn, adlertz --- src/share/vm/compiler/compileBroker.cpp | 26 +++++++++++++++++-------- 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/src/share/vm/compiler/compileBroker.cpp b/src/share/vm/compiler/compileBroker.cpp index c6a768425..be98488ba 100644 --- a/src/share/vm/compiler/compileBroker.cpp +++ b/src/share/vm/compiler/compileBroker.cpp @@ -664,17 +664,27 @@ void CompileQueue::add(CompileTask* task) { lock()->notify_all(); } +/** + * Empties compilation queue by putting all compilation tasks onto + * a freelist. Furthermore, the method wakes up all threads that are + * waiting on a compilation task to finish. This can happen if background + * compilation is disabled. + */ void CompileQueue::free_all() { MutexLocker mu(lock()); - if (_first != NULL) { - for (CompileTask* task = _first; task != NULL; task = task->next()) { - // Wake up thread that blocks on the compile task. - task->lock()->notify(); - // Puts task back on the freelist. - CompileTask::free(task); - } - _first = NULL; + CompileTask* next = _first; + + // Iterate over all tasks in the compile queue + while (next != NULL) { + CompileTask* current = next; + next = current->next(); + // Wake up thread that blocks on the compile task. + current->lock()->notify(); + // Put the task back on the freelist. + CompileTask::free(current); } + _first = NULL; + // Wake up all threads that block on the queue. lock()->notify_all(); } -- GitLab