summaryrefslogtreecommitdiff
path: root/tools/gfx/vulkan/vk-query.h
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-query.h
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-query.h')
-rw-r--r--tools/gfx/vulkan/vk-query.h34
1 files changed, 34 insertions, 0 deletions
diff --git a/tools/gfx/vulkan/vk-query.h b/tools/gfx/vulkan/vk-query.h
new file mode 100644
index 000000000..b9cda2557
--- /dev/null
+++ b/tools/gfx/vulkan/vk-query.h
@@ -0,0 +1,34 @@
+// vk-query.h
+#pragma once
+
+#include "vk-base.h"
+#include "vk-device.h"
+
+namespace gfx
+{
+
+using namespace Slang;
+
+namespace vk
+{
+
+class QueryPoolImpl : public QueryPoolBase
+{
+public:
+ Result init(const IQueryPool::Desc& desc, DeviceImpl* device);
+ ~QueryPoolImpl();
+
+public:
+ virtual SLANG_NO_THROW Result SLANG_MCALL
+ getResult(GfxIndex index, GfxCount count, uint64_t* data) override;
+
+public:
+ VkQueryPool m_pool;
+ RefPtr<DeviceImpl> m_device;
+};
+
+void _writeTimestamp(
+ VulkanApi* api, VkCommandBuffer vkCmdBuffer, IQueryPool* queryPool, SlangInt index);
+
+} // namespace vk
+} // namespace gfx