1
0
mirror of https://github.com/doitsujin/dxvk.git synced 2025-04-06 00:57:40 +02:00

[d3d11] Move *SetShaderResources methods to D3D11CommonContext

This commit is contained in:
Philip Rebohle 2022-08-03 19:58:55 +02:00
parent bfaa21dccc
commit 3af5b3ba7b
No known key found for this signature in database
GPG Key ID: C8CC613427A31C99
4 changed files with 273 additions and 259 deletions

View File

@ -1284,19 +1284,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::VSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::VertexShader>(
m_state.vs.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::VSSetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::VSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -1310,17 +1297,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::VSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.vs.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::VSGetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::VSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -1332,19 +1308,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::HSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::HullShader>(
m_state.hs.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::HSSetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::HSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -1358,17 +1321,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::HSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.hs.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::HSGetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::HSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -1380,19 +1332,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::DSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::DomainShader>(
m_state.ds.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::DSSetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::DSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -1406,17 +1345,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::DSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.ds.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::DSGetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::DSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -1428,19 +1356,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::GSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::GeometryShader>(
m_state.gs.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::GSSetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::GSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -1454,17 +1369,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::GSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.gs.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::GSGetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::GSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -1476,19 +1380,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::PSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::PixelShader>(
m_state.ps.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::PSSetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::PSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -1502,17 +1393,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::PSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.ps.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::PSGetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::PSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -1524,19 +1404,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::CSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::ComputeShader>(
m_state.cs.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::CSSetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::CSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -1606,17 +1473,6 @@ namespace dxvk {
} }
void STDMETHODCALLTYPE D3D11DeviceContext::CSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.cs.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
void STDMETHODCALLTYPE D3D11DeviceContext::CSGetSamplers( void STDMETHODCALLTYPE D3D11DeviceContext::CSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -2957,48 +2813,6 @@ namespace dxvk {
} }
template<DxbcProgramType ShaderStage>
void D3D11DeviceContext::SetShaderResources(
D3D11ShaderResourceBindings& Bindings,
UINT StartSlot,
UINT NumResources,
ID3D11ShaderResourceView* const* ppResources) {
uint32_t slotId = computeSrvBinding(ShaderStage, StartSlot);
for (uint32_t i = 0; i < NumResources; i++) {
auto resView = static_cast<D3D11ShaderResourceView*>(ppResources[i]);
if (Bindings.views[StartSlot + i] != resView) {
if (unlikely(resView && resView->TestHazards())) {
if (TestSrvHazards<ShaderStage>(resView))
resView = nullptr;
// Only set if necessary, but don't reset it on every
// bind as this would be more expensive than a few
// redundant checks in OMSetRenderTargets and friends.
Bindings.hazardous.set(StartSlot + i, resView);
}
Bindings.views[StartSlot + i] = resView;
BindShaderResource<ShaderStage>(slotId + i, resView);
}
}
}
void D3D11DeviceContext::GetShaderResources(
const D3D11ShaderResourceBindings& Bindings,
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
for (uint32_t i = 0; i < NumViews; i++) {
ppShaderResourceViews[i] = StartSlot + i < Bindings.views.size()
? Bindings.views[StartSlot + i].ref()
: nullptr;
}
}
void D3D11DeviceContext::GetSamplers( void D3D11DeviceContext::GetSamplers(
const D3D11SamplerBindings& Bindings, const D3D11SamplerBindings& Bindings,
UINT StartSlot, UINT StartSlot,

View File

@ -208,111 +208,56 @@ namespace dxvk {
ID3D11Buffer* pBufferForArgs, ID3D11Buffer* pBufferForArgs,
UINT AlignedByteOffsetForArgs); UINT AlignedByteOffsetForArgs);
void STDMETHODCALLTYPE VSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE VSSetSamplers( void STDMETHODCALLTYPE VSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers); ID3D11SamplerState* const* ppSamplers);
void STDMETHODCALLTYPE VSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE VSGetSamplers( void STDMETHODCALLTYPE VSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState** ppSamplers); ID3D11SamplerState** ppSamplers);
void STDMETHODCALLTYPE HSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE HSSetSamplers( void STDMETHODCALLTYPE HSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers); ID3D11SamplerState* const* ppSamplers);
void STDMETHODCALLTYPE HSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE HSGetSamplers( void STDMETHODCALLTYPE HSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState** ppSamplers); ID3D11SamplerState** ppSamplers);
void STDMETHODCALLTYPE DSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE DSSetSamplers( void STDMETHODCALLTYPE DSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers); ID3D11SamplerState* const* ppSamplers);
void STDMETHODCALLTYPE DSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE DSGetSamplers( void STDMETHODCALLTYPE DSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState** ppSamplers); ID3D11SamplerState** ppSamplers);
void STDMETHODCALLTYPE GSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE GSSetSamplers( void STDMETHODCALLTYPE GSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers); ID3D11SamplerState* const* ppSamplers);
void STDMETHODCALLTYPE GSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE GSGetSamplers( void STDMETHODCALLTYPE GSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState** ppSamplers); ID3D11SamplerState** ppSamplers);
void STDMETHODCALLTYPE PSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE PSSetSamplers( void STDMETHODCALLTYPE PSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers); ID3D11SamplerState* const* ppSamplers);
void STDMETHODCALLTYPE PSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE PSGetSamplers( void STDMETHODCALLTYPE PSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState** ppSamplers); ID3D11SamplerState** ppSamplers);
void STDMETHODCALLTYPE CSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE CSSetSamplers( void STDMETHODCALLTYPE CSSetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -324,11 +269,6 @@ namespace dxvk {
ID3D11UnorderedAccessView* const* ppUnorderedAccessViews, ID3D11UnorderedAccessView* const* ppUnorderedAccessViews,
const UINT* pUAVInitialCounts); const UINT* pUAVInitialCounts);
void STDMETHODCALLTYPE CSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE CSGetSamplers( void STDMETHODCALLTYPE CSGetSamplers(
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
@ -545,19 +485,6 @@ namespace dxvk {
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers); ID3D11SamplerState* const* ppSamplers);
template<DxbcProgramType ShaderStage>
void SetShaderResources(
D3D11ShaderResourceBindings& Bindings,
UINT StartSlot,
UINT NumResources,
ID3D11ShaderResourceView* const* ppResources);
void GetShaderResources(
const D3D11ShaderResourceBindings& Bindings,
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void GetSamplers( void GetSamplers(
const D3D11SamplerBindings& Bindings, const D3D11SamplerBindings& Bindings,
UINT StartSlot, UINT StartSlot,

View File

@ -297,6 +297,20 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::VSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::VertexShader>(
m_state.vs.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::VSGetShader( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::VSGetShader(
ID3D11VertexShader** ppVertexShader, ID3D11VertexShader** ppVertexShader,
@ -345,6 +359,18 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::VSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.vs.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::HSSetShader( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::HSSetShader(
ID3D11HullShader* pHullShader, ID3D11HullShader* pHullShader,
@ -397,6 +423,20 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::HSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::HullShader>(
m_state.hs.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::HSGetShader( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::HSGetShader(
ID3D11HullShader** ppHullShader, ID3D11HullShader** ppHullShader,
@ -445,6 +485,18 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::HSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.hs.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::DSSetShader( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::DSSetShader(
ID3D11DomainShader* pDomainShader, ID3D11DomainShader* pDomainShader,
@ -497,6 +549,20 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::DSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::DomainShader>(
m_state.ds.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::DSGetShader( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::DSGetShader(
ID3D11DomainShader** ppDomainShader, ID3D11DomainShader** ppDomainShader,
@ -545,6 +611,18 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::DSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.ds.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::GSSetShader( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::GSSetShader(
ID3D11GeometryShader* pShader, ID3D11GeometryShader* pShader,
@ -597,6 +675,20 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::GSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::GeometryShader>(
m_state.gs.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::GSGetShader( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::GSGetShader(
ID3D11GeometryShader** ppGeometryShader, ID3D11GeometryShader** ppGeometryShader,
@ -645,6 +737,18 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::GSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.gs.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::PSSetShader( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::PSSetShader(
ID3D11PixelShader* pPixelShader, ID3D11PixelShader* pPixelShader,
@ -697,6 +801,20 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::PSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::PixelShader>(
m_state.ps.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::PSGetShader( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::PSGetShader(
ID3D11PixelShader** ppPixelShader, ID3D11PixelShader** ppPixelShader,
@ -745,6 +863,18 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::PSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.ps.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::CSSetShader( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::CSSetShader(
ID3D11ComputeShader* pComputeShader, ID3D11ComputeShader* pComputeShader,
@ -797,6 +927,20 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::CSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources<DxbcProgramType::ComputeShader>(
m_state.cs.shaderResources,
StartSlot, NumViews,
ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::CSGetShader( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::CSGetShader(
ID3D11ComputeShader** ppComputeShader, ID3D11ComputeShader** ppComputeShader,
@ -845,6 +989,18 @@ namespace dxvk {
} }
template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::CSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
GetShaderResources(m_state.cs.shaderResources,
StartSlot, NumViews, ppShaderResourceViews);
}
template<typename ContextType> template<typename ContextType>
void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::OMSetRenderTargets( void STDMETHODCALLTYPE D3D11CommonContext<ContextType>::OMSetRenderTargets(
UINT NumViews, UINT NumViews,
@ -1305,6 +1461,20 @@ namespace dxvk {
} }
template<typename ContextType>
void D3D11CommonContext<ContextType>::GetShaderResources(
const D3D11ShaderResourceBindings& Bindings,
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) {
for (uint32_t i = 0; i < NumViews; i++) {
ppShaderResourceViews[i] = StartSlot + i < Bindings.views.size()
? Bindings.views[StartSlot + i].ref()
: nullptr;
}
}
template<typename ContextType> template<typename ContextType>
template<DxbcProgramType ShaderStage, typename T> template<DxbcProgramType ShaderStage, typename T>
void D3D11CommonContext<ContextType>::ResolveSrvHazards( void D3D11CommonContext<ContextType>::ResolveSrvHazards(
@ -1503,6 +1673,36 @@ namespace dxvk {
} }
template<typename ContextType>
template<DxbcProgramType ShaderStage>
void D3D11CommonContext<ContextType>::SetShaderResources(
D3D11ShaderResourceBindings& Bindings,
UINT StartSlot,
UINT NumResources,
ID3D11ShaderResourceView* const* ppResources) {
uint32_t slotId = computeSrvBinding(ShaderStage, StartSlot);
for (uint32_t i = 0; i < NumResources; i++) {
auto resView = static_cast<D3D11ShaderResourceView*>(ppResources[i]);
if (Bindings.views[StartSlot + i] != resView) {
if (unlikely(resView && resView->TestHazards())) {
if (TestSrvHazards<ShaderStage>(resView))
resView = nullptr;
// Only set if necessary, but don't reset it on every
// bind as this would be more expensive than a few
// redundant checks in OMSetRenderTargets and friends.
Bindings.hazardous.set(StartSlot + i, resView);
}
Bindings.views[StartSlot + i] = resView;
BindShaderResource<ShaderStage>(slotId + i, resView);
}
}
}
template<typename ContextType> template<typename ContextType>
void D3D11CommonContext<ContextType>::SetRenderTargetsAndUnorderedAccessViews( void D3D11CommonContext<ContextType>::SetRenderTargetsAndUnorderedAccessViews(
UINT NumRTVs, UINT NumRTVs,

View File

@ -138,6 +138,11 @@ namespace dxvk {
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants); const UINT* pNumConstants);
void STDMETHODCALLTYPE VSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE VSGetShader( void STDMETHODCALLTYPE VSGetShader(
ID3D11VertexShader** ppVertexShader, ID3D11VertexShader** ppVertexShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
@ -155,6 +160,11 @@ namespace dxvk {
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants); UINT* pNumConstants);
void STDMETHODCALLTYPE VSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE HSSetShader( void STDMETHODCALLTYPE HSSetShader(
ID3D11HullShader* pHullShader, ID3D11HullShader* pHullShader,
ID3D11ClassInstance* const* ppClassInstances, ID3D11ClassInstance* const* ppClassInstances,
@ -172,6 +182,11 @@ namespace dxvk {
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants); const UINT* pNumConstants);
void STDMETHODCALLTYPE HSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE HSGetShader( void STDMETHODCALLTYPE HSGetShader(
ID3D11HullShader** ppHullShader, ID3D11HullShader** ppHullShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
@ -189,6 +204,11 @@ namespace dxvk {
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants); UINT* pNumConstants);
void STDMETHODCALLTYPE HSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE DSSetShader( void STDMETHODCALLTYPE DSSetShader(
ID3D11DomainShader* pDomainShader, ID3D11DomainShader* pDomainShader,
ID3D11ClassInstance* const* ppClassInstances, ID3D11ClassInstance* const* ppClassInstances,
@ -206,6 +226,11 @@ namespace dxvk {
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants); const UINT* pNumConstants);
void STDMETHODCALLTYPE DSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE DSGetShader( void STDMETHODCALLTYPE DSGetShader(
ID3D11DomainShader** ppDomainShader, ID3D11DomainShader** ppDomainShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
@ -223,6 +248,11 @@ namespace dxvk {
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants); UINT* pNumConstants);
void STDMETHODCALLTYPE DSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE GSSetShader( void STDMETHODCALLTYPE GSSetShader(
ID3D11GeometryShader* pShader, ID3D11GeometryShader* pShader,
ID3D11ClassInstance* const* ppClassInstances, ID3D11ClassInstance* const* ppClassInstances,
@ -240,6 +270,11 @@ namespace dxvk {
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants); const UINT* pNumConstants);
void STDMETHODCALLTYPE GSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE GSGetShader( void STDMETHODCALLTYPE GSGetShader(
ID3D11GeometryShader** ppGeometryShader, ID3D11GeometryShader** ppGeometryShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
@ -257,6 +292,11 @@ namespace dxvk {
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants); UINT* pNumConstants);
void STDMETHODCALLTYPE GSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE PSSetShader( void STDMETHODCALLTYPE PSSetShader(
ID3D11PixelShader* pPixelShader, ID3D11PixelShader* pPixelShader,
ID3D11ClassInstance* const* ppClassInstances, ID3D11ClassInstance* const* ppClassInstances,
@ -274,6 +314,11 @@ namespace dxvk {
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants); const UINT* pNumConstants);
void STDMETHODCALLTYPE PSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE PSGetShader( void STDMETHODCALLTYPE PSGetShader(
ID3D11PixelShader** ppPixelShader, ID3D11PixelShader** ppPixelShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
@ -291,6 +336,11 @@ namespace dxvk {
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants); UINT* pNumConstants);
void STDMETHODCALLTYPE PSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE CSSetShader( void STDMETHODCALLTYPE CSSetShader(
ID3D11ComputeShader* pComputeShader, ID3D11ComputeShader* pComputeShader,
ID3D11ClassInstance* const* ppClassInstances, ID3D11ClassInstance* const* ppClassInstances,
@ -308,6 +358,11 @@ namespace dxvk {
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants); const UINT* pNumConstants);
void STDMETHODCALLTYPE CSSetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews);
void STDMETHODCALLTYPE CSGetShader( void STDMETHODCALLTYPE CSGetShader(
ID3D11ComputeShader** ppComputeShader, ID3D11ComputeShader** ppComputeShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
@ -325,6 +380,11 @@ namespace dxvk {
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants); UINT* pNumConstants);
void STDMETHODCALLTYPE CSGetShaderResources(
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
void STDMETHODCALLTYPE OMSetRenderTargets( void STDMETHODCALLTYPE OMSetRenderTargets(
UINT NumViews, UINT NumViews,
ID3D11RenderTargetView* const* ppRenderTargetViews, ID3D11RenderTargetView* const* ppRenderTargetViews,
@ -441,6 +501,12 @@ namespace dxvk {
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants); UINT* pNumConstants);
void GetShaderResources(
const D3D11ShaderResourceBindings& Bindings,
UINT StartSlot,
UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews);
template<DxbcProgramType ShaderStage, typename T> template<DxbcProgramType ShaderStage, typename T>
void ResolveSrvHazards( void ResolveSrvHazards(
T* pView, T* pView,
@ -476,6 +542,13 @@ namespace dxvk {
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants); const UINT* pNumConstants);
template<DxbcProgramType ShaderStage>
void SetShaderResources(
D3D11ShaderResourceBindings& Bindings,
UINT StartSlot,
UINT NumResources,
ID3D11ShaderResourceView* const* ppResources);
void SetRenderTargetsAndUnorderedAccessViews( void SetRenderTargetsAndUnorderedAccessViews(
UINT NumRTVs, UINT NumRTVs,
ID3D11RenderTargetView* const* ppRenderTargetViews, ID3D11RenderTargetView* const* ppRenderTargetViews,