blob: 5fdc1aa8a4b73422d4bccaf5a4ab7b97a5d98d74 [file] [log] [blame]
Courtney Goeltzenleuchterd8e229c2015-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 Wub0ed7d42015-07-03 10:13:26 +080027#include <assert.h>
Courtney Goeltzenleuchterd8e229c2015-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 Wu999f0482015-07-03 10:32:05 +080036class PhysicalDevice;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060037class Device;
38class Queue;
Chia-I Wuf8f074f2015-07-03 10:58:57 +080039class DeviceMemory;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060040class Fence;
41class Semaphore;
42class Event;
43class QueryPool;
44class Buffer;
45class BufferView;
46class Image;
47class ImageView;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060048class DepthStencilView;
49class Shader;
50class Pipeline;
51class PipelineDelta;
52class Sampler;
53class DescriptorSetLayout;
Mark Lobodzinski0fadf5f2015-04-17 14:11:39 -050054class PipelineLayout;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060055class DescriptorSetPool;
56class DescriptorSet;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060057class CmdBuffer;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -060058class CmdPool;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060059
Courtney Goeltzenleuchter110fdf92015-06-29 15:39:26 -060060std::vector<VkLayerProperties> GetGlobalLayers();
61std::vector<VkExtensionProperties> GetGlobalExtensions();
62std::vector<VkExtensionProperties> GetGlobalExtensions(const char *pLayerName);
63
Chia-I Wub0ed7d42015-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 Wu999f0482015-07-03 10:32:05 +0800114class PhysicalDevice : public internal::Handle<VkPhysicalDevice> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600115public:
Chia-I Wu999f0482015-07-03 10:32:05 +0800116 explicit PhysicalDevice(VkPhysicalDevice phy) : Handle(phy)
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600117 {
118 memory_properties_ = memory_properties();
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600119 device_properties_ = properties();
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600120 }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600121
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600122
Tony Barbourd1c35722015-04-16 15:59:00 -0600123 VkPhysicalDeviceProperties properties() const;
Tony Barbourd1c35722015-04-16 15:59:00 -0600124 VkPhysicalDeviceMemoryProperties memory_properties() const;
Cody Northropd0802882015-08-03 17:04:53 -0600125 std::vector<VkQueueFamilyProperties> queue_properties() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600126
Courtney Goeltzenleuchter1d2f0dd2015-10-22 11:03:31 -0600127 bool set_memory_type(const uint32_t type_bits, VkMemoryAllocInfo *info, const VkMemoryPropertyFlags properties,
Mike Stroyan713b2d72015-08-04 10:49:29 -0600128 const VkMemoryPropertyFlags forbid = 0) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600129
Courtney Goeltzenleuchter35985f62015-09-14 17:22:16 -0600130 // vkEnumerateDeviceExtensionProperties()
Courtney Goeltzenleuchterf579fa62015-06-10 17:39:03 -0600131 std::vector<VkExtensionProperties> extensions() const;
Courtney Goeltzenleuchter110fdf92015-06-29 15:39:26 -0600132 std::vector<VkExtensionProperties> extensions(const char * pLayerName) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600133
134 // vkEnumerateLayers()
Courtney Goeltzenleuchtercd69eee2015-07-06 09:10:47 -0600135 std::vector<VkLayerProperties> layers() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600136
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600137private:
Courtney Goeltzenleuchterf579fa62015-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 Wu999f0482015-07-03 10:32:05 +0800141
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600142 VkPhysicalDeviceMemoryProperties memory_properties_;
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600143
144 VkPhysicalDeviceProperties device_properties_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600145};
146
Chia-I Wuf368b602015-07-03 10:41:20 +0800147class Device : public internal::Handle<VkDevice> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600148public:
Chia-I Wu999f0482015-07-03 10:32:05 +0800149 explicit Device(VkPhysicalDevice phy) : phy_(phy) {}
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600150 ~Device();
151
152 // vkCreateDevice()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600153 void init(const VkDeviceCreateInfo &info);
Courtney Goeltzenleuchter5bac6092015-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 Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600156
Chia-I Wu999f0482015-07-03 10:32:05 +0800157 const PhysicalDevice &phy() const { return phy_; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600158
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600159 // vkGetDeviceProcAddr()
Courtney Goeltzenleuchter2d3ba632015-07-12 14:35:22 -0600160 PFN_vkVoidFunction get_proc(const char *name) const { return vkGetDeviceProcAddr(handle(), name); }
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600161
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600162 // vkGetDeviceQueue()
Mark Lobodzinski40f7f402015-04-16 11:44:05 -0500163 const std::vector<Queue *> &graphics_queues() const { return queues_[GRAPHICS]; }
Courtney Goeltzenleuchterd8e229c2015-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 Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600169 VkFormat format;
170 VkImageTiling tiling;
171 VkFlags features;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600172 };
173 // vkGetFormatInfo()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600174 VkFormatProperties format_properties(VkFormat format);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600175 const std::vector<Format> &formats() const { return formats_; }
176
177 // vkDeviceWaitIdle()
178 void wait();
179
180 // vkWaitForFences()
Courtney Goeltzenleuchterfb4efc62015-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 Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600183
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800184 // vkUpdateDescriptorSets()
Mark Lobodzinski2141f652015-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 Wu9d00ed72015-05-25 16:27:55 +0800187
188 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
189 VkDescriptorType type, uint32_t count, const VkDescriptorInfo *descriptors);
190 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
191 VkDescriptorType type, const std::vector<VkDescriptorInfo> &descriptors);
192
193 static VkCopyDescriptorSet copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding, uint32_t src_array_element,
194 const DescriptorSet &dst_set, uint32_t dst_binding, uint32_t dst_array_element,
195 uint32_t count);
196
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600197private:
198 enum QueueIndex {
199 GRAPHICS,
200 COMPUTE,
201 DMA,
202 QUEUE_COUNT,
203 };
204
205 void init_queues();
206 void init_formats();
207
Chia-I Wu999f0482015-07-03 10:32:05 +0800208 PhysicalDevice phy_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600209
210 std::vector<Queue *> queues_[QUEUE_COUNT];
211 std::vector<Format> formats_;
212};
213
Chia-I Wudf12ffd2015-07-03 10:53:18 +0800214class Queue : public internal::Handle<VkQueue> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600215public:
Tony Barbourfb21ea32015-07-23 10:35:30 -0600216 explicit Queue(VkQueue queue, int index) : Handle(queue) {family_index_ = index;}
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600217
218 // vkQueueSubmit()
219 void submit(const std::vector<const CmdBuffer *> &cmds, Fence &fence);
220 void submit(const CmdBuffer &cmd, Fence &fence);
221 void submit(const CmdBuffer &cmd);
222
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600223 // vkQueueWaitIdle()
224 void wait();
225
226 // vkQueueSignalSemaphore()
227 // vkQueueWaitSemaphore()
228 void signal_semaphore(Semaphore &sem);
229 void wait_semaphore(Semaphore &sem);
Tony Barbourfb21ea32015-07-23 10:35:30 -0600230
231 int get_family_index() {return family_index_;}
232
233private:
234 int family_index_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600235};
236
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800237class DeviceMemory : public internal::NonDispHandle<VkDeviceMemory> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600238public:
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800239 ~DeviceMemory();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600240
241 // vkAllocMemory()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600242 void init(const Device &dev, const VkMemoryAllocInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600243
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600244 // vkMapMemory()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600245 const void *map(VkFlags flags) const;
246 void *map(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600247 const void *map() const { return map(0); }
248 void *map() { return map(0); }
249
250 // vkUnmapMemory()
251 void unmap() const;
252
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800253 static VkMemoryAllocInfo alloc_info(VkDeviceSize size, uint32_t memory_type_index);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600254};
255
Chia-I Wud9e8e822015-07-03 11:45:55 +0800256class Fence : public internal::NonDispHandle<VkFence> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600257public:
Chia-I Wud9e8e822015-07-03 11:45:55 +0800258 ~Fence();
259
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600260 // vkCreateFence()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600261 void init(const Device &dev, const VkFenceCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600262
263 // vkGetFenceStatus()
Chia-I Wud9e8e822015-07-03 11:45:55 +0800264 VkResult status() const { return vkGetFenceStatus(device(), handle()); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600265
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600266 static VkFenceCreateInfo create_info(VkFenceCreateFlags flags);
267 static VkFenceCreateInfo create_info();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600268};
269
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800270class Semaphore : public internal::NonDispHandle<VkSemaphore> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600271public:
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800272 ~Semaphore();
273
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600274 // vkCreateSemaphore()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600275 void init(const Device &dev, const VkSemaphoreCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600276
Tony Barbouraf892a12015-06-26 12:56:09 -0600277 static VkSemaphoreCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600278};
279
Chia-I Wuc5c97992015-07-03 11:49:42 +0800280class Event : public internal::NonDispHandle<VkEvent> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600281public:
Chia-I Wuc5c97992015-07-03 11:49:42 +0800282 ~Event();
283
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600284 // vkCreateEvent()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600285 void init(const Device &dev, const VkEventCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600286
287 // vkGetEventStatus()
288 // vkSetEvent()
289 // vkResetEvent()
Chia-I Wuc5c97992015-07-03 11:49:42 +0800290 VkResult status() const { return vkGetEventStatus(device(), handle()); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600291 void set();
292 void reset();
293
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600294 static VkEventCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600295};
296
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800297class QueryPool : public internal::NonDispHandle<VkQueryPool> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600298public:
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800299 ~QueryPool();
300
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600301 // vkCreateQueryPool()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600302 void init(const Device &dev, const VkQueryPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600303
304 // vkGetQueryPoolResults()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600305 VkResult results(uint32_t start, uint32_t count, size_t size, void *data);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600306
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600307 static VkQueryPoolCreateInfo create_info(VkQueryType type, uint32_t slot_count);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600308};
309
Chia-I Wu681d7a02015-07-03 13:44:34 +0800310class Buffer : public internal::NonDispHandle<VkBuffer> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600311public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800312 explicit Buffer() : NonDispHandle() {}
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600313 explicit Buffer(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info); }
Tony Barbourd1c35722015-04-16 15:59:00 -0600314 explicit Buffer(const Device &dev, VkDeviceSize size) { init(dev, size); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600315
Chia-I Wu681d7a02015-07-03 13:44:34 +0800316 ~Buffer();
317
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600318 // vkCreateBuffer()
Chia-I Wu681d7a02015-07-03 13:44:34 +0800319 void init(const Device &dev, const VkBufferCreateInfo &info, VkMemoryPropertyFlags mem_props);
320 void init(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info, 0); }
321 void init(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags mem_props) { init(dev, create_info(size, 0), mem_props); }
322 void init(const Device &dev, VkDeviceSize size) { init(dev, size, 0); }
Cody Northrop7fb43862015-06-22 14:56:14 -0600323 void init_as_src(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) { init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_SOURCE_BIT), reqs); }
324 void init_as_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) { init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_DESTINATION_BIT), reqs); }
325 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 Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600326 void init_no_mem(const Device &dev, const VkBufferCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600327
Chia-I Wu681d7a02015-07-03 13:44:34 +0800328 // get the internal memory
329 const DeviceMemory &memory() const { return internal_mem_; }
330 DeviceMemory &memory() { return internal_mem_; }
331
332 // vkGetObjectMemoryRequirements()
333 VkMemoryRequirements memory_requirements() const;
334
335 // vkBindObjectMemory()
336 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Mark Lobodzinski942b1722015-05-11 17:21:15 -0500337
Tony Barbourd1c35722015-04-16 15:59:00 -0600338 static VkBufferCreateInfo create_info(VkDeviceSize size, VkFlags usage);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600339
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600340 VkBufferMemoryBarrier buffer_memory_barrier(VkFlags output_mask, VkFlags input_mask,
Tony Barbourd1c35722015-04-16 15:59:00 -0600341 VkDeviceSize offset, VkDeviceSize size) const
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600342 {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600343 VkBufferMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600344 barrier.sType = VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800345 barrier.buffer = handle();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600346 barrier.outputMask = output_mask;
347 barrier.inputMask = input_mask;
348 barrier.offset = offset;
349 barrier.size = size;
350 return barrier;
351 }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800352
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600353private:
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600354 VkBufferCreateInfo create_info_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800355
356 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600357};
358
Chia-I Wu3158bf32015-07-03 11:49:42 +0800359class BufferView : public internal::NonDispHandle<VkBufferView> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600360public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800361 ~BufferView();
362
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600363 // vkCreateBufferView()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600364 void init(const Device &dev, const VkBufferViewCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600365};
366
Chia-I Wu681d7a02015-07-03 13:44:34 +0800367class Image : public internal::NonDispHandle<VkImage> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600368public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800369 explicit Image() : NonDispHandle(), format_features_(0) {}
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600370 explicit Image(const Device &dev, const VkImageCreateInfo &info) : format_features_(0) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600371
Chia-I Wu681d7a02015-07-03 13:44:34 +0800372 ~Image();
373
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600374 // vkCreateImage()
Chia-I Wu681d7a02015-07-03 13:44:34 +0800375 void init(const Device &dev, const VkImageCreateInfo &info, VkMemoryPropertyFlags mem_props);
376 void init(const Device &dev, const VkImageCreateInfo &info) { init(dev, info, 0); }
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600377 void init_no_mem(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600378
Chia-I Wu681d7a02015-07-03 13:44:34 +0800379 // get the internal memory
380 const DeviceMemory &memory() const { return internal_mem_; }
381 DeviceMemory &memory() { return internal_mem_; }
382
383 // vkGetObjectMemoryRequirements()
384 VkMemoryRequirements memory_requirements() const;
385
386 // vkBindObjectMemory()
387 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600388
Tony Barbour59a47322015-06-24 16:06:58 -0600389 // vkGetImageSubresourceLayout()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600390 VkSubresourceLayout subresource_layout(const VkImageSubresource &subres) const;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600391 VkSubresourceLayout subresource_layout(const VkImageSubresourceCopy &subres) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600392
393 bool transparent() const;
Tony Barbourd1c35722015-04-16 15:59:00 -0600394 bool copyable() const { return (format_features_ & VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600395
Courtney Goeltzenleuchter908e7672015-10-21 17:00:51 -0600396 VkImageSubresourceRange subresource_range(VkImageAspectFlagBits aspect) const { return subresource_range(create_info_, aspect); }
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600397 VkExtent3D extent() const { return create_info_.extent; }
398 VkExtent3D extent(uint32_t mip_level) const { return extent(create_info_.extent, mip_level); }
399 VkFormat format() const {return create_info_.format;}
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600400
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600401 VkImageMemoryBarrier image_memory_barrier(VkFlags output_mask, VkFlags input_mask,
402 VkImageLayout old_layout,
403 VkImageLayout new_layout,
404 const VkImageSubresourceRange &range) const
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600405 {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600406 VkImageMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600407 barrier.sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER;
408 barrier.outputMask = output_mask;
409 barrier.inputMask = input_mask;
410 barrier.oldLayout = old_layout;
411 barrier.newLayout = new_layout;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800412 barrier.image = handle();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600413 barrier.subresourceRange = range;
414 return barrier;
415 }
416
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600417 static VkImageCreateInfo create_info();
Courtney Goeltzenleuchter908e7672015-10-21 17:00:51 -0600418 static VkImageAspectFlagBits image_aspect(VkImageAspectFlags flags);
419 static VkImageSubresource subresource(VkImageAspectFlagBits aspect, uint32_t mip_level, uint32_t array_layer);
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600420 static VkImageSubresource subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer);
Courtney Goeltzenleuchter908e7672015-10-21 17:00:51 -0600421 static VkImageSubresourceCopy subresource(VkImageAspectFlagBits aspect, uint32_t mip_level, uint32_t array_layer, uint32_t array_size);
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600422 static VkImageSubresourceCopy subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer, uint32_t array_size);
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600423 static VkImageSubresourceRange subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level, uint32_t mip_levels,
Courtney Goeltzenleuchter8367ce02015-10-16 09:46:00 -0600424 uint32_t base_array_layer, uint32_t num_layers);
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600425 static VkImageSubresourceRange subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask);
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600426 static VkImageSubresourceRange subresource_range(const VkImageSubresource &subres);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600427
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600428 static VkExtent2D extent(int32_t width, int32_t height);
429 static VkExtent2D extent(const VkExtent2D &extent, uint32_t mip_level);
430 static VkExtent2D extent(const VkExtent3D &extent);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600431
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600432 static VkExtent3D extent(int32_t width, int32_t height, int32_t depth);
433 static VkExtent3D extent(const VkExtent3D &extent, uint32_t mip_level);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600434
435private:
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600436 void init_info(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600437
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600438 VkImageCreateInfo create_info_;
439 VkFlags format_features_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800440
441 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600442};
443
Chia-I Wu3158bf32015-07-03 11:49:42 +0800444class ImageView : public internal::NonDispHandle<VkImageView> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600445public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800446 ~ImageView();
447
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600448 // vkCreateImageView()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600449 void init(const Device &dev, const VkImageViewCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600450};
451
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800452class ShaderModule : public internal::NonDispHandle<VkShaderModule> {
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600453public:
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800454 ~ShaderModule();
455
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600456 // vkCreateShaderModule()
457 void init(const Device &dev, const VkShaderModuleCreateInfo &info);
458 VkResult init_try(const Device &dev, const VkShaderModuleCreateInfo &info);
459
460 static VkShaderModuleCreateInfo create_info(size_t code_size, const void *code, VkFlags flags);
461};
462
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800463class Shader : public internal::NonDispHandle<VkShader> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600464public:
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800465 ~Shader();
466
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600467 // vkCreateShader()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600468 void init(const Device &dev, const VkShaderCreateInfo &info);
469 VkResult init_try(const Device &dev, const VkShaderCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600470
Courtney Goeltzenleuchterd2635502015-10-21 17:08:06 -0600471 static VkShaderCreateInfo create_info(VkShaderModule module, const char *pName, VkFlags flags, VkShaderStageFlagBits stage);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600472};
473
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800474class Pipeline : public internal::NonDispHandle<VkPipeline> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600475public:
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800476 ~Pipeline();
477
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600478 // vkCreateGraphicsPipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600479 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600480 // vkCreateGraphicsPipelineDerivative()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600481 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info, const VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600482 // vkCreateComputePipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600483 void init(const Device &dev, const VkComputePipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600484 // vkLoadPipeline()
485 void init(const Device&dev, size_t size, const void *data);
486 // vkLoadPipelineDerivative()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600487 void init(const Device&dev, size_t size, const void *data, VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600488
Chris Forbes95292b12015-05-25 11:13:26 +1200489 // vkCreateGraphicsPipeline with error return
490 VkResult init_try(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
491
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600492 // vkStorePipeline()
493 size_t store(size_t size, void *data);
494};
495
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800496class PipelineLayout : public internal::NonDispHandle<VkPipelineLayout> {
497public:
498 ~PipelineLayout();
499
500 // vCreatePipelineLayout()
501 void init(const Device &dev, VkPipelineLayoutCreateInfo &info, const std::vector<const DescriptorSetLayout *> &layouts);
502};
503
Chia-I Wu8c721c62015-07-03 11:49:42 +0800504class Sampler : public internal::NonDispHandle<VkSampler> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600505public:
Chia-I Wu8c721c62015-07-03 11:49:42 +0800506 ~Sampler();
507
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600508 // vkCreateSampler()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600509 void init(const Device &dev, const VkSamplerCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600510};
511
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800512class DescriptorSetLayout : public internal::NonDispHandle<VkDescriptorSetLayout> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600513public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800514 ~DescriptorSetLayout();
515
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600516 // vkCreateDescriptorSetLayout()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600517 void init(const Device &dev, const VkDescriptorSetLayoutCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600518};
519
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800520class DescriptorPool : public internal::NonDispHandle<VkDescriptorPool> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600521public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800522 ~DescriptorPool();
523
Cody Northropcdc72a42015-10-08 11:39:25 -0600524 // Descriptor sets allocated from this pool will need access to the original object
525 VkDescriptorPool GetObj() { return pool_; }
526
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600527 // vkCreateDescriptorPool()
Courtney Goeltzenleuchterfe908d32015-09-16 16:12:45 -0600528 void init(const Device &dev, const VkDescriptorPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600529
530 // vkResetDescriptorPool()
531 void reset();
532
Cody Northropcdc72a42015-10-08 11:39:25 -0600533 // vkFreeDescriptorSet()
534 void setDynamicUsage(bool isDynamic) { dynamic_usage_ = isDynamic; }
535 bool getDynamicUsage() { return dynamic_usage_; }
536
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600537 // vkAllocDescriptorSets()
Courtney Goeltzenleuchterbee18a92015-10-23 14:21:05 -0600538 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const std::vector<const DescriptorSetLayout *> &layouts);
539 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const DescriptorSetLayout &layout, uint32_t count);
540 DescriptorSet *alloc_sets(const Device &dev, const DescriptorSetLayout &layout);
Cody Northropcdc72a42015-10-08 11:39:25 -0600541
542private:
543 VkDescriptorPool pool_;
544
545 // Track whether this pool's usage is VK_DESCRIPTOR_POOL_USAGE_DYNAMIC
546 bool dynamic_usage_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600547};
548
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800549class DescriptorSet : public internal::NonDispHandle<VkDescriptorSet> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600550public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800551 ~DescriptorSet();
552
553 explicit DescriptorSet() : NonDispHandle() {}
Cody Northropcdc72a42015-10-08 11:39:25 -0600554 explicit DescriptorSet(const Device &dev, DescriptorPool* pool, VkDescriptorSet set) : NonDispHandle(dev.handle(), set) { containing_pool_ = pool;}
Tony Barbour67e99152015-07-10 14:10:27 -0600555
556private:
Cody Northropcdc72a42015-10-08 11:39:25 -0600557 DescriptorPool* containing_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600558};
559
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600560class CmdPool : public internal::NonDispHandle<VkCmdPool> {
561public:
562 ~CmdPool();
563
564 explicit CmdPool() : NonDispHandle() {}
565 explicit CmdPool(const Device &dev, const VkCmdPoolCreateInfo &info) { init(dev, info); }
566
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600567 void init(const Device &dev, const VkCmdPoolCreateInfo &info);
568
569 static VkCmdPoolCreateInfo create_info(uint32_t queue_family_index);
570};
571
572inline VkCmdPoolCreateInfo CmdPool::create_info(uint32_t queue_family_index)
573{
574 VkCmdPoolCreateInfo info = {};
Tony Barboure815fd72015-07-27 09:36:24 -0600575 info.sType = VK_STRUCTURE_TYPE_CMD_POOL_CREATE_INFO;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600576 info.queueFamilyIndex = queue_family_index;
577 return info;
578}
579
Chia-I Wube2b9172015-07-03 11:49:42 +0800580class CmdBuffer : public internal::Handle<VkCmdBuffer> {
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600581public:
Chia-I Wube2b9172015-07-03 11:49:42 +0800582 ~CmdBuffer();
583
584 explicit CmdBuffer() : Handle() {}
Courtney Goeltzenleuchterbee18a92015-10-23 14:21:05 -0600585 explicit CmdBuffer(const Device &dev, const VkCmdBufferAllocInfo &info) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600586
Courtney Goeltzenleuchterbee18a92015-10-23 14:21:05 -0600587 // vkAllocCommandBuffers()
588 void init(const Device &dev, const VkCmdBufferAllocInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600589
590 // vkBeginCommandBuffer()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600591 void begin(const VkCmdBufferBeginInfo *info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600592 void begin();
593
594 // vkEndCommandBuffer()
595 // vkResetCommandBuffer()
596 void end();
Cody Northrope62183e2015-07-09 18:08:05 -0600597 void reset(VkCmdBufferResetFlags flags);
Courtney Goeltzenleuchter7b0d95d2015-09-11 11:40:48 -0600598 void reset() { reset(VK_CMD_BUFFER_RESET_RELEASE_RESOURCES_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600599
Courtney Goeltzenleuchterbee18a92015-10-23 14:21:05 -0600600 static VkCmdBufferAllocInfo create_info(VkCmdPool const &pool);
Chia-I Wube2b9172015-07-03 11:49:42 +0800601
602private:
603 VkDevice dev_handle_;
Courtney Goeltzenleuchterbee18a92015-10-23 14:21:05 -0600604 VkCmdPool cmd_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600605};
606
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800607inline VkMemoryAllocInfo DeviceMemory::alloc_info(VkDeviceSize size, uint32_t memory_type_index)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600608{
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600609 VkMemoryAllocInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600610 info.sType = VK_STRUCTURE_TYPE_MEMORY_ALLOC_INFO;
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800611 info.allocationSize = size;
612 info.memoryTypeIndex = memory_type_index;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600613 return info;
614}
615
Tony Barbourd1c35722015-04-16 15:59:00 -0600616inline VkBufferCreateInfo Buffer::create_info(VkDeviceSize size, VkFlags usage)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600617{
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600618 VkBufferCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600619 info.sType = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO;
620 info.size = size;
621 info.usage = usage;
622 return info;
623}
624
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600625inline VkFenceCreateInfo Fence::create_info(VkFenceCreateFlags flags)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600626{
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600627 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600628 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
629 info.flags = flags;
630 return info;
631}
632
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600633inline VkFenceCreateInfo Fence::create_info()
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600634{
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600635 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600636 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
637 return info;
638}
639
Tony Barbouraf892a12015-06-26 12:56:09 -0600640inline VkSemaphoreCreateInfo Semaphore::create_info(VkFlags flags)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600641{
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600642 VkSemaphoreCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600643 info.sType = VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600644 info.flags = flags;
645 return info;
646}
647
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600648inline VkEventCreateInfo Event::create_info(VkFlags flags)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600649{
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600650 VkEventCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600651 info.sType = VK_STRUCTURE_TYPE_EVENT_CREATE_INFO;
652 info.flags = flags;
653 return info;
654}
655
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600656inline VkQueryPoolCreateInfo QueryPool::create_info(VkQueryType type, uint32_t slot_count)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600657{
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600658 VkQueryPoolCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600659 info.sType = VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO;
660 info.queryType = type;
661 info.slots = slot_count;
662 return info;
663}
664
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600665inline VkImageCreateInfo Image::create_info()
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600666{
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600667 VkImageCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600668 info.sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO;
669 info.extent.width = 1;
670 info.extent.height = 1;
671 info.extent.depth = 1;
672 info.mipLevels = 1;
Courtney Goeltzenleuchter5d2aed42015-10-21 17:57:31 -0600673 info.arrayLayers = 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600674 info.samples = 1;
675 return info;
676}
677
Courtney Goeltzenleuchter908e7672015-10-21 17:00:51 -0600678inline VkImageSubresource Image::subresource(VkImageAspectFlagBits aspect, uint32_t mip_level, uint32_t array_layer)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600679{
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600680 VkImageSubresource subres = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600681 subres.aspect = aspect;
682 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600683 subres.arrayLayer = array_layer;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600684 return subres;
685}
686
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600687inline VkImageSubresource Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600688{
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600689 return subresource(image_aspect(range.aspectMask), range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600690}
691
Courtney Goeltzenleuchter908e7672015-10-21 17:00:51 -0600692inline VkImageSubresourceCopy Image::subresource(VkImageAspectFlagBits aspect, uint32_t mip_level, uint32_t array_layer, uint32_t array_size)
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600693{
694 VkImageSubresourceCopy subres = {};
695 subres.aspect = aspect;
696 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter8367ce02015-10-16 09:46:00 -0600697 subres.baseArrayLayer = array_layer;
698 subres.numLayers = array_size;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600699 return subres;
700}
701
Courtney Goeltzenleuchter908e7672015-10-21 17:00:51 -0600702inline VkImageAspectFlagBits Image::image_aspect(VkImageAspectFlags flags)
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600703{
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600704 /*
705 * This will map VkImageAspectFlags into a single VkImageAspect.
706 * If there is more than one bit defined we'll get an assertion.
707 */
708 switch (flags) {
709 case VK_IMAGE_ASPECT_COLOR_BIT:
Courtney Goeltzenleuchter908e7672015-10-21 17:00:51 -0600710 return VK_IMAGE_ASPECT_COLOR_BIT;
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600711 case VK_IMAGE_ASPECT_DEPTH_BIT:
Courtney Goeltzenleuchter908e7672015-10-21 17:00:51 -0600712 return VK_IMAGE_ASPECT_DEPTH_BIT;
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600713 case VK_IMAGE_ASPECT_STENCIL_BIT:
Courtney Goeltzenleuchter908e7672015-10-21 17:00:51 -0600714 return VK_IMAGE_ASPECT_STENCIL_BIT;
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600715 case VK_IMAGE_ASPECT_METADATA_BIT:
Courtney Goeltzenleuchter908e7672015-10-21 17:00:51 -0600716 return VK_IMAGE_ASPECT_METADATA_BIT;
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600717 default:
718 assert(!"Invalid VkImageAspect");
719 }
Courtney Goeltzenleuchter908e7672015-10-21 17:00:51 -0600720 return VK_IMAGE_ASPECT_COLOR_BIT;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600721}
722
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600723inline VkImageSubresourceCopy Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer, uint32_t array_size)
724{
725 return subresource(image_aspect(range.aspectMask), range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer, array_size);
726}
727
728inline VkImageSubresourceRange Image::subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level, uint32_t mip_levels,
Courtney Goeltzenleuchter8367ce02015-10-16 09:46:00 -0600729 uint32_t base_array_layer, uint32_t num_layers)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600730{
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600731 VkImageSubresourceRange range = {};
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600732 range.aspectMask = aspect_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600733 range.baseMipLevel = base_mip_level;
Courtney Goeltzenleuchter8367ce02015-10-16 09:46:00 -0600734 range.numLevels = mip_levels;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600735 range.baseArrayLayer = base_array_layer;
Courtney Goeltzenleuchter8367ce02015-10-16 09:46:00 -0600736 range.numLayers = num_layers;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600737 return range;
738}
739
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600740inline VkImageSubresourceRange Image::subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600741{
Courtney Goeltzenleuchter5d2aed42015-10-21 17:57:31 -0600742 return subresource_range(aspect_mask, 0, info.mipLevels, 0, info.arrayLayers);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600743}
744
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600745inline VkImageSubresourceRange Image::subresource_range(const VkImageSubresource &subres)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600746{
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600747 return subresource_range(subres.aspect, subres.mipLevel, 1, subres.arrayLayer, 1);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600748}
749
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600750inline VkExtent2D Image::extent(int32_t width, int32_t height)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600751{
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600752 VkExtent2D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600753 extent.width = width;
754 extent.height = height;
755 return extent;
756}
757
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600758inline VkExtent2D Image::extent(const VkExtent2D &extent, uint32_t mip_level)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600759{
760 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
761 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
762 return Image::extent(width, height);
763}
764
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600765inline VkExtent2D Image::extent(const VkExtent3D &extent)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600766{
767 return Image::extent(extent.width, extent.height);
768}
769
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600770inline VkExtent3D Image::extent(int32_t width, int32_t height, int32_t depth)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600771{
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600772 VkExtent3D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600773 extent.width = width;
774 extent.height = height;
775 extent.depth = depth;
776 return extent;
777}
778
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600779inline VkExtent3D Image::extent(const VkExtent3D &extent, uint32_t mip_level)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600780{
781 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
782 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
783 const int32_t depth = (extent.depth >> mip_level) ? extent.depth >> mip_level : 1;
784 return Image::extent(width, height, depth);
785}
786
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600787inline VkShaderModuleCreateInfo ShaderModule::create_info(size_t code_size, const void *code, VkFlags flags)
788{
789 VkShaderModuleCreateInfo info = {};
790 info.sType = VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO;
791 info.codeSize = code_size;
792 info.pCode = code;
793 info.flags = flags;
794 return info;
795}
796
Courtney Goeltzenleuchterd2635502015-10-21 17:08:06 -0600797inline VkShaderCreateInfo Shader::create_info(VkShaderModule module, const char *pName, VkFlags flags, VkShaderStageFlagBits stage)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600798{
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600799 VkShaderCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600800 info.sType = VK_STRUCTURE_TYPE_SHADER_CREATE_INFO;
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600801 info.module = module;
802 info.pName = pName;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600803 info.flags = flags;
Cody Northropfd4bcfd2015-08-24 15:11:10 -0600804 info.stage = stage;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600805 return info;
806}
807
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800808inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
809 VkDescriptorType type, uint32_t count, const VkDescriptorInfo *descriptors)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600810{
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800811 VkWriteDescriptorSet write = {};
812 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800813 write.destSet = set.handle();
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800814 write.destBinding = binding;
815 write.destArrayElement = array_element;
816 write.count = count;
817 write.descriptorType = type;
818 write.pDescriptors = descriptors;
819 return write;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600820}
821
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800822inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
823 VkDescriptorType type, const std::vector<VkDescriptorInfo> &descriptors)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600824{
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800825 return write_descriptor_set(set, binding, array_element, type, descriptors.size(), &descriptors[0]);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600826}
827
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800828inline VkCopyDescriptorSet Device::copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding, uint32_t src_array_element,
829 const DescriptorSet &dst_set, uint32_t dst_binding, uint32_t dst_array_element,
830 uint32_t count)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600831{
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800832 VkCopyDescriptorSet copy = {};
833 copy.sType = VK_STRUCTURE_TYPE_COPY_DESCRIPTOR_SET;
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800834 copy.srcSet = src_set.handle();
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800835 copy.srcBinding = src_binding;
836 copy.srcArrayElement = src_array_element;
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800837 copy.destSet = dst_set.handle();
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800838 copy.destBinding = dst_binding;
839 copy.destArrayElement = dst_array_element;
840 copy.count = count;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600841
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800842 return copy;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600843}
844
Courtney Goeltzenleuchterbee18a92015-10-23 14:21:05 -0600845inline VkCmdBufferAllocInfo CmdBuffer::create_info(VkCmdPool const &pool)
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600846{
Courtney Goeltzenleuchterbee18a92015-10-23 14:21:05 -0600847 VkCmdBufferAllocInfo info = {};
848 info.sType = VK_STRUCTURE_TYPE_CMD_BUFFER_ALLOC_INFO;
Cody Northrope62183e2015-07-09 18:08:05 -0600849 info.cmdPool = pool;
Courtney Goeltzenleuchterbee18a92015-10-23 14:21:05 -0600850 info.count = 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600851 return info;
852}
853
854}; // namespace vk_testing
855
856#endif // VKTESTBINDING_H