2017-10-10 23:32:13 +02:00
|
|
|
#pragma once
|
|
|
|
|
2017-12-09 02:44:59 +01:00
|
|
|
#include "dxvk_format.h"
|
2017-10-15 14:36:41 +02:00
|
|
|
#include "dxvk_memory.h"
|
2017-10-10 23:32:13 +02:00
|
|
|
#include "dxvk_resource.h"
|
|
|
|
|
|
|
|
namespace dxvk {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Buffer create info
|
|
|
|
*
|
|
|
|
* The properties of a buffer that are
|
|
|
|
* passed to \ref DxvkDevice::createBuffer
|
|
|
|
*/
|
|
|
|
struct DxvkBufferCreateInfo {
|
|
|
|
/// Size of the buffer, in bytes
|
2017-10-15 14:36:41 +02:00
|
|
|
VkDeviceSize size;
|
|
|
|
|
|
|
|
/// Buffer usage flags
|
|
|
|
VkBufferUsageFlags usage;
|
2017-10-10 23:32:13 +02:00
|
|
|
|
2017-10-15 17:56:06 +02:00
|
|
|
/// Pipeline stages that can access
|
|
|
|
/// the contents of the buffer.
|
|
|
|
VkPipelineStageFlags stages;
|
|
|
|
|
|
|
|
/// Allowed access patterns
|
|
|
|
VkAccessFlags access;
|
2017-10-10 23:32:13 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-11-21 19:50:57 +01:00
|
|
|
/**
|
|
|
|
* \brief Buffer view create info
|
|
|
|
*
|
|
|
|
* The properties of a buffer view that
|
|
|
|
* are to \ref DxvkDevice::createBufferView
|
|
|
|
*/
|
|
|
|
struct DxvkBufferViewCreateInfo {
|
|
|
|
/// Buffer data format, like image data
|
|
|
|
VkFormat format;
|
|
|
|
|
|
|
|
/// Offset of the buffer region to include in the view
|
|
|
|
VkDeviceSize rangeOffset;
|
|
|
|
|
|
|
|
/// Size of the buffer region to include in the view
|
|
|
|
VkDeviceSize rangeLength;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-10-10 23:32:13 +02:00
|
|
|
/**
|
|
|
|
* \brief DXVK buffer
|
|
|
|
*
|
2017-10-15 14:36:41 +02:00
|
|
|
* A simple buffer resource that stores
|
|
|
|
* linear data. Can be mapped to host
|
|
|
|
* memory.
|
2017-10-10 23:32:13 +02:00
|
|
|
*/
|
|
|
|
class DxvkBuffer : public DxvkResource {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
2017-10-15 14:36:41 +02:00
|
|
|
DxvkBuffer(
|
|
|
|
const Rc<vk::DeviceFn>& vkd,
|
|
|
|
const DxvkBufferCreateInfo& createInfo,
|
|
|
|
DxvkMemoryAllocator& memAlloc,
|
|
|
|
VkMemoryPropertyFlags memFlags);
|
|
|
|
~DxvkBuffer();
|
2017-10-10 23:32:13 +02:00
|
|
|
|
2017-10-15 14:36:41 +02:00
|
|
|
/**
|
|
|
|
* \brief Buffer handle
|
|
|
|
* \returns Buffer handle
|
|
|
|
*/
|
|
|
|
VkBuffer handle() const {
|
|
|
|
return m_buffer;
|
|
|
|
}
|
2017-10-10 23:32:13 +02:00
|
|
|
|
2017-10-15 14:36:41 +02:00
|
|
|
/**
|
|
|
|
* \brief Buffer properties
|
|
|
|
* \returns Buffer properties
|
|
|
|
*/
|
|
|
|
const DxvkBufferCreateInfo& info() const {
|
|
|
|
return m_info;
|
|
|
|
}
|
2017-10-10 23:32:13 +02:00
|
|
|
|
2017-10-15 14:36:41 +02:00
|
|
|
/**
|
|
|
|
* \brief Map pointer
|
|
|
|
*
|
|
|
|
* If the buffer has been created on a host-visible
|
|
|
|
* memory type, the buffer memory is mapped and can
|
|
|
|
* be accessed by the host.
|
|
|
|
* \returns Pointer to mapped memory region
|
|
|
|
*/
|
|
|
|
void* mapPtr() const {
|
|
|
|
return m_memory.mapPtr();
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2017-10-10 23:32:13 +02:00
|
|
|
|
2017-10-15 14:36:41 +02:00
|
|
|
Rc<vk::DeviceFn> m_vkd;
|
|
|
|
DxvkBufferCreateInfo m_info;
|
|
|
|
DxvkMemory m_memory;
|
|
|
|
VkBuffer m_buffer = VK_NULL_HANDLE;
|
2017-10-10 23:32:13 +02:00
|
|
|
|
|
|
|
};
|
|
|
|
|
2017-10-15 17:56:06 +02:00
|
|
|
|
2017-11-21 19:50:57 +01:00
|
|
|
/**
|
|
|
|
* \brief Buffer view
|
|
|
|
*
|
|
|
|
* Allows the application to interpret buffer
|
|
|
|
* contents like formatted pixel data. These
|
|
|
|
* buffer views are used as texel buffers.
|
|
|
|
*/
|
|
|
|
class DxvkBufferView : public DxvkResource {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
DxvkBufferView(
|
|
|
|
const Rc<vk::DeviceFn>& vkd,
|
|
|
|
const Rc<DxvkBuffer>& buffer,
|
|
|
|
const DxvkBufferViewCreateInfo& info);
|
|
|
|
|
|
|
|
~DxvkBufferView();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Buffer view handle
|
|
|
|
* \returns Buffer view handle
|
|
|
|
*/
|
|
|
|
VkBufferView handle() const {
|
|
|
|
return m_view;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Buffer view properties
|
|
|
|
* \returns Buffer view properties
|
|
|
|
*/
|
|
|
|
const DxvkBufferViewCreateInfo& info() const {
|
|
|
|
return m_info;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Underlying buffer object
|
|
|
|
* \returns Underlying buffer object
|
|
|
|
*/
|
|
|
|
Rc<DxvkBuffer> buffer() const {
|
|
|
|
return m_buffer;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
Rc<vk::DeviceFn> m_vkd;
|
|
|
|
Rc<DxvkBuffer> m_buffer;
|
|
|
|
|
|
|
|
DxvkBufferViewCreateInfo m_info;
|
|
|
|
VkBufferView m_view;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-10-15 17:56:06 +02:00
|
|
|
/**
|
|
|
|
* \brief Buffer binding
|
|
|
|
*
|
|
|
|
* Stores the buffer and the sub-range of the buffer
|
|
|
|
* to bind. Bindings are considered equal if all three
|
|
|
|
* parameters are the same.
|
|
|
|
*/
|
|
|
|
class DxvkBufferBinding {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
DxvkBufferBinding() { }
|
|
|
|
DxvkBufferBinding(
|
|
|
|
const Rc<DxvkBuffer>& buffer,
|
|
|
|
VkDeviceSize rangeOffset,
|
|
|
|
VkDeviceSize rangeLength)
|
|
|
|
: m_buffer(buffer),
|
|
|
|
m_offset(rangeOffset),
|
|
|
|
m_length(rangeLength) { }
|
|
|
|
|
|
|
|
Rc<DxvkResource> resource() const {
|
|
|
|
return m_buffer;
|
|
|
|
}
|
|
|
|
|
2017-11-20 13:21:27 +01:00
|
|
|
VkBuffer bufferHandle() const {
|
2017-11-20 15:35:29 +01:00
|
|
|
return m_buffer != nullptr
|
|
|
|
? m_buffer->handle()
|
|
|
|
: VK_NULL_HANDLE;
|
2017-11-20 13:21:27 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
size_t bufferOffset() const {
|
|
|
|
return m_offset;
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t bufferRange() const {
|
|
|
|
return m_length;
|
|
|
|
}
|
|
|
|
|
2017-10-15 17:56:06 +02:00
|
|
|
VkDescriptorBufferInfo descriptorInfo() const {
|
|
|
|
VkDescriptorBufferInfo info;
|
|
|
|
info.buffer = m_buffer->handle();
|
|
|
|
info.offset = m_offset;
|
|
|
|
info.range = m_length;
|
|
|
|
return info;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool operator == (const DxvkBufferBinding& other) const {
|
|
|
|
return this->m_buffer == other.m_buffer
|
|
|
|
&& this->m_offset == other.m_offset
|
|
|
|
&& this->m_length == other.m_length;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool operator != (const DxvkBufferBinding& other) const {
|
|
|
|
return this->m_buffer != other.m_buffer
|
|
|
|
|| this->m_offset != other.m_offset
|
|
|
|
|| this->m_length != other.m_length;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
Rc<DxvkBuffer> m_buffer = nullptr;
|
|
|
|
VkDeviceSize m_offset = 0;
|
|
|
|
VkDeviceSize m_length = 0;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2017-10-10 23:32:13 +02:00
|
|
|
}
|