BsVulkanVertexBuffer.cpp 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. //********************************** Banshee Engine (www.banshee3d.com) **************************************************//
  2. //**************** Copyright (c) 2016 Marko Pintera ([email protected]). All rights reserved. **********************//
  3. #include "BsVulkanVertexBuffer.h"
  4. #include "BsVulkanHardwareBuffer.h"
  5. #include "Profiling/BsRenderStats.h"
  6. namespace bs { namespace ct
  7. {
  8. VulkanVertexBuffer::VulkanVertexBuffer(const VERTEX_BUFFER_DESC& desc, GpuDeviceFlags deviceMask)
  9. :VertexBuffer(desc, deviceMask), mBuffer(nullptr), mUsage(desc.usage), mDeviceMask(deviceMask)
  10. { }
  11. VulkanVertexBuffer::~VulkanVertexBuffer()
  12. {
  13. if (mBuffer != nullptr)
  14. bs_delete(mBuffer);
  15. BS_INC_RENDER_STAT_CAT(ResDestroyed, RenderStatObject_VertexBuffer);
  16. }
  17. void VulkanVertexBuffer::initialize()
  18. {
  19. mBuffer = bs_new<VulkanHardwareBuffer>(VulkanHardwareBuffer::BT_VERTEX, BF_UNKNOWN, mUsage, mSize, mDeviceMask);
  20. BS_INC_RENDER_STAT_CAT(ResCreated, RenderStatObject_VertexBuffer);
  21. VertexBuffer::initialize();
  22. }
  23. void* VulkanVertexBuffer::map(UINT32 offset, UINT32 length, GpuLockOptions options, UINT32 deviceIdx, UINT32 queueIdx)
  24. {
  25. #if BS_PROFILING_ENABLED
  26. if (options == GBL_READ_ONLY || options == GBL_READ_WRITE)
  27. {
  28. BS_INC_RENDER_STAT_CAT(ResRead, RenderStatObject_VertexBuffer);
  29. }
  30. if (options == GBL_READ_WRITE || options == GBL_WRITE_ONLY || options == GBL_WRITE_ONLY_DISCARD || options == GBL_WRITE_ONLY_NO_OVERWRITE)
  31. {
  32. BS_INC_RENDER_STAT_CAT(ResWrite, RenderStatObject_VertexBuffer);
  33. }
  34. #endif
  35. return mBuffer->lock(offset, length, options, deviceIdx, queueIdx);
  36. }
  37. void VulkanVertexBuffer::unmap()
  38. {
  39. mBuffer->unlock();
  40. }
  41. void VulkanVertexBuffer::readData(UINT32 offset, UINT32 length, void* dest, UINT32 deviceIdx, UINT32 queueIdx)
  42. {
  43. mBuffer->readData(offset, length, dest, deviceIdx, queueIdx);
  44. BS_INC_RENDER_STAT_CAT(ResRead, RenderStatObject_VertexBuffer);
  45. }
  46. void VulkanVertexBuffer::writeData(UINT32 offset, UINT32 length, const void* source, BufferWriteType writeFlags,
  47. UINT32 queueIdx)
  48. {
  49. mBuffer->writeData(offset, length, source, writeFlags, queueIdx);
  50. BS_INC_RENDER_STAT_CAT(ResWrite, RenderStatObject_VertexBuffer);
  51. }
  52. void VulkanVertexBuffer::copyData(HardwareBuffer& srcBuffer, UINT32 srcOffset,
  53. UINT32 dstOffset, UINT32 length, bool discardWholeBuffer, const SPtr<CommandBuffer>& commandBuffer)
  54. {
  55. mBuffer->copyData(srcBuffer, srcOffset, dstOffset, length, discardWholeBuffer, commandBuffer);
  56. }
  57. VulkanBuffer* VulkanVertexBuffer::getResource(UINT32 deviceIdx) const
  58. {
  59. return mBuffer->getResource(deviceIdx);
  60. }
  61. }}