blob: d153115f8e8ecd0cf4107000c19a22d817197abe [file] [log] [blame]
Tobin Ehlis62086412014-11-19 16:19:28 -07001/*
Tobin Ehlis62086412014-11-19 16:19:28 -07002 *
Courtney Goeltzenleuchter8a17da52015-10-29 13:50:34 -06003 * Copyright (C) 2015 Valve Corporation
Michael Lentine62c60c32015-10-29 10:41:47 -07004 * Copyright (C) 2015 Google, Inc.
Tobin Ehlis62086412014-11-19 16:19:28 -07005 *
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.
Courtney Goeltzenleuchter96cd7952015-10-30 11:14:30 -060023 *
24 * Author: Tobin Ehlis <tobin@lunarg.com>
Tobin Ehlis62086412014-11-19 16:19:28 -070025 */
Mark Lobodzinski283a4c22015-03-24 16:29:24 -050026#pragma once
Chia-I Wu5b66aa52015-04-16 22:02:10 +080027#include <vector>
Michael Lentinea3c1c002015-12-22 11:36:14 -060028#include <unordered_map>
David Pinedo329ca9e2015-11-06 12:54:48 -070029#include "vulkan/vk_layer.h"
Courtney Goeltzenleuchteracb13592015-12-09 15:48:16 -070030#include "vulkan/vk_ext_debug_report.h"
Mark Lobodzinski283a4c22015-03-24 16:29:24 -050031
32#ifdef __cplusplus
33extern "C" {
34#endif
35
Tobin Ehlis62086412014-11-19 16:19:28 -070036// Mem Tracker ERROR codes
37typedef enum _MEM_TRACK_ERROR
38{
Mark Lobodzinskic66c6712015-06-05 13:59:04 -050039 MEMTRACK_NONE, // Used for INFO & other non-error messages
40 MEMTRACK_INVALID_CB, // Cmd Buffer invalid
41 MEMTRACK_INVALID_MEM_OBJ, // Invalid Memory Object
42 MEMTRACK_INTERNAL_ERROR, // Bug in Mem Track Layer internal data structures
43 MEMTRACK_FREED_MEM_REF, // MEM Obj freed while it still has obj and/or CB refs
44 MEMTRACK_MEM_OBJ_CLEAR_EMPTY_BINDINGS, // Clearing bindings on mem obj that doesn't have any bindings
45 MEMTRACK_MISSING_MEM_BINDINGS, // Trying to retrieve mem bindings, but none found (may be internal error)
46 MEMTRACK_INVALID_OBJECT, // Attempting to reference generic VK Object that is invalid
Mark Lobodzinskic66c6712015-06-05 13:59:04 -050047 MEMTRACK_MEMORY_BINDING_ERROR, // Error during one of many calls that bind memory to object or CB
48 MEMTRACK_MEMORY_LEAK, // Failure to call vkFreeMemory on Mem Obj prior to DestroyDevice
49 MEMTRACK_INVALID_STATE, // Memory not in the correct state
50 MEMTRACK_RESET_CB_WHILE_IN_FLIGHT, // vkResetCommandBuffer() called on a CB that hasn't completed
51 MEMTRACK_INVALID_FENCE_STATE, // Invalid Fence State signaled or used
52 MEMTRACK_REBIND_OBJECT, // Non-sparse object bindings are immutable
Tobin Ehlisd94ba722015-07-03 08:45:14 -060053 MEMTRACK_INVALID_USAGE_FLAG, // Usage flags specified at image/buffer create conflict w/ use of object
Michael Lentine4fbbaa32015-10-28 16:26:14 -070054 MEMTRACK_INVALID_MAP, // Size flag specified at alloc is too small for mapping range
Tobin Ehlis62086412014-11-19 16:19:28 -070055} MEM_TRACK_ERROR;
56
Mark Lobodzinski2a253072015-10-08 10:44:07 -060057// MemTracker Semaphore states
58typedef enum _MtSemaphoreState
59{
60 MEMTRACK_SEMAPHORE_STATE_UNSET, // Semaphore is in an undefined state
61 MEMTRACK_SEMAPHORE_STATE_SIGNALLED, // Semaphore has is in signalled state
62 MEMTRACK_SEMAPHORE_STATE_WAIT, // Semaphore is in wait state
63} MtSemaphoreState;
64
Michael Lentine62c60c32015-10-29 10:41:47 -070065struct MemRange {
66 VkDeviceSize offset;
67 VkDeviceSize size;
68};
69
Tobin Ehlis6aa77422015-01-07 17:49:29 -070070/*
71 * Data Structure overview
Courtney Goeltzenleuchterdfd1b2a2015-04-15 00:14:36 -060072 * There are 4 global STL(' maps
Mark Lobodzinski7a428ce2015-03-31 16:05:35 -050073 * cbMap -- map of command Buffer (CB) objects to MT_CB_INFO structures
74 * Each MT_CB_INFO struct has an stl list container with
Tobin Ehlis6aa77422015-01-07 17:49:29 -070075 * memory objects that are referenced by this CB
Mark Lobodzinski7a428ce2015-03-31 16:05:35 -050076 * memObjMap -- map of Memory Objects to MT_MEM_OBJ_INFO structures
77 * Each MT_MEM_OBJ_INFO has two stl list containers with:
Mark Lobodzinski283a4c22015-03-24 16:29:24 -050078 * -- all CBs referencing this mem obj
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -060079 * -- all VK Objects that are bound to this memory
Mark Lobodzinski7a428ce2015-03-31 16:05:35 -050080 * objectMap -- map of objects to MT_OBJ_INFO structures
Tobin Ehlis6aa77422015-01-07 17:49:29 -070081 *
82 * Algorithm overview
83 * These are the primary events that should happen related to different objects
84 * 1. Command buffers
Mark Lobodzinski283a4c22015-03-24 16:29:24 -050085 * CREATION - Add object,structure to map
86 * CMD BIND - If mem associated, add mem reference to list container
87 * DESTROY - Remove from map, decrement (and report) mem references
Tobin Ehlis6aa77422015-01-07 17:49:29 -070088 * 2. Mem Objects
Mark Lobodzinski283a4c22015-03-24 16:29:24 -050089 * CREATION - Add object,structure to map
90 * OBJ BIND - Add obj structure to list container for that mem node
91 * CMB BIND - If mem-related add CB structure to list container for that mem node
92 * DESTROY - Flag as errors any remaining refs and remove from map
Tobin Ehlis6aa77422015-01-07 17:49:29 -070093 * 3. Generic Objects
Mark Lobodzinski283a4c22015-03-24 16:29:24 -050094 * MEM BIND - DESTROY any previous binding, Add obj node w/ ref to map, add obj ref to list container for that mem node
Mark Lobodzinski7a428ce2015-03-31 16:05:35 -050095 * DESTROY - If mem bound, remove reference list container for that memInfo, remove object ref from map
Tobin Ehlis6aa77422015-01-07 17:49:29 -070096 */
97// TODO : Is there a way to track when Cmd Buffer finishes & remove mem references at that point?
98// TODO : Could potentially store a list of freed mem allocs to flag when they're incorrectly used
99
Tobin Ehlis92f12cd2015-07-08 17:08:02 -0600100// Simple struct to hold handle and type of object so they can be uniquely identified and looked up in appropriate map
101struct MT_OBJ_HANDLE_TYPE {
102 uint64_t handle;
Courtney Goeltzenleuchteracb13592015-12-09 15:48:16 -0700103 VkDebugReportObjectTypeEXT type;
Tobin Ehlis92f12cd2015-07-08 17:08:02 -0600104};
105
Tobin Ehlis6aa77422015-01-07 17:49:29 -0700106// Data struct for tracking memory object
Mark Lobodzinski7a428ce2015-03-31 16:05:35 -0500107struct MT_MEM_OBJ_INFO {
Michael Lentine62c60c32015-10-29 10:41:47 -0700108 void* object; // Dispatchable object used to create this memory (device of swapchain)
109 uint32_t refCount; // Count of references (obj bindings or CB use)
Michael Lentine6306a5a2015-11-24 17:55:33 -0600110 bool valid; // Stores if the memory has valid data or not
Mark Lobodzinskia908b162015-04-21 15:33:04 -0600111 VkDeviceMemory mem;
Michael Lentine62c60c32015-10-29 10:41:47 -0700112 VkMemoryAllocateInfo allocInfo;
113 list<MT_OBJ_HANDLE_TYPE> pObjBindings; // list container of objects bound to this memory
114 list<VkCommandBuffer> pCommandBufferBindings; // list container of cmd buffers that reference this mem object
Michael Lentine62c60c32015-10-29 10:41:47 -0700115 MemRange memRange;
Mark Lobodzinskic0e316f2015-11-13 13:47:01 -0700116 void *pData, *pDriverData;
Mark Lobodzinski283a4c22015-03-24 16:29:24 -0500117};
Tobin Ehlis6aa77422015-01-07 17:49:29 -0700118
Tobin Ehlis92f12cd2015-07-08 17:08:02 -0600119// This only applies to Buffers and Images, which can have memory bound to them
120struct MT_OBJ_BINDING_INFO {
121 VkDeviceMemory mem;
Michael Lentine6306a5a2015-11-24 17:55:33 -0600122 bool valid; //If this is a swapchain image backing memory is not a MT_MEM_OBJ_INFO so store it here.
Chris Forbesa0a71b62015-07-11 16:06:23 +1200123 union create_info {
Tobin Ehlis92f12cd2015-07-08 17:08:02 -0600124 VkImageCreateInfo image;
125 VkBufferCreateInfo buffer;
Tobin Ehlis6aa77422015-01-07 17:49:29 -0700126 } create_info;
Mark Lobodzinski283a4c22015-03-24 16:29:24 -0500127};
Tobin Ehlis2836a7d2015-01-08 15:22:32 -0700128
Mark Lobodzinski283a4c22015-03-24 16:29:24 -0500129// Track all command buffers
Mark Lobodzinski820d8622015-10-29 15:45:27 -0600130typedef struct _MT_CB_INFO {
Mark Lobodzinskic0e316f2015-11-13 13:47:01 -0700131 VkCommandBufferAllocateInfo createInfo;
Chia-I Wu1f851912015-10-27 18:04:07 +0800132 VkPipeline pipelines[VK_PIPELINE_BIND_POINT_RANGE_SIZE];
Chia-I Wuc278df82015-07-07 11:50:03 +0800133 uint32_t attachmentCount;
Mark Lobodzinskic0e316f2015-11-13 13:47:01 -0700134 VkCommandBuffer commandBuffer;
Mark Lobodzinskia908b162015-04-21 15:33:04 -0600135 uint64_t fenceId;
Mike Stroyan53430332015-05-19 15:16:08 -0600136 VkFence lastSubmittedFence;
137 VkQueue lastSubmittedQueue;
Michael Lentine6306a5a2015-11-24 17:55:33 -0600138 VkRenderPass pass;
Mark Lobodzinski283a4c22015-03-24 16:29:24 -0500139 // Order dependent, stl containers must be at end of struct
Mark Lobodzinskia908b162015-04-21 15:33:04 -0600140 list<VkDeviceMemory> pMemObjList; // List container of Mem objs referenced by this CB
Mark Lobodzinski820d8622015-10-29 15:45:27 -0600141 // Constructor
142 _MT_CB_INFO():createInfo{},pipelines{},attachmentCount(0),fenceId(0),lastSubmittedFence{},lastSubmittedQueue{} {};
143} MT_CB_INFO;
Mark Lobodzinski4aad3642015-03-17 10:53:12 -0500144
Mark Lobodzinskic0e316f2015-11-13 13:47:01 -0700145// Track command pools and their command buffers
146typedef struct _MT_CMD_POOL_INFO {
147 VkCommandPoolCreateFlags createFlags;
148 list<VkCommandBuffer> pCommandBuffers; // list container of cmd buffers allocated from this pool
149} MT_CMD_POOL_INFO;
150
Michael Lentine6306a5a2015-11-24 17:55:33 -0600151struct MT_IMAGE_VIEW_INFO {
152 VkImage image;
153};
154
155struct MT_FB_ATTACHMENT_INFO {
156 VkImage image;
157 VkDeviceMemory mem;
158};
159
160struct MT_FB_INFO {
161 std::vector<MT_FB_ATTACHMENT_INFO> attachments;
162};
163
164struct MT_PASS_ATTACHMENT_INFO {
Michael Lentinea3c1c002015-12-22 11:36:14 -0600165 uint32_t attachment;
Michael Lentine6306a5a2015-11-24 17:55:33 -0600166 VkAttachmentLoadOp load_op;
Michael Lentinea3c1c002015-12-22 11:36:14 -0600167 VkAttachmentStoreOp store_op;
Michael Lentine6306a5a2015-11-24 17:55:33 -0600168};
169
170struct MT_PASS_INFO {
171 VkFramebuffer fb;
172 std::vector<MT_PASS_ATTACHMENT_INFO> attachments;
Michael Lentinea3c1c002015-12-22 11:36:14 -0600173 std::unordered_map<uint32_t, bool> attachment_first_read;
Michael Lentine6306a5a2015-11-24 17:55:33 -0600174};
175
Mark Lobodzinski85a83982015-04-02 08:52:53 -0500176// Associate fenceId with a fence object
Mark Lobodzinski7a428ce2015-03-31 16:05:35 -0500177struct MT_FENCE_INFO {
Mark Lobodzinskic0e316f2015-11-13 13:47:01 -0700178 uint64_t fenceId; // Sequence number for fence at last submit
179 VkQueue queue; // Queue that this fence is submitted against or NULL
Tobin Ehlis92f12cd2015-07-08 17:08:02 -0600180 VkFenceCreateInfo createInfo;
Mark Lobodzinski283a4c22015-03-24 16:29:24 -0500181};
Mark Lobodzinski4aad3642015-03-17 10:53:12 -0500182
Mark Lobodzinski85a83982015-04-02 08:52:53 -0500183// Track Queue information
184struct MT_QUEUE_INFO {
Mark Lobodzinskia908b162015-04-21 15:33:04 -0600185 uint64_t lastRetiredId;
186 uint64_t lastSubmittedId;
Mark Lobodzinskic0e316f2015-11-13 13:47:01 -0700187 list<VkCommandBuffer> pQueueCommandBuffers;
Mark Lobodzinskia908b162015-04-21 15:33:04 -0600188 list<VkDeviceMemory> pMemRefList;
Mark Lobodzinski85a83982015-04-02 08:52:53 -0500189};
190
Mark Lobodzinski2a253072015-10-08 10:44:07 -0600191// Track Swapchain Information
Chia-I Wu5b66aa52015-04-16 22:02:10 +0800192struct MT_SWAP_CHAIN_INFO {
Mark Lobodzinski2a253072015-10-08 10:44:07 -0600193 VkSwapchainCreateInfoKHR createInfo;
194 std::vector<VkImage> images;
Chia-I Wu5b66aa52015-04-16 22:02:10 +0800195};
196
Mark Lobodzinski283a4c22015-03-24 16:29:24 -0500197#ifdef __cplusplus
198}
199#endif