1
0
mirror of https://github.com/doitsujin/dxvk.git synced 2025-01-23 08:52:12 +01:00
dxvk/src/d3d11/d3d11_device.h

406 lines
14 KiB
C
Raw Normal View History

2017-10-11 09:51:48 +02:00
#pragma once
#include <mutex>
#include <vector>
#include "../dxbc/dxbc_options.h"
2017-12-12 12:50:52 +01:00
#include "../dxgi/dxgi_object.h"
#include "../util/com/com_private_data.h"
#include "d3d11_interfaces.h"
#include "d3d11_options.h"
#include "d3d11_shader.h"
#include "d3d11_state.h"
#include "d3d11_util.h"
2017-10-11 09:51:48 +02:00
namespace dxvk {
class DxgiAdapter;
class D3D11Buffer;
2017-12-29 22:20:31 +01:00
class D3D11Counter;
2017-10-11 09:51:48 +02:00
class D3D11DeviceContext;
class D3D11ImmediateContext;
2017-12-29 22:20:31 +01:00
class D3D11Predicate;
class D3D11Presenter;
2017-12-29 22:20:31 +01:00
class D3D11Query;
class D3D11ShaderModule;
2017-12-19 16:01:50 +01:00
class D3D11Texture1D;
class D3D11Texture2D;
class D3D11Texture3D;
class D3D11VkInterop;
2017-10-11 09:51:48 +02:00
/**
* \brief D3D11 device container
*
* Stores all the objects that contribute to the D3D11
* device implementation, including the DXGI device.
*/
class D3D11DeviceContainer : public DxgiObject<IDXGIObject> {
public:
D3D11DeviceContainer();
~D3D11DeviceContainer();
HRESULT STDMETHODCALLTYPE QueryInterface(
REFIID riid,
void** ppvObject);
HRESULT STDMETHODCALLTYPE GetParent(
REFIID riid,
void** ppParent);
IDXGIVkDevice* m_dxgiDevice = nullptr;
D3D11Device* m_d3d11Device = nullptr;
D3D11Presenter* m_d3d11Presenter = nullptr;
D3D11VkInterop* m_d3d11VkInterop = nullptr;
};
/**
* \brief D3D11 device implementation
*
* Implements the ID3D11Device interfaces
* as part of a \ref D3D11DeviceContainer.
*/
class D3D11Device final : public ID3D11Device1 {
/// 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(
IDXGIObject* pContainer,
IDXGIVkDevice* pDxgiDevice,
D3D_FEATURE_LEVEL FeatureLevel,
UINT FeatureFlags);
2017-10-11 09:51:48 +02:00
~D3D11Device();
ULONG STDMETHODCALLTYPE AddRef();
ULONG STDMETHODCALLTYPE Release();
2017-12-12 12:50:52 +01:00
HRESULT STDMETHODCALLTYPE QueryInterface(
REFIID riid,
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,
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,
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,
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,
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,
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,
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,
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,
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,
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,
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,
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,
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,
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,
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,
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,
ID3D11ComputeShader** ppComputeShader);
2017-10-11 09:51:48 +02:00
2017-12-12 12:50:52 +01:00
HRESULT STDMETHODCALLTYPE CreateClassLinkage(
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,
ID3D11BlendState** ppBlendState);
2017-10-11 09:51:48 +02:00
HRESULT STDMETHODCALLTYPE CreateBlendState1(
const D3D11_BLEND_DESC1* pBlendStateDesc,
ID3D11BlendState1** ppBlendState);
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,
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,
ID3D11RasterizerState** ppRasterizerState);
2017-10-11 09:51:48 +02:00
HRESULT STDMETHODCALLTYPE CreateRasterizerState1(
const D3D11_RASTERIZER_DESC1* pRasterizerDesc,
ID3D11RasterizerState1** ppRasterizerState);
2017-12-12 12:50:52 +01:00
HRESULT STDMETHODCALLTYPE CreateSamplerState(
2017-10-11 09:51:48 +02:00
const D3D11_SAMPLER_DESC* pSamplerDesc,
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,
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,
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,
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,
ID3D11DeviceContext** ppDeferredContext);
HRESULT STDMETHODCALLTYPE CreateDeferredContext1(
UINT ContextFlags,
ID3D11DeviceContext1** ppDeferredContext);
HRESULT STDMETHODCALLTYPE CreateDeviceContextState(
UINT Flags,
const D3D_FEATURE_LEVEL* pFeatureLevels,
UINT FeatureLevels,
UINT SDKVersion,
REFIID EmulatedInterface,
D3D_FEATURE_LEVEL* pChosenFeatureLevel,
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,
void** ppResource);
HRESULT STDMETHODCALLTYPE OpenSharedResource1(
HANDLE hResource,
REFIID returnedInterface,
void** ppResource);
HRESULT STDMETHODCALLTYPE OpenSharedResourceByName(
LPCWSTR lpName,
DWORD dwDesiredAccess,
REFIID returnedInterface,
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,
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,
UINT* pNumQualityLevels);
2017-10-11 09:51:48 +02:00
2017-12-12 12:50:52 +01:00
void STDMETHODCALLTYPE CheckCounterInfo(
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,
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,
UINT FeatureSupportDataSize);
2017-10-11 09:51:48 +02:00
2017-12-12 12:50:52 +01:00
HRESULT STDMETHODCALLTYPE GetPrivateData(
REFGUID Name,
UINT *pDataSize,
void *pData);
2017-10-11 09:51:48 +02:00
2017-12-12 12:50:52 +01:00
HRESULT STDMETHODCALLTYPE SetPrivateData(
REFGUID Name,
UINT DataSize,
const void *pData);
2017-10-11 09:51:48 +02:00
2017-12-12 12:50:52 +01:00
HRESULT STDMETHODCALLTYPE SetPrivateDataInterface(
REFGUID Name,
const IUnknown *pUnknown);
2017-10-11 09:51:48 +02:00
D3D_FEATURE_LEVEL STDMETHODCALLTYPE GetFeatureLevel();
2017-10-11 09:51:48 +02:00
UINT STDMETHODCALLTYPE GetCreationFlags();
2017-10-11 09:51:48 +02:00
HRESULT STDMETHODCALLTYPE GetDeviceRemovedReason();
2017-10-11 09:51:48 +02:00
2017-12-12 12:50:52 +01:00
void STDMETHODCALLTYPE GetImmediateContext(
ID3D11DeviceContext** ppImmediateContext);
void STDMETHODCALLTYPE GetImmediateContext1(
ID3D11DeviceContext1** ppImmediateContext);
2017-10-11 09:51:48 +02:00
HRESULT STDMETHODCALLTYPE SetExceptionMode(UINT RaiseFlags);
2017-10-11 09:51:48 +02:00
UINT STDMETHODCALLTYPE GetExceptionMode();
2017-10-11 09:51:48 +02:00
Rc<DxvkDevice> GetDXVKDevice() {
return m_dxvkDevice;
}
2017-10-15 21:38:09 +02:00
DxvkBufferSlice AllocateCounterSlice();
void FreeCounterSlice(const DxvkBufferSlice& Slice);
2018-01-13 05:00:27 +01:00
void FlushInitContext();
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
bool TestOption(D3D11Option Option) const {
return m_d3d11Options.test(Option);
}
static bool CheckFeatureLevelSupport(
const Rc<DxvkAdapter>& adapter,
D3D_FEATURE_LEVEL featureLevel);
static VkPhysicalDeviceFeatures GetDeviceFeatures(
const Rc<DxvkAdapter>& adapter,
D3D_FEATURE_LEVEL featureLevel);
2017-10-11 09:51:48 +02:00
private:
IDXGIObject* m_container;
Com<IDXGIVkAdapter> m_dxgiAdapter;
const D3D_FEATURE_LEVEL m_featureLevel;
const UINT m_featureFlags;
const Rc<DxvkDevice> m_dxvkDevice;
const Rc<DxvkAdapter> m_dxvkAdapter;
2017-10-11 09:51:48 +02:00
const D3D11OptionSet m_d3d11Options;
const DxbcOptions m_dxbcOptions;
D3D11ImmediateContext* m_context = nullptr;
2017-10-11 09:51:48 +02:00
std::mutex m_counterMutex;
std::vector<uint32_t> m_counterSlices;
Rc<DxvkBuffer> m_counterBuffer;
std::mutex m_resourceInitMutex;
Rc<DxvkContext> m_resourceInitContext;
uint64_t m_resourceInitCommands = 0;
D3D11StateObjectSet<D3D11BlendState> m_bsStateObjects;
D3D11StateObjectSet<D3D11DepthStencilState> m_dsStateObjects;
D3D11StateObjectSet<D3D11RasterizerState> m_rsStateObjects;
D3D11StateObjectSet<D3D11SamplerState> m_samplerObjects;
D3D11ShaderModuleSet m_shaderModules;
HRESULT CreateShaderModule(
D3D11ShaderModule* pShaderModule,
const void* pShaderBytecode,
size_t BytecodeLength,
ID3D11ClassLinkage* pClassLinkage,
DxbcProgramType ProgramType);
void InitBuffer(
D3D11Buffer* pBuffer,
const D3D11_SUBRESOURCE_DATA* pInitialData);
2017-12-08 23:13:15 +01:00
void InitTexture(
const Rc<DxvkImage>& image,
2017-12-08 23:13:15 +01:00
const D3D11_SUBRESOURCE_DATA* pInitialData);
HRESULT GetFormatSupportFlags(
DXGI_FORMAT Format,
UINT* pFlags1,
UINT* pFlags2) const;
BOOL GetImageTypeSupport(
VkFormat Format,
VkImageType Type) const;
void CreateCounterBuffer();
void LockResourceInitContext();
void UnlockResourceInitContext(uint64_t CommandCount);
void SubmitResourceInitCommands();
2018-01-13 05:00:27 +01:00
static D3D_FEATURE_LEVEL GetMaxFeatureLevel();
2017-10-11 09:51:48 +02:00
};
}