Update thread names (#1120)

This commit is contained in:
goeiecool9999 2024-03-15 23:06:48 +01:00 committed by GitHub
parent 731713de3a
commit eaa82817dd
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
20 changed files with 29 additions and 12 deletions

View file

@ -297,7 +297,7 @@ bool GDBServer::Initialize()
void GDBServer::ThreadFunc() void GDBServer::ThreadFunc()
{ {
SetThreadName("GDBServer::ThreadFunc"); SetThreadName("GDBServer");
while (!m_stopRequested) while (!m_stopRequested)
{ {

View file

@ -294,7 +294,7 @@ std::atomic_bool s_recompilerThreadStopSignal{false};
void PPCRecompiler_thread() void PPCRecompiler_thread()
{ {
SetThreadName("PPCRecompiler_thread"); SetThreadName("PPCRecompiler");
while (true) while (true)
{ {
if(s_recompilerThreadStopSignal) if(s_recompilerThreadStopSignal)

View file

@ -8,6 +8,7 @@
#include <glslang/Public/ShaderLang.h> #include <glslang/Public/ShaderLang.h>
#include <glslang/SPIRV/GlslangToSpv.h> #include <glslang/SPIRV/GlslangToSpv.h>
#include <util/helpers/helpers.h>
bool s_isLoadingShadersVk{ false }; bool s_isLoadingShadersVk{ false };
class FileCache* s_spirvCache{nullptr}; class FileCache* s_spirvCache{nullptr};
@ -155,6 +156,7 @@ public:
void CompilerThreadFunc() void CompilerThreadFunc()
{ {
SetThreadName("vkShaderComp");
while (m_threadsActive.load(std::memory_order::relaxed)) while (m_threadsActive.load(std::memory_order::relaxed))
{ {
s_compilationQueueCount.decrementWithWait(); s_compilationQueueCount.decrementWithWait();

View file

@ -408,6 +408,7 @@ bool VulkanPipelineStableCache::DeserializePipeline(MemStreamReader& memReader,
int VulkanPipelineStableCache::CompilerThread() int VulkanPipelineStableCache::CompilerThread()
{ {
SetThreadName("plCacheCompiler");
while (m_numCompilationThreads != 0) while (m_numCompilationThreads != 0)
{ {
std::vector<uint8> pipelineData = m_compilationQueue.pop(); std::vector<uint8> pipelineData = m_compilationQueue.pop();
@ -421,6 +422,7 @@ int VulkanPipelineStableCache::CompilerThread()
void VulkanPipelineStableCache::WorkerThread() void VulkanPipelineStableCache::WorkerThread()
{ {
SetThreadName("plCacheWriter");
while (true) while (true)
{ {
CachedPipeline* job; CachedPipeline* job;

View file

@ -1986,6 +1986,7 @@ void VulkanRenderer::WaitCommandBufferFinished(uint64 commandBufferId)
void VulkanRenderer::PipelineCacheSaveThread(size_t cache_size) void VulkanRenderer::PipelineCacheSaveThread(size_t cache_size)
{ {
SetThreadName("vkDriverPlCache");
const auto dir = ActiveSettings::GetCachePath("shaderCache/driver/vk"); const auto dir = ActiveSettings::GetCachePath("shaderCache/driver/vk");
if (!fs::exists(dir)) if (!fs::exists(dir))
{ {

View file

@ -190,6 +190,7 @@ std::queue<PipelineCompiler*> g_compilePipelineRequests;
void compilePipeline_thread(sint32 threadIndex) void compilePipeline_thread(sint32 threadIndex)
{ {
SetThreadName("compilePl");
#ifdef _WIN32 #ifdef _WIN32
// one thread runs at normal priority while the others run at lower priority // one thread runs at normal priority while the others run at lower priority
if(threadIndex != 0) if(threadIndex != 0)

View file

@ -1,3 +1,4 @@
#include <util/helpers/helpers.h>
#include "iosu_odm.h" #include "iosu_odm.h"
#include "config/ActiveSettings.h" #include "config/ActiveSettings.h"
#include "Common/FileStream.h" #include "Common/FileStream.h"
@ -79,6 +80,7 @@ namespace iosu
void ODMServiceThread() void ODMServiceThread()
{ {
SetThreadName("ODMService");
s_msgQueueId = IOS_CreateMessageQueue(_s_msgBuffer.GetPtr(), _s_msgBuffer.GetCount()); s_msgQueueId = IOS_CreateMessageQueue(_s_msgBuffer.GetPtr(), _s_msgBuffer.GetCount());
cemu_assert(!IOS_ResultIsError((IOS_ERROR)s_msgQueueId)); cemu_assert(!IOS_ResultIsError((IOS_ERROR)s_msgQueueId));
IOS_ERROR r = IOS_RegisterResourceManager(s_devicePath.c_str(), s_msgQueueId); IOS_ERROR r = IOS_RegisterResourceManager(s_devicePath.c_str(), s_msgQueueId);

View file

@ -1,3 +1,4 @@
#include <util/helpers/helpers.h>
#include "iosu_pdm.h" #include "iosu_pdm.h"
#include "Cafe/CafeSystem.h" #include "Cafe/CafeSystem.h"
#include "config/ActiveSettings.h" #include "config/ActiveSettings.h"
@ -387,6 +388,7 @@ namespace iosu
void TimeTrackingThread(uint64 titleId) void TimeTrackingThread(uint64 titleId)
{ {
SetThreadName("PlayDiaryThread");
PlayStatsEntry* playStatsEntry = PlayStats_BeginNewTracking(titleId); PlayStatsEntry* playStatsEntry = PlayStats_BeginNewTracking(titleId);
auto startTime = std::chrono::steady_clock::now(); auto startTime = std::chrono::steady_clock::now();

View file

@ -155,6 +155,7 @@ namespace iosu
void IPCService::ServiceThread() void IPCService::ServiceThread()
{ {
SetThreadName("IPCService");
m_msgQueueId = IOS_CreateMessageQueue(_m_msgBuffer.GetPtr(), _m_msgBuffer.GetCount()); m_msgQueueId = IOS_CreateMessageQueue(_m_msgBuffer.GetPtr(), _m_msgBuffer.GetCount());
cemu_assert(!IOS_ResultIsError((IOS_ERROR)m_msgQueueId)); cemu_assert(!IOS_ResultIsError((IOS_ERROR)m_msgQueueId));
IOS_ERROR r = IOS_RegisterResourceManager(m_devicePath.c_str(), m_msgQueueId); IOS_ERROR r = IOS_RegisterResourceManager(m_devicePath.c_str(), m_msgQueueId);

View file

@ -1168,7 +1168,7 @@ namespace coreinit
void OSSchedulerCoreEmulationThread(void* _assignedCoreIndex) void OSSchedulerCoreEmulationThread(void* _assignedCoreIndex)
{ {
SetThreadName(fmt::format("OSSchedulerThread[core={}]", (uintptr_t)_assignedCoreIndex).c_str()); SetThreadName(fmt::format("OSSched[core={}]", (uintptr_t)_assignedCoreIndex).c_str());
t_assignedCoreIndex = (sint32)(uintptr_t)_assignedCoreIndex; t_assignedCoreIndex = (sint32)(uintptr_t)_assignedCoreIndex;
#if defined(ARCH_X86_64) #if defined(ARCH_X86_64)
_mm_setcsr(_mm_getcsr() | 0x8000); // flush denormals to zero _mm_setcsr(_mm_getcsr() | 0x8000); // flush denormals to zero

View file

@ -1,5 +1,6 @@
#include "SaveList.h" #include "SaveList.h"
#include <charconv> #include <charconv>
#include <util/helpers/helpers.h>
std::mutex sSLMutex; std::mutex sSLMutex;
fs::path sSLMLCPath; fs::path sSLMLCPath;
@ -44,6 +45,7 @@ void CafeSaveList::Refresh()
void CafeSaveList::RefreshThreadWorker() void CafeSaveList::RefreshThreadWorker()
{ {
SetThreadName("SaveListWorker");
// clear save list // clear save list
for (auto& itSaveInfo : sSLList) for (auto& itSaveInfo : sSLList)
{ {

View file

@ -258,6 +258,7 @@ void CafeTitleList::AddTitleFromPath(fs::path path)
bool CafeTitleList::RefreshWorkerThread() bool CafeTitleList::RefreshWorkerThread()
{ {
SetThreadName("TitleListWorker");
while (sTLRefreshRequests.load()) while (sTLRefreshRequests.load())
{ {
sTLRefreshRequests.store(0); sTLRefreshRequests.store(0);

View file

@ -50,7 +50,7 @@ struct _FileCacheAsyncWriter
private: private:
void FileCacheThread() void FileCacheThread()
{ {
SetThreadName("fileCache_thread"); SetThreadName("fileCache");
while (true) while (true)
{ {
std::unique_lock lock(m_fileCacheMutex); std::unique_lock lock(m_fileCacheMutex);

View file

@ -1194,6 +1194,7 @@ void wxGameList::RemoveCache(const std::list<fs::path>& cachePaths, const std::s
void wxGameList::AsyncWorkerThread() void wxGameList::AsyncWorkerThread()
{ {
SetThreadName("GameListWorker");
while (m_async_worker_active) while (m_async_worker_active)
{ {
m_async_task_count.decrementWithWait(); m_async_task_count.decrementWithWait();

View file

@ -37,7 +37,7 @@ void _wxLaunch()
void gui_create() void gui_create()
{ {
SetThreadName("MainThread"); SetThreadName("cemu");
#if BOOST_OS_WINDOWS #if BOOST_OS_WINDOWS
// on Windows wxWidgets there is a bug where wxDirDialog->ShowModal will deadlock in Windows internals somehow // on Windows wxWidgets there is a bug where wxDirDialog->ShowModal will deadlock in Windows internals somehow
// moving the UI thread off the main thread fixes this // moving the UI thread off the main thread fixes this

View file

@ -934,7 +934,7 @@ std::optional<glm::ivec2> InputManager::get_right_down_mouse_info(bool* is_pad)
void InputManager::update_thread() void InputManager::update_thread()
{ {
SetThreadName("InputManager::update_thread"); SetThreadName("Input_update");
while (!m_update_thread_shutdown.load(std::memory_order::relaxed)) while (!m_update_thread_shutdown.load(std::memory_order::relaxed))
{ {
std::shared_lock lock(m_mutex); std::shared_lock lock(m_mutex);

View file

@ -250,7 +250,7 @@ MotionSample DSUControllerProvider::get_motion_sample(uint8_t index) const
void DSUControllerProvider::reader_thread() void DSUControllerProvider::reader_thread()
{ {
SetThreadName("DSUControllerProvider::reader_thread"); SetThreadName("DSU-reader");
bool first_read = true; bool first_read = true;
while (m_running.load(std::memory_order_relaxed)) while (m_running.load(std::memory_order_relaxed))
{ {
@ -383,7 +383,7 @@ void DSUControllerProvider::reader_thread()
void DSUControllerProvider::writer_thread() void DSUControllerProvider::writer_thread()
{ {
SetThreadName("DSUControllerProvider::writer_thread"); SetThreadName("DSU-writer");
while (m_running.load(std::memory_order_relaxed)) while (m_running.load(std::memory_order_relaxed))
{ {
std::unique_lock lock(m_writer_mutex); std::unique_lock lock(m_writer_mutex);

View file

@ -124,7 +124,7 @@ MotionSample SDLControllerProvider::motion_sample(int diid)
void SDLControllerProvider::event_thread() void SDLControllerProvider::event_thread()
{ {
SetThreadName("SDLControllerProvider::event_thread"); SetThreadName("SDL_events");
while (m_running.load(std::memory_order_relaxed)) while (m_running.load(std::memory_order_relaxed))
{ {
SDL_Event event{}; SDL_Event event{};

View file

@ -143,7 +143,7 @@ WiimoteControllerProvider::WiimoteState WiimoteControllerProvider::get_state(siz
void WiimoteControllerProvider::reader_thread() void WiimoteControllerProvider::reader_thread()
{ {
SetThreadName("WiimoteControllerProvider::reader_thread"); SetThreadName("Wiimote-reader");
std::chrono::steady_clock::time_point lastCheck = {}; std::chrono::steady_clock::time_point lastCheck = {};
while (m_running.load(std::memory_order_relaxed)) while (m_running.load(std::memory_order_relaxed))
{ {
@ -878,7 +878,7 @@ void WiimoteControllerProvider::set_motion_plus(size_t index, bool state)
void WiimoteControllerProvider::writer_thread() void WiimoteControllerProvider::writer_thread()
{ {
SetThreadName("WiimoteControllerProvider::writer_thread"); SetThreadName("Wiimote-writer");
while (m_running.load(std::memory_order_relaxed)) while (m_running.load(std::memory_order_relaxed))
{ {
std::unique_lock writer_lock(m_writer_mutex); std::unique_lock writer_lock(m_writer_mutex);

View file

@ -155,7 +155,9 @@ void SetThreadName(const char* name)
#elif BOOST_OS_MACOS #elif BOOST_OS_MACOS
pthread_setname_np(name); pthread_setname_np(name);
#else #else
pthread_setname_np(pthread_self(), name); if(std::strlen(name) > 15)
cemuLog_log(LogType::Force, "Truncating thread name {} because it was longer than 15 characters", name);
pthread_setname_np(pthread_self(), std::string{name}.substr(0,15).c_str());
#endif #endif
} }