From ecd47ca40c2282371818d6462f2582124fbbd3ff Mon Sep 17 00:00:00 2001 From: baldurk Date: Wed, 25 Oct 2023 17:56:27 +0100 Subject: [PATCH] If descriptor heap fails to expand on tier 3 HW, fall back. Closes #3092 * Descriptor heap tier limits are not very useful as even tier 3 might be as limited as tier 2. Previously expanding a small amount was safe but newer NV drivers or systems seem to have stricter limits than before. --- renderdoc/driver/d3d12/d3d12_device_wrap.cpp | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/renderdoc/driver/d3d12/d3d12_device_wrap.cpp b/renderdoc/driver/d3d12/d3d12_device_wrap.cpp index 9cd343192f..2eea826634 100644 --- a/renderdoc/driver/d3d12/d3d12_device_wrap.cpp +++ b/renderdoc/driver/d3d12/d3d12_device_wrap.cpp @@ -911,6 +911,7 @@ bool WrappedID3D12Device::Serialise_CreateDescriptorHeap( if(IsReplayingAndReading()) { D3D12_DESCRIPTOR_HEAP_DESC PatchedDesc = Descriptor; + bool patched = false; // inflate the heap so we can insert our own descriptors at the end // while patching, because DX12 has a stupid limitation to not be able @@ -919,16 +920,31 @@ bool WrappedID3D12Device::Serialise_CreateDescriptorHeap( { if(m_D3D12Opts.ResourceBindingTier == D3D12_RESOURCE_BINDING_TIER_3 || PatchedDesc.NumDescriptors + 16 <= 1000000) + { PatchedDesc.NumDescriptors += 16; + patched = true; + } else + { RDCERR( "RenderDoc needs extra descriptors for patching during analysis," "but heap is already at binding tier limit"); + } } ID3D12DescriptorHeap *ret = NULL; HRESULT hr = m_pDevice->CreateDescriptorHeap(&PatchedDesc, guid, (void **)&ret); + if(patched && FAILED(hr)) + { + RDCERR( + "RenderDoc needs extra descriptors for patching during analysis," + "but heap failed to expand any further even at tier 3"); + PatchedDesc.NumDescriptors = Descriptor.NumDescriptors; + + hr = m_pDevice->CreateDescriptorHeap(&PatchedDesc, guid, (void **)&ret); + } + if(FAILED(hr)) { SET_ERROR_RESULT(m_FailedReplayResult, ResultCode::APIReplayFailed,