blob: 39224688c78fc9378bc475323ee0b01c0b035eec [file] [log] [blame]
Tobin Ehlise79df942014-11-18 16:38:08 -07001/*
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -06002 * Vulkan
Tobin Ehlise79df942014-11-18 16:38:08 -07003 *
4 * Copyright (C) 2014 LunarG, Inc.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"),
8 * to deal in the Software without restriction, including without limitation
9 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 * and/or sell copies of the Software, and to permit persons to whom the
11 * Software is furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included
14 * in all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22 * DEALINGS IN THE SOFTWARE.
23 */
Tobin Ehlis2d1d9702015-07-03 09:42:57 -060024#include "vk_layer.h"
Tobin Ehlis63bb9482015-03-17 16:24:32 -060025#include <vector>
26
27using namespace std;
28
Tobin Ehlise79df942014-11-18 16:38:08 -070029// Draw State ERROR codes
30typedef enum _DRAW_STATE_ERROR
31{
Tobin Ehlis84c521c2015-01-19 08:42:29 -070032 DRAWSTATE_NONE, // Used for INFO & other non-error messages
Tobin Ehlis41415bb2015-01-22 10:45:21 -070033 DRAWSTATE_INTERNAL_ERROR, // Error with DrawState internal data structures
Tobin Ehlis84c521c2015-01-19 08:42:29 -070034 DRAWSTATE_NO_PIPELINE_BOUND, // Unable to identify a bound pipeline
Tobin Ehlisdd82f6b2015-04-03 12:01:11 -060035 DRAWSTATE_INVALID_POOL, // Invalid DS pool
Tobin Ehlis83ebbef2015-02-10 15:35:23 -070036 DRAWSTATE_INVALID_SET, // Invalid DS
Tobin Ehlis41415bb2015-01-22 10:45:21 -070037 DRAWSTATE_INVALID_LAYOUT, // Invalid DS layout
Tobin Ehlisde63c532015-06-18 15:59:33 -060038 DRAWSTATE_INVALID_PIPELINE, // Invalid Pipeline handle referenced
39 DRAWSTATE_INVALID_PIPELINE_CREATE_STATE, // Attempt to create a pipeline with invalid state
Tobin Ehlis8cced212015-02-13 10:26:14 -070040 DRAWSTATE_INVALID_CMD_BUFFER, // Invalid CmdBuffer referenced
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -060041 DRAWSTATE_VTX_INDEX_OUT_OF_BOUNDS, // binding in vkCmdBindVertexData() too large for PSO's pVertexBindingDescriptions array
Tobin Ehlis84c521c2015-01-19 08:42:29 -070042 DRAWSTATE_INVALID_DYNAMIC_STATE_OBJECT, // Invalid dyn state object
43 DRAWSTATE_MISSING_DOT_PROGRAM, // No "dot" program in order to generate png image
Tobin Ehlis41415bb2015-01-22 10:45:21 -070044 DRAWSTATE_OUT_OF_MEMORY, // malloc failed
45 DRAWSTATE_DESCRIPTOR_TYPE_MISMATCH, // Type in layout vs. update are not the same
Tobin Ehlis83ebbef2015-02-10 15:35:23 -070046 DRAWSTATE_DESCRIPTOR_UPDATE_OUT_OF_BOUNDS, // Descriptors set for update out of bounds for corresponding layout section
Tobin Ehlis8733adc2015-02-23 16:09:58 -070047 DRAWSTATE_INVALID_UPDATE_INDEX, // Index of requested update is invalid for specified descriptors set
Tobin Ehlis2464b882015-04-01 08:40:34 -060048 DRAWSTATE_INVALID_UPDATE_STRUCT, // Struct in DS Update tree is of invalid type
Tobin Ehlis28be0be2015-05-22 12:38:16 -060049 DRAWSTATE_NUM_SAMPLES_MISMATCH, // Number of samples in bound PSO does not match number in FB of current RenderPass
50 DRAWSTATE_NO_END_CMD_BUFFER, // Must call vkEndCommandBuffer() before QueueSubmit on that cmdBuffer
Tobin Ehlise42007c2015-06-19 13:00:59 -060051 DRAWSTATE_NO_BEGIN_CMD_BUFFER, // Binding cmds or calling End on CB that never had vkBeginCommandBuffer() called on it
Tobin Ehlis97866202015-06-10 12:57:07 -060052 DRAWSTATE_VIEWPORT_NOT_BOUND, // Draw submitted with no viewport state object bound
53 DRAWSTATE_RASTER_NOT_BOUND, // Draw submitted with no raster state object bound
54 DRAWSTATE_COLOR_BLEND_NOT_BOUND, // Draw submitted with no color blend state object bound when color write enabled
55 DRAWSTATE_DEPTH_STENCIL_NOT_BOUND, // Draw submitted with no depth-stencil state object bound when depth write enabled
Tobin Ehlisa366ca22015-06-19 15:07:05 -060056 DRAWSTATE_INDEX_BUFFER_NOT_BOUND, // Draw submitted with no depth-stencil state object bound when depth write enabled
Tobin Ehlisc6c3d6d2015-06-22 17:20:50 -060057 DRAWSTATE_PIPELINE_LAYOUT_MISMATCH, // Draw submitted PSO Pipeline layout that doesn't match layout from BindDescriptorSets
Tobin Ehlis8b6c2352015-06-23 16:13:03 -060058 DRAWSTATE_INVALID_RENDERPASS, // Use of a NULL or otherwise invalid RenderPass object
Tobin Ehlis451efca2015-06-23 11:22:55 -060059 DRAWSTATE_INVALID_RENDERPASS_CMD, // Invalid cmd submitted while a RenderPass is active
60 DRAWSTATE_NO_ACTIVE_RENDERPASS, // Rendering cmd submitted without an active RenderPass
Tobin Ehlise4076782015-06-24 15:53:07 -060061 DRAWSTATE_DESCRIPTOR_SET_NOT_UPDATED, // DescriptorSet bound but it was never updated. This is a warning code.
Tobin Ehlis8cd650e2015-07-01 16:46:13 -060062 DRAWSTATE_CLEAR_CMD_BEFORE_DRAW, // Clear cmd issued before any Draw in CmdBuffer, should use RenderPass Ops instead
Tobin Ehlisde63c532015-06-18 15:59:33 -060063 DRAWSTATE_INVALID_EXTENSION,
Tobin Ehlise79df942014-11-18 16:38:08 -070064} DRAW_STATE_ERROR;
Tobin Ehlis26092022014-11-20 09:49:17 -070065
66typedef enum _DRAW_TYPE
67{
68 DRAW = 0,
69 DRAW_INDEXED = 1,
70 DRAW_INDIRECT = 2,
71 DRAW_INDEXED_INDIRECT = 3,
72 DRAW_BEGIN_RANGE = DRAW,
73 DRAW_END_RANGE = DRAW_INDEXED_INDIRECT,
74 NUM_DRAW_TYPES = (DRAW_END_RANGE - DRAW_BEGIN_RANGE + 1),
75} DRAW_TYPE;
Tobin Ehlisa701ef02014-11-27 15:43:39 -070076
Tobin Ehlis1dce5f12015-07-07 10:42:20 -060077typedef enum _DYNAMIC_STATE_BIND_POINT
78{
79 VK_STATE_BIND_POINT_VIEWPORT,
80 VK_STATE_BIND_POINT_RASTER,
81 VK_STATE_BIND_POINT_COLOR_BLEND,
82 VK_STATE_BIND_POINT_DEPTH_STENCIL,
83 VK_NUM_STATE_BIND_POINT // Used for array sizing
84} DYNAMIC_STATE_BIND_POINT;
85
86static string string_DYNAMIC_STATE_BIND_POINT(DYNAMIC_STATE_BIND_POINT sbp)
87{
88 switch (sbp)
89 {
90 case VK_STATE_BIND_POINT_VIEWPORT:
91 return "VIEWPORT";
92 case VK_STATE_BIND_POINT_RASTER:
93 return "RASTER";
94 case VK_STATE_BIND_POINT_COLOR_BLEND:
95 return "COLOR_BLEND";
96 case VK_STATE_BIND_POINT_DEPTH_STENCIL:
97 return "DEPTH_STENCIL";
98 default:
99 return "UNKNOWN_DYNAMIC_STATE_BIND_POINT";
100 }
101}
102
103static VkDbgObjectType dynamicStateBindPointToObjType(DYNAMIC_STATE_BIND_POINT sbp)
104{
105 switch (sbp)
106 {
107 case VK_STATE_BIND_POINT_VIEWPORT:
108 return VK_OBJECT_TYPE_DYNAMIC_VP_STATE;
109 case VK_STATE_BIND_POINT_RASTER:
110 return VK_OBJECT_TYPE_DYNAMIC_RS_STATE;
111 case VK_STATE_BIND_POINT_COLOR_BLEND:
112 return VK_OBJECT_TYPE_DYNAMIC_CB_STATE;
113 case VK_STATE_BIND_POINT_DEPTH_STENCIL:
114 return VK_OBJECT_TYPE_DYNAMIC_DS_STATE;
115 default:
116 return VK_OBJECT_TYPE_MAX_ENUM;
117 }
118}
119
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700120typedef struct _SHADER_DS_MAPPING {
121 uint32_t slotCount;
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600122 VkDescriptorSetLayoutCreateInfo* pShaderMappingSlot;
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700123} SHADER_DS_MAPPING;
124
Tobin Ehlis41415bb2015-01-22 10:45:21 -0700125typedef struct _GENERIC_HEADER {
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600126 VkStructureType sType;
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700127 const void* pNext;
Tobin Ehlis41415bb2015-01-22 10:45:21 -0700128} GENERIC_HEADER;
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700129
130typedef struct _PIPELINE_NODE {
Mark Lobodzinski0e0fb5c2015-06-23 15:11:57 -0600131 VkPipeline pipeline;
132 VkGraphicsPipelineCreateInfo graphicsPipelineCI;
133 VkPipelineVertexInputStateCreateInfo vertexInputCI;
134 VkPipelineIaStateCreateInfo iaStateCI;
135 VkPipelineTessStateCreateInfo tessStateCI;
136 VkPipelineVpStateCreateInfo vpStateCI;
137 VkPipelineRsStateCreateInfo rsStateCI;
138 VkPipelineMsStateCreateInfo msStateCI;
139 VkPipelineCbStateCreateInfo cbStateCI;
140 VkPipelineDsStateCreateInfo dsStateCI;
141 VkPipelineShaderStageCreateInfo vsCI;
142 VkPipelineShaderStageCreateInfo tcsCI;
143 VkPipelineShaderStageCreateInfo tesCI;
144 VkPipelineShaderStageCreateInfo gsCI;
145 VkPipelineShaderStageCreateInfo fsCI;
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600146 // Compute shader is include in VkComputePipelineCreateInfo
Mark Lobodzinski0e0fb5c2015-06-23 15:11:57 -0600147 VkComputePipelineCreateInfo computePipelineCI;
Tobin Ehlis806a97a2015-06-18 11:02:59 -0600148 // Flag of which shader stages are active for this pipeline
Mark Lobodzinski0e0fb5c2015-06-23 15:11:57 -0600149 uint32_t active_shaders;
150 VkGraphicsPipelineCreateInfo* pCreateTree; // Ptr to shadow of data in create tree
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700151 // Vtx input info (if any)
Mark Lobodzinski0e0fb5c2015-06-23 15:11:57 -0600152 uint32_t vtxBindingCount; // number of bindings
153 VkVertexInputBindingDescription* pVertexBindingDescriptions;
154 uint32_t vtxAttributeCount; // number of attributes
155 VkVertexInputAttributeDescription* pVertexAttributeDescriptions;
156 uint32_t attachmentCount; // number of CB attachments
157 VkPipelineCbAttachmentState* pAttachments;
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700158} PIPELINE_NODE;
159
160typedef struct _SAMPLER_NODE {
Tobin Ehlisa366ca22015-06-19 15:07:05 -0600161 VkSampler sampler;
162 VkSamplerCreateInfo createInfo;
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700163} SAMPLER_NODE;
164
Tobin Ehlis41415bb2015-01-22 10:45:21 -0700165typedef struct _BUFFER_NODE {
Tobin Ehlisa366ca22015-06-19 15:07:05 -0600166 VkBufferView buffer;
Courtney Goeltzenleuchterddcb6192015-04-14 18:48:46 -0600167 VkBufferViewCreateInfo createInfo;
Tobin Ehlisa366ca22015-06-19 15:07:05 -0600168 VkDescriptorInfo descriptorInfo;
Tobin Ehlis41415bb2015-01-22 10:45:21 -0700169} BUFFER_NODE;
170
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700171// Descriptor Data structures
Tobin Ehlis41415bb2015-01-22 10:45:21 -0700172// Layout Node has the core layout data
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700173typedef struct _LAYOUT_NODE {
Tobin Ehlisa366ca22015-06-19 15:07:05 -0600174 VkDescriptorSetLayout layout;
175 VkDescriptorType* pTypes; // Dynamic array that will be created to verify descriptor types
176 VkDescriptorSetLayoutCreateInfo createInfo;
177 uint32_t startIndex; // 1st index of this layout
178 uint32_t endIndex; // last index of this layout
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700179} LAYOUT_NODE;
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700180typedef struct _SET_NODE {
Tobin Ehlisa366ca22015-06-19 15:07:05 -0600181 VkDescriptorSet set;
182 VkDescriptorPool pool;
183 VkDescriptorSetUsage setUsage;
Tobin Ehlis82871a82015-02-19 09:55:18 -0700184 // Head of LL of all Update structs for this set
Tobin Ehlisa366ca22015-06-19 15:07:05 -0600185 GENERIC_HEADER* pUpdateStructs;
Tobin Ehlis41415bb2015-01-22 10:45:21 -0700186 // Total num of descriptors in this set (count of its layout plus all prior layouts)
Tobin Ehlisa366ca22015-06-19 15:07:05 -0600187 uint32_t descriptorCount;
188 GENERIC_HEADER** ppDescriptors; // Array where each index points to update node for its slot
189 LAYOUT_NODE* pLayout; // Layout for this set
190 struct _SET_NODE* pNext;
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700191} SET_NODE;
192
Tobin Ehlisdd82f6b2015-04-03 12:01:11 -0600193typedef struct _POOL_NODE {
Tobin Ehlisa366ca22015-06-19 15:07:05 -0600194 VkDescriptorPool pool;
195 VkDescriptorPoolUsage poolUsage;
196 uint32_t maxSets;
197 VkDescriptorPoolCreateInfo createInfo;
198 SET_NODE* pSets; // Head of LL of sets for this Pool
Tobin Ehlisdd82f6b2015-04-03 12:01:11 -0600199} POOL_NODE;
Tobin Ehlis84c521c2015-01-19 08:42:29 -0700200
Tobin Ehlis8cced212015-02-13 10:26:14 -0700201// Cmd Buffer Tracking
202typedef enum _CMD_TYPE
203{
204 CMD_BINDPIPELINE,
205 CMD_BINDPIPELINEDELTA,
Tobin Ehlis1dce5f12015-07-07 10:42:20 -0600206 CMD_BINDDYNAMICVIEWPORTSTATE,
207 CMD_BINDDYNAMICRASTERSTATE,
208 CMD_BINDDYNAMICCOLORBLENDSTATE,
209 CMD_BINDDYNAMICDEPTHSTENCILSTATE,
Tobin Ehlisdd82f6b2015-04-03 12:01:11 -0600210 CMD_BINDDESCRIPTORSETS,
Tobin Ehlis8cced212015-02-13 10:26:14 -0700211 CMD_BINDINDEXBUFFER,
212 CMD_BINDVERTEXBUFFER,
213 CMD_DRAW,
214 CMD_DRAWINDEXED,
215 CMD_DRAWINDIRECT,
216 CMD_DRAWINDEXEDINDIRECT,
217 CMD_DISPATCH,
218 CMD_DISPATCHINDIRECT,
219 CMD_COPYBUFFER,
220 CMD_COPYIMAGE,
Tobin Ehlisdd82f6b2015-04-03 12:01:11 -0600221 CMD_BLITIMAGE,
Tobin Ehlis8cced212015-02-13 10:26:14 -0700222 CMD_COPYBUFFERTOIMAGE,
223 CMD_COPYIMAGETOBUFFER,
224 CMD_CLONEIMAGEDATA,
225 CMD_UPDATEBUFFER,
226 CMD_FILLBUFFER,
227 CMD_CLEARCOLORIMAGE,
Tobin Ehlis8cd650e2015-07-01 16:46:13 -0600228 CMD_CLEARCOLORATTACHMENT,
229 CMD_CLEARDEPTHSTENCILIMAGE,
230 CMD_CLEARDEPTHSTENCILATTACHMENT,
Tobin Ehlis8cced212015-02-13 10:26:14 -0700231 CMD_RESOLVEIMAGE,
232 CMD_SETEVENT,
233 CMD_RESETEVENT,
234 CMD_WAITEVENTS,
235 CMD_PIPELINEBARRIER,
236 CMD_BEGINQUERY,
237 CMD_ENDQUERY,
238 CMD_RESETQUERYPOOL,
239 CMD_WRITETIMESTAMP,
240 CMD_INITATOMICCOUNTERS,
241 CMD_LOADATOMICCOUNTERS,
242 CMD_SAVEATOMICCOUNTERS,
243 CMD_BEGINRENDERPASS,
Chia-I Wuc278df82015-07-07 11:50:03 +0800244 CMD_NEXTSUBPASS,
Tobin Ehlis1dae99a2015-03-02 10:16:40 -0700245 CMD_ENDRENDERPASS,
Chia-I Wu88eaa3b2015-06-26 15:34:39 +0800246 CMD_EXECUTECOMMANDS,
Tobin Ehlis1dae99a2015-03-02 10:16:40 -0700247 CMD_DBGMARKERBEGIN,
248 CMD_DBGMARKEREND,
Tobin Ehlis8cced212015-02-13 10:26:14 -0700249} CMD_TYPE;
250// Data structure for holding sequence of cmds in cmd buffer
251typedef struct _CMD_NODE {
Tobin Ehlis8cced212015-02-13 10:26:14 -0700252 CMD_TYPE type;
253 uint64_t cmdNumber;
254} CMD_NODE;
255
256typedef enum _CB_STATE
257{
258 CB_NEW, // Newly created CB w/o any cmds
259 CB_UPDATE_ACTIVE, // BeginCB has been called on this CB
260 CB_UPDATE_COMPLETE // EndCB has been called on this CB
261} CB_STATE;
Tobin Ehlis97866202015-06-10 12:57:07 -0600262// CB Status -- used to track status of various bindings on cmd buffer objects
263typedef VkFlags CBStatusFlags;
264typedef enum _CBStatusFlagBits
265{
266 CBSTATUS_NONE = 0x00000000, // No status is set
267 CBSTATUS_VIEWPORT_BOUND = 0x00000001, // Viewport state object has been bound
268 CBSTATUS_RASTER_BOUND = 0x00000002, // Raster state object has been bound
269 CBSTATUS_COLOR_BLEND_WRITE_ENABLE = 0x00000004, // PSO w/ CB Enable set has been bound
270 CBSTATUS_COLOR_BLEND_BOUND = 0x00000008, // CB state object has been bound
271 CBSTATUS_DEPTH_STENCIL_WRITE_ENABLE = 0x00000010, // PSO w/ DS Enable set has been bound
272 CBSTATUS_DEPTH_STENCIL_BOUND = 0x00000020, // DS state object has been bound
Tobin Ehlisa366ca22015-06-19 15:07:05 -0600273 CBSTATUS_INDEX_BUFFER_BOUND = 0x00000040, // Index buffer has been bound
Tobin Ehlis97866202015-06-10 12:57:07 -0600274} CBStatusFlagBits;
Tobin Ehlis1dce5f12015-07-07 10:42:20 -0600275
Tobin Ehlis63bb9482015-03-17 16:24:32 -0600276// Cmd Buffer Wrapper Struct
Tobin Ehlis8cced212015-02-13 10:26:14 -0700277typedef struct _GLOBAL_CB_NODE {
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600278 VkCmdBuffer cmdBuffer;
Tobin Ehlis28be0be2015-05-22 12:38:16 -0600279 uint32_t queueNodeIndex;
280 VkFlags flags;
281 VkFence fence; // fence tracking this cmd buffer
282 uint64_t numCmds; // number of cmds in this CB
283 uint64_t drawCount[NUM_DRAW_TYPES]; // Count of each type of draw in this CB
Tobin Ehlis97866202015-06-10 12:57:07 -0600284 CB_STATE state; // Track cmd buffer update state
285 CBStatusFlags status; // Track status of various bindings on cmd buffer
Tobin Ehlis28be0be2015-05-22 12:38:16 -0600286 vector<CMD_NODE*> pCmds;
Tobin Ehlis8cced212015-02-13 10:26:14 -0700287 // Currently storing "lastBound" objects on per-CB basis
288 // long-term may want to create caches of "lastBound" states and could have
289 // each individual CMD_NODE referencing its own "lastBound" state
Tobin Ehlis28be0be2015-05-22 12:38:16 -0600290 VkPipeline lastBoundPipeline;
291 uint32_t lastVtxBinding;
Tobin Ehlis1dce5f12015-07-07 10:42:20 -0600292 uint64_t lastBoundDynamicState[VK_NUM_STATE_BIND_POINT];
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600293 VkDescriptorSet lastBoundDescriptorSet;
Tobin Ehlisc6c3d6d2015-06-22 17:20:50 -0600294 VkPipelineLayout lastBoundPipelineLayout;
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -0600295 VkRenderPass activeRenderPass;
Chia-I Wuc278df82015-07-07 11:50:03 +0800296 uint32_t activeSubpass;
Tobin Ehlis28be0be2015-05-22 12:38:16 -0600297 VkFramebuffer framebuffer;
298 vector<VkDescriptorSet> boundDescriptorSets;
Tobin Ehlis8cced212015-02-13 10:26:14 -0700299} GLOBAL_CB_NODE;