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:
parent
28216909bd
commit
cf21111401
@ -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()) {
|
||||||
@ -58,6 +59,11 @@ namespace dxvk {
|
|||||||
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));
|
||||||
return E_NOINTERFACE;
|
return E_NOINTERFACE;
|
||||||
@ -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;
|
||||||
|
|
||||||
|
@ -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)) {
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user