blob: 9f0baa7d3b9353dcca9fc8da94a3c78e38addab0 [file] [log] [blame]
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -06001// VK tests
2//
3// Copyright (C) 2014 LunarG, Inc.
4//
5// Permission is hereby granted, free of charge, to any person obtaining a
6// copy of this software and associated documentation files (the "Software"),
7// to deal in the Software without restriction, including without limitation
8// the rights to use, copy, modify, merge, publish, distribute, sublicense,
9// and/or sell copies of the Software, and to permit persons to whom the
10// Software is furnished to do so, subject to the following conditions:
11//
12// The above copyright notice and this permission notice shall be included
13// in all copies or substantial portions of the Software.
14//
15// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21// DEALINGS IN THE SOFTWARE.
22
23#ifndef VKTESTBINDING_H
24#define VKTESTBINDING_H
25
26#include <vector>
Chia-I Wua10be9d2015-07-03 10:13:26 +080027#include <assert.h>
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -060028
29#include "vulkan.h"
30
31namespace vk_testing {
32
33typedef void (*ErrorCallback)(const char *expr, const char *file, unsigned int line, const char *function);
34void set_error_callback(ErrorCallback callback);
35
Chia-I Wuf5fb1092015-07-03 10:32:05 +080036class PhysicalDevice;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -060037class Device;
38class Queue;
Chia-I Wuba0836f2015-07-03 10:58:57 +080039class DeviceMemory;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -060040class Fence;
41class Semaphore;
42class Event;
43class QueryPool;
44class Buffer;
45class BufferView;
46class Image;
47class ImageView;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -060048class DepthStencilView;
49class Shader;
50class Pipeline;
51class PipelineDelta;
52class Sampler;
53class DescriptorSetLayout;
Mark Lobodzinski556f7212015-04-17 14:11:39 -050054class PipelineLayout;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -060055class DescriptorSetPool;
56class DescriptorSet;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -060057class CmdBuffer;
Courtney Goeltzenleuchter902d0812015-07-10 19:50:17 -060058class CmdPool;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -060059
Courtney Goeltzenleuchter18061cd2015-06-29 15:39:26 -060060std::vector<VkLayerProperties> GetGlobalLayers();
61std::vector<VkExtensionProperties> GetGlobalExtensions();
62std::vector<VkExtensionProperties> GetGlobalExtensions(const char *pLayerName);
63
Chia-I Wua10be9d2015-07-03 10:13:26 +080064namespace internal {
65
66template<typename T>
67class Handle {
68public:
69 const T &handle() const { return handle_; }
70 bool initialized() const { return (handle_ != VK_NULL_HANDLE); }
71
72protected:
73 typedef T handle_type;
74
75 explicit Handle() : handle_(VK_NULL_HANDLE) {}
76 explicit Handle(T handle) : handle_(handle) {}
77
78 void init(T handle)
79 {
80 assert(!initialized());
81 handle_ = handle;
82 }
83
84private:
85 // handles are non-copyable
86 Handle(const Handle &);
87 Handle &operator=(const Handle &);
88
89 T handle_;
90};
91
92
93template<typename T>
94class NonDispHandle : public Handle<T> {
95protected:
96 explicit NonDispHandle() : Handle<T>(), dev_handle_(VK_NULL_HANDLE) {}
97 explicit NonDispHandle(VkDevice dev, T handle) : Handle<T>(handle), dev_handle_(dev) {}
98
99 const VkDevice &device() const { return dev_handle_; }
100
101 void init(VkDevice dev, T handle)
102 {
103 assert(!Handle<T>::initialized() && dev_handle_ == VK_NULL_HANDLE);
104 Handle<T>::init(handle);
105 dev_handle_ = dev;
106 }
107
108private:
109 VkDevice dev_handle_;
110};
111
112} // namespace internal
113
Chia-I Wuf5fb1092015-07-03 10:32:05 +0800114class PhysicalDevice : public internal::Handle<VkPhysicalDevice> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600115public:
Chia-I Wuf5fb1092015-07-03 10:32:05 +0800116 explicit PhysicalDevice(VkPhysicalDevice phy) : Handle(phy)
Mark Lobodzinski72346292015-07-02 16:49:40 -0600117 {
118 memory_properties_ = memory_properties();
Mark Lobodzinskiddaecf82015-09-22 09:33:21 -0600119 device_properties_ = properties();
Mark Lobodzinski72346292015-07-02 16:49:40 -0600120 }
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600121
Mark Lobodzinskiddaecf82015-09-22 09:33:21 -0600122
Tony Barbour8205d902015-04-16 15:59:00 -0600123 VkPhysicalDeviceProperties properties() const;
Tony Barbour8205d902015-04-16 15:59:00 -0600124 VkPhysicalDeviceMemoryProperties memory_properties() const;
Cody Northropef72e2a2015-08-03 17:04:53 -0600125 std::vector<VkQueueFamilyProperties> queue_properties() const;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600126
Courtney Goeltzenleuchter37a43a62015-10-22 11:03:31 -0600127 bool set_memory_type(const uint32_t type_bits, VkMemoryAllocInfo *info, const VkMemoryPropertyFlags properties,
Mike Stroyand72da752015-08-04 10:49:29 -0600128 const VkMemoryPropertyFlags forbid = 0) const;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600129
Courtney Goeltzenleuchter74c4ce92015-09-14 17:22:16 -0600130 // vkEnumerateDeviceExtensionProperties()
Courtney Goeltzenleuchter1c7c65d2015-06-10 17:39:03 -0600131 std::vector<VkExtensionProperties> extensions() const;
Courtney Goeltzenleuchter18061cd2015-06-29 15:39:26 -0600132 std::vector<VkExtensionProperties> extensions(const char * pLayerName) const;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600133
134 // vkEnumerateLayers()
Courtney Goeltzenleuchterf5c61952015-07-06 09:10:47 -0600135 std::vector<VkLayerProperties> layers() const;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600136
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600137private:
Courtney Goeltzenleuchter1c7c65d2015-06-10 17:39:03 -0600138 void add_extension_dependencies(uint32_t dependency_count,
139 VkExtensionProperties *depencency_props,
140 std::vector<VkExtensionProperties> &ext_list);
Chia-I Wuf5fb1092015-07-03 10:32:05 +0800141
Mark Lobodzinski72346292015-07-02 16:49:40 -0600142 VkPhysicalDeviceMemoryProperties memory_properties_;
Mark Lobodzinskiddaecf82015-09-22 09:33:21 -0600143
144 VkPhysicalDeviceProperties device_properties_;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600145};
146
Chia-I Wua2636292015-07-03 10:41:20 +0800147class Device : public internal::Handle<VkDevice> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600148public:
Chia-I Wuf5fb1092015-07-03 10:32:05 +0800149 explicit Device(VkPhysicalDevice phy) : phy_(phy) {}
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600150 ~Device();
151
152 // vkCreateDevice()
Courtney Goeltzenleuchterddcb6192015-04-14 18:48:46 -0600153 void init(const VkDeviceCreateInfo &info);
Courtney Goeltzenleuchter61414de2015-07-07 11:47:33 -0600154 void init(std::vector<const char*> &layers, std::vector<const char *> &extensions); // all queues, all extensions, etc
155 void init() { std::vector<const char *> layers; std::vector<const char *> extensions; init(layers, extensions); };
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600156
Chia-I Wuf5fb1092015-07-03 10:32:05 +0800157 const PhysicalDevice &phy() const { return phy_; }
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600158
Jon Ashburn1245cec2015-05-18 13:20:15 -0600159 // vkGetDeviceProcAddr()
Courtney Goeltzenleuchtera4c8c712015-07-12 14:35:22 -0600160 PFN_vkVoidFunction get_proc(const char *name) const { return vkGetDeviceProcAddr(handle(), name); }
Jon Ashburn1245cec2015-05-18 13:20:15 -0600161
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600162 // vkGetDeviceQueue()
Mark Lobodzinskicf26e072015-04-16 11:44:05 -0500163 const std::vector<Queue *> &graphics_queues() const { return queues_[GRAPHICS]; }
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600164 const std::vector<Queue *> &compute_queues() { return queues_[COMPUTE]; }
165 const std::vector<Queue *> &dma_queues() { return queues_[DMA]; }
166 uint32_t graphics_queue_node_index_;
167
168 struct Format {
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600169 VkFormat format;
170 VkImageTiling tiling;
171 VkFlags features;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600172 };
173 // vkGetFormatInfo()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600174 VkFormatProperties format_properties(VkFormat format);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600175 const std::vector<Format> &formats() const { return formats_; }
176
177 // vkDeviceWaitIdle()
178 void wait();
179
180 // vkWaitForFences()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600181 VkResult wait(const std::vector<const Fence *> &fences, bool wait_all, uint64_t timeout);
182 VkResult wait(const Fence &fence) { return wait(std::vector<const Fence *>(1, &fence), true, (uint64_t) -1); }
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600183
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800184 // vkUpdateDescriptorSets()
Mark Lobodzinski67b42b72015-09-07 13:59:43 -0600185 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes, const std::vector<VkCopyDescriptorSet> &copies);
186 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes) { return update_descriptor_sets(writes, std::vector<VkCopyDescriptorSet>()); }
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800187
188 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
Courtney Goeltzenleuchter34aa5c82015-10-23 13:38:14 -0600189 VkDescriptorType type, uint32_t count, const VkDescriptorImageInfo *image_info);
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800190 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
Courtney Goeltzenleuchter34aa5c82015-10-23 13:38:14 -0600191 VkDescriptorType type, uint32_t count, const VkDescriptorBufferInfo *buffer_info);
192 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
193 VkDescriptorType type, uint32_t count, const VkBufferView *buffer_views);
194 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
195 VkDescriptorType type, const std::vector<VkDescriptorImageInfo> &image_info);
196 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
197 VkDescriptorType type, const std::vector<VkDescriptorBufferInfo> &buffer_info);
198 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
199 VkDescriptorType type, const std::vector<VkBufferView> &buffer_views);
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800200
201 static VkCopyDescriptorSet copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding, uint32_t src_array_element,
202 const DescriptorSet &dst_set, uint32_t dst_binding, uint32_t dst_array_element,
203 uint32_t count);
204
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600205private:
206 enum QueueIndex {
207 GRAPHICS,
208 COMPUTE,
209 DMA,
210 QUEUE_COUNT,
211 };
212
213 void init_queues();
214 void init_formats();
215
Chia-I Wuf5fb1092015-07-03 10:32:05 +0800216 PhysicalDevice phy_;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600217
218 std::vector<Queue *> queues_[QUEUE_COUNT];
219 std::vector<Format> formats_;
220};
221
Chia-I Wuf2862c72015-07-03 10:53:18 +0800222class Queue : public internal::Handle<VkQueue> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600223public:
Tony Barbour0caa94f2015-07-23 10:35:30 -0600224 explicit Queue(VkQueue queue, int index) : Handle(queue) {family_index_ = index;}
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600225
226 // vkQueueSubmit()
227 void submit(const std::vector<const CmdBuffer *> &cmds, Fence &fence);
228 void submit(const CmdBuffer &cmd, Fence &fence);
229 void submit(const CmdBuffer &cmd);
230
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600231 // vkQueueWaitIdle()
232 void wait();
233
234 // vkQueueSignalSemaphore()
235 // vkQueueWaitSemaphore()
236 void signal_semaphore(Semaphore &sem);
237 void wait_semaphore(Semaphore &sem);
Tony Barbour0caa94f2015-07-23 10:35:30 -0600238
239 int get_family_index() {return family_index_;}
240
241private:
242 int family_index_;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600243};
244
Chia-I Wuba0836f2015-07-03 10:58:57 +0800245class DeviceMemory : public internal::NonDispHandle<VkDeviceMemory> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600246public:
Chia-I Wuba0836f2015-07-03 10:58:57 +0800247 ~DeviceMemory();
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600248
249 // vkAllocMemory()
Courtney Goeltzenleuchterddcb6192015-04-14 18:48:46 -0600250 void init(const Device &dev, const VkMemoryAllocInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600251
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600252 // vkMapMemory()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600253 const void *map(VkFlags flags) const;
254 void *map(VkFlags flags);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600255 const void *map() const { return map(0); }
256 void *map() { return map(0); }
257
258 // vkUnmapMemory()
259 void unmap() const;
260
Chia-I Wuba0836f2015-07-03 10:58:57 +0800261 static VkMemoryAllocInfo alloc_info(VkDeviceSize size, uint32_t memory_type_index);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600262};
263
Chia-I Wua4992342015-07-03 11:45:55 +0800264class Fence : public internal::NonDispHandle<VkFence> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600265public:
Chia-I Wua4992342015-07-03 11:45:55 +0800266 ~Fence();
267
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600268 // vkCreateFence()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600269 void init(const Device &dev, const VkFenceCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600270
271 // vkGetFenceStatus()
Chia-I Wua4992342015-07-03 11:45:55 +0800272 VkResult status() const { return vkGetFenceStatus(device(), handle()); }
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600273
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600274 static VkFenceCreateInfo create_info(VkFenceCreateFlags flags);
275 static VkFenceCreateInfo create_info();
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600276};
277
Chia-I Wu2454b922015-07-03 11:49:42 +0800278class Semaphore : public internal::NonDispHandle<VkSemaphore> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600279public:
Chia-I Wu2454b922015-07-03 11:49:42 +0800280 ~Semaphore();
281
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600282 // vkCreateSemaphore()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600283 void init(const Device &dev, const VkSemaphoreCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600284
Tony Barbour864fd382015-06-26 12:56:09 -0600285 static VkSemaphoreCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600286};
287
Chia-I Wu9b6db1d2015-07-03 11:49:42 +0800288class Event : public internal::NonDispHandle<VkEvent> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600289public:
Chia-I Wu9b6db1d2015-07-03 11:49:42 +0800290 ~Event();
291
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600292 // vkCreateEvent()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600293 void init(const Device &dev, const VkEventCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600294
295 // vkGetEventStatus()
296 // vkSetEvent()
297 // vkResetEvent()
Chia-I Wu9b6db1d2015-07-03 11:49:42 +0800298 VkResult status() const { return vkGetEventStatus(device(), handle()); }
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600299 void set();
300 void reset();
301
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600302 static VkEventCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600303};
304
Chia-I Wufd0ce992015-07-03 11:49:42 +0800305class QueryPool : public internal::NonDispHandle<VkQueryPool> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600306public:
Chia-I Wufd0ce992015-07-03 11:49:42 +0800307 ~QueryPool();
308
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600309 // vkCreateQueryPool()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600310 void init(const Device &dev, const VkQueryPoolCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600311
312 // vkGetQueryPoolResults()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600313 VkResult results(uint32_t start, uint32_t count, size_t size, void *data);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600314
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600315 static VkQueryPoolCreateInfo create_info(VkQueryType type, uint32_t slot_count);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600316};
317
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800318class Buffer : public internal::NonDispHandle<VkBuffer> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600319public:
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800320 explicit Buffer() : NonDispHandle() {}
Courtney Goeltzenleuchterddcb6192015-04-14 18:48:46 -0600321 explicit Buffer(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info); }
Tony Barbour8205d902015-04-16 15:59:00 -0600322 explicit Buffer(const Device &dev, VkDeviceSize size) { init(dev, size); }
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600323
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800324 ~Buffer();
325
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600326 // vkCreateBuffer()
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800327 void init(const Device &dev, const VkBufferCreateInfo &info, VkMemoryPropertyFlags mem_props);
328 void init(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info, 0); }
329 void init(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags mem_props) { init(dev, create_info(size, 0), mem_props); }
330 void init(const Device &dev, VkDeviceSize size) { init(dev, size, 0); }
Cody Northropd0e7d222015-06-22 14:56:14 -0600331 void init_as_src(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) { init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_SOURCE_BIT), reqs); }
332 void init_as_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) { init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_DESTINATION_BIT), reqs); }
333 void init_as_src_and_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) { init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_SOURCE_BIT | VK_BUFFER_USAGE_TRANSFER_DESTINATION_BIT), reqs); }
Courtney Goeltzenleuchterddcb6192015-04-14 18:48:46 -0600334 void init_no_mem(const Device &dev, const VkBufferCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600335
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800336 // get the internal memory
337 const DeviceMemory &memory() const { return internal_mem_; }
338 DeviceMemory &memory() { return internal_mem_; }
339
340 // vkGetObjectMemoryRequirements()
341 VkMemoryRequirements memory_requirements() const;
342
343 // vkBindObjectMemory()
344 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Mark Lobodzinskifb9f5642015-05-11 17:21:15 -0500345
Tony Barbour8205d902015-04-16 15:59:00 -0600346 static VkBufferCreateInfo create_info(VkDeviceSize size, VkFlags usage);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600347
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600348 VkBufferMemoryBarrier buffer_memory_barrier(VkFlags output_mask, VkFlags input_mask,
Tony Barbour8205d902015-04-16 15:59:00 -0600349 VkDeviceSize offset, VkDeviceSize size) const
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600350 {
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600351 VkBufferMemoryBarrier barrier = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600352 barrier.sType = VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER;
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800353 barrier.buffer = handle();
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600354 barrier.outputMask = output_mask;
355 barrier.inputMask = input_mask;
356 barrier.offset = offset;
357 barrier.size = size;
358 return barrier;
359 }
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800360
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600361private:
Courtney Goeltzenleuchterddcb6192015-04-14 18:48:46 -0600362 VkBufferCreateInfo create_info_;
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800363
364 DeviceMemory internal_mem_;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600365};
366
Chia-I Wu76ab1ff2015-07-03 11:49:42 +0800367class BufferView : public internal::NonDispHandle<VkBufferView> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600368public:
Chia-I Wu76ab1ff2015-07-03 11:49:42 +0800369 ~BufferView();
370
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600371 // vkCreateBufferView()
Courtney Goeltzenleuchterddcb6192015-04-14 18:48:46 -0600372 void init(const Device &dev, const VkBufferViewCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600373};
374
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800375class Image : public internal::NonDispHandle<VkImage> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600376public:
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800377 explicit Image() : NonDispHandle(), format_features_(0) {}
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600378 explicit Image(const Device &dev, const VkImageCreateInfo &info) : format_features_(0) { init(dev, info); }
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600379
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800380 ~Image();
381
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600382 // vkCreateImage()
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800383 void init(const Device &dev, const VkImageCreateInfo &info, VkMemoryPropertyFlags mem_props);
384 void init(const Device &dev, const VkImageCreateInfo &info) { init(dev, info, 0); }
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600385 void init_no_mem(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600386
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800387 // get the internal memory
388 const DeviceMemory &memory() const { return internal_mem_; }
389 DeviceMemory &memory() { return internal_mem_; }
390
391 // vkGetObjectMemoryRequirements()
392 VkMemoryRequirements memory_requirements() const;
393
394 // vkBindObjectMemory()
395 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600396
Tony Barbour426b9052015-06-24 16:06:58 -0600397 // vkGetImageSubresourceLayout()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600398 VkSubresourceLayout subresource_layout(const VkImageSubresource &subres) const;
Courtney Goeltzenleuchterbd7f5922015-09-10 16:41:13 -0600399 VkSubresourceLayout subresource_layout(const VkImageSubresourceCopy &subres) const;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600400
401 bool transparent() const;
Tony Barbour8205d902015-04-16 15:59:00 -0600402 bool copyable() const { return (format_features_ & VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT); }
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600403
Courtney Goeltzenleuchterba11ebe2015-10-21 17:00:51 -0600404 VkImageSubresourceRange subresource_range(VkImageAspectFlagBits aspect) const { return subresource_range(create_info_, aspect); }
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600405 VkExtent3D extent() const { return create_info_.extent; }
406 VkExtent3D extent(uint32_t mip_level) const { return extent(create_info_.extent, mip_level); }
407 VkFormat format() const {return create_info_.format;}
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600408
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600409 VkImageMemoryBarrier image_memory_barrier(VkFlags output_mask, VkFlags input_mask,
410 VkImageLayout old_layout,
411 VkImageLayout new_layout,
412 const VkImageSubresourceRange &range) const
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600413 {
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600414 VkImageMemoryBarrier barrier = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600415 barrier.sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER;
416 barrier.outputMask = output_mask;
417 barrier.inputMask = input_mask;
418 barrier.oldLayout = old_layout;
419 barrier.newLayout = new_layout;
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800420 barrier.image = handle();
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600421 barrier.subresourceRange = range;
422 return barrier;
423 }
424
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600425 static VkImageCreateInfo create_info();
Courtney Goeltzenleuchterba11ebe2015-10-21 17:00:51 -0600426 static VkImageAspectFlagBits image_aspect(VkImageAspectFlags flags);
427 static VkImageSubresource subresource(VkImageAspectFlagBits aspect, uint32_t mip_level, uint32_t array_layer);
Courtney Goeltzenleuchter3dee8082015-09-10 16:38:41 -0600428 static VkImageSubresource subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer);
Courtney Goeltzenleuchterba11ebe2015-10-21 17:00:51 -0600429 static VkImageSubresourceCopy subresource(VkImageAspectFlagBits aspect, uint32_t mip_level, uint32_t array_layer, uint32_t array_size);
Courtney Goeltzenleuchterbd7f5922015-09-10 16:41:13 -0600430 static VkImageSubresourceCopy subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer, uint32_t array_size);
Courtney Goeltzenleuchteraeffeae2015-09-10 17:58:54 -0600431 static VkImageSubresourceRange subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level, uint32_t mip_levels,
Courtney Goeltzenleuchter63f0ead2015-10-16 09:46:00 -0600432 uint32_t base_array_layer, uint32_t num_layers);
Courtney Goeltzenleuchteraeffeae2015-09-10 17:58:54 -0600433 static VkImageSubresourceRange subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask);
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600434 static VkImageSubresourceRange subresource_range(const VkImageSubresource &subres);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600435
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600436 static VkExtent2D extent(int32_t width, int32_t height);
437 static VkExtent2D extent(const VkExtent2D &extent, uint32_t mip_level);
438 static VkExtent2D extent(const VkExtent3D &extent);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600439
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600440 static VkExtent3D extent(int32_t width, int32_t height, int32_t depth);
441 static VkExtent3D extent(const VkExtent3D &extent, uint32_t mip_level);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600442
443private:
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600444 void init_info(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600445
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600446 VkImageCreateInfo create_info_;
447 VkFlags format_features_;
Chia-I Wuf4aed6c2015-07-03 13:44:34 +0800448
449 DeviceMemory internal_mem_;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600450};
451
Chia-I Wu76ab1ff2015-07-03 11:49:42 +0800452class ImageView : public internal::NonDispHandle<VkImageView> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600453public:
Chia-I Wu76ab1ff2015-07-03 11:49:42 +0800454 ~ImageView();
455
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600456 // vkCreateImageView()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600457 void init(const Device &dev, const VkImageViewCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600458};
459
Chia-I Wub48eddb2015-07-03 11:49:42 +0800460class ShaderModule : public internal::NonDispHandle<VkShaderModule> {
Courtney Goeltzenleuchter2d034fd2015-06-28 13:01:17 -0600461public:
Chia-I Wub48eddb2015-07-03 11:49:42 +0800462 ~ShaderModule();
463
Courtney Goeltzenleuchter2d034fd2015-06-28 13:01:17 -0600464 // vkCreateShaderModule()
465 void init(const Device &dev, const VkShaderModuleCreateInfo &info);
466 VkResult init_try(const Device &dev, const VkShaderModuleCreateInfo &info);
467
468 static VkShaderModuleCreateInfo create_info(size_t code_size, const void *code, VkFlags flags);
469};
470
Chia-I Wub48eddb2015-07-03 11:49:42 +0800471class Shader : public internal::NonDispHandle<VkShader> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600472public:
Chia-I Wub48eddb2015-07-03 11:49:42 +0800473 ~Shader();
474
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600475 // vkCreateShader()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600476 void init(const Device &dev, const VkShaderCreateInfo &info);
477 VkResult init_try(const Device &dev, const VkShaderCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600478
Courtney Goeltzenleuchter8e2f0972015-10-21 17:08:06 -0600479 static VkShaderCreateInfo create_info(VkShaderModule module, const char *pName, VkFlags flags, VkShaderStageFlagBits stage);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600480};
481
Chia-I Wu2b1d4d02015-07-03 11:49:42 +0800482class Pipeline : public internal::NonDispHandle<VkPipeline> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600483public:
Chia-I Wu2b1d4d02015-07-03 11:49:42 +0800484 ~Pipeline();
485
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600486 // vkCreateGraphicsPipeline()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600487 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600488 // vkCreateGraphicsPipelineDerivative()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600489 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info, const VkPipeline basePipeline);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600490 // vkCreateComputePipeline()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600491 void init(const Device &dev, const VkComputePipelineCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600492 // vkLoadPipeline()
493 void init(const Device&dev, size_t size, const void *data);
494 // vkLoadPipelineDerivative()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600495 void init(const Device&dev, size_t size, const void *data, VkPipeline basePipeline);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600496
Chris Forbesdc2188c2015-05-25 11:13:26 +1200497 // vkCreateGraphicsPipeline with error return
498 VkResult init_try(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
499
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600500 // vkStorePipeline()
501 size_t store(size_t size, void *data);
502};
503
Chia-I Wudeb99132015-07-03 11:49:42 +0800504class PipelineLayout : public internal::NonDispHandle<VkPipelineLayout> {
505public:
506 ~PipelineLayout();
507
508 // vCreatePipelineLayout()
509 void init(const Device &dev, VkPipelineLayoutCreateInfo &info, const std::vector<const DescriptorSetLayout *> &layouts);
510};
511
Chia-I Wu6abe35d2015-07-03 11:49:42 +0800512class Sampler : public internal::NonDispHandle<VkSampler> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600513public:
Chia-I Wu6abe35d2015-07-03 11:49:42 +0800514 ~Sampler();
515
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600516 // vkCreateSampler()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600517 void init(const Device &dev, const VkSamplerCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600518};
519
Chia-I Wu55a871f2015-07-03 11:49:42 +0800520class DescriptorSetLayout : public internal::NonDispHandle<VkDescriptorSetLayout> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600521public:
Chia-I Wu55a871f2015-07-03 11:49:42 +0800522 ~DescriptorSetLayout();
523
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600524 // vkCreateDescriptorSetLayout()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600525 void init(const Device &dev, const VkDescriptorSetLayoutCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600526};
527
Chia-I Wu55a871f2015-07-03 11:49:42 +0800528class DescriptorPool : public internal::NonDispHandle<VkDescriptorPool> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600529public:
Chia-I Wu55a871f2015-07-03 11:49:42 +0800530 ~DescriptorPool();
531
Cody Northrop35ce7e62015-10-08 11:39:25 -0600532 // Descriptor sets allocated from this pool will need access to the original object
533 VkDescriptorPool GetObj() { return pool_; }
534
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600535 // vkCreateDescriptorPool()
Courtney Goeltzenleuchterd9e966a2015-09-16 16:12:45 -0600536 void init(const Device &dev, const VkDescriptorPoolCreateInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600537
538 // vkResetDescriptorPool()
539 void reset();
540
Cody Northrop35ce7e62015-10-08 11:39:25 -0600541 // vkFreeDescriptorSet()
542 void setDynamicUsage(bool isDynamic) { dynamic_usage_ = isDynamic; }
543 bool getDynamicUsage() { return dynamic_usage_; }
544
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600545 // vkAllocDescriptorSets()
Courtney Goeltzenleuchter831c1832015-10-23 14:21:05 -0600546 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const std::vector<const DescriptorSetLayout *> &layouts);
547 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const DescriptorSetLayout &layout, uint32_t count);
548 DescriptorSet *alloc_sets(const Device &dev, const DescriptorSetLayout &layout);
Cody Northrop35ce7e62015-10-08 11:39:25 -0600549
550private:
551 VkDescriptorPool pool_;
552
553 // Track whether this pool's usage is VK_DESCRIPTOR_POOL_USAGE_DYNAMIC
554 bool dynamic_usage_;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600555};
556
Chia-I Wu55a871f2015-07-03 11:49:42 +0800557class DescriptorSet : public internal::NonDispHandle<VkDescriptorSet> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600558public:
Chia-I Wu55a871f2015-07-03 11:49:42 +0800559 ~DescriptorSet();
560
561 explicit DescriptorSet() : NonDispHandle() {}
Cody Northrop35ce7e62015-10-08 11:39:25 -0600562 explicit DescriptorSet(const Device &dev, DescriptorPool* pool, VkDescriptorSet set) : NonDispHandle(dev.handle(), set) { containing_pool_ = pool;}
Tony Barboure84a8d62015-07-10 14:10:27 -0600563
564private:
Cody Northrop35ce7e62015-10-08 11:39:25 -0600565 DescriptorPool* containing_pool_;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600566};
567
Courtney Goeltzenleuchter902d0812015-07-10 19:50:17 -0600568class CmdPool : public internal::NonDispHandle<VkCmdPool> {
569public:
570 ~CmdPool();
571
572 explicit CmdPool() : NonDispHandle() {}
573 explicit CmdPool(const Device &dev, const VkCmdPoolCreateInfo &info) { init(dev, info); }
574
Courtney Goeltzenleuchter902d0812015-07-10 19:50:17 -0600575 void init(const Device &dev, const VkCmdPoolCreateInfo &info);
576
577 static VkCmdPoolCreateInfo create_info(uint32_t queue_family_index);
578};
579
580inline VkCmdPoolCreateInfo CmdPool::create_info(uint32_t queue_family_index)
581{
582 VkCmdPoolCreateInfo info = {};
Tony Barbour73c22f42015-07-27 09:36:24 -0600583 info.sType = VK_STRUCTURE_TYPE_CMD_POOL_CREATE_INFO;
Courtney Goeltzenleuchter902d0812015-07-10 19:50:17 -0600584 info.queueFamilyIndex = queue_family_index;
585 return info;
586}
587
Chia-I Wu78c2a352015-07-03 11:49:42 +0800588class CmdBuffer : public internal::Handle<VkCmdBuffer> {
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600589public:
Chia-I Wu78c2a352015-07-03 11:49:42 +0800590 ~CmdBuffer();
591
592 explicit CmdBuffer() : Handle() {}
Courtney Goeltzenleuchter831c1832015-10-23 14:21:05 -0600593 explicit CmdBuffer(const Device &dev, const VkCmdBufferAllocInfo &info) { init(dev, info); }
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600594
Courtney Goeltzenleuchter831c1832015-10-23 14:21:05 -0600595 // vkAllocCommandBuffers()
596 void init(const Device &dev, const VkCmdBufferAllocInfo &info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600597
598 // vkBeginCommandBuffer()
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600599 void begin(const VkCmdBufferBeginInfo *info);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600600 void begin();
601
602 // vkEndCommandBuffer()
603 // vkResetCommandBuffer()
604 void end();
Cody Northropf02f9f82015-07-09 18:08:05 -0600605 void reset(VkCmdBufferResetFlags flags);
Courtney Goeltzenleuchterb88d01e2015-09-11 11:40:48 -0600606 void reset() { reset(VK_CMD_BUFFER_RESET_RELEASE_RESOURCES_BIT); }
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600607
Courtney Goeltzenleuchter831c1832015-10-23 14:21:05 -0600608 static VkCmdBufferAllocInfo create_info(VkCmdPool const &pool);
Chia-I Wu78c2a352015-07-03 11:49:42 +0800609
610private:
611 VkDevice dev_handle_;
Courtney Goeltzenleuchter831c1832015-10-23 14:21:05 -0600612 VkCmdPool cmd_pool_;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600613};
614
Chia-I Wuba0836f2015-07-03 10:58:57 +0800615inline VkMemoryAllocInfo DeviceMemory::alloc_info(VkDeviceSize size, uint32_t memory_type_index)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600616{
Courtney Goeltzenleuchterddcb6192015-04-14 18:48:46 -0600617 VkMemoryAllocInfo info = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600618 info.sType = VK_STRUCTURE_TYPE_MEMORY_ALLOC_INFO;
Chia-I Wuba0836f2015-07-03 10:58:57 +0800619 info.allocationSize = size;
620 info.memoryTypeIndex = memory_type_index;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600621 return info;
622}
623
Tony Barbour8205d902015-04-16 15:59:00 -0600624inline VkBufferCreateInfo Buffer::create_info(VkDeviceSize size, VkFlags usage)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600625{
Courtney Goeltzenleuchterddcb6192015-04-14 18:48:46 -0600626 VkBufferCreateInfo info = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600627 info.sType = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO;
628 info.size = size;
629 info.usage = usage;
630 return info;
631}
632
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600633inline VkFenceCreateInfo Fence::create_info(VkFenceCreateFlags flags)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600634{
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600635 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600636 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
637 info.flags = flags;
638 return info;
639}
640
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600641inline VkFenceCreateInfo Fence::create_info()
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600642{
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600643 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600644 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
645 return info;
646}
647
Tony Barbour864fd382015-06-26 12:56:09 -0600648inline VkSemaphoreCreateInfo Semaphore::create_info(VkFlags flags)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600649{
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600650 VkSemaphoreCreateInfo info = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600651 info.sType = VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600652 info.flags = flags;
653 return info;
654}
655
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600656inline VkEventCreateInfo Event::create_info(VkFlags flags)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600657{
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600658 VkEventCreateInfo info = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600659 info.sType = VK_STRUCTURE_TYPE_EVENT_CREATE_INFO;
660 info.flags = flags;
661 return info;
662}
663
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600664inline VkQueryPoolCreateInfo QueryPool::create_info(VkQueryType type, uint32_t slot_count)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600665{
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600666 VkQueryPoolCreateInfo info = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600667 info.sType = VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO;
668 info.queryType = type;
669 info.slots = slot_count;
670 return info;
671}
672
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600673inline VkImageCreateInfo Image::create_info()
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600674{
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600675 VkImageCreateInfo info = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600676 info.sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO;
677 info.extent.width = 1;
678 info.extent.height = 1;
679 info.extent.depth = 1;
680 info.mipLevels = 1;
Courtney Goeltzenleuchter2ebc2342015-10-21 17:57:31 -0600681 info.arrayLayers = 1;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600682 info.samples = 1;
683 return info;
684}
685
Courtney Goeltzenleuchterba11ebe2015-10-21 17:00:51 -0600686inline VkImageSubresource Image::subresource(VkImageAspectFlagBits aspect, uint32_t mip_level, uint32_t array_layer)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600687{
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600688 VkImageSubresource subres = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600689 subres.aspect = aspect;
690 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter3dee8082015-09-10 16:38:41 -0600691 subres.arrayLayer = array_layer;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600692 return subres;
693}
694
Courtney Goeltzenleuchter3dee8082015-09-10 16:38:41 -0600695inline VkImageSubresource Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600696{
Courtney Goeltzenleuchteraeffeae2015-09-10 17:58:54 -0600697 return subresource(image_aspect(range.aspectMask), range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600698}
699
Courtney Goeltzenleuchterba11ebe2015-10-21 17:00:51 -0600700inline VkImageSubresourceCopy Image::subresource(VkImageAspectFlagBits aspect, uint32_t mip_level, uint32_t array_layer, uint32_t array_size)
Courtney Goeltzenleuchterbd7f5922015-09-10 16:41:13 -0600701{
702 VkImageSubresourceCopy subres = {};
703 subres.aspect = aspect;
704 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter63f0ead2015-10-16 09:46:00 -0600705 subres.baseArrayLayer = array_layer;
706 subres.numLayers = array_size;
Courtney Goeltzenleuchterbd7f5922015-09-10 16:41:13 -0600707 return subres;
708}
709
Courtney Goeltzenleuchterba11ebe2015-10-21 17:00:51 -0600710inline VkImageAspectFlagBits Image::image_aspect(VkImageAspectFlags flags)
Courtney Goeltzenleuchterbd7f5922015-09-10 16:41:13 -0600711{
Courtney Goeltzenleuchteraeffeae2015-09-10 17:58:54 -0600712 /*
713 * This will map VkImageAspectFlags into a single VkImageAspect.
714 * If there is more than one bit defined we'll get an assertion.
715 */
716 switch (flags) {
717 case VK_IMAGE_ASPECT_COLOR_BIT:
Courtney Goeltzenleuchterba11ebe2015-10-21 17:00:51 -0600718 return VK_IMAGE_ASPECT_COLOR_BIT;
Courtney Goeltzenleuchteraeffeae2015-09-10 17:58:54 -0600719 case VK_IMAGE_ASPECT_DEPTH_BIT:
Courtney Goeltzenleuchterba11ebe2015-10-21 17:00:51 -0600720 return VK_IMAGE_ASPECT_DEPTH_BIT;
Courtney Goeltzenleuchteraeffeae2015-09-10 17:58:54 -0600721 case VK_IMAGE_ASPECT_STENCIL_BIT:
Courtney Goeltzenleuchterba11ebe2015-10-21 17:00:51 -0600722 return VK_IMAGE_ASPECT_STENCIL_BIT;
Courtney Goeltzenleuchteraeffeae2015-09-10 17:58:54 -0600723 case VK_IMAGE_ASPECT_METADATA_BIT:
Courtney Goeltzenleuchterba11ebe2015-10-21 17:00:51 -0600724 return VK_IMAGE_ASPECT_METADATA_BIT;
Courtney Goeltzenleuchteraeffeae2015-09-10 17:58:54 -0600725 default:
726 assert(!"Invalid VkImageAspect");
727 }
Courtney Goeltzenleuchterba11ebe2015-10-21 17:00:51 -0600728 return VK_IMAGE_ASPECT_COLOR_BIT;
Courtney Goeltzenleuchterbd7f5922015-09-10 16:41:13 -0600729}
730
Courtney Goeltzenleuchteraeffeae2015-09-10 17:58:54 -0600731inline VkImageSubresourceCopy Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer, uint32_t array_size)
732{
733 return subresource(image_aspect(range.aspectMask), range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer, array_size);
734}
735
736inline VkImageSubresourceRange Image::subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level, uint32_t mip_levels,
Courtney Goeltzenleuchter63f0ead2015-10-16 09:46:00 -0600737 uint32_t base_array_layer, uint32_t num_layers)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600738{
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600739 VkImageSubresourceRange range = {};
Courtney Goeltzenleuchteraeffeae2015-09-10 17:58:54 -0600740 range.aspectMask = aspect_mask;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600741 range.baseMipLevel = base_mip_level;
Courtney Goeltzenleuchter63f0ead2015-10-16 09:46:00 -0600742 range.numLevels = mip_levels;
Courtney Goeltzenleuchter3dee8082015-09-10 16:38:41 -0600743 range.baseArrayLayer = base_array_layer;
Courtney Goeltzenleuchter63f0ead2015-10-16 09:46:00 -0600744 range.numLayers = num_layers;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600745 return range;
746}
747
Courtney Goeltzenleuchteraeffeae2015-09-10 17:58:54 -0600748inline VkImageSubresourceRange Image::subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600749{
Courtney Goeltzenleuchter2ebc2342015-10-21 17:57:31 -0600750 return subresource_range(aspect_mask, 0, info.mipLevels, 0, info.arrayLayers);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600751}
752
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600753inline VkImageSubresourceRange Image::subresource_range(const VkImageSubresource &subres)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600754{
Courtney Goeltzenleuchter3dee8082015-09-10 16:38:41 -0600755 return subresource_range(subres.aspect, subres.mipLevel, 1, subres.arrayLayer, 1);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600756}
757
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600758inline VkExtent2D Image::extent(int32_t width, int32_t height)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600759{
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600760 VkExtent2D extent = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600761 extent.width = width;
762 extent.height = height;
763 return extent;
764}
765
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600766inline VkExtent2D Image::extent(const VkExtent2D &extent, uint32_t mip_level)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600767{
768 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
769 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
770 return Image::extent(width, height);
771}
772
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600773inline VkExtent2D Image::extent(const VkExtent3D &extent)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600774{
775 return Image::extent(extent.width, extent.height);
776}
777
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600778inline VkExtent3D Image::extent(int32_t width, int32_t height, int32_t depth)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600779{
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600780 VkExtent3D extent = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600781 extent.width = width;
782 extent.height = height;
783 extent.depth = depth;
784 return extent;
785}
786
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600787inline VkExtent3D Image::extent(const VkExtent3D &extent, uint32_t mip_level)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600788{
789 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
790 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
791 const int32_t depth = (extent.depth >> mip_level) ? extent.depth >> mip_level : 1;
792 return Image::extent(width, height, depth);
793}
794
Courtney Goeltzenleuchter2d034fd2015-06-28 13:01:17 -0600795inline VkShaderModuleCreateInfo ShaderModule::create_info(size_t code_size, const void *code, VkFlags flags)
796{
797 VkShaderModuleCreateInfo info = {};
798 info.sType = VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO;
799 info.codeSize = code_size;
800 info.pCode = code;
801 info.flags = flags;
802 return info;
803}
804
Courtney Goeltzenleuchter8e2f0972015-10-21 17:08:06 -0600805inline VkShaderCreateInfo Shader::create_info(VkShaderModule module, const char *pName, VkFlags flags, VkShaderStageFlagBits stage)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600806{
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600807 VkShaderCreateInfo info = {};
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600808 info.sType = VK_STRUCTURE_TYPE_SHADER_CREATE_INFO;
Courtney Goeltzenleuchter2d034fd2015-06-28 13:01:17 -0600809 info.module = module;
810 info.pName = pName;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600811 info.flags = flags;
Cody Northrop87ae5e12015-08-24 15:11:10 -0600812 info.stage = stage;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600813 return info;
814}
815
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800816inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
Courtney Goeltzenleuchter34aa5c82015-10-23 13:38:14 -0600817 VkDescriptorType type, uint32_t count, const VkDescriptorImageInfo *image_info)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600818{
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800819 VkWriteDescriptorSet write = {};
820 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu55a871f2015-07-03 11:49:42 +0800821 write.destSet = set.handle();
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800822 write.destBinding = binding;
823 write.destArrayElement = array_element;
824 write.count = count;
825 write.descriptorType = type;
Courtney Goeltzenleuchter34aa5c82015-10-23 13:38:14 -0600826 write.pImageInfo = image_info;
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800827 return write;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600828}
829
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800830inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
Courtney Goeltzenleuchter34aa5c82015-10-23 13:38:14 -0600831 VkDescriptorType type, uint32_t count, const VkDescriptorBufferInfo *buffer_info)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600832{
Courtney Goeltzenleuchter34aa5c82015-10-23 13:38:14 -0600833 VkWriteDescriptorSet write = {};
834 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
835 write.destSet = set.handle();
836 write.destBinding = binding;
837 write.destArrayElement = array_element;
838 write.count = count;
839 write.descriptorType = type;
840 write.pBufferInfo = buffer_info;
841 return write;
842}
843
844inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
845 VkDescriptorType type, uint32_t count, const VkBufferView *buffer_views)
846{
847 VkWriteDescriptorSet write = {};
848 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
849 write.destSet = set.handle();
850 write.destBinding = binding;
851 write.destArrayElement = array_element;
852 write.count = count;
853 write.descriptorType = type;
854 write.pTexelBufferView = buffer_views;
855 return write;
856}
857
858inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
859 VkDescriptorType type, const std::vector<VkDescriptorImageInfo> &image_info)
860{
861 return write_descriptor_set(set, binding, array_element, type, image_info.size(), &image_info[0]);
862}
863
864inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
865 VkDescriptorType type, const std::vector<VkDescriptorBufferInfo> &buffer_info)
866{
867 return write_descriptor_set(set, binding, array_element, type, buffer_info.size(), &buffer_info[0]);
868}
869
870inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
871 VkDescriptorType type, const std::vector<VkBufferView> &buffer_views)
872{
873 return write_descriptor_set(set, binding, array_element, type, buffer_views.size(), &buffer_views[0]);
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600874}
875
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800876inline VkCopyDescriptorSet Device::copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding, uint32_t src_array_element,
877 const DescriptorSet &dst_set, uint32_t dst_binding, uint32_t dst_array_element,
878 uint32_t count)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600879{
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800880 VkCopyDescriptorSet copy = {};
881 copy.sType = VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET;
Chia-I Wu55a871f2015-07-03 11:49:42 +0800882 copy.srcSet = src_set.handle();
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800883 copy.srcBinding = src_binding;
884 copy.srcArrayElement = src_array_element;
Chia-I Wu55a871f2015-07-03 11:49:42 +0800885 copy.destSet = dst_set.handle();
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800886 copy.destBinding = dst_binding;
887 copy.destArrayElement = dst_array_element;
888 copy.count = count;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600889
Chia-I Wu8cd8ecd2015-05-25 16:27:55 +0800890 return copy;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600891}
892
Courtney Goeltzenleuchter831c1832015-10-23 14:21:05 -0600893inline VkCmdBufferAllocInfo CmdBuffer::create_info(VkCmdPool const &pool)
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600894{
Courtney Goeltzenleuchter831c1832015-10-23 14:21:05 -0600895 VkCmdBufferAllocInfo info = {};
896 info.sType = VK_STRUCTURE_TYPE_CMD_BUFFER_ALLOC_INFO;
Cody Northropf02f9f82015-07-09 18:08:05 -0600897 info.cmdPool = pool;
Courtney Goeltzenleuchter831c1832015-10-23 14:21:05 -0600898 info.count = 1;
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -0600899 return info;
900}
901
902}; // namespace vk_testing
903
904#endif // VKTESTBINDING_H