2017-10-11 09:51:48 +02:00
|
|
|
#pragma once
|
|
|
|
|
2018-01-11 12:23:55 +01:00
|
|
|
#include <mutex>
|
|
|
|
#include <vector>
|
|
|
|
|
2018-01-07 20:05:27 +01:00
|
|
|
#include "../dxbc/dxbc_options.h"
|
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
#include "../dxgi/dxgi_object.h"
|
2018-12-21 12:23:45 +01:00
|
|
|
#include "../dxgi/dxgi_interfaces.h"
|
2017-10-11 15:32:24 +02:00
|
|
|
|
2018-08-27 16:07:38 +02:00
|
|
|
#include "../dxvk/dxvk_cs.h"
|
|
|
|
|
2018-08-11 16:36:54 +02:00
|
|
|
#include "../d3d10/d3d10_device.h"
|
|
|
|
|
2018-01-07 20:05:27 +01:00
|
|
|
#include "../util/com/com_private_data.h"
|
|
|
|
|
2018-08-30 15:24:47 +02:00
|
|
|
#include "d3d11_counter_buffer.h"
|
2018-07-23 15:21:17 +02:00
|
|
|
#include "d3d11_initializer.h"
|
2017-11-29 07:55:44 +01:00
|
|
|
#include "d3d11_interfaces.h"
|
2018-12-03 19:26:29 +01:00
|
|
|
#include "d3d11_interop.h"
|
2018-03-24 17:02:24 +01:00
|
|
|
#include "d3d11_options.h"
|
2018-12-03 19:26:29 +01:00
|
|
|
#include "d3d11_present.h"
|
2018-04-06 17:54:02 +02:00
|
|
|
#include "d3d11_shader.h"
|
2017-12-06 13:16:54 +01:00
|
|
|
#include "d3d11_state.h"
|
2017-12-11 01:43:15 +01:00
|
|
|
#include "d3d11_util.h"
|
2017-10-11 09:51:48 +02:00
|
|
|
|
|
|
|
namespace dxvk {
|
|
|
|
class DxgiAdapter;
|
2017-12-14 15:59:55 +01:00
|
|
|
|
|
|
|
class D3D11Buffer;
|
2018-07-30 19:34:48 +02:00
|
|
|
class D3D11CommonShader;
|
2018-05-22 21:06:26 +02:00
|
|
|
class D3D11CommonTexture;
|
2017-12-29 22:20:31 +01:00
|
|
|
class D3D11Counter;
|
2017-10-11 09:51:48 +02:00
|
|
|
class D3D11DeviceContext;
|
2018-12-03 19:26:29 +01:00
|
|
|
class D3D11DXGIDevice;
|
2018-01-20 13:22:44 +01:00
|
|
|
class D3D11ImmediateContext;
|
2017-12-29 22:20:31 +01:00
|
|
|
class D3D11Predicate;
|
|
|
|
class D3D11Query;
|
2017-12-19 16:01:50 +01:00
|
|
|
class D3D11Texture1D;
|
|
|
|
class D3D11Texture2D;
|
|
|
|
class D3D11Texture3D;
|
2018-03-28 21:24:52 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief D3D11 device implementation
|
|
|
|
*
|
|
|
|
* Implements the ID3D11Device interfaces
|
|
|
|
* as part of a \ref D3D11DeviceContainer.
|
|
|
|
*/
|
|
|
|
class D3D11Device final : public ID3D11Device1 {
|
2018-01-13 23:40:17 +01:00
|
|
|
/// Maximum number of resource init commands per command buffer
|
|
|
|
constexpr static uint64_t InitCommandThreshold = 50;
|
2017-10-11 09:51:48 +02:00
|
|
|
public:
|
|
|
|
|
|
|
|
D3D11Device(
|
2018-12-03 19:26:29 +01:00
|
|
|
D3D11DXGIDevice* pContainer,
|
2018-03-28 21:24:52 +02:00
|
|
|
D3D_FEATURE_LEVEL FeatureLevel,
|
|
|
|
UINT FeatureFlags);
|
2018-12-03 19:26:29 +01:00
|
|
|
|
2017-10-11 09:51:48 +02:00
|
|
|
~D3D11Device();
|
|
|
|
|
2018-03-28 21:24:52 +02:00
|
|
|
ULONG STDMETHODCALLTYPE AddRef();
|
|
|
|
|
|
|
|
ULONG STDMETHODCALLTYPE Release();
|
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE QueryInterface(
|
2017-10-11 15:32:24 +02:00
|
|
|
REFIID riid,
|
2018-03-28 21:24:52 +02:00
|
|
|
void** ppvObject);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateBuffer(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_BUFFER_DESC* pDesc,
|
|
|
|
const D3D11_SUBRESOURCE_DATA* pInitialData,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11Buffer** ppBuffer);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateTexture1D(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_TEXTURE1D_DESC* pDesc,
|
|
|
|
const D3D11_SUBRESOURCE_DATA* pInitialData,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11Texture1D** ppTexture1D);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateTexture2D(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_TEXTURE2D_DESC* pDesc,
|
|
|
|
const D3D11_SUBRESOURCE_DATA* pInitialData,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11Texture2D** ppTexture2D);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateTexture3D(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_TEXTURE3D_DESC* pDesc,
|
|
|
|
const D3D11_SUBRESOURCE_DATA* pInitialData,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11Texture3D** ppTexture3D);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateShaderResourceView(
|
2017-10-11 09:51:48 +02:00
|
|
|
ID3D11Resource* pResource,
|
|
|
|
const D3D11_SHADER_RESOURCE_VIEW_DESC* pDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11ShaderResourceView** ppSRView);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateUnorderedAccessView(
|
2017-10-11 09:51:48 +02:00
|
|
|
ID3D11Resource* pResource,
|
|
|
|
const D3D11_UNORDERED_ACCESS_VIEW_DESC* pDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11UnorderedAccessView** ppUAView);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateRenderTargetView(
|
2017-10-11 09:51:48 +02:00
|
|
|
ID3D11Resource* pResource,
|
|
|
|
const D3D11_RENDER_TARGET_VIEW_DESC* pDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11RenderTargetView** ppRTView);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateDepthStencilView(
|
2017-10-11 09:51:48 +02:00
|
|
|
ID3D11Resource* pResource,
|
|
|
|
const D3D11_DEPTH_STENCIL_VIEW_DESC* pDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11DepthStencilView** ppDepthStencilView);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateInputLayout(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_INPUT_ELEMENT_DESC* pInputElementDescs,
|
|
|
|
UINT NumElements,
|
|
|
|
const void* pShaderBytecodeWithInputSignature,
|
|
|
|
SIZE_T BytecodeLength,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11InputLayout** ppInputLayout);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateVertexShader(
|
2017-10-11 09:51:48 +02:00
|
|
|
const void* pShaderBytecode,
|
|
|
|
SIZE_T BytecodeLength,
|
|
|
|
ID3D11ClassLinkage* pClassLinkage,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11VertexShader** ppVertexShader);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateGeometryShader(
|
2017-10-11 09:51:48 +02:00
|
|
|
const void* pShaderBytecode,
|
|
|
|
SIZE_T BytecodeLength,
|
|
|
|
ID3D11ClassLinkage* pClassLinkage,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11GeometryShader** ppGeometryShader);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateGeometryShaderWithStreamOutput(
|
2017-10-11 09:51:48 +02:00
|
|
|
const void* pShaderBytecode,
|
|
|
|
SIZE_T BytecodeLength,
|
|
|
|
const D3D11_SO_DECLARATION_ENTRY* pSODeclaration,
|
|
|
|
UINT NumEntries,
|
|
|
|
const UINT* pBufferStrides,
|
|
|
|
UINT NumStrides,
|
|
|
|
UINT RasterizedStream,
|
|
|
|
ID3D11ClassLinkage* pClassLinkage,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11GeometryShader** ppGeometryShader);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreatePixelShader(
|
2017-10-11 09:51:48 +02:00
|
|
|
const void* pShaderBytecode,
|
|
|
|
SIZE_T BytecodeLength,
|
|
|
|
ID3D11ClassLinkage* pClassLinkage,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11PixelShader** ppPixelShader);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateHullShader(
|
2017-10-11 09:51:48 +02:00
|
|
|
const void* pShaderBytecode,
|
|
|
|
SIZE_T BytecodeLength,
|
|
|
|
ID3D11ClassLinkage* pClassLinkage,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11HullShader** ppHullShader);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateDomainShader(
|
2017-10-11 09:51:48 +02:00
|
|
|
const void* pShaderBytecode,
|
|
|
|
SIZE_T BytecodeLength,
|
|
|
|
ID3D11ClassLinkage* pClassLinkage,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11DomainShader** ppDomainShader);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateComputeShader(
|
2017-10-11 09:51:48 +02:00
|
|
|
const void* pShaderBytecode,
|
|
|
|
SIZE_T BytecodeLength,
|
|
|
|
ID3D11ClassLinkage* pClassLinkage,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11ComputeShader** ppComputeShader);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateClassLinkage(
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11ClassLinkage** ppLinkage);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateBlendState(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_BLEND_DESC* pBlendStateDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11BlendState** ppBlendState);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2018-03-17 22:11:00 +03:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateBlendState1(
|
|
|
|
const D3D11_BLEND_DESC1* pBlendStateDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11BlendState1** ppBlendState);
|
2018-03-17 22:11:00 +03:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateDepthStencilState(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_DEPTH_STENCIL_DESC* pDepthStencilDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11DepthStencilState** ppDepthStencilState);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateRasterizerState(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_RASTERIZER_DESC* pRasterizerDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11RasterizerState** ppRasterizerState);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2018-03-17 22:11:00 +03:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateRasterizerState1(
|
|
|
|
const D3D11_RASTERIZER_DESC1* pRasterizerDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11RasterizerState1** ppRasterizerState);
|
2018-03-17 22:11:00 +03:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateSamplerState(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_SAMPLER_DESC* pSamplerDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11SamplerState** ppSamplerState);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateQuery(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_QUERY_DESC* pQueryDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11Query** ppQuery);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreatePredicate(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_QUERY_DESC* pPredicateDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11Predicate** ppPredicate);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateCounter(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_COUNTER_DESC* pCounterDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11Counter** ppCounter);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CreateDeferredContext(
|
2017-10-11 09:51:48 +02:00
|
|
|
UINT ContextFlags,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11DeviceContext** ppDeferredContext);
|
2018-03-17 22:11:00 +03:00
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE CreateDeferredContext1(
|
|
|
|
UINT ContextFlags,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11DeviceContext1** ppDeferredContext);
|
2018-03-17 22:11:00 +03:00
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE CreateDeviceContextState(
|
|
|
|
UINT Flags,
|
|
|
|
const D3D_FEATURE_LEVEL* pFeatureLevels,
|
|
|
|
UINT FeatureLevels,
|
|
|
|
UINT SDKVersion,
|
|
|
|
REFIID EmulatedInterface,
|
|
|
|
D3D_FEATURE_LEVEL* pChosenFeatureLevel,
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3DDeviceContextState** ppContextState);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE OpenSharedResource(
|
2017-10-11 09:51:48 +02:00
|
|
|
HANDLE hResource,
|
|
|
|
REFIID ReturnedInterface,
|
2018-03-28 21:24:52 +02:00
|
|
|
void** ppResource);
|
2018-03-17 22:11:00 +03:00
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE OpenSharedResource1(
|
|
|
|
HANDLE hResource,
|
|
|
|
REFIID returnedInterface,
|
2018-03-28 21:24:52 +02:00
|
|
|
void** ppResource);
|
2018-03-17 22:11:00 +03:00
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE OpenSharedResourceByName(
|
|
|
|
LPCWSTR lpName,
|
|
|
|
DWORD dwDesiredAccess,
|
|
|
|
REFIID returnedInterface,
|
2018-03-28 21:24:52 +02:00
|
|
|
void** ppResource);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CheckFormatSupport(
|
2017-10-11 09:51:48 +02:00
|
|
|
DXGI_FORMAT Format,
|
2018-03-28 21:24:52 +02:00
|
|
|
UINT* pFormatSupport);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CheckMultisampleQualityLevels(
|
2017-10-11 09:51:48 +02:00
|
|
|
DXGI_FORMAT Format,
|
|
|
|
UINT SampleCount,
|
2018-03-28 21:24:52 +02:00
|
|
|
UINT* pNumQualityLevels);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
void STDMETHODCALLTYPE CheckCounterInfo(
|
2018-03-28 21:24:52 +02:00
|
|
|
D3D11_COUNTER_INFO* pCounterInfo);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CheckCounter(
|
2017-10-11 09:51:48 +02:00
|
|
|
const D3D11_COUNTER_DESC* pDesc,
|
|
|
|
D3D11_COUNTER_TYPE* pType,
|
|
|
|
UINT* pActiveCounters,
|
|
|
|
LPSTR szName,
|
|
|
|
UINT* pNameLength,
|
|
|
|
LPSTR szUnits,
|
|
|
|
UINT* pUnitsLength,
|
|
|
|
LPSTR szDescription,
|
2018-03-28 21:24:52 +02:00
|
|
|
UINT* pDescriptionLength);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE CheckFeatureSupport(
|
2017-10-11 09:51:48 +02:00
|
|
|
D3D11_FEATURE Feature,
|
|
|
|
void* pFeatureSupportData,
|
2018-03-28 21:24:52 +02:00
|
|
|
UINT FeatureSupportDataSize);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE GetPrivateData(
|
2017-10-11 15:32:24 +02:00
|
|
|
REFGUID Name,
|
|
|
|
UINT *pDataSize,
|
2018-03-28 21:24:52 +02:00
|
|
|
void *pData);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE SetPrivateData(
|
2017-10-11 15:32:24 +02:00
|
|
|
REFGUID Name,
|
|
|
|
UINT DataSize,
|
2018-03-28 21:24:52 +02:00
|
|
|
const void *pData);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE SetPrivateDataInterface(
|
2017-10-11 15:32:24 +02:00
|
|
|
REFGUID Name,
|
2018-03-28 21:24:52 +02:00
|
|
|
const IUnknown *pUnknown);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2018-03-28 21:24:52 +02:00
|
|
|
D3D_FEATURE_LEVEL STDMETHODCALLTYPE GetFeatureLevel();
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2018-03-28 21:24:52 +02:00
|
|
|
UINT STDMETHODCALLTYPE GetCreationFlags();
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2018-03-28 21:24:52 +02:00
|
|
|
HRESULT STDMETHODCALLTYPE GetDeviceRemovedReason();
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
void STDMETHODCALLTYPE GetImmediateContext(
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11DeviceContext** ppImmediateContext);
|
2018-03-17 22:11:00 +03:00
|
|
|
|
|
|
|
void STDMETHODCALLTYPE GetImmediateContext1(
|
2018-03-28 21:24:52 +02:00
|
|
|
ID3D11DeviceContext1** ppImmediateContext);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2018-03-28 21:24:52 +02:00
|
|
|
HRESULT STDMETHODCALLTYPE SetExceptionMode(UINT RaiseFlags);
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2018-03-28 21:24:52 +02:00
|
|
|
UINT STDMETHODCALLTYPE GetExceptionMode();
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-11-29 16:23:33 +01:00
|
|
|
Rc<DxvkDevice> GetDXVKDevice() {
|
|
|
|
return m_dxvkDevice;
|
|
|
|
}
|
2017-10-15 21:38:09 +02:00
|
|
|
|
2018-01-13 05:00:27 +01:00
|
|
|
void FlushInitContext();
|
|
|
|
|
2017-12-14 15:59:55 +01:00
|
|
|
VkPipelineStageFlags GetEnabledShaderStages() const;
|
|
|
|
|
2018-05-05 12:57:22 +02:00
|
|
|
DXGI_VK_FORMAT_INFO LookupFormat(
|
|
|
|
DXGI_FORMAT Format,
|
|
|
|
DXGI_VK_FORMAT_MODE Mode) const;
|
2017-12-19 16:01:50 +01:00
|
|
|
|
2018-07-03 12:44:56 +02:00
|
|
|
DXGI_VK_FORMAT_FAMILY LookupFamily(
|
|
|
|
DXGI_FORMAT Format,
|
|
|
|
DXGI_VK_FORMAT_MODE Mode) const;
|
|
|
|
|
2018-11-20 10:35:23 +01:00
|
|
|
DxvkCsChunkRef AllocCsChunk(DxvkCsChunkFlags flags) {
|
|
|
|
DxvkCsChunk* chunk = m_csChunkPool.allocChunk(flags);
|
2018-08-27 16:07:38 +02:00
|
|
|
return DxvkCsChunkRef(chunk, &m_csChunkPool);
|
|
|
|
}
|
|
|
|
|
2018-08-07 14:58:08 +02:00
|
|
|
const D3D11Options* GetOptions() const {
|
|
|
|
return &m_d3d11Options;
|
2018-03-24 17:02:24 +01:00
|
|
|
}
|
2018-08-11 16:36:54 +02:00
|
|
|
|
|
|
|
D3D10Device* GetD3D10Interface() const {
|
|
|
|
return m_d3d10Device;
|
|
|
|
}
|
2018-11-29 20:13:36 +01:00
|
|
|
|
|
|
|
D3D10Multithread* GetD3D10Multithread() const {
|
|
|
|
return m_d3d10Device->GetMultithread();
|
|
|
|
}
|
2018-03-24 17:02:24 +01:00
|
|
|
|
2018-08-30 15:56:51 +02:00
|
|
|
DxvkBufferSlice AllocUavCounterSlice() { return m_uavCounters->AllocSlice(); }
|
|
|
|
DxvkBufferSlice AllocXfbCounterSlice() { return m_xfbCounters->AllocSlice(); }
|
|
|
|
|
|
|
|
void FreeUavCounterSlice(const DxvkBufferSlice& Slice) { m_uavCounters->FreeSlice(Slice); }
|
|
|
|
void FreeXfbCounterSlice(const DxvkBufferSlice& Slice) { m_xfbCounters->FreeSlice(Slice); }
|
|
|
|
|
2017-10-11 15:32:24 +02:00
|
|
|
static bool CheckFeatureLevelSupport(
|
2017-12-02 16:47:06 +01:00
|
|
|
const Rc<DxvkAdapter>& adapter,
|
|
|
|
D3D_FEATURE_LEVEL featureLevel);
|
|
|
|
|
2018-07-31 16:58:25 +02:00
|
|
|
static DxvkDeviceFeatures GetDeviceFeatures(
|
2017-12-02 16:47:06 +01:00
|
|
|
const Rc<DxvkAdapter>& adapter,
|
2017-10-11 15:32:24 +02:00
|
|
|
D3D_FEATURE_LEVEL featureLevel);
|
|
|
|
|
2017-10-11 09:51:48 +02:00
|
|
|
private:
|
|
|
|
|
2018-03-28 21:24:52 +02:00
|
|
|
IDXGIObject* m_container;
|
2018-08-07 14:58:08 +02:00
|
|
|
|
2017-12-04 13:47:18 +01:00
|
|
|
const D3D_FEATURE_LEVEL m_featureLevel;
|
|
|
|
const UINT m_featureFlags;
|
2017-10-11 15:32:24 +02:00
|
|
|
|
2017-12-04 13:47:18 +01:00
|
|
|
const Rc<DxvkDevice> m_dxvkDevice;
|
|
|
|
const Rc<DxvkAdapter> m_dxvkAdapter;
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2018-11-28 18:34:05 +01:00
|
|
|
const DXGIVkFormatTable m_d3d11Formats;
|
2018-08-07 14:58:08 +02:00
|
|
|
const D3D11Options m_d3d11Options;
|
2018-01-07 20:05:27 +01:00
|
|
|
const DxbcOptions m_dxbcOptions;
|
|
|
|
|
2018-08-27 16:07:38 +02:00
|
|
|
DxvkCsChunkPool m_csChunkPool;
|
|
|
|
|
2018-07-23 15:21:17 +02:00
|
|
|
D3D11Initializer* m_initializer = nullptr;
|
|
|
|
D3D11ImmediateContext* m_context = nullptr;
|
2018-08-11 16:36:54 +02:00
|
|
|
D3D10Device* m_d3d10Device = nullptr;
|
2018-08-30 15:24:47 +02:00
|
|
|
|
|
|
|
Rc<D3D11CounterBuffer> m_uavCounters;
|
2018-08-30 15:56:51 +02:00
|
|
|
Rc<D3D11CounterBuffer> m_xfbCounters;
|
2017-10-11 09:51:48 +02:00
|
|
|
|
2017-12-11 13:03:07 +01:00
|
|
|
D3D11StateObjectSet<D3D11BlendState> m_bsStateObjects;
|
2017-12-11 01:43:15 +01:00
|
|
|
D3D11StateObjectSet<D3D11DepthStencilState> m_dsStateObjects;
|
|
|
|
D3D11StateObjectSet<D3D11RasterizerState> m_rsStateObjects;
|
2018-03-05 02:21:34 +01:00
|
|
|
D3D11StateObjectSet<D3D11SamplerState> m_samplerObjects;
|
2018-04-06 17:54:02 +02:00
|
|
|
D3D11ShaderModuleSet m_shaderModules;
|
2017-12-06 13:16:54 +01:00
|
|
|
|
2018-08-30 15:24:47 +02:00
|
|
|
Rc<D3D11CounterBuffer> CreateUAVCounterBuffer();
|
2018-08-30 15:56:51 +02:00
|
|
|
Rc<D3D11CounterBuffer> CreateXFBCounterBuffer();
|
2018-08-30 15:24:47 +02:00
|
|
|
|
2017-12-06 18:54:01 +01:00
|
|
|
HRESULT CreateShaderModule(
|
2018-07-30 19:34:48 +02:00
|
|
|
D3D11CommonShader* pShaderModule,
|
2018-10-25 11:28:02 +02:00
|
|
|
DxvkShaderKey ShaderKey,
|
2017-12-06 18:54:01 +01:00
|
|
|
const void* pShaderBytecode,
|
|
|
|
size_t BytecodeLength,
|
2018-04-06 17:54:02 +02:00
|
|
|
ID3D11ClassLinkage* pClassLinkage,
|
2018-10-25 11:28:02 +02:00
|
|
|
const DxbcModuleInfo* pModuleInfo);
|
2017-12-06 18:54:01 +01:00
|
|
|
|
2018-03-21 13:31:22 +01:00
|
|
|
HRESULT GetFormatSupportFlags(
|
|
|
|
DXGI_FORMAT Format,
|
|
|
|
UINT* pFlags1,
|
|
|
|
UINT* pFlags2) const;
|
2017-12-19 11:05:41 +01:00
|
|
|
|
2018-04-14 16:07:01 +02:00
|
|
|
BOOL GetImageTypeSupport(
|
|
|
|
VkFormat Format,
|
|
|
|
VkImageType Type) const;
|
|
|
|
|
2018-08-09 21:08:03 +02:00
|
|
|
static D3D_FEATURE_LEVEL GetMaxFeatureLevel(
|
|
|
|
const Rc<DxvkAdapter>& Adapter);
|
2018-01-30 12:19:53 +01:00
|
|
|
|
2017-10-11 09:51:48 +02:00
|
|
|
};
|
|
|
|
|
2018-12-21 12:23:45 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief DXGI swap chain factory
|
|
|
|
*/
|
|
|
|
class WineDXGISwapChainFactory : public IWineDXGISwapChainFactory {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
WineDXGISwapChainFactory(IUnknown* pContainer);
|
|
|
|
|
|
|
|
ULONG STDMETHODCALLTYPE AddRef();
|
|
|
|
|
|
|
|
ULONG STDMETHODCALLTYPE Release();
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE QueryInterface(
|
|
|
|
REFIID riid,
|
|
|
|
void** ppvObject);
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE CreateSwapChainForHwnd(
|
|
|
|
IDXGIFactory* pFactory,
|
|
|
|
HWND hWnd,
|
|
|
|
const DXGI_SWAP_CHAIN_DESC1* pDesc,
|
|
|
|
const DXGI_SWAP_CHAIN_FULLSCREEN_DESC* pFullscreenDesc,
|
|
|
|
IDXGIOutput* pRestrictToOutput,
|
|
|
|
IDXGISwapChain1** ppSwapChain);
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
IUnknown* m_container;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2018-12-03 19:26:29 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief D3D11 device container
|
|
|
|
*
|
|
|
|
* Stores all the objects that contribute to the D3D11
|
|
|
|
* device implementation, including the DXGI device.
|
|
|
|
*/
|
|
|
|
class D3D11DXGIDevice : public DxgiObject<IDXGIDevice3> {
|
|
|
|
constexpr static uint32_t DefaultFrameLatency = 3;
|
|
|
|
public:
|
|
|
|
|
|
|
|
D3D11DXGIDevice(
|
|
|
|
IDXGIAdapter* pAdapter,
|
|
|
|
DxvkAdapter* pDxvkAdapter,
|
|
|
|
D3D_FEATURE_LEVEL FeatureLevel,
|
|
|
|
UINT FeatureFlags);
|
|
|
|
|
|
|
|
~D3D11DXGIDevice();
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE QueryInterface(
|
|
|
|
REFIID riid,
|
|
|
|
void** ppvObject);
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE GetParent(
|
|
|
|
REFIID riid,
|
|
|
|
void** ppParent);
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE CreateSurface(
|
|
|
|
const DXGI_SURFACE_DESC* pDesc,
|
|
|
|
UINT NumSurfaces,
|
|
|
|
DXGI_USAGE Usage,
|
|
|
|
const DXGI_SHARED_RESOURCE* pSharedResource,
|
|
|
|
IDXGISurface** ppSurface) final;
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE GetAdapter(
|
|
|
|
IDXGIAdapter** pAdapter) final;
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE GetGPUThreadPriority(
|
|
|
|
INT* pPriority) final;
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE QueryResourceResidency(
|
|
|
|
IUnknown* const* ppResources,
|
|
|
|
DXGI_RESIDENCY* pResidencyStatus,
|
|
|
|
UINT NumResources) final;
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE SetGPUThreadPriority(
|
|
|
|
INT Priority) final;
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE GetMaximumFrameLatency(
|
|
|
|
UINT* pMaxLatency) final;
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE SetMaximumFrameLatency(
|
|
|
|
UINT MaxLatency) final;
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE OfferResources(
|
|
|
|
UINT NumResources,
|
|
|
|
IDXGIResource* const* ppResources,
|
|
|
|
DXGI_OFFER_RESOURCE_PRIORITY Priority) final;
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE ReclaimResources(
|
|
|
|
UINT NumResources,
|
|
|
|
IDXGIResource* const* ppResources,
|
|
|
|
BOOL* pDiscarded) final;
|
|
|
|
|
|
|
|
HRESULT STDMETHODCALLTYPE EnqueueSetEvent(
|
|
|
|
HANDLE hEvent) final;
|
|
|
|
|
|
|
|
void STDMETHODCALLTYPE Trim() final;
|
|
|
|
|
|
|
|
Rc<DxvkEvent> STDMETHODCALLTYPE GetFrameSyncEvent();
|
|
|
|
|
|
|
|
Rc<DxvkDevice> STDMETHODCALLTYPE GetDXVKDevice();
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
Com<IDXGIAdapter> m_dxgiAdapter;
|
|
|
|
|
|
|
|
Rc<DxvkAdapter> m_dxvkAdapter;
|
|
|
|
Rc<DxvkDevice> m_dxvkDevice;
|
|
|
|
|
|
|
|
D3D11Device m_d3d11Device;
|
|
|
|
D3D11PresentDevice m_d3d11Presenter;
|
|
|
|
D3D11VkInterop m_d3d11Interop;
|
|
|
|
|
2018-12-21 12:23:45 +01:00
|
|
|
WineDXGISwapChainFactory m_wineFactory;
|
|
|
|
|
2018-12-03 19:26:29 +01:00
|
|
|
uint32_t m_frameLatencyCap = 0;
|
|
|
|
uint32_t m_frameLatency = DefaultFrameLatency;
|
|
|
|
uint32_t m_frameId = 0;
|
|
|
|
|
|
|
|
std::array<Rc<DxvkEvent>, 16> m_frameEvents;
|
|
|
|
|
|
|
|
Rc<DxvkDevice> CreateDevice(D3D_FEATURE_LEVEL FeatureLevel);
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2017-10-11 09:51:48 +02:00
|
|
|
}
|