blob: f50e66092b013068ed5415ef3846a00ce1f6611e [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
Chia-I Wub0ed7d42015-07-03 10:13:26 +080025#include <assert.h>
Mark Lobodzinski722841d2016-09-07 16:34:56 -060026#include <vector>
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060027
David Pinedo9316d3b2015-11-06 12:54:48 -070028#include "vulkan/vulkan.h"
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060029
30namespace vk_testing {
31
Mark Lobodzinski722841d2016-09-07 16:34:56 -060032typedef void (*ErrorCallback)(const char *expr, const char *file, unsigned int line, const char *function);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060033void set_error_callback(ErrorCallback callback);
34
Chia-I Wu999f0482015-07-03 10:32:05 +080035class PhysicalDevice;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060036class Device;
37class Queue;
Chia-I Wuf8f074f2015-07-03 10:58:57 +080038class DeviceMemory;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060039class Fence;
40class Semaphore;
41class Event;
42class QueryPool;
43class Buffer;
44class BufferView;
45class Image;
46class ImageView;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060047class DepthStencilView;
48class Shader;
49class Pipeline;
50class PipelineDelta;
51class Sampler;
52class DescriptorSetLayout;
Mark Lobodzinski0fadf5f2015-04-17 14:11:39 -050053class PipelineLayout;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060054class DescriptorSetPool;
55class DescriptorSet;
Chia-I Wu3432a0c2015-10-27 18:04:07 +080056class CommandBuffer;
57class CommandPool;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060058
Courtney Goeltzenleuchter110fdf92015-06-29 15:39:26 -060059std::vector<VkLayerProperties> GetGlobalLayers();
60std::vector<VkExtensionProperties> GetGlobalExtensions();
61std::vector<VkExtensionProperties> GetGlobalExtensions(const char *pLayerName);
62
Chia-I Wub0ed7d42015-07-03 10:13:26 +080063namespace internal {
64
Mark Lobodzinski64318ba2017-01-26 13:34:13 -070065template <typename T>
66class Handle {
67 public:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080068 const T &handle() const { return handle_; }
Petr Krausb3d2c822017-12-01 23:09:19 +010069 bool initialized() const { return (handle_ != T{}); }
Chia-I Wub0ed7d42015-07-03 10:13:26 +080070
Mark Lobodzinski64318ba2017-01-26 13:34:13 -070071 protected:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080072 typedef T handle_type;
73
Petr Krausb3d2c822017-12-01 23:09:19 +010074 explicit Handle() : handle_{} {}
Chia-I Wub0ed7d42015-07-03 10:13:26 +080075 explicit Handle(T handle) : handle_(handle) {}
76
Petr Krausb3d2c822017-12-01 23:09:19 +010077 // handles are non-copyable
78 Handle(const Handle &) = delete;
79 Handle &operator=(const Handle &) = delete;
80
81 // handles can be moved out
82 Handle(Handle &&src) noexcept : handle_{src.handle_} { src.handle_ = {}; }
83 Handle &operator=(Handle &&src) noexcept {
84 handle_ = src.handle_;
85 src.handle_ = {};
86 return *this;
87 }
88
Karl Schultz6addd812016-02-02 17:17:23 -070089 void init(T handle) {
Chia-I Wub0ed7d42015-07-03 10:13:26 +080090 assert(!initialized());
91 handle_ = handle;
92 }
93
Mark Lobodzinski64318ba2017-01-26 13:34:13 -070094 private:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080095 T handle_;
96};
97
Mark Lobodzinski64318ba2017-01-26 13:34:13 -070098template <typename T>
99class NonDispHandle : public Handle<T> {
100 protected:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800101 explicit NonDispHandle() : Handle<T>(), dev_handle_(VK_NULL_HANDLE) {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600102 explicit NonDispHandle(VkDevice dev, T handle) : Handle<T>(handle), dev_handle_(dev) {}
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800103
Petr Krausb3d2c822017-12-01 23:09:19 +0100104 NonDispHandle(NonDispHandle &&src) = default;
105 NonDispHandle &operator=(NonDispHandle &&src) = default;
106
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800107 const VkDevice &device() const { return dev_handle_; }
108
Karl Schultz6addd812016-02-02 17:17:23 -0700109 void init(VkDevice dev, T handle) {
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800110 assert(!Handle<T>::initialized() && dev_handle_ == VK_NULL_HANDLE);
111 Handle<T>::init(handle);
112 dev_handle_ = dev;
113 }
114
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700115 private:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800116 VkDevice dev_handle_;
117};
118
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700119} // namespace internal
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800120
Chia-I Wu999f0482015-07-03 10:32:05 +0800121class PhysicalDevice : public internal::Handle<VkPhysicalDevice> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700122 public:
Karl Schultz6addd812016-02-02 17:17:23 -0700123 explicit PhysicalDevice(VkPhysicalDevice phy) : Handle(phy) {
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600124 memory_properties_ = memory_properties();
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600125 device_properties_ = properties();
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600126 }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600127
Tony Barbourd1c35722015-04-16 15:59:00 -0600128 VkPhysicalDeviceProperties properties() const;
Tony Barbourd1c35722015-04-16 15:59:00 -0600129 VkPhysicalDeviceMemoryProperties memory_properties() const;
Cody Northropd0802882015-08-03 17:04:53 -0600130 std::vector<VkQueueFamilyProperties> queue_properties() const;
Chris Forbesf9cfe182016-04-04 17:22:42 +1200131 VkPhysicalDeviceFeatures features() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600132
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600133 bool set_memory_type(const uint32_t type_bits, VkMemoryAllocateInfo *info, const VkMemoryPropertyFlags properties,
Karl Schultz6addd812016-02-02 17:17:23 -0700134 const VkMemoryPropertyFlags forbid = 0) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600135
Courtney Goeltzenleuchter35985f62015-09-14 17:22:16 -0600136 // vkEnumerateDeviceExtensionProperties()
Courtney Goeltzenleuchterf579fa62015-06-10 17:39:03 -0600137 std::vector<VkExtensionProperties> extensions() const;
Karl Schultz6addd812016-02-02 17:17:23 -0700138 std::vector<VkExtensionProperties> extensions(const char *pLayerName) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600139
140 // vkEnumerateLayers()
Courtney Goeltzenleuchtercd69eee2015-07-06 09:10:47 -0600141 std::vector<VkLayerProperties> layers() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600142
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700143 private:
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600144 void add_extension_dependencies(uint32_t dependency_count, VkExtensionProperties *depencency_props,
145 std::vector<VkExtensionProperties> &ext_list);
Chia-I Wu999f0482015-07-03 10:32:05 +0800146
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600147 VkPhysicalDeviceMemoryProperties memory_properties_;
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600148
149 VkPhysicalDeviceProperties device_properties_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600150};
151
John Zulauf01da3ee2017-10-18 18:13:37 -0600152class QueueCreateInfoArray {
153 private:
154 std::vector<VkDeviceQueueCreateInfo> queue_info_;
155 std::vector<std::vector<float>> queue_priorities_;
156
157 public:
158 QueueCreateInfoArray(const std::vector<VkQueueFamilyProperties> &queue_props);
159 size_t size() const { return queue_info_.size(); }
160 const VkDeviceQueueCreateInfo *data() const { return queue_info_.data(); }
161};
162
Chia-I Wuf368b602015-07-03 10:41:20 +0800163class Device : public internal::Handle<VkDevice> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700164 public:
Chia-I Wu999f0482015-07-03 10:32:05 +0800165 explicit Device(VkPhysicalDevice phy) : phy_(phy) {}
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600166 ~Device();
167
168 // vkCreateDevice()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600169 void init(const VkDeviceCreateInfo &info);
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600170 void init(std::vector<const char *> &extensions,
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700171 VkPhysicalDeviceFeatures *features = nullptr); // all queues, all extensions, etc
Karl Schultz6addd812016-02-02 17:17:23 -0700172 void init() {
Karl Schultz6addd812016-02-02 17:17:23 -0700173 std::vector<const char *> extensions;
Tony Barbour4c70d102016-08-08 16:06:56 -0600174 init(extensions);
Karl Schultz6addd812016-02-02 17:17:23 -0700175 };
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600176
Chia-I Wu999f0482015-07-03 10:32:05 +0800177 const PhysicalDevice &phy() const { return phy_; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600178
Petr Krausb9659a02017-12-11 01:17:46 +0100179 std::vector<const char *> GetEnabledExtensions() { return enabled_extensions_; }
180 bool IsEnbledExtension(const char *extension);
181
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600182 // vkGetDeviceProcAddr()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600183 PFN_vkVoidFunction get_proc(const char *name) const { return vkGetDeviceProcAddr(handle(), name); }
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600184
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600185 // vkGetDeviceQueue()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600186 const std::vector<Queue *> &graphics_queues() const { return queues_[GRAPHICS]; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600187 const std::vector<Queue *> &compute_queues() { return queues_[COMPUTE]; }
188 const std::vector<Queue *> &dma_queues() { return queues_[DMA]; }
Mike Schuchardt06304c22017-03-01 17:09:09 -0700189 uint32_t queue_family_without_capabilities( VkQueueFlags capabilities );
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600190 uint32_t graphics_queue_node_index_;
191
192 struct Format {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600193 VkFormat format;
194 VkImageTiling tiling;
195 VkFlags features;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600196 };
197 // vkGetFormatInfo()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600198 VkFormatProperties format_properties(VkFormat format);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600199 const std::vector<Format> &formats() const { return formats_; }
200
201 // vkDeviceWaitIdle()
202 void wait();
203
204 // vkWaitForFences()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600205 VkResult wait(const std::vector<const Fence *> &fences, bool wait_all, uint64_t timeout);
206 VkResult wait(const Fence &fence) { return wait(std::vector<const Fence *>(1, &fence), true, (uint64_t)-1); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600207
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800208 // vkUpdateDescriptorSets()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600209 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes, const std::vector<VkCopyDescriptorSet> &copies);
210 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes) {
211 return update_descriptor_sets(writes, std::vector<VkCopyDescriptorSet>());
Karl Schultz6addd812016-02-02 17:17:23 -0700212 }
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800213
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600214 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
215 VkDescriptorType type, uint32_t count,
216 const VkDescriptorImageInfo *image_info);
217 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
218 VkDescriptorType type, uint32_t count,
219 const VkDescriptorBufferInfo *buffer_info);
220 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
221 VkDescriptorType type, uint32_t count, const VkBufferView *buffer_views);
222 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
223 VkDescriptorType type, const std::vector<VkDescriptorImageInfo> &image_info);
224 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
225 VkDescriptorType type, const std::vector<VkDescriptorBufferInfo> &buffer_info);
226 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
227 VkDescriptorType type, const std::vector<VkBufferView> &buffer_views);
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800228
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600229 static VkCopyDescriptorSet copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding, uint32_t src_array_element,
230 const DescriptorSet &dst_set, uint32_t dst_binding, uint32_t dst_array_element,
231 uint32_t count);
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800232
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700233 private:
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600234 enum QueueIndex {
235 GRAPHICS,
236 COMPUTE,
237 DMA,
238 QUEUE_COUNT,
239 };
240
241 void init_queues();
242 void init_formats();
243
Chia-I Wu999f0482015-07-03 10:32:05 +0800244 PhysicalDevice phy_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600245
Petr Krausb9659a02017-12-11 01:17:46 +0100246 std::vector<const char *> enabled_extensions_;
247
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600248 std::vector<Queue *> queues_[QUEUE_COUNT];
249 std::vector<Format> formats_;
250};
251
Chia-I Wudf12ffd2015-07-03 10:53:18 +0800252class Queue : public internal::Handle<VkQueue> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700253 public:
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600254 explicit Queue(VkQueue queue, int index) : Handle(queue) { family_index_ = index; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600255
256 // vkQueueSubmit()
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800257 void submit(const std::vector<const CommandBuffer *> &cmds, Fence &fence);
258 void submit(const CommandBuffer &cmd, Fence &fence);
259 void submit(const CommandBuffer &cmd);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600260
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600261 // vkQueueWaitIdle()
262 void wait();
263
Karl Schultz6addd812016-02-02 17:17:23 -0700264 int get_family_index() { return family_index_; }
Tony Barbourfb21ea32015-07-23 10:35:30 -0600265
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700266 private:
Tony Barbourfb21ea32015-07-23 10:35:30 -0600267 int family_index_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600268};
269
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800270class DeviceMemory : public internal::NonDispHandle<VkDeviceMemory> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700271 public:
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800272 ~DeviceMemory();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600273
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800274 // vkAllocateMemory()
275 void init(const Device &dev, const VkMemoryAllocateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600276
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600277 // vkMapMemory()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600278 const void *map(VkFlags flags) const;
Karl Schultz6addd812016-02-02 17:17:23 -0700279 void *map(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600280 const void *map() const { return map(0); }
Karl Schultz6addd812016-02-02 17:17:23 -0700281 void *map() { return map(0); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600282
283 // vkUnmapMemory()
284 void unmap() const;
285
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600286 static VkMemoryAllocateInfo alloc_info(VkDeviceSize size, uint32_t memory_type_index);
Mike Schuchardt8cacbb02017-10-26 14:06:38 -0600287 static VkMemoryAllocateInfo get_resource_alloc_info(const vk_testing::Device &dev, const VkMemoryRequirements &reqs,
288 VkMemoryPropertyFlags mem_props);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600289};
290
Chia-I Wud9e8e822015-07-03 11:45:55 +0800291class Fence : public internal::NonDispHandle<VkFence> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700292 public:
Chia-I Wud9e8e822015-07-03 11:45:55 +0800293 ~Fence();
294
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600295 // vkCreateFence()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600296 void init(const Device &dev, const VkFenceCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600297
298 // vkGetFenceStatus()
Chia-I Wud9e8e822015-07-03 11:45:55 +0800299 VkResult status() const { return vkGetFenceStatus(device(), handle()); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600300
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600301 static VkFenceCreateInfo create_info(VkFenceCreateFlags flags);
302 static VkFenceCreateInfo create_info();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600303};
304
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800305class Semaphore : public internal::NonDispHandle<VkSemaphore> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700306 public:
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800307 ~Semaphore();
308
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600309 // vkCreateSemaphore()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600310 void init(const Device &dev, const VkSemaphoreCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600311
Tony Barbouraf892a12015-06-26 12:56:09 -0600312 static VkSemaphoreCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600313};
314
Chia-I Wuc5c97992015-07-03 11:49:42 +0800315class Event : public internal::NonDispHandle<VkEvent> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700316 public:
Chia-I Wuc5c97992015-07-03 11:49:42 +0800317 ~Event();
318
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600319 // vkCreateEvent()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600320 void init(const Device &dev, const VkEventCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600321
322 // vkGetEventStatus()
323 // vkSetEvent()
324 // vkResetEvent()
Chia-I Wuc5c97992015-07-03 11:49:42 +0800325 VkResult status() const { return vkGetEventStatus(device(), handle()); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600326 void set();
327 void reset();
328
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600329 static VkEventCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600330};
331
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800332class QueryPool : public internal::NonDispHandle<VkQueryPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700333 public:
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800334 ~QueryPool();
335
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600336 // vkCreateQueryPool()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600337 void init(const Device &dev, const VkQueryPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600338
339 // vkGetQueryPoolResults()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600340 VkResult results(uint32_t first, uint32_t count, size_t size, void *data, size_t stride);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600341
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600342 static VkQueryPoolCreateInfo create_info(VkQueryType type, uint32_t slot_count);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600343};
344
Chia-I Wu681d7a02015-07-03 13:44:34 +0800345class Buffer : public internal::NonDispHandle<VkBuffer> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700346 public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800347 explicit Buffer() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600348 explicit Buffer(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info); }
Tony Barbourd1c35722015-04-16 15:59:00 -0600349 explicit Buffer(const Device &dev, VkDeviceSize size) { init(dev, size); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600350
Chia-I Wu681d7a02015-07-03 13:44:34 +0800351 ~Buffer();
352
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600353 // vkCreateBuffer()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600354 void init(const Device &dev, const VkBufferCreateInfo &info, VkMemoryPropertyFlags mem_props);
355 void init(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info, 0); }
356 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 +0800357 void init(const Device &dev, VkDeviceSize size) { init(dev, size, 0); }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600358 void init_as_src(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) {
Karl Schultz6addd812016-02-02 17:17:23 -0700359 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_SRC_BIT), reqs);
360 }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600361 void init_as_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) {
Karl Schultz6addd812016-02-02 17:17:23 -0700362 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_DST_BIT), reqs);
363 }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600364 void init_as_src_and_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) {
365 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 -0700366 }
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600367 void init_no_mem(const Device &dev, const VkBufferCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600368
Chia-I Wu681d7a02015-07-03 13:44:34 +0800369 // get the internal memory
370 const DeviceMemory &memory() const { return internal_mem_; }
Karl Schultz6addd812016-02-02 17:17:23 -0700371 DeviceMemory &memory() { return internal_mem_; }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800372
373 // vkGetObjectMemoryRequirements()
374 VkMemoryRequirements memory_requirements() const;
375
376 // vkBindObjectMemory()
377 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Mark Lobodzinski942b1722015-05-11 17:21:15 -0500378
Tony Barbourd1c35722015-04-16 15:59:00 -0600379 static VkBufferCreateInfo create_info(VkDeviceSize size, VkFlags usage);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600380
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600381 VkBufferMemoryBarrier buffer_memory_barrier(VkFlags output_mask, VkFlags input_mask, VkDeviceSize offset,
Karl Schultz6addd812016-02-02 17:17:23 -0700382 VkDeviceSize size) const {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600383 VkBufferMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600384 barrier.sType = VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800385 barrier.buffer = handle();
Chia-I Wua4594202015-10-27 19:54:37 +0800386 barrier.srcAccessMask = output_mask;
387 barrier.dstAccessMask = input_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600388 barrier.offset = offset;
389 barrier.size = size;
390 return barrier;
391 }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800392
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700393 private:
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600394 VkBufferCreateInfo create_info_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800395
396 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600397};
398
Chia-I Wu3158bf32015-07-03 11:49:42 +0800399class BufferView : public internal::NonDispHandle<VkBufferView> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700400 public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800401 ~BufferView();
402
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600403 // vkCreateBufferView()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600404 void init(const Device &dev, const VkBufferViewCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600405};
406
Chia-I Wu681d7a02015-07-03 13:44:34 +0800407class Image : public internal::NonDispHandle<VkImage> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700408 public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800409 explicit Image() : NonDispHandle(), format_features_(0) {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600410 explicit Image(const Device &dev, const VkImageCreateInfo &info) : format_features_(0) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600411
Chia-I Wu681d7a02015-07-03 13:44:34 +0800412 ~Image();
413
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600414 // vkCreateImage()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600415 void init(const Device &dev, const VkImageCreateInfo &info, VkMemoryPropertyFlags mem_props);
416 void init(const Device &dev, const VkImageCreateInfo &info) { init(dev, info, 0); }
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600417 void init_no_mem(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600418
Chia-I Wu681d7a02015-07-03 13:44:34 +0800419 // get the internal memory
420 const DeviceMemory &memory() const { return internal_mem_; }
Karl Schultz6addd812016-02-02 17:17:23 -0700421 DeviceMemory &memory() { return internal_mem_; }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800422
423 // vkGetObjectMemoryRequirements()
424 VkMemoryRequirements memory_requirements() const;
425
426 // vkBindObjectMemory()
427 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600428
Tony Barbour59a47322015-06-24 16:06:58 -0600429 // vkGetImageSubresourceLayout()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600430 VkSubresourceLayout subresource_layout(const VkImageSubresource &subres) const;
431 VkSubresourceLayout subresource_layout(const VkImageSubresourceLayers &subres) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600432
433 bool transparent() const;
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600434 bool copyable() const { return (format_features_ & VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600435
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600436 VkImageSubresourceRange subresource_range(VkImageAspectFlagBits aspect) const {
Karl Schultz6addd812016-02-02 17:17:23 -0700437 return subresource_range(create_info_, aspect);
438 }
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600439 VkExtent3D extent() const { return create_info_.extent; }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600440 VkExtent3D extent(uint32_t mip_level) const { return extent(create_info_.extent, mip_level); }
Karl Schultz6addd812016-02-02 17:17:23 -0700441 VkFormat format() const { return create_info_.format; }
Mike Weiblene6e01172017-03-07 22:18:40 -0700442 VkImageUsageFlags usage() const { return create_info_.usage; }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600443 VkImageMemoryBarrier image_memory_barrier(VkFlags output_mask, VkFlags input_mask, VkImageLayout old_layout,
444 VkImageLayout new_layout, const VkImageSubresourceRange &range) const {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600445 VkImageMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600446 barrier.sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER;
Chia-I Wua4594202015-10-27 19:54:37 +0800447 barrier.srcAccessMask = output_mask;
448 barrier.dstAccessMask = input_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600449 barrier.oldLayout = old_layout;
450 barrier.newLayout = new_layout;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800451 barrier.image = handle();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600452 barrier.subresourceRange = range;
453 return barrier;
454 }
455
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600456 static VkImageCreateInfo create_info();
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600457 static VkImageSubresource subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer);
458 static VkImageSubresource subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer);
459 static VkImageSubresourceLayers subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer,
Karl Schultz6addd812016-02-02 17:17:23 -0700460 uint32_t array_size);
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600461 static VkImageSubresourceLayers subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer,
462 uint32_t array_size);
463 static VkImageSubresourceRange subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level, uint32_t mip_levels,
464 uint32_t base_array_layer, uint32_t num_layers);
465 static VkImageSubresourceRange subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask);
466 static VkImageSubresourceRange subresource_range(const VkImageSubresource &subres);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600467
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600468 static VkExtent2D extent(int32_t width, int32_t height);
469 static VkExtent2D extent(const VkExtent2D &extent, uint32_t mip_level);
470 static VkExtent2D extent(const VkExtent3D &extent);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600471
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600472 static VkExtent3D extent(int32_t width, int32_t height, int32_t depth);
473 static VkExtent3D extent(const VkExtent3D &extent, uint32_t mip_level);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600474
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700475 private:
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600476 void init_info(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600477
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600478 VkImageCreateInfo create_info_;
479 VkFlags format_features_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800480
481 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600482};
483
Chia-I Wu3158bf32015-07-03 11:49:42 +0800484class ImageView : public internal::NonDispHandle<VkImageView> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700485 public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800486 ~ImageView();
487
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600488 // vkCreateImageView()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600489 void init(const Device &dev, const VkImageViewCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600490};
491
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800492class ShaderModule : public internal::NonDispHandle<VkShaderModule> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700493 public:
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800494 ~ShaderModule();
495
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600496 // vkCreateShaderModule()
497 void init(const Device &dev, const VkShaderModuleCreateInfo &info);
498 VkResult init_try(const Device &dev, const VkShaderModuleCreateInfo &info);
499
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600500 static VkShaderModuleCreateInfo create_info(size_t code_size, const uint32_t *code, VkFlags flags);
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600501};
502
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800503class Pipeline : public internal::NonDispHandle<VkPipeline> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700504 public:
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800505 ~Pipeline();
506
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600507 // vkCreateGraphicsPipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600508 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600509 // vkCreateGraphicsPipelineDerivative()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600510 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info, const VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600511 // vkCreateComputePipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600512 void init(const Device &dev, const VkComputePipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600513 // vkLoadPipeline()
Karl Schultz6addd812016-02-02 17:17:23 -0700514 void init(const Device &dev, size_t size, const void *data);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600515 // vkLoadPipelineDerivative()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600516 void init(const Device &dev, size_t size, const void *data, VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600517
Chris Forbes95292b12015-05-25 11:13:26 +1200518 // vkCreateGraphicsPipeline with error return
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600519 VkResult init_try(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Chris Forbes95292b12015-05-25 11:13:26 +1200520
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600521 // vkStorePipeline()
522 size_t store(size_t size, void *data);
523};
524
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800525class PipelineLayout : public internal::NonDispHandle<VkPipelineLayout> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700526 public:
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800527 ~PipelineLayout();
528
529 // vCreatePipelineLayout()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600530 void init(const Device &dev, VkPipelineLayoutCreateInfo &info, const std::vector<const DescriptorSetLayout *> &layouts);
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800531};
532
Chia-I Wu8c721c62015-07-03 11:49:42 +0800533class Sampler : public internal::NonDispHandle<VkSampler> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700534 public:
Chia-I Wu8c721c62015-07-03 11:49:42 +0800535 ~Sampler();
536
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600537 // vkCreateSampler()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600538 void init(const Device &dev, const VkSamplerCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600539};
540
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600541class DescriptorSetLayout : public internal::NonDispHandle<VkDescriptorSetLayout> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700542 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800543 ~DescriptorSetLayout();
544
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600545 // vkCreateDescriptorSetLayout()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600546 void init(const Device &dev, const VkDescriptorSetLayoutCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600547};
548
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800549class DescriptorPool : public internal::NonDispHandle<VkDescriptorPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700550 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800551 ~DescriptorPool();
552
Karl Schultz6addd812016-02-02 17:17:23 -0700553 // Descriptor sets allocated from this pool will need access to the original
554 // object
Cody Northropcdc72a42015-10-08 11:39:25 -0600555 VkDescriptorPool GetObj() { return pool_; }
556
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600557 // vkCreateDescriptorPool()
Courtney Goeltzenleuchterfe908d32015-09-16 16:12:45 -0600558 void init(const Device &dev, const VkDescriptorPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600559
560 // vkResetDescriptorPool()
561 void reset();
562
Cody Northropcdc72a42015-10-08 11:39:25 -0600563 // vkFreeDescriptorSet()
564 void setDynamicUsage(bool isDynamic) { dynamic_usage_ = isDynamic; }
565 bool getDynamicUsage() { return dynamic_usage_; }
566
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800567 // vkAllocateDescriptorSets()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600568 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const std::vector<const DescriptorSetLayout *> &layouts);
569 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const DescriptorSetLayout &layout, uint32_t count);
570 DescriptorSet *alloc_sets(const Device &dev, const DescriptorSetLayout &layout);
Cody Northropcdc72a42015-10-08 11:39:25 -0600571
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700572 private:
Cody Northropcdc72a42015-10-08 11:39:25 -0600573 VkDescriptorPool pool_;
574
575 // Track whether this pool's usage is VK_DESCRIPTOR_POOL_USAGE_DYNAMIC
576 bool dynamic_usage_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600577};
578
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800579class DescriptorSet : public internal::NonDispHandle<VkDescriptorSet> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700580 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800581 ~DescriptorSet();
582
583 explicit DescriptorSet() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600584 explicit DescriptorSet(const Device &dev, DescriptorPool *pool, VkDescriptorSet set) : NonDispHandle(dev.handle(), set) {
Karl Schultz6addd812016-02-02 17:17:23 -0700585 containing_pool_ = pool;
586 }
Tony Barbour67e99152015-07-10 14:10:27 -0600587
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700588 private:
Karl Schultz6addd812016-02-02 17:17:23 -0700589 DescriptorPool *containing_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600590};
591
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800592class CommandPool : public internal::NonDispHandle<VkCommandPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700593 public:
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800594 ~CommandPool();
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600595
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800596 explicit CommandPool() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600597 explicit CommandPool(const Device &dev, const VkCommandPoolCreateInfo &info) { init(dev, info); }
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600598
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800599 void init(const Device &dev, const VkCommandPoolCreateInfo &info);
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600600
Mike Schuchardt06304c22017-03-01 17:09:09 -0700601 static VkCommandPoolCreateInfo create_info(uint32_t queue_family_index, VkCommandPoolCreateFlags flags);
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600602};
603
Mike Schuchardt06304c22017-03-01 17:09:09 -0700604inline VkCommandPoolCreateInfo CommandPool::create_info(uint32_t queue_family_index, VkCommandPoolCreateFlags flags) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800605 VkCommandPoolCreateInfo info = {};
606 info.sType = VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600607 info.queueFamilyIndex = queue_family_index;
Mike Schuchardt06304c22017-03-01 17:09:09 -0700608 info.flags = flags;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600609 return info;
610}
611
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800612class CommandBuffer : public internal::Handle<VkCommandBuffer> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700613 public:
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800614 ~CommandBuffer();
Chia-I Wube2b9172015-07-03 11:49:42 +0800615
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800616 explicit CommandBuffer() : Handle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600617 explicit CommandBuffer(const Device &dev, const VkCommandBufferAllocateInfo &info) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600618
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800619 // vkAllocateCommandBuffers()
620 void init(const Device &dev, const VkCommandBufferAllocateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600621
622 // vkBeginCommandBuffer()
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800623 void begin(const VkCommandBufferBeginInfo *info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600624 void begin();
625
626 // vkEndCommandBuffer()
627 // vkResetCommandBuffer()
628 void end();
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800629 void reset(VkCommandBufferResetFlags flags);
630 void reset() { reset(VK_COMMAND_BUFFER_RESET_RELEASE_RESOURCES_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600631
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800632 static VkCommandBufferAllocateInfo create_info(VkCommandPool const &pool);
Chia-I Wube2b9172015-07-03 11:49:42 +0800633
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700634 private:
Chia-I Wube2b9172015-07-03 11:49:42 +0800635 VkDevice dev_handle_;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800636 VkCommandPool cmd_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600637};
638
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600639inline VkMemoryAllocateInfo DeviceMemory::alloc_info(VkDeviceSize size, uint32_t memory_type_index) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800640 VkMemoryAllocateInfo info = {};
Chia-I Wu00ce5402015-11-10 16:21:09 +0800641 info.sType = VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO;
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800642 info.allocationSize = size;
643 info.memoryTypeIndex = memory_type_index;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600644 return info;
645}
646
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600647inline VkBufferCreateInfo Buffer::create_info(VkDeviceSize size, VkFlags usage) {
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600648 VkBufferCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600649 info.sType = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO;
650 info.size = size;
651 info.usage = usage;
652 return info;
653}
654
Karl Schultz6addd812016-02-02 17:17:23 -0700655inline VkFenceCreateInfo Fence::create_info(VkFenceCreateFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600656 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600657 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
658 info.flags = flags;
659 return info;
660}
661
Karl Schultz6addd812016-02-02 17:17:23 -0700662inline VkFenceCreateInfo Fence::create_info() {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600663 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600664 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
665 return info;
666}
667
Karl Schultz6addd812016-02-02 17:17:23 -0700668inline VkSemaphoreCreateInfo Semaphore::create_info(VkFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600669 VkSemaphoreCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600670 info.sType = VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600671 info.flags = flags;
672 return info;
673}
674
Karl Schultz6addd812016-02-02 17:17:23 -0700675inline VkEventCreateInfo Event::create_info(VkFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600676 VkEventCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600677 info.sType = VK_STRUCTURE_TYPE_EVENT_CREATE_INFO;
678 info.flags = flags;
679 return info;
680}
681
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600682inline VkQueryPoolCreateInfo QueryPool::create_info(VkQueryType type, uint32_t slot_count) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600683 VkQueryPoolCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600684 info.sType = VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO;
685 info.queryType = type;
Jon Ashburnf19916e2016-01-11 13:12:43 -0700686 info.queryCount = slot_count;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600687 return info;
688}
689
Karl Schultz6addd812016-02-02 17:17:23 -0700690inline VkImageCreateInfo Image::create_info() {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600691 VkImageCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600692 info.sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO;
693 info.extent.width = 1;
694 info.extent.height = 1;
695 info.extent.depth = 1;
696 info.mipLevels = 1;
Courtney Goeltzenleuchter5d2aed42015-10-21 17:57:31 -0600697 info.arrayLayers = 1;
Chia-I Wu5c17c962015-10-31 00:31:16 +0800698 info.samples = VK_SAMPLE_COUNT_1_BIT;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600699 return info;
700}
701
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600702inline VkImageSubresource Image::subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600703 VkImageSubresource subres = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600704 if (aspect == 0) {
705 assert(!"Invalid VkImageAspectFlags");
706 }
Chia-I Wu52b07e72015-10-27 19:55:05 +0800707 subres.aspectMask = aspect;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600708 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600709 subres.arrayLayer = array_layer;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600710 return subres;
711}
712
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600713inline VkImageSubresource Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer) {
714 return subresource(range.aspectMask, range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600715}
716
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600717inline VkImageSubresourceLayers Image::subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer,
Karl Schultz6addd812016-02-02 17:17:23 -0700718 uint32_t array_size) {
Chia-I Wu1b99bb22015-10-27 19:25:11 +0800719 VkImageSubresourceLayers subres = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600720 switch (aspect) {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700721 case VK_IMAGE_ASPECT_COLOR_BIT:
722 case VK_IMAGE_ASPECT_DEPTH_BIT:
723 case VK_IMAGE_ASPECT_STENCIL_BIT:
724 case VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT:
725 /* valid */
726 break;
727 default:
728 assert(!"Invalid VkImageAspectFlags");
Karl Schultz0ab73f82016-03-29 12:41:24 -0600729 }
Chia-I Wuab83a0e2015-10-27 19:00:15 +0800730 subres.aspectMask = aspect;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600731 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter8367ce02015-10-16 09:46:00 -0600732 subres.baseArrayLayer = array_layer;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800733 subres.layerCount = array_size;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600734 return subres;
735}
736
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600737inline VkImageSubresourceLayers Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer,
738 uint32_t array_size) {
739 return subresource(range.aspectMask, range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer, array_size);
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600740}
741
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600742inline VkImageSubresourceRange Image::subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level,
743 uint32_t mip_levels, uint32_t base_array_layer, uint32_t num_layers) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600744 VkImageSubresourceRange range = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600745 if (aspect_mask == 0) {
746 assert(!"Invalid VkImageAspectFlags");
747 }
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600748 range.aspectMask = aspect_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600749 range.baseMipLevel = base_mip_level;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800750 range.levelCount = mip_levels;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600751 range.baseArrayLayer = base_array_layer;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800752 range.layerCount = num_layers;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600753 return range;
754}
755
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600756inline VkImageSubresourceRange Image::subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask) {
757 return subresource_range(aspect_mask, 0, info.mipLevels, 0, info.arrayLayers);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600758}
759
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600760inline VkImageSubresourceRange Image::subresource_range(const VkImageSubresource &subres) {
761 return subresource_range(subres.aspectMask, subres.mipLevel, 1, subres.arrayLayer, 1);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600762}
763
Karl Schultz6addd812016-02-02 17:17:23 -0700764inline VkExtent2D Image::extent(int32_t width, int32_t height) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600765 VkExtent2D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600766 extent.width = width;
767 extent.height = height;
768 return extent;
769}
770
Karl Schultz6addd812016-02-02 17:17:23 -0700771inline VkExtent2D Image::extent(const VkExtent2D &extent, uint32_t mip_level) {
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600772 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
773 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600774 return Image::extent(width, height);
775}
776
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600777inline VkExtent2D Image::extent(const VkExtent3D &extent) { return Image::extent(extent.width, extent.height); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600778
Karl Schultz6addd812016-02-02 17:17:23 -0700779inline VkExtent3D Image::extent(int32_t width, int32_t height, int32_t depth) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600780 VkExtent3D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600781 extent.width = width;
782 extent.height = height;
783 extent.depth = depth;
784 return extent;
785}
786
Karl Schultz6addd812016-02-02 17:17:23 -0700787inline VkExtent3D Image::extent(const VkExtent3D &extent, uint32_t mip_level) {
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600788 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
789 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
790 const int32_t depth = (extent.depth >> mip_level) ? extent.depth >> mip_level : 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600791 return Image::extent(width, height, depth);
792}
793
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600794inline VkShaderModuleCreateInfo ShaderModule::create_info(size_t code_size, const uint32_t *code, VkFlags flags) {
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600795 VkShaderModuleCreateInfo info = {};
796 info.sType = VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO;
797 info.codeSize = code_size;
798 info.pCode = code;
799 info.flags = flags;
800 return info;
801}
802
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600803inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
804 VkDescriptorType type, uint32_t count,
805 const VkDescriptorImageInfo *image_info) {
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800806 VkWriteDescriptorSet write = {};
807 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800808 write.dstSet = set.handle();
809 write.dstBinding = binding;
810 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800811 write.descriptorCount = count;
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800812 write.descriptorType = type;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600813 write.pImageInfo = image_info;
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800814 return write;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600815}
816
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600817inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
818 VkDescriptorType type, uint32_t count,
819 const VkDescriptorBufferInfo *buffer_info) {
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600820 VkWriteDescriptorSet write = {};
821 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800822 write.dstSet = set.handle();
823 write.dstBinding = binding;
824 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800825 write.descriptorCount = count;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600826 write.descriptorType = type;
827 write.pBufferInfo = buffer_info;
828 return write;
829}
830
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600831inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
832 VkDescriptorType type, uint32_t count, const VkBufferView *buffer_views) {
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600833 VkWriteDescriptorSet write = {};
834 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800835 write.dstSet = set.handle();
836 write.dstBinding = binding;
837 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800838 write.descriptorCount = count;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600839 write.descriptorType = type;
840 write.pTexelBufferView = buffer_views;
841 return write;
842}
843
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600844inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
845 VkDescriptorType type,
846 const std::vector<VkDescriptorImageInfo> &image_info) {
847 return write_descriptor_set(set, binding, array_element, type, image_info.size(), &image_info[0]);
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600848}
849
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600850inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
851 VkDescriptorType type,
852 const std::vector<VkDescriptorBufferInfo> &buffer_info) {
853 return write_descriptor_set(set, binding, array_element, type, buffer_info.size(), &buffer_info[0]);
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600854}
855
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600856inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
857 VkDescriptorType type, const std::vector<VkBufferView> &buffer_views) {
858 return write_descriptor_set(set, binding, array_element, type, buffer_views.size(), &buffer_views[0]);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600859}
860
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600861inline VkCopyDescriptorSet Device::copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding,
862 uint32_t src_array_element, const DescriptorSet &dst_set,
863 uint32_t dst_binding, uint32_t dst_array_element, uint32_t count) {
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800864 VkCopyDescriptorSet copy = {};
865 copy.sType = VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET;
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800866 copy.srcSet = src_set.handle();
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800867 copy.srcBinding = src_binding;
868 copy.srcArrayElement = src_array_element;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800869 copy.dstSet = dst_set.handle();
870 copy.dstBinding = dst_binding;
871 copy.dstArrayElement = dst_array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800872 copy.descriptorCount = count;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600873
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800874 return copy;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600875}
876
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600877inline VkCommandBufferAllocateInfo CommandBuffer::create_info(VkCommandPool const &pool) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800878 VkCommandBufferAllocateInfo info = {};
Chia-I Wu00ce5402015-11-10 16:21:09 +0800879 info.sType = VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800880 info.commandPool = pool;
Jon Ashburnf19916e2016-01-11 13:12:43 -0700881 info.commandBufferCount = 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600882 return info;
883}
884
Petr Kraus13c98a62017-12-09 00:22:39 +0100885} // namespace vk_testing
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600886
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700887#endif // VKTESTBINDING_H