summaryrefslogtreecommitdiff
path: root/tools/gfx/d3d12/render-d3d12.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tools/gfx/d3d12/render-d3d12.cpp')
-rw-r--r--tools/gfx/d3d12/render-d3d12.cpp71
1 files changed, 39 insertions, 32 deletions
diff --git a/tools/gfx/d3d12/render-d3d12.cpp b/tools/gfx/d3d12/render-d3d12.cpp
index 3daddc73f..aab260cd1 100644
--- a/tools/gfx/d3d12/render-d3d12.cpp
+++ b/tools/gfx/d3d12/render-d3d12.cpp
@@ -3425,26 +3425,15 @@ public:
{
prepareDraw();
- D3D12_INDIRECT_ARGUMENT_DESC args[1];
- args[0].Type = D3D12_INDIRECT_ARGUMENT_TYPE_DRAW;
-
- D3D12_COMMAND_SIGNATURE_DESC desc;
- desc.ByteStride = 36;
- desc.NumArgumentDescs = 1;
- desc.pArgumentDescs = args;
-
- ComPtr<ID3D12CommandSignature> cmdSignature = nullptr;
- if (FAILED(m_device->CreateCommandSignature(&desc, nullptr, IID_PPV_ARGS(cmdSignature.writeRef()))))
- {
- return;
- }
+ auto argBufferImpl = static_cast<BufferResourceImpl*>(argBuffer);
+ auto countBufferImpl = static_cast<BufferResourceImpl*>(countBuffer);
m_d3dCmdList->ExecuteIndirect(
- cmdSignature,
+ m_renderer->drawIndirectCmdSignature,
maxDrawCount,
- (ID3D12Resource*)argBuffer,
+ argBufferImpl->m_resource,
argOffset,
- (ID3D12Resource*)countBuffer,
+ countBufferImpl->m_resource,
countOffset);
}
@@ -3457,26 +3446,15 @@ public:
{
prepareDraw();
- D3D12_INDIRECT_ARGUMENT_DESC args[1];
- args[0].Type = D3D12_INDIRECT_ARGUMENT_TYPE_DRAW_INDEXED;
-
- D3D12_COMMAND_SIGNATURE_DESC desc;
- desc.ByteStride = 36;
- desc.NumArgumentDescs = 1;
- desc.pArgumentDescs = args;
-
- ComPtr<ID3D12CommandSignature> cmdSignature = nullptr;
- if (FAILED(m_device->CreateCommandSignature(&desc, nullptr, IID_PPV_ARGS(cmdSignature.writeRef()))))
- {
- return;
- }
+ auto argBufferImpl = static_cast<BufferResourceImpl*>(argBuffer);
+ auto countBufferImpl = static_cast<BufferResourceImpl*>(countBuffer);
m_d3dCmdList->ExecuteIndirect(
- cmdSignature,
+ m_renderer->drawIndexedIndirectCmdSignature,
maxDrawCount,
- (ID3D12Resource*)argBuffer,
+ argBufferImpl->m_resource,
argOffset,
- (ID3D12Resource*)countBuffer,
+ countBufferImpl->m_resource,
countOffset);
}
@@ -4549,6 +4527,9 @@ public:
PFN_D3D12_SERIALIZE_ROOT_SIGNATURE m_D3D12SerializeRootSignature = nullptr;
bool m_nvapi = false;
+
+ ComPtr<ID3D12CommandSignature> drawIndirectCmdSignature;
+ ComPtr<ID3D12CommandSignature> drawIndexedIndirectCmdSignature;
};
SLANG_NO_THROW Result SLANG_MCALL D3D12Device::TransientResourceHeapImpl::synchronizeAndReset()
@@ -5328,6 +5309,32 @@ Result D3D12Device::initialize(const Desc& desc)
profileName,
makeArray(slang::PreprocessorMacroDesc{"__D3D12__", "1"}).getView()));
+ {
+ D3D12_INDIRECT_ARGUMENT_DESC args[1];
+ args[0].Type = D3D12_INDIRECT_ARGUMENT_TYPE_DRAW;
+
+ D3D12_COMMAND_SIGNATURE_DESC desc;
+ desc.ByteStride = 36;
+ desc.NumArgumentDescs = 1;
+ desc.pArgumentDescs = args;
+ desc.NodeMask = 0;
+
+ SLANG_RETURN_ON_FAIL(m_device->CreateCommandSignature(&desc, nullptr, IID_PPV_ARGS(drawIndirectCmdSignature.writeRef())));
+ }
+
+ {
+ D3D12_INDIRECT_ARGUMENT_DESC args[1];
+ args[0].Type = D3D12_INDIRECT_ARGUMENT_TYPE_DRAW_INDEXED;
+
+ D3D12_COMMAND_SIGNATURE_DESC desc;
+ desc.ByteStride = 36;
+ desc.NumArgumentDescs = 1;
+ desc.pArgumentDescs = args;
+ desc.NodeMask = 0;
+
+ SLANG_RETURN_ON_FAIL(m_device->CreateCommandSignature(&desc, nullptr, IID_PPV_ARGS(drawIndexedIndirectCmdSignature.writeRef())));
+ }
+
m_isInitialized = true;
return SLANG_OK;
}