summaryrefslogtreecommitdiff
path: root/tools/gfx/vulkan/vk-resource-views.cpp
diff options
context:
space:
mode:
authorlucy96chen <47800040+lucy96chen@users.noreply.github.com>2022-05-26 10:54:35 -0700
committerGitHub <noreply@github.com>2022-05-26 10:54:35 -0700
commit43e1b7cdc70b2fcac8a3e8ee72f5bc91726f4ec5 (patch)
tree1e4701b4ab324a199b81e1f6c671f6660f1050c5 /tools/gfx/vulkan/vk-resource-views.cpp
parent5ff4f42c636a67724523e4fe60697cfac64908cd (diff)
Split render-vk.h/.cpp into a set of smaller files (#2244)
* Some preliminary work on splitting render-vk * render-vk split, tests currently crash on null reference * fixed circular include
Diffstat (limited to 'tools/gfx/vulkan/vk-resource-views.cpp')
-rw-r--r--tools/gfx/vulkan/vk-resource-views.cpp71
1 files changed, 71 insertions, 0 deletions
diff --git a/tools/gfx/vulkan/vk-resource-views.cpp b/tools/gfx/vulkan/vk-resource-views.cpp
new file mode 100644
index 000000000..10d96ed54
--- /dev/null
+++ b/tools/gfx/vulkan/vk-resource-views.cpp
@@ -0,0 +1,71 @@
+// vk-resource-views.cpp
+#include "vk-resource-views.h"
+
+namespace gfx
+{
+
+using namespace Slang;
+
+namespace vk
+{
+
+TextureResourceViewImpl::~TextureResourceViewImpl()
+{
+ m_device->m_api.vkDestroyImageView(m_device->m_api.m_device, m_view, nullptr);
+}
+
+Result TextureResourceViewImpl::getNativeHandle(InteropHandle* outHandle)
+{
+ outHandle->api = InteropHandleAPI::Vulkan;
+ outHandle->handleValue = (uint64_t)(m_view);
+ return SLANG_OK;
+}
+
+TexelBufferResourceViewImpl::TexelBufferResourceViewImpl(DeviceImpl* device)
+ : ResourceViewImpl(ViewType::TexelBuffer, device)
+{}
+
+TexelBufferResourceViewImpl::~TexelBufferResourceViewImpl()
+{
+ m_device->m_api.vkDestroyBufferView(m_device->m_api.m_device, m_view, nullptr);
+}
+
+Result TexelBufferResourceViewImpl::getNativeHandle(InteropHandle* outHandle)
+{
+ outHandle->api = InteropHandleAPI::Vulkan;
+ outHandle->handleValue = (uint64_t)(m_view);
+ return SLANG_OK;
+}
+
+PlainBufferResourceViewImpl::PlainBufferResourceViewImpl(DeviceImpl* device)
+ : ResourceViewImpl(ViewType::PlainBuffer, device)
+{}
+
+Result PlainBufferResourceViewImpl::getNativeHandle(InteropHandle* outHandle)
+{
+ return m_buffer->getNativeResourceHandle(outHandle);
+}
+
+DeviceAddress AccelerationStructureImpl::getDeviceAddress()
+{
+ return m_buffer->getDeviceAddress() + m_offset;
+}
+
+Result AccelerationStructureImpl::getNativeHandle(InteropHandle* outHandle)
+{
+ outHandle->api = InteropHandleAPI::Vulkan;
+ outHandle->handleValue = (uint64_t)(m_vkHandle);
+ return SLANG_OK;
+}
+
+AccelerationStructureImpl::~AccelerationStructureImpl()
+{
+ if (m_device)
+ {
+ m_device->m_api.vkDestroyAccelerationStructureKHR(
+ m_device->m_api.m_device, m_vkHandle, nullptr);
+ }
+}
+
+} // namespace vk
+} // namespace gfx