flycast/core/rend/vulkan/buffer.h

97 lines
3.0 KiB
C
Raw Normal View History

2019-10-05 09:50:14 +00:00
/*
* Created on: Oct 3, 2019
Copyright 2019 flyinghead
This file is part of Flycast.
Flycast is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 2 of the License, or
(at your option) any later version.
Flycast is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Flycast. If not, see <https://www.gnu.org/licenses/>.
*/
#pragma once
#include "vulkan.h"
2019-10-12 11:47:25 +00:00
#include "allocator.h"
2019-10-05 09:50:14 +00:00
struct BufferData
{
BufferData(vk::PhysicalDevice const& physicalDevice, vk::Device const& device, vk::DeviceSize size, vk::BufferUsageFlags usage,
2019-10-12 11:47:25 +00:00
Allocator *allocator = &SimpleAllocator::instance,
2019-10-05 09:50:14 +00:00
vk::MemoryPropertyFlags propertyFlags = vk::MemoryPropertyFlagBits::eHostVisible | vk::MemoryPropertyFlagBits::eHostCoherent);
2019-10-12 11:47:25 +00:00
~BufferData()
{
buffer.reset();
allocator->Free(offset, memoryType, sharedDeviceMemory);
}
2019-10-05 09:50:14 +00:00
void upload(u32 size, const void *data, u32 bufOffset = 0) const
2019-10-05 09:50:14 +00:00
{
verify((m_propertyFlags & vk::MemoryPropertyFlagBits::eHostCoherent) && (m_propertyFlags & vk::MemoryPropertyFlagBits::eHostVisible));
verify(bufOffset + size <= bufferSize);
2019-10-05 09:50:14 +00:00
2019-10-12 11:47:25 +00:00
void* dataPtr = device.mapMemory(sharedDeviceMemory, offset + bufOffset, size);
2019-10-05 09:50:14 +00:00
memcpy(dataPtr, data, size);
2019-10-12 11:47:25 +00:00
device.unmapMemory(sharedDeviceMemory);
2019-10-05 09:50:14 +00:00
}
void upload(size_t count, u32 *sizes, const void **data, u32 bufOffset = 0) const
2019-10-06 19:21:31 +00:00
{
verify((m_propertyFlags & vk::MemoryPropertyFlagBits::eHostCoherent) && (m_propertyFlags & vk::MemoryPropertyFlagBits::eHostVisible));
u32 totalSize = 0;
for (int i = 0; i < count; i++)
totalSize += sizes[i];
verify(bufOffset + totalSize <= bufferSize);
2019-10-12 11:47:25 +00:00
void* dataPtr = device.mapMemory(sharedDeviceMemory, offset + bufOffset, totalSize);
2019-10-06 19:21:31 +00:00
for (int i = 0; i < count; i++)
{
if (data[i] != nullptr)
memcpy(dataPtr, data[i], sizes[i]);
2019-10-06 19:21:31 +00:00
dataPtr = (u8 *)dataPtr + sizes[i];
}
2019-10-12 11:47:25 +00:00
device.unmapMemory(sharedDeviceMemory);
2019-10-06 19:21:31 +00:00
}
void download(u32 size, void *data, u32 bufOffset = 0) const
2019-10-09 19:16:12 +00:00
{
verify((m_propertyFlags & vk::MemoryPropertyFlagBits::eHostCoherent) && (m_propertyFlags & vk::MemoryPropertyFlagBits::eHostVisible));
verify(bufOffset + size <= bufferSize);
2019-10-09 19:16:12 +00:00
2019-10-12 11:47:25 +00:00
void* dataPtr = device.mapMemory(sharedDeviceMemory, offset + bufOffset, size);
2019-10-09 19:16:12 +00:00
memcpy(data, dataPtr, size);
2019-10-12 11:47:25 +00:00
device.unmapMemory(sharedDeviceMemory);
}
void *MapMemory()
{
return device.mapMemory(sharedDeviceMemory, offset, bufferSize);
}
void UnmapMemory()
{
device.unmapMemory(sharedDeviceMemory);
2019-10-09 19:16:12 +00:00
}
2019-10-12 11:47:25 +00:00
vk::UniqueBuffer buffer;
vk::DeviceSize bufferSize;
Allocator *allocator;
vk::DeviceSize offset;
u32 memoryType;
vk::DeviceMemory sharedDeviceMemory;
vk::Device device;
2019-10-05 09:50:14 +00:00
#if !defined(NDEBUG)
private:
vk::BufferUsageFlags m_usage;
vk::MemoryPropertyFlags m_propertyFlags;
#endif
};