diff --git a/src/d3d11/d3d11_context.cpp b/src/d3d11/d3d11_context.cpp index f69c3d16a..4c8e2506b 100644 --- a/src/d3d11/d3d11_context.cpp +++ b/src/d3d11/d3d11_context.cpp @@ -2976,8 +2976,8 @@ namespace dxvk { void D3D11DeviceContext::BindUnorderedAccessView( UINT UavSlot, - UINT CtrSlot, D3D11UnorderedAccessView* pUav, + UINT CtrSlot, UINT Counter) { EmitCs([ cUavSlotId = UavSlot, @@ -3129,11 +3129,14 @@ namespace dxvk { for (uint32_t i = 0; i < NumUAVs; i++) { auto uav = static_cast(ppUnorderedAccessViews[i]); + auto ctr = pUAVInitialCounts ? pUAVInitialCounts[i] : ~0u; - if (Bindings[StartSlot + i] != uav) { + if (Bindings[StartSlot + i] != uav || ctr != ~0u) { Bindings[StartSlot + i] = uav; - BindUnorderedAccessView(uavSlotId + i, ctrSlotId + i, uav, - pUAVInitialCounts ? pUAVInitialCounts[i] : ~0u); + + BindUnorderedAccessView( + uavSlotId + i, uav, + ctrSlotId + i, ctr); } } } @@ -3285,8 +3288,9 @@ namespace dxvk { for (uint32_t i = 0; i < Bindings.size(); i++) { BindUnorderedAccessView( - uavSlotId + i, ctrSlotId + i, - Bindings[i].ptr(), ~0u); + uavSlotId + i, + Bindings[i].ptr(), + ctrSlotId + i, ~0u); } } diff --git a/src/d3d11/d3d11_context.h b/src/d3d11/d3d11_context.h index 052c552ba..7ce4375d4 100644 --- a/src/d3d11/d3d11_context.h +++ b/src/d3d11/d3d11_context.h @@ -716,8 +716,8 @@ namespace dxvk { void BindUnorderedAccessView( UINT UavSlot, - UINT CtrSlot, D3D11UnorderedAccessView* pUav, + UINT CtrSlot, UINT Counter); void DiscardBuffer(