PerformanceMetrics: Switch to ThreadHandle

This commit is contained in:
Connor McLaughlin 2022-05-02 16:05:24 +10:00 committed by refractionpcsx2
parent 6ebb8c2e91
commit 4bdf180145
5 changed files with 47 additions and 32 deletions

View File

@ -217,7 +217,7 @@ void EmuThread::saveStateToSlot(qint32 slot)
void EmuThread::run() void EmuThread::run()
{ {
PerformanceMetrics::SetCPUThreadTimer(Common::ThreadCPUTimer::GetForCallingThread()); PerformanceMetrics::SetCPUThread(Threading::ThreadHandle::GetForCallingThread());
m_event_loop = new QEventLoop(); m_event_loop = new QEventLoop();
m_started_semaphore.release(); m_started_semaphore.release();
@ -244,7 +244,7 @@ void EmuThread::run()
destroyBackgroundControllerPollTimer(); destroyBackgroundControllerPollTimer();
InputManager::CloseSources(); InputManager::CloseSources();
VMManager::Internal::ReleaseMemory(); VMManager::Internal::ReleaseMemory();
PerformanceMetrics::SetCPUThreadTimer(Common::ThreadCPUTimer()); PerformanceMetrics::SetCPUThread(Threading::ThreadHandle());
moveToThread(m_ui_thread); moveToThread(m_ui_thread);
deleteLater(); deleteLater();
} }

View File

@ -1204,7 +1204,7 @@ GSRasterizerList::~GSRasterizerList()
void GSRasterizerList::OnWorkerStartup(int i) void GSRasterizerList::OnWorkerStartup(int i)
{ {
Threading::SetNameOfCurrentThread(StringUtil::StdStringFromFormat("GS-SW-%d", i).c_str()); Threading::SetNameOfCurrentThread(StringUtil::StdStringFromFormat("GS-SW-%d", i).c_str());
PerformanceMetrics::SetGSSWThreadTimer(i, Common::ThreadCPUTimer::GetForCallingThread()); PerformanceMetrics::SetGSSWThread(i, Threading::ThreadHandle::GetForCallingThread());
} }
void GSRasterizerList::OnWorkerShutdown(int i) void GSRasterizerList::OnWorkerShutdown(int i)

View File

@ -18,6 +18,9 @@
#include <chrono> #include <chrono>
#include <vector> #include <vector>
#include "common/Timer.h"
#include "common/Threading.h"
#include "PerformanceMetrics.h" #include "PerformanceMetrics.h"
#include "System.h" #include "System.h"
#include "System/SysThreads.h" #include "System/SysThreads.h"
@ -50,7 +53,8 @@ static PerformanceMetrics::InternalFPSMethod s_internal_fps_method = Performance
static u32 s_gs_framebuffer_blits_since_last_update = 0; static u32 s_gs_framebuffer_blits_since_last_update = 0;
static u32 s_gs_privileged_register_writes_since_last_update = 0; static u32 s_gs_privileged_register_writes_since_last_update = 0;
static Common::ThreadCPUTimer s_cpu_thread_timer; static Threading::ThreadHandle s_cpu_thread_handle;
static u64 s_last_cpu_time = 0;
static u64 s_last_gs_time = 0; static u64 s_last_gs_time = 0;
static u64 s_last_vu_time = 0; static u64 s_last_vu_time = 0;
static u64 s_last_ticks = 0; static u64 s_last_ticks = 0;
@ -64,7 +68,8 @@ static float s_vu_thread_time = 0.0f;
struct GSSWThreadStats struct GSSWThreadStats
{ {
Common::ThreadCPUTimer timer; Threading::ThreadHandle handle;
u64 last_cpu_time = 0;
double usage = 0.0; double usage = 0.0;
double time = 0.0; double time = 0.0;
}; };
@ -112,10 +117,13 @@ void PerformanceMetrics::Reset()
s_last_update_time.Reset(); s_last_update_time.Reset();
s_last_frame_time.Reset(); s_last_frame_time.Reset();
s_cpu_thread_timer.Reset(); s_last_cpu_time = s_cpu_thread_handle.GetCPUTime();
s_last_gs_time = GetMTGS().GetCpuTime(); s_last_gs_time = GetMTGS().GetCpuTime();
s_last_vu_time = THREAD_VU1 ? vu1Thread.GetCpuTime() : 0; s_last_vu_time = THREAD_VU1 ? vu1Thread.GetCpuTime() : 0;
s_last_ticks = GetCPUTicks(); s_last_ticks = GetCPUTicks();
for (GSSWThreadStats& stat : s_gs_sw_threads)
stat.last_cpu_time = stat.handle.GetCPUTime();
} }
void PerformanceMetrics::Update(bool gs_register_write, bool fb_blit) void PerformanceMetrics::Update(bool gs_register_write, bool fb_blit)
@ -164,22 +172,9 @@ void PerformanceMetrics::Update(bool gs_register_write, bool fb_blit)
s_gs_privileged_register_writes_since_last_update = 0; s_gs_privileged_register_writes_since_last_update = 0;
s_gs_framebuffer_blits_since_last_update = 0; s_gs_framebuffer_blits_since_last_update = 0;
s_cpu_thread_timer.GetUsageInMillisecondsAndReset(ticks_diff, &s_cpu_thread_time, &s_cpu_thread_usage);
s_cpu_thread_time /= static_cast<double>(s_frames_since_last_update);
for (GSSWThreadStats& thread : s_gs_sw_threads)
{
thread.timer.GetUsageInMillisecondsAndReset(ticks_diff, &thread.time, &thread.usage);
thread.time /= static_cast<double>(s_frames_since_last_update);
}
const u64 gs_time = GetMTGS().GetCpuTime();
const u64 vu_time = THREAD_VU1 ? vu1Thread.GetCpuTime() : 0;
const u64 ticks = GetCPUTicks(); const u64 ticks = GetCPUTicks();
const u64 gs_delta = gs_time - s_last_gs_time;
const u64 vu_delta = vu_time - s_last_vu_time;
const u64 ticks_delta = ticks - s_last_ticks; const u64 ticks_delta = ticks - s_last_ticks;
s_last_ticks = ticks;
const double pct_divider = const double pct_divider =
100.0 * (1.0 / ((static_cast<double>(ticks_delta) * static_cast<double>(GetThreadTicksPerSecond())) / 100.0 * (1.0 / ((static_cast<double>(ticks_delta) * static_cast<double>(GetThreadTicksPerSecond())) /
@ -187,14 +182,32 @@ void PerformanceMetrics::Update(bool gs_register_write, bool fb_blit)
const double time_divider = 1000.0 * (1.0 / static_cast<double>(GetThreadTicksPerSecond())) * const double time_divider = 1000.0 * (1.0 / static_cast<double>(GetThreadTicksPerSecond())) *
(1.0 / static_cast<double>(s_frames_since_last_update)); (1.0 / static_cast<double>(s_frames_since_last_update));
const u64 cpu_time = s_cpu_thread_handle.GetCPUTime();
const u64 gs_time = GetMTGS().GetCpuTime();
const u64 vu_time = THREAD_VU1 ? vu1Thread.GetCpuTime() : 0;
const u64 cpu_delta = cpu_time - s_last_cpu_time;
const u64 gs_delta = gs_time - s_last_gs_time;
const u64 vu_delta = vu_time - s_last_vu_time;
s_last_cpu_time = cpu_time;
s_last_gs_time = gs_time;
s_last_vu_time = vu_time;
s_cpu_thread_usage = static_cast<double>(cpu_delta) * pct_divider;
s_gs_thread_usage = static_cast<double>(gs_delta) * pct_divider; s_gs_thread_usage = static_cast<double>(gs_delta) * pct_divider;
s_vu_thread_usage = static_cast<double>(vu_delta) * pct_divider; s_vu_thread_usage = static_cast<double>(vu_delta) * pct_divider;
s_cpu_thread_time = static_cast<double>(cpu_delta) * time_divider;
s_gs_thread_time = static_cast<double>(gs_delta) * time_divider; s_gs_thread_time = static_cast<double>(gs_delta) * time_divider;
s_vu_thread_time = static_cast<double>(vu_delta) * time_divider; s_vu_thread_time = static_cast<double>(vu_delta) * time_divider;
s_last_gs_time = gs_time; for (GSSWThreadStats& thread : s_gs_sw_threads)
s_last_vu_time = vu_time; {
s_last_ticks = ticks; const u64 time = thread.handle.GetCPUTime();
const u64 delta = time - thread.last_cpu_time;
thread.last_cpu_time = time;
thread.usage = static_cast<double>(delta) * pct_divider;
thread.time = static_cast<double>(delta) * time_divider;
}
s_frames_since_last_update = 0; s_frames_since_last_update = 0;
s_presents_since_last_update = 0; s_presents_since_last_update = 0;
@ -210,9 +223,10 @@ void PerformanceMetrics::OnGPUPresent(float gpu_time)
s_presents_since_last_update++; s_presents_since_last_update++;
} }
void PerformanceMetrics::SetCPUThreadTimer(Common::ThreadCPUTimer timer) void PerformanceMetrics::SetCPUThread(Threading::ThreadHandle thread)
{ {
s_cpu_thread_timer = std::move(timer); s_last_cpu_time = thread ? thread.GetCPUTime() : 0;
s_cpu_thread_handle = std::move(thread);
} }
void PerformanceMetrics::SetGSSWThreadCount(u32 count) void PerformanceMetrics::SetGSSWThreadCount(u32 count)
@ -221,9 +235,10 @@ void PerformanceMetrics::SetGSSWThreadCount(u32 count)
s_gs_sw_threads.resize(count); s_gs_sw_threads.resize(count);
} }
void PerformanceMetrics::SetGSSWThreadTimer(u32 index, Common::ThreadCPUTimer timer) void PerformanceMetrics::SetGSSWThread(u32 index, Threading::ThreadHandle thread)
{ {
s_gs_sw_threads[index].timer = std::move(timer); s_gs_sw_threads[index].last_cpu_time = thread ? thread.GetCPUTime() : 0;
s_gs_sw_threads[index].handle = std::move(thread);
} }
void PerformanceMetrics::SetVerticalFrequency(float rate) void PerformanceMetrics::SetVerticalFrequency(float rate)

View File

@ -14,7 +14,7 @@
*/ */
#pragma once #pragma once
#include "common/Timer.h" #include "common/Threading.h"
namespace PerformanceMetrics namespace PerformanceMetrics
{ {
@ -31,11 +31,11 @@ namespace PerformanceMetrics
void OnGPUPresent(float gpu_time); void OnGPUPresent(float gpu_time);
/// Sets the EE thread for CPU usage calculations. /// Sets the EE thread for CPU usage calculations.
void SetCPUThreadTimer(Common::ThreadCPUTimer timer); void SetCPUThread(Threading::ThreadHandle thread);
/// Sets timers for GS software threads. /// Sets timers for GS software threads.
void SetGSSWThreadCount(u32 count); void SetGSSWThreadCount(u32 count);
void SetGSSWThreadTimer(u32 index, Common::ThreadCPUTimer timer); void SetGSSWThread(u32 index, Threading::ThreadHandle thread);
/// Sets the vertical frequency, used in speed calculations. /// Sets the vertical frequency, used in speed calculations.
void SetVerticalFrequency(float rate); void SetVerticalFrequency(float rate);

View File

@ -341,12 +341,12 @@ void SysCoreThread::TearDownSystems(SystemsMask systemsToTearDown)
if (systemsToTearDown & System_SPU2) SPU2close(); if (systemsToTearDown & System_SPU2) SPU2close();
if (systemsToTearDown & System_MCD) FileMcd_EmuClose(); if (systemsToTearDown & System_MCD) FileMcd_EmuClose();
PerformanceMetrics::SetCPUThreadTimer(Common::ThreadCPUTimer()); PerformanceMetrics::SetCPUThread(Threading::ThreadHandle());
} }
void SysCoreThread::OnResumeInThread(SystemsMask systemsToReinstate) void SysCoreThread::OnResumeInThread(SystemsMask systemsToReinstate)
{ {
PerformanceMetrics::SetCPUThreadTimer(Common::ThreadCPUTimer::GetForCallingThread()); PerformanceMetrics::SetCPUThread(Threading::ThreadHandle::GetForCallingThread());
PerformanceMetrics::Reset(); PerformanceMetrics::Reset();
GetMTGS().WaitForOpen(); GetMTGS().WaitForOpen();