diff options
Diffstat (limited to 'tools/gfx/d3d12/render-d3d12.cpp')
| -rw-r--r-- | tools/gfx/d3d12/render-d3d12.cpp | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/tools/gfx/d3d12/render-d3d12.cpp b/tools/gfx/d3d12/render-d3d12.cpp index 68a5b3e50..25caa84a2 100644 --- a/tools/gfx/d3d12/render-d3d12.cpp +++ b/tools/gfx/d3d12/render-d3d12.cpp @@ -3036,6 +3036,7 @@ public: virtual void comFree() override { m_transientHeap.breakStrongReference(); } public: ComPtr<ID3D12GraphicsCommandList> m_cmdList; + ComPtr<ID3D12GraphicsCommandList1> m_cmdList1; ComPtr<ID3D12GraphicsCommandList4> m_cmdList4; BreakableReference<TransientResourceHeapImpl> m_transientHeap; @@ -3063,6 +3064,7 @@ public: #if SLANG_GFX_HAS_DXR_SUPPORT m_cmdList->QueryInterface<ID3D12GraphicsCommandList4>(m_cmdList4.writeRef()); #endif + m_cmdList->QueryInterface<ID3D12GraphicsCommandList1>(m_cmdList1.writeRef()); } class RenderCommandEncoderImpl @@ -3483,10 +3485,13 @@ public: uint32_t pixelCount, const SamplePosition* samplePositions) override { - SLANG_UNUSED(samplesPerPixel); - SLANG_UNUSED(pixelCount); - SLANG_UNUSED(samplePositions); - SLANG_UNIMPLEMENTED_X("setSamplePositions"); + if (m_commandBuffer->m_cmdList1) + { + m_commandBuffer->m_cmdList1->SetSamplePositions( + samplesPerPixel, pixelCount, (D3D12_SAMPLE_POSITION*)samplePositions); + return SLANG_OK; + } + return SLANG_E_NOT_AVAILABLE; } virtual SLANG_NO_THROW void SLANG_MCALL drawInstanced( |
