2017-10-15 21:38:09 +02:00
|
|
|
#include "d3d11_buffer.h"
|
2017-12-13 17:49:08 +01:00
|
|
|
#include "d3d11_context.h"
|
2017-10-15 21:38:09 +02:00
|
|
|
#include "d3d11_device.h"
|
|
|
|
|
2017-12-13 17:49:08 +01:00
|
|
|
#include "../dxvk/dxvk_data.h"
|
|
|
|
|
2017-10-15 21:38:09 +02:00
|
|
|
namespace dxvk {
|
|
|
|
|
|
|
|
D3D11Buffer::D3D11Buffer(
|
2017-12-14 15:59:55 +01:00
|
|
|
D3D11Device* pDevice,
|
|
|
|
const D3D11_BUFFER_DESC* pDesc)
|
2017-12-14 19:07:08 +01:00
|
|
|
: m_device (pDevice),
|
|
|
|
m_desc (*pDesc),
|
|
|
|
m_buffer (CreateBuffer(pDesc)) {
|
2017-11-26 14:01:41 +01:00
|
|
|
|
2017-10-15 21:38:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
D3D11Buffer::~D3D11Buffer() {
|
2017-11-26 14:01:41 +01:00
|
|
|
|
2017-10-15 21:38:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
HRESULT STDMETHODCALLTYPE D3D11Buffer::QueryInterface(REFIID riid, void** ppvObject) {
|
2017-10-15 21:50:34 +02:00
|
|
|
COM_QUERY_IFACE(riid, ppvObject, IUnknown);
|
|
|
|
COM_QUERY_IFACE(riid, ppvObject, ID3D11DeviceChild);
|
|
|
|
COM_QUERY_IFACE(riid, ppvObject, ID3D11Resource);
|
2017-10-15 21:38:09 +02:00
|
|
|
COM_QUERY_IFACE(riid, ppvObject, ID3D11Buffer);
|
|
|
|
|
|
|
|
Logger::warn("D3D11Buffer::QueryInterface: Unknown interface query");
|
|
|
|
return E_NOINTERFACE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
void STDMETHODCALLTYPE D3D11Buffer::GetDevice(ID3D11Device** ppDevice) {
|
2017-12-09 15:57:05 +01:00
|
|
|
*ppDevice = m_device.ref();
|
2017-10-15 21:38:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
UINT STDMETHODCALLTYPE D3D11Buffer::GetEvictionPriority() {
|
2017-12-14 15:59:55 +01:00
|
|
|
Logger::warn("D3D11Buffer::GetEvictionPriority: Stub");
|
|
|
|
return DXGI_RESOURCE_PRIORITY_NORMAL;
|
2017-12-07 13:31:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
void STDMETHODCALLTYPE D3D11Buffer::SetEvictionPriority(UINT EvictionPriority) {
|
2017-12-14 15:59:55 +01:00
|
|
|
Logger::warn("D3D11Buffer::SetEvictionPriority: Stub");
|
2017-12-07 13:31:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
void STDMETHODCALLTYPE D3D11Buffer::GetType(D3D11_RESOURCE_DIMENSION* pResourceDimension) {
|
2017-10-15 21:38:09 +02:00
|
|
|
*pResourceDimension = D3D11_RESOURCE_DIMENSION_BUFFER;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-12-12 12:50:52 +01:00
|
|
|
void STDMETHODCALLTYPE D3D11Buffer::GetDesc(D3D11_BUFFER_DESC* pDesc) {
|
2017-10-15 21:38:09 +02:00
|
|
|
*pDesc = m_desc;
|
|
|
|
}
|
|
|
|
|
2017-12-07 14:03:15 +01:00
|
|
|
|
2017-12-14 15:59:55 +01:00
|
|
|
Rc<DxvkBuffer> D3D11Buffer::CreateBuffer(
|
|
|
|
const D3D11_BUFFER_DESC* pDesc) const {
|
|
|
|
DxvkBufferCreateInfo info;
|
|
|
|
info.size = pDesc->ByteWidth;
|
2017-12-28 19:05:53 +01:00
|
|
|
info.usage = VK_BUFFER_USAGE_TRANSFER_SRC_BIT
|
2017-12-14 15:59:55 +01:00
|
|
|
| VK_BUFFER_USAGE_TRANSFER_DST_BIT;
|
|
|
|
info.stages = VK_PIPELINE_STAGE_TRANSFER_BIT;
|
|
|
|
info.access = VK_ACCESS_TRANSFER_READ_BIT
|
|
|
|
| VK_ACCESS_TRANSFER_WRITE_BIT;
|
|
|
|
|
|
|
|
if (pDesc->BindFlags & D3D11_BIND_VERTEX_BUFFER) {
|
|
|
|
info.usage |= VK_BUFFER_USAGE_VERTEX_BUFFER_BIT;
|
|
|
|
info.stages |= VK_PIPELINE_STAGE_VERTEX_INPUT_BIT;
|
|
|
|
info.access |= VK_ACCESS_VERTEX_ATTRIBUTE_READ_BIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pDesc->BindFlags & D3D11_BIND_INDEX_BUFFER) {
|
|
|
|
info.usage |= VK_BUFFER_USAGE_INDEX_BUFFER_BIT;
|
|
|
|
info.stages |= VK_PIPELINE_STAGE_VERTEX_INPUT_BIT;
|
|
|
|
info.access |= VK_ACCESS_INDEX_READ_BIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pDesc->BindFlags & D3D11_BIND_CONSTANT_BUFFER) {
|
|
|
|
info.usage |= VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT;
|
|
|
|
info.stages |= m_device->GetEnabledShaderStages();
|
|
|
|
info.access |= VK_ACCESS_UNIFORM_READ_BIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pDesc->BindFlags & D3D11_BIND_SHADER_RESOURCE) {
|
2017-12-28 16:35:07 +01:00
|
|
|
info.usage |= VK_BUFFER_USAGE_UNIFORM_TEXEL_BUFFER_BIT;
|
2017-12-14 15:59:55 +01:00
|
|
|
info.stages |= m_device->GetEnabledShaderStages();
|
|
|
|
info.access |= VK_ACCESS_SHADER_READ_BIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pDesc->BindFlags & D3D11_BIND_STREAM_OUTPUT)
|
|
|
|
throw DxvkError("D3D11Device::CreateBuffer: D3D11_BIND_STREAM_OUTPUT not supported");
|
|
|
|
|
|
|
|
if (pDesc->BindFlags & D3D11_BIND_UNORDERED_ACCESS) {
|
2017-12-28 16:35:07 +01:00
|
|
|
info.usage |= VK_BUFFER_USAGE_STORAGE_TEXEL_BUFFER_BIT;
|
2017-12-14 15:59:55 +01:00
|
|
|
info.stages |= VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT
|
|
|
|
| VK_PIPELINE_STAGE_COMPUTE_SHADER_BIT;
|
|
|
|
info.access |= VK_ACCESS_SHADER_READ_BIT
|
|
|
|
| VK_ACCESS_SHADER_WRITE_BIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pDesc->CPUAccessFlags & D3D11_CPU_ACCESS_WRITE) {
|
|
|
|
info.stages |= VK_PIPELINE_STAGE_HOST_BIT;
|
|
|
|
info.access |= VK_ACCESS_HOST_WRITE_BIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pDesc->CPUAccessFlags & D3D11_CPU_ACCESS_READ) {
|
|
|
|
info.stages |= VK_PIPELINE_STAGE_HOST_BIT;
|
|
|
|
info.access |= VK_ACCESS_HOST_READ_BIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pDesc->MiscFlags & D3D11_RESOURCE_MISC_DRAWINDIRECT_ARGS) {
|
|
|
|
info.usage |= VK_BUFFER_USAGE_INDIRECT_BUFFER_BIT;
|
|
|
|
info.stages |= VK_PIPELINE_STAGE_DRAW_INDIRECT_BIT;
|
|
|
|
info.access |= VK_ACCESS_INDIRECT_COMMAND_READ_BIT;
|
|
|
|
}
|
|
|
|
|
|
|
|
return m_device->GetDXVKDevice()->createBuffer(
|
|
|
|
info, GetMemoryFlagsForUsage(pDesc->Usage));
|
2017-12-07 14:03:15 +01:00
|
|
|
}
|
|
|
|
|
2017-10-15 21:38:09 +02:00
|
|
|
}
|