mirror of
				https://github.com/AxioDL/metaforce.git
				synced 2025-10-25 12:50:24 +00:00 
			
		
		
		
	Merge pull request #388 from henriquegemignani/feature/optick
Using optick, linked from boo
This commit is contained in:
		
						commit
						f795332d89
					
				| @ -73,6 +73,7 @@ bool ProjectManager::newProject(hecl::SystemStringView path) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool ProjectManager::openProject(hecl::SystemStringView path) { | bool ProjectManager::openProject(hecl::SystemStringView path) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   hecl::SystemString subPath; |   hecl::SystemString subPath; | ||||||
|   hecl::ProjectRootPath projPath = hecl::SearchForProject(path, subPath); |   hecl::ProjectRootPath projPath = hecl::SearchForProject(path, subPath); | ||||||
|   if (!projPath) { |   if (!projPath) { | ||||||
| @ -166,6 +167,7 @@ bool ProjectManager::saveProject() { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ProjectManager::mainUpdate() { | void ProjectManager::mainUpdate() { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (m_precooking) { |   if (m_precooking) { | ||||||
|     if (!m_factoryMP1.IsBusy()) |     if (!m_factoryMP1.IsBusy()) | ||||||
|       m_precooking = false; |       m_precooking = false; | ||||||
|  | |||||||
| @ -172,6 +172,7 @@ public: | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   void think() override { |   void think() override { | ||||||
|  |     OPTICK_EVENT(); | ||||||
|     if (m_spaceTree) |     if (m_spaceTree) | ||||||
|       m_spaceTree->think(); |       m_spaceTree->think(); | ||||||
|   } |   } | ||||||
|  | |||||||
| @ -50,6 +50,7 @@ void SplashScreen::think() { | |||||||
|       m_fileBrowser.m_view.reset(); |       m_fileBrowser.m_view.reset(); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|  |   OPTICK_EVENT(); | ||||||
| 
 | 
 | ||||||
|   ModalWindow::think(); |   ModalWindow::think(); | ||||||
|   if (m_fileBrowser.m_view) |   if (m_fileBrowser.m_view) | ||||||
|  | |||||||
| @ -18,6 +18,7 @@ | |||||||
| #include "hecl/Pipeline.hpp" | #include "hecl/Pipeline.hpp" | ||||||
| #include "version.h" | #include "version.h" | ||||||
| #include <cstdio> | #include <cstdio> | ||||||
|  | #include "optick.h" | ||||||
| 
 | 
 | ||||||
| using YAMLNode = athena::io::YAMLNode; | using YAMLNode = athena::io::YAMLNode; | ||||||
| 
 | 
 | ||||||
| @ -54,6 +55,7 @@ void ViewManager::TestGameView::draw(boo::IGraphicsCommandQueue* gfxQ) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ViewManager::TestGameView::think() { | void ViewManager::TestGameView::think() { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (!m_debugText) { |   if (!m_debugText) { | ||||||
|     m_debugText.reset(new specter::MultiLineTextView(m_vm.m_viewResources, *this, m_vm.m_viewResources.m_monoFont18)); |     m_debugText.reset(new specter::MultiLineTextView(m_vm.m_viewResources, *this, m_vm.m_viewResources.m_monoFont18)); | ||||||
|     boo::SWindowRect sub = subRect(); |     boo::SWindowRect sub = subRect(); | ||||||
| @ -356,6 +358,7 @@ bool ViewManager::proc() { | |||||||
|     return false; |     return false; | ||||||
| 
 | 
 | ||||||
|   if (m_updatePf) { |   if (m_updatePf) { | ||||||
|  |     OPTICK_EVENT("m_updatePf"); | ||||||
|     m_viewResources.resetPixelFactor(m_reqPf); |     m_viewResources.resetPixelFactor(m_reqPf); | ||||||
|     specter::RootView* root = SetupRootView(); |     specter::RootView* root = SetupRootView(); | ||||||
|     if (m_rootSpace) |     if (m_rootSpace) | ||||||
| @ -368,8 +371,14 @@ bool ViewManager::proc() { | |||||||
|     m_updatePf = false; |     m_updatePf = false; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  |   { | ||||||
|  |     OPTICK_EVENT("m_rootView->DispatchEvents"); | ||||||
|     m_rootView->dispatchEvents(); |     m_rootView->dispatchEvents(); | ||||||
|  |   } | ||||||
|  |   { | ||||||
|  |     OPTICK_EVENT("m_rootView->internalThink"); | ||||||
|     m_rootView->internalThink(); |     m_rootView->internalThink(); | ||||||
|  |   } | ||||||
|   if (m_rootSpace) |   if (m_rootSpace) | ||||||
|     m_rootSpace->think(); |     m_rootSpace->think(); | ||||||
|   if (m_splash) |   if (m_splash) | ||||||
| @ -391,19 +400,24 @@ bool ViewManager::proc() { | |||||||
|   if (m_testGameView) |   if (m_testGameView) | ||||||
|     m_testGameView->think(); |     m_testGameView->think(); | ||||||
| 
 | 
 | ||||||
|  |   { | ||||||
|  |     OPTICK_EVENT("Draw"); | ||||||
|     if (g_Renderer) |     if (g_Renderer) | ||||||
|       g_Renderer->BeginScene(); |       g_Renderer->BeginScene(); | ||||||
|     m_rootView->draw(gfxQ); |     m_rootView->draw(gfxQ); | ||||||
|     if (g_Renderer) |     if (g_Renderer) | ||||||
|       g_Renderer->EndScene(); |       g_Renderer->EndScene(); | ||||||
|     gfxQ->execute(); |     gfxQ->execute(); | ||||||
|  |   } | ||||||
|   if (g_ResFactory) |   if (g_ResFactory) | ||||||
|     g_ResFactory->AsyncIdle(); |     g_ResFactory->AsyncIdle(); | ||||||
| #ifndef URDE_MSAN | #ifndef URDE_MSAN | ||||||
|   m_voiceEngine->pumpAndMixVoices(); |   m_voiceEngine->pumpAndMixVoices(); | ||||||
| #endif | #endif | ||||||
|   if (!m_skipWait || !hecl::com_developer->toBoolean()) |   if (!m_skipWait || !hecl::com_developer->toBoolean()) { | ||||||
|  |     OPTICK_EVENT("waitForRetrace"); | ||||||
|     m_mainWindow->waitForRetrace(); |     m_mainWindow->waitForRetrace(); | ||||||
|  |   } | ||||||
|   CBooModel::ClearModelUniformCounters(); |   CBooModel::ClearModelUniformCounters(); | ||||||
|   CGraphics::TickRenderTimings(); |   CGraphics::TickRenderTimings(); | ||||||
|   ++logvisor::FrameIndex; |   ++logvisor::FrameIndex; | ||||||
|  | |||||||
| @ -9,6 +9,7 @@ | |||||||
| #include "hecl/Console.hpp" | #include "hecl/Console.hpp" | ||||||
| #include "fmt/chrono.h" | #include "fmt/chrono.h" | ||||||
| #include "version.h" | #include "version.h" | ||||||
|  | #include "optick.h" | ||||||
| 
 | 
 | ||||||
| static logvisor::Module AthenaLog("Athena"); | static logvisor::Module AthenaLog("Athena"); | ||||||
| static void AthenaExc(athena::error::Level level, const char* file, const char*, int line, fmt::string_view fmt, | static void AthenaExc(athena::error::Level level, const char* file, const char*, int line, fmt::string_view fmt, | ||||||
| @ -71,6 +72,7 @@ struct Application : boo::IApplicationCallback { | |||||||
|     initialize(app); |     initialize(app); | ||||||
|     m_viewManager->init(app); |     m_viewManager->init(app); | ||||||
|     while (m_running.load()) { |     while (m_running.load()) { | ||||||
|  |       OPTICK_FRAME("MainThread"); | ||||||
|       if (!m_viewManager->proc()) |       if (!m_viewManager->proc()) | ||||||
|         break; |         break; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -78,6 +78,7 @@ CMapArea::CMapArea(CInputStream& in, u32 size) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CMapArea::PostConstruct() { | void CMapArea::PostConstruct() { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   x38_moStart = x44_buf.get(); |   x38_moStart = x44_buf.get(); | ||||||
|   x3c_vertexStart = x38_moStart + (x28_mappableObjCount * 0x50); |   x3c_vertexStart = x38_moStart + (x28_mappableObjCount * 0x50); | ||||||
|   x40_surfaceStart = x3c_vertexStart + (x2c_vertexCount * 12); |   x40_surfaceStart = x3c_vertexStart + (x2c_vertexCount * 12); | ||||||
|  | |||||||
| @ -4,6 +4,7 @@ | |||||||
| #include <array> | #include <array> | ||||||
| #include <cctype> | #include <cctype> | ||||||
| #include <iterator> | #include <iterator> | ||||||
|  | #include "optick.h" | ||||||
| 
 | 
 | ||||||
| #include "Runtime/CStopwatch.hpp" | #include "Runtime/CStopwatch.hpp" | ||||||
| #include "Runtime/IObj.hpp" | #include "Runtime/IObj.hpp" | ||||||
| @ -35,6 +36,7 @@ bool CFactoryMgr::CanMakeMemory(const metaforce::SObjectTag& tag) const { | |||||||
| CFactoryFnReturn CFactoryMgr::MakeObjectFromMemory(const SObjectTag& tag, std::unique_ptr<u8[]>&& buf, int size, | CFactoryFnReturn CFactoryMgr::MakeObjectFromMemory(const SObjectTag& tag, std::unique_ptr<u8[]>&& buf, int size, | ||||||
|                                                    bool compressed, const CVParamTransfer& paramXfer, |                                                    bool compressed, const CVParamTransfer& paramXfer, | ||||||
|                                                    CObjectReference* selfRef) { |                                                    CObjectReference* selfRef) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   std::unique_ptr<u8[]> localBuf = std::move(buf); |   std::unique_ptr<u8[]> localBuf = std::move(buf); | ||||||
| 
 | 
 | ||||||
|   const auto memFactoryIter = m_memFactories.find(tag.type); |   const auto memFactoryIter = m_memFactories.find(tag.type); | ||||||
|  | |||||||
| @ -133,7 +133,7 @@ endfunction() | |||||||
| 
 | 
 | ||||||
| set(RUNTIME_INCLUDES ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR}) | set(RUNTIME_INCLUDES ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR}) | ||||||
| set(RUNTIME_LIBRARIES ${HECL_APPLICATION_REPS_TARGETS_LIST} RetroDataSpec AssetNameMapNull NESEmulator | set(RUNTIME_LIBRARIES ${HECL_APPLICATION_REPS_TARGETS_LIST} RetroDataSpec AssetNameMapNull NESEmulator | ||||||
|         libjpeg-turbo jbus kabufuda discord-rpc logvisor) |         libjpeg-turbo jbus kabufuda discord-rpc logvisor OptickCore) | ||||||
| 
 | 
 | ||||||
| if(MSVC) | if(MSVC) | ||||||
|   # WTF MS???? LINK.EXE is unable to address static libraries larger than 4GB. |   # WTF MS???? LINK.EXE is unable to address static libraries larger than 4GB. | ||||||
|  | |||||||
| @ -2,6 +2,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "Runtime/CSimplePool.hpp" | #include "Runtime/CSimplePool.hpp" | ||||||
| #include "Runtime/CStopwatch.hpp" | #include "Runtime/CStopwatch.hpp" | ||||||
|  | #include "optick.h" | ||||||
| 
 | 
 | ||||||
| namespace metaforce { | namespace metaforce { | ||||||
| static logvisor::Module Log("CResFactory"); | static logvisor::Module Log("CResFactory"); | ||||||
| @ -33,6 +34,7 @@ CFactoryFnReturn CResFactory::BuildSync(const SObjectTag& tag, const CVParamTran | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool CResFactory::PumpResource(SLoadingData& data) { | bool CResFactory::PumpResource(SLoadingData& data) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (data.x8_dvdReq && data.x8_dvdReq->IsComplete()) { |   if (data.x8_dvdReq && data.x8_dvdReq->IsComplete()) { | ||||||
|     data.x8_dvdReq.reset(); |     data.x8_dvdReq.reset(); | ||||||
|     *data.xc_targetPtr = |     *data.xc_targetPtr = | ||||||
| @ -74,6 +76,7 @@ void CResFactory::BuildAsync(const SObjectTag& tag, const CVParamTransfer& xfer, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CResFactory::AsyncIdle() { | void CResFactory::AsyncIdle() { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (m_loadList.empty()) |   if (m_loadList.empty()) | ||||||
|     return; |     return; | ||||||
|   auto startTime = std::chrono::steady_clock::now(); |   auto startTime = std::chrono::steady_clock::now(); | ||||||
|  | |||||||
| @ -780,6 +780,7 @@ void CStateManager::DrawWorld() { | |||||||
|   g_Renderer->SetThermalColdScale(xf28_thermColdScale2 + xf24_thermColdScale1); |   g_Renderer->SetThermalColdScale(xf28_thermColdScale2 + xf24_thermColdScale1); | ||||||
| 
 | 
 | ||||||
|   for (int i = areaCount - 1; i >= 0; --i) { |   for (int i = areaCount - 1; i >= 0; --i) { | ||||||
|  |     OPTICK_EVENT("CStateManager::DrawWorld DrawArea"); | ||||||
|     const CGameArea& area = *areaArr[i]; |     const CGameArea& area = *areaArr[i]; | ||||||
|     SetupFogForArea(area); |     SetupFogForArea(area); | ||||||
|     g_Renderer->EnablePVS(pvsArr[i], area.x4_selfIdx); |     g_Renderer->EnablePVS(pvsArr[i], area.x4_selfIdx); | ||||||
| @ -1472,6 +1473,7 @@ void CStateManager::LoadScriptObjects(TAreaId aid, CInputStream& in, std::vector | |||||||
| 
 | 
 | ||||||
| std::pair<TEditorId, TUniqueId> CStateManager::LoadScriptObject(TAreaId aid, EScriptObjectType type, u32 length, | std::pair<TEditorId, TUniqueId> CStateManager::LoadScriptObject(TAreaId aid, EScriptObjectType type, u32 length, | ||||||
|                                                                 CInputStream& in) { |                                                                 CInputStream& in) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   const TEditorId id = in.readUint32Big(); |   const TEditorId id = in.readUint32Big(); | ||||||
|   const u32 connCount = in.readUint32Big(); |   const u32 connCount = in.readUint32Big(); | ||||||
|   length -= 8; |   length -= 8; | ||||||
|  | |||||||
| @ -553,6 +553,7 @@ void CAnimData::Render(CSkinnedModel& model, const CModelFlags& drawFlags, | |||||||
| 
 | 
 | ||||||
| void CAnimData::SetupRender(CSkinnedModel& model, const CModelFlags& drawFlags, | void CAnimData::SetupRender(CSkinnedModel& model, const CModelFlags& drawFlags, | ||||||
|                             const std::optional<CVertexMorphEffect>& morphEffect, const float* morphMagnitudes) { |                             const std::optional<CVertexMorphEffect>& morphEffect, const float* morphMagnitudes) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (!x220_30_poseBuilt) { |   if (!x220_30_poseBuilt) { | ||||||
|     x2fc_poseBuilder.BuildNoScale(x224_pose); |     x2fc_poseBuilder.BuildNoScale(x224_pose); | ||||||
|     x220_30_poseBuilt = true; |     x220_30_poseBuilt = true; | ||||||
| @ -560,7 +561,9 @@ void CAnimData::SetupRender(CSkinnedModel& model, const CModelFlags& drawFlags, | |||||||
|   PoseSkinnedModel(model, x224_pose, drawFlags, morphEffect, morphMagnitudes); |   PoseSkinnedModel(model, x224_pose, drawFlags, morphEffect, morphMagnitudes); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CAnimData::DrawSkinnedModel(CSkinnedModel& model, const CModelFlags& flags) { model.Draw(flags); } | void CAnimData::DrawSkinnedModel(CSkinnedModel& model, const CModelFlags& flags) { | ||||||
|  |   model.Draw(flags); | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| void CAnimData::PreRender() { | void CAnimData::PreRender() { | ||||||
|   if (!x220_31_poseCached) { |   if (!x220_31_poseCached) { | ||||||
|  | |||||||
| @ -25,6 +25,7 @@ CSkinRules::CSkinRules(CInputStream& in) { | |||||||
| 
 | 
 | ||||||
| void CSkinRules::TransformVerticesCPU(std::vector<std::pair<zeus::CVector3f, zeus::CVector3f>>& vnOut, | void CSkinRules::TransformVerticesCPU(std::vector<std::pair<zeus::CVector3f, zeus::CVector3f>>& vnOut, | ||||||
|                                       const CPoseAsTransforms& pose, const CModel& model) const { |                                       const CPoseAsTransforms& pose, const CModel& model) const { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   vnOut.resize(m_poolToSkinIdx.size()); |   vnOut.resize(m_poolToSkinIdx.size()); | ||||||
|   for (size_t i = 0; i < m_poolToSkinIdx.size(); ++i) { |   for (size_t i = 0; i < m_poolToSkinIdx.size(); ++i) { | ||||||
|     const CVirtualBone& vb = m_virtualBones[m_poolToSkinIdx[i]]; |     const CVirtualBone& vb = m_virtualBones[m_poolToSkinIdx[i]]; | ||||||
|  | |||||||
| @ -223,6 +223,7 @@ CBooRenderer::CAreaListItem::CAreaListItem(const std::vector<CMetroidModelInstan | |||||||
| CBooRenderer::CAreaListItem::~CAreaListItem() = default; | CBooRenderer::CAreaListItem::~CAreaListItem() = default; | ||||||
| 
 | 
 | ||||||
| void CBooRenderer::ActivateLightsForModel(CAreaListItem* item, CBooModel& model) { | void CBooRenderer::ActivateLightsForModel(CAreaListItem* item, CBooModel& model) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   constexpr size_t lightCount = 4; |   constexpr size_t lightCount = 4; | ||||||
|   std::vector<CLight> thisLights; |   std::vector<CLight> thisLights; | ||||||
|   thisLights.reserve(lightCount); |   thisLights.reserve(lightCount); | ||||||
| @ -767,6 +768,7 @@ void CBooRenderer::DisablePVS() { xc8_pvs = std::nullopt; } | |||||||
| 
 | 
 | ||||||
| void CBooRenderer::UpdateAreaUniforms(int areaIdx, EWorldShadowMode shadowMode, bool activateLights, int cubeFace, | void CBooRenderer::UpdateAreaUniforms(int areaIdx, EWorldShadowMode shadowMode, bool activateLights, int cubeFace, | ||||||
|                                       const CModelFlags* ballShadowFlags) { |                                       const CModelFlags* ballShadowFlags) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   SetupRendererStates(); |   SetupRendererStates(); | ||||||
| 
 | 
 | ||||||
|   CModelFlags flags; |   CModelFlags flags; | ||||||
| @ -1067,6 +1069,7 @@ void CBooRenderer::SetViewport(int left, int bottom, int width, int height) { | |||||||
| void CBooRenderer::SetDebugOption(EDebugOption, int) {} | void CBooRenderer::SetDebugOption(EDebugOption, int) {} | ||||||
| 
 | 
 | ||||||
| void CBooRenderer::BeginScene() { | void CBooRenderer::BeginScene() { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   CGraphics::SetViewport(0, 0, g_Viewport.x8_width, g_Viewport.xc_height); |   CGraphics::SetViewport(0, 0, g_Viewport.x8_width, g_Viewport.xc_height); | ||||||
|   CGraphics::SetPerspective(75.f, CGraphics::g_ProjAspect, 1.f, 4096.f); |   CGraphics::SetPerspective(75.f, CGraphics::g_ProjAspect, 1.f, 4096.f); | ||||||
|   CGraphics::SetModelMatrix(zeus::CTransform()); |   CGraphics::SetModelMatrix(zeus::CTransform()); | ||||||
| @ -1088,6 +1091,7 @@ void CBooRenderer::BeginScene() { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CBooRenderer::EndScene() { | void CBooRenderer::EndScene() { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   CGraphics::EndScene(); |   CGraphics::EndScene(); | ||||||
|   if (x2dc_reflectionAge >= 2) { |   if (x2dc_reflectionAge >= 2) { | ||||||
|     // Delete reflection tex x14c_
 |     // Delete reflection tex x14c_
 | ||||||
|  | |||||||
| @ -445,6 +445,7 @@ float CGraphics::GetSecondsMod900() { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CGraphics::TickRenderTimings() { | void CGraphics::TickRenderTimings() { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   g_RenderTimings = (g_RenderTimings + 1) % u32(900 * 60); |   g_RenderTimings = (g_RenderTimings + 1) % u32(900 * 60); | ||||||
|   g_DefaultSeconds = g_RenderTimings / 60.f; |   g_DefaultSeconds = g_RenderTimings / 60.f; | ||||||
| } | } | ||||||
|  | |||||||
| @ -3,6 +3,7 @@ | |||||||
| #include <array> | #include <array> | ||||||
| #include <vector> | #include <vector> | ||||||
| #include <chrono> | #include <chrono> | ||||||
|  | #include "optick.h" | ||||||
| 
 | 
 | ||||||
| #include "Runtime/RetroTypes.hpp" | #include "Runtime/RetroTypes.hpp" | ||||||
| 
 | 
 | ||||||
| @ -438,7 +439,7 @@ public: | |||||||
| }; | }; | ||||||
| #define SCOPED_GRAPHICS_DEBUG_GROUP(...) GraphicsDebugGroup _GfxDbg_(__VA_ARGS__); | #define SCOPED_GRAPHICS_DEBUG_GROUP(...) GraphicsDebugGroup _GfxDbg_(__VA_ARGS__); | ||||||
| #else | #else | ||||||
| #define SCOPED_GRAPHICS_DEBUG_GROUP(...) | #define SCOPED_GRAPHICS_DEBUG_GROUP(name, ...) OPTICK_EVENT_DYNAMIC(name) | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| } // namespace metaforce
 | } // namespace metaforce
 | ||||||
|  | |||||||
| @ -23,6 +23,7 @@ hecl::UniformBufferPool<CLineRenderer::SDrawUniform> CLineRenderer::s_uniformPoo | |||||||
| CLineRenderer::CLineRenderer(boo::IGraphicsDataFactory::Context& ctx, EPrimitiveMode mode, u32 maxVerts, | CLineRenderer::CLineRenderer(boo::IGraphicsDataFactory::Context& ctx, EPrimitiveMode mode, u32 maxVerts, | ||||||
|                              const boo::ObjToken<boo::ITexture>& texture, bool additive, bool zTest, bool zGEqual) |                              const boo::ObjToken<boo::ITexture>& texture, bool additive, bool zTest, bool zGEqual) | ||||||
| : m_mode(mode), m_maxVerts(maxVerts) { | : m_mode(mode), m_maxVerts(maxVerts) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (maxVerts < 2) { |   if (maxVerts < 2) { | ||||||
|     LineRendererLog.report(logvisor::Fatal, FMT_STRING(_SYS_STR("maxVerts < 2, maxVerts = {}")), maxVerts); |     LineRendererLog.report(logvisor::Fatal, FMT_STRING(_SYS_STR("maxVerts < 2, maxVerts = {}")), maxVerts); | ||||||
|     return; |     return; | ||||||
| @ -54,6 +55,7 @@ CLineRenderer::CLineRenderer(boo::IGraphicsDataFactory::Context& ctx, EPrimitive | |||||||
| CLineRenderer::CLineRenderer(EPrimitiveMode mode, u32 maxVerts, const boo::ObjToken<boo::ITexture>& texture, | CLineRenderer::CLineRenderer(EPrimitiveMode mode, u32 maxVerts, const boo::ObjToken<boo::ITexture>& texture, | ||||||
|                              bool additive, bool zTest, bool zGEqual) |                              bool additive, bool zTest, bool zGEqual) | ||||||
| : m_mode(mode), m_maxVerts(maxVerts) { | : m_mode(mode), m_maxVerts(maxVerts) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (maxVerts < 2) { |   if (maxVerts < 2) { | ||||||
|     LineRendererLog.report(logvisor::Fatal, FMT_STRING(_SYS_STR("maxVerts < 2, maxVerts = {}")), maxVerts); |     LineRendererLog.report(logvisor::Fatal, FMT_STRING(_SYS_STR("maxVerts < 2, maxVerts = {}")), maxVerts); | ||||||
|     return; |     return; | ||||||
|  | |||||||
| @ -51,6 +51,7 @@ void CBooModel::Shutdown() { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CBooModel::ClearModelUniformCounters() { | void CBooModel::ClearModelUniformCounters() { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   for (CBooModel* model = g_FirstModel; model; model = model->m_next) |   for (CBooModel* model = g_FirstModel; model; model = model->m_next) | ||||||
|     model->ClearUniformCounter(); |     model->ClearUniformCounter(); | ||||||
| } | } | ||||||
| @ -244,6 +245,7 @@ GeometryUniformLayout::GeometryUniformLayout(const CModel* model, const Material | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CBooModel::ModelInstance* CBooModel::PushNewModelInstance(int sharedLayoutBuf, boo::IGraphicsDataFactory::Context* ctx) { | CBooModel::ModelInstance* CBooModel::PushNewModelInstance(int sharedLayoutBuf, boo::IGraphicsDataFactory::Context* ctx) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (!x40_24_texturesLoaded && !g_DummyTextures) { |   if (!x40_24_texturesLoaded && !g_DummyTextures) { | ||||||
|     return nullptr; |     return nullptr; | ||||||
|   } |   } | ||||||
| @ -981,6 +983,7 @@ boo::ObjToken<boo::IGraphicsBufferD> GeometryUniformLayout::GetSharedBuffer(int | |||||||
| boo::ObjToken<boo::IGraphicsBufferD> CBooModel::UpdateUniformData(const CModelFlags& flags, const CSkinRules* cskr, | boo::ObjToken<boo::IGraphicsBufferD> CBooModel::UpdateUniformData(const CModelFlags& flags, const CSkinRules* cskr, | ||||||
|                                                                   const CPoseAsTransforms* pose, int sharedLayoutBuf, |                                                                   const CPoseAsTransforms* pose, int sharedLayoutBuf, | ||||||
|                                                                   boo::IGraphicsDataFactory::Context* ctx) { |                                                                   boo::IGraphicsDataFactory::Context* ctx) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (!g_DummyTextures && !TryLockTextures()) |   if (!g_DummyTextures && !TryLockTextures()) | ||||||
|     return {}; |     return {}; | ||||||
| 
 | 
 | ||||||
| @ -1154,6 +1157,7 @@ std::unique_ptr<CBooModel> CModel::MakeNewInstance(int shaderIdx, int subInsts, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CModelShaders::ShaderPipelines SShader::BuildShader(const hecl::HMDLMeta& meta, const MaterialSet::Material& mat) { | CModelShaders::ShaderPipelines SShader::BuildShader(const hecl::HMDLMeta& meta, const MaterialSet::Material& mat) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   hecl::Backend::ReflectionType reflectionType; |   hecl::Backend::ReflectionType reflectionType; | ||||||
|   if (mat.flags.samusReflectionIndirectTexture()) |   if (mat.flags.samusReflectionIndirectTexture()) | ||||||
|     reflectionType = hecl::Backend::ReflectionType::Indirect; |     reflectionType = hecl::Backend::ReflectionType::Indirect; | ||||||
|  | |||||||
| @ -53,6 +53,7 @@ void CSkinnedModel::Calculate(const CPoseAsTransforms& pose, const CModelFlags& | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CSkinnedModel::Draw(const CModelFlags& drawFlags) const { | void CSkinnedModel::Draw(const CModelFlags& drawFlags) const { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (m_modelInst->TryLockTextures()) |   if (m_modelInst->TryLockTextures()) | ||||||
|     m_modelInst->DrawSurfaces(drawFlags); |     m_modelInst->DrawSurfaces(drawFlags); | ||||||
| } | } | ||||||
|  | |||||||
| @ -90,6 +90,7 @@ u16 CFluidPlaneShader::Cache::MakeCacheKey(const SFluidPlaneDoorShaderInfo& info | |||||||
| template <> | template <> | ||||||
| CFluidPlaneShader::ShaderPair | CFluidPlaneShader::ShaderPair | ||||||
| CFluidPlaneShader::Cache::GetOrBuildShader<SFluidPlaneShaderInfo>(const SFluidPlaneShaderInfo& info) { | CFluidPlaneShader::Cache::GetOrBuildShader<SFluidPlaneShaderInfo>(const SFluidPlaneShaderInfo& info) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   u16 key = MakeCacheKey(info); |   u16 key = MakeCacheKey(info); | ||||||
|   auto& slot = CacheSlot(info, key); |   auto& slot = CacheSlot(info, key); | ||||||
|   if (slot.m_regular) |   if (slot.m_regular) | ||||||
| @ -104,6 +105,7 @@ CFluidPlaneShader::Cache::GetOrBuildShader<SFluidPlaneShaderInfo>(const SFluidPl | |||||||
| template <> | template <> | ||||||
| CFluidPlaneShader::ShaderPair | CFluidPlaneShader::ShaderPair | ||||||
| CFluidPlaneShader::Cache::GetOrBuildShader<SFluidPlaneDoorShaderInfo>(const SFluidPlaneDoorShaderInfo& info) { | CFluidPlaneShader::Cache::GetOrBuildShader<SFluidPlaneDoorShaderInfo>(const SFluidPlaneDoorShaderInfo& info) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   u16 key = MakeCacheKey(info); |   u16 key = MakeCacheKey(info); | ||||||
|   auto& slot = CacheSlot(info, key); |   auto& slot = CacheSlot(info, key); | ||||||
|   if (slot.m_regular) |   if (slot.m_regular) | ||||||
|  | |||||||
| @ -93,6 +93,7 @@ void CDecalManager::Update(float dt, CStateManager& mgr) { | |||||||
| 
 | 
 | ||||||
| void CDecalManager::AddDecal(const TToken<CDecalDescription>& decal, const zeus::CTransform& xf, bool notIce, | void CDecalManager::AddDecal(const TToken<CDecalDescription>& decal, const zeus::CTransform& xf, bool notIce, | ||||||
|                              CStateManager& mgr) { |                              CStateManager& mgr) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (m_LastDecalCreatedIndex != -1 && m_DeltaTimeSinceLastDecalCreation < 0.75f && |   if (m_LastDecalCreatedIndex != -1 && m_DeltaTimeSinceLastDecalCreation < 0.75f && | ||||||
|       m_LastDecalCreatedAssetId == decal.GetObjectTag()->id) { |       m_LastDecalCreatedAssetId == decal.GetObjectTag()->id) { | ||||||
|     SDecal& existingDecal = m_DecalPool[m_LastDecalCreatedIndex]; |     SDecal& existingDecal = m_DecalPool[m_LastDecalCreatedIndex]; | ||||||
|  | |||||||
| @ -593,6 +593,7 @@ void CElementGen::UpdatePSTranslationAndOrientation() { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::unique_ptr<CParticleGen> CElementGen::ConstructChildParticleSystem(const TToken<CGenDescription>& desc) const { | std::unique_ptr<CParticleGen> CElementGen::ConstructChildParticleSystem(const TToken<CGenDescription>& desc) const { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   auto ret = std::make_unique<CElementGen>(desc, EModelOrientationType::Normal, |   auto ret = std::make_unique<CElementGen>(desc, EModelOrientationType::Normal, | ||||||
|                                            x26d_27_enableOPTS ? EOptionalSystemFlags::Two : EOptionalSystemFlags::One); |                                            x26d_27_enableOPTS ? EOptionalSystemFlags::Two : EOptionalSystemFlags::One); | ||||||
|   ret->x26d_26_modelsUseLights = x26d_26_modelsUseLights; |   ret->x26d_26_modelsUseLights = x26d_26_modelsUseLights; | ||||||
|  | |||||||
| @ -176,6 +176,7 @@ constexpr std::array<s32, 2> CGunWeapon::skShootAnim{4, 3}; | |||||||
| 
 | 
 | ||||||
| void CGunWeapon::Fire(bool underwater, float dt, EChargeState chargeState, const zeus::CTransform& xf, | void CGunWeapon::Fire(bool underwater, float dt, EChargeState chargeState, const zeus::CTransform& xf, | ||||||
|                       CStateManager& mgr, TUniqueId homingTarget, float chargeFactor1, float chargeFactor2) { |                       CStateManager& mgr, TUniqueId homingTarget, float chargeFactor1, float chargeFactor2) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   CDamageInfo dInfo = GetDamageInfo(mgr, chargeState, chargeFactor1); |   CDamageInfo dInfo = GetDamageInfo(mgr, chargeState, chargeFactor1); | ||||||
|   zeus::CVector3f scale(chargeState == EChargeState::Normal ? 1.f : chargeFactor2); |   zeus::CVector3f scale(chargeState == EChargeState::Normal ? 1.f : chargeFactor2); | ||||||
|   bool partialCharge = chargeState == EChargeState::Normal ? false : !zeus::close_enough(chargeFactor1, 1.f); |   bool partialCharge = chargeState == EChargeState::Normal ? false : !zeus::close_enough(chargeFactor1, 1.f); | ||||||
|  | |||||||
| @ -312,6 +312,7 @@ void CFluidPlane::RenderStripWithRipples(float curY, const Heights& heights, con | |||||||
| void CFluidPlane::RenderPatch(const CFluidPlaneRender::SPatchInfo& info, const Heights& heights, const Flags& flags, | void CFluidPlane::RenderPatch(const CFluidPlaneRender::SPatchInfo& info, const Heights& heights, const Flags& flags, | ||||||
|                               bool noRipples, bool flagIs1, std::vector<CFluidPlaneShader::Vertex>& vOut, |                               bool noRipples, bool flagIs1, std::vector<CFluidPlaneShader::Vertex>& vOut, | ||||||
|                               std::vector<CFluidPlaneShader::PatchVertex>& pvOut) { |                               std::vector<CFluidPlaneShader::PatchVertex>& pvOut) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   if (noRipples) { |   if (noRipples) { | ||||||
|     m_shader->bindRegular(); |     m_shader->bindRegular(); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -129,6 +129,7 @@ CFluidPlaneShader::RenderSetupInfo CFluidPlaneCPU::RenderSetup(const CStateManag | |||||||
|                                                                const zeus::CTransform& xf, |                                                                const zeus::CTransform& xf, | ||||||
|                                                                const zeus::CTransform& areaXf, const zeus::CAABox& aabb, |                                                                const zeus::CTransform& areaXf, const zeus::CAABox& aabb, | ||||||
|                                                                const CScriptWater* water) { |                                                                const CScriptWater* water) { | ||||||
|  |   OPTICK_EVENT(); | ||||||
|   CFluidPlaneShader::RenderSetupInfo out; |   CFluidPlaneShader::RenderSetupInfo out; | ||||||
| 
 | 
 | ||||||
|   const float uvT = mgr.GetFluidPlaneManager()->GetUVT(); |   const float uvT = mgr.GetFluidPlaneManager()->GetUVT(); | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								extern/boo
									
									
									
									
										vendored
									
									
								
							
							
								
								
								
								
								
								
									
									
								
							
						
						
									
										2
									
								
								extern/boo
									
									
									
									
										vendored
									
									
								
							| @ -1 +1 @@ | |||||||
| Subproject commit 6335cb09fe5046984e8baa9b5a65de837037e70c | Subproject commit cd25ff4abfeb8c32256447f97a1a829bdbaf262c | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user