mirror of
https://github.com/RGBCube/serenity
synced 2025-10-24 11:32:08 +00:00

Previously, init() in BackgroundAction.cpp was calling Core::Object::set_name, which does not affect the displayed thread name which is displayed by the system monitor. This changes it to pass the name to the thread constructor.
64 lines
1.6 KiB
C++
64 lines
1.6 KiB
C++
/*
|
|
* Copyright (c) 2019-2020, Sergey Bugaev <bugaevc@serenityos.org>
|
|
* Copyright (c) 2021, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <AK/Queue.h>
|
|
#include <LibThreading/BackgroundAction.h>
|
|
#include <LibThreading/Mutex.h>
|
|
#include <LibThreading/Thread.h>
|
|
#include <unistd.h>
|
|
|
|
static pthread_mutex_t s_mutex = PTHREAD_MUTEX_INITIALIZER;
|
|
static pthread_cond_t s_condition = PTHREAD_COND_INITIALIZER;
|
|
static Queue<Function<void()>>* s_all_actions;
|
|
static Threading::Thread* s_background_thread;
|
|
|
|
static intptr_t background_thread_func()
|
|
{
|
|
Vector<Function<void()>> actions;
|
|
while (true) {
|
|
|
|
pthread_mutex_lock(&s_mutex);
|
|
|
|
while (s_all_actions->is_empty())
|
|
pthread_cond_wait(&s_condition, &s_mutex);
|
|
|
|
while (!s_all_actions->is_empty())
|
|
actions.append(s_all_actions->dequeue());
|
|
|
|
pthread_mutex_unlock(&s_mutex);
|
|
|
|
for (auto& action : actions)
|
|
action();
|
|
|
|
actions.clear();
|
|
}
|
|
}
|
|
|
|
static void init()
|
|
{
|
|
s_all_actions = new Queue<Function<void()>>;
|
|
s_background_thread = &Threading::Thread::construct(background_thread_func, "Background Thread"sv).leak_ref();
|
|
s_background_thread->start();
|
|
}
|
|
|
|
Threading::Thread& Threading::BackgroundActionBase::background_thread()
|
|
{
|
|
if (s_background_thread == nullptr)
|
|
init();
|
|
return *s_background_thread;
|
|
}
|
|
|
|
void Threading::BackgroundActionBase::enqueue_work(Function<void()> work)
|
|
{
|
|
if (s_all_actions == nullptr)
|
|
init();
|
|
|
|
pthread_mutex_lock(&s_mutex);
|
|
s_all_actions->enqueue(move(work));
|
|
pthread_cond_broadcast(&s_condition);
|
|
pthread_mutex_unlock(&s_mutex);
|
|
}
|