1
0
mirror of https://github.com/doitsujin/dxvk.git synced 2025-01-19 05:52:11 +01:00

[d3d11] Implement ID3D11Multithread for D3D11 contexts

This commit is contained in:
Philip Rebohle 2018-11-29 20:59:40 +01:00
parent 28216909bd
commit cf21111401
No known key found for this signature in database
GPG Key ID: C8CC613427A31C99
4 changed files with 261 additions and 0 deletions

View File

@ -15,6 +15,7 @@ namespace dxvk {
DxvkCsChunkFlags CsFlags) DxvkCsChunkFlags CsFlags)
: m_parent (pParent), : m_parent (pParent),
m_annotation(this), m_annotation(this),
m_multithread(this, false),
m_device (Device), m_device (Device),
m_csFlags (CsFlags), m_csFlags (CsFlags),
m_csChunk (AllocCsChunk()) { m_csChunk (AllocCsChunk()) {
@ -57,6 +58,11 @@ namespace dxvk {
*ppvObject = ref(&m_annotation); *ppvObject = ref(&m_annotation);
return S_OK; return S_OK;
} }
if (riid == __uuidof(ID3D10Multithread)) {
*ppvObject = ref(&m_multithread);
return S_OK;
}
Logger::warn("D3D11DeviceContext::QueryInterface: Unknown interface query"); Logger::warn("D3D11DeviceContext::QueryInterface: Unknown interface query");
Logger::warn(str::format(riid)); Logger::warn(str::format(riid));
@ -65,6 +71,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::DiscardResource(ID3D11Resource* pResource) { void STDMETHODCALLTYPE D3D11DeviceContext::DiscardResource(ID3D11Resource* pResource) {
D3D10DeviceLock lock = LockContext();
if (!pResource) if (!pResource)
return; return;
@ -80,6 +88,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::DiscardView(ID3D11View* pResourceView) { void STDMETHODCALLTYPE D3D11DeviceContext::DiscardView(ID3D11View* pResourceView) {
D3D10DeviceLock lock = LockContext();
// ID3D11View has no methods to query the exact type of // ID3D11View has no methods to query the exact type of
// the view, so we'll have to check each possible class // the view, so we'll have to check each possible class
auto dsv = dynamic_cast<D3D11DepthStencilView*>(pResourceView); auto dsv = dynamic_cast<D3D11DepthStencilView*>(pResourceView);
@ -112,18 +122,22 @@ namespace dxvk {
Logger::err("D3D11DeviceContext::DiscardView1: Not implemented"); Logger::err("D3D11DeviceContext::DiscardView1: Not implemented");
} }
void STDMETHODCALLTYPE D3D11DeviceContext::SwapDeviceContextState( void STDMETHODCALLTYPE D3D11DeviceContext::SwapDeviceContextState(
ID3DDeviceContextState* pState, ID3DDeviceContextState* pState,
ID3DDeviceContextState** ppPreviousState) { ID3DDeviceContextState** ppPreviousState) {
Logger::err("D3D11DeviceContext::SwapDeviceContextState: Not implemented"); Logger::err("D3D11DeviceContext::SwapDeviceContextState: Not implemented");
} }
void STDMETHODCALLTYPE D3D11DeviceContext::GetDevice(ID3D11Device **ppDevice) { void STDMETHODCALLTYPE D3D11DeviceContext::GetDevice(ID3D11Device **ppDevice) {
*ppDevice = ref(m_parent); *ppDevice = ref(m_parent);
} }
void STDMETHODCALLTYPE D3D11DeviceContext::ClearState() { void STDMETHODCALLTYPE D3D11DeviceContext::ClearState() {
D3D10DeviceLock lock = LockContext();
// Default shaders // Default shaders
m_state.vs.shader = nullptr; m_state.vs.shader = nullptr;
m_state.hs.shader = nullptr; m_state.hs.shader = nullptr;
@ -225,6 +239,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::Begin(ID3D11Asynchronous *pAsync) { void STDMETHODCALLTYPE D3D11DeviceContext::Begin(ID3D11Asynchronous *pAsync) {
D3D10DeviceLock lock = LockContext();
if (!pAsync) if (!pAsync)
return; return;
@ -240,6 +256,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::End(ID3D11Asynchronous *pAsync) { void STDMETHODCALLTYPE D3D11DeviceContext::End(ID3D11Asynchronous *pAsync) {
D3D10DeviceLock lock = LockContext();
if (!pAsync) if (!pAsync)
return; return;
@ -266,6 +284,8 @@ namespace dxvk {
if (pPredicate && !std::exchange(s_errorShown, true)) if (pPredicate && !std::exchange(s_errorShown, true))
Logger::err("D3D11DeviceContext::SetPredication: Stub"); Logger::err("D3D11DeviceContext::SetPredication: Stub");
D3D10DeviceLock lock = LockContext();
m_state.pr.predicateObject = static_cast<D3D11Query*>(pPredicate); m_state.pr.predicateObject = static_cast<D3D11Query*>(pPredicate);
m_state.pr.predicateValue = PredicateValue; m_state.pr.predicateValue = PredicateValue;
} }
@ -274,6 +294,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::GetPredication( void STDMETHODCALLTYPE D3D11DeviceContext::GetPredication(
ID3D11Predicate** ppPredicate, ID3D11Predicate** ppPredicate,
BOOL* pPredicateValue) { BOOL* pPredicateValue) {
D3D10DeviceLock lock = LockContext();
if (ppPredicate != nullptr) if (ppPredicate != nullptr)
*ppPredicate = m_state.pr.predicateObject.ref(); *ppPredicate = m_state.pr.predicateObject.ref();
@ -307,6 +329,8 @@ namespace dxvk {
UINT SrcSubresource, UINT SrcSubresource,
const D3D11_BOX* pSrcBox, const D3D11_BOX* pSrcBox,
UINT CopyFlags) { UINT CopyFlags) {
D3D10DeviceLock lock = LockContext();
D3D11_RESOURCE_DIMENSION dstResourceDim = D3D11_RESOURCE_DIMENSION_UNKNOWN; D3D11_RESOURCE_DIMENSION dstResourceDim = D3D11_RESOURCE_DIMENSION_UNKNOWN;
D3D11_RESOURCE_DIMENSION srcResourceDim = D3D11_RESOURCE_DIMENSION_UNKNOWN; D3D11_RESOURCE_DIMENSION srcResourceDim = D3D11_RESOURCE_DIMENSION_UNKNOWN;
@ -526,6 +550,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::CopyResource( void STDMETHODCALLTYPE D3D11DeviceContext::CopyResource(
ID3D11Resource* pDstResource, ID3D11Resource* pDstResource,
ID3D11Resource* pSrcResource) { ID3D11Resource* pSrcResource) {
D3D10DeviceLock lock = LockContext();
if (!pDstResource || !pSrcResource || (pDstResource == pSrcResource)) if (!pDstResource || !pSrcResource || (pDstResource == pSrcResource))
return; return;
@ -624,6 +650,8 @@ namespace dxvk {
ID3D11Buffer* pDstBuffer, ID3D11Buffer* pDstBuffer,
UINT DstAlignedByteOffset, UINT DstAlignedByteOffset,
ID3D11UnorderedAccessView* pSrcView) { ID3D11UnorderedAccessView* pSrcView) {
D3D10DeviceLock lock = LockContext();
auto buf = static_cast<D3D11Buffer*>(pDstBuffer); auto buf = static_cast<D3D11Buffer*>(pDstBuffer);
auto uav = static_cast<D3D11UnorderedAccessView*>(pSrcView); auto uav = static_cast<D3D11UnorderedAccessView*>(pSrcView);
@ -647,6 +675,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::ClearRenderTargetView( void STDMETHODCALLTYPE D3D11DeviceContext::ClearRenderTargetView(
ID3D11RenderTargetView* pRenderTargetView, ID3D11RenderTargetView* pRenderTargetView,
const FLOAT ColorRGBA[4]) { const FLOAT ColorRGBA[4]) {
D3D10DeviceLock lock = LockContext();
auto rtv = static_cast<D3D11RenderTargetView*>(pRenderTargetView); auto rtv = static_cast<D3D11RenderTargetView*>(pRenderTargetView);
if (!rtv) if (!rtv)
@ -675,6 +705,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::ClearUnorderedAccessViewUint( void STDMETHODCALLTYPE D3D11DeviceContext::ClearUnorderedAccessViewUint(
ID3D11UnorderedAccessView* pUnorderedAccessView, ID3D11UnorderedAccessView* pUnorderedAccessView,
const UINT Values[4]) { const UINT Values[4]) {
D3D10DeviceLock lock = LockContext();
auto uav = static_cast<D3D11UnorderedAccessView*>(pUnorderedAccessView); auto uav = static_cast<D3D11UnorderedAccessView*>(pUnorderedAccessView);
if (!uav) if (!uav)
@ -774,6 +806,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::ClearUnorderedAccessViewFloat( void STDMETHODCALLTYPE D3D11DeviceContext::ClearUnorderedAccessViewFloat(
ID3D11UnorderedAccessView* pUnorderedAccessView, ID3D11UnorderedAccessView* pUnorderedAccessView,
const FLOAT Values[4]) { const FLOAT Values[4]) {
D3D10DeviceLock lock = LockContext();
auto uav = static_cast<D3D11UnorderedAccessView*>(pUnorderedAccessView); auto uav = static_cast<D3D11UnorderedAccessView*>(pUnorderedAccessView);
if (!uav) if (!uav)
@ -814,6 +848,8 @@ namespace dxvk {
UINT ClearFlags, UINT ClearFlags,
FLOAT Depth, FLOAT Depth,
UINT8 Stencil) { UINT8 Stencil) {
D3D10DeviceLock lock = LockContext();
auto dsv = static_cast<D3D11DepthStencilView*>(pDepthStencilView); auto dsv = static_cast<D3D11DepthStencilView*>(pDepthStencilView);
if (!dsv) if (!dsv)
@ -855,6 +891,8 @@ namespace dxvk {
const FLOAT Color[4], const FLOAT Color[4],
const D3D11_RECT* pRect, const D3D11_RECT* pRect,
UINT NumRects) { UINT NumRects) {
D3D10DeviceLock lock = LockContext();
// ID3D11View has no methods to query the exact type of // ID3D11View has no methods to query the exact type of
// the view, so we'll have to check each possible class // the view, so we'll have to check each possible class
auto dsv = dynamic_cast<D3D11DepthStencilView*>(pView); auto dsv = dynamic_cast<D3D11DepthStencilView*>(pView);
@ -995,6 +1033,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::GenerateMips(ID3D11ShaderResourceView* pShaderResourceView) { void STDMETHODCALLTYPE D3D11DeviceContext::GenerateMips(ID3D11ShaderResourceView* pShaderResourceView) {
D3D10DeviceLock lock = LockContext();
auto view = static_cast<D3D11ShaderResourceView*>(pShaderResourceView); auto view = static_cast<D3D11ShaderResourceView*>(pShaderResourceView);
if (!view || view->GetResourceType() == D3D11_RESOURCE_DIMENSION_BUFFER) if (!view || view->GetResourceType() == D3D11_RESOURCE_DIMENSION_BUFFER)
@ -1028,6 +1068,8 @@ namespace dxvk {
UINT SrcRowPitch, UINT SrcRowPitch,
UINT SrcDepthPitch, UINT SrcDepthPitch,
UINT CopyFlags) { UINT CopyFlags) {
D3D10DeviceLock lock = LockContext();
if (!pDstResource) if (!pDstResource)
return; return;
@ -1167,6 +1209,8 @@ namespace dxvk {
ID3D11Resource* pSrcResource, ID3D11Resource* pSrcResource,
UINT SrcSubresource, UINT SrcSubresource,
DXGI_FORMAT Format) { DXGI_FORMAT Format) {
D3D10DeviceLock lock = LockContext();
bool isSameSubresource = pDstResource == pSrcResource bool isSameSubresource = pDstResource == pSrcResource
&& DstSubresource == SrcSubresource; && DstSubresource == SrcSubresource;
@ -1265,6 +1309,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::DrawAuto() { void STDMETHODCALLTYPE D3D11DeviceContext::DrawAuto() {
D3D10DeviceLock lock = LockContext();
D3D11Buffer* buffer = m_state.ia.vertexBuffers[0].buffer.ptr(); D3D11Buffer* buffer = m_state.ia.vertexBuffers[0].buffer.ptr();
if (buffer == nullptr) if (buffer == nullptr)
@ -1287,6 +1333,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::Draw( void STDMETHODCALLTYPE D3D11DeviceContext::Draw(
UINT VertexCount, UINT VertexCount,
UINT StartVertexLocation) { UINT StartVertexLocation) {
D3D10DeviceLock lock = LockContext();
EmitCs([=] (DxvkContext* ctx) { EmitCs([=] (DxvkContext* ctx) {
ctx->draw( ctx->draw(
VertexCount, 1, VertexCount, 1,
@ -1299,6 +1347,8 @@ namespace dxvk {
UINT IndexCount, UINT IndexCount,
UINT StartIndexLocation, UINT StartIndexLocation,
INT BaseVertexLocation) { INT BaseVertexLocation) {
D3D10DeviceLock lock = LockContext();
EmitCs([=] (DxvkContext* ctx) { EmitCs([=] (DxvkContext* ctx) {
ctx->drawIndexed( ctx->drawIndexed(
IndexCount, 1, IndexCount, 1,
@ -1313,6 +1363,8 @@ namespace dxvk {
UINT InstanceCount, UINT InstanceCount,
UINT StartVertexLocation, UINT StartVertexLocation,
UINT StartInstanceLocation) { UINT StartInstanceLocation) {
D3D10DeviceLock lock = LockContext();
EmitCs([=] (DxvkContext* ctx) { EmitCs([=] (DxvkContext* ctx) {
ctx->draw( ctx->draw(
VertexCountPerInstance, VertexCountPerInstance,
@ -1329,6 +1381,8 @@ namespace dxvk {
UINT StartIndexLocation, UINT StartIndexLocation,
INT BaseVertexLocation, INT BaseVertexLocation,
UINT StartInstanceLocation) { UINT StartInstanceLocation) {
D3D10DeviceLock lock = LockContext();
EmitCs([=] (DxvkContext* ctx) { EmitCs([=] (DxvkContext* ctx) {
ctx->drawIndexed( ctx->drawIndexed(
IndexCountPerInstance, IndexCountPerInstance,
@ -1343,6 +1397,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::DrawIndexedInstancedIndirect( void STDMETHODCALLTYPE D3D11DeviceContext::DrawIndexedInstancedIndirect(
ID3D11Buffer* pBufferForArgs, ID3D11Buffer* pBufferForArgs,
UINT AlignedByteOffsetForArgs) { UINT AlignedByteOffsetForArgs) {
D3D10DeviceLock lock = LockContext();
SetDrawBuffer(pBufferForArgs); SetDrawBuffer(pBufferForArgs);
EmitCs([cOffset = AlignedByteOffsetForArgs] EmitCs([cOffset = AlignedByteOffsetForArgs]
@ -1355,6 +1411,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::DrawInstancedIndirect( void STDMETHODCALLTYPE D3D11DeviceContext::DrawInstancedIndirect(
ID3D11Buffer* pBufferForArgs, ID3D11Buffer* pBufferForArgs,
UINT AlignedByteOffsetForArgs) { UINT AlignedByteOffsetForArgs) {
D3D10DeviceLock lock = LockContext();
SetDrawBuffer(pBufferForArgs); SetDrawBuffer(pBufferForArgs);
EmitCs([cOffset = AlignedByteOffsetForArgs] EmitCs([cOffset = AlignedByteOffsetForArgs]
@ -1368,6 +1426,8 @@ namespace dxvk {
UINT ThreadGroupCountX, UINT ThreadGroupCountX,
UINT ThreadGroupCountY, UINT ThreadGroupCountY,
UINT ThreadGroupCountZ) { UINT ThreadGroupCountZ) {
D3D10DeviceLock lock = LockContext();
EmitCs([=] (DxvkContext* ctx) { EmitCs([=] (DxvkContext* ctx) {
ctx->dispatch( ctx->dispatch(
ThreadGroupCountX, ThreadGroupCountX,
@ -1380,6 +1440,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::DispatchIndirect( void STDMETHODCALLTYPE D3D11DeviceContext::DispatchIndirect(
ID3D11Buffer* pBufferForArgs, ID3D11Buffer* pBufferForArgs,
UINT AlignedByteOffsetForArgs) { UINT AlignedByteOffsetForArgs) {
D3D10DeviceLock lock = LockContext();
SetDrawBuffer(pBufferForArgs); SetDrawBuffer(pBufferForArgs);
EmitCs([cOffset = AlignedByteOffsetForArgs] EmitCs([cOffset = AlignedByteOffsetForArgs]
@ -1390,6 +1452,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::IASetInputLayout(ID3D11InputLayout* pInputLayout) { void STDMETHODCALLTYPE D3D11DeviceContext::IASetInputLayout(ID3D11InputLayout* pInputLayout) {
D3D10DeviceLock lock = LockContext();
auto inputLayout = static_cast<D3D11InputLayout*>(pInputLayout); auto inputLayout = static_cast<D3D11InputLayout*>(pInputLayout);
if (m_state.ia.inputLayout != inputLayout) { if (m_state.ia.inputLayout != inputLayout) {
@ -1410,6 +1474,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::IASetPrimitiveTopology(D3D11_PRIMITIVE_TOPOLOGY Topology) { void STDMETHODCALLTYPE D3D11DeviceContext::IASetPrimitiveTopology(D3D11_PRIMITIVE_TOPOLOGY Topology) {
D3D10DeviceLock lock = LockContext();
if (m_state.ia.primitiveTopology != Topology) { if (m_state.ia.primitiveTopology != Topology) {
m_state.ia.primitiveTopology = Topology; m_state.ia.primitiveTopology = Topology;
ApplyPrimitiveTopology(); ApplyPrimitiveTopology();
@ -1423,6 +1489,8 @@ namespace dxvk {
ID3D11Buffer* const* ppVertexBuffers, ID3D11Buffer* const* ppVertexBuffers,
const UINT* pStrides, const UINT* pStrides,
const UINT* pOffsets) { const UINT* pOffsets) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumBuffers; i++) { for (uint32_t i = 0; i < NumBuffers; i++) {
auto newBuffer = static_cast<D3D11Buffer*>(ppVertexBuffers[i]); auto newBuffer = static_cast<D3D11Buffer*>(ppVertexBuffers[i]);
@ -1439,6 +1507,8 @@ namespace dxvk {
ID3D11Buffer* pIndexBuffer, ID3D11Buffer* pIndexBuffer,
DXGI_FORMAT Format, DXGI_FORMAT Format,
UINT Offset) { UINT Offset) {
D3D10DeviceLock lock = LockContext();
auto newBuffer = static_cast<D3D11Buffer*>(pIndexBuffer); auto newBuffer = static_cast<D3D11Buffer*>(pIndexBuffer);
m_state.ia.indexBuffer.buffer = newBuffer; m_state.ia.indexBuffer.buffer = newBuffer;
@ -1450,11 +1520,15 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::IAGetInputLayout(ID3D11InputLayout** ppInputLayout) { void STDMETHODCALLTYPE D3D11DeviceContext::IAGetInputLayout(ID3D11InputLayout** ppInputLayout) {
D3D10DeviceLock lock = LockContext();
*ppInputLayout = m_state.ia.inputLayout.ref(); *ppInputLayout = m_state.ia.inputLayout.ref();
} }
void STDMETHODCALLTYPE D3D11DeviceContext::IAGetPrimitiveTopology(D3D11_PRIMITIVE_TOPOLOGY* pTopology) { void STDMETHODCALLTYPE D3D11DeviceContext::IAGetPrimitiveTopology(D3D11_PRIMITIVE_TOPOLOGY* pTopology) {
D3D10DeviceLock lock = LockContext();
*pTopology = m_state.ia.primitiveTopology; *pTopology = m_state.ia.primitiveTopology;
} }
@ -1465,6 +1539,8 @@ namespace dxvk {
ID3D11Buffer** ppVertexBuffers, ID3D11Buffer** ppVertexBuffers,
UINT* pStrides, UINT* pStrides,
UINT* pOffsets) { UINT* pOffsets) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumBuffers; i++) { for (uint32_t i = 0; i < NumBuffers; i++) {
if (ppVertexBuffers != nullptr) if (ppVertexBuffers != nullptr)
ppVertexBuffers[i] = m_state.ia.vertexBuffers[StartSlot + i].buffer.ref(); ppVertexBuffers[i] = m_state.ia.vertexBuffers[StartSlot + i].buffer.ref();
@ -1482,6 +1558,8 @@ namespace dxvk {
ID3D11Buffer** ppIndexBuffer, ID3D11Buffer** ppIndexBuffer,
DXGI_FORMAT* pFormat, DXGI_FORMAT* pFormat,
UINT* pOffset) { UINT* pOffset) {
D3D10DeviceLock lock = LockContext();
if (ppIndexBuffer != nullptr) if (ppIndexBuffer != nullptr)
*ppIndexBuffer = m_state.ia.indexBuffer.buffer.ref(); *ppIndexBuffer = m_state.ia.indexBuffer.buffer.ref();
@ -1497,6 +1575,8 @@ namespace dxvk {
ID3D11VertexShader* pVertexShader, ID3D11VertexShader* pVertexShader,
ID3D11ClassInstance* const* ppClassInstances, ID3D11ClassInstance* const* ppClassInstances,
UINT NumClassInstances) { UINT NumClassInstances) {
D3D10DeviceLock lock = LockContext();
auto shader = static_cast<D3D11VertexShader*>(pVertexShader); auto shader = static_cast<D3D11VertexShader*>(pVertexShader);
if (NumClassInstances != 0) if (NumClassInstances != 0)
@ -1516,6 +1596,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer* const* ppConstantBuffers) { ID3D11Buffer* const* ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::VertexShader, DxbcProgramType::VertexShader,
m_state.vs.constantBuffers, m_state.vs.constantBuffers,
@ -1531,6 +1613,8 @@ namespace dxvk {
ID3D11Buffer* const* ppConstantBuffers, ID3D11Buffer* const* ppConstantBuffers,
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants) { const UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::VertexShader, DxbcProgramType::VertexShader,
m_state.vs.constantBuffers, m_state.vs.constantBuffers,
@ -1545,6 +1629,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) { ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources( SetShaderResources(
DxbcProgramType::VertexShader, DxbcProgramType::VertexShader,
m_state.vs.shaderResources, m_state.vs.shaderResources,
@ -1557,6 +1643,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers) { ID3D11SamplerState* const* ppSamplers) {
D3D10DeviceLock lock = LockContext();
SetSamplers( SetSamplers(
DxbcProgramType::VertexShader, DxbcProgramType::VertexShader,
m_state.vs.samplers, m_state.vs.samplers,
@ -1569,6 +1657,8 @@ namespace dxvk {
ID3D11VertexShader** ppVertexShader, ID3D11VertexShader** ppVertexShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
UINT* pNumClassInstances) { UINT* pNumClassInstances) {
D3D10DeviceLock lock = LockContext();
if (ppVertexShader != nullptr) if (ppVertexShader != nullptr)
*ppVertexShader = m_state.vs.shader.ref(); *ppVertexShader = m_state.vs.shader.ref();
@ -1581,6 +1671,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer** ppConstantBuffers) { ID3D11Buffer** ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.vs.constantBuffers, m_state.vs.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -1595,6 +1687,8 @@ namespace dxvk {
ID3D11Buffer** ppConstantBuffers, ID3D11Buffer** ppConstantBuffers,
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants) { UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.vs.constantBuffers, m_state.vs.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -1608,6 +1702,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) { ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumViews; i++) for (uint32_t i = 0; i < NumViews; i++)
ppShaderResourceViews[i] = m_state.vs.shaderResources.at(StartSlot + i).ref(); ppShaderResourceViews[i] = m_state.vs.shaderResources.at(StartSlot + i).ref();
} }
@ -1617,6 +1713,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState** ppSamplers) { ID3D11SamplerState** ppSamplers) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumSamplers; i++) for (uint32_t i = 0; i < NumSamplers; i++)
ppSamplers[i] = m_state.vs.samplers.at(StartSlot + i).ref(); ppSamplers[i] = m_state.vs.samplers.at(StartSlot + i).ref();
} }
@ -1626,6 +1724,8 @@ namespace dxvk {
ID3D11HullShader* pHullShader, ID3D11HullShader* pHullShader,
ID3D11ClassInstance* const* ppClassInstances, ID3D11ClassInstance* const* ppClassInstances,
UINT NumClassInstances) { UINT NumClassInstances) {
D3D10DeviceLock lock = LockContext();
auto shader = static_cast<D3D11HullShader*>(pHullShader); auto shader = static_cast<D3D11HullShader*>(pHullShader);
if (NumClassInstances != 0) if (NumClassInstances != 0)
@ -1645,6 +1745,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) { ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources( SetShaderResources(
DxbcProgramType::HullShader, DxbcProgramType::HullShader,
m_state.hs.shaderResources, m_state.hs.shaderResources,
@ -1657,6 +1759,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer* const* ppConstantBuffers) { ID3D11Buffer* const* ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::HullShader, DxbcProgramType::HullShader,
m_state.hs.constantBuffers, m_state.hs.constantBuffers,
@ -1672,6 +1776,8 @@ namespace dxvk {
ID3D11Buffer* const* ppConstantBuffers, ID3D11Buffer* const* ppConstantBuffers,
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants) { const UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::HullShader, DxbcProgramType::HullShader,
m_state.hs.constantBuffers, m_state.hs.constantBuffers,
@ -1686,6 +1792,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers) { ID3D11SamplerState* const* ppSamplers) {
D3D10DeviceLock lock = LockContext();
SetSamplers( SetSamplers(
DxbcProgramType::HullShader, DxbcProgramType::HullShader,
m_state.hs.samplers, m_state.hs.samplers,
@ -1698,6 +1806,8 @@ namespace dxvk {
ID3D11HullShader** ppHullShader, ID3D11HullShader** ppHullShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
UINT* pNumClassInstances) { UINT* pNumClassInstances) {
D3D10DeviceLock lock = LockContext();
if (ppHullShader != nullptr) if (ppHullShader != nullptr)
*ppHullShader = m_state.hs.shader.ref(); *ppHullShader = m_state.hs.shader.ref();
@ -1710,6 +1820,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer** ppConstantBuffers) { ID3D11Buffer** ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.hs.constantBuffers, m_state.hs.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -1724,6 +1836,8 @@ namespace dxvk {
ID3D11Buffer** ppConstantBuffers, ID3D11Buffer** ppConstantBuffers,
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants) { UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.hs.constantBuffers, m_state.hs.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -1737,6 +1851,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) { ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumViews; i++) for (uint32_t i = 0; i < NumViews; i++)
ppShaderResourceViews[i] = m_state.hs.shaderResources.at(StartSlot + i).ref(); ppShaderResourceViews[i] = m_state.hs.shaderResources.at(StartSlot + i).ref();
} }
@ -1746,6 +1862,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState** ppSamplers) { ID3D11SamplerState** ppSamplers) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumSamplers; i++) for (uint32_t i = 0; i < NumSamplers; i++)
ppSamplers[i] = m_state.hs.samplers.at(StartSlot + i).ref(); ppSamplers[i] = m_state.hs.samplers.at(StartSlot + i).ref();
} }
@ -1755,6 +1873,8 @@ namespace dxvk {
ID3D11DomainShader* pDomainShader, ID3D11DomainShader* pDomainShader,
ID3D11ClassInstance* const* ppClassInstances, ID3D11ClassInstance* const* ppClassInstances,
UINT NumClassInstances) { UINT NumClassInstances) {
D3D10DeviceLock lock = LockContext();
auto shader = static_cast<D3D11DomainShader*>(pDomainShader); auto shader = static_cast<D3D11DomainShader*>(pDomainShader);
if (NumClassInstances != 0) if (NumClassInstances != 0)
@ -1774,6 +1894,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) { ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources( SetShaderResources(
DxbcProgramType::DomainShader, DxbcProgramType::DomainShader,
m_state.ds.shaderResources, m_state.ds.shaderResources,
@ -1786,6 +1908,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer* const* ppConstantBuffers) { ID3D11Buffer* const* ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::DomainShader, DxbcProgramType::DomainShader,
m_state.ds.constantBuffers, m_state.ds.constantBuffers,
@ -1801,6 +1925,8 @@ namespace dxvk {
ID3D11Buffer* const* ppConstantBuffers, ID3D11Buffer* const* ppConstantBuffers,
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants) { const UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::DomainShader, DxbcProgramType::DomainShader,
m_state.ds.constantBuffers, m_state.ds.constantBuffers,
@ -1815,6 +1941,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers) { ID3D11SamplerState* const* ppSamplers) {
D3D10DeviceLock lock = LockContext();
SetSamplers( SetSamplers(
DxbcProgramType::DomainShader, DxbcProgramType::DomainShader,
m_state.ds.samplers, m_state.ds.samplers,
@ -1827,6 +1955,8 @@ namespace dxvk {
ID3D11DomainShader** ppDomainShader, ID3D11DomainShader** ppDomainShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
UINT* pNumClassInstances) { UINT* pNumClassInstances) {
D3D10DeviceLock lock = LockContext();
if (ppDomainShader != nullptr) if (ppDomainShader != nullptr)
*ppDomainShader = m_state.ds.shader.ref(); *ppDomainShader = m_state.ds.shader.ref();
@ -1839,6 +1969,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer** ppConstantBuffers) { ID3D11Buffer** ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.ds.constantBuffers, m_state.ds.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -1853,6 +1985,8 @@ namespace dxvk {
ID3D11Buffer** ppConstantBuffers, ID3D11Buffer** ppConstantBuffers,
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants) { UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.ds.constantBuffers, m_state.ds.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -1866,6 +2000,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) { ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumViews; i++) for (uint32_t i = 0; i < NumViews; i++)
ppShaderResourceViews[i] = m_state.ds.shaderResources.at(StartSlot + i).ref(); ppShaderResourceViews[i] = m_state.ds.shaderResources.at(StartSlot + i).ref();
} }
@ -1875,6 +2011,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState** ppSamplers) { ID3D11SamplerState** ppSamplers) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumSamplers; i++) for (uint32_t i = 0; i < NumSamplers; i++)
ppSamplers[i] = m_state.ds.samplers.at(StartSlot + i).ref(); ppSamplers[i] = m_state.ds.samplers.at(StartSlot + i).ref();
} }
@ -1884,6 +2022,8 @@ namespace dxvk {
ID3D11GeometryShader* pShader, ID3D11GeometryShader* pShader,
ID3D11ClassInstance* const* ppClassInstances, ID3D11ClassInstance* const* ppClassInstances,
UINT NumClassInstances) { UINT NumClassInstances) {
D3D10DeviceLock lock = LockContext();
auto shader = static_cast<D3D11GeometryShader*>(pShader); auto shader = static_cast<D3D11GeometryShader*>(pShader);
if (NumClassInstances != 0) if (NumClassInstances != 0)
@ -1903,6 +2043,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer* const* ppConstantBuffers) { ID3D11Buffer* const* ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::GeometryShader, DxbcProgramType::GeometryShader,
m_state.gs.constantBuffers, m_state.gs.constantBuffers,
@ -1918,6 +2060,8 @@ namespace dxvk {
ID3D11Buffer* const* ppConstantBuffers, ID3D11Buffer* const* ppConstantBuffers,
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants) { const UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::GeometryShader, DxbcProgramType::GeometryShader,
m_state.gs.constantBuffers, m_state.gs.constantBuffers,
@ -1932,6 +2076,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) { ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources( SetShaderResources(
DxbcProgramType::GeometryShader, DxbcProgramType::GeometryShader,
m_state.gs.shaderResources, m_state.gs.shaderResources,
@ -1944,6 +2090,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers) { ID3D11SamplerState* const* ppSamplers) {
D3D10DeviceLock lock = LockContext();
SetSamplers( SetSamplers(
DxbcProgramType::GeometryShader, DxbcProgramType::GeometryShader,
m_state.gs.samplers, m_state.gs.samplers,
@ -1956,6 +2104,8 @@ namespace dxvk {
ID3D11GeometryShader** ppGeometryShader, ID3D11GeometryShader** ppGeometryShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
UINT* pNumClassInstances) { UINT* pNumClassInstances) {
D3D10DeviceLock lock = LockContext();
if (ppGeometryShader != nullptr) if (ppGeometryShader != nullptr)
*ppGeometryShader = m_state.gs.shader.ref(); *ppGeometryShader = m_state.gs.shader.ref();
@ -1968,6 +2118,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer** ppConstantBuffers) { ID3D11Buffer** ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.gs.constantBuffers, m_state.gs.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -1982,6 +2134,8 @@ namespace dxvk {
ID3D11Buffer** ppConstantBuffers, ID3D11Buffer** ppConstantBuffers,
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants) { UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.gs.constantBuffers, m_state.gs.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -1995,6 +2149,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) { ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumViews; i++) for (uint32_t i = 0; i < NumViews; i++)
ppShaderResourceViews[i] = m_state.gs.shaderResources.at(StartSlot + i).ref(); ppShaderResourceViews[i] = m_state.gs.shaderResources.at(StartSlot + i).ref();
} }
@ -2004,6 +2160,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState** ppSamplers) { ID3D11SamplerState** ppSamplers) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumSamplers; i++) for (uint32_t i = 0; i < NumSamplers; i++)
ppSamplers[i] = m_state.gs.samplers.at(StartSlot + i).ref(); ppSamplers[i] = m_state.gs.samplers.at(StartSlot + i).ref();
} }
@ -2013,6 +2171,8 @@ namespace dxvk {
ID3D11PixelShader* pPixelShader, ID3D11PixelShader* pPixelShader,
ID3D11ClassInstance* const* ppClassInstances, ID3D11ClassInstance* const* ppClassInstances,
UINT NumClassInstances) { UINT NumClassInstances) {
D3D10DeviceLock lock = LockContext();
auto shader = static_cast<D3D11PixelShader*>(pPixelShader); auto shader = static_cast<D3D11PixelShader*>(pPixelShader);
if (NumClassInstances != 0) if (NumClassInstances != 0)
@ -2032,6 +2192,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer* const* ppConstantBuffers) { ID3D11Buffer* const* ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::PixelShader, DxbcProgramType::PixelShader,
m_state.ps.constantBuffers, m_state.ps.constantBuffers,
@ -2047,6 +2209,8 @@ namespace dxvk {
ID3D11Buffer* const* ppConstantBuffers, ID3D11Buffer* const* ppConstantBuffers,
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants) { const UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::PixelShader, DxbcProgramType::PixelShader,
m_state.ps.constantBuffers, m_state.ps.constantBuffers,
@ -2061,6 +2225,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) { ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources( SetShaderResources(
DxbcProgramType::PixelShader, DxbcProgramType::PixelShader,
m_state.ps.shaderResources, m_state.ps.shaderResources,
@ -2073,6 +2239,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers) { ID3D11SamplerState* const* ppSamplers) {
D3D10DeviceLock lock = LockContext();
SetSamplers( SetSamplers(
DxbcProgramType::PixelShader, DxbcProgramType::PixelShader,
m_state.ps.samplers, m_state.ps.samplers,
@ -2085,6 +2253,8 @@ namespace dxvk {
ID3D11PixelShader** ppPixelShader, ID3D11PixelShader** ppPixelShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
UINT* pNumClassInstances) { UINT* pNumClassInstances) {
D3D10DeviceLock lock = LockContext();
if (ppPixelShader != nullptr) if (ppPixelShader != nullptr)
*ppPixelShader = m_state.ps.shader.ref(); *ppPixelShader = m_state.ps.shader.ref();
@ -2097,6 +2267,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer** ppConstantBuffers) { ID3D11Buffer** ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.ps.constantBuffers, m_state.ps.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -2111,6 +2283,8 @@ namespace dxvk {
ID3D11Buffer** ppConstantBuffers, ID3D11Buffer** ppConstantBuffers,
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants) { UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.ps.constantBuffers, m_state.ps.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -2124,6 +2298,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) { ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumViews; i++) for (uint32_t i = 0; i < NumViews; i++)
ppShaderResourceViews[i] = m_state.ps.shaderResources.at(StartSlot + i).ref(); ppShaderResourceViews[i] = m_state.ps.shaderResources.at(StartSlot + i).ref();
} }
@ -2133,6 +2309,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState** ppSamplers) { ID3D11SamplerState** ppSamplers) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumSamplers; i++) for (uint32_t i = 0; i < NumSamplers; i++)
ppSamplers[i] = m_state.ps.samplers.at(StartSlot + i).ref(); ppSamplers[i] = m_state.ps.samplers.at(StartSlot + i).ref();
} }
@ -2142,6 +2320,8 @@ namespace dxvk {
ID3D11ComputeShader* pComputeShader, ID3D11ComputeShader* pComputeShader,
ID3D11ClassInstance* const* ppClassInstances, ID3D11ClassInstance* const* ppClassInstances,
UINT NumClassInstances) { UINT NumClassInstances) {
D3D10DeviceLock lock = LockContext();
auto shader = static_cast<D3D11ComputeShader*>(pComputeShader); auto shader = static_cast<D3D11ComputeShader*>(pComputeShader);
if (NumClassInstances != 0) if (NumClassInstances != 0)
@ -2161,6 +2341,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer* const* ppConstantBuffers) { ID3D11Buffer* const* ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::ComputeShader, DxbcProgramType::ComputeShader,
m_state.cs.constantBuffers, m_state.cs.constantBuffers,
@ -2176,6 +2358,8 @@ namespace dxvk {
ID3D11Buffer* const* ppConstantBuffers, ID3D11Buffer* const* ppConstantBuffers,
const UINT* pFirstConstant, const UINT* pFirstConstant,
const UINT* pNumConstants) { const UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
SetConstantBuffers( SetConstantBuffers(
DxbcProgramType::ComputeShader, DxbcProgramType::ComputeShader,
m_state.cs.constantBuffers, m_state.cs.constantBuffers,
@ -2190,6 +2374,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView* const* ppShaderResourceViews) { ID3D11ShaderResourceView* const* ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
SetShaderResources( SetShaderResources(
DxbcProgramType::ComputeShader, DxbcProgramType::ComputeShader,
m_state.cs.shaderResources, m_state.cs.shaderResources,
@ -2202,6 +2388,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState* const* ppSamplers) { ID3D11SamplerState* const* ppSamplers) {
D3D10DeviceLock lock = LockContext();
SetSamplers( SetSamplers(
DxbcProgramType::ComputeShader, DxbcProgramType::ComputeShader,
m_state.cs.samplers, m_state.cs.samplers,
@ -2215,6 +2403,8 @@ namespace dxvk {
UINT NumUAVs, UINT NumUAVs,
ID3D11UnorderedAccessView* const* ppUnorderedAccessViews, ID3D11UnorderedAccessView* const* ppUnorderedAccessViews,
const UINT* pUAVInitialCounts) { const UINT* pUAVInitialCounts) {
D3D10DeviceLock lock = LockContext();
SetUnorderedAccessViews( SetUnorderedAccessViews(
DxbcProgramType::ComputeShader, DxbcProgramType::ComputeShader,
m_state.cs.unorderedAccessViews, m_state.cs.unorderedAccessViews,
@ -2228,6 +2418,8 @@ namespace dxvk {
ID3D11ComputeShader** ppComputeShader, ID3D11ComputeShader** ppComputeShader,
ID3D11ClassInstance** ppClassInstances, ID3D11ClassInstance** ppClassInstances,
UINT* pNumClassInstances) { UINT* pNumClassInstances) {
D3D10DeviceLock lock = LockContext();
if (ppComputeShader != nullptr) if (ppComputeShader != nullptr)
*ppComputeShader = m_state.cs.shader.ref(); *ppComputeShader = m_state.cs.shader.ref();
@ -2240,6 +2432,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer** ppConstantBuffers) { ID3D11Buffer** ppConstantBuffers) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.cs.constantBuffers, m_state.cs.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -2254,6 +2448,8 @@ namespace dxvk {
ID3D11Buffer** ppConstantBuffers, ID3D11Buffer** ppConstantBuffers,
UINT* pFirstConstant, UINT* pFirstConstant,
UINT* pNumConstants) { UINT* pNumConstants) {
D3D10DeviceLock lock = LockContext();
GetConstantBuffers( GetConstantBuffers(
m_state.cs.constantBuffers, m_state.cs.constantBuffers,
StartSlot, NumBuffers, StartSlot, NumBuffers,
@ -2267,6 +2463,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumViews, UINT NumViews,
ID3D11ShaderResourceView** ppShaderResourceViews) { ID3D11ShaderResourceView** ppShaderResourceViews) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumViews; i++) for (uint32_t i = 0; i < NumViews; i++)
ppShaderResourceViews[i] = m_state.cs.shaderResources.at(StartSlot + i).ref(); ppShaderResourceViews[i] = m_state.cs.shaderResources.at(StartSlot + i).ref();
} }
@ -2276,6 +2474,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumSamplers, UINT NumSamplers,
ID3D11SamplerState** ppSamplers) { ID3D11SamplerState** ppSamplers) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumSamplers; i++) for (uint32_t i = 0; i < NumSamplers; i++)
ppSamplers[i] = m_state.cs.samplers.at(StartSlot + i).ref(); ppSamplers[i] = m_state.cs.samplers.at(StartSlot + i).ref();
} }
@ -2285,6 +2485,8 @@ namespace dxvk {
UINT StartSlot, UINT StartSlot,
UINT NumUAVs, UINT NumUAVs,
ID3D11UnorderedAccessView** ppUnorderedAccessViews) { ID3D11UnorderedAccessView** ppUnorderedAccessViews) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumUAVs; i++) for (uint32_t i = 0; i < NumUAVs; i++)
ppUnorderedAccessViews[i] = m_state.cs.unorderedAccessViews.at(StartSlot + i).ref(); ppUnorderedAccessViews[i] = m_state.cs.unorderedAccessViews.at(StartSlot + i).ref();
} }
@ -2294,6 +2496,8 @@ namespace dxvk {
UINT NumViews, UINT NumViews,
ID3D11RenderTargetView* const* ppRenderTargetViews, ID3D11RenderTargetView* const* ppRenderTargetViews,
ID3D11DepthStencilView* pDepthStencilView) { ID3D11DepthStencilView* pDepthStencilView) {
D3D10DeviceLock lock = LockContext();
SetRenderTargets(NumViews, ppRenderTargetViews, pDepthStencilView); SetRenderTargets(NumViews, ppRenderTargetViews, pDepthStencilView);
BindFramebuffer(false); BindFramebuffer(false);
} }
@ -2307,6 +2511,8 @@ namespace dxvk {
UINT NumUAVs, UINT NumUAVs,
ID3D11UnorderedAccessView* const* ppUnorderedAccessViews, ID3D11UnorderedAccessView* const* ppUnorderedAccessViews,
const UINT* pUAVInitialCounts) { const UINT* pUAVInitialCounts) {
D3D10DeviceLock lock = LockContext();
bool isUavRendering = false; bool isUavRendering = false;
if (NumRTVs != D3D11_KEEP_RENDER_TARGETS_AND_DEPTH_STENCIL) if (NumRTVs != D3D11_KEEP_RENDER_TARGETS_AND_DEPTH_STENCIL)
@ -2336,6 +2542,8 @@ namespace dxvk {
ID3D11BlendState* pBlendState, ID3D11BlendState* pBlendState,
const FLOAT BlendFactor[4], const FLOAT BlendFactor[4],
UINT SampleMask) { UINT SampleMask) {
D3D10DeviceLock lock = LockContext();
auto blendState = static_cast<D3D11BlendState*>(pBlendState); auto blendState = static_cast<D3D11BlendState*>(pBlendState);
if (m_state.om.cbState != blendState if (m_state.om.cbState != blendState
@ -2358,6 +2566,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::OMSetDepthStencilState( void STDMETHODCALLTYPE D3D11DeviceContext::OMSetDepthStencilState(
ID3D11DepthStencilState* pDepthStencilState, ID3D11DepthStencilState* pDepthStencilState,
UINT StencilRef) { UINT StencilRef) {
D3D10DeviceLock lock = LockContext();
auto depthStencilState = static_cast<D3D11DepthStencilState*>(pDepthStencilState); auto depthStencilState = static_cast<D3D11DepthStencilState*>(pDepthStencilState);
if (m_state.om.dsState != depthStencilState) { if (m_state.om.dsState != depthStencilState) {
@ -2376,6 +2586,8 @@ namespace dxvk {
UINT NumViews, UINT NumViews,
ID3D11RenderTargetView** ppRenderTargetViews, ID3D11RenderTargetView** ppRenderTargetViews,
ID3D11DepthStencilView** ppDepthStencilView) { ID3D11DepthStencilView** ppDepthStencilView) {
D3D10DeviceLock lock = LockContext();
if (ppRenderTargetViews != nullptr) { if (ppRenderTargetViews != nullptr) {
for (UINT i = 0; i < NumViews; i++) for (UINT i = 0; i < NumViews; i++)
ppRenderTargetViews[i] = m_state.om.renderTargetViews[i].ref(); ppRenderTargetViews[i] = m_state.om.renderTargetViews[i].ref();
@ -2395,6 +2607,8 @@ namespace dxvk {
ID3D11UnorderedAccessView** ppUnorderedAccessViews) { ID3D11UnorderedAccessView** ppUnorderedAccessViews) {
OMGetRenderTargets(NumRTVs, ppRenderTargetViews, ppDepthStencilView); OMGetRenderTargets(NumRTVs, ppRenderTargetViews, ppDepthStencilView);
D3D10DeviceLock lock = LockContext();
if (ppUnorderedAccessViews != nullptr) { if (ppUnorderedAccessViews != nullptr) {
for (UINT i = 0; i < NumUAVs; i++) for (UINT i = 0; i < NumUAVs; i++)
ppUnorderedAccessViews[i] = m_state.ps.unorderedAccessViews[UAVStartSlot + i].ref(); ppUnorderedAccessViews[i] = m_state.ps.unorderedAccessViews[UAVStartSlot + i].ref();
@ -2406,6 +2620,8 @@ namespace dxvk {
ID3D11BlendState** ppBlendState, ID3D11BlendState** ppBlendState,
FLOAT BlendFactor[4], FLOAT BlendFactor[4],
UINT* pSampleMask) { UINT* pSampleMask) {
D3D10DeviceLock lock = LockContext();
if (ppBlendState != nullptr) if (ppBlendState != nullptr)
*ppBlendState = m_state.om.cbState.ref(); *ppBlendState = m_state.om.cbState.ref();
@ -2420,6 +2636,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::OMGetDepthStencilState( void STDMETHODCALLTYPE D3D11DeviceContext::OMGetDepthStencilState(
ID3D11DepthStencilState** ppDepthStencilState, ID3D11DepthStencilState** ppDepthStencilState,
UINT* pStencilRef) { UINT* pStencilRef) {
D3D10DeviceLock lock = LockContext();
if (ppDepthStencilState != nullptr) if (ppDepthStencilState != nullptr)
*ppDepthStencilState = m_state.om.dsState.ref(); *ppDepthStencilState = m_state.om.dsState.ref();
@ -2429,6 +2647,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::RSSetState(ID3D11RasterizerState* pRasterizerState) { void STDMETHODCALLTYPE D3D11DeviceContext::RSSetState(ID3D11RasterizerState* pRasterizerState) {
D3D10DeviceLock lock = LockContext();
auto rasterizerState = static_cast<D3D11RasterizerState*>(pRasterizerState); auto rasterizerState = static_cast<D3D11RasterizerState*>(pRasterizerState);
if (m_state.rs.state != rasterizerState) { if (m_state.rs.state != rasterizerState) {
@ -2446,6 +2666,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::RSSetViewports( void STDMETHODCALLTYPE D3D11DeviceContext::RSSetViewports(
UINT NumViewports, UINT NumViewports,
const D3D11_VIEWPORT* pViewports) { const D3D11_VIEWPORT* pViewports) {
D3D10DeviceLock lock = LockContext();
m_state.rs.numViewports = NumViewports; m_state.rs.numViewports = NumViewports;
for (uint32_t i = 0; i < NumViewports; i++) for (uint32_t i = 0; i < NumViewports; i++)
@ -2458,6 +2680,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::RSSetScissorRects( void STDMETHODCALLTYPE D3D11DeviceContext::RSSetScissorRects(
UINT NumRects, UINT NumRects,
const D3D11_RECT* pRects) { const D3D11_RECT* pRects) {
D3D10DeviceLock lock = LockContext();
m_state.rs.numScissors = NumRects; m_state.rs.numScissors = NumRects;
for (uint32_t i = 0; i < NumRects; i++) { for (uint32_t i = 0; i < NumRects; i++) {
@ -2477,6 +2701,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::RSGetState(ID3D11RasterizerState** ppRasterizerState) { void STDMETHODCALLTYPE D3D11DeviceContext::RSGetState(ID3D11RasterizerState** ppRasterizerState) {
D3D10DeviceLock lock = LockContext();
if (ppRasterizerState != nullptr) if (ppRasterizerState != nullptr)
*ppRasterizerState = m_state.rs.state.ref(); *ppRasterizerState = m_state.rs.state.ref();
} }
@ -2485,6 +2711,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::RSGetViewports( void STDMETHODCALLTYPE D3D11DeviceContext::RSGetViewports(
UINT* pNumViewports, UINT* pNumViewports,
D3D11_VIEWPORT* pViewports) { D3D11_VIEWPORT* pViewports) {
D3D10DeviceLock lock = LockContext();
if (pViewports != nullptr) { if (pViewports != nullptr) {
for (uint32_t i = 0; i < *pNumViewports; i++) { for (uint32_t i = 0; i < *pNumViewports; i++) {
if (i < m_state.rs.numViewports) { if (i < m_state.rs.numViewports) {
@ -2507,6 +2735,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::RSGetScissorRects( void STDMETHODCALLTYPE D3D11DeviceContext::RSGetScissorRects(
UINT* pNumRects, UINT* pNumRects,
D3D11_RECT* pRects) { D3D11_RECT* pRects) {
D3D10DeviceLock lock = LockContext();
if (pRects != nullptr) { if (pRects != nullptr) {
for (uint32_t i = 0; i < *pNumRects; i++) { for (uint32_t i = 0; i < *pNumRects; i++) {
if (i < m_state.rs.numScissors) { if (i < m_state.rs.numScissors) {
@ -2528,6 +2758,8 @@ namespace dxvk {
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer* const* ppSOTargets, ID3D11Buffer* const* ppSOTargets,
const UINT* pOffsets) { const UINT* pOffsets) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumBuffers; i++) { for (uint32_t i = 0; i < NumBuffers; i++) {
D3D11Buffer* buffer = static_cast<D3D11Buffer*>(ppSOTargets[i]); D3D11Buffer* buffer = static_cast<D3D11Buffer*>(ppSOTargets[i]);
UINT offset = pOffsets != nullptr ? pOffsets[i] : 0; UINT offset = pOffsets != nullptr ? pOffsets[i] : 0;
@ -2552,6 +2784,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeviceContext::SOGetTargets( void STDMETHODCALLTYPE D3D11DeviceContext::SOGetTargets(
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer** ppSOTargets) { ID3D11Buffer** ppSOTargets) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumBuffers; i++) for (uint32_t i = 0; i < NumBuffers; i++)
ppSOTargets[i] = m_state.so.targets[i].buffer.ref(); ppSOTargets[i] = m_state.so.targets[i].buffer.ref();
} }
@ -2561,6 +2795,8 @@ namespace dxvk {
UINT NumBuffers, UINT NumBuffers,
ID3D11Buffer** ppSOTargets, ID3D11Buffer** ppSOTargets,
UINT* pOffsets) { UINT* pOffsets) {
D3D10DeviceLock lock = LockContext();
for (uint32_t i = 0; i < NumBuffers; i++) { for (uint32_t i = 0; i < NumBuffers; i++) {
if (ppSOTargets != nullptr) if (ppSOTargets != nullptr)
ppSOTargets[i] = m_state.so.targets[i].buffer.ref(); ppSOTargets[i] = m_state.so.targets[i].buffer.ref();
@ -2576,6 +2812,8 @@ namespace dxvk {
const VkImageSubresourceRange* pSubresources, const VkImageSubresourceRange* pSubresources,
VkImageLayout OldLayout, VkImageLayout OldLayout,
VkImageLayout NewLayout) { VkImageLayout NewLayout) {
D3D10DeviceLock lock = LockContext();
// Get the underlying D3D11 resource // Get the underlying D3D11 resource
Com<ID3D11Resource> resource; Com<ID3D11Resource> resource;

View File

@ -4,6 +4,8 @@
#include "../dxvk/dxvk_cs.h" #include "../dxvk/dxvk_cs.h"
#include "../dxvk/dxvk_device.h" #include "../dxvk/dxvk_device.h"
#include "../d3d10/d3d10_multithread.h"
#include "d3d11_annotation.h" #include "d3d11_annotation.h"
#include "d3d11_context_state.h" #include "d3d11_context_state.h"
#include "d3d11_device_child.h" #include "d3d11_device_child.h"
@ -647,6 +649,7 @@ namespace dxvk {
D3D11Device* const m_parent; D3D11Device* const m_parent;
D3D11UserDefinedAnnotation m_annotation; D3D11UserDefinedAnnotation m_annotation;
D3D10Multithread m_multithread;
Rc<DxvkDevice> m_device; Rc<DxvkDevice> m_device;
Rc<DxvkDataBuffer> m_updateBuffer; Rc<DxvkDataBuffer> m_updateBuffer;
@ -805,6 +808,10 @@ namespace dxvk {
return pShader != nullptr ? pShader->GetCommonShader() : nullptr; return pShader != nullptr ? pShader->GetCommonShader() : nullptr;
} }
D3D10DeviceLock LockContext() {
return m_multithread.AcquireLock();
}
template<typename Cmd> template<typename Cmd>
void EmitCs(Cmd&& command) { void EmitCs(Cmd&& command) {
if (!m_csChunk->push(command)) { if (!m_csChunk->push(command)) {

View File

@ -42,6 +42,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeferredContext::ExecuteCommandList( void STDMETHODCALLTYPE D3D11DeferredContext::ExecuteCommandList(
ID3D11CommandList* pCommandList, ID3D11CommandList* pCommandList,
BOOL RestoreContextState) { BOOL RestoreContextState) {
D3D10DeviceLock lock = LockContext();
FlushCsChunk(); FlushCsChunk();
static_cast<D3D11CommandList*>(pCommandList)->EmitToCommandList(m_commandList.ptr()); static_cast<D3D11CommandList*>(pCommandList)->EmitToCommandList(m_commandList.ptr());
@ -56,6 +58,8 @@ namespace dxvk {
HRESULT STDMETHODCALLTYPE D3D11DeferredContext::FinishCommandList( HRESULT STDMETHODCALLTYPE D3D11DeferredContext::FinishCommandList(
BOOL RestoreDeferredContextState, BOOL RestoreDeferredContextState,
ID3D11CommandList **ppCommandList) { ID3D11CommandList **ppCommandList) {
D3D10DeviceLock lock = LockContext();
FlushCsChunk(); FlushCsChunk();
if (ppCommandList != nullptr) if (ppCommandList != nullptr)
@ -78,6 +82,8 @@ namespace dxvk {
D3D11_MAP MapType, D3D11_MAP MapType,
UINT MapFlags, UINT MapFlags,
D3D11_MAPPED_SUBRESOURCE* pMappedResource) { D3D11_MAPPED_SUBRESOURCE* pMappedResource) {
D3D10DeviceLock lock = LockContext();
D3D11_RESOURCE_DIMENSION resourceDim = D3D11_RESOURCE_DIMENSION_UNKNOWN; D3D11_RESOURCE_DIMENSION resourceDim = D3D11_RESOURCE_DIMENSION_UNKNOWN;
pResource->GetType(&resourceDim); pResource->GetType(&resourceDim);
@ -132,6 +138,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11DeferredContext::Unmap( void STDMETHODCALLTYPE D3D11DeferredContext::Unmap(
ID3D11Resource* pResource, ID3D11Resource* pResource,
UINT Subresource) { UINT Subresource) {
D3D10DeviceLock lock = LockContext();
D3D11_RESOURCE_DIMENSION resourceDim = D3D11_RESOURCE_DIMENSION_UNKNOWN; D3D11_RESOURCE_DIMENSION resourceDim = D3D11_RESOURCE_DIMENSION_UNKNOWN;
pResource->GetType(&resourceDim); pResource->GetType(&resourceDim);

View File

@ -98,6 +98,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11ImmediateContext::Flush() { void STDMETHODCALLTYPE D3D11ImmediateContext::Flush() {
m_parent->FlushInitContext(); m_parent->FlushInitContext();
D3D10DeviceLock lock = LockContext();
if (m_csIsBusy || m_csChunk->commandCount() != 0) { if (m_csIsBusy || m_csChunk->commandCount() != 0) {
// Add commands to flush the threaded // Add commands to flush the threaded
// context, then flush the command list // context, then flush the command list
@ -117,6 +119,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11ImmediateContext::ExecuteCommandList( void STDMETHODCALLTYPE D3D11ImmediateContext::ExecuteCommandList(
ID3D11CommandList* pCommandList, ID3D11CommandList* pCommandList,
BOOL RestoreContextState) { BOOL RestoreContextState) {
D3D10DeviceLock lock = LockContext();
auto commandList = static_cast<D3D11CommandList*>(pCommandList); auto commandList = static_cast<D3D11CommandList*>(pCommandList);
// Flush any outstanding commands so that // Flush any outstanding commands so that
@ -158,6 +162,8 @@ namespace dxvk {
D3D11_MAP MapType, D3D11_MAP MapType,
UINT MapFlags, UINT MapFlags,
D3D11_MAPPED_SUBRESOURCE* pMappedResource) { D3D11_MAPPED_SUBRESOURCE* pMappedResource) {
D3D10DeviceLock lock = LockContext();
if (!pResource || !pMappedResource) if (!pResource || !pMappedResource)
return E_INVALIDARG; return E_INVALIDARG;
@ -190,6 +196,8 @@ namespace dxvk {
void STDMETHODCALLTYPE D3D11ImmediateContext::Unmap( void STDMETHODCALLTYPE D3D11ImmediateContext::Unmap(
ID3D11Resource* pResource, ID3D11Resource* pResource,
UINT Subresource) { UINT Subresource) {
D3D10DeviceLock lock = LockContext();
D3D11_RESOURCE_DIMENSION resourceDim = D3D11_RESOURCE_DIMENSION_UNKNOWN; D3D11_RESOURCE_DIMENSION resourceDim = D3D11_RESOURCE_DIMENSION_UNKNOWN;
pResource->GetType(&resourceDim); pResource->GetType(&resourceDim);