2017-10-11 15:31:36 +02:00
|
|
|
#pragma once
|
|
|
|
|
2017-12-04 11:33:04 +01:00
|
|
|
#include "../dxvk/dxvk_include.h"
|
|
|
|
|
2017-10-11 15:31:36 +02:00
|
|
|
#include "dxgi_include.h"
|
|
|
|
|
|
|
|
namespace dxvk {
|
|
|
|
class DxgiAdapter;
|
|
|
|
class DxvkAdapter;
|
2017-11-29 15:16:07 +01:00
|
|
|
class DxvkBuffer;
|
2017-10-11 15:31:36 +02:00
|
|
|
class DxvkDevice;
|
2017-11-29 15:16:07 +01:00
|
|
|
class DxvkImage;
|
2017-12-04 11:33:04 +01:00
|
|
|
|
2018-01-28 18:06:08 +01:00
|
|
|
/**
|
|
|
|
* \brief Format information
|
|
|
|
*/
|
|
|
|
enum class DxgiFormatFlag {
|
|
|
|
Typeless = 0,
|
|
|
|
};
|
|
|
|
|
|
|
|
using DxgiFormatFlags = Flags<DxgiFormatFlag>;
|
|
|
|
|
2017-12-04 11:33:04 +01:00
|
|
|
/**
|
2017-12-20 14:54:24 +01:00
|
|
|
* \brief Format info
|
2017-12-04 11:33:04 +01:00
|
|
|
*
|
2017-12-20 14:54:24 +01:00
|
|
|
* Stores a Vulkan image format for a given
|
|
|
|
* DXGI format and some additional information
|
|
|
|
* on how resources with the particular format
|
|
|
|
* are supposed to be used.
|
2017-12-04 11:33:04 +01:00
|
|
|
*/
|
2017-12-20 14:54:24 +01:00
|
|
|
struct DxgiFormatInfo {
|
|
|
|
VkFormat format;
|
|
|
|
VkImageAspectFlags aspect;
|
|
|
|
VkComponentMapping swizzle;
|
2018-01-28 18:06:08 +01:00
|
|
|
DxgiFormatFlags flags;
|
2017-12-04 11:33:04 +01:00
|
|
|
};
|
2017-12-19 14:47:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Format lookup mode
|
|
|
|
*
|
|
|
|
* When looking up an image format, additional information
|
|
|
|
* might be needed on how the image is going to be used.
|
|
|
|
* This is used to properly map typeless formats and color
|
|
|
|
* formats to depth formats if they are used on depth images.
|
|
|
|
*/
|
|
|
|
enum class DxgiFormatMode : uint32_t {
|
|
|
|
Any = 0,
|
|
|
|
Color = 1,
|
|
|
|
Depth = 2,
|
|
|
|
};
|
2017-10-11 15:31:36 +02:00
|
|
|
}
|
2018-03-28 18:58:53 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Private DXGI device interface
|
|
|
|
*
|
|
|
|
* The implementation of \c IDXGIDevice stores a
|
|
|
|
* \ref DxvkDevice which can be retrieved using
|
|
|
|
* this interface.
|
|
|
|
*/
|
|
|
|
MIDL_INTERFACE("7a622cf6-627a-46b2-b52f-360ef3da831c")
|
2018-03-28 19:06:00 +02:00
|
|
|
IDXGIVkDevice : public IDXGIDevice2 {
|
2018-03-28 18:58:53 +02:00
|
|
|
static const GUID guid;
|
2017-10-11 15:31:36 +02:00
|
|
|
|
2018-03-28 21:24:52 +02:00
|
|
|
virtual ~IDXGIVkDevice() { }
|
2018-03-28 18:58:53 +02:00
|
|
|
|
|
|
|
virtual dxvk::Rc<dxvk::DxvkDevice> STDMETHODCALLTYPE GetDXVKDevice() = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-10-11 15:31:36 +02:00
|
|
|
/**
|
2017-11-29 07:55:44 +01:00
|
|
|
* \brief Private DXGI adapter interface
|
2017-10-11 15:31:36 +02:00
|
|
|
*
|
|
|
|
* The implementation of \c IDXGIAdapter holds a
|
|
|
|
* \ref DxvkAdapter which can be retrieved using
|
|
|
|
* this interface.
|
|
|
|
*/
|
|
|
|
MIDL_INTERFACE("907bf281-ea3c-43b4-a8e4-9f231107b4ff")
|
2018-03-28 19:06:00 +02:00
|
|
|
IDXGIVkAdapter : public IDXGIAdapter1 {
|
2017-10-11 15:31:36 +02:00
|
|
|
static const GUID guid;
|
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
virtual dxvk::Rc<dxvk::DxvkAdapter> STDMETHODCALLTYPE GetDXVKAdapter() = 0;
|
2017-12-04 11:33:04 +01:00
|
|
|
|
2018-03-28 18:58:53 +02:00
|
|
|
/**
|
|
|
|
* \brief Creates a DXGI device object
|
|
|
|
*
|
|
|
|
* \param [in] pAdapter The adapter
|
|
|
|
* \param [in] pFeatures Device features to enable
|
|
|
|
* \param [out] ppDevice The DXGI device object
|
|
|
|
* \returns \c S_OK on success, or an error code
|
|
|
|
*/
|
|
|
|
virtual HRESULT STDMETHODCALLTYPE CreateDevice(
|
2018-03-28 21:24:52 +02:00
|
|
|
IDXGIObject* pContainer,
|
2018-03-28 18:58:53 +02:00
|
|
|
const VkPhysicalDeviceFeatures* pFeatures,
|
2018-03-28 21:24:52 +02:00
|
|
|
IDXGIVkDevice** ppDevice) = 0;
|
2018-03-28 18:58:53 +02:00
|
|
|
|
2017-12-19 14:47:35 +01:00
|
|
|
/**
|
|
|
|
* \brief Maps a DXGI format to a compatible Vulkan format
|
|
|
|
*
|
|
|
|
* For color formats, the returned Vulkan format has the
|
|
|
|
* same memory layout as the DXGI format so that it can
|
|
|
|
* be mapped and copied to buffers. For depth-stencil
|
|
|
|
* formats, this is not guaranteed.
|
|
|
|
* \param [in] format The DXGI format
|
|
|
|
* \param [in] mode Format lookup mode
|
|
|
|
* \returns Vulkan format pair
|
|
|
|
*/
|
2017-12-20 14:54:24 +01:00
|
|
|
virtual dxvk::DxgiFormatInfo STDMETHODCALLTYPE LookupFormat(
|
2017-12-19 14:47:35 +01:00
|
|
|
DXGI_FORMAT format,
|
|
|
|
dxvk::DxgiFormatMode mode) = 0;
|
2017-10-11 15:31:36 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-11-29 15:16:07 +01:00
|
|
|
/**
|
2017-12-19 16:01:50 +01:00
|
|
|
* \brief Swap chain back buffer interface
|
|
|
|
*
|
|
|
|
* Allows the swap chain and presenter to query
|
|
|
|
* the underlying image while it is embedded in
|
|
|
|
* a texture object specified by the client API.
|
2017-11-29 15:16:07 +01:00
|
|
|
*/
|
|
|
|
MIDL_INTERFACE("5679becd-8547-4d93-96a1-e61a1ce7ef37")
|
2018-03-28 19:06:00 +02:00
|
|
|
IDXGIVkBackBuffer : public IUnknown {
|
2017-11-29 15:16:07 +01:00
|
|
|
static const GUID guid;
|
|
|
|
|
2017-12-19 16:01:50 +01:00
|
|
|
virtual dxvk::Rc<dxvk::DxvkImage> GetDXVKImage() = 0;
|
2017-11-29 15:16:07 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-11-29 16:23:33 +01:00
|
|
|
/**
|
|
|
|
* \brief Private presentation device interface
|
|
|
|
*
|
|
|
|
* Allows a swap chain to communicate with the device
|
|
|
|
* in order to flush pending commands or create the
|
|
|
|
* back buffer interface.
|
|
|
|
*/
|
|
|
|
MIDL_INTERFACE("79352328-16f2-4f81-9746-9c2e2ccd43cf")
|
2018-03-28 19:06:00 +02:00
|
|
|
IDXGIVkPresenter : public IUnknown {
|
2017-11-29 16:23:33 +01:00
|
|
|
static const GUID guid;
|
|
|
|
|
|
|
|
/**
|
2017-12-19 16:01:50 +01:00
|
|
|
* \brief Creates a swap chain back buffer
|
2017-11-29 16:23:33 +01:00
|
|
|
*
|
2018-03-28 21:24:52 +02:00
|
|
|
* \param [in] pSwapChainDesc Swap chain description
|
|
|
|
* \param [out] ppBackBuffer The swap chain back buffer
|
2017-11-29 16:23:33 +01:00
|
|
|
* \returns \c S_OK on success
|
|
|
|
*/
|
2017-12-19 16:01:50 +01:00
|
|
|
virtual HRESULT STDMETHODCALLTYPE CreateSwapChainBackBuffer(
|
2017-11-29 16:23:33 +01:00
|
|
|
const DXGI_SWAP_CHAIN_DESC* pSwapChainDesc,
|
2018-03-28 21:24:52 +02:00
|
|
|
IDXGIVkBackBuffer** ppBackBuffer) = 0;
|
2017-11-29 16:23:33 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Flushes the immediate context
|
|
|
|
*
|
|
|
|
* Used by the swap chain's \c Present method to
|
|
|
|
* ensure that all rendering commands get dispatched
|
|
|
|
* before presenting the swap chain's back buffer.
|
|
|
|
* \returns \c S_OK on success
|
|
|
|
*/
|
2017-12-12 12:50:52 +01:00
|
|
|
virtual HRESULT STDMETHODCALLTYPE FlushRenderingCommands() = 0;
|
2017-11-29 16:23:33 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Underlying DXVK device
|
|
|
|
*
|
|
|
|
* \param [in] riid Device type
|
|
|
|
* \param [in] ppDevice device
|
|
|
|
* \returns DXVK device handle
|
|
|
|
*/
|
2017-12-12 12:50:52 +01:00
|
|
|
virtual HRESULT STDMETHODCALLTYPE GetDevice(
|
2017-11-29 16:23:33 +01:00
|
|
|
REFGUID riid,
|
|
|
|
void** ppDevice) = 0;
|
|
|
|
};
|
|
|
|
|
2018-03-06 18:34:34 +01:00
|
|
|
#ifdef _MSC_VER
|
2018-03-28 19:06:00 +02:00
|
|
|
struct __declspec(uuid("907bf281-ea3c-43b4-a8e4-9f231107b4ff")) IDXGIVkAdapter;
|
|
|
|
struct __declspec(uuid("7a622cf6-627a-46b2-b52f-360ef3da831c")) IDXGIVkDevice;
|
|
|
|
struct __declspec(uuid("5679becd-8547-4d93-96a1-e61a1ce7ef37")) IDXGIVkBackBuffer;
|
|
|
|
struct __declspec(uuid("79352328-16f2-4f81-9746-9c2e2ccd43cf")) IDXGIVkPresenter;
|
2018-03-06 18:34:34 +01:00
|
|
|
#else
|
2018-03-28 19:06:00 +02:00
|
|
|
DXVK_DEFINE_GUID(IDXGIVkAdapter);
|
|
|
|
DXVK_DEFINE_GUID(IDXGIVkDevice);
|
|
|
|
DXVK_DEFINE_GUID(IDXGIVkBackBuffer);
|
|
|
|
DXVK_DEFINE_GUID(IDXGIVkPresenter);
|
2018-03-06 18:34:34 +01:00
|
|
|
#endif
|