Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: tracy profiler integration #365

Merged
merged 15 commits into from
Aug 12, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 10 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,11 @@ message("Options:")
option(AUTO_PLUGIN_DEPLOYMENT "Copy the build output and addons to env:CommunityShadersOutputDir." OFF)
option(ZIP_TO_DIST "Zip the base mod and addons to their own 7z file in dist." ON)
option(AIO_ZIP_TO_DIST "Zip the base mod and addons to a AIO 7z file in dist." ON)
option(TRACY_SUPPORT "Enable support for tracy profiler" OFF)
message("\tAuto plugin deployment: ${AUTO_PLUGIN_DEPLOYMENT}")
message("\tZip to dist: ${ZIP_TO_DIST}")
message("\tAIO Zip to dist: ${AIO_ZIP_TO_DIST}")
message("\tTracy profiler: ${TRACY_SUPPORT}")

# #######################################################################################################################
# # Add CMake features
Expand All @@ -40,10 +42,17 @@ find_package(pystring CONFIG REQUIRED)
find_package(cppwinrt CONFIG REQUIRED)
find_package(unordered_dense CONFIG REQUIRED)
find_package(efsw CONFIG REQUIRED)
find_package(Tracy CONFIG REQUIRED)

set(NVAPI_INCLUDE_DIR "${CMAKE_SOURCE_DIR}/extern/nvapi/" CACHE STRING "Path to NVAPI include headers/shaders" )
set(NVAPI_LIBRARY "${CMAKE_SOURCE_DIR}/extern/nvapi/amd64/nvapi64.lib" CACHE STRING "Path to NVAPI .lib file")

target_compile_definitions(
${PROJECT_NAME}
PRIVATE
"$<$<BOOL:${TRACY_SUPPORT}>:TRACY_SUPPORT>"
)

target_include_directories(
${PROJECT_NAME}
PRIVATE
Expand All @@ -68,6 +77,7 @@ target_link_libraries(
pystring::pystring
unordered_dense::unordered_dense
efsw::efsw
Tracy::TracyClient
${NVAPI_LIBRARY}
)

Expand Down
7 changes: 7 additions & 0 deletions CMakePresets.json
FlayaN marked this conversation as resolved.
Show resolved Hide resolved
Pentalimbed marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,13 @@
"ENABLE_SKYRIM_VR": "OFF"
},
"inherits": "skyrim"
},
{
"name": "ALL-TRACY",
"cacheVariables": {
"TRACY_SUPPORT": "ON"
},
"inherits": "ALL"
}
]
}
4 changes: 4 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,10 @@ If you want an example CMakeUserPreset to start off with you can copy the `CMake
* This option is default `"ON"`
* Make sure `"ZIP_TO_DIST"` is set to `"ON"` in `CMakeUserPresets.json`
* This will create a zip for each feature and one for the base Community shaders in /dist containing
#### TRACY_SUPPORT
* This option is default `"OFF"`
* This will enable tracy support, might need to delete build folder when this option is changed


When using custom preset you can call BuildRelease.bat with an parameter to specify which preset to configure eg:
`.\BuildRelease.bat ALL-WITH-AUTO-DEPLOYMENT`
Expand Down
4 changes: 4 additions & 0 deletions include/PCH.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,10 @@ void* operator new[](size_t size, size_t alignment, size_t alignmentOffset, cons
#define WIN32_LEAN_AND_MEAN
#include <Windows.h>

#ifndef TRACY_SUPPORT
#undef TRACY_ENABLE
#endif

using namespace std::literals;

namespace stl
Expand Down
13 changes: 13 additions & 0 deletions src/Deferred.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -189,6 +189,9 @@ void Deferred::SetupResources()

void Deferred::CopyShadowData()
{
ZoneScoped;
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "CopyShadowData");

auto& context = State::GetSingleton()->context;

ID3D11UnorderedAccessView* uavs[1]{ perShadow->uav.get() };
Expand Down Expand Up @@ -252,6 +255,9 @@ void Deferred::UpdateConstantBuffer()

void Deferred::PrepassPasses()
{
ZoneScoped;
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Prepass");

auto& shaderCache = SIE::ShaderCache::Instance();

if (!shaderCache.IsEnabled())
Expand Down Expand Up @@ -337,6 +343,9 @@ void Deferred::StartDeferred()

void Deferred::DeferredPasses()
{
ZoneScoped;
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Deferred");

auto renderer = RE::BSGraphics::Renderer::GetSingleton();
auto& context = State::GetSingleton()->context;

Expand Down Expand Up @@ -377,6 +386,8 @@ void Deferred::DeferredPasses()

// Ambient Composite
{
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Ambient Composite");

ID3D11Buffer* buffer = skylighting->loaded ? skylighting->skylightingCB->CB() : nullptr;
context->CSSetConstantBuffers(1, 1, &buffer);

Expand Down Expand Up @@ -416,6 +427,8 @@ void Deferred::DeferredPasses()

// Deferred Composite
{
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Deferred Composite");

ID3D11Buffer* buffer = skylighting->loaded ? skylighting->skylightingCB->CB() : nullptr;
context->CSSetConstantBuffers(1, 1, &buffer);

Expand Down
2 changes: 2 additions & 0 deletions src/Features/DynamicCubemaps.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -368,6 +368,8 @@ void DynamicCubemaps::Irradiance(bool a_reflections)

void DynamicCubemaps::UpdateCubemap()
{
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Cubemap Update");

switch (nextTask) {
case NextTask::kInferrence:
nextTask = NextTask::kIrradiance;
Expand Down
12 changes: 12 additions & 0 deletions src/Features/ScreenSpaceGI.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -677,6 +677,9 @@ void ScreenSpaceGI::DrawSSGI(Texture2D* srcPrevAmbient)
return;
}

ZoneScoped;
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "SSGI");

static uint lastFrameGITexIdx = 0;
static uint lastFrameAccumTexIdx = 0;
uint inputGITexIdx = lastFrameGITexIdx;
Expand Down Expand Up @@ -721,6 +724,8 @@ void ScreenSpaceGI::DrawSSGI(Texture2D* srcPrevAmbient)

// prefilter depths
{
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "SSGI - Prefilter Depths");

srvs.at(0) = renderer->GetDepthStencilData().depthStencils[RE::RENDER_TARGETS_DEPTHSTENCIL::kPOST_ZPREPASS_COPY].depthSRV;
for (int i = 0; i < 5; ++i)
uavs.at(i) = uavWorkingDepth[i].get();
Expand All @@ -733,6 +738,8 @@ void ScreenSpaceGI::DrawSSGI(Texture2D* srcPrevAmbient)

// fetch radiance and disocclusion
{
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "SSGI - Radiance Disocc");

resetViews();
srvs.at(0) = rts[deferred->forwardRenderTargets[0]].SRV;
srvs.at(1) = texGI[inputGITexIdx]->srv.get();
Expand Down Expand Up @@ -762,6 +769,8 @@ void ScreenSpaceGI::DrawSSGI(Texture2D* srcPrevAmbient)

// GI
{
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "SSGI - GI");

resetViews();
srvs.at(0) = texWorkingDepth->srv.get();
srvs.at(1) = rts[NORMALROUGHNESS].SRV;
Expand Down Expand Up @@ -789,6 +798,7 @@ void ScreenSpaceGI::DrawSSGI(Texture2D* srcPrevAmbient)
if (settings.EnableBlur) {
for (uint i = 0; i < settings.BlurPasses; i++) {
if (doSpecular) {
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "SSGI - Specular Blur");
resetViews();
srvs.at(0) = texGISpecular[inputGITexIdx]->srv.get();
srvs.at(1) = nullptr;
Expand All @@ -804,6 +814,8 @@ void ScreenSpaceGI::DrawSSGI(Texture2D* srcPrevAmbient)
context->Dispatch((internalRes[0] + 7u) >> 3, (internalRes[1] + 7u) >> 3, 1);
}

TracyD3D11Zone(State::GetSingleton()->tracyCtx, "SSGI - Diffuse Blur");

resetViews();
srvs.at(0) = texGI[inputGITexIdx]->srv.get();
srvs.at(1) = texAccumFrames[lastFrameAccumTexIdx]->srv.get();
Expand Down
7 changes: 7 additions & 0 deletions src/Features/ScreenSpaceShadows.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,9 @@ ID3D11ComputeShader* ScreenSpaceShadows::GetComputeRaymarchRight()

void ScreenSpaceShadows::DrawShadows()
{
ZoneScoped;
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Screen Space Shadows");

auto renderer = RE::BSGraphics::Renderer::GetSingleton();
auto context = State::GetSingleton()->context;

Expand Down Expand Up @@ -134,6 +137,8 @@ void ScreenSpaceShadows::DrawShadows()
float2 dynamicRes = { viewport->GetRuntimeData().dynamicResolutionWidthRatio, viewport->GetRuntimeData().dynamicResolutionHeightRatio };

for (int i = 0; i < dispatchList.DispatchCount; i++) {
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "SSS - Ray March");

auto dispatchData = dispatchList.Dispatch[i];

RaymarchCB data{};
Expand Down Expand Up @@ -174,6 +179,8 @@ void ScreenSpaceShadows::DrawShadows()
dispatchList = Bend::BuildDispatchList(lightProjectionRightF, viewportSize, minRenderBounds, maxRenderBounds);

for (int i = 0; i < dispatchList.DispatchCount; i++) {
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "SSS - Ray March (VR Right Eye)");

auto dispatchData = dispatchList.Dispatch[i];

RaymarchCB data{};
Expand Down
7 changes: 6 additions & 1 deletion src/Features/Skylighting.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -201,6 +201,8 @@ void Skylighting::CompileComputeShaders()

void Skylighting::Prepass()
{
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Skylighting - Update Probes");

auto& context = State::GetSingleton()->context;

{
Expand Down Expand Up @@ -494,7 +496,10 @@ void Skylighting::Main_Precipitation_RenderOcclusion::thunk()
precip->SetupMask(); // Calling setup twice fixes an issue when it is raining

BSParticleShaderRainEmitter* rain = new BSParticleShaderRainEmitter;
precip->RenderMask((RE::BSParticleShaderRainEmitter*)rain);
{
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Skylighting - Render Height Map");
precip->RenderMask((RE::BSParticleShaderRainEmitter*)rain);
}
singleton->inOcclusion = false;

singleton->OcclusionDir = -float4{ PrecipitationShaderDirectionF.x, PrecipitationShaderDirectionF.y, PrecipitationShaderDirectionF.z, 0 };
Expand Down
7 changes: 7 additions & 0 deletions src/Features/SubsurfaceScattering.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -163,6 +163,9 @@ void SubsurfaceScattering::DrawSSS()
if (!validMaterials)
return;

ZoneScoped;
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Subsurface Scattering");

validMaterials = false;

auto dispatchCount = Util::GetScreenDispatchCount();
Expand Down Expand Up @@ -204,6 +207,8 @@ void SubsurfaceScattering::DrawSSS()

// Horizontal pass to temporary texture
{
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Subsurface Scattering - Horizontal");

auto shader = GetComputeShaderHorizontalBlur();
context->CSSetShader(shader, nullptr, 0);

Expand All @@ -215,6 +220,8 @@ void SubsurfaceScattering::DrawSSS()

// Vertical pass to main texture
{
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Subsurface Scattering - Vertical");

views[0] = blurHorizontalTemp->srv.get();
context->CSSetShaderResources(0, 1, views);

Expand Down
3 changes: 3 additions & 0 deletions src/Features/TerrainOcclusion.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -432,6 +432,9 @@ void TerrainOcclusion::UpdateShadow()
if (!sunLight)
return;

ZoneScoped;
TracyD3D11Zone(State::GetSingleton()->tracyCtx, "Terrain Occlusion - Update Shadows");

/* ---- UPDATE CB ---- */
uint width = texNormalisedHeight->desc.Width;
uint height = texNormalisedHeight->desc.Height;
Expand Down
20 changes: 19 additions & 1 deletion src/Hooks.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,9 @@ HRESULT WINAPI hk_IDXGISwapChain_Present(IDXGISwapChain* This, UINT SyncInterval
{
State::GetSingleton()->Reset();
Menu::GetSingleton()->DrawOverlay();
return (This->*ptr_IDXGISwapChain_Present)(SyncInterval, Flags);
auto retval = (This->*ptr_IDXGISwapChain_Present)(SyncInterval, Flags);
TracyD3D11Collect(State::GetSingleton()->tracyCtx);
return retval;
}

void hk_BSGraphics_SetDirtyStates(bool isCompute);
Expand Down Expand Up @@ -451,6 +453,18 @@ namespace Hooks
static inline REL::Relocation<decltype(thunk)> func;
};

#ifdef TRACY_ENABLE
struct Main_Update
{
static void thunk(RE::Main* a_this, float a2)
{
func(a_this, a2);
FrameMark;
}
static inline REL::Relocation<decltype(thunk)> func;
};
#endif

void Install()
{
SKSE::AllocTrampoline(14);
Expand Down Expand Up @@ -490,5 +504,9 @@ namespace Hooks
stl::write_thunk_call<CreateRenderTarget_Snow>(REL::RelocationID(100458, 107175).address() + REL::Relocate(0x406, 0x409));
stl::write_thunk_call<CreateDepthStencil_PrecipitationMask>(REL::RelocationID(100458, 107175).address() + REL::Relocate(0x1245, 0x123B, 0x1917));
stl::write_thunk_call<CreateCubemapRenderTarget_Reflections>(REL::RelocationID(100458, 107175).address() + REL::Relocate(0xA25, 0xA25, 0xCD2));

#ifdef TRACY_ENABLE
stl::write_thunk_call<Main_Update>(REL::RelocationID(35551, 36544).address() + REL::Relocate(0x11F, 0x160));
#endif
}
}
2 changes: 2 additions & 0 deletions src/State.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -375,6 +375,8 @@ void State::SetupResources()
context = reinterpret_cast<ID3D11DeviceContext*>(renderer->GetRuntimeData().context);
device = reinterpret_cast<ID3D11Device*>(renderer->GetRuntimeData().forwarder);
context->QueryInterface(__uuidof(pPerf), reinterpret_cast<void**>(&pPerf));

tracyCtx = TracyD3D11Context(device, context);
}

void State::ModifyShaderLookup(const RE::BSShader& a_shader, uint& a_vertexDescriptor, uint& a_pixelDescriptor, bool a_forceDeferred)
Expand Down
13 changes: 13 additions & 0 deletions src/State.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
#pragma once

#include <Tracy/Tracy.hpp>
Pentalimbed marked this conversation as resolved.
Show resolved Hide resolved
#include <Tracy/TracyD3D11.hpp>

#include <Buffer.h>
#include <nlohmann/json.hpp>
using json = nlohmann::json;
Expand Down Expand Up @@ -139,6 +142,16 @@ class State
ID3D11DeviceContext* context = nullptr;
ID3D11Device* device = nullptr;

TracyD3D11Ctx tracyCtx = nullptr; // Tracy context

inline ~State()
{
#ifdef TRACY_ENABLE
if (tracyCtx)
TracyD3D11Destroy(tracyCtx);
#endif
}

private:
std::shared_ptr<REX::W32::ID3DUserDefinedAnnotation> pPerf;
bool initialized = false;
Expand Down
5 changes: 5 additions & 0 deletions vcpkg.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
"magic-enum",
"nlohmann-json",
"pystring",
"tracy",
"unordered-dense",
"xbyak"
],
Expand All @@ -35,6 +36,10 @@
{
"name": "imgui",
"version": "1.90"
},
{
"name": "tracy",
"version": "0.11.0"
}
],
"builtin-baseline": "1dc5ee30eb1032221d29f281f4a94b73f06b4284"
Expand Down
Loading