blob: c244b0e75d54e7c40ac7ec79c15019ba213aaa35 [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>
John Zulauf5abdf122018-03-27 10:12:37 -060029#include <memory>
Mark Lobodzinski722841d2016-09-07 16:34:56 -060030#include <vector>
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060031
David Pinedo9316d3b2015-11-06 12:54:48 -070032#include "vulkan/vulkan.h"
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060033
34namespace vk_testing {
35
Petr Kraus858bacd2017-12-01 23:10:08 +010036template <class Dst, class Src>
37std::vector<Dst> MakeVkHandles(const std::vector<Src> &v) {
38 std::vector<Dst> handles;
39 handles.reserve(v.size());
40 std::transform(v.begin(), v.end(), std::back_inserter(handles), [](const Src &o) { return o.handle(); });
41 return handles;
42}
43
44template <class Dst, class Src>
45std::vector<Dst> MakeVkHandles(const std::vector<Src *> &v) {
46 std::vector<Dst> handles;
47 handles.reserve(v.size());
48 std::transform(v.begin(), v.end(), std::back_inserter(handles), [](const Src *o) { return o->handle(); });
49 return handles;
50}
51
Mark Lobodzinski722841d2016-09-07 16:34:56 -060052typedef void (*ErrorCallback)(const char *expr, const char *file, unsigned int line, const char *function);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060053void set_error_callback(ErrorCallback callback);
54
Chia-I Wu999f0482015-07-03 10:32:05 +080055class PhysicalDevice;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060056class Device;
57class Queue;
Chia-I Wuf8f074f2015-07-03 10:58:57 +080058class DeviceMemory;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060059class Fence;
60class Semaphore;
61class Event;
62class QueryPool;
63class Buffer;
64class BufferView;
65class Image;
66class ImageView;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060067class DepthStencilView;
68class Shader;
69class Pipeline;
70class PipelineDelta;
71class Sampler;
72class DescriptorSetLayout;
Mark Lobodzinski0fadf5f2015-04-17 14:11:39 -050073class PipelineLayout;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060074class DescriptorSetPool;
75class DescriptorSet;
Chia-I Wu3432a0c2015-10-27 18:04:07 +080076class CommandBuffer;
77class CommandPool;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060078
Courtney Goeltzenleuchter110fdf92015-06-29 15:39:26 -060079std::vector<VkLayerProperties> GetGlobalLayers();
80std::vector<VkExtensionProperties> GetGlobalExtensions();
81std::vector<VkExtensionProperties> GetGlobalExtensions(const char *pLayerName);
82
Chia-I Wub0ed7d42015-07-03 10:13:26 +080083namespace internal {
84
Mark Lobodzinski64318ba2017-01-26 13:34:13 -070085template <typename T>
86class Handle {
87 public:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080088 const T &handle() const { return handle_; }
Petr Krausb3d2c822017-12-01 23:09:19 +010089 bool initialized() const { return (handle_ != T{}); }
Chia-I Wub0ed7d42015-07-03 10:13:26 +080090
Mark Lobodzinski64318ba2017-01-26 13:34:13 -070091 protected:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080092 typedef T handle_type;
93
Petr Krausb3d2c822017-12-01 23:09:19 +010094 explicit Handle() : handle_{} {}
Chia-I Wub0ed7d42015-07-03 10:13:26 +080095 explicit Handle(T handle) : handle_(handle) {}
96
Petr Krausb3d2c822017-12-01 23:09:19 +010097 // handles are non-copyable
98 Handle(const Handle &) = delete;
99 Handle &operator=(const Handle &) = delete;
100
101 // handles can be moved out
Dave Houlton0cf0d132017-12-22 13:55:53 -0700102 Handle(Handle &&src) NOEXCEPT : handle_{src.handle_} { src.handle_ = {}; }
103 Handle &operator=(Handle &&src) NOEXCEPT {
Petr Krausb3d2c822017-12-01 23:09:19 +0100104 handle_ = src.handle_;
105 src.handle_ = {};
106 return *this;
107 }
108
Karl Schultz6addd812016-02-02 17:17:23 -0700109 void init(T handle) {
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800110 assert(!initialized());
111 handle_ = handle;
112 }
113
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700114 private:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800115 T handle_;
116};
117
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700118template <typename T>
119class NonDispHandle : public Handle<T> {
120 protected:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800121 explicit NonDispHandle() : Handle<T>(), dev_handle_(VK_NULL_HANDLE) {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600122 explicit NonDispHandle(VkDevice dev, T handle) : Handle<T>(handle), dev_handle_(dev) {}
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800123
Mike Schuchardt0bc8e7a2018-01-02 14:39:51 -0700124 NonDispHandle(NonDispHandle &&src) : Handle<T>(std::move(src)) {
125 dev_handle_ = src.dev_handle_;
126 src.dev_handle_ = VK_NULL_HANDLE;
127 }
128 NonDispHandle &operator=(NonDispHandle &&src) {
129 Handle<T>::operator=(std::move(src));
130 dev_handle_ = src.dev_handle_;
131 src.dev_handle_ = VK_NULL_HANDLE;
132 return *this;
133 }
Petr Krausb3d2c822017-12-01 23:09:19 +0100134
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800135 const VkDevice &device() const { return dev_handle_; }
136
Karl Schultz6addd812016-02-02 17:17:23 -0700137 void init(VkDevice dev, T handle) {
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800138 assert(!Handle<T>::initialized() && dev_handle_ == VK_NULL_HANDLE);
139 Handle<T>::init(handle);
140 dev_handle_ = dev;
141 }
142
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700143 private:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800144 VkDevice dev_handle_;
145};
146
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700147} // namespace internal
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800148
Chia-I Wu999f0482015-07-03 10:32:05 +0800149class PhysicalDevice : public internal::Handle<VkPhysicalDevice> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700150 public:
Karl Schultz6addd812016-02-02 17:17:23 -0700151 explicit PhysicalDevice(VkPhysicalDevice phy) : Handle(phy) {
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600152 memory_properties_ = memory_properties();
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600153 device_properties_ = properties();
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600154 }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600155
Tony Barbourd1c35722015-04-16 15:59:00 -0600156 VkPhysicalDeviceProperties properties() const;
Tony Barbourd1c35722015-04-16 15:59:00 -0600157 VkPhysicalDeviceMemoryProperties memory_properties() const;
Cody Northropd0802882015-08-03 17:04:53 -0600158 std::vector<VkQueueFamilyProperties> queue_properties() const;
Chris Forbesf9cfe182016-04-04 17:22:42 +1200159 VkPhysicalDeviceFeatures features() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600160
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600161 bool set_memory_type(const uint32_t type_bits, VkMemoryAllocateInfo *info, const VkMemoryPropertyFlags properties,
Karl Schultz6addd812016-02-02 17:17:23 -0700162 const VkMemoryPropertyFlags forbid = 0) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600163
Courtney Goeltzenleuchter35985f62015-09-14 17:22:16 -0600164 // vkEnumerateDeviceExtensionProperties()
Courtney Goeltzenleuchterf579fa62015-06-10 17:39:03 -0600165 std::vector<VkExtensionProperties> extensions() const;
Karl Schultz6addd812016-02-02 17:17:23 -0700166 std::vector<VkExtensionProperties> extensions(const char *pLayerName) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600167
168 // vkEnumerateLayers()
Courtney Goeltzenleuchtercd69eee2015-07-06 09:10:47 -0600169 std::vector<VkLayerProperties> layers() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600170
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700171 private:
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600172 void add_extension_dependencies(uint32_t dependency_count, VkExtensionProperties *depencency_props,
173 std::vector<VkExtensionProperties> &ext_list);
Chia-I Wu999f0482015-07-03 10:32:05 +0800174
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600175 VkPhysicalDeviceMemoryProperties memory_properties_;
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600176
177 VkPhysicalDeviceProperties device_properties_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600178};
179
John Zulauf01da3ee2017-10-18 18:13:37 -0600180class QueueCreateInfoArray {
181 private:
182 std::vector<VkDeviceQueueCreateInfo> queue_info_;
183 std::vector<std::vector<float>> queue_priorities_;
184
185 public:
186 QueueCreateInfoArray(const std::vector<VkQueueFamilyProperties> &queue_props);
187 size_t size() const { return queue_info_.size(); }
188 const VkDeviceQueueCreateInfo *data() const { return queue_info_.data(); }
189};
190
Chia-I Wuf368b602015-07-03 10:41:20 +0800191class Device : public internal::Handle<VkDevice> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700192 public:
Chia-I Wu999f0482015-07-03 10:32:05 +0800193 explicit Device(VkPhysicalDevice phy) : phy_(phy) {}
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600194 ~Device();
195
196 // vkCreateDevice()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600197 void init(const VkDeviceCreateInfo &info);
Jeff Bolzfdf96072018-04-10 14:32:18 -0500198 void init(std::vector<const char *> &extensions, VkPhysicalDeviceFeatures *features = nullptr,
199 VkPhysicalDeviceFeatures2 *features2 = nullptr); // all queues, all extensions, etc
Karl Schultz6addd812016-02-02 17:17:23 -0700200 void init() {
Karl Schultz6addd812016-02-02 17:17:23 -0700201 std::vector<const char *> extensions;
Tony Barbour4c70d102016-08-08 16:06:56 -0600202 init(extensions);
Karl Schultz6addd812016-02-02 17:17:23 -0700203 };
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600204
Chia-I Wu999f0482015-07-03 10:32:05 +0800205 const PhysicalDevice &phy() const { return phy_; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600206
Petr Krausb9659a02017-12-11 01:17:46 +0100207 std::vector<const char *> GetEnabledExtensions() { return enabled_extensions_; }
Cort Stratton72f89aa2018-05-27 10:40:27 -0700208 bool IsEnabledExtension(const char *extension);
Petr Krausb9659a02017-12-11 01:17:46 +0100209
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600210 // vkGetDeviceProcAddr()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600211 PFN_vkVoidFunction get_proc(const char *name) const { return vkGetDeviceProcAddr(handle(), name); }
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600212
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600213 // vkGetDeviceQueue()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600214 const std::vector<Queue *> &graphics_queues() const { return queues_[GRAPHICS]; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600215 const std::vector<Queue *> &compute_queues() { return queues_[COMPUTE]; }
216 const std::vector<Queue *> &dma_queues() { return queues_[DMA]; }
John Zulauf5abdf122018-03-27 10:12:37 -0600217
218 typedef std::vector<std::unique_ptr<Queue>> QueueFamilyQueues;
219 typedef std::vector<QueueFamilyQueues> QueueFamilies;
220 const QueueFamilyQueues &queue_family_queues(uint32_t queue_family) const;
221
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600222 uint32_t graphics_queue_node_index_;
223
224 struct Format {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600225 VkFormat format;
226 VkImageTiling tiling;
227 VkFlags features;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600228 };
229 // vkGetFormatInfo()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600230 VkFormatProperties format_properties(VkFormat format);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600231 const std::vector<Format> &formats() const { return formats_; }
232
233 // vkDeviceWaitIdle()
234 void wait();
235
236 // vkWaitForFences()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600237 VkResult wait(const std::vector<const Fence *> &fences, bool wait_all, uint64_t timeout);
238 VkResult wait(const Fence &fence) { return wait(std::vector<const Fence *>(1, &fence), true, (uint64_t)-1); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600239
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800240 // vkUpdateDescriptorSets()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600241 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes, const std::vector<VkCopyDescriptorSet> &copies);
242 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes) {
243 return update_descriptor_sets(writes, std::vector<VkCopyDescriptorSet>());
Karl Schultz6addd812016-02-02 17:17:23 -0700244 }
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800245
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600246 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
247 VkDescriptorType type, uint32_t count,
248 const VkDescriptorImageInfo *image_info);
249 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
250 VkDescriptorType type, uint32_t count,
251 const VkDescriptorBufferInfo *buffer_info);
252 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
253 VkDescriptorType type, uint32_t count, const VkBufferView *buffer_views);
254 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
255 VkDescriptorType type, const std::vector<VkDescriptorImageInfo> &image_info);
256 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
257 VkDescriptorType type, const std::vector<VkDescriptorBufferInfo> &buffer_info);
258 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
259 VkDescriptorType type, const std::vector<VkBufferView> &buffer_views);
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800260
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600261 static VkCopyDescriptorSet copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding, uint32_t src_array_element,
262 const DescriptorSet &dst_set, uint32_t dst_binding, uint32_t dst_array_element,
263 uint32_t count);
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800264
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700265 private:
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600266 enum QueueIndex {
267 GRAPHICS,
268 COMPUTE,
269 DMA,
270 QUEUE_COUNT,
271 };
272
273 void init_queues();
274 void init_formats();
275
Chia-I Wu999f0482015-07-03 10:32:05 +0800276 PhysicalDevice phy_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600277
Petr Krausb9659a02017-12-11 01:17:46 +0100278 std::vector<const char *> enabled_extensions_;
279
John Zulauf5abdf122018-03-27 10:12:37 -0600280 QueueFamilies queue_families_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600281 std::vector<Queue *> queues_[QUEUE_COUNT];
282 std::vector<Format> formats_;
283};
284
Chia-I Wudf12ffd2015-07-03 10:53:18 +0800285class Queue : public internal::Handle<VkQueue> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700286 public:
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600287 explicit Queue(VkQueue queue, int index) : Handle(queue) { family_index_ = index; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600288
289 // vkQueueSubmit()
John Zulauf71095472018-03-26 14:45:12 -0600290 VkResult submit(const std::vector<const CommandBuffer *> &cmds, const Fence &fence, bool expect_success = true);
291 VkResult submit(const CommandBuffer &cmd, const Fence &fence, bool expect_success = true);
292 VkResult submit(const CommandBuffer &cmd, bool expect_success = true);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600293
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600294 // vkQueueWaitIdle()
John Zulauf71095472018-03-26 14:45:12 -0600295 VkResult wait();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600296
Karl Schultz6addd812016-02-02 17:17:23 -0700297 int get_family_index() { return family_index_; }
Tony Barbourfb21ea32015-07-23 10:35:30 -0600298
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700299 private:
Tony Barbourfb21ea32015-07-23 10:35:30 -0600300 int family_index_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600301};
302
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800303class DeviceMemory : public internal::NonDispHandle<VkDeviceMemory> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700304 public:
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800305 ~DeviceMemory();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600306
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800307 // vkAllocateMemory()
308 void init(const Device &dev, const VkMemoryAllocateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600309
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600310 // vkMapMemory()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600311 const void *map(VkFlags flags) const;
Karl Schultz6addd812016-02-02 17:17:23 -0700312 void *map(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600313 const void *map() const { return map(0); }
Karl Schultz6addd812016-02-02 17:17:23 -0700314 void *map() { return map(0); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600315
316 // vkUnmapMemory()
317 void unmap() const;
318
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600319 static VkMemoryAllocateInfo alloc_info(VkDeviceSize size, uint32_t memory_type_index);
Mike Schuchardt8cacbb02017-10-26 14:06:38 -0600320 static VkMemoryAllocateInfo get_resource_alloc_info(const vk_testing::Device &dev, const VkMemoryRequirements &reqs,
321 VkMemoryPropertyFlags mem_props);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600322};
323
Chia-I Wud9e8e822015-07-03 11:45:55 +0800324class Fence : public internal::NonDispHandle<VkFence> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700325 public:
Chia-I Wud9e8e822015-07-03 11:45:55 +0800326 ~Fence();
327
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600328 // vkCreateFence()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600329 void init(const Device &dev, const VkFenceCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600330
331 // vkGetFenceStatus()
Chia-I Wud9e8e822015-07-03 11:45:55 +0800332 VkResult status() const { return vkGetFenceStatus(device(), handle()); }
John Zulauf71095472018-03-26 14:45:12 -0600333 VkResult wait(VkBool32 wait_all, uint64_t timeout) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600334
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600335 static VkFenceCreateInfo create_info(VkFenceCreateFlags flags);
336 static VkFenceCreateInfo create_info();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600337};
338
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800339class Semaphore : public internal::NonDispHandle<VkSemaphore> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700340 public:
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800341 ~Semaphore();
342
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600343 // vkCreateSemaphore()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600344 void init(const Device &dev, const VkSemaphoreCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600345
Tony Barbouraf892a12015-06-26 12:56:09 -0600346 static VkSemaphoreCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600347};
348
Chia-I Wuc5c97992015-07-03 11:49:42 +0800349class Event : public internal::NonDispHandle<VkEvent> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700350 public:
Chia-I Wuc5c97992015-07-03 11:49:42 +0800351 ~Event();
352
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600353 // vkCreateEvent()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600354 void init(const Device &dev, const VkEventCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600355
356 // vkGetEventStatus()
357 // vkSetEvent()
358 // vkResetEvent()
Chia-I Wuc5c97992015-07-03 11:49:42 +0800359 VkResult status() const { return vkGetEventStatus(device(), handle()); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600360 void set();
361 void reset();
362
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600363 static VkEventCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600364};
365
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800366class QueryPool : public internal::NonDispHandle<VkQueryPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700367 public:
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800368 ~QueryPool();
369
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600370 // vkCreateQueryPool()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600371 void init(const Device &dev, const VkQueryPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600372
373 // vkGetQueryPoolResults()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600374 VkResult results(uint32_t first, uint32_t count, size_t size, void *data, size_t stride);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600375
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600376 static VkQueryPoolCreateInfo create_info(VkQueryType type, uint32_t slot_count);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600377};
378
Chia-I Wu681d7a02015-07-03 13:44:34 +0800379class Buffer : public internal::NonDispHandle<VkBuffer> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700380 public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800381 explicit Buffer() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600382 explicit Buffer(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info); }
Tony Barbourd1c35722015-04-16 15:59:00 -0600383 explicit Buffer(const Device &dev, VkDeviceSize size) { init(dev, size); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600384
Chia-I Wu681d7a02015-07-03 13:44:34 +0800385 ~Buffer();
386
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600387 // vkCreateBuffer()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600388 void init(const Device &dev, const VkBufferCreateInfo &info, VkMemoryPropertyFlags mem_props);
389 void init(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info, 0); }
390 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 +0800391 void init(const Device &dev, VkDeviceSize size) { init(dev, size, 0); }
John Zulauf3d92b722018-01-16 11:15:15 -0700392 void init_as_src(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs,
393 const std::vector<uint32_t> *queue_families = nullptr) {
394 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_SRC_BIT, queue_families), reqs);
Karl Schultz6addd812016-02-02 17:17:23 -0700395 }
John Zulauf3d92b722018-01-16 11:15:15 -0700396 void init_as_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs,
397 const std::vector<uint32_t> *queue_families = nullptr) {
398 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_DST_BIT, queue_families), reqs);
Karl Schultz6addd812016-02-02 17:17:23 -0700399 }
John Zulauf3d92b722018-01-16 11:15:15 -0700400 void init_as_src_and_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs,
401 const std::vector<uint32_t> *queue_families = nullptr) {
402 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 -0700403 }
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600404 void init_no_mem(const Device &dev, const VkBufferCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600405
Chia-I Wu681d7a02015-07-03 13:44:34 +0800406 // get the internal memory
407 const DeviceMemory &memory() const { return internal_mem_; }
Karl Schultz6addd812016-02-02 17:17:23 -0700408 DeviceMemory &memory() { return internal_mem_; }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800409
410 // vkGetObjectMemoryRequirements()
411 VkMemoryRequirements memory_requirements() const;
412
413 // vkBindObjectMemory()
414 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Mark Lobodzinski942b1722015-05-11 17:21:15 -0500415
John Zulauf065ca132018-02-20 12:19:28 -0700416 const VkBufferCreateInfo &create_info() const { return create_info_; }
John Zulauf3d92b722018-01-16 11:15:15 -0700417 static VkBufferCreateInfo create_info(VkDeviceSize size, VkFlags usage, const std::vector<uint32_t> *queue_families = nullptr);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600418
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600419 VkBufferMemoryBarrier buffer_memory_barrier(VkFlags output_mask, VkFlags input_mask, VkDeviceSize offset,
Karl Schultz6addd812016-02-02 17:17:23 -0700420 VkDeviceSize size) const {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600421 VkBufferMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600422 barrier.sType = VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800423 barrier.buffer = handle();
Chia-I Wua4594202015-10-27 19:54:37 +0800424 barrier.srcAccessMask = output_mask;
425 barrier.dstAccessMask = input_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600426 barrier.offset = offset;
427 barrier.size = size;
John Zulauf3d92b722018-01-16 11:15:15 -0700428 if (create_info_.sharingMode == VK_SHARING_MODE_CONCURRENT) {
429 barrier.srcQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
430 barrier.dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
431 }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600432 return barrier;
433 }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800434
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700435 private:
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600436 VkBufferCreateInfo create_info_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800437
438 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600439};
440
Chia-I Wu3158bf32015-07-03 11:49:42 +0800441class BufferView : public internal::NonDispHandle<VkBufferView> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700442 public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800443 ~BufferView();
444
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600445 // vkCreateBufferView()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600446 void init(const Device &dev, const VkBufferViewCreateInfo &info);
John Zulaufcde9d7d2018-01-18 16:53:07 -0700447 static VkBufferViewCreateInfo createInfo(VkBuffer buffer, VkFormat format, VkDeviceSize offset = 0,
448 VkDeviceSize range = VK_WHOLE_SIZE);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600449};
450
John Zulaufcde9d7d2018-01-18 16:53:07 -0700451inline VkBufferViewCreateInfo BufferView::createInfo(VkBuffer buffer, VkFormat format, VkDeviceSize offset, VkDeviceSize range) {
452 VkBufferViewCreateInfo info = {};
453 info.sType = VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO;
454 info.pNext = nullptr;
455 info.flags = VkFlags(0);
456 info.buffer = buffer;
457 info.format = format;
458 info.offset = offset;
459 info.range = range;
460 return info;
461}
462
Chia-I Wu681d7a02015-07-03 13:44:34 +0800463class Image : public internal::NonDispHandle<VkImage> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700464 public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800465 explicit Image() : NonDispHandle(), format_features_(0) {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600466 explicit Image(const Device &dev, const VkImageCreateInfo &info) : format_features_(0) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600467
Chia-I Wu681d7a02015-07-03 13:44:34 +0800468 ~Image();
469
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600470 // vkCreateImage()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600471 void init(const Device &dev, const VkImageCreateInfo &info, VkMemoryPropertyFlags mem_props);
472 void init(const Device &dev, const VkImageCreateInfo &info) { init(dev, info, 0); }
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600473 void init_no_mem(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600474
Chia-I Wu681d7a02015-07-03 13:44:34 +0800475 // get the internal memory
476 const DeviceMemory &memory() const { return internal_mem_; }
Karl Schultz6addd812016-02-02 17:17:23 -0700477 DeviceMemory &memory() { return internal_mem_; }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800478
479 // vkGetObjectMemoryRequirements()
480 VkMemoryRequirements memory_requirements() const;
481
482 // vkBindObjectMemory()
483 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600484
Tony Barbour59a47322015-06-24 16:06:58 -0600485 // vkGetImageSubresourceLayout()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600486 VkSubresourceLayout subresource_layout(const VkImageSubresource &subres) const;
487 VkSubresourceLayout subresource_layout(const VkImageSubresourceLayers &subres) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600488
489 bool transparent() const;
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600490 bool copyable() const { return (format_features_ & VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600491
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600492 VkImageSubresourceRange subresource_range(VkImageAspectFlagBits aspect) const {
Karl Schultz6addd812016-02-02 17:17:23 -0700493 return subresource_range(create_info_, aspect);
494 }
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600495 VkExtent3D extent() const { return create_info_.extent; }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600496 VkExtent3D extent(uint32_t mip_level) const { return extent(create_info_.extent, mip_level); }
Karl Schultz6addd812016-02-02 17:17:23 -0700497 VkFormat format() const { return create_info_.format; }
Mike Weiblene6e01172017-03-07 22:18:40 -0700498 VkImageUsageFlags usage() const { return create_info_.usage; }
John Zulauf3d92b722018-01-16 11:15:15 -0700499 VkSharingMode sharing_mode() const { return create_info_.sharingMode; }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600500 VkImageMemoryBarrier image_memory_barrier(VkFlags output_mask, VkFlags input_mask, VkImageLayout old_layout,
501 VkImageLayout new_layout, const VkImageSubresourceRange &range) const {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600502 VkImageMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600503 barrier.sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER;
Chia-I Wua4594202015-10-27 19:54:37 +0800504 barrier.srcAccessMask = output_mask;
505 barrier.dstAccessMask = input_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600506 barrier.oldLayout = old_layout;
507 barrier.newLayout = new_layout;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800508 barrier.image = handle();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600509 barrier.subresourceRange = range;
John Zulauf3d92b722018-01-16 11:15:15 -0700510
511 if (sharing_mode() == VK_SHARING_MODE_CONCURRENT) {
512 barrier.srcQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
513 barrier.dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
514 }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600515 return barrier;
516 }
517
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600518 static VkImageCreateInfo create_info();
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600519 static VkImageSubresource subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer);
520 static VkImageSubresource subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer);
521 static VkImageSubresourceLayers subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer,
Karl Schultz6addd812016-02-02 17:17:23 -0700522 uint32_t array_size);
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600523 static VkImageSubresourceLayers subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer,
524 uint32_t array_size);
525 static VkImageSubresourceRange subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level, uint32_t mip_levels,
526 uint32_t base_array_layer, uint32_t num_layers);
527 static VkImageSubresourceRange subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask);
528 static VkImageSubresourceRange subresource_range(const VkImageSubresource &subres);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600529
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600530 static VkExtent2D extent(int32_t width, int32_t height);
531 static VkExtent2D extent(const VkExtent2D &extent, uint32_t mip_level);
532 static VkExtent2D extent(const VkExtent3D &extent);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600533
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600534 static VkExtent3D extent(int32_t width, int32_t height, int32_t depth);
535 static VkExtent3D extent(const VkExtent3D &extent, uint32_t mip_level);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600536
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700537 private:
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600538 void init_info(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600539
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600540 VkImageCreateInfo create_info_;
541 VkFlags format_features_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800542
543 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600544};
545
Chia-I Wu3158bf32015-07-03 11:49:42 +0800546class ImageView : public internal::NonDispHandle<VkImageView> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700547 public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800548 ~ImageView();
549
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600550 // vkCreateImageView()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600551 void init(const Device &dev, const VkImageViewCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600552};
553
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800554class ShaderModule : public internal::NonDispHandle<VkShaderModule> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700555 public:
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800556 ~ShaderModule();
557
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600558 // vkCreateShaderModule()
559 void init(const Device &dev, const VkShaderModuleCreateInfo &info);
560 VkResult init_try(const Device &dev, const VkShaderModuleCreateInfo &info);
561
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600562 static VkShaderModuleCreateInfo create_info(size_t code_size, const uint32_t *code, VkFlags flags);
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600563};
564
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800565class Pipeline : public internal::NonDispHandle<VkPipeline> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700566 public:
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800567 ~Pipeline();
568
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600569 // vkCreateGraphicsPipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600570 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600571 // vkCreateGraphicsPipelineDerivative()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600572 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info, const VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600573 // vkCreateComputePipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600574 void init(const Device &dev, const VkComputePipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600575 // vkLoadPipeline()
Karl Schultz6addd812016-02-02 17:17:23 -0700576 void init(const Device &dev, size_t size, const void *data);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600577 // vkLoadPipelineDerivative()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600578 void init(const Device &dev, size_t size, const void *data, VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600579
Chris Forbes95292b12015-05-25 11:13:26 +1200580 // vkCreateGraphicsPipeline with error return
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600581 VkResult init_try(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Chris Forbes95292b12015-05-25 11:13:26 +1200582
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600583 // vkStorePipeline()
584 size_t store(size_t size, void *data);
585};
586
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800587class PipelineLayout : public internal::NonDispHandle<VkPipelineLayout> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700588 public:
Dave Houlton0cf0d132017-12-22 13:55:53 -0700589 PipelineLayout() NOEXCEPT : NonDispHandle(){};
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800590 ~PipelineLayout();
591
Mike Schuchardt0bc8e7a2018-01-02 14:39:51 -0700592 // Move constructor for Visual Studio 2013
593 PipelineLayout(PipelineLayout &&src) : NonDispHandle(std::move(src)){};
594
Petr Kraus65ccc882017-12-03 15:36:03 +0100595 PipelineLayout &operator=(PipelineLayout &&src) {
596 this->~PipelineLayout();
597 this->NonDispHandle::operator=(std::move(src));
598 return *this;
599 };
600
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800601 // vCreatePipelineLayout()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600602 void init(const Device &dev, VkPipelineLayoutCreateInfo &info, const std::vector<const DescriptorSetLayout *> &layouts);
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800603};
604
Chia-I Wu8c721c62015-07-03 11:49:42 +0800605class Sampler : public internal::NonDispHandle<VkSampler> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700606 public:
Chia-I Wu8c721c62015-07-03 11:49:42 +0800607 ~Sampler();
608
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600609 // vkCreateSampler()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600610 void init(const Device &dev, const VkSamplerCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600611};
612
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600613class DescriptorSetLayout : public internal::NonDispHandle<VkDescriptorSetLayout> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700614 public:
Dave Houlton0cf0d132017-12-22 13:55:53 -0700615 DescriptorSetLayout() NOEXCEPT : NonDispHandle(){};
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800616 ~DescriptorSetLayout();
617
Mike Schuchardt0bc8e7a2018-01-02 14:39:51 -0700618 // Move constructor for Visual Studio 2013
619 DescriptorSetLayout(DescriptorSetLayout &&src) : NonDispHandle(std::move(src)){};
620
Dave Houlton0cf0d132017-12-22 13:55:53 -0700621 DescriptorSetLayout &operator=(DescriptorSetLayout &&src) NOEXCEPT {
Petr Kraus32ea6082017-12-02 01:02:59 +0100622 this->~DescriptorSetLayout();
623 this->NonDispHandle::operator=(std::move(src));
624 return *this;
625 }
626
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600627 // vkCreateDescriptorSetLayout()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600628 void init(const Device &dev, const VkDescriptorSetLayoutCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600629};
630
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800631class DescriptorPool : public internal::NonDispHandle<VkDescriptorPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700632 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800633 ~DescriptorPool();
634
Karl Schultz6addd812016-02-02 17:17:23 -0700635 // Descriptor sets allocated from this pool will need access to the original
636 // object
Cody Northropcdc72a42015-10-08 11:39:25 -0600637 VkDescriptorPool GetObj() { return pool_; }
638
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600639 // vkCreateDescriptorPool()
Courtney Goeltzenleuchterfe908d32015-09-16 16:12:45 -0600640 void init(const Device &dev, const VkDescriptorPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600641
642 // vkResetDescriptorPool()
643 void reset();
644
Cody Northropcdc72a42015-10-08 11:39:25 -0600645 // vkFreeDescriptorSet()
646 void setDynamicUsage(bool isDynamic) { dynamic_usage_ = isDynamic; }
647 bool getDynamicUsage() { return dynamic_usage_; }
648
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800649 // vkAllocateDescriptorSets()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600650 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const std::vector<const DescriptorSetLayout *> &layouts);
651 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const DescriptorSetLayout &layout, uint32_t count);
652 DescriptorSet *alloc_sets(const Device &dev, const DescriptorSetLayout &layout);
Cody Northropcdc72a42015-10-08 11:39:25 -0600653
John Zulaufcde9d7d2018-01-18 16:53:07 -0700654 template <typename PoolSizes>
655 static VkDescriptorPoolCreateInfo create_info(VkDescriptorPoolCreateFlags flags, uint32_t max_sets,
656 const PoolSizes &pool_sizes);
657
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700658 private:
Cody Northropcdc72a42015-10-08 11:39:25 -0600659 VkDescriptorPool pool_;
660
661 // Track whether this pool's usage is VK_DESCRIPTOR_POOL_USAGE_DYNAMIC
662 bool dynamic_usage_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600663};
664
John Zulaufcde9d7d2018-01-18 16:53:07 -0700665template <typename PoolSizes>
666inline VkDescriptorPoolCreateInfo DescriptorPool::create_info(VkDescriptorPoolCreateFlags flags, uint32_t max_sets,
667 const PoolSizes &pool_sizes) {
668 VkDescriptorPoolCreateInfo info{};
669 info.sType = VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO;
670 info.pNext = nullptr;
671 info.flags = flags;
672 info.maxSets = max_sets;
673 info.poolSizeCount = pool_sizes.size();
674 info.pPoolSizes = (info.poolSizeCount) ? pool_sizes.data() : nullptr;
675 return info;
676}
677
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800678class DescriptorSet : public internal::NonDispHandle<VkDescriptorSet> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700679 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800680 ~DescriptorSet();
681
682 explicit DescriptorSet() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600683 explicit DescriptorSet(const Device &dev, DescriptorPool *pool, VkDescriptorSet set) : NonDispHandle(dev.handle(), set) {
Karl Schultz6addd812016-02-02 17:17:23 -0700684 containing_pool_ = pool;
685 }
Tony Barbour67e99152015-07-10 14:10:27 -0600686
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700687 private:
Karl Schultz6addd812016-02-02 17:17:23 -0700688 DescriptorPool *containing_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600689};
690
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800691class CommandPool : public internal::NonDispHandle<VkCommandPool> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700692 public:
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800693 ~CommandPool();
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600694
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800695 explicit CommandPool() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600696 explicit CommandPool(const Device &dev, const VkCommandPoolCreateInfo &info) { init(dev, info); }
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600697
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800698 void init(const Device &dev, const VkCommandPoolCreateInfo &info);
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600699
Mike Schuchardt06304c22017-03-01 17:09:09 -0700700 static VkCommandPoolCreateInfo create_info(uint32_t queue_family_index, VkCommandPoolCreateFlags flags);
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600701};
702
Mike Schuchardt06304c22017-03-01 17:09:09 -0700703inline VkCommandPoolCreateInfo CommandPool::create_info(uint32_t queue_family_index, VkCommandPoolCreateFlags flags) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800704 VkCommandPoolCreateInfo info = {};
705 info.sType = VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600706 info.queueFamilyIndex = queue_family_index;
Mike Schuchardt06304c22017-03-01 17:09:09 -0700707 info.flags = flags;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600708 return info;
709}
710
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800711class CommandBuffer : public internal::Handle<VkCommandBuffer> {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700712 public:
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800713 ~CommandBuffer();
Chia-I Wube2b9172015-07-03 11:49:42 +0800714
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800715 explicit CommandBuffer() : Handle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600716 explicit CommandBuffer(const Device &dev, const VkCommandBufferAllocateInfo &info) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600717
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800718 // vkAllocateCommandBuffers()
719 void init(const Device &dev, const VkCommandBufferAllocateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600720
721 // vkBeginCommandBuffer()
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800722 void begin(const VkCommandBufferBeginInfo *info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600723 void begin();
724
725 // vkEndCommandBuffer()
726 // vkResetCommandBuffer()
727 void end();
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800728 void reset(VkCommandBufferResetFlags flags);
729 void reset() { reset(VK_COMMAND_BUFFER_RESET_RELEASE_RESOURCES_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600730
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800731 static VkCommandBufferAllocateInfo create_info(VkCommandPool const &pool);
Chia-I Wube2b9172015-07-03 11:49:42 +0800732
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700733 private:
Chia-I Wube2b9172015-07-03 11:49:42 +0800734 VkDevice dev_handle_;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800735 VkCommandPool cmd_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600736};
737
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600738inline VkMemoryAllocateInfo DeviceMemory::alloc_info(VkDeviceSize size, uint32_t memory_type_index) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800739 VkMemoryAllocateInfo info = {};
Chia-I Wu00ce5402015-11-10 16:21:09 +0800740 info.sType = VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO;
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800741 info.allocationSize = size;
742 info.memoryTypeIndex = memory_type_index;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600743 return info;
744}
745
John Zulauf3d92b722018-01-16 11:15:15 -0700746inline VkBufferCreateInfo Buffer::create_info(VkDeviceSize size, VkFlags usage, const std::vector<uint32_t> *queue_families) {
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600747 VkBufferCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600748 info.sType = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO;
749 info.size = size;
750 info.usage = usage;
John Zulauf3d92b722018-01-16 11:15:15 -0700751
752 if (queue_families && queue_families->size() > 1) {
753 info.sharingMode = VK_SHARING_MODE_CONCURRENT;
754 info.queueFamilyIndexCount = static_cast<uint32_t>(queue_families->size());
755 info.pQueueFamilyIndices = queue_families->data();
756 }
757
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600758 return info;
759}
760
Karl Schultz6addd812016-02-02 17:17:23 -0700761inline VkFenceCreateInfo Fence::create_info(VkFenceCreateFlags flags) {
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 info.flags = flags;
765 return info;
766}
767
Karl Schultz6addd812016-02-02 17:17:23 -0700768inline VkFenceCreateInfo Fence::create_info() {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600769 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600770 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
771 return info;
772}
773
Karl Schultz6addd812016-02-02 17:17:23 -0700774inline VkSemaphoreCreateInfo Semaphore::create_info(VkFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600775 VkSemaphoreCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600776 info.sType = VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600777 info.flags = flags;
778 return info;
779}
780
Karl Schultz6addd812016-02-02 17:17:23 -0700781inline VkEventCreateInfo Event::create_info(VkFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600782 VkEventCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600783 info.sType = VK_STRUCTURE_TYPE_EVENT_CREATE_INFO;
784 info.flags = flags;
785 return info;
786}
787
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600788inline VkQueryPoolCreateInfo QueryPool::create_info(VkQueryType type, uint32_t slot_count) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600789 VkQueryPoolCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600790 info.sType = VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO;
791 info.queryType = type;
Jon Ashburnf19916e2016-01-11 13:12:43 -0700792 info.queryCount = slot_count;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600793 return info;
794}
795
Karl Schultz6addd812016-02-02 17:17:23 -0700796inline VkImageCreateInfo Image::create_info() {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600797 VkImageCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600798 info.sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO;
799 info.extent.width = 1;
800 info.extent.height = 1;
801 info.extent.depth = 1;
802 info.mipLevels = 1;
Courtney Goeltzenleuchter5d2aed42015-10-21 17:57:31 -0600803 info.arrayLayers = 1;
Chia-I Wu5c17c962015-10-31 00:31:16 +0800804 info.samples = VK_SAMPLE_COUNT_1_BIT;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600805 return info;
806}
807
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600808inline VkImageSubresource Image::subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600809 VkImageSubresource subres = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600810 if (aspect == 0) {
811 assert(!"Invalid VkImageAspectFlags");
812 }
Chia-I Wu52b07e72015-10-27 19:55:05 +0800813 subres.aspectMask = aspect;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600814 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600815 subres.arrayLayer = array_layer;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600816 return subres;
817}
818
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600819inline VkImageSubresource Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer) {
820 return subresource(range.aspectMask, range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600821}
822
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600823inline VkImageSubresourceLayers Image::subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer,
Karl Schultz6addd812016-02-02 17:17:23 -0700824 uint32_t array_size) {
Chia-I Wu1b99bb22015-10-27 19:25:11 +0800825 VkImageSubresourceLayers subres = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600826 switch (aspect) {
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700827 case VK_IMAGE_ASPECT_COLOR_BIT:
828 case VK_IMAGE_ASPECT_DEPTH_BIT:
829 case VK_IMAGE_ASPECT_STENCIL_BIT:
830 case VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT:
831 /* valid */
832 break;
833 default:
834 assert(!"Invalid VkImageAspectFlags");
Karl Schultz0ab73f82016-03-29 12:41:24 -0600835 }
Chia-I Wuab83a0e2015-10-27 19:00:15 +0800836 subres.aspectMask = aspect;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600837 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter8367ce02015-10-16 09:46:00 -0600838 subres.baseArrayLayer = array_layer;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800839 subres.layerCount = array_size;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600840 return subres;
841}
842
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600843inline VkImageSubresourceLayers Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer,
844 uint32_t array_size) {
845 return subresource(range.aspectMask, range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer, array_size);
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600846}
847
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600848inline VkImageSubresourceRange Image::subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level,
849 uint32_t mip_levels, uint32_t base_array_layer, uint32_t num_layers) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600850 VkImageSubresourceRange range = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600851 if (aspect_mask == 0) {
852 assert(!"Invalid VkImageAspectFlags");
853 }
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600854 range.aspectMask = aspect_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600855 range.baseMipLevel = base_mip_level;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800856 range.levelCount = mip_levels;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600857 range.baseArrayLayer = base_array_layer;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800858 range.layerCount = num_layers;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600859 return range;
860}
861
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600862inline VkImageSubresourceRange Image::subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask) {
863 return subresource_range(aspect_mask, 0, info.mipLevels, 0, info.arrayLayers);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600864}
865
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600866inline VkImageSubresourceRange Image::subresource_range(const VkImageSubresource &subres) {
867 return subresource_range(subres.aspectMask, subres.mipLevel, 1, subres.arrayLayer, 1);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600868}
869
Karl Schultz6addd812016-02-02 17:17:23 -0700870inline VkExtent2D Image::extent(int32_t width, int32_t height) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600871 VkExtent2D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600872 extent.width = width;
873 extent.height = height;
874 return extent;
875}
876
Karl Schultz6addd812016-02-02 17:17:23 -0700877inline VkExtent2D Image::extent(const VkExtent2D &extent, uint32_t mip_level) {
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600878 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
879 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600880 return Image::extent(width, height);
881}
882
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600883inline VkExtent2D Image::extent(const VkExtent3D &extent) { return Image::extent(extent.width, extent.height); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600884
Karl Schultz6addd812016-02-02 17:17:23 -0700885inline VkExtent3D Image::extent(int32_t width, int32_t height, int32_t depth) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600886 VkExtent3D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600887 extent.width = width;
888 extent.height = height;
889 extent.depth = depth;
890 return extent;
891}
892
Karl Schultz6addd812016-02-02 17:17:23 -0700893inline VkExtent3D Image::extent(const VkExtent3D &extent, uint32_t mip_level) {
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600894 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
895 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
896 const int32_t depth = (extent.depth >> mip_level) ? extent.depth >> mip_level : 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600897 return Image::extent(width, height, depth);
898}
899
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600900inline VkShaderModuleCreateInfo ShaderModule::create_info(size_t code_size, const uint32_t *code, VkFlags flags) {
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600901 VkShaderModuleCreateInfo info = {};
902 info.sType = VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO;
903 info.codeSize = code_size;
904 info.pCode = code;
905 info.flags = flags;
906 return info;
907}
908
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600909inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
910 VkDescriptorType type, uint32_t count,
911 const VkDescriptorImageInfo *image_info) {
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800912 VkWriteDescriptorSet write = {};
913 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800914 write.dstSet = set.handle();
915 write.dstBinding = binding;
916 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800917 write.descriptorCount = count;
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800918 write.descriptorType = type;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600919 write.pImageInfo = image_info;
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800920 return write;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600921}
922
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600923inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
924 VkDescriptorType type, uint32_t count,
925 const VkDescriptorBufferInfo *buffer_info) {
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600926 VkWriteDescriptorSet write = {};
927 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800928 write.dstSet = set.handle();
929 write.dstBinding = binding;
930 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800931 write.descriptorCount = count;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600932 write.descriptorType = type;
933 write.pBufferInfo = buffer_info;
934 return write;
935}
936
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600937inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
938 VkDescriptorType type, uint32_t count, const VkBufferView *buffer_views) {
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600939 VkWriteDescriptorSet write = {};
940 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800941 write.dstSet = set.handle();
942 write.dstBinding = binding;
943 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800944 write.descriptorCount = count;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600945 write.descriptorType = type;
946 write.pTexelBufferView = buffer_views;
947 return write;
948}
949
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600950inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
951 VkDescriptorType type,
952 const std::vector<VkDescriptorImageInfo> &image_info) {
953 return write_descriptor_set(set, binding, array_element, type, image_info.size(), &image_info[0]);
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600954}
955
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600956inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
957 VkDescriptorType type,
958 const std::vector<VkDescriptorBufferInfo> &buffer_info) {
959 return write_descriptor_set(set, binding, array_element, type, buffer_info.size(), &buffer_info[0]);
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600960}
961
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600962inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
963 VkDescriptorType type, const std::vector<VkBufferView> &buffer_views) {
964 return write_descriptor_set(set, binding, array_element, type, buffer_views.size(), &buffer_views[0]);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600965}
966
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600967inline VkCopyDescriptorSet Device::copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding,
968 uint32_t src_array_element, const DescriptorSet &dst_set,
969 uint32_t dst_binding, uint32_t dst_array_element, uint32_t count) {
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800970 VkCopyDescriptorSet copy = {};
971 copy.sType = VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET;
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800972 copy.srcSet = src_set.handle();
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800973 copy.srcBinding = src_binding;
974 copy.srcArrayElement = src_array_element;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800975 copy.dstSet = dst_set.handle();
976 copy.dstBinding = dst_binding;
977 copy.dstArrayElement = dst_array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800978 copy.descriptorCount = count;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600979
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800980 return copy;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600981}
982
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600983inline VkCommandBufferAllocateInfo CommandBuffer::create_info(VkCommandPool const &pool) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800984 VkCommandBufferAllocateInfo info = {};
Chia-I Wu00ce5402015-11-10 16:21:09 +0800985 info.sType = VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800986 info.commandPool = pool;
Jon Ashburnf19916e2016-01-11 13:12:43 -0700987 info.commandBufferCount = 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600988 return info;
989}
990
Petr Kraus13c98a62017-12-09 00:22:39 +0100991} // namespace vk_testing
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600992
Mark Lobodzinski64318ba2017-01-26 13:34:13 -0700993#endif // VKTESTBINDING_H