blob: f3e2fc9117e4113dd3968eb360311977510c175e [file] [log] [blame]
Karl Schultz6addd812016-02-02 17:17:23 -07001/*
2 * Copyright (c) 2015-2016 The Khronos Group Inc.
3 * Copyright (c) 2015-2016 Valve Corporation
4 * Copyright (c) 2015-2016 LunarG, Inc.
5 *
Jon Ashburn3ebf1252016-04-19 11:30:31 -06006 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
Karl Schultz6addd812016-02-02 17:17:23 -07009 *
Jon Ashburn3ebf1252016-04-19 11:30:31 -060010 * http://www.apache.org/licenses/LICENSE-2.0
Karl Schultz6addd812016-02-02 17:17:23 -070011 *
Jon Ashburn3ebf1252016-04-19 11:30:31 -060012 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
Karl Schultz6addd812016-02-02 17:17:23 -070017 *
18 * Author: Courtney Goeltzenleuchter <courtney@LunarG.com>
19 * Author: Cody Northrop <cody@lunarg.com>
20 */
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060021
22#ifndef VKTESTBINDING_H
23#define VKTESTBINDING_H
24
Petr Kraus858bacd2017-12-01 23:10:08 +010025#include <algorithm>
Chia-I Wub0ed7d42015-07-03 10:13:26 +080026#include <assert.h>
Petr Kraus858bacd2017-12-01 23:10:08 +010027#include <iterator>
Mark Lobodzinski722841d2016-09-07 16:34:56 -060028#include <vector>
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060029
David Pinedo9316d3b2015-11-06 12:54:48 -070030#include "vulkan/vulkan.h"
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060031
32namespace vk_testing {
33
Petr Kraus858bacd2017-12-01 23:10:08 +010034template <class Dst, class Src>
35std::vector<Dst> MakeVkHandles(const std::vector<Src> &v) {
36 std::vector<Dst> handles;
37 handles.reserve(v.size());
38 std::transform(v.begin(), v.end(), std::back_inserter(handles), [](const Src &o) { return o.handle(); });
39 return handles;
40}
41
42template <class Dst, class Src>
43std::vector<Dst> MakeVkHandles(const std::vector<Src *> &v) {
44 std::vector<Dst> handles;
45 handles.reserve(v.size());
46 std::transform(v.begin(), v.end(), std::back_inserter(handles), [](const Src *o) { return o->handle(); });
47 return handles;
48}
49
Mark Lobodzinski722841d2016-09-07 16:34:56 -060050typedef void (*ErrorCallback)(const char *expr, const char *file, unsigned int line, const char *function);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060051void set_error_callback(ErrorCallback callback);
52
Chia-I Wu999f0482015-07-03 10:32:05 +080053class PhysicalDevice;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060054class Device;
55class Queue;
Chia-I Wuf8f074f2015-07-03 10:58:57 +080056class DeviceMemory;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060057class Fence;
58class Semaphore;
59class Event;
60class QueryPool;
61class Buffer;
62class BufferView;
63class Image;
64class ImageView;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060065class DepthStencilView;
66class Shader;
67class Pipeline;
68class PipelineDelta;
69class Sampler;
70class DescriptorSetLayout;
Mark Lobodzinski0fadf5f2015-04-17 14:11:39 -050071class PipelineLayout;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060072class DescriptorSetPool;
73class DescriptorSet;
Chia-I Wu3432a0c2015-10-27 18:04:07 +080074class CommandBuffer;
75class CommandPool;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060076
Courtney Goeltzenleuchter110fdf92015-06-29 15:39:26 -060077std::vector<VkLayerProperties> GetGlobalLayers();
78std::vector<VkExtensionProperties> GetGlobalExtensions();
79std::vector<VkExtensionProperties> GetGlobalExtensions(const char *pLayerName);
80
Chia-I Wub0ed7d42015-07-03 10:13:26 +080081namespace internal {
82
Mark Lobodzinski64318ba2017-01-26 13:34:13 -070083template <typename T>
84class Handle {
85 public:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080086 const T &handle() const { return handle_; }
Petr Krausb3d2c822017-12-01 23:09:19 +010087 bool initialized() const { return (handle_ != T{}); }
Chia-I Wub0ed7d42015-07-03 10:13:26 +080088
Mark Lobodzinski64318ba2017-01-26 13:34:13 -070089 protected:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080090 typedef T handle_type;
91
Petr Krausb3d2c822017-12-01 23:09:19 +010092 explicit Handle() : handle_{} {}
Chia-I Wub0ed7d42015-07-03 10:13:26 +080093 explicit Handle(T handle) : handle_(handle) {}
94
Petr Krausb3d2c822017-12-01 23:09:19 +010095 // handles are non-copyable
96 Handle(const Handle &) = delete;
97 Handle &operator=(const Handle &) = delete;
98
99 // handles can be moved out
Dave Houlton0cf0d132017-12-22 13:55:53 -0700100 Handle(Handle &&src) NOEXCEPT : handle_{src.handle_} { src.handle_ = {}; }
101 Handle &operator=(Handle &&src) NOEXCEPT {
Petr Krausb3d2c822017-12-01 23:09:19 +0100102 handle_ = src.handle_;
103 src.handle_ = {};
104 return *this;
105 }
106
Karl Schultz6addd812016-02-02 17:17:23 -0700107 void init(T handle) {
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800108 assert(!initialized());
109 handle_ = handle;
110 }
111
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700112 private:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800113 T handle_;
114};
115
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700116template <typename T>
117class NonDispHandle : public Handle<T> {
118 protected:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800119 explicit NonDispHandle() : Handle<T>(), dev_handle_(VK_NULL_HANDLE) {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600120 explicit NonDispHandle(VkDevice dev, T handle) : Handle<T>(handle), dev_handle_(dev) {}
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800121
Mike Schuchardt0bc8e7a2018-01-02 14:39:51 -0700122 NonDispHandle(NonDispHandle &&src) : Handle<T>(std::move(src)) {
123 dev_handle_ = src.dev_handle_;
124 src.dev_handle_ = VK_NULL_HANDLE;
125 }
126 NonDispHandle &operator=(NonDispHandle &&src) {
127 Handle<T>::operator=(std::move(src));
128 dev_handle_ = src.dev_handle_;
129 src.dev_handle_ = VK_NULL_HANDLE;
130 return *this;
131 }
Petr Krausb3d2c822017-12-01 23:09:19 +0100132
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800133 const VkDevice &device() const { return dev_handle_; }
134
Karl Schultz6addd812016-02-02 17:17:23 -0700135 void init(VkDevice dev, T handle) {
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800136 assert(!Handle<T>::initialized() && dev_handle_ == VK_NULL_HANDLE);
137 Handle<T>::init(handle);
138 dev_handle_ = dev;
139 }
140
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700141 private:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800142 VkDevice dev_handle_;
143};
144
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700145} // namespace internal
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800146
Chia-I Wu999f0482015-07-03 10:32:05 +0800147class PhysicalDevice : public internal::Handle<VkPhysicalDevice> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700148 public:
Karl Schultz6addd812016-02-02 17:17:23 -0700149 explicit PhysicalDevice(VkPhysicalDevice phy) : Handle(phy) {
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600150 memory_properties_ = memory_properties();
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600151 device_properties_ = properties();
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600152 }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600153
Tony Barbourd1c35722015-04-16 15:59:00 -0600154 VkPhysicalDeviceProperties properties() const;
Tony Barbourd1c35722015-04-16 15:59:00 -0600155 VkPhysicalDeviceMemoryProperties memory_properties() const;
Cody Northropd0802882015-08-03 17:04:53 -0600156 std::vector<VkQueueFamilyProperties> queue_properties() const;
Chris Forbesf9cfe182016-04-04 17:22:42 +1200157 VkPhysicalDeviceFeatures features() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600158
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600159 bool set_memory_type(const uint32_t type_bits, VkMemoryAllocateInfo *info, const VkMemoryPropertyFlags properties,
Karl Schultz6addd812016-02-02 17:17:23 -0700160 const VkMemoryPropertyFlags forbid = 0) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600161
Courtney Goeltzenleuchter35985f62015-09-14 17:22:16 -0600162 // vkEnumerateDeviceExtensionProperties()
Courtney Goeltzenleuchterf579fa62015-06-10 17:39:03 -0600163 std::vector<VkExtensionProperties> extensions() const;
Karl Schultz6addd812016-02-02 17:17:23 -0700164 std::vector<VkExtensionProperties> extensions(const char *pLayerName) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600165
166 // vkEnumerateLayers()
Courtney Goeltzenleuchtercd69eee2015-07-06 09:10:47 -0600167 std::vector<VkLayerProperties> layers() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600168
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700169 private:
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600170 void add_extension_dependencies(uint32_t dependency_count, VkExtensionProperties *depencency_props,
171 std::vector<VkExtensionProperties> &ext_list);
Chia-I Wu999f0482015-07-03 10:32:05 +0800172
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600173 VkPhysicalDeviceMemoryProperties memory_properties_;
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600174
175 VkPhysicalDeviceProperties device_properties_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600176};
177
John Zulauf01da3ee2017-10-18 18:13:37 -0600178class QueueCreateInfoArray {
179 private:
180 std::vector<VkDeviceQueueCreateInfo> queue_info_;
181 std::vector<std::vector<float>> queue_priorities_;
182
183 public:
184 QueueCreateInfoArray(const std::vector<VkQueueFamilyProperties> &queue_props);
185 size_t size() const { return queue_info_.size(); }
186 const VkDeviceQueueCreateInfo *data() const { return queue_info_.data(); }
187};
188
Chia-I Wuf368b602015-07-03 10:41:20 +0800189class Device : public internal::Handle<VkDevice> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700190 public:
Chia-I Wu999f0482015-07-03 10:32:05 +0800191 explicit Device(VkPhysicalDevice phy) : phy_(phy) {}
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600192 ~Device();
193
194 // vkCreateDevice()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600195 void init(const VkDeviceCreateInfo &info);
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600196 void init(std::vector<const char *> &extensions,
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700197 VkPhysicalDeviceFeatures *features = nullptr); // all queues, all extensions, etc
Karl Schultz6addd812016-02-02 17:17:23 -0700198 void init() {
Karl Schultz6addd812016-02-02 17:17:23 -0700199 std::vector<const char *> extensions;
Tony Barbour4c70d102016-08-08 16:06:56 -0600200 init(extensions);
Karl Schultz6addd812016-02-02 17:17:23 -0700201 };
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600202
Chia-I Wu999f0482015-07-03 10:32:05 +0800203 const PhysicalDevice &phy() const { return phy_; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600204
Petr Krausb9659a02017-12-11 01:17:46 +0100205 std::vector<const char *> GetEnabledExtensions() { return enabled_extensions_; }
206 bool IsEnbledExtension(const char *extension);
207
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600208 // vkGetDeviceProcAddr()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600209 PFN_vkVoidFunction get_proc(const char *name) const { return vkGetDeviceProcAddr(handle(), name); }
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600210
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600211 // vkGetDeviceQueue()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600212 const std::vector<Queue *> &graphics_queues() const { return queues_[GRAPHICS]; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600213 const std::vector<Queue *> &compute_queues() { return queues_[COMPUTE]; }
214 const std::vector<Queue *> &dma_queues() { return queues_[DMA]; }
Mike Schuchardt06304c22017-03-01 17:09:09 -0700215 uint32_t queue_family_without_capabilities( VkQueueFlags capabilities );
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600216 uint32_t graphics_queue_node_index_;
217
218 struct Format {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600219 VkFormat format;
220 VkImageTiling tiling;
221 VkFlags features;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600222 };
223 // vkGetFormatInfo()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600224 VkFormatProperties format_properties(VkFormat format);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600225 const std::vector<Format> &formats() const { return formats_; }
226
227 // vkDeviceWaitIdle()
228 void wait();
229
230 // vkWaitForFences()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600231 VkResult wait(const std::vector<const Fence *> &fences, bool wait_all, uint64_t timeout);
232 VkResult wait(const Fence &fence) { return wait(std::vector<const Fence *>(1, &fence), true, (uint64_t)-1); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600233
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800234 // vkUpdateDescriptorSets()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600235 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes, const std::vector<VkCopyDescriptorSet> &copies);
236 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes) {
237 return update_descriptor_sets(writes, std::vector<VkCopyDescriptorSet>());
Karl Schultz6addd812016-02-02 17:17:23 -0700238 }
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800239
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600240 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
241 VkDescriptorType type, uint32_t count,
242 const VkDescriptorImageInfo *image_info);
243 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
244 VkDescriptorType type, uint32_t count,
245 const VkDescriptorBufferInfo *buffer_info);
246 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
247 VkDescriptorType type, uint32_t count, const VkBufferView *buffer_views);
248 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
249 VkDescriptorType type, const std::vector<VkDescriptorImageInfo> &image_info);
250 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
251 VkDescriptorType type, const std::vector<VkDescriptorBufferInfo> &buffer_info);
252 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
253 VkDescriptorType type, const std::vector<VkBufferView> &buffer_views);
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800254
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600255 static VkCopyDescriptorSet copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding, uint32_t src_array_element,
256 const DescriptorSet &dst_set, uint32_t dst_binding, uint32_t dst_array_element,
257 uint32_t count);
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800258
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700259 private:
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600260 enum QueueIndex {
261 GRAPHICS,
262 COMPUTE,
263 DMA,
264 QUEUE_COUNT,
265 };
266
267 void init_queues();
268 void init_formats();
269
Chia-I Wu999f0482015-07-03 10:32:05 +0800270 PhysicalDevice phy_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600271
Petr Krausb9659a02017-12-11 01:17:46 +0100272 std::vector<const char *> enabled_extensions_;
273
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600274 std::vector<Queue *> queues_[QUEUE_COUNT];
275 std::vector<Format> formats_;
276};
277
Chia-I Wudf12ffd2015-07-03 10:53:18 +0800278class Queue : public internal::Handle<VkQueue> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700279 public:
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600280 explicit Queue(VkQueue queue, int index) : Handle(queue) { family_index_ = index; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600281
282 // vkQueueSubmit()
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800283 void submit(const std::vector<const CommandBuffer *> &cmds, Fence &fence);
284 void submit(const CommandBuffer &cmd, Fence &fence);
285 void submit(const CommandBuffer &cmd);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600286
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600287 // vkQueueWaitIdle()
288 void wait();
289
Karl Schultz6addd812016-02-02 17:17:23 -0700290 int get_family_index() { return family_index_; }
Tony Barbourfb21ea32015-07-23 10:35:30 -0600291
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700292 private:
Tony Barbourfb21ea32015-07-23 10:35:30 -0600293 int family_index_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600294};
295
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800296class DeviceMemory : public internal::NonDispHandle<VkDeviceMemory> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700297 public:
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800298 ~DeviceMemory();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600299
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800300 // vkAllocateMemory()
301 void init(const Device &dev, const VkMemoryAllocateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600302
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600303 // vkMapMemory()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600304 const void *map(VkFlags flags) const;
Karl Schultz6addd812016-02-02 17:17:23 -0700305 void *map(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600306 const void *map() const { return map(0); }
Karl Schultz6addd812016-02-02 17:17:23 -0700307 void *map() { return map(0); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600308
309 // vkUnmapMemory()
310 void unmap() const;
311
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600312 static VkMemoryAllocateInfo alloc_info(VkDeviceSize size, uint32_t memory_type_index);
Mike Schuchardt8cacbb02017-10-26 14:06:38 -0600313 static VkMemoryAllocateInfo get_resource_alloc_info(const vk_testing::Device &dev, const VkMemoryRequirements &reqs,
314 VkMemoryPropertyFlags mem_props);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600315};
316
Chia-I Wud9e8e822015-07-03 11:45:55 +0800317class Fence : public internal::NonDispHandle<VkFence> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700318 public:
Chia-I Wud9e8e822015-07-03 11:45:55 +0800319 ~Fence();
320
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600321 // vkCreateFence()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600322 void init(const Device &dev, const VkFenceCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600323
324 // vkGetFenceStatus()
Chia-I Wud9e8e822015-07-03 11:45:55 +0800325 VkResult status() const { return vkGetFenceStatus(device(), handle()); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600326
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600327 static VkFenceCreateInfo create_info(VkFenceCreateFlags flags);
328 static VkFenceCreateInfo create_info();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600329};
330
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800331class Semaphore : public internal::NonDispHandle<VkSemaphore> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700332 public:
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800333 ~Semaphore();
334
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600335 // vkCreateSemaphore()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600336 void init(const Device &dev, const VkSemaphoreCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600337
Tony Barbouraf892a12015-06-26 12:56:09 -0600338 static VkSemaphoreCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600339};
340
Chia-I Wuc5c97992015-07-03 11:49:42 +0800341class Event : public internal::NonDispHandle<VkEvent> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700342 public:
Chia-I Wuc5c97992015-07-03 11:49:42 +0800343 ~Event();
344
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600345 // vkCreateEvent()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600346 void init(const Device &dev, const VkEventCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600347
348 // vkGetEventStatus()
349 // vkSetEvent()
350 // vkResetEvent()
Chia-I Wuc5c97992015-07-03 11:49:42 +0800351 VkResult status() const { return vkGetEventStatus(device(), handle()); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600352 void set();
353 void reset();
354
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600355 static VkEventCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600356};
357
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800358class QueryPool : public internal::NonDispHandle<VkQueryPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700359 public:
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800360 ~QueryPool();
361
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600362 // vkCreateQueryPool()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600363 void init(const Device &dev, const VkQueryPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600364
365 // vkGetQueryPoolResults()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600366 VkResult results(uint32_t first, uint32_t count, size_t size, void *data, size_t stride);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600367
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600368 static VkQueryPoolCreateInfo create_info(VkQueryType type, uint32_t slot_count);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600369};
370
Chia-I Wu681d7a02015-07-03 13:44:34 +0800371class Buffer : public internal::NonDispHandle<VkBuffer> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700372 public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800373 explicit Buffer() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600374 explicit Buffer(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info); }
Tony Barbourd1c35722015-04-16 15:59:00 -0600375 explicit Buffer(const Device &dev, VkDeviceSize size) { init(dev, size); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600376
Chia-I Wu681d7a02015-07-03 13:44:34 +0800377 ~Buffer();
378
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600379 // vkCreateBuffer()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600380 void init(const Device &dev, const VkBufferCreateInfo &info, VkMemoryPropertyFlags mem_props);
381 void init(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info, 0); }
382 void init(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags mem_props) { init(dev, create_info(size, 0), mem_props); }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800383 void init(const Device &dev, VkDeviceSize size) { init(dev, size, 0); }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600384 void init_as_src(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) {
Karl Schultz6addd812016-02-02 17:17:23 -0700385 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_SRC_BIT), reqs);
386 }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600387 void init_as_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) {
Karl Schultz6addd812016-02-02 17:17:23 -0700388 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_DST_BIT), reqs);
389 }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600390 void init_as_src_and_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) {
391 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_SRC_BIT | VK_BUFFER_USAGE_TRANSFER_DST_BIT), reqs);
Karl Schultz6addd812016-02-02 17:17:23 -0700392 }
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600393 void init_no_mem(const Device &dev, const VkBufferCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600394
Chia-I Wu681d7a02015-07-03 13:44:34 +0800395 // get the internal memory
396 const DeviceMemory &memory() const { return internal_mem_; }
Karl Schultz6addd812016-02-02 17:17:23 -0700397 DeviceMemory &memory() { return internal_mem_; }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800398
399 // vkGetObjectMemoryRequirements()
400 VkMemoryRequirements memory_requirements() const;
401
402 // vkBindObjectMemory()
403 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Mark Lobodzinski942b1722015-05-11 17:21:15 -0500404
Tony Barbourd1c35722015-04-16 15:59:00 -0600405 static VkBufferCreateInfo create_info(VkDeviceSize size, VkFlags usage);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600406
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600407 VkBufferMemoryBarrier buffer_memory_barrier(VkFlags output_mask, VkFlags input_mask, VkDeviceSize offset,
Karl Schultz6addd812016-02-02 17:17:23 -0700408 VkDeviceSize size) const {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600409 VkBufferMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600410 barrier.sType = VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800411 barrier.buffer = handle();
Chia-I Wua4594202015-10-27 19:54:37 +0800412 barrier.srcAccessMask = output_mask;
413 barrier.dstAccessMask = input_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600414 barrier.offset = offset;
415 barrier.size = size;
416 return barrier;
417 }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800418
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700419 private:
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600420 VkBufferCreateInfo create_info_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800421
422 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600423};
424
Chia-I Wu3158bf32015-07-03 11:49:42 +0800425class BufferView : public internal::NonDispHandle<VkBufferView> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700426 public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800427 ~BufferView();
428
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600429 // vkCreateBufferView()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600430 void init(const Device &dev, const VkBufferViewCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600431};
432
Chia-I Wu681d7a02015-07-03 13:44:34 +0800433class Image : public internal::NonDispHandle<VkImage> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700434 public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800435 explicit Image() : NonDispHandle(), format_features_(0) {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600436 explicit Image(const Device &dev, const VkImageCreateInfo &info) : format_features_(0) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600437
Chia-I Wu681d7a02015-07-03 13:44:34 +0800438 ~Image();
439
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600440 // vkCreateImage()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600441 void init(const Device &dev, const VkImageCreateInfo &info, VkMemoryPropertyFlags mem_props);
442 void init(const Device &dev, const VkImageCreateInfo &info) { init(dev, info, 0); }
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600443 void init_no_mem(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600444
Chia-I Wu681d7a02015-07-03 13:44:34 +0800445 // get the internal memory
446 const DeviceMemory &memory() const { return internal_mem_; }
Karl Schultz6addd812016-02-02 17:17:23 -0700447 DeviceMemory &memory() { return internal_mem_; }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800448
449 // vkGetObjectMemoryRequirements()
450 VkMemoryRequirements memory_requirements() const;
451
452 // vkBindObjectMemory()
453 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600454
Tony Barbour59a47322015-06-24 16:06:58 -0600455 // vkGetImageSubresourceLayout()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600456 VkSubresourceLayout subresource_layout(const VkImageSubresource &subres) const;
457 VkSubresourceLayout subresource_layout(const VkImageSubresourceLayers &subres) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600458
459 bool transparent() const;
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600460 bool copyable() const { return (format_features_ & VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600461
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600462 VkImageSubresourceRange subresource_range(VkImageAspectFlagBits aspect) const {
Karl Schultz6addd812016-02-02 17:17:23 -0700463 return subresource_range(create_info_, aspect);
464 }
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600465 VkExtent3D extent() const { return create_info_.extent; }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600466 VkExtent3D extent(uint32_t mip_level) const { return extent(create_info_.extent, mip_level); }
Karl Schultz6addd812016-02-02 17:17:23 -0700467 VkFormat format() const { return create_info_.format; }
Mike Weiblene6e01172017-03-07 22:18:40 -0700468 VkImageUsageFlags usage() const { return create_info_.usage; }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600469 VkImageMemoryBarrier image_memory_barrier(VkFlags output_mask, VkFlags input_mask, VkImageLayout old_layout,
470 VkImageLayout new_layout, const VkImageSubresourceRange &range) const {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600471 VkImageMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600472 barrier.sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER;
Chia-I Wua4594202015-10-27 19:54:37 +0800473 barrier.srcAccessMask = output_mask;
474 barrier.dstAccessMask = input_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600475 barrier.oldLayout = old_layout;
476 barrier.newLayout = new_layout;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800477 barrier.image = handle();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600478 barrier.subresourceRange = range;
479 return barrier;
480 }
481
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600482 static VkImageCreateInfo create_info();
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600483 static VkImageSubresource subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer);
484 static VkImageSubresource subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer);
485 static VkImageSubresourceLayers subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer,
Karl Schultz6addd812016-02-02 17:17:23 -0700486 uint32_t array_size);
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600487 static VkImageSubresourceLayers subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer,
488 uint32_t array_size);
489 static VkImageSubresourceRange subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level, uint32_t mip_levels,
490 uint32_t base_array_layer, uint32_t num_layers);
491 static VkImageSubresourceRange subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask);
492 static VkImageSubresourceRange subresource_range(const VkImageSubresource &subres);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600493
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600494 static VkExtent2D extent(int32_t width, int32_t height);
495 static VkExtent2D extent(const VkExtent2D &extent, uint32_t mip_level);
496 static VkExtent2D extent(const VkExtent3D &extent);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600497
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600498 static VkExtent3D extent(int32_t width, int32_t height, int32_t depth);
499 static VkExtent3D extent(const VkExtent3D &extent, uint32_t mip_level);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600500
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700501 private:
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600502 void init_info(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600503
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600504 VkImageCreateInfo create_info_;
505 VkFlags format_features_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800506
507 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600508};
509
Chia-I Wu3158bf32015-07-03 11:49:42 +0800510class ImageView : public internal::NonDispHandle<VkImageView> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700511 public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800512 ~ImageView();
513
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600514 // vkCreateImageView()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600515 void init(const Device &dev, const VkImageViewCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600516};
517
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800518class ShaderModule : public internal::NonDispHandle<VkShaderModule> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700519 public:
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800520 ~ShaderModule();
521
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600522 // vkCreateShaderModule()
523 void init(const Device &dev, const VkShaderModuleCreateInfo &info);
524 VkResult init_try(const Device &dev, const VkShaderModuleCreateInfo &info);
525
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600526 static VkShaderModuleCreateInfo create_info(size_t code_size, const uint32_t *code, VkFlags flags);
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600527};
528
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800529class Pipeline : public internal::NonDispHandle<VkPipeline> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700530 public:
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800531 ~Pipeline();
532
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600533 // vkCreateGraphicsPipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600534 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600535 // vkCreateGraphicsPipelineDerivative()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600536 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info, const VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600537 // vkCreateComputePipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600538 void init(const Device &dev, const VkComputePipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600539 // vkLoadPipeline()
Karl Schultz6addd812016-02-02 17:17:23 -0700540 void init(const Device &dev, size_t size, const void *data);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600541 // vkLoadPipelineDerivative()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600542 void init(const Device &dev, size_t size, const void *data, VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600543
Chris Forbes95292b12015-05-25 11:13:26 +1200544 // vkCreateGraphicsPipeline with error return
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600545 VkResult init_try(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Chris Forbes95292b12015-05-25 11:13:26 +1200546
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600547 // vkStorePipeline()
548 size_t store(size_t size, void *data);
549};
550
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800551class PipelineLayout : public internal::NonDispHandle<VkPipelineLayout> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700552 public:
Dave Houlton0cf0d132017-12-22 13:55:53 -0700553 PipelineLayout() NOEXCEPT : NonDispHandle(){};
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800554 ~PipelineLayout();
555
Mike Schuchardt0bc8e7a2018-01-02 14:39:51 -0700556 // Move constructor for Visual Studio 2013
557 PipelineLayout(PipelineLayout &&src) : NonDispHandle(std::move(src)){};
558
Petr Kraus65ccc882017-12-03 15:36:03 +0100559 PipelineLayout &operator=(PipelineLayout &&src) {
560 this->~PipelineLayout();
561 this->NonDispHandle::operator=(std::move(src));
562 return *this;
563 };
564
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800565 // vCreatePipelineLayout()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600566 void init(const Device &dev, VkPipelineLayoutCreateInfo &info, const std::vector<const DescriptorSetLayout *> &layouts);
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800567};
568
Chia-I Wu8c721c62015-07-03 11:49:42 +0800569class Sampler : public internal::NonDispHandle<VkSampler> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700570 public:
Chia-I Wu8c721c62015-07-03 11:49:42 +0800571 ~Sampler();
572
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600573 // vkCreateSampler()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600574 void init(const Device &dev, const VkSamplerCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600575};
576
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600577class DescriptorSetLayout : public internal::NonDispHandle<VkDescriptorSetLayout> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700578 public:
Dave Houlton0cf0d132017-12-22 13:55:53 -0700579 DescriptorSetLayout() NOEXCEPT : NonDispHandle(){};
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800580 ~DescriptorSetLayout();
581
Mike Schuchardt0bc8e7a2018-01-02 14:39:51 -0700582 // Move constructor for Visual Studio 2013
583 DescriptorSetLayout(DescriptorSetLayout &&src) : NonDispHandle(std::move(src)){};
584
Dave Houlton0cf0d132017-12-22 13:55:53 -0700585 DescriptorSetLayout &operator=(DescriptorSetLayout &&src) NOEXCEPT {
Petr Kraus32ea6082017-12-02 01:02:59 +0100586 this->~DescriptorSetLayout();
587 this->NonDispHandle::operator=(std::move(src));
588 return *this;
589 }
590
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600591 // vkCreateDescriptorSetLayout()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600592 void init(const Device &dev, const VkDescriptorSetLayoutCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600593};
594
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800595class DescriptorPool : public internal::NonDispHandle<VkDescriptorPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700596 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800597 ~DescriptorPool();
598
Karl Schultz6addd812016-02-02 17:17:23 -0700599 // Descriptor sets allocated from this pool will need access to the original
600 // object
Cody Northropcdc72a42015-10-08 11:39:25 -0600601 VkDescriptorPool GetObj() { return pool_; }
602
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600603 // vkCreateDescriptorPool()
Courtney Goeltzenleuchterfe908d32015-09-16 16:12:45 -0600604 void init(const Device &dev, const VkDescriptorPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600605
606 // vkResetDescriptorPool()
607 void reset();
608
Cody Northropcdc72a42015-10-08 11:39:25 -0600609 // vkFreeDescriptorSet()
610 void setDynamicUsage(bool isDynamic) { dynamic_usage_ = isDynamic; }
611 bool getDynamicUsage() { return dynamic_usage_; }
612
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800613 // vkAllocateDescriptorSets()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600614 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const std::vector<const DescriptorSetLayout *> &layouts);
615 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const DescriptorSetLayout &layout, uint32_t count);
616 DescriptorSet *alloc_sets(const Device &dev, const DescriptorSetLayout &layout);
Cody Northropcdc72a42015-10-08 11:39:25 -0600617
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700618 private:
Cody Northropcdc72a42015-10-08 11:39:25 -0600619 VkDescriptorPool pool_;
620
621 // Track whether this pool's usage is VK_DESCRIPTOR_POOL_USAGE_DYNAMIC
622 bool dynamic_usage_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600623};
624
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800625class DescriptorSet : public internal::NonDispHandle<VkDescriptorSet> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700626 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800627 ~DescriptorSet();
628
629 explicit DescriptorSet() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600630 explicit DescriptorSet(const Device &dev, DescriptorPool *pool, VkDescriptorSet set) : NonDispHandle(dev.handle(), set) {
Karl Schultz6addd812016-02-02 17:17:23 -0700631 containing_pool_ = pool;
632 }
Tony Barbour67e99152015-07-10 14:10:27 -0600633
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700634 private:
Karl Schultz6addd812016-02-02 17:17:23 -0700635 DescriptorPool *containing_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600636};
637
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800638class CommandPool : public internal::NonDispHandle<VkCommandPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700639 public:
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800640 ~CommandPool();
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600641
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800642 explicit CommandPool() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600643 explicit CommandPool(const Device &dev, const VkCommandPoolCreateInfo &info) { init(dev, info); }
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600644
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800645 void init(const Device &dev, const VkCommandPoolCreateInfo &info);
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600646
Mike Schuchardt06304c22017-03-01 17:09:09 -0700647 static VkCommandPoolCreateInfo create_info(uint32_t queue_family_index, VkCommandPoolCreateFlags flags);
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600648};
649
Mike Schuchardt06304c22017-03-01 17:09:09 -0700650inline VkCommandPoolCreateInfo CommandPool::create_info(uint32_t queue_family_index, VkCommandPoolCreateFlags flags) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800651 VkCommandPoolCreateInfo info = {};
652 info.sType = VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600653 info.queueFamilyIndex = queue_family_index;
Mike Schuchardt06304c22017-03-01 17:09:09 -0700654 info.flags = flags;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600655 return info;
656}
657
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800658class CommandBuffer : public internal::Handle<VkCommandBuffer> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700659 public:
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800660 ~CommandBuffer();
Chia-I Wube2b9172015-07-03 11:49:42 +0800661
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800662 explicit CommandBuffer() : Handle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600663 explicit CommandBuffer(const Device &dev, const VkCommandBufferAllocateInfo &info) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600664
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800665 // vkAllocateCommandBuffers()
666 void init(const Device &dev, const VkCommandBufferAllocateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600667
668 // vkBeginCommandBuffer()
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800669 void begin(const VkCommandBufferBeginInfo *info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600670 void begin();
671
672 // vkEndCommandBuffer()
673 // vkResetCommandBuffer()
674 void end();
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800675 void reset(VkCommandBufferResetFlags flags);
676 void reset() { reset(VK_COMMAND_BUFFER_RESET_RELEASE_RESOURCES_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600677
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800678 static VkCommandBufferAllocateInfo create_info(VkCommandPool const &pool);
Chia-I Wube2b9172015-07-03 11:49:42 +0800679
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700680 private:
Chia-I Wube2b9172015-07-03 11:49:42 +0800681 VkDevice dev_handle_;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800682 VkCommandPool cmd_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600683};
684
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600685inline VkMemoryAllocateInfo DeviceMemory::alloc_info(VkDeviceSize size, uint32_t memory_type_index) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800686 VkMemoryAllocateInfo info = {};
Chia-I Wu00ce5402015-11-10 16:21:09 +0800687 info.sType = VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO;
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800688 info.allocationSize = size;
689 info.memoryTypeIndex = memory_type_index;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600690 return info;
691}
692
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600693inline VkBufferCreateInfo Buffer::create_info(VkDeviceSize size, VkFlags usage) {
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600694 VkBufferCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600695 info.sType = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO;
696 info.size = size;
697 info.usage = usage;
698 return info;
699}
700
Karl Schultz6addd812016-02-02 17:17:23 -0700701inline VkFenceCreateInfo Fence::create_info(VkFenceCreateFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600702 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600703 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
704 info.flags = flags;
705 return info;
706}
707
Karl Schultz6addd812016-02-02 17:17:23 -0700708inline VkFenceCreateInfo Fence::create_info() {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600709 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600710 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
711 return info;
712}
713
Karl Schultz6addd812016-02-02 17:17:23 -0700714inline VkSemaphoreCreateInfo Semaphore::create_info(VkFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600715 VkSemaphoreCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600716 info.sType = VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600717 info.flags = flags;
718 return info;
719}
720
Karl Schultz6addd812016-02-02 17:17:23 -0700721inline VkEventCreateInfo Event::create_info(VkFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600722 VkEventCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600723 info.sType = VK_STRUCTURE_TYPE_EVENT_CREATE_INFO;
724 info.flags = flags;
725 return info;
726}
727
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600728inline VkQueryPoolCreateInfo QueryPool::create_info(VkQueryType type, uint32_t slot_count) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600729 VkQueryPoolCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600730 info.sType = VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO;
731 info.queryType = type;
Jon Ashburnf19916e2016-01-11 13:12:43 -0700732 info.queryCount = slot_count;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600733 return info;
734}
735
Karl Schultz6addd812016-02-02 17:17:23 -0700736inline VkImageCreateInfo Image::create_info() {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600737 VkImageCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600738 info.sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO;
739 info.extent.width = 1;
740 info.extent.height = 1;
741 info.extent.depth = 1;
742 info.mipLevels = 1;
Courtney Goeltzenleuchter5d2aed42015-10-21 17:57:31 -0600743 info.arrayLayers = 1;
Chia-I Wu5c17c962015-10-31 00:31:16 +0800744 info.samples = VK_SAMPLE_COUNT_1_BIT;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600745 return info;
746}
747
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600748inline VkImageSubresource Image::subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600749 VkImageSubresource subres = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600750 if (aspect == 0) {
751 assert(!"Invalid VkImageAspectFlags");
752 }
Chia-I Wu52b07e72015-10-27 19:55:05 +0800753 subres.aspectMask = aspect;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600754 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600755 subres.arrayLayer = array_layer;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600756 return subres;
757}
758
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600759inline VkImageSubresource Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer) {
760 return subresource(range.aspectMask, range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600761}
762
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600763inline VkImageSubresourceLayers Image::subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer,
Karl Schultz6addd812016-02-02 17:17:23 -0700764 uint32_t array_size) {
Chia-I Wu1b99bb22015-10-27 19:25:11 +0800765 VkImageSubresourceLayers subres = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600766 switch (aspect) {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700767 case VK_IMAGE_ASPECT_COLOR_BIT:
768 case VK_IMAGE_ASPECT_DEPTH_BIT:
769 case VK_IMAGE_ASPECT_STENCIL_BIT:
770 case VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT:
771 /* valid */
772 break;
773 default:
774 assert(!"Invalid VkImageAspectFlags");
Karl Schultz0ab73f82016-03-29 12:41:24 -0600775 }
Chia-I Wuab83a0e2015-10-27 19:00:15 +0800776 subres.aspectMask = aspect;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600777 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter8367ce02015-10-16 09:46:00 -0600778 subres.baseArrayLayer = array_layer;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800779 subres.layerCount = array_size;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600780 return subres;
781}
782
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600783inline VkImageSubresourceLayers Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer,
784 uint32_t array_size) {
785 return subresource(range.aspectMask, range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer, array_size);
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600786}
787
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600788inline VkImageSubresourceRange Image::subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level,
789 uint32_t mip_levels, uint32_t base_array_layer, uint32_t num_layers) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600790 VkImageSubresourceRange range = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600791 if (aspect_mask == 0) {
792 assert(!"Invalid VkImageAspectFlags");
793 }
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600794 range.aspectMask = aspect_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600795 range.baseMipLevel = base_mip_level;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800796 range.levelCount = mip_levels;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600797 range.baseArrayLayer = base_array_layer;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800798 range.layerCount = num_layers;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600799 return range;
800}
801
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600802inline VkImageSubresourceRange Image::subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask) {
803 return subresource_range(aspect_mask, 0, info.mipLevels, 0, info.arrayLayers);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600804}
805
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600806inline VkImageSubresourceRange Image::subresource_range(const VkImageSubresource &subres) {
807 return subresource_range(subres.aspectMask, subres.mipLevel, 1, subres.arrayLayer, 1);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600808}
809
Karl Schultz6addd812016-02-02 17:17:23 -0700810inline VkExtent2D Image::extent(int32_t width, int32_t height) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600811 VkExtent2D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600812 extent.width = width;
813 extent.height = height;
814 return extent;
815}
816
Karl Schultz6addd812016-02-02 17:17:23 -0700817inline VkExtent2D Image::extent(const VkExtent2D &extent, uint32_t mip_level) {
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600818 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
819 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600820 return Image::extent(width, height);
821}
822
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600823inline VkExtent2D Image::extent(const VkExtent3D &extent) { return Image::extent(extent.width, extent.height); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600824
Karl Schultz6addd812016-02-02 17:17:23 -0700825inline VkExtent3D Image::extent(int32_t width, int32_t height, int32_t depth) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600826 VkExtent3D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600827 extent.width = width;
828 extent.height = height;
829 extent.depth = depth;
830 return extent;
831}
832
Karl Schultz6addd812016-02-02 17:17:23 -0700833inline VkExtent3D Image::extent(const VkExtent3D &extent, uint32_t mip_level) {
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600834 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
835 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
836 const int32_t depth = (extent.depth >> mip_level) ? extent.depth >> mip_level : 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600837 return Image::extent(width, height, depth);
838}
839
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600840inline VkShaderModuleCreateInfo ShaderModule::create_info(size_t code_size, const uint32_t *code, VkFlags flags) {
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600841 VkShaderModuleCreateInfo info = {};
842 info.sType = VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO;
843 info.codeSize = code_size;
844 info.pCode = code;
845 info.flags = flags;
846 return info;
847}
848
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600849inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
850 VkDescriptorType type, uint32_t count,
851 const VkDescriptorImageInfo *image_info) {
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800852 VkWriteDescriptorSet write = {};
853 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800854 write.dstSet = set.handle();
855 write.dstBinding = binding;
856 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800857 write.descriptorCount = count;
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800858 write.descriptorType = type;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600859 write.pImageInfo = image_info;
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800860 return write;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600861}
862
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600863inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
864 VkDescriptorType type, uint32_t count,
865 const VkDescriptorBufferInfo *buffer_info) {
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600866 VkWriteDescriptorSet write = {};
867 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800868 write.dstSet = set.handle();
869 write.dstBinding = binding;
870 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800871 write.descriptorCount = count;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600872 write.descriptorType = type;
873 write.pBufferInfo = buffer_info;
874 return write;
875}
876
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600877inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
878 VkDescriptorType type, uint32_t count, const VkBufferView *buffer_views) {
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600879 VkWriteDescriptorSet write = {};
880 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800881 write.dstSet = set.handle();
882 write.dstBinding = binding;
883 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800884 write.descriptorCount = count;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600885 write.descriptorType = type;
886 write.pTexelBufferView = buffer_views;
887 return write;
888}
889
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600890inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
891 VkDescriptorType type,
892 const std::vector<VkDescriptorImageInfo> &image_info) {
893 return write_descriptor_set(set, binding, array_element, type, image_info.size(), &image_info[0]);
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600894}
895
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600896inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
897 VkDescriptorType type,
898 const std::vector<VkDescriptorBufferInfo> &buffer_info) {
899 return write_descriptor_set(set, binding, array_element, type, buffer_info.size(), &buffer_info[0]);
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600900}
901
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600902inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
903 VkDescriptorType type, const std::vector<VkBufferView> &buffer_views) {
904 return write_descriptor_set(set, binding, array_element, type, buffer_views.size(), &buffer_views[0]);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600905}
906
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600907inline VkCopyDescriptorSet Device::copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding,
908 uint32_t src_array_element, const DescriptorSet &dst_set,
909 uint32_t dst_binding, uint32_t dst_array_element, uint32_t count) {
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800910 VkCopyDescriptorSet copy = {};
911 copy.sType = VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET;
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800912 copy.srcSet = src_set.handle();
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800913 copy.srcBinding = src_binding;
914 copy.srcArrayElement = src_array_element;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800915 copy.dstSet = dst_set.handle();
916 copy.dstBinding = dst_binding;
917 copy.dstArrayElement = dst_array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800918 copy.descriptorCount = count;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600919
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800920 return copy;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600921}
922
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600923inline VkCommandBufferAllocateInfo CommandBuffer::create_info(VkCommandPool const &pool) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800924 VkCommandBufferAllocateInfo info = {};
Chia-I Wu00ce5402015-11-10 16:21:09 +0800925 info.sType = VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800926 info.commandPool = pool;
Jon Ashburnf19916e2016-01-11 13:12:43 -0700927 info.commandBufferCount = 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600928 return info;
929}
930
Petr Kraus13c98a62017-12-09 00:22:39 +0100931} // namespace vk_testing
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600932
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700933#endif // VKTESTBINDING_H