blob: cbd1b895ed0e5a31e8241ec14941a33471f563c5 [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>
John Zulaufcde9d7d2018-01-18 16:53:07 -070020 * Author: John Zulauf <jzulauf@lunarg.com>
Karl Schultz6addd812016-02-02 17:17:23 -070021 */
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060022
23#ifndef VKTESTBINDING_H
24#define VKTESTBINDING_H
25
Petr Kraus858bacd2017-12-01 23:10:08 +010026#include <algorithm>
Chia-I Wub0ed7d42015-07-03 10:13:26 +080027#include <assert.h>
Petr Kraus858bacd2017-12-01 23:10:08 +010028#include <iterator>
Mark Lobodzinski722841d2016-09-07 16:34:56 -060029#include <vector>
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060030
David Pinedo9316d3b2015-11-06 12:54:48 -070031#include "vulkan/vulkan.h"
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060032
33namespace vk_testing {
34
Petr Kraus858bacd2017-12-01 23:10:08 +010035template <class Dst, class Src>
36std::vector<Dst> MakeVkHandles(const std::vector<Src> &v) {
37 std::vector<Dst> handles;
38 handles.reserve(v.size());
39 std::transform(v.begin(), v.end(), std::back_inserter(handles), [](const Src &o) { return o.handle(); });
40 return handles;
41}
42
43template <class Dst, class Src>
44std::vector<Dst> MakeVkHandles(const std::vector<Src *> &v) {
45 std::vector<Dst> handles;
46 handles.reserve(v.size());
47 std::transform(v.begin(), v.end(), std::back_inserter(handles), [](const Src *o) { return o->handle(); });
48 return handles;
49}
50
Mark Lobodzinski722841d2016-09-07 16:34:56 -060051typedef void (*ErrorCallback)(const char *expr, const char *file, unsigned int line, const char *function);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060052void set_error_callback(ErrorCallback callback);
53
Chia-I Wu999f0482015-07-03 10:32:05 +080054class PhysicalDevice;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060055class Device;
56class Queue;
Chia-I Wuf8f074f2015-07-03 10:58:57 +080057class DeviceMemory;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060058class Fence;
59class Semaphore;
60class Event;
61class QueryPool;
62class Buffer;
63class BufferView;
64class Image;
65class ImageView;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060066class DepthStencilView;
67class Shader;
68class Pipeline;
69class PipelineDelta;
70class Sampler;
71class DescriptorSetLayout;
Mark Lobodzinski0fadf5f2015-04-17 14:11:39 -050072class PipelineLayout;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060073class DescriptorSetPool;
74class DescriptorSet;
Chia-I Wu3432a0c2015-10-27 18:04:07 +080075class CommandBuffer;
76class CommandPool;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060077
Courtney Goeltzenleuchter110fdf92015-06-29 15:39:26 -060078std::vector<VkLayerProperties> GetGlobalLayers();
79std::vector<VkExtensionProperties> GetGlobalExtensions();
80std::vector<VkExtensionProperties> GetGlobalExtensions(const char *pLayerName);
81
Chia-I Wub0ed7d42015-07-03 10:13:26 +080082namespace internal {
83
Mark Lobodzinski64318ba2017-01-26 13:34:13 -070084template <typename T>
85class Handle {
86 public:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080087 const T &handle() const { return handle_; }
Petr Krausb3d2c822017-12-01 23:09:19 +010088 bool initialized() const { return (handle_ != T{}); }
Chia-I Wub0ed7d42015-07-03 10:13:26 +080089
Mark Lobodzinski64318ba2017-01-26 13:34:13 -070090 protected:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080091 typedef T handle_type;
92
Petr Krausb3d2c822017-12-01 23:09:19 +010093 explicit Handle() : handle_{} {}
Chia-I Wub0ed7d42015-07-03 10:13:26 +080094 explicit Handle(T handle) : handle_(handle) {}
95
Petr Krausb3d2c822017-12-01 23:09:19 +010096 // handles are non-copyable
97 Handle(const Handle &) = delete;
98 Handle &operator=(const Handle &) = delete;
99
100 // handles can be moved out
Dave Houlton0cf0d132017-12-22 13:55:53 -0700101 Handle(Handle &&src) NOEXCEPT : handle_{src.handle_} { src.handle_ = {}; }
102 Handle &operator=(Handle &&src) NOEXCEPT {
Petr Krausb3d2c822017-12-01 23:09:19 +0100103 handle_ = src.handle_;
104 src.handle_ = {};
105 return *this;
106 }
107
Karl Schultz6addd812016-02-02 17:17:23 -0700108 void init(T handle) {
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800109 assert(!initialized());
110 handle_ = handle;
111 }
112
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700113 private:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800114 T handle_;
115};
116
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700117template <typename T>
118class NonDispHandle : public Handle<T> {
119 protected:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800120 explicit NonDispHandle() : Handle<T>(), dev_handle_(VK_NULL_HANDLE) {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600121 explicit NonDispHandle(VkDevice dev, T handle) : Handle<T>(handle), dev_handle_(dev) {}
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800122
Mike Schuchardt0bc8e7a2018-01-02 14:39:51 -0700123 NonDispHandle(NonDispHandle &&src) : Handle<T>(std::move(src)) {
124 dev_handle_ = src.dev_handle_;
125 src.dev_handle_ = VK_NULL_HANDLE;
126 }
127 NonDispHandle &operator=(NonDispHandle &&src) {
128 Handle<T>::operator=(std::move(src));
129 dev_handle_ = src.dev_handle_;
130 src.dev_handle_ = VK_NULL_HANDLE;
131 return *this;
132 }
Petr Krausb3d2c822017-12-01 23:09:19 +0100133
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800134 const VkDevice &device() const { return dev_handle_; }
135
Karl Schultz6addd812016-02-02 17:17:23 -0700136 void init(VkDevice dev, T handle) {
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800137 assert(!Handle<T>::initialized() && dev_handle_ == VK_NULL_HANDLE);
138 Handle<T>::init(handle);
139 dev_handle_ = dev;
140 }
141
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700142 private:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800143 VkDevice dev_handle_;
144};
145
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700146} // namespace internal
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800147
Chia-I Wu999f0482015-07-03 10:32:05 +0800148class PhysicalDevice : public internal::Handle<VkPhysicalDevice> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700149 public:
Karl Schultz6addd812016-02-02 17:17:23 -0700150 explicit PhysicalDevice(VkPhysicalDevice phy) : Handle(phy) {
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600151 memory_properties_ = memory_properties();
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600152 device_properties_ = properties();
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600153 }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600154
Tony Barbourd1c35722015-04-16 15:59:00 -0600155 VkPhysicalDeviceProperties properties() const;
Tony Barbourd1c35722015-04-16 15:59:00 -0600156 VkPhysicalDeviceMemoryProperties memory_properties() const;
Cody Northropd0802882015-08-03 17:04:53 -0600157 std::vector<VkQueueFamilyProperties> queue_properties() const;
Chris Forbesf9cfe182016-04-04 17:22:42 +1200158 VkPhysicalDeviceFeatures features() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600159
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600160 bool set_memory_type(const uint32_t type_bits, VkMemoryAllocateInfo *info, const VkMemoryPropertyFlags properties,
Karl Schultz6addd812016-02-02 17:17:23 -0700161 const VkMemoryPropertyFlags forbid = 0) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600162
Courtney Goeltzenleuchter35985f62015-09-14 17:22:16 -0600163 // vkEnumerateDeviceExtensionProperties()
Courtney Goeltzenleuchterf579fa62015-06-10 17:39:03 -0600164 std::vector<VkExtensionProperties> extensions() const;
Karl Schultz6addd812016-02-02 17:17:23 -0700165 std::vector<VkExtensionProperties> extensions(const char *pLayerName) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600166
167 // vkEnumerateLayers()
Courtney Goeltzenleuchtercd69eee2015-07-06 09:10:47 -0600168 std::vector<VkLayerProperties> layers() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600169
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700170 private:
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600171 void add_extension_dependencies(uint32_t dependency_count, VkExtensionProperties *depencency_props,
172 std::vector<VkExtensionProperties> &ext_list);
Chia-I Wu999f0482015-07-03 10:32:05 +0800173
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600174 VkPhysicalDeviceMemoryProperties memory_properties_;
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600175
176 VkPhysicalDeviceProperties device_properties_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600177};
178
John Zulauf01da3ee2017-10-18 18:13:37 -0600179class QueueCreateInfoArray {
180 private:
181 std::vector<VkDeviceQueueCreateInfo> queue_info_;
182 std::vector<std::vector<float>> queue_priorities_;
183
184 public:
185 QueueCreateInfoArray(const std::vector<VkQueueFamilyProperties> &queue_props);
186 size_t size() const { return queue_info_.size(); }
187 const VkDeviceQueueCreateInfo *data() const { return queue_info_.data(); }
188};
189
Chia-I Wuf368b602015-07-03 10:41:20 +0800190class Device : public internal::Handle<VkDevice> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700191 public:
Chia-I Wu999f0482015-07-03 10:32:05 +0800192 explicit Device(VkPhysicalDevice phy) : phy_(phy) {}
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600193 ~Device();
194
195 // vkCreateDevice()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600196 void init(const VkDeviceCreateInfo &info);
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600197 void init(std::vector<const char *> &extensions,
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700198 VkPhysicalDeviceFeatures *features = nullptr); // all queues, all extensions, etc
Karl Schultz6addd812016-02-02 17:17:23 -0700199 void init() {
Karl Schultz6addd812016-02-02 17:17:23 -0700200 std::vector<const char *> extensions;
Tony Barbour4c70d102016-08-08 16:06:56 -0600201 init(extensions);
Karl Schultz6addd812016-02-02 17:17:23 -0700202 };
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600203
Chia-I Wu999f0482015-07-03 10:32:05 +0800204 const PhysicalDevice &phy() const { return phy_; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600205
Petr Krausb9659a02017-12-11 01:17:46 +0100206 std::vector<const char *> GetEnabledExtensions() { return enabled_extensions_; }
207 bool IsEnbledExtension(const char *extension);
208
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600209 // vkGetDeviceProcAddr()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600210 PFN_vkVoidFunction get_proc(const char *name) const { return vkGetDeviceProcAddr(handle(), name); }
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600211
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600212 // vkGetDeviceQueue()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600213 const std::vector<Queue *> &graphics_queues() const { return queues_[GRAPHICS]; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600214 const std::vector<Queue *> &compute_queues() { return queues_[COMPUTE]; }
215 const std::vector<Queue *> &dma_queues() { return queues_[DMA]; }
Dave Houlton6c72f352018-02-06 17:49:16 -0700216 uint32_t queue_family_without_capabilities(VkQueueFlags capabilities);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600217 uint32_t graphics_queue_node_index_;
218
219 struct Format {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600220 VkFormat format;
221 VkImageTiling tiling;
222 VkFlags features;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600223 };
224 // vkGetFormatInfo()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600225 VkFormatProperties format_properties(VkFormat format);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600226 const std::vector<Format> &formats() const { return formats_; }
227
228 // vkDeviceWaitIdle()
229 void wait();
230
231 // vkWaitForFences()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600232 VkResult wait(const std::vector<const Fence *> &fences, bool wait_all, uint64_t timeout);
233 VkResult wait(const Fence &fence) { return wait(std::vector<const Fence *>(1, &fence), true, (uint64_t)-1); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600234
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800235 // vkUpdateDescriptorSets()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600236 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes, const std::vector<VkCopyDescriptorSet> &copies);
237 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes) {
238 return update_descriptor_sets(writes, std::vector<VkCopyDescriptorSet>());
Karl Schultz6addd812016-02-02 17:17:23 -0700239 }
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800240
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600241 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
242 VkDescriptorType type, uint32_t count,
243 const VkDescriptorImageInfo *image_info);
244 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
245 VkDescriptorType type, uint32_t count,
246 const VkDescriptorBufferInfo *buffer_info);
247 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
248 VkDescriptorType type, uint32_t count, const VkBufferView *buffer_views);
249 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
250 VkDescriptorType type, const std::vector<VkDescriptorImageInfo> &image_info);
251 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
252 VkDescriptorType type, const std::vector<VkDescriptorBufferInfo> &buffer_info);
253 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
254 VkDescriptorType type, const std::vector<VkBufferView> &buffer_views);
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800255
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600256 static VkCopyDescriptorSet copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding, uint32_t src_array_element,
257 const DescriptorSet &dst_set, uint32_t dst_binding, uint32_t dst_array_element,
258 uint32_t count);
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800259
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700260 private:
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600261 enum QueueIndex {
262 GRAPHICS,
263 COMPUTE,
264 DMA,
265 QUEUE_COUNT,
266 };
267
268 void init_queues();
269 void init_formats();
270
Chia-I Wu999f0482015-07-03 10:32:05 +0800271 PhysicalDevice phy_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600272
Petr Krausb9659a02017-12-11 01:17:46 +0100273 std::vector<const char *> enabled_extensions_;
274
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600275 std::vector<Queue *> queues_[QUEUE_COUNT];
276 std::vector<Format> formats_;
277};
278
Chia-I Wudf12ffd2015-07-03 10:53:18 +0800279class Queue : public internal::Handle<VkQueue> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700280 public:
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600281 explicit Queue(VkQueue queue, int index) : Handle(queue) { family_index_ = index; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600282
283 // vkQueueSubmit()
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800284 void submit(const std::vector<const CommandBuffer *> &cmds, Fence &fence);
285 void submit(const CommandBuffer &cmd, Fence &fence);
286 void submit(const CommandBuffer &cmd);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600287
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600288 // vkQueueWaitIdle()
289 void wait();
290
Karl Schultz6addd812016-02-02 17:17:23 -0700291 int get_family_index() { return family_index_; }
Tony Barbourfb21ea32015-07-23 10:35:30 -0600292
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700293 private:
Tony Barbourfb21ea32015-07-23 10:35:30 -0600294 int family_index_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600295};
296
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800297class DeviceMemory : public internal::NonDispHandle<VkDeviceMemory> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700298 public:
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800299 ~DeviceMemory();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600300
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800301 // vkAllocateMemory()
302 void init(const Device &dev, const VkMemoryAllocateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600303
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600304 // vkMapMemory()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600305 const void *map(VkFlags flags) const;
Karl Schultz6addd812016-02-02 17:17:23 -0700306 void *map(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600307 const void *map() const { return map(0); }
Karl Schultz6addd812016-02-02 17:17:23 -0700308 void *map() { return map(0); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600309
310 // vkUnmapMemory()
311 void unmap() const;
312
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600313 static VkMemoryAllocateInfo alloc_info(VkDeviceSize size, uint32_t memory_type_index);
Mike Schuchardt8cacbb02017-10-26 14:06:38 -0600314 static VkMemoryAllocateInfo get_resource_alloc_info(const vk_testing::Device &dev, const VkMemoryRequirements &reqs,
315 VkMemoryPropertyFlags mem_props);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600316};
317
Chia-I Wud9e8e822015-07-03 11:45:55 +0800318class Fence : public internal::NonDispHandle<VkFence> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700319 public:
Chia-I Wud9e8e822015-07-03 11:45:55 +0800320 ~Fence();
321
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600322 // vkCreateFence()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600323 void init(const Device &dev, const VkFenceCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600324
325 // vkGetFenceStatus()
Chia-I Wud9e8e822015-07-03 11:45:55 +0800326 VkResult status() const { return vkGetFenceStatus(device(), handle()); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600327
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600328 static VkFenceCreateInfo create_info(VkFenceCreateFlags flags);
329 static VkFenceCreateInfo create_info();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600330};
331
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800332class Semaphore : public internal::NonDispHandle<VkSemaphore> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700333 public:
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800334 ~Semaphore();
335
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600336 // vkCreateSemaphore()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600337 void init(const Device &dev, const VkSemaphoreCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600338
Tony Barbouraf892a12015-06-26 12:56:09 -0600339 static VkSemaphoreCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600340};
341
Chia-I Wuc5c97992015-07-03 11:49:42 +0800342class Event : public internal::NonDispHandle<VkEvent> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700343 public:
Chia-I Wuc5c97992015-07-03 11:49:42 +0800344 ~Event();
345
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600346 // vkCreateEvent()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600347 void init(const Device &dev, const VkEventCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600348
349 // vkGetEventStatus()
350 // vkSetEvent()
351 // vkResetEvent()
Chia-I Wuc5c97992015-07-03 11:49:42 +0800352 VkResult status() const { return vkGetEventStatus(device(), handle()); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600353 void set();
354 void reset();
355
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600356 static VkEventCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600357};
358
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800359class QueryPool : public internal::NonDispHandle<VkQueryPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700360 public:
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800361 ~QueryPool();
362
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600363 // vkCreateQueryPool()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600364 void init(const Device &dev, const VkQueryPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600365
366 // vkGetQueryPoolResults()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600367 VkResult results(uint32_t first, uint32_t count, size_t size, void *data, size_t stride);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600368
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600369 static VkQueryPoolCreateInfo create_info(VkQueryType type, uint32_t slot_count);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600370};
371
Chia-I Wu681d7a02015-07-03 13:44:34 +0800372class Buffer : public internal::NonDispHandle<VkBuffer> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700373 public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800374 explicit Buffer() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600375 explicit Buffer(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info); }
Tony Barbourd1c35722015-04-16 15:59:00 -0600376 explicit Buffer(const Device &dev, VkDeviceSize size) { init(dev, size); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600377
Chia-I Wu681d7a02015-07-03 13:44:34 +0800378 ~Buffer();
379
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600380 // vkCreateBuffer()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600381 void init(const Device &dev, const VkBufferCreateInfo &info, VkMemoryPropertyFlags mem_props);
382 void init(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info, 0); }
383 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 +0800384 void init(const Device &dev, VkDeviceSize size) { init(dev, size, 0); }
John Zulauf3d92b722018-01-16 11:15:15 -0700385 void init_as_src(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs,
386 const std::vector<uint32_t> *queue_families = nullptr) {
387 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_SRC_BIT, queue_families), reqs);
Karl Schultz6addd812016-02-02 17:17:23 -0700388 }
John Zulauf3d92b722018-01-16 11:15:15 -0700389 void init_as_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs,
390 const std::vector<uint32_t> *queue_families = nullptr) {
391 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_DST_BIT, queue_families), reqs);
Karl Schultz6addd812016-02-02 17:17:23 -0700392 }
John Zulauf3d92b722018-01-16 11:15:15 -0700393 void init_as_src_and_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs,
394 const std::vector<uint32_t> *queue_families = nullptr) {
395 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_SRC_BIT | VK_BUFFER_USAGE_TRANSFER_DST_BIT, queue_families), reqs);
Karl Schultz6addd812016-02-02 17:17:23 -0700396 }
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600397 void init_no_mem(const Device &dev, const VkBufferCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600398
Chia-I Wu681d7a02015-07-03 13:44:34 +0800399 // get the internal memory
400 const DeviceMemory &memory() const { return internal_mem_; }
Karl Schultz6addd812016-02-02 17:17:23 -0700401 DeviceMemory &memory() { return internal_mem_; }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800402
403 // vkGetObjectMemoryRequirements()
404 VkMemoryRequirements memory_requirements() const;
405
406 // vkBindObjectMemory()
407 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Mark Lobodzinski942b1722015-05-11 17:21:15 -0500408
John Zulauf065ca132018-02-20 12:19:28 -0700409 const VkBufferCreateInfo &create_info() const { return create_info_; }
John Zulauf3d92b722018-01-16 11:15:15 -0700410 static VkBufferCreateInfo create_info(VkDeviceSize size, VkFlags usage, const std::vector<uint32_t> *queue_families = nullptr);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600411
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600412 VkBufferMemoryBarrier buffer_memory_barrier(VkFlags output_mask, VkFlags input_mask, VkDeviceSize offset,
Karl Schultz6addd812016-02-02 17:17:23 -0700413 VkDeviceSize size) const {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600414 VkBufferMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600415 barrier.sType = VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800416 barrier.buffer = handle();
Chia-I Wua4594202015-10-27 19:54:37 +0800417 barrier.srcAccessMask = output_mask;
418 barrier.dstAccessMask = input_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600419 barrier.offset = offset;
420 barrier.size = size;
John Zulauf3d92b722018-01-16 11:15:15 -0700421 if (create_info_.sharingMode == VK_SHARING_MODE_CONCURRENT) {
422 barrier.srcQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
423 barrier.dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
424 }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600425 return barrier;
426 }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800427
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700428 private:
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600429 VkBufferCreateInfo create_info_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800430
431 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600432};
433
Chia-I Wu3158bf32015-07-03 11:49:42 +0800434class BufferView : public internal::NonDispHandle<VkBufferView> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700435 public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800436 ~BufferView();
437
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600438 // vkCreateBufferView()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600439 void init(const Device &dev, const VkBufferViewCreateInfo &info);
John Zulaufcde9d7d2018-01-18 16:53:07 -0700440 static VkBufferViewCreateInfo createInfo(VkBuffer buffer, VkFormat format, VkDeviceSize offset = 0,
441 VkDeviceSize range = VK_WHOLE_SIZE);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600442};
443
John Zulaufcde9d7d2018-01-18 16:53:07 -0700444inline VkBufferViewCreateInfo BufferView::createInfo(VkBuffer buffer, VkFormat format, VkDeviceSize offset, VkDeviceSize range) {
445 VkBufferViewCreateInfo info = {};
446 info.sType = VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO;
447 info.pNext = nullptr;
448 info.flags = VkFlags(0);
449 info.buffer = buffer;
450 info.format = format;
451 info.offset = offset;
452 info.range = range;
453 return info;
454}
455
Chia-I Wu681d7a02015-07-03 13:44:34 +0800456class Image : public internal::NonDispHandle<VkImage> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700457 public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800458 explicit Image() : NonDispHandle(), format_features_(0) {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600459 explicit Image(const Device &dev, const VkImageCreateInfo &info) : format_features_(0) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600460
Chia-I Wu681d7a02015-07-03 13:44:34 +0800461 ~Image();
462
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600463 // vkCreateImage()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600464 void init(const Device &dev, const VkImageCreateInfo &info, VkMemoryPropertyFlags mem_props);
465 void init(const Device &dev, const VkImageCreateInfo &info) { init(dev, info, 0); }
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600466 void init_no_mem(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600467
Chia-I Wu681d7a02015-07-03 13:44:34 +0800468 // get the internal memory
469 const DeviceMemory &memory() const { return internal_mem_; }
Karl Schultz6addd812016-02-02 17:17:23 -0700470 DeviceMemory &memory() { return internal_mem_; }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800471
472 // vkGetObjectMemoryRequirements()
473 VkMemoryRequirements memory_requirements() const;
474
475 // vkBindObjectMemory()
476 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600477
Tony Barbour59a47322015-06-24 16:06:58 -0600478 // vkGetImageSubresourceLayout()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600479 VkSubresourceLayout subresource_layout(const VkImageSubresource &subres) const;
480 VkSubresourceLayout subresource_layout(const VkImageSubresourceLayers &subres) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600481
482 bool transparent() const;
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600483 bool copyable() const { return (format_features_ & VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600484
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600485 VkImageSubresourceRange subresource_range(VkImageAspectFlagBits aspect) const {
Karl Schultz6addd812016-02-02 17:17:23 -0700486 return subresource_range(create_info_, aspect);
487 }
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600488 VkExtent3D extent() const { return create_info_.extent; }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600489 VkExtent3D extent(uint32_t mip_level) const { return extent(create_info_.extent, mip_level); }
Karl Schultz6addd812016-02-02 17:17:23 -0700490 VkFormat format() const { return create_info_.format; }
Mike Weiblene6e01172017-03-07 22:18:40 -0700491 VkImageUsageFlags usage() const { return create_info_.usage; }
John Zulauf3d92b722018-01-16 11:15:15 -0700492 VkSharingMode sharing_mode() const { return create_info_.sharingMode; }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600493 VkImageMemoryBarrier image_memory_barrier(VkFlags output_mask, VkFlags input_mask, VkImageLayout old_layout,
494 VkImageLayout new_layout, const VkImageSubresourceRange &range) const {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600495 VkImageMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600496 barrier.sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER;
Chia-I Wua4594202015-10-27 19:54:37 +0800497 barrier.srcAccessMask = output_mask;
498 barrier.dstAccessMask = input_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600499 barrier.oldLayout = old_layout;
500 barrier.newLayout = new_layout;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800501 barrier.image = handle();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600502 barrier.subresourceRange = range;
John Zulauf3d92b722018-01-16 11:15:15 -0700503
504 if (sharing_mode() == VK_SHARING_MODE_CONCURRENT) {
505 barrier.srcQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
506 barrier.dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
507 }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600508 return barrier;
509 }
510
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600511 static VkImageCreateInfo create_info();
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600512 static VkImageSubresource subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer);
513 static VkImageSubresource subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer);
514 static VkImageSubresourceLayers subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer,
Karl Schultz6addd812016-02-02 17:17:23 -0700515 uint32_t array_size);
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600516 static VkImageSubresourceLayers subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer,
517 uint32_t array_size);
518 static VkImageSubresourceRange subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level, uint32_t mip_levels,
519 uint32_t base_array_layer, uint32_t num_layers);
520 static VkImageSubresourceRange subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask);
521 static VkImageSubresourceRange subresource_range(const VkImageSubresource &subres);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600522
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600523 static VkExtent2D extent(int32_t width, int32_t height);
524 static VkExtent2D extent(const VkExtent2D &extent, uint32_t mip_level);
525 static VkExtent2D extent(const VkExtent3D &extent);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600526
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600527 static VkExtent3D extent(int32_t width, int32_t height, int32_t depth);
528 static VkExtent3D extent(const VkExtent3D &extent, uint32_t mip_level);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600529
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700530 private:
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600531 void init_info(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600532
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600533 VkImageCreateInfo create_info_;
534 VkFlags format_features_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800535
536 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600537};
538
Chia-I Wu3158bf32015-07-03 11:49:42 +0800539class ImageView : public internal::NonDispHandle<VkImageView> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700540 public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800541 ~ImageView();
542
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600543 // vkCreateImageView()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600544 void init(const Device &dev, const VkImageViewCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600545};
546
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800547class ShaderModule : public internal::NonDispHandle<VkShaderModule> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700548 public:
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800549 ~ShaderModule();
550
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600551 // vkCreateShaderModule()
552 void init(const Device &dev, const VkShaderModuleCreateInfo &info);
553 VkResult init_try(const Device &dev, const VkShaderModuleCreateInfo &info);
554
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600555 static VkShaderModuleCreateInfo create_info(size_t code_size, const uint32_t *code, VkFlags flags);
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600556};
557
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800558class Pipeline : public internal::NonDispHandle<VkPipeline> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700559 public:
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800560 ~Pipeline();
561
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600562 // vkCreateGraphicsPipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600563 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600564 // vkCreateGraphicsPipelineDerivative()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600565 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info, const VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600566 // vkCreateComputePipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600567 void init(const Device &dev, const VkComputePipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600568 // vkLoadPipeline()
Karl Schultz6addd812016-02-02 17:17:23 -0700569 void init(const Device &dev, size_t size, const void *data);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600570 // vkLoadPipelineDerivative()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600571 void init(const Device &dev, size_t size, const void *data, VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600572
Chris Forbes95292b12015-05-25 11:13:26 +1200573 // vkCreateGraphicsPipeline with error return
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600574 VkResult init_try(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Chris Forbes95292b12015-05-25 11:13:26 +1200575
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600576 // vkStorePipeline()
577 size_t store(size_t size, void *data);
578};
579
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800580class PipelineLayout : public internal::NonDispHandle<VkPipelineLayout> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700581 public:
Dave Houlton0cf0d132017-12-22 13:55:53 -0700582 PipelineLayout() NOEXCEPT : NonDispHandle(){};
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800583 ~PipelineLayout();
584
Mike Schuchardt0bc8e7a2018-01-02 14:39:51 -0700585 // Move constructor for Visual Studio 2013
586 PipelineLayout(PipelineLayout &&src) : NonDispHandle(std::move(src)){};
587
Petr Kraus65ccc882017-12-03 15:36:03 +0100588 PipelineLayout &operator=(PipelineLayout &&src) {
589 this->~PipelineLayout();
590 this->NonDispHandle::operator=(std::move(src));
591 return *this;
592 };
593
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800594 // vCreatePipelineLayout()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600595 void init(const Device &dev, VkPipelineLayoutCreateInfo &info, const std::vector<const DescriptorSetLayout *> &layouts);
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800596};
597
Chia-I Wu8c721c62015-07-03 11:49:42 +0800598class Sampler : public internal::NonDispHandle<VkSampler> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700599 public:
Chia-I Wu8c721c62015-07-03 11:49:42 +0800600 ~Sampler();
601
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600602 // vkCreateSampler()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600603 void init(const Device &dev, const VkSamplerCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600604};
605
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600606class DescriptorSetLayout : public internal::NonDispHandle<VkDescriptorSetLayout> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700607 public:
Dave Houlton0cf0d132017-12-22 13:55:53 -0700608 DescriptorSetLayout() NOEXCEPT : NonDispHandle(){};
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800609 ~DescriptorSetLayout();
610
Mike Schuchardt0bc8e7a2018-01-02 14:39:51 -0700611 // Move constructor for Visual Studio 2013
612 DescriptorSetLayout(DescriptorSetLayout &&src) : NonDispHandle(std::move(src)){};
613
Dave Houlton0cf0d132017-12-22 13:55:53 -0700614 DescriptorSetLayout &operator=(DescriptorSetLayout &&src) NOEXCEPT {
Petr Kraus32ea6082017-12-02 01:02:59 +0100615 this->~DescriptorSetLayout();
616 this->NonDispHandle::operator=(std::move(src));
617 return *this;
618 }
619
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600620 // vkCreateDescriptorSetLayout()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600621 void init(const Device &dev, const VkDescriptorSetLayoutCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600622};
623
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800624class DescriptorPool : public internal::NonDispHandle<VkDescriptorPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700625 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800626 ~DescriptorPool();
627
Karl Schultz6addd812016-02-02 17:17:23 -0700628 // Descriptor sets allocated from this pool will need access to the original
629 // object
Cody Northropcdc72a42015-10-08 11:39:25 -0600630 VkDescriptorPool GetObj() { return pool_; }
631
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600632 // vkCreateDescriptorPool()
Courtney Goeltzenleuchterfe908d32015-09-16 16:12:45 -0600633 void init(const Device &dev, const VkDescriptorPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600634
635 // vkResetDescriptorPool()
636 void reset();
637
Cody Northropcdc72a42015-10-08 11:39:25 -0600638 // vkFreeDescriptorSet()
639 void setDynamicUsage(bool isDynamic) { dynamic_usage_ = isDynamic; }
640 bool getDynamicUsage() { return dynamic_usage_; }
641
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800642 // vkAllocateDescriptorSets()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600643 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const std::vector<const DescriptorSetLayout *> &layouts);
644 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const DescriptorSetLayout &layout, uint32_t count);
645 DescriptorSet *alloc_sets(const Device &dev, const DescriptorSetLayout &layout);
Cody Northropcdc72a42015-10-08 11:39:25 -0600646
John Zulaufcde9d7d2018-01-18 16:53:07 -0700647 template <typename PoolSizes>
648 static VkDescriptorPoolCreateInfo create_info(VkDescriptorPoolCreateFlags flags, uint32_t max_sets,
649 const PoolSizes &pool_sizes);
650
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700651 private:
Cody Northropcdc72a42015-10-08 11:39:25 -0600652 VkDescriptorPool pool_;
653
654 // Track whether this pool's usage is VK_DESCRIPTOR_POOL_USAGE_DYNAMIC
655 bool dynamic_usage_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600656};
657
John Zulaufcde9d7d2018-01-18 16:53:07 -0700658template <typename PoolSizes>
659inline VkDescriptorPoolCreateInfo DescriptorPool::create_info(VkDescriptorPoolCreateFlags flags, uint32_t max_sets,
660 const PoolSizes &pool_sizes) {
661 VkDescriptorPoolCreateInfo info{};
662 info.sType = VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO;
663 info.pNext = nullptr;
664 info.flags = flags;
665 info.maxSets = max_sets;
666 info.poolSizeCount = pool_sizes.size();
667 info.pPoolSizes = (info.poolSizeCount) ? pool_sizes.data() : nullptr;
668 return info;
669}
670
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800671class DescriptorSet : public internal::NonDispHandle<VkDescriptorSet> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700672 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800673 ~DescriptorSet();
674
675 explicit DescriptorSet() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600676 explicit DescriptorSet(const Device &dev, DescriptorPool *pool, VkDescriptorSet set) : NonDispHandle(dev.handle(), set) {
Karl Schultz6addd812016-02-02 17:17:23 -0700677 containing_pool_ = pool;
678 }
Tony Barbour67e99152015-07-10 14:10:27 -0600679
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700680 private:
Karl Schultz6addd812016-02-02 17:17:23 -0700681 DescriptorPool *containing_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600682};
683
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800684class CommandPool : public internal::NonDispHandle<VkCommandPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700685 public:
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800686 ~CommandPool();
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600687
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800688 explicit CommandPool() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600689 explicit CommandPool(const Device &dev, const VkCommandPoolCreateInfo &info) { init(dev, info); }
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600690
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800691 void init(const Device &dev, const VkCommandPoolCreateInfo &info);
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600692
Mike Schuchardt06304c22017-03-01 17:09:09 -0700693 static VkCommandPoolCreateInfo create_info(uint32_t queue_family_index, VkCommandPoolCreateFlags flags);
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600694};
695
Mike Schuchardt06304c22017-03-01 17:09:09 -0700696inline VkCommandPoolCreateInfo CommandPool::create_info(uint32_t queue_family_index, VkCommandPoolCreateFlags flags) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800697 VkCommandPoolCreateInfo info = {};
698 info.sType = VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600699 info.queueFamilyIndex = queue_family_index;
Mike Schuchardt06304c22017-03-01 17:09:09 -0700700 info.flags = flags;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600701 return info;
702}
703
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800704class CommandBuffer : public internal::Handle<VkCommandBuffer> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700705 public:
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800706 ~CommandBuffer();
Chia-I Wube2b9172015-07-03 11:49:42 +0800707
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800708 explicit CommandBuffer() : Handle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600709 explicit CommandBuffer(const Device &dev, const VkCommandBufferAllocateInfo &info) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600710
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800711 // vkAllocateCommandBuffers()
712 void init(const Device &dev, const VkCommandBufferAllocateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600713
714 // vkBeginCommandBuffer()
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800715 void begin(const VkCommandBufferBeginInfo *info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600716 void begin();
717
718 // vkEndCommandBuffer()
719 // vkResetCommandBuffer()
720 void end();
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800721 void reset(VkCommandBufferResetFlags flags);
722 void reset() { reset(VK_COMMAND_BUFFER_RESET_RELEASE_RESOURCES_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600723
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800724 static VkCommandBufferAllocateInfo create_info(VkCommandPool const &pool);
Chia-I Wube2b9172015-07-03 11:49:42 +0800725
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700726 private:
Chia-I Wube2b9172015-07-03 11:49:42 +0800727 VkDevice dev_handle_;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800728 VkCommandPool cmd_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600729};
730
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600731inline VkMemoryAllocateInfo DeviceMemory::alloc_info(VkDeviceSize size, uint32_t memory_type_index) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800732 VkMemoryAllocateInfo info = {};
Chia-I Wu00ce5402015-11-10 16:21:09 +0800733 info.sType = VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO;
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800734 info.allocationSize = size;
735 info.memoryTypeIndex = memory_type_index;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600736 return info;
737}
738
John Zulauf3d92b722018-01-16 11:15:15 -0700739inline VkBufferCreateInfo Buffer::create_info(VkDeviceSize size, VkFlags usage, const std::vector<uint32_t> *queue_families) {
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600740 VkBufferCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600741 info.sType = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO;
742 info.size = size;
743 info.usage = usage;
John Zulauf3d92b722018-01-16 11:15:15 -0700744
745 if (queue_families && queue_families->size() > 1) {
746 info.sharingMode = VK_SHARING_MODE_CONCURRENT;
747 info.queueFamilyIndexCount = static_cast<uint32_t>(queue_families->size());
748 info.pQueueFamilyIndices = queue_families->data();
749 }
750
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600751 return info;
752}
753
Karl Schultz6addd812016-02-02 17:17:23 -0700754inline VkFenceCreateInfo Fence::create_info(VkFenceCreateFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600755 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600756 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
757 info.flags = flags;
758 return info;
759}
760
Karl Schultz6addd812016-02-02 17:17:23 -0700761inline VkFenceCreateInfo Fence::create_info() {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600762 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600763 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
764 return info;
765}
766
Karl Schultz6addd812016-02-02 17:17:23 -0700767inline VkSemaphoreCreateInfo Semaphore::create_info(VkFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600768 VkSemaphoreCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600769 info.sType = VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600770 info.flags = flags;
771 return info;
772}
773
Karl Schultz6addd812016-02-02 17:17:23 -0700774inline VkEventCreateInfo Event::create_info(VkFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600775 VkEventCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600776 info.sType = VK_STRUCTURE_TYPE_EVENT_CREATE_INFO;
777 info.flags = flags;
778 return info;
779}
780
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600781inline VkQueryPoolCreateInfo QueryPool::create_info(VkQueryType type, uint32_t slot_count) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600782 VkQueryPoolCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600783 info.sType = VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO;
784 info.queryType = type;
Jon Ashburnf19916e2016-01-11 13:12:43 -0700785 info.queryCount = slot_count;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600786 return info;
787}
788
Karl Schultz6addd812016-02-02 17:17:23 -0700789inline VkImageCreateInfo Image::create_info() {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600790 VkImageCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600791 info.sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO;
792 info.extent.width = 1;
793 info.extent.height = 1;
794 info.extent.depth = 1;
795 info.mipLevels = 1;
Courtney Goeltzenleuchter5d2aed42015-10-21 17:57:31 -0600796 info.arrayLayers = 1;
Chia-I Wu5c17c962015-10-31 00:31:16 +0800797 info.samples = VK_SAMPLE_COUNT_1_BIT;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600798 return info;
799}
800
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600801inline VkImageSubresource Image::subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600802 VkImageSubresource subres = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600803 if (aspect == 0) {
804 assert(!"Invalid VkImageAspectFlags");
805 }
Chia-I Wu52b07e72015-10-27 19:55:05 +0800806 subres.aspectMask = aspect;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600807 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600808 subres.arrayLayer = array_layer;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600809 return subres;
810}
811
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600812inline VkImageSubresource Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer) {
813 return subresource(range.aspectMask, range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600814}
815
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600816inline VkImageSubresourceLayers Image::subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer,
Karl Schultz6addd812016-02-02 17:17:23 -0700817 uint32_t array_size) {
Chia-I Wu1b99bb22015-10-27 19:25:11 +0800818 VkImageSubresourceLayers subres = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600819 switch (aspect) {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700820 case VK_IMAGE_ASPECT_COLOR_BIT:
821 case VK_IMAGE_ASPECT_DEPTH_BIT:
822 case VK_IMAGE_ASPECT_STENCIL_BIT:
823 case VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT:
824 /* valid */
825 break;
826 default:
827 assert(!"Invalid VkImageAspectFlags");
Karl Schultz0ab73f82016-03-29 12:41:24 -0600828 }
Chia-I Wuab83a0e2015-10-27 19:00:15 +0800829 subres.aspectMask = aspect;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600830 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter8367ce02015-10-16 09:46:00 -0600831 subres.baseArrayLayer = array_layer;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800832 subres.layerCount = array_size;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600833 return subres;
834}
835
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600836inline VkImageSubresourceLayers Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer,
837 uint32_t array_size) {
838 return subresource(range.aspectMask, range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer, array_size);
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600839}
840
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600841inline VkImageSubresourceRange Image::subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level,
842 uint32_t mip_levels, uint32_t base_array_layer, uint32_t num_layers) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600843 VkImageSubresourceRange range = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600844 if (aspect_mask == 0) {
845 assert(!"Invalid VkImageAspectFlags");
846 }
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600847 range.aspectMask = aspect_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600848 range.baseMipLevel = base_mip_level;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800849 range.levelCount = mip_levels;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600850 range.baseArrayLayer = base_array_layer;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800851 range.layerCount = num_layers;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600852 return range;
853}
854
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600855inline VkImageSubresourceRange Image::subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask) {
856 return subresource_range(aspect_mask, 0, info.mipLevels, 0, info.arrayLayers);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600857}
858
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600859inline VkImageSubresourceRange Image::subresource_range(const VkImageSubresource &subres) {
860 return subresource_range(subres.aspectMask, subres.mipLevel, 1, subres.arrayLayer, 1);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600861}
862
Karl Schultz6addd812016-02-02 17:17:23 -0700863inline VkExtent2D Image::extent(int32_t width, int32_t height) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600864 VkExtent2D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600865 extent.width = width;
866 extent.height = height;
867 return extent;
868}
869
Karl Schultz6addd812016-02-02 17:17:23 -0700870inline VkExtent2D Image::extent(const VkExtent2D &extent, uint32_t mip_level) {
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600871 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
872 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600873 return Image::extent(width, height);
874}
875
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600876inline VkExtent2D Image::extent(const VkExtent3D &extent) { return Image::extent(extent.width, extent.height); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600877
Karl Schultz6addd812016-02-02 17:17:23 -0700878inline VkExtent3D Image::extent(int32_t width, int32_t height, int32_t depth) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600879 VkExtent3D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600880 extent.width = width;
881 extent.height = height;
882 extent.depth = depth;
883 return extent;
884}
885
Karl Schultz6addd812016-02-02 17:17:23 -0700886inline VkExtent3D Image::extent(const VkExtent3D &extent, uint32_t mip_level) {
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600887 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
888 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
889 const int32_t depth = (extent.depth >> mip_level) ? extent.depth >> mip_level : 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600890 return Image::extent(width, height, depth);
891}
892
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600893inline VkShaderModuleCreateInfo ShaderModule::create_info(size_t code_size, const uint32_t *code, VkFlags flags) {
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600894 VkShaderModuleCreateInfo info = {};
895 info.sType = VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO;
896 info.codeSize = code_size;
897 info.pCode = code;
898 info.flags = flags;
899 return info;
900}
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, uint32_t count,
904 const VkDescriptorImageInfo *image_info) {
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800905 VkWriteDescriptorSet write = {};
906 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800907 write.dstSet = set.handle();
908 write.dstBinding = binding;
909 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800910 write.descriptorCount = count;
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800911 write.descriptorType = type;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600912 write.pImageInfo = image_info;
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800913 return write;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600914}
915
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600916inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
917 VkDescriptorType type, uint32_t count,
918 const VkDescriptorBufferInfo *buffer_info) {
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600919 VkWriteDescriptorSet write = {};
920 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800921 write.dstSet = set.handle();
922 write.dstBinding = binding;
923 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800924 write.descriptorCount = count;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600925 write.descriptorType = type;
926 write.pBufferInfo = buffer_info;
927 return write;
928}
929
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600930inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
931 VkDescriptorType type, uint32_t count, const VkBufferView *buffer_views) {
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600932 VkWriteDescriptorSet write = {};
933 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800934 write.dstSet = set.handle();
935 write.dstBinding = binding;
936 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800937 write.descriptorCount = count;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600938 write.descriptorType = type;
939 write.pTexelBufferView = buffer_views;
940 return write;
941}
942
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600943inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
944 VkDescriptorType type,
945 const std::vector<VkDescriptorImageInfo> &image_info) {
946 return write_descriptor_set(set, binding, array_element, type, image_info.size(), &image_info[0]);
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600947}
948
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600949inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
950 VkDescriptorType type,
951 const std::vector<VkDescriptorBufferInfo> &buffer_info) {
952 return write_descriptor_set(set, binding, array_element, type, buffer_info.size(), &buffer_info[0]);
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600953}
954
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600955inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
956 VkDescriptorType type, const std::vector<VkBufferView> &buffer_views) {
957 return write_descriptor_set(set, binding, array_element, type, buffer_views.size(), &buffer_views[0]);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600958}
959
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600960inline VkCopyDescriptorSet Device::copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding,
961 uint32_t src_array_element, const DescriptorSet &dst_set,
962 uint32_t dst_binding, uint32_t dst_array_element, uint32_t count) {
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800963 VkCopyDescriptorSet copy = {};
964 copy.sType = VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET;
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800965 copy.srcSet = src_set.handle();
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800966 copy.srcBinding = src_binding;
967 copy.srcArrayElement = src_array_element;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800968 copy.dstSet = dst_set.handle();
969 copy.dstBinding = dst_binding;
970 copy.dstArrayElement = dst_array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800971 copy.descriptorCount = count;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600972
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800973 return copy;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600974}
975
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600976inline VkCommandBufferAllocateInfo CommandBuffer::create_info(VkCommandPool const &pool) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800977 VkCommandBufferAllocateInfo info = {};
Chia-I Wu00ce5402015-11-10 16:21:09 +0800978 info.sType = VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800979 info.commandPool = pool;
Jon Ashburnf19916e2016-01-11 13:12:43 -0700980 info.commandBufferCount = 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600981 return info;
982}
983
Petr Kraus13c98a62017-12-09 00:22:39 +0100984} // namespace vk_testing
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600985
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700986#endif // VKTESTBINDING_H