Commit 508bc20a authored by Vladislav Vaintroub's avatar Vladislav Vaintroub

tpool - misc fixes

parent c27577a1
......@@ -742,16 +742,13 @@ void thread_pool_generic::submit_task(task* task)
/* Notify thread pool that current thread is going to wait */
void thread_pool_generic::wait_begin()
{
if (!tls_worker_data || tls_worker_data->is_long_task() || tls_worker_data->is_waiting())
if (!tls_worker_data || tls_worker_data->is_long_task())
return;
std::unique_lock<std::mutex> lk(m_mtx);
tls_worker_data->m_state |= worker_data::WAITING;
m_waiting_task_count++;
/* Maintain concurrency */
if (m_task_queue.empty())
return;
if (m_active_threads.size() - m_long_tasks_count - m_waiting_task_count < m_concurrency)
maybe_wake_or_create_thread();
}
......
#include <tpool.h>
namespace tpool
{
static thread_local tpool::thread_pool* tls_thread_pool;
extern "C" void set_tls_pool(tpool::thread_pool* pool)
......@@ -19,3 +21,5 @@ extern "C" void tpool_wait_end()
if (tls_thread_pool)
tls_thread_pool->wait_end();
}
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment