From bbd47ebd2754b0f92e077134c1c579b789809032 Mon Sep 17 00:00:00 2001 From: ueshita Date: Sat, 24 Feb 2024 15:30:19 +0900 Subject: [PATCH] Fix gpu timer (#999) * Rename GPUTime -> GpuTime * Add stage feature of GpuTimer --- .../Effekseer/Effekseer/Effekseer.Manager.cpp | 97 ++++++------- .../Effekseer/Effekseer/Effekseer.Manager.h | 4 +- .../Effekseer/Effekseer.ManagerImplemented.h | 4 +- .../Effekseer/Network/Effekseer.Client.cpp | 6 +- .../Effekseer/Network/Effekseer.Client.h | 6 +- .../Effekseer/Network/Effekseer.Server.cpp | 4 +- .../Effekseer/Renderer/Effekseer.GpuTimer.h | 67 ++++++++- .../EffekseerRendererDX11.GpuTimer.cpp | 130 ++++++++++++------ .../EffekseerRendererDX11.GpuTimer.h | 21 +-- .../EffekseerRendererGL.GpuTimer.cpp | 76 ++++++---- .../EffekseerRendererGL.GpuTimer.h | 23 ++-- Dev/Cpp/Viewer/3D/EffectRenderer.cpp | 10 +- Dev/Cpp/Viewer/3D/EffectRenderer.h | 4 +- Dev/Cpp/Viewer/Network/Network.cpp | 6 +- Dev/Cpp/Viewer/Network/ProfileSample.h | 6 +- Dev/Cpp/Viewer/dll_cs.cxx | 32 ++--- Dev/Editor/Effekseer/GUI/Dock/Profiler.cs | 10 +- .../EffekseerCoreGUI/swig/EffectRenderer.cs | 8 +- .../swig/EffekseerNativePINVOKE.cs | 32 ++--- .../EffekseerCoreGUI/swig/ProfileSample.cs | 18 +-- .../languages/ja/Effekseer_Profiler.csv | 4 +- 21 files changed, 345 insertions(+), 223 deletions(-) diff --git a/Dev/Cpp/Effekseer/Effekseer/Effekseer.Manager.cpp b/Dev/Cpp/Effekseer/Effekseer/Effekseer.Manager.cpp index b0842c1c2b..ca15256a1e 100644 --- a/Dev/Cpp/Effekseer/Effekseer/Effekseer.Manager.cpp +++ b/Dev/Cpp/Effekseer/Effekseer/Effekseer.Manager.cpp @@ -637,7 +637,17 @@ GpuTimerRef ManagerImplemented::GetGpuTimer() void ManagerImplemented::SetGpuTimer(GpuTimerRef gpuTimer) { + if (m_gpuTimer && m_gpuParticleSystem) + { + m_gpuTimer->RemoveTimer(m_gpuParticleSystem.Get()); + } + m_gpuTimer = gpuTimer; + + if (m_gpuTimer && m_gpuParticleSystem) + { + m_gpuTimer->AddTimer(m_gpuParticleSystem.Get()); + } } GpuParticleSystemRef ManagerImplemented::GetGpuParticleSystem() @@ -647,7 +657,17 @@ GpuParticleSystemRef ManagerImplemented::GetGpuParticleSystem() void ManagerImplemented::SetGpuParticleSystem(GpuParticleSystemRef system) { + if (m_gpuTimer && m_gpuParticleSystem) + { + m_gpuTimer->RemoveTimer(m_gpuParticleSystem.Get()); + } + m_gpuParticleSystem = system; + + if (m_gpuTimer && m_gpuParticleSystem) + { + m_gpuTimer->AddTimer(m_gpuParticleSystem.Get()); + } } GpuParticleFactoryRef ManagerImplemented::GetGpuParticleFactory() @@ -1798,8 +1818,12 @@ void ManagerImplemented::ResetAndPlayWithDataSet(DrawSet& drawSet, float frame) void ManagerImplemented::Compute() { + ScopedGpuStage gpuPass(m_gpuTimer, GpuStage::Compute); + if (auto gpuParticleSystem = GetGpuParticleSystem()) { + ScopedGpuTime gpuTime(m_gpuTimer, gpuParticleSystem.Get()); + for (int i = 0; i < m_nextComputeCount; i++) { gpuParticleSystem->ComputeFrame(); @@ -1821,10 +1845,7 @@ void ManagerImplemented::Draw(const Manager::DrawParameter& drawParameter) // start to record a time int64_t beginTime = ::Effekseer::GetTime(); - if (m_gpuTimer != nullptr) - { - m_gpuTimer->BeginFrame(); - } + ScopedGpuStage gpuPass(m_gpuTimer, GpuStage::Draw); const auto cullingPlanes = GeometryUtility::CalculateFrustumPlanes(drawParameter.ViewProjectionMatrix, drawParameter.ZNear, drawParameter.ZFar, GetSetting()->GetCoordinateSystem()); @@ -1837,8 +1858,7 @@ void ManagerImplemented::Draw(const Manager::DrawParameter& drawParameter) if (drawSet.IsAutoDrawing) { - if (m_gpuTimer != nullptr) - m_gpuTimer->Start(drawSet.GlobalPointer, 0); + ScopedGpuTime gpuTime(m_gpuTimer, drawSet.GlobalPointer); if (drawSet.GlobalPointer->RenderedInstanceContainers.size() > 0) { @@ -1854,9 +1874,6 @@ void ManagerImplemented::Draw(const Manager::DrawParameter& drawParameter) { drawSet.InstanceContainerPointer->Draw(true); } - - if (m_gpuTimer != nullptr) - m_gpuTimer->Stop(drawSet.GlobalPointer, 0); } }; @@ -1879,12 +1896,9 @@ void ManagerImplemented::Draw(const Manager::DrawParameter& drawParameter) if (auto gpuParticleSystem = GetGpuParticleSystem()) { - gpuParticleSystem->RenderFrame(); - } + ScopedGpuTime gpuTime(m_gpuTimer, gpuParticleSystem.Get()); - if (m_gpuTimer != nullptr) - { - m_gpuTimer->EndFrame(); + gpuParticleSystem->RenderFrame(); } // calculate a time @@ -1898,6 +1912,8 @@ void ManagerImplemented::DrawBack(const Manager::DrawParameter& drawParameter) // start to record a time int64_t beginTime = ::Effekseer::GetTime(); + ScopedGpuStage gpuPass(m_gpuTimer, GpuStage::DrawBack); + const auto cullingPlanes = GeometryUtility::CalculateFrustumPlanes(drawParameter.ViewProjectionMatrix, drawParameter.ZNear, drawParameter.ZFar, GetSetting()->GetCoordinateSystem()); const auto render = [this, &drawParameter, &cullingPlanes](DrawSet& drawSet) -> void @@ -1909,8 +1925,7 @@ void ManagerImplemented::DrawBack(const Manager::DrawParameter& drawParameter) if (drawSet.IsAutoDrawing) { - if (m_gpuTimer != nullptr) - m_gpuTimer->Start(drawSet.GlobalPointer, 0); + ScopedGpuTime gpuTime(m_gpuTimer, drawSet.GlobalPointer); auto e = (EffectImplemented*)drawSet.ParameterPointer.Get(); for (int32_t j = 0; j < e->renderingNodesThreshold; j++) @@ -1920,9 +1935,6 @@ void ManagerImplemented::DrawBack(const Manager::DrawParameter& drawParameter) drawSet.GlobalPointer->RenderedInstanceContainers[j]->Draw(false); } - - if (m_gpuTimer != nullptr) - m_gpuTimer->Stop(drawSet.GlobalPointer, 0); } }; @@ -1953,11 +1965,8 @@ void ManagerImplemented::DrawFront(const Manager::DrawParameter& drawParameter) // start to record a time int64_t beginTime = ::Effekseer::GetTime(); - - if (m_gpuTimer != nullptr) - { - m_gpuTimer->BeginFrame(); - } + + ScopedGpuStage gpuPass(m_gpuTimer, GpuStage::DrawFront); const auto cullingPlanes = GeometryUtility::CalculateFrustumPlanes(drawParameter.ViewProjectionMatrix, drawParameter.ZNear, drawParameter.ZFar, GetSetting()->GetCoordinateSystem()); @@ -1970,8 +1979,7 @@ void ManagerImplemented::DrawFront(const Manager::DrawParameter& drawParameter) if (drawSet.IsAutoDrawing) { - if (m_gpuTimer != nullptr) - m_gpuTimer->Start(drawSet.GlobalPointer, 1); + ScopedGpuTime gpuTime(m_gpuTimer, drawSet.GlobalPointer); if (drawSet.GlobalPointer->RenderedInstanceContainers.size() > 0) { @@ -1988,9 +1996,6 @@ void ManagerImplemented::DrawFront(const Manager::DrawParameter& drawParameter) { drawSet.InstanceContainerPointer->Draw(true); } - - if (m_gpuTimer != nullptr) - m_gpuTimer->Stop(drawSet.GlobalPointer, 1); } }; @@ -2013,12 +2018,9 @@ void ManagerImplemented::DrawFront(const Manager::DrawParameter& drawParameter) if (auto gpuParticleSystem = GetGpuParticleSystem()) { - gpuParticleSystem->RenderFrame(); - } + ScopedGpuTime gpuTime(m_gpuTimer, gpuParticleSystem.Get()); - if (m_gpuTimer != nullptr) - { - m_gpuTimer->EndFrame(); + gpuParticleSystem->RenderFrame(); } // calculate a time @@ -2111,9 +2113,6 @@ void ManagerImplemented::DrawHandle(Handle handle, const Manager::DrawParameter& return; } - if (m_gpuTimer != nullptr) - m_gpuTimer->Start(drawSet.GlobalPointer, 0); - if (drawSet.GlobalPointer->RenderedInstanceContainers.size() > 0) { for (auto& c : drawSet.GlobalPointer->RenderedInstanceContainers) @@ -2128,9 +2127,6 @@ void ManagerImplemented::DrawHandle(Handle handle, const Manager::DrawParameter& { drawSet.InstanceContainerPointer->Draw(true); } - - if (m_gpuTimer != nullptr) - m_gpuTimer->Stop(drawSet.GlobalPointer, 0); } } @@ -2156,9 +2152,6 @@ void ManagerImplemented::DrawHandleBack(Handle handle, const Manager::DrawParame return; } - if (m_gpuTimer != nullptr) - m_gpuTimer->Start(drawSet.GlobalPointer, 0); - for (int32_t i = 0; i < e->renderingNodesThreshold; i++) { if (IsClippedWithDepth(drawSet, drawSet.GlobalPointer->RenderedInstanceContainers[i], drawParameter)) @@ -2166,9 +2159,6 @@ void ManagerImplemented::DrawHandleBack(Handle handle, const Manager::DrawParame drawSet.GlobalPointer->RenderedInstanceContainers[i]->Draw(false); } - - if (m_gpuTimer != nullptr) - m_gpuTimer->Stop(drawSet.GlobalPointer, 0); } } @@ -2194,9 +2184,6 @@ void ManagerImplemented::DrawHandleFront(Handle handle, const Manager::DrawParam return; } - if (m_gpuTimer != nullptr) - m_gpuTimer->Start(drawSet.GlobalPointer, 1); - if (drawSet.GlobalPointer->RenderedInstanceContainers.size() > 0) { for (size_t i = e->renderingNodesThreshold; i < drawSet.GlobalPointer->RenderedInstanceContainers.size(); i++) @@ -2211,9 +2198,6 @@ void ManagerImplemented::DrawHandleFront(Handle handle, const Manager::DrawParam { drawSet.InstanceContainerPointer->Draw(true); } - - if (m_gpuTimer != nullptr) - m_gpuTimer->Stop(drawSet.GlobalPointer, 1); } } @@ -2239,7 +2223,7 @@ int ManagerImplemented::GetDrawTime() const return m_drawTime; } -int32_t ManagerImplemented::GetGPUTime() const +int32_t ManagerImplemented::GetGpuTime() const { if (m_gpuTimer != nullptr) { @@ -2248,12 +2232,17 @@ int32_t ManagerImplemented::GetGPUTime() const { timeCount += m_gpuTimer->GetResult(kv.second.GlobalPointer); } + + if (m_gpuParticleSystem) + { + timeCount += m_gpuTimer->GetResult(m_gpuParticleSystem.Get()); + } return timeCount; } return 0; } -int32_t ManagerImplemented::GetGPUTime(Handle handle) const +int32_t ManagerImplemented::GetGpuTime(Handle handle) const { if (m_gpuTimer != nullptr) { diff --git a/Dev/Cpp/Effekseer/Effekseer/Effekseer.Manager.h b/Dev/Cpp/Effekseer/Effekseer/Effekseer.Manager.h index 7e0263798b..0b559f707a 100644 --- a/Dev/Cpp/Effekseer/Effekseer/Effekseer.Manager.h +++ b/Dev/Cpp/Effekseer/Effekseer/Effekseer.Manager.h @@ -960,14 +960,14 @@ class Manager : public IReference \~English Gets the GPU time (microseconds) taken to render the all effects. \~Japanese エフェクト全ての描画処理にかかるGPU時間(マイクロ秒)を取得する。 */ - virtual int32_t GetGPUTime() const = 0; + virtual int32_t GetGpuTime() const = 0; /** @brief \~English Gets the GPU time (microseconds) taken to render the effect. \~Japanese エフェクトの描画処理にかかるGPU時間(マイクロ秒)を取得する。 */ - virtual int32_t GetGPUTime(Handle handle) const = 0; + virtual int32_t GetGpuTime(Handle handle) const = 0; /** @brief diff --git a/Dev/Cpp/Effekseer/Effekseer/Effekseer.ManagerImplemented.h b/Dev/Cpp/Effekseer/Effekseer/Effekseer.ManagerImplemented.h index 5ef0e1ec40..c6ba2b09e5 100644 --- a/Dev/Cpp/Effekseer/Effekseer/Effekseer.ManagerImplemented.h +++ b/Dev/Cpp/Effekseer/Effekseer/Effekseer.ManagerImplemented.h @@ -453,9 +453,9 @@ class ManagerImplemented : public Manager, public ReferenceObject int GetDrawTime() const override; - int32_t GetGPUTime() const override; + int32_t GetGpuTime() const override; - int32_t GetGPUTime(Handle handle) const override; + int32_t GetGpuTime(Handle handle) const override; int32_t GetRestInstancesCount() const override; diff --git a/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Client.cpp b/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Client.cpp index ff583591c8..6389636caf 100644 --- a/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Client.cpp +++ b/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Client.cpp @@ -119,8 +119,8 @@ void ClientImplemented::OnProfileSample(const Session::Message& msg) for (auto fbManager : *fb->managers()) { ProfileSample::Manager profileManager; - profileManager.CPUTime = fbManager->cpu_time(); - profileManager.GPUTime = fbManager->gpu_time(); + profileManager.CpuTime = fbManager->cpu_time(); + profileManager.GpuTime = fbManager->gpu_time(); profileManager.HandleCount = fbManager->handle_count(); profileSample.Managers.emplace_back(profileManager); } @@ -129,7 +129,7 @@ void ClientImplemented::OnProfileSample(const Session::Message& msg) { ProfileSample::Effect profileEffect; profileEffect.Key.assign((const char16_t*)fbEffect->key()->data(), (size_t)fbEffect->key()->size()); - profileEffect.GPUTime = fbEffect->gpu_time(); + profileEffect.GpuTime = fbEffect->gpu_time(); profileEffect.HandleCount = fbEffect->handle_count(); profileSample.Effects.emplace_back(profileEffect); } diff --git a/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Client.h b/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Client.h index 42a078eefd..cd3ebb4a54 100644 --- a/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Client.h +++ b/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Client.h @@ -35,8 +35,8 @@ class Client : public IReference struct Manager { uint32_t HandleCount = 0; - float CPUTime = 0.0f; - float GPUTime = 0.0f; + float CpuTime = 0.0f; + float GpuTime = 0.0f; }; std::vector Managers; @@ -44,7 +44,7 @@ class Client : public IReference { std::u16string Key; uint32_t HandleCount = 0; - float GPUTime = 0.0f; + float GpuTime = 0.0f; }; std::vector Effects; }; diff --git a/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Server.cpp b/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Server.cpp index cdefeb4046..efe0329c71 100644 --- a/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Server.cpp +++ b/Dev/Cpp/Effekseer/Effekseer/Network/Effekseer.Server.cpp @@ -218,7 +218,7 @@ void ServerImplemented::UpdateProfiler(InternalClient& client) if (handleAndDrawSet.second.ParameterPointer == profile.effect) { profile.handleCount += 1; - profile.gpuTime += manager->GetGPUTime(handleAndDrawSet.first); + profile.gpuTime += manager->GetGpuTime(handleAndDrawSet.first); break; } } @@ -227,7 +227,7 @@ void ServerImplemented::UpdateProfiler(InternalClient& client) fbManagers.emplace_back(Data::CreateNetworkManagerProfile(fbb, (uint32_t)drawSets.size(), manager->GetUpdateTime() + manager->GetDrawTime(), - manager->GetGPUTime())); + manager->GetGpuTime())); } for (auto& profile : effectProfiles) diff --git a/Dev/Cpp/Effekseer/Effekseer/Renderer/Effekseer.GpuTimer.h b/Dev/Cpp/Effekseer/Effekseer/Renderer/Effekseer.GpuTimer.h index 90a540748f..a32fbd8f86 100644 --- a/Dev/Cpp/Effekseer/Effekseer/Renderer/Effekseer.GpuTimer.h +++ b/Dev/Cpp/Effekseer/Effekseer/Renderer/Effekseer.GpuTimer.h @@ -10,6 +10,15 @@ namespace Effekseer class GpuTimer; using GpuTimerRef = RefPtr; +enum class GpuStage : uint8_t +{ + None, + Compute, + Draw, + DrawBack, + DrawFront, +}; + class GpuTimer : public ReferenceObject { public: @@ -17,21 +26,71 @@ class GpuTimer : public ReferenceObject virtual ~GpuTimer() = default; - virtual void BeginFrame() {} + virtual void BeginStage(GpuStage stage) {} - virtual void EndFrame() {} + virtual void EndStage(GpuStage stage) {} virtual void AddTimer(const void* object) {} virtual void RemoveTimer(const void* object) {} - virtual void Start(const void* object, uint32_t phase) {} + virtual void Start(const void* object) {} - virtual void Stop(const void* object, uint32_t phase) {} + virtual void Stop(const void* object) {} virtual int32_t GetResult(const void* object) { return -1; } }; +class ScopedGpuStage +{ +public: + ScopedGpuStage(GpuTimerRef timer, GpuStage stage) + : m_timer(timer), m_stage(stage) + { + if (m_timer) + { + m_timer->BeginStage(m_stage); + } + } + + ~ScopedGpuStage() + { + if (m_timer) + { + m_timer->EndStage(m_stage); + } + } + +private: + GpuTimerRef m_timer; + GpuStage m_stage; +}; + +class ScopedGpuTime +{ +public: + ScopedGpuTime(GpuTimerRef timer, const void* object) + : m_timer(timer), m_object(object) + { + if (m_timer) + { + m_timer->Start(m_object); + } + } + + ~ScopedGpuTime() + { + if (m_timer) + { + m_timer->Stop(m_object); + } + } + +private: + GpuTimerRef m_timer; + const void* m_object; +}; + } // namespace Effekseer #endif // __EFFEKSEER_GPU_TIMER_H__ diff --git a/Dev/Cpp/EffekseerRendererDX11/EffekseerRendererDX11/EffekseerRendererDX11.GpuTimer.cpp b/Dev/Cpp/EffekseerRendererDX11/EffekseerRendererDX11/EffekseerRendererDX11.GpuTimer.cpp index 4c1a6abcb7..9fde6d6d87 100644 --- a/Dev/Cpp/EffekseerRendererDX11/EffekseerRendererDX11/EffekseerRendererDX11.GpuTimer.cpp +++ b/Dev/Cpp/EffekseerRendererDX11/EffekseerRendererDX11/EffekseerRendererDX11.GpuTimer.cpp @@ -46,9 +46,13 @@ void GpuTimer::InitDevice() { D3D11_QUERY_DESC desc = {}; desc.Query = D3D11_QUERY_TIMESTAMP_DISJOINT; - ID3D11Query* disjoint = nullptr; - device->CreateQuery(&desc, &disjoint); - m_disjoint.reset(disjoint); + + for (uint32_t index = 1; index < 5; index++) + { + ID3D11Query* disjoint = nullptr; + device->CreateQuery(&desc, &disjoint); + m_disjoint[index].reset(disjoint); + } } for (auto& kv : m_timeData) @@ -58,15 +62,15 @@ void GpuTimer::InitDevice() D3D11_QUERY_DESC desc = {}; desc.Query = D3D11_QUERY_TIMESTAMP; - for (uint32_t i = 0; i < NUM_PHASES; i++) + for (uint32_t phase = 0; phase < NUM_PHASES; phase++) { ID3D11Query* startQuery = nullptr; device->CreateQuery(&desc, &startQuery); - timeData.startQuery[i].reset(startQuery); + timeData.startQuery[phase].reset(startQuery); ID3D11Query* stopQuery = nullptr; device->CreateQuery(&desc, &stopQuery); - timeData.stopQuery[i].reset(stopQuery); + timeData.stopQuery[phase].reset(stopQuery); } } } @@ -79,14 +83,17 @@ void GpuTimer::ReleaseDevice() for (auto& kv : m_timeData) { TimeData& timeData = kv.second; - for (uint32_t i = 0; i < NUM_PHASES; i++) + for (uint32_t phase = 0; phase < NUM_PHASES; phase++) { - timeData.startQuery[i].reset(); - timeData.stopQuery[i].reset(); + timeData.startQuery[phase].reset(); + timeData.stopQuery[phase].reset(); } } - m_disjoint.reset(); + for (uint32_t index = 1; index < 5; index++) + { + m_disjoint[index].reset(); + } } //----------------------------------------------------------------------------------- @@ -108,49 +115,73 @@ void GpuTimer::OnResetDevice() //----------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------- -void GpuTimer::BeginFrame() +void GpuTimer::BeginStage(Effekseer::GpuStage stage) { - assert(m_state != State::DuringFrame); + assert(stage != Effekseer::GpuStage::None); + + uint32_t index = static_cast(stage); + assert(m_stageState[index] != State::DuringStage); - if (m_state == State::AfterFrame) + if (m_stageState[index] == State::AfterStage) { // Avoid D3D11 warning - UpdateResults(); + UpdateResults(stage); } auto context = GetRenderer()->GetContext(); - context->Begin(m_disjoint.get()); - m_state = State::DuringFrame; + context->Begin(m_disjoint[index].get()); + + m_stageState[index] = State::DuringStage; + m_currentStage = stage; } //----------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------- -void GpuTimer::EndFrame() +void GpuTimer::EndStage(Effekseer::GpuStage stage) { - assert(m_state == State::DuringFrame); + assert(stage != Effekseer::GpuStage::None); + + uint32_t index = static_cast(stage); + assert(m_stageState[index] == State::DuringStage); auto context = GetRenderer()->GetContext(); - context->End(m_disjoint.get()); - m_state = State::AfterFrame; + context->End(m_disjoint[index].get()); + + m_stageState[index] = State::AfterStage; + m_currentStage = Effekseer::GpuStage::None; } //----------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------- -void GpuTimer::UpdateResults() +void GpuTimer::UpdateResults(Effekseer::GpuStage stage) { HRESULT hr = S_OK; auto context = GetRenderer()->GetContext(); + assert(stage != Effekseer::GpuStage::None); + uint32_t index = static_cast(stage); + D3D11_QUERY_DATA_TIMESTAMP_DISJOINT disjoint = {1, TRUE}; - hr = context->GetData(m_disjoint.get(), &disjoint, sizeof(disjoint), 0); - if (hr != S_OK) + + while (true) { - return; + hr = context->GetData(m_disjoint[index].get(), &disjoint, sizeof(disjoint), 0); + if (hr == S_OK) + { + break; + } + else if (hr == S_FALSE) + { + Sleep(1); + } + else + { + return; + } } - auto getTimeStamp = [context](ID3D11Query* query, uint64_t& time) { while (true) @@ -177,21 +208,21 @@ void GpuTimer::UpdateResults() timeData.result = 0; uint64_t elapsedTime = 0; - for (uint32_t i = 0; i < NUM_PHASES; i++) + for (uint32_t phase = 0; phase < NUM_PHASES; phase++) { - if (timeData.queryRequested[i]) + if (timeData.queryedStage[phase] == stage) { uint64_t startTime, stopTime; - if (!getTimeStamp(timeData.startQuery[i].get(), startTime)) continue; - if (!getTimeStamp(timeData.stopQuery[i].get(), stopTime)) continue; + if (!getTimeStamp(timeData.startQuery[phase].get(), startTime)) continue; + if (!getTimeStamp(timeData.stopQuery[phase].get(), stopTime)) continue; elapsedTime += (stopTime - startTime) * 1000000 / disjoint.Frequency; - timeData.queryRequested[i] = false; + timeData.queryedStage[phase] = Effekseer::GpuStage::None; } } timeData.result = static_cast(elapsedTime); } - m_state = State::ResultUpdated; + m_stageState[index] = State::ResultUpdated; } //----------------------------------------------------------------------------------- @@ -232,9 +263,9 @@ void GpuTimer::RemoveTimer(const void* object) //----------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------- -void GpuTimer::Start(const void* object, uint32_t phase) +void GpuTimer::Start(const void* object) { - assert(phase < NUM_PHASES); + assert(m_currentStage != Effekseer::GpuStage::None); auto context = GetRenderer()->GetContext(); @@ -242,17 +273,24 @@ void GpuTimer::Start(const void* object, uint32_t phase) if (it != m_timeData.end()) { TimeData& timeData = it->second; - context->End(timeData.startQuery[phase].get()); - timeData.queryRequested[phase] = true; + for (uint32_t phase = 0; phase < NUM_PHASES; phase++) + { + if (timeData.queryedStage[phase] == Effekseer::GpuStage::None) + { + context->End(timeData.startQuery[phase].get()); + timeData.queryedStage[phase] = m_currentStage; + break; + } + } } } //----------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------- -void GpuTimer::Stop(const void* object, uint32_t phase) +void GpuTimer::Stop(const void* object) { - assert(phase < NUM_PHASES); + assert(m_currentStage != Effekseer::GpuStage::None); auto context = GetRenderer()->GetContext(); @@ -260,7 +298,14 @@ void GpuTimer::Stop(const void* object, uint32_t phase) if (it != m_timeData.end()) { TimeData& timeData = it->second; - context->End(timeData.stopQuery[phase].get()); + for (uint32_t phase = 0; phase < NUM_PHASES; phase++) + { + if (timeData.queryedStage[phase] == m_currentStage) + { + context->End(timeData.stopQuery[phase].get()); + break; + } + } } } @@ -269,11 +314,12 @@ void GpuTimer::Stop(const void* object, uint32_t phase) //----------------------------------------------------------------------------------- int32_t GpuTimer::GetResult(const void* object) { - assert(m_state == State::ResultUpdated || m_state == State::AfterFrame); - - if (m_state == State::AfterFrame) + for (uint32_t index = 1; index < 5; index++) { - UpdateResults(); + if (m_stageState[index] == State::AfterStage) + { + UpdateResults(static_cast(index)); + } } auto it = m_timeData.find(object); diff --git a/Dev/Cpp/EffekseerRendererDX11/EffekseerRendererDX11/EffekseerRendererDX11.GpuTimer.h b/Dev/Cpp/EffekseerRendererDX11/EffekseerRendererDX11/EffekseerRendererDX11.GpuTimer.h index 6f8e504e75..b91e153bf3 100644 --- a/Dev/Cpp/EffekseerRendererDX11/EffekseerRendererDX11/EffekseerRendererDX11.GpuTimer.h +++ b/Dev/Cpp/EffekseerRendererDX11/EffekseerRendererDX11/EffekseerRendererDX11.GpuTimer.h @@ -26,19 +26,19 @@ class GpuTimer : public DeviceObject, public ::Effekseer::GpuTimer void InitDevice(); void ReleaseDevice(); - void UpdateResults(); + void UpdateResults(Effekseer::GpuStage stage); public: // For device restore virtual void OnLostDevice(); virtual void OnResetDevice(); public: // GpuTimer - virtual void BeginFrame() override; - virtual void EndFrame() override; + virtual void BeginStage(Effekseer::GpuStage stage) override; + virtual void EndStage(Effekseer::GpuStage stage) override; virtual void AddTimer(const void* object) override; virtual void RemoveTimer(const void* object) override; - virtual void Start(const void* object, uint32_t phase) override; - virtual void Stop(const void* object, uint32_t phase) override; + virtual void Start(const void* object) override; + virtual void Stop(const void* object) override; virtual int32_t GetResult(const void* object) override; private: @@ -46,19 +46,20 @@ class GpuTimer : public DeviceObject, public ::Effekseer::GpuTimer { Backend::D3D11QueryPtr startQuery[NUM_PHASES]; Backend::D3D11QueryPtr stopQuery[NUM_PHASES]; - bool queryRequested[NUM_PHASES] = {}; + Effekseer::GpuStage queryedStage[NUM_PHASES] = {}; int32_t result = 0; }; std::unordered_map m_timeData; - Backend::D3D11QueryPtr m_disjoint; + Backend::D3D11QueryPtr m_disjoint[8]; enum class State { NoResult, - DuringFrame, - AfterFrame, + DuringStage, + AfterStage, ResultUpdated, }; - State m_state = State::NoResult; + State m_stageState[8] = {}; + Effekseer::GpuStage m_currentStage = {}; }; //----------------------------------------------------------------------------------- diff --git a/Dev/Cpp/EffekseerRendererGL/EffekseerRendererGL/EffekseerRendererGL.GpuTimer.cpp b/Dev/Cpp/EffekseerRendererGL/EffekseerRendererGL/EffekseerRendererGL.GpuTimer.cpp index 7708a8f592..2a4b461a26 100644 --- a/Dev/Cpp/EffekseerRendererGL/EffekseerRendererGL/EffekseerRendererGL.GpuTimer.cpp +++ b/Dev/Cpp/EffekseerRendererGL/EffekseerRendererGL/EffekseerRendererGL.GpuTimer.cpp @@ -78,53 +78,64 @@ void GpuTimer::OnResetDevice() //----------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------- -void GpuTimer::BeginFrame() +void GpuTimer::BeginStage(Effekseer::GpuStage stage) { - assert(m_state != State::DuringFrame); + assert(stage != Effekseer::GpuStage::None); - if (m_state == State::AfterFrame) + uint32_t index = static_cast(stage); + assert(m_stageState[index] != State::DuringStage); + + if (m_stageState[index] == State::AfterStage) { - UpdateResults(); + UpdateResults(stage); } - m_state = State::DuringFrame; + m_stageState[index] = State::DuringStage; + m_currentStage = stage; } //----------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------- -void GpuTimer::EndFrame() +void GpuTimer::EndStage(Effekseer::GpuStage stage) { - assert(m_state == State::DuringFrame); + assert(stage != Effekseer::GpuStage::None); + + uint32_t index = static_cast(stage); + assert(m_stageState[index] == State::DuringStage); - m_state = State::AfterFrame; + m_stageState[index] = State::AfterStage; + m_currentStage = Effekseer::GpuStage::None; } //----------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------- -void GpuTimer::UpdateResults() +void GpuTimer::UpdateResults(Effekseer::GpuStage stage) { + assert(stage != Effekseer::GpuStage::None); + uint32_t index = static_cast(stage); + for (auto& kv : m_timeData) { auto& timeData = kv.second; timeData.result = 0; uint64_t elapsedTime = 0; - for (uint32_t i = 0; i < NUM_PHASES; i++) + for (uint32_t phase = 0; phase < NUM_PHASES; phase++) { - if (timeData.queryRequested[i]) + if (timeData.queryedStage[phase] == stage) { uint64_t result = 0; - GLExt::glGetQueryObjectui64v(timeData.timeElapsedQuery[i], GL_QUERY_RESULT, &result); + GLExt::glGetQueryObjectui64v(timeData.timeElapsedQuery[phase], GL_QUERY_RESULT, &result); elapsedTime += result / 1000; // nanoseconds -> microseconds - timeData.queryRequested[i] = false; + timeData.queryedStage[phase] = Effekseer::GpuStage::None; } } timeData.result = static_cast(elapsedTime); } - m_state = State::ResultUpdated; + m_stageState[index] = State::ResultUpdated; GLCheckError(); } @@ -163,16 +174,23 @@ void GpuTimer::RemoveTimer(const void* object) //----------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------- -void GpuTimer::Start(const void* object, uint32_t phase) +void GpuTimer::Start(const void* object) { - assert(phase < NUM_PHASES); + assert(m_currentStage != Effekseer::GpuStage::None); auto it = m_timeData.find(object); if (it != m_timeData.end()) { TimeData& timeData = it->second; - GLExt::glBeginQuery(GL_TIME_ELAPSED, timeData.timeElapsedQuery[phase]); - timeData.queryRequested[phase] = true; + for (uint32_t phase = 0; phase < NUM_PHASES; phase++) + { + if (timeData.queryedStage[phase] == Effekseer::GpuStage::None) + { + GLExt::glBeginQuery(GL_TIME_ELAPSED, timeData.timeElapsedQuery[phase]); + timeData.queryedStage[phase] = m_currentStage; + break; + } + } } GLCheckError(); @@ -181,15 +199,22 @@ void GpuTimer::Start(const void* object, uint32_t phase) //----------------------------------------------------------------------------------- // //----------------------------------------------------------------------------------- -void GpuTimer::Stop(const void* object, uint32_t phase) +void GpuTimer::Stop(const void* object) { - assert(phase < NUM_PHASES); + assert(m_currentStage != Effekseer::GpuStage::None); auto it = m_timeData.find(object); if (it != m_timeData.end()) { TimeData& timeData = it->second; - GLExt::glEndQuery(GL_TIME_ELAPSED); + for (uint32_t phase = 0; phase < NUM_PHASES; phase++) + { + if (timeData.queryedStage[phase] == m_currentStage) + { + GLExt::glEndQuery(GL_TIME_ELAPSED); + break; + } + } } GLCheckError(); @@ -200,11 +225,12 @@ void GpuTimer::Stop(const void* object, uint32_t phase) //----------------------------------------------------------------------------------- int32_t GpuTimer::GetResult(const void* object) { - assert(m_state == State::ResultUpdated || m_state == State::AfterFrame); - - if (m_state == State::AfterFrame) + for (uint32_t index = 1; index < 5; index++) { - UpdateResults(); + if (m_stageState[index] == State::AfterStage) + { + UpdateResults(static_cast(index)); + } } auto it = m_timeData.find(object); diff --git a/Dev/Cpp/EffekseerRendererGL/EffekseerRendererGL/EffekseerRendererGL.GpuTimer.h b/Dev/Cpp/EffekseerRendererGL/EffekseerRendererGL/EffekseerRendererGL.GpuTimer.h index 793da9ced3..5313cc40b6 100644 --- a/Dev/Cpp/EffekseerRendererGL/EffekseerRendererGL/EffekseerRendererGL.GpuTimer.h +++ b/Dev/Cpp/EffekseerRendererGL/EffekseerRendererGL/EffekseerRendererGL.GpuTimer.h @@ -27,19 +27,19 @@ class GpuTimer : public DeviceObject, public ::Effekseer::GpuTimer void InitDevice(); void ReleaseDevice(); - void UpdateResults(); + void UpdateResults(Effekseer::GpuStage stage); public: // For device restore virtual void OnLostDevice(); virtual void OnResetDevice(); public: // GpuTimer - virtual void BeginFrame() override; - virtual void EndFrame() override; + virtual void BeginStage(Effekseer::GpuStage stage) override; + virtual void EndStage(Effekseer::GpuStage stage) override; virtual void AddTimer(const void* object) override; virtual void RemoveTimer(const void* object) override; - virtual void Start(const void* object, uint32_t phase) override; - virtual void Stop(const void* object, uint32_t phase) override; + virtual void Start(const void* object) override; + virtual void Stop(const void* object) override; virtual int32_t GetResult(const void* object) override; private: @@ -47,19 +47,20 @@ class GpuTimer : public DeviceObject, public ::Effekseer::GpuTimer struct TimeData { - GLuint timeElapsedQuery[NUM_PHASES]; - bool queryRequested[NUM_PHASES] = {}; + GLuint timeElapsedQuery[NUM_PHASES] = {}; + Effekseer::GpuStage queryedStage[NUM_PHASES] = {}; int32_t result = 0; }; std::unordered_map m_timeData; - enum class State { + enum class State : uint8_t { NoResult, - DuringFrame, - AfterFrame, + DuringStage, + AfterStage, ResultUpdated, }; - State m_state = State::NoResult; + State m_stageState[8] = {}; + Effekseer::GpuStage m_currentStage = {}; }; //----------------------------------------------------------------------------------- diff --git a/Dev/Cpp/Viewer/3D/EffectRenderer.cpp b/Dev/Cpp/Viewer/3D/EffectRenderer.cpp index d41b02c022..2980f2b40c 100644 --- a/Dev/Cpp/Viewer/3D/EffectRenderer.cpp +++ b/Dev/Cpp/Viewer/3D/EffectRenderer.cpp @@ -625,9 +625,9 @@ void EffectRenderer::UpdatePaused() void EffectRenderer::Update() { /*{ - int32_t gpuTime = manager_->GetGPUTime(); + int32_t gpuTime = manager_->GetGpuTime(); char log[256]; - snprintf(log, sizeof(log), "GPUTime: %d\n", gpuTime); + snprintf(log, sizeof(log), "GpuTime: %d\n", gpuTime); OutputDebugStringA(log); }*/ @@ -1142,14 +1142,14 @@ void EffectRenderer::SetPostEffectParameter(const Effekseer::Tool::PostEffectPar postEffectParameter_ = param; } -int32_t EffectRenderer::GetCPUTime() +int32_t EffectRenderer::GetCpuTime() { return manager_->GetUpdateTime() + manager_->GetDrawTime(); } -int32_t EffectRenderer::GetGPUTime() +int32_t EffectRenderer::GetGpuTime() { - return manager_->GetGPUTime(); + return manager_->GetGpuTime(); } } // namespace Tool diff --git a/Dev/Cpp/Viewer/3D/EffectRenderer.h b/Dev/Cpp/Viewer/3D/EffectRenderer.h index 9249d621b6..6cca56c2be 100644 --- a/Dev/Cpp/Viewer/3D/EffectRenderer.h +++ b/Dev/Cpp/Viewer/3D/EffectRenderer.h @@ -274,9 +274,9 @@ class EffectRenderer return call; } - int32_t GetCPUTime(); + int32_t GetCpuTime(); - int32_t GetGPUTime(); + int32_t GetGpuTime(); int32_t RandomSeed = -1; EffectRendererCallback* Callback = nullptr; diff --git a/Dev/Cpp/Viewer/Network/Network.cpp b/Dev/Cpp/Viewer/Network/Network.cpp index fca81f9201..670b7121b9 100644 --- a/Dev/Cpp/Viewer/Network/Network.cpp +++ b/Dev/Cpp/Viewer/Network/Network.cpp @@ -53,8 +53,8 @@ ProfileSample NetworkClient::ReadProfileSample() for (auto& profileManager : profileSample.Managers) { ProfileSample::Manager resultManager; - resultManager.CPUTime = profileManager.CPUTime; - resultManager.GPUTime = profileManager.GPUTime; + resultManager.CpuTime = profileManager.CpuTime; + resultManager.GpuTime = profileManager.GpuTime; resultManager.HandleCount = profileManager.HandleCount; result.Managers.emplace_back(resultManager); } @@ -63,7 +63,7 @@ ProfileSample NetworkClient::ReadProfileSample() { ProfileSample::Effect resultEffect; resultEffect.Key = profileEffect.Key; - resultEffect.GPUTime = profileEffect.GPUTime; + resultEffect.GpuTime = profileEffect.GpuTime; resultEffect.HandleCount = profileEffect.HandleCount; result.Effects.emplace_back(resultEffect); } diff --git a/Dev/Cpp/Viewer/Network/ProfileSample.h b/Dev/Cpp/Viewer/Network/ProfileSample.h index e7e7ec3c68..4e66991fe9 100644 --- a/Dev/Cpp/Viewer/Network/ProfileSample.h +++ b/Dev/Cpp/Viewer/Network/ProfileSample.h @@ -12,8 +12,8 @@ struct ProfileSample struct Manager { uint32_t HandleCount = 0; - float CPUTime = 0.0f; - float GPUTime = 0.0f; + float CpuTime = 0.0f; + float GpuTime = 0.0f; }; std::vector Managers; @@ -21,7 +21,7 @@ struct ProfileSample { std::u16string Key; uint32_t HandleCount = 0; - float GPUTime = 0.0f; + float GpuTime = 0.0f; }; std::vector Effects; }; diff --git a/Dev/Cpp/Viewer/dll_cs.cxx b/Dev/Cpp/Viewer/dll_cs.cxx index bd705b89b0..219eeac2af 100644 --- a/Dev/Cpp/Viewer/dll_cs.cxx +++ b/Dev/Cpp/Viewer/dll_cs.cxx @@ -5156,25 +5156,25 @@ SWIGEXPORT int SWIGSTDCALL CSharp_Effekseerfswig_EffectRenderer_GetAndResetVerte } -SWIGEXPORT int SWIGSTDCALL CSharp_Effekseerfswig_EffectRenderer_GetCPUTime___(void * jarg1) { +SWIGEXPORT int SWIGSTDCALL CSharp_Effekseerfswig_EffectRenderer_GetCpuTime___(void * jarg1) { int jresult ; Effekseer::Tool::EffectRenderer *arg1 = (Effekseer::Tool::EffectRenderer *) 0 ; int32_t result; arg1 = (Effekseer::Tool::EffectRenderer *)jarg1; - result = (int32_t)(arg1)->GetCPUTime(); + result = (int32_t)(arg1)->GetCpuTime(); jresult = result; return jresult; } -SWIGEXPORT int SWIGSTDCALL CSharp_Effekseerfswig_EffectRenderer_GetGPUTime___(void * jarg1) { +SWIGEXPORT int SWIGSTDCALL CSharp_Effekseerfswig_EffectRenderer_GetGpuTime___(void * jarg1) { int jresult ; Effekseer::Tool::EffectRenderer *arg1 = (Effekseer::Tool::EffectRenderer *) 0 ; int32_t result; arg1 = (Effekseer::Tool::EffectRenderer *)jarg1; - result = (int32_t)(arg1)->GetGPUTime(); + result = (int32_t)(arg1)->GetGpuTime(); jresult = result; return jresult; } @@ -5462,45 +5462,45 @@ SWIGEXPORT unsigned int SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Manager_ } -SWIGEXPORT void SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Manager_CPUTime_set___(void * jarg1, float jarg2) { +SWIGEXPORT void SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Manager_CpuTime_set___(void * jarg1, float jarg2) { Effekseer::Tool::ProfileSample::Manager *arg1 = (Effekseer::Tool::ProfileSample::Manager *) 0 ; float arg2 ; arg1 = (Effekseer::Tool::ProfileSample::Manager *)jarg1; arg2 = (float)jarg2; - if (arg1) (arg1)->CPUTime = arg2; + if (arg1) (arg1)->CpuTime = arg2; } -SWIGEXPORT float SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Manager_CPUTime_get___(void * jarg1) { +SWIGEXPORT float SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Manager_CpuTime_get___(void * jarg1) { float jresult ; Effekseer::Tool::ProfileSample::Manager *arg1 = (Effekseer::Tool::ProfileSample::Manager *) 0 ; float result; arg1 = (Effekseer::Tool::ProfileSample::Manager *)jarg1; - result = (float) ((arg1)->CPUTime); + result = (float) ((arg1)->CpuTime); jresult = result; return jresult; } -SWIGEXPORT void SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Manager_GPUTime_set___(void * jarg1, float jarg2) { +SWIGEXPORT void SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Manager_GpuTime_set___(void * jarg1, float jarg2) { Effekseer::Tool::ProfileSample::Manager *arg1 = (Effekseer::Tool::ProfileSample::Manager *) 0 ; float arg2 ; arg1 = (Effekseer::Tool::ProfileSample::Manager *)jarg1; arg2 = (float)jarg2; - if (arg1) (arg1)->GPUTime = arg2; + if (arg1) (arg1)->GpuTime = arg2; } -SWIGEXPORT float SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Manager_GPUTime_get___(void * jarg1) { +SWIGEXPORT float SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Manager_GpuTime_get___(void * jarg1) { float jresult ; Effekseer::Tool::ProfileSample::Manager *arg1 = (Effekseer::Tool::ProfileSample::Manager *) 0 ; float result; arg1 = (Effekseer::Tool::ProfileSample::Manager *)jarg1; - result = (float) ((arg1)->GPUTime); + result = (float) ((arg1)->GpuTime); jresult = result; return jresult; } @@ -5595,23 +5595,23 @@ SWIGEXPORT unsigned int SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Effect_H } -SWIGEXPORT void SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Effect_GPUTime_set___(void * jarg1, float jarg2) { +SWIGEXPORT void SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Effect_GpuTime_set___(void * jarg1, float jarg2) { Effekseer::Tool::ProfileSample::Effect *arg1 = (Effekseer::Tool::ProfileSample::Effect *) 0 ; float arg2 ; arg1 = (Effekseer::Tool::ProfileSample::Effect *)jarg1; arg2 = (float)jarg2; - if (arg1) (arg1)->GPUTime = arg2; + if (arg1) (arg1)->GpuTime = arg2; } -SWIGEXPORT float SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Effect_GPUTime_get___(void * jarg1) { +SWIGEXPORT float SWIGSTDCALL CSharp_Effekseerfswig_ProfileSample_Effect_GpuTime_get___(void * jarg1) { float jresult ; Effekseer::Tool::ProfileSample::Effect *arg1 = (Effekseer::Tool::ProfileSample::Effect *) 0 ; float result; arg1 = (Effekseer::Tool::ProfileSample::Effect *)jarg1; - result = (float) ((arg1)->GPUTime); + result = (float) ((arg1)->GpuTime); jresult = result; return jresult; } diff --git a/Dev/Editor/Effekseer/GUI/Dock/Profiler.cs b/Dev/Editor/Effekseer/GUI/Dock/Profiler.cs index a59aff0b0e..4935048904 100644 --- a/Dev/Editor/Effekseer/GUI/Dock/Profiler.cs +++ b/Dev/Editor/Effekseer/GUI/Dock/Profiler.cs @@ -114,8 +114,8 @@ public void Reset() public void Update(swig.GUIManager gui, ref Texts texts) { - CpuChart.Push(Manager.Viewer.EffectRenderer.GetCPUTime()); - GpuChart.Push(Manager.Viewer.EffectRenderer.GetGPUTime()); + CpuChart.Push(Manager.Viewer.EffectRenderer.GetCpuTime()); + GpuChart.Push(Manager.Viewer.EffectRenderer.GetGpuTime()); if (gui.Button(texts.ProfilerReset)) { @@ -173,8 +173,8 @@ public void Update(swig.GUIManager gui, ref Texts texts) public void PushData(swig.ProfileSample.Manager data) { HandleCountChart.Push(data.HandleCount); - CpuTimeChart.Push(data.CPUTime); - GpuTimeChart.Push(data.GPUTime); + CpuTimeChart.Push(data.CpuTime); + GpuTimeChart.Push(data.GpuTime); } } @@ -214,7 +214,7 @@ public void Update(swig.GUIManager gui, ref Texts texts) public void PushData(swig.ProfileSample.Effect data) { HandleCountChart.Push(data.HandleCount); - GpuTimeChart.Push(data.GPUTime); + GpuTimeChart.Push(data.GpuTime); } } diff --git a/Dev/Editor/EffekseerCoreGUI/swig/EffectRenderer.cs b/Dev/Editor/EffekseerCoreGUI/swig/EffectRenderer.cs index 6eba475ae3..c320e773f9 100644 --- a/Dev/Editor/EffekseerCoreGUI/swig/EffectRenderer.cs +++ b/Dev/Editor/EffekseerCoreGUI/swig/EffectRenderer.cs @@ -164,13 +164,13 @@ public int GetAndResetVertexCount() { return ret; } - public int GetCPUTime() { - int ret = EffekseerNativePINVOKE.EffectRenderer_GetCPUTime(swigCPtr); + public int GetCpuTime() { + int ret = EffekseerNativePINVOKE.EffectRenderer_GetCpuTime(swigCPtr); return ret; } - public int GetGPUTime() { - int ret = EffekseerNativePINVOKE.EffectRenderer_GetGPUTime(swigCPtr); + public int GetGpuTime() { + int ret = EffekseerNativePINVOKE.EffectRenderer_GetGpuTime(swigCPtr); return ret; } diff --git a/Dev/Editor/EffekseerCoreGUI/swig/EffekseerNativePINVOKE.cs b/Dev/Editor/EffekseerCoreGUI/swig/EffekseerNativePINVOKE.cs index 21d67d58aa..bdc655063f 100644 --- a/Dev/Editor/EffekseerCoreGUI/swig/EffekseerNativePINVOKE.cs +++ b/Dev/Editor/EffekseerCoreGUI/swig/EffekseerNativePINVOKE.cs @@ -1284,11 +1284,11 @@ static SWIGWStringHelper() { [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_EffectRenderer_GetAndResetVertexCount___")] public static extern int EffectRenderer_GetAndResetVertexCount(global::System.Runtime.InteropServices.HandleRef jarg1); - [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_EffectRenderer_GetCPUTime___")] - public static extern int EffectRenderer_GetCPUTime(global::System.Runtime.InteropServices.HandleRef jarg1); + [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_EffectRenderer_GetCpuTime___")] + public static extern int EffectRenderer_GetCpuTime(global::System.Runtime.InteropServices.HandleRef jarg1); - [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_EffectRenderer_GetGPUTime___")] - public static extern int EffectRenderer_GetGPUTime(global::System.Runtime.InteropServices.HandleRef jarg1); + [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_EffectRenderer_GetGpuTime___")] + public static extern int EffectRenderer_GetGpuTime(global::System.Runtime.InteropServices.HandleRef jarg1); [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_EffectRenderer_RandomSeed_set___")] public static extern void EffectRenderer_RandomSeed_set(global::System.Runtime.InteropServices.HandleRef jarg1, int jarg2); @@ -1362,17 +1362,17 @@ static SWIGWStringHelper() { [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Manager_HandleCount_get___")] public static extern uint ProfileSample_Manager_HandleCount_get(global::System.Runtime.InteropServices.HandleRef jarg1); - [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Manager_CPUTime_set___")] - public static extern void ProfileSample_Manager_CPUTime_set(global::System.Runtime.InteropServices.HandleRef jarg1, float jarg2); + [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Manager_CpuTime_set___")] + public static extern void ProfileSample_Manager_CpuTime_set(global::System.Runtime.InteropServices.HandleRef jarg1, float jarg2); - [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Manager_CPUTime_get___")] - public static extern float ProfileSample_Manager_CPUTime_get(global::System.Runtime.InteropServices.HandleRef jarg1); + [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Manager_CpuTime_get___")] + public static extern float ProfileSample_Manager_CpuTime_get(global::System.Runtime.InteropServices.HandleRef jarg1); - [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Manager_GPUTime_set___")] - public static extern void ProfileSample_Manager_GPUTime_set(global::System.Runtime.InteropServices.HandleRef jarg1, float jarg2); + [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Manager_GpuTime_set___")] + public static extern void ProfileSample_Manager_GpuTime_set(global::System.Runtime.InteropServices.HandleRef jarg1, float jarg2); - [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Manager_GPUTime_get___")] - public static extern float ProfileSample_Manager_GPUTime_get(global::System.Runtime.InteropServices.HandleRef jarg1); + [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Manager_GpuTime_get___")] + public static extern float ProfileSample_Manager_GpuTime_get(global::System.Runtime.InteropServices.HandleRef jarg1); [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_new_ProfileSample_Manager___")] public static extern global::System.IntPtr new_ProfileSample_Manager(); @@ -1399,11 +1399,11 @@ static SWIGWStringHelper() { [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Effect_HandleCount_get___")] public static extern uint ProfileSample_Effect_HandleCount_get(global::System.Runtime.InteropServices.HandleRef jarg1); - [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Effect_GPUTime_set___")] - public static extern void ProfileSample_Effect_GPUTime_set(global::System.Runtime.InteropServices.HandleRef jarg1, float jarg2); + [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Effect_GpuTime_set___")] + public static extern void ProfileSample_Effect_GpuTime_set(global::System.Runtime.InteropServices.HandleRef jarg1, float jarg2); - [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Effect_GPUTime_get___")] - public static extern float ProfileSample_Effect_GPUTime_get(global::System.Runtime.InteropServices.HandleRef jarg1); + [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_ProfileSample_Effect_GpuTime_get___")] + public static extern float ProfileSample_Effect_GpuTime_get(global::System.Runtime.InteropServices.HandleRef jarg1); [global::System.Runtime.InteropServices.DllImport("Viewer", EntryPoint="CSharp_Effekseerfswig_new_ProfileSample_Effect___")] public static extern global::System.IntPtr new_ProfileSample_Effect(); diff --git a/Dev/Editor/EffekseerCoreGUI/swig/ProfileSample.cs b/Dev/Editor/EffekseerCoreGUI/swig/ProfileSample.cs index 5e1e818f13..b7d477cea6 100644 --- a/Dev/Editor/EffekseerCoreGUI/swig/ProfileSample.cs +++ b/Dev/Editor/EffekseerCoreGUI/swig/ProfileSample.cs @@ -98,22 +98,22 @@ public uint HandleCount { } } - public float CPUTime { + public float CpuTime { set { - EffekseerNativePINVOKE.ProfileSample_Manager_CPUTime_set(swigCPtr, value); + EffekseerNativePINVOKE.ProfileSample_Manager_CpuTime_set(swigCPtr, value); } get { - float ret = EffekseerNativePINVOKE.ProfileSample_Manager_CPUTime_get(swigCPtr); + float ret = EffekseerNativePINVOKE.ProfileSample_Manager_CpuTime_get(swigCPtr); return ret; } } - public float GPUTime { + public float GpuTime { set { - EffekseerNativePINVOKE.ProfileSample_Manager_GPUTime_set(swigCPtr, value); + EffekseerNativePINVOKE.ProfileSample_Manager_GpuTime_set(swigCPtr, value); } get { - float ret = EffekseerNativePINVOKE.ProfileSample_Manager_GPUTime_get(swigCPtr); + float ret = EffekseerNativePINVOKE.ProfileSample_Manager_GpuTime_get(swigCPtr); return ret; } } @@ -190,12 +190,12 @@ public uint HandleCount { } } - public float GPUTime { + public float GpuTime { set { - EffekseerNativePINVOKE.ProfileSample_Effect_GPUTime_set(swigCPtr, value); + EffekseerNativePINVOKE.ProfileSample_Effect_GpuTime_set(swigCPtr, value); } get { - float ret = EffekseerNativePINVOKE.ProfileSample_Effect_GPUTime_get(swigCPtr); + float ret = EffekseerNativePINVOKE.ProfileSample_Effect_GpuTime_get(swigCPtr); return ret; } } diff --git a/Dev/release/resources/languages/ja/Effekseer_Profiler.csv b/Dev/release/resources/languages/ja/Effekseer_Profiler.csv index 28498c0b24..9387d5816c 100644 --- a/Dev/release/resources/languages/ja/Effekseer_Profiler.csv +++ b/Dev/release/resources/languages/ja/Effekseer_Profiler.csv @@ -2,6 +2,6 @@ Profiler,プロファイラ Profiler_Start,プロファイル開始 Profiler_Stop,プロファイル停止 Profiler_Reset,記録クリア -Profiler_CpuUsage,CPU使用率 -Profiler_GpuUsage,GPU使用率 +Profiler_CpuUsage,CPU使用時間 +Profiler_GpuUsage,GPU使用時間 Profiler_Handles,エフェクト数