blob: 40d73c8767e6aa64476a04d27f93434eef0fe652 [file] [log] [blame]
Karl Schultz6addd812016-02-02 17:17:23 -07001/*
2 * Copyright (c) 2015-2016 The Khronos Group Inc.
3 * Copyright (c) 2015-2016 Valve Corporation
4 * Copyright (c) 2015-2016 LunarG, Inc.
5 *
Jon Ashburn3ebf1252016-04-19 11:30:31 -06006 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
Karl Schultz6addd812016-02-02 17:17:23 -07009 *
Jon Ashburn3ebf1252016-04-19 11:30:31 -060010 * http://www.apache.org/licenses/LICENSE-2.0
Karl Schultz6addd812016-02-02 17:17:23 -070011 *
Jon Ashburn3ebf1252016-04-19 11:30:31 -060012 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
Karl Schultz6addd812016-02-02 17:17:23 -070017 *
18 * Author: Courtney Goeltzenleuchter <courtney@LunarG.com>
19 * Author: Cody Northrop <cody@lunarg.com>
20 */
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060021
22#ifndef VKTESTBINDING_H
23#define VKTESTBINDING_H
24
Chia-I Wub0ed7d42015-07-03 10:13:26 +080025#include <assert.h>
Mark Lobodzinski722841d2016-09-07 16:34:56 -060026#include <vector>
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060027
David Pinedo9316d3b2015-11-06 12:54:48 -070028#include "vulkan/vulkan.h"
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060029
30namespace vk_testing {
31
Mark Lobodzinski722841d2016-09-07 16:34:56 -060032typedef void (*ErrorCallback)(const char *expr, const char *file, unsigned int line, const char *function);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060033void set_error_callback(ErrorCallback callback);
34
Chia-I Wu999f0482015-07-03 10:32:05 +080035class PhysicalDevice;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060036class Device;
37class Queue;
Chia-I Wuf8f074f2015-07-03 10:58:57 +080038class DeviceMemory;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060039class Fence;
40class Semaphore;
41class Event;
42class QueryPool;
43class Buffer;
44class BufferView;
45class Image;
46class ImageView;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060047class DepthStencilView;
48class Shader;
49class Pipeline;
50class PipelineDelta;
51class Sampler;
52class DescriptorSetLayout;
Mark Lobodzinski0fadf5f2015-04-17 14:11:39 -050053class PipelineLayout;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060054class DescriptorSetPool;
55class DescriptorSet;
Chia-I Wu3432a0c2015-10-27 18:04:07 +080056class CommandBuffer;
57class CommandPool;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -060058
Courtney Goeltzenleuchter110fdf92015-06-29 15:39:26 -060059std::vector<VkLayerProperties> GetGlobalLayers();
60std::vector<VkExtensionProperties> GetGlobalExtensions();
61std::vector<VkExtensionProperties> GetGlobalExtensions(const char *pLayerName);
62
Chia-I Wub0ed7d42015-07-03 10:13:26 +080063namespace internal {
64
Karl Schultz6addd812016-02-02 17:17:23 -070065template <typename T> class Handle {
66 public:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080067 const T &handle() const { return handle_; }
68 bool initialized() const { return (handle_ != VK_NULL_HANDLE); }
69
Karl Schultz6addd812016-02-02 17:17:23 -070070 protected:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080071 typedef T handle_type;
72
73 explicit Handle() : handle_(VK_NULL_HANDLE) {}
74 explicit Handle(T handle) : handle_(handle) {}
75
Karl Schultz6addd812016-02-02 17:17:23 -070076 void init(T handle) {
Chia-I Wub0ed7d42015-07-03 10:13:26 +080077 assert(!initialized());
78 handle_ = handle;
79 }
80
Karl Schultz6addd812016-02-02 17:17:23 -070081 private:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080082 // handles are non-copyable
83 Handle(const Handle &);
84 Handle &operator=(const Handle &);
85
86 T handle_;
87};
88
Karl Schultz6addd812016-02-02 17:17:23 -070089template <typename T> class NonDispHandle : public Handle<T> {
90 protected:
Chia-I Wub0ed7d42015-07-03 10:13:26 +080091 explicit NonDispHandle() : Handle<T>(), dev_handle_(VK_NULL_HANDLE) {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -060092 explicit NonDispHandle(VkDevice dev, T handle) : Handle<T>(handle), dev_handle_(dev) {}
Chia-I Wub0ed7d42015-07-03 10:13:26 +080093
94 const VkDevice &device() const { return dev_handle_; }
95
Karl Schultz6addd812016-02-02 17:17:23 -070096 void init(VkDevice dev, T handle) {
Chia-I Wub0ed7d42015-07-03 10:13:26 +080097 assert(!Handle<T>::initialized() && dev_handle_ == VK_NULL_HANDLE);
98 Handle<T>::init(handle);
99 dev_handle_ = dev;
100 }
101
Karl Schultz6addd812016-02-02 17:17:23 -0700102 private:
Chia-I Wub0ed7d42015-07-03 10:13:26 +0800103 VkDevice dev_handle_;
104};
105
106} // namespace internal
107
Chia-I Wu999f0482015-07-03 10:32:05 +0800108class PhysicalDevice : public internal::Handle<VkPhysicalDevice> {
Karl Schultz6addd812016-02-02 17:17:23 -0700109 public:
110 explicit PhysicalDevice(VkPhysicalDevice phy) : Handle(phy) {
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600111 memory_properties_ = memory_properties();
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600112 device_properties_ = properties();
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600113 }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600114
Tony Barbourd1c35722015-04-16 15:59:00 -0600115 VkPhysicalDeviceProperties properties() const;
Tony Barbourd1c35722015-04-16 15:59:00 -0600116 VkPhysicalDeviceMemoryProperties memory_properties() const;
Cody Northropd0802882015-08-03 17:04:53 -0600117 std::vector<VkQueueFamilyProperties> queue_properties() const;
Chris Forbesf9cfe182016-04-04 17:22:42 +1200118 VkPhysicalDeviceFeatures features() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600119
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600120 bool set_memory_type(const uint32_t type_bits, VkMemoryAllocateInfo *info, const VkMemoryPropertyFlags properties,
Karl Schultz6addd812016-02-02 17:17:23 -0700121 const VkMemoryPropertyFlags forbid = 0) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600122
Courtney Goeltzenleuchter35985f62015-09-14 17:22:16 -0600123 // vkEnumerateDeviceExtensionProperties()
Courtney Goeltzenleuchterf579fa62015-06-10 17:39:03 -0600124 std::vector<VkExtensionProperties> extensions() const;
Karl Schultz6addd812016-02-02 17:17:23 -0700125 std::vector<VkExtensionProperties> extensions(const char *pLayerName) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600126
127 // vkEnumerateLayers()
Courtney Goeltzenleuchtercd69eee2015-07-06 09:10:47 -0600128 std::vector<VkLayerProperties> layers() const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600129
Karl Schultz6addd812016-02-02 17:17:23 -0700130 private:
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600131 void add_extension_dependencies(uint32_t dependency_count, VkExtensionProperties *depencency_props,
132 std::vector<VkExtensionProperties> &ext_list);
Chia-I Wu999f0482015-07-03 10:32:05 +0800133
Mark Lobodzinskib3fbcd92015-07-02 16:49:40 -0600134 VkPhysicalDeviceMemoryProperties memory_properties_;
Mark Lobodzinski6f2274e2015-09-22 09:33:21 -0600135
136 VkPhysicalDeviceProperties device_properties_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600137};
138
Chia-I Wuf368b602015-07-03 10:41:20 +0800139class Device : public internal::Handle<VkDevice> {
Karl Schultz6addd812016-02-02 17:17:23 -0700140 public:
Chia-I Wu999f0482015-07-03 10:32:05 +0800141 explicit Device(VkPhysicalDevice phy) : phy_(phy) {}
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600142 ~Device();
143
144 // vkCreateDevice()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600145 void init(const VkDeviceCreateInfo &info);
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600146 void init(std::vector<const char *> &extensions,
147 VkPhysicalDeviceFeatures *features = nullptr); // all queues, all extensions, etc
Karl Schultz6addd812016-02-02 17:17:23 -0700148 void init() {
Karl Schultz6addd812016-02-02 17:17:23 -0700149 std::vector<const char *> extensions;
Tony Barbour4c70d102016-08-08 16:06:56 -0600150 init(extensions);
Karl Schultz6addd812016-02-02 17:17:23 -0700151 };
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600152
Chia-I Wu999f0482015-07-03 10:32:05 +0800153 const PhysicalDevice &phy() const { return phy_; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600154
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600155 // vkGetDeviceProcAddr()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600156 PFN_vkVoidFunction get_proc(const char *name) const { return vkGetDeviceProcAddr(handle(), name); }
Jon Ashburn8d1b0b52015-05-18 13:20:15 -0600157
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600158 // vkGetDeviceQueue()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600159 const std::vector<Queue *> &graphics_queues() const { return queues_[GRAPHICS]; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600160 const std::vector<Queue *> &compute_queues() { return queues_[COMPUTE]; }
161 const std::vector<Queue *> &dma_queues() { return queues_[DMA]; }
162 uint32_t graphics_queue_node_index_;
163
164 struct Format {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600165 VkFormat format;
166 VkImageTiling tiling;
167 VkFlags features;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600168 };
169 // vkGetFormatInfo()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600170 VkFormatProperties format_properties(VkFormat format);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600171 const std::vector<Format> &formats() const { return formats_; }
172
173 // vkDeviceWaitIdle()
174 void wait();
175
176 // vkWaitForFences()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600177 VkResult wait(const std::vector<const Fence *> &fences, bool wait_all, uint64_t timeout);
178 VkResult wait(const Fence &fence) { return wait(std::vector<const Fence *>(1, &fence), true, (uint64_t)-1); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600179
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800180 // vkUpdateDescriptorSets()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600181 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes, const std::vector<VkCopyDescriptorSet> &copies);
182 void update_descriptor_sets(const std::vector<VkWriteDescriptorSet> &writes) {
183 return update_descriptor_sets(writes, std::vector<VkCopyDescriptorSet>());
Karl Schultz6addd812016-02-02 17:17:23 -0700184 }
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800185
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600186 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
187 VkDescriptorType type, uint32_t count,
188 const VkDescriptorImageInfo *image_info);
189 static VkWriteDescriptorSet write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
190 VkDescriptorType type, uint32_t count,
191 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 Wu9d00ed72015-05-25 16:27:55 +0800200
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600201 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);
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800204
Karl Schultz6addd812016-02-02 17:17:23 -0700205 private:
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600206 enum QueueIndex {
207 GRAPHICS,
208 COMPUTE,
209 DMA,
210 QUEUE_COUNT,
211 };
212
213 void init_queues();
214 void init_formats();
215
Chia-I Wu999f0482015-07-03 10:32:05 +0800216 PhysicalDevice phy_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600217
218 std::vector<Queue *> queues_[QUEUE_COUNT];
219 std::vector<Format> formats_;
220};
221
Chia-I Wudf12ffd2015-07-03 10:53:18 +0800222class Queue : public internal::Handle<VkQueue> {
Karl Schultz6addd812016-02-02 17:17:23 -0700223 public:
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600224 explicit Queue(VkQueue queue, int index) : Handle(queue) { family_index_ = index; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600225
226 // vkQueueSubmit()
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800227 void submit(const std::vector<const CommandBuffer *> &cmds, Fence &fence);
228 void submit(const CommandBuffer &cmd, Fence &fence);
229 void submit(const CommandBuffer &cmd);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600230
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600231 // vkQueueWaitIdle()
232 void wait();
233
Karl Schultz6addd812016-02-02 17:17:23 -0700234 int get_family_index() { return family_index_; }
Tony Barbourfb21ea32015-07-23 10:35:30 -0600235
Karl Schultz6addd812016-02-02 17:17:23 -0700236 private:
Tony Barbourfb21ea32015-07-23 10:35:30 -0600237 int family_index_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600238};
239
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800240class DeviceMemory : public internal::NonDispHandle<VkDeviceMemory> {
Karl Schultz6addd812016-02-02 17:17:23 -0700241 public:
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800242 ~DeviceMemory();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600243
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800244 // vkAllocateMemory()
245 void init(const Device &dev, const VkMemoryAllocateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600246
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600247 // vkMapMemory()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600248 const void *map(VkFlags flags) const;
Karl Schultz6addd812016-02-02 17:17:23 -0700249 void *map(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600250 const void *map() const { return map(0); }
Karl Schultz6addd812016-02-02 17:17:23 -0700251 void *map() { return map(0); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600252
253 // vkUnmapMemory()
254 void unmap() const;
255
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600256 static VkMemoryAllocateInfo alloc_info(VkDeviceSize size, uint32_t memory_type_index);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600257};
258
Chia-I Wud9e8e822015-07-03 11:45:55 +0800259class Fence : public internal::NonDispHandle<VkFence> {
Karl Schultz6addd812016-02-02 17:17:23 -0700260 public:
Chia-I Wud9e8e822015-07-03 11:45:55 +0800261 ~Fence();
262
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600263 // vkCreateFence()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600264 void init(const Device &dev, const VkFenceCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600265
266 // vkGetFenceStatus()
Chia-I Wud9e8e822015-07-03 11:45:55 +0800267 VkResult status() const { return vkGetFenceStatus(device(), handle()); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600268
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600269 static VkFenceCreateInfo create_info(VkFenceCreateFlags flags);
270 static VkFenceCreateInfo create_info();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600271};
272
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800273class Semaphore : public internal::NonDispHandle<VkSemaphore> {
Karl Schultz6addd812016-02-02 17:17:23 -0700274 public:
Chia-I Wu6b1c2482015-07-03 11:49:42 +0800275 ~Semaphore();
276
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600277 // vkCreateSemaphore()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600278 void init(const Device &dev, const VkSemaphoreCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600279
Tony Barbouraf892a12015-06-26 12:56:09 -0600280 static VkSemaphoreCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600281};
282
Chia-I Wuc5c97992015-07-03 11:49:42 +0800283class Event : public internal::NonDispHandle<VkEvent> {
Karl Schultz6addd812016-02-02 17:17:23 -0700284 public:
Chia-I Wuc5c97992015-07-03 11:49:42 +0800285 ~Event();
286
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600287 // vkCreateEvent()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600288 void init(const Device &dev, const VkEventCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600289
290 // vkGetEventStatus()
291 // vkSetEvent()
292 // vkResetEvent()
Chia-I Wuc5c97992015-07-03 11:49:42 +0800293 VkResult status() const { return vkGetEventStatus(device(), handle()); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600294 void set();
295 void reset();
296
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600297 static VkEventCreateInfo create_info(VkFlags flags);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600298};
299
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800300class QueryPool : public internal::NonDispHandle<VkQueryPool> {
Karl Schultz6addd812016-02-02 17:17:23 -0700301 public:
Chia-I Wu1b7d4762015-07-03 11:49:42 +0800302 ~QueryPool();
303
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600304 // vkCreateQueryPool()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600305 void init(const Device &dev, const VkQueryPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600306
307 // vkGetQueryPoolResults()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600308 VkResult results(uint32_t first, uint32_t count, size_t size, void *data, size_t stride);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600309
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600310 static VkQueryPoolCreateInfo create_info(VkQueryType type, uint32_t slot_count);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600311};
312
Chia-I Wu681d7a02015-07-03 13:44:34 +0800313class Buffer : public internal::NonDispHandle<VkBuffer> {
Karl Schultz6addd812016-02-02 17:17:23 -0700314 public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800315 explicit Buffer() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600316 explicit Buffer(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info); }
Tony Barbourd1c35722015-04-16 15:59:00 -0600317 explicit Buffer(const Device &dev, VkDeviceSize size) { init(dev, size); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600318
Chia-I Wu681d7a02015-07-03 13:44:34 +0800319 ~Buffer();
320
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600321 // vkCreateBuffer()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600322 void init(const Device &dev, const VkBufferCreateInfo &info, VkMemoryPropertyFlags mem_props);
323 void init(const Device &dev, const VkBufferCreateInfo &info) { init(dev, info, 0); }
324 void init(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags mem_props) { init(dev, create_info(size, 0), mem_props); }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800325 void init(const Device &dev, VkDeviceSize size) { init(dev, size, 0); }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600326 void init_as_src(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) {
Karl Schultz6addd812016-02-02 17:17:23 -0700327 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_SRC_BIT), reqs);
328 }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600329 void init_as_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) {
Karl Schultz6addd812016-02-02 17:17:23 -0700330 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_DST_BIT), reqs);
331 }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600332 void init_as_src_and_dst(const Device &dev, VkDeviceSize size, VkMemoryPropertyFlags &reqs) {
333 init(dev, create_info(size, VK_BUFFER_USAGE_TRANSFER_SRC_BIT | VK_BUFFER_USAGE_TRANSFER_DST_BIT), reqs);
Karl Schultz6addd812016-02-02 17:17:23 -0700334 }
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600335 void init_no_mem(const Device &dev, const VkBufferCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600336
Chia-I Wu681d7a02015-07-03 13:44:34 +0800337 // get the internal memory
338 const DeviceMemory &memory() const { return internal_mem_; }
Karl Schultz6addd812016-02-02 17:17:23 -0700339 DeviceMemory &memory() { return internal_mem_; }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800340
341 // vkGetObjectMemoryRequirements()
342 VkMemoryRequirements memory_requirements() const;
343
344 // vkBindObjectMemory()
345 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Mark Lobodzinski942b1722015-05-11 17:21:15 -0500346
Tony Barbourd1c35722015-04-16 15:59:00 -0600347 static VkBufferCreateInfo create_info(VkDeviceSize size, VkFlags usage);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600348
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600349 VkBufferMemoryBarrier buffer_memory_barrier(VkFlags output_mask, VkFlags input_mask, VkDeviceSize offset,
Karl Schultz6addd812016-02-02 17:17:23 -0700350 VkDeviceSize size) const {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600351 VkBufferMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600352 barrier.sType = VK_STRUCTURE_TYPE_BUFFER_MEMORY_BARRIER;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800353 barrier.buffer = handle();
Chia-I Wua4594202015-10-27 19:54:37 +0800354 barrier.srcAccessMask = output_mask;
355 barrier.dstAccessMask = input_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600356 barrier.offset = offset;
357 barrier.size = size;
358 return barrier;
359 }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800360
Karl Schultz6addd812016-02-02 17:17:23 -0700361 private:
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600362 VkBufferCreateInfo create_info_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800363
364 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600365};
366
Chia-I Wu3158bf32015-07-03 11:49:42 +0800367class BufferView : public internal::NonDispHandle<VkBufferView> {
Karl Schultz6addd812016-02-02 17:17:23 -0700368 public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800369 ~BufferView();
370
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600371 // vkCreateBufferView()
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600372 void init(const Device &dev, const VkBufferViewCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600373};
374
Chia-I Wu681d7a02015-07-03 13:44:34 +0800375class Image : public internal::NonDispHandle<VkImage> {
Karl Schultz6addd812016-02-02 17:17:23 -0700376 public:
Chia-I Wu681d7a02015-07-03 13:44:34 +0800377 explicit Image() : NonDispHandle(), format_features_(0) {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600378 explicit Image(const Device &dev, const VkImageCreateInfo &info) : format_features_(0) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600379
Chia-I Wu681d7a02015-07-03 13:44:34 +0800380 ~Image();
381
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600382 // vkCreateImage()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600383 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 Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600385 void init_no_mem(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600386
Chia-I Wu681d7a02015-07-03 13:44:34 +0800387 // get the internal memory
388 const DeviceMemory &memory() const { return internal_mem_; }
Karl Schultz6addd812016-02-02 17:17:23 -0700389 DeviceMemory &memory() { return internal_mem_; }
Chia-I Wu681d7a02015-07-03 13:44:34 +0800390
391 // vkGetObjectMemoryRequirements()
392 VkMemoryRequirements memory_requirements() const;
393
394 // vkBindObjectMemory()
395 void bind_memory(const DeviceMemory &mem, VkDeviceSize mem_offset);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600396
Tony Barbour59a47322015-06-24 16:06:58 -0600397 // vkGetImageSubresourceLayout()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600398 VkSubresourceLayout subresource_layout(const VkImageSubresource &subres) const;
399 VkSubresourceLayout subresource_layout(const VkImageSubresourceLayers &subres) const;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600400
401 bool transparent() const;
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600402 bool copyable() const { return (format_features_ & VK_FORMAT_FEATURE_SAMPLED_IMAGE_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600403
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600404 VkImageSubresourceRange subresource_range(VkImageAspectFlagBits aspect) const {
Karl Schultz6addd812016-02-02 17:17:23 -0700405 return subresource_range(create_info_, aspect);
406 }
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600407 VkExtent3D extent() const { return create_info_.extent; }
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600408 VkExtent3D extent(uint32_t mip_level) const { return extent(create_info_.extent, mip_level); }
Karl Schultz6addd812016-02-02 17:17:23 -0700409 VkFormat format() const { return create_info_.format; }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600410
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600411 VkImageMemoryBarrier image_memory_barrier(VkFlags output_mask, VkFlags input_mask, VkImageLayout old_layout,
412 VkImageLayout new_layout, const VkImageSubresourceRange &range) const {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600413 VkImageMemoryBarrier barrier = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600414 barrier.sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER;
Chia-I Wua4594202015-10-27 19:54:37 +0800415 barrier.srcAccessMask = output_mask;
416 barrier.dstAccessMask = input_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600417 barrier.oldLayout = old_layout;
418 barrier.newLayout = new_layout;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800419 barrier.image = handle();
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600420 barrier.subresourceRange = range;
421 return barrier;
422 }
423
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600424 static VkImageCreateInfo create_info();
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600425 static VkImageSubresource subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer);
426 static VkImageSubresource subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer);
427 static VkImageSubresourceLayers subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer,
Karl Schultz6addd812016-02-02 17:17:23 -0700428 uint32_t array_size);
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600429 static VkImageSubresourceLayers subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer,
430 uint32_t array_size);
431 static VkImageSubresourceRange subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level, uint32_t mip_levels,
432 uint32_t base_array_layer, uint32_t num_layers);
433 static VkImageSubresourceRange subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask);
434 static VkImageSubresourceRange subresource_range(const VkImageSubresource &subres);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600435
Courtney Goeltzenleuchterfb4efc62015-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 Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600439
Courtney Goeltzenleuchterfb4efc62015-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 Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600442
Karl Schultz6addd812016-02-02 17:17:23 -0700443 private:
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600444 void init_info(const Device &dev, const VkImageCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600445
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600446 VkImageCreateInfo create_info_;
447 VkFlags format_features_;
Chia-I Wu681d7a02015-07-03 13:44:34 +0800448
449 DeviceMemory internal_mem_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600450};
451
Chia-I Wu3158bf32015-07-03 11:49:42 +0800452class ImageView : public internal::NonDispHandle<VkImageView> {
Karl Schultz6addd812016-02-02 17:17:23 -0700453 public:
Chia-I Wu3158bf32015-07-03 11:49:42 +0800454 ~ImageView();
455
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600456 // vkCreateImageView()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600457 void init(const Device &dev, const VkImageViewCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600458};
459
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800460class ShaderModule : public internal::NonDispHandle<VkShaderModule> {
Karl Schultz6addd812016-02-02 17:17:23 -0700461 public:
Chia-I Wu4d0c7922015-07-03 11:49:42 +0800462 ~ShaderModule();
463
Courtney Goeltzenleuchteree4027d2015-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
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600468 static VkShaderModuleCreateInfo create_info(size_t code_size, const uint32_t *code, VkFlags flags);
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600469};
470
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800471class Pipeline : public internal::NonDispHandle<VkPipeline> {
Karl Schultz6addd812016-02-02 17:17:23 -0700472 public:
Chia-I Wu2ff72fd2015-07-03 11:49:42 +0800473 ~Pipeline();
474
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600475 // vkCreateGraphicsPipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600476 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600477 // vkCreateGraphicsPipelineDerivative()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600478 void init(const Device &dev, const VkGraphicsPipelineCreateInfo &info, const VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600479 // vkCreateComputePipeline()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600480 void init(const Device &dev, const VkComputePipelineCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600481 // vkLoadPipeline()
Karl Schultz6addd812016-02-02 17:17:23 -0700482 void init(const Device &dev, size_t size, const void *data);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600483 // vkLoadPipelineDerivative()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600484 void init(const Device &dev, size_t size, const void *data, VkPipeline basePipeline);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600485
Chris Forbes95292b12015-05-25 11:13:26 +1200486 // vkCreateGraphicsPipeline with error return
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600487 VkResult init_try(const Device &dev, const VkGraphicsPipelineCreateInfo &info);
Chris Forbes95292b12015-05-25 11:13:26 +1200488
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600489 // vkStorePipeline()
490 size_t store(size_t size, void *data);
491};
492
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800493class PipelineLayout : public internal::NonDispHandle<VkPipelineLayout> {
Karl Schultz6addd812016-02-02 17:17:23 -0700494 public:
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800495 ~PipelineLayout();
496
497 // vCreatePipelineLayout()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600498 void init(const Device &dev, VkPipelineLayoutCreateInfo &info, const std::vector<const DescriptorSetLayout *> &layouts);
Chia-I Wufd46e7d2015-07-03 11:49:42 +0800499};
500
Chia-I Wu8c721c62015-07-03 11:49:42 +0800501class Sampler : public internal::NonDispHandle<VkSampler> {
Karl Schultz6addd812016-02-02 17:17:23 -0700502 public:
Chia-I Wu8c721c62015-07-03 11:49:42 +0800503 ~Sampler();
504
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600505 // vkCreateSampler()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600506 void init(const Device &dev, const VkSamplerCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600507};
508
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600509class DescriptorSetLayout : public internal::NonDispHandle<VkDescriptorSetLayout> {
Karl Schultz6addd812016-02-02 17:17:23 -0700510 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800511 ~DescriptorSetLayout();
512
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600513 // vkCreateDescriptorSetLayout()
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600514 void init(const Device &dev, const VkDescriptorSetLayoutCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600515};
516
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800517class DescriptorPool : public internal::NonDispHandle<VkDescriptorPool> {
Karl Schultz6addd812016-02-02 17:17:23 -0700518 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800519 ~DescriptorPool();
520
Karl Schultz6addd812016-02-02 17:17:23 -0700521 // Descriptor sets allocated from this pool will need access to the original
522 // object
Cody Northropcdc72a42015-10-08 11:39:25 -0600523 VkDescriptorPool GetObj() { return pool_; }
524
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600525 // vkCreateDescriptorPool()
Courtney Goeltzenleuchterfe908d32015-09-16 16:12:45 -0600526 void init(const Device &dev, const VkDescriptorPoolCreateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600527
528 // vkResetDescriptorPool()
529 void reset();
530
Cody Northropcdc72a42015-10-08 11:39:25 -0600531 // vkFreeDescriptorSet()
532 void setDynamicUsage(bool isDynamic) { dynamic_usage_ = isDynamic; }
533 bool getDynamicUsage() { return dynamic_usage_; }
534
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800535 // vkAllocateDescriptorSets()
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600536 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const std::vector<const DescriptorSetLayout *> &layouts);
537 std::vector<DescriptorSet *> alloc_sets(const Device &dev, const DescriptorSetLayout &layout, uint32_t count);
538 DescriptorSet *alloc_sets(const Device &dev, const DescriptorSetLayout &layout);
Cody Northropcdc72a42015-10-08 11:39:25 -0600539
Karl Schultz6addd812016-02-02 17:17:23 -0700540 private:
Cody Northropcdc72a42015-10-08 11:39:25 -0600541 VkDescriptorPool pool_;
542
543 // Track whether this pool's usage is VK_DESCRIPTOR_POOL_USAGE_DYNAMIC
544 bool dynamic_usage_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600545};
546
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800547class DescriptorSet : public internal::NonDispHandle<VkDescriptorSet> {
Karl Schultz6addd812016-02-02 17:17:23 -0700548 public:
Chia-I Wuafdfd7f2015-07-03 11:49:42 +0800549 ~DescriptorSet();
550
551 explicit DescriptorSet() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600552 explicit DescriptorSet(const Device &dev, DescriptorPool *pool, VkDescriptorSet set) : NonDispHandle(dev.handle(), set) {
Karl Schultz6addd812016-02-02 17:17:23 -0700553 containing_pool_ = pool;
554 }
Tony Barbour67e99152015-07-10 14:10:27 -0600555
Karl Schultz6addd812016-02-02 17:17:23 -0700556 private:
557 DescriptorPool *containing_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600558};
559
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800560class CommandPool : public internal::NonDispHandle<VkCommandPool> {
Karl Schultz6addd812016-02-02 17:17:23 -0700561 public:
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800562 ~CommandPool();
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600563
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800564 explicit CommandPool() : NonDispHandle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600565 explicit CommandPool(const Device &dev, const VkCommandPoolCreateInfo &info) { init(dev, info); }
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600566
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800567 void init(const Device &dev, const VkCommandPoolCreateInfo &info);
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600568
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800569 static VkCommandPoolCreateInfo create_info(uint32_t queue_family_index);
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600570};
571
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600572inline VkCommandPoolCreateInfo CommandPool::create_info(uint32_t queue_family_index) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800573 VkCommandPoolCreateInfo info = {};
574 info.sType = VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600575 info.queueFamilyIndex = queue_family_index;
Tobin Ehlisac0ef842015-12-14 13:46:38 -0700576 info.flags = VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT;
Courtney Goeltzenleuchteree5d80b2015-07-10 19:50:17 -0600577 return info;
578}
579
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800580class CommandBuffer : public internal::Handle<VkCommandBuffer> {
Karl Schultz6addd812016-02-02 17:17:23 -0700581 public:
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800582 ~CommandBuffer();
Chia-I Wube2b9172015-07-03 11:49:42 +0800583
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800584 explicit CommandBuffer() : Handle() {}
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600585 explicit CommandBuffer(const Device &dev, const VkCommandBufferAllocateInfo &info) { init(dev, info); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600586
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800587 // vkAllocateCommandBuffers()
588 void init(const Device &dev, const VkCommandBufferAllocateInfo &info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600589
590 // vkBeginCommandBuffer()
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800591 void begin(const VkCommandBufferBeginInfo *info);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600592 void begin();
593
594 // vkEndCommandBuffer()
595 // vkResetCommandBuffer()
596 void end();
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800597 void reset(VkCommandBufferResetFlags flags);
598 void reset() { reset(VK_COMMAND_BUFFER_RESET_RELEASE_RESOURCES_BIT); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600599
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800600 static VkCommandBufferAllocateInfo create_info(VkCommandPool const &pool);
Chia-I Wube2b9172015-07-03 11:49:42 +0800601
Karl Schultz6addd812016-02-02 17:17:23 -0700602 private:
Chia-I Wube2b9172015-07-03 11:49:42 +0800603 VkDevice dev_handle_;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800604 VkCommandPool cmd_pool_;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600605};
606
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600607inline VkMemoryAllocateInfo DeviceMemory::alloc_info(VkDeviceSize size, uint32_t memory_type_index) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800608 VkMemoryAllocateInfo info = {};
Chia-I Wu00ce5402015-11-10 16:21:09 +0800609 info.sType = VK_STRUCTURE_TYPE_MEMORY_ALLOCATE_INFO;
Chia-I Wuf8f074f2015-07-03 10:58:57 +0800610 info.allocationSize = size;
611 info.memoryTypeIndex = memory_type_index;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600612 return info;
613}
614
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600615inline VkBufferCreateInfo Buffer::create_info(VkDeviceSize size, VkFlags usage) {
Courtney Goeltzenleuchter95487bc2015-04-14 18:48:46 -0600616 VkBufferCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600617 info.sType = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO;
618 info.size = size;
619 info.usage = usage;
620 return info;
621}
622
Karl Schultz6addd812016-02-02 17:17:23 -0700623inline VkFenceCreateInfo Fence::create_info(VkFenceCreateFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600624 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600625 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
626 info.flags = flags;
627 return info;
628}
629
Karl Schultz6addd812016-02-02 17:17:23 -0700630inline VkFenceCreateInfo Fence::create_info() {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600631 VkFenceCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600632 info.sType = VK_STRUCTURE_TYPE_FENCE_CREATE_INFO;
633 return info;
634}
635
Karl Schultz6addd812016-02-02 17:17:23 -0700636inline VkSemaphoreCreateInfo Semaphore::create_info(VkFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600637 VkSemaphoreCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600638 info.sType = VK_STRUCTURE_TYPE_SEMAPHORE_CREATE_INFO;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600639 info.flags = flags;
640 return info;
641}
642
Karl Schultz6addd812016-02-02 17:17:23 -0700643inline VkEventCreateInfo Event::create_info(VkFlags flags) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600644 VkEventCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600645 info.sType = VK_STRUCTURE_TYPE_EVENT_CREATE_INFO;
646 info.flags = flags;
647 return info;
648}
649
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600650inline VkQueryPoolCreateInfo QueryPool::create_info(VkQueryType type, uint32_t slot_count) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600651 VkQueryPoolCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600652 info.sType = VK_STRUCTURE_TYPE_QUERY_POOL_CREATE_INFO;
653 info.queryType = type;
Jon Ashburnf19916e2016-01-11 13:12:43 -0700654 info.queryCount = slot_count;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600655 return info;
656}
657
Karl Schultz6addd812016-02-02 17:17:23 -0700658inline VkImageCreateInfo Image::create_info() {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600659 VkImageCreateInfo info = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600660 info.sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO;
661 info.extent.width = 1;
662 info.extent.height = 1;
663 info.extent.depth = 1;
664 info.mipLevels = 1;
Courtney Goeltzenleuchter5d2aed42015-10-21 17:57:31 -0600665 info.arrayLayers = 1;
Chia-I Wu5c17c962015-10-31 00:31:16 +0800666 info.samples = VK_SAMPLE_COUNT_1_BIT;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600667 return info;
668}
669
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600670inline VkImageSubresource Image::subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600671 VkImageSubresource subres = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600672 if (aspect == 0) {
673 assert(!"Invalid VkImageAspectFlags");
674 }
Chia-I Wu52b07e72015-10-27 19:55:05 +0800675 subres.aspectMask = aspect;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600676 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600677 subres.arrayLayer = array_layer;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600678 return subres;
679}
680
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600681inline VkImageSubresource Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer) {
682 return subresource(range.aspectMask, range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600683}
684
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600685inline VkImageSubresourceLayers Image::subresource(VkImageAspectFlags aspect, uint32_t mip_level, uint32_t array_layer,
Karl Schultz6addd812016-02-02 17:17:23 -0700686 uint32_t array_size) {
Chia-I Wu1b99bb22015-10-27 19:25:11 +0800687 VkImageSubresourceLayers subres = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600688 switch (aspect) {
689 case VK_IMAGE_ASPECT_COLOR_BIT:
690 case VK_IMAGE_ASPECT_DEPTH_BIT:
691 case VK_IMAGE_ASPECT_STENCIL_BIT:
692 case VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT:
693 /* valid */
694 break;
695 default:
696 assert(!"Invalid VkImageAspectFlags");
697 }
Chia-I Wuab83a0e2015-10-27 19:00:15 +0800698 subres.aspectMask = aspect;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600699 subres.mipLevel = mip_level;
Courtney Goeltzenleuchter8367ce02015-10-16 09:46:00 -0600700 subres.baseArrayLayer = array_layer;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800701 subres.layerCount = array_size;
Courtney Goeltzenleuchter01ee1ca2015-09-10 16:41:13 -0600702 return subres;
703}
704
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600705inline VkImageSubresourceLayers Image::subresource(const VkImageSubresourceRange &range, uint32_t mip_level, uint32_t array_layer,
706 uint32_t array_size) {
707 return subresource(range.aspectMask, range.baseMipLevel + mip_level, range.baseArrayLayer + array_layer, array_size);
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600708}
709
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600710inline VkImageSubresourceRange Image::subresource_range(VkImageAspectFlags aspect_mask, uint32_t base_mip_level,
711 uint32_t mip_levels, uint32_t base_array_layer, uint32_t num_layers) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600712 VkImageSubresourceRange range = {};
Karl Schultz0ab73f82016-03-29 12:41:24 -0600713 if (aspect_mask == 0) {
714 assert(!"Invalid VkImageAspectFlags");
715 }
Courtney Goeltzenleuchterba724512015-09-10 17:58:54 -0600716 range.aspectMask = aspect_mask;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600717 range.baseMipLevel = base_mip_level;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800718 range.levelCount = mip_levels;
Courtney Goeltzenleuchter4a261892015-09-10 16:38:41 -0600719 range.baseArrayLayer = base_array_layer;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800720 range.layerCount = num_layers;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600721 return range;
722}
723
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600724inline VkImageSubresourceRange Image::subresource_range(const VkImageCreateInfo &info, VkImageAspectFlags aspect_mask) {
725 return subresource_range(aspect_mask, 0, info.mipLevels, 0, info.arrayLayers);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600726}
727
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600728inline VkImageSubresourceRange Image::subresource_range(const VkImageSubresource &subres) {
729 return subresource_range(subres.aspectMask, subres.mipLevel, 1, subres.arrayLayer, 1);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600730}
731
Karl Schultz6addd812016-02-02 17:17:23 -0700732inline VkExtent2D Image::extent(int32_t width, int32_t height) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600733 VkExtent2D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600734 extent.width = width;
735 extent.height = height;
736 return extent;
737}
738
Karl Schultz6addd812016-02-02 17:17:23 -0700739inline VkExtent2D Image::extent(const VkExtent2D &extent, uint32_t mip_level) {
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600740 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
741 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600742 return Image::extent(width, height);
743}
744
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600745inline VkExtent2D Image::extent(const VkExtent3D &extent) { return Image::extent(extent.width, extent.height); }
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600746
Karl Schultz6addd812016-02-02 17:17:23 -0700747inline VkExtent3D Image::extent(int32_t width, int32_t height, int32_t depth) {
Courtney Goeltzenleuchterfb4efc62015-04-10 08:34:15 -0600748 VkExtent3D extent = {};
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600749 extent.width = width;
750 extent.height = height;
751 extent.depth = depth;
752 return extent;
753}
754
Karl Schultz6addd812016-02-02 17:17:23 -0700755inline VkExtent3D Image::extent(const VkExtent3D &extent, uint32_t mip_level) {
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600756 const int32_t width = (extent.width >> mip_level) ? extent.width >> mip_level : 1;
757 const int32_t height = (extent.height >> mip_level) ? extent.height >> mip_level : 1;
758 const int32_t depth = (extent.depth >> mip_level) ? extent.depth >> mip_level : 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600759 return Image::extent(width, height, depth);
760}
761
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600762inline VkShaderModuleCreateInfo ShaderModule::create_info(size_t code_size, const uint32_t *code, VkFlags flags) {
Courtney Goeltzenleuchteree4027d2015-06-28 13:01:17 -0600763 VkShaderModuleCreateInfo info = {};
764 info.sType = VK_STRUCTURE_TYPE_SHADER_MODULE_CREATE_INFO;
765 info.codeSize = code_size;
766 info.pCode = code;
767 info.flags = flags;
768 return info;
769}
770
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600771inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
772 VkDescriptorType type, uint32_t count,
773 const VkDescriptorImageInfo *image_info) {
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800774 VkWriteDescriptorSet write = {};
775 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800776 write.dstSet = set.handle();
777 write.dstBinding = binding;
778 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800779 write.descriptorCount = count;
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800780 write.descriptorType = type;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600781 write.pImageInfo = image_info;
Chia-I Wu9d00ed72015-05-25 16:27:55 +0800782 return write;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600783}
784
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600785inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
786 VkDescriptorType type, uint32_t count,
787 const VkDescriptorBufferInfo *buffer_info) {
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600788 VkWriteDescriptorSet write = {};
789 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800790 write.dstSet = set.handle();
791 write.dstBinding = binding;
792 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800793 write.descriptorCount = count;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600794 write.descriptorType = type;
795 write.pBufferInfo = buffer_info;
796 return write;
797}
798
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600799inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
800 VkDescriptorType type, uint32_t count, const VkBufferView *buffer_views) {
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600801 VkWriteDescriptorSet write = {};
802 write.sType = VK_STRUCTURE_TYPE_WRITE_DESCRIPTOR_SET;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800803 write.dstSet = set.handle();
804 write.dstBinding = binding;
805 write.dstArrayElement = array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800806 write.descriptorCount = count;
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600807 write.descriptorType = type;
808 write.pTexelBufferView = buffer_views;
809 return write;
810}
811
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600812inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
813 VkDescriptorType type,
814 const std::vector<VkDescriptorImageInfo> &image_info) {
815 return write_descriptor_set(set, binding, array_element, type, image_info.size(), &image_info[0]);
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600816}
817
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600818inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
819 VkDescriptorType type,
820 const std::vector<VkDescriptorBufferInfo> &buffer_info) {
821 return write_descriptor_set(set, binding, array_element, type, buffer_info.size(), &buffer_info[0]);
Courtney Goeltzenleuchter4cb6d922015-10-23 13:38:14 -0600822}
823
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600824inline VkWriteDescriptorSet Device::write_descriptor_set(const DescriptorSet &set, uint32_t binding, uint32_t array_element,
825 VkDescriptorType type, const std::vector<VkBufferView> &buffer_views) {
826 return write_descriptor_set(set, binding, array_element, type, buffer_views.size(), &buffer_views[0]);
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600827}
828
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600829inline VkCopyDescriptorSet Device::copy_descriptor_set(const DescriptorSet &src_set, uint32_t src_binding,
830 uint32_t src_array_element, const DescriptorSet &dst_set,
831 uint32_t dst_binding, uint32_t dst_array_element, uint32_t count) {
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 Wu3432a0c2015-10-27 18:04:07 +0800837 copy.dstSet = dst_set.handle();
838 copy.dstBinding = dst_binding;
839 copy.dstArrayElement = dst_array_element;
Chia-I Wud50a7d72015-10-26 20:48:51 +0800840 copy.descriptorCount = 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
Mark Lobodzinski722841d2016-09-07 16:34:56 -0600845inline VkCommandBufferAllocateInfo CommandBuffer::create_info(VkCommandPool const &pool) {
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800846 VkCommandBufferAllocateInfo info = {};
Chia-I Wu00ce5402015-11-10 16:21:09 +0800847 info.sType = VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO;
Chia-I Wu3432a0c2015-10-27 18:04:07 +0800848 info.commandPool = pool;
Jon Ashburnf19916e2016-01-11 13:12:43 -0700849 info.commandBufferCount = 1;
Courtney Goeltzenleuchterd8e229c2015-04-08 15:36:08 -0600850 return info;
851}
852
853}; // namespace vk_testing
854
855#endif // VKTESTBINDING_H