blob: fd924c5c211b977b61763e8bc42192ee2582eadf [file] [log] [blame]
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001#!/usr/bin/env python3
2#
3# Vulkan
4#
Courtney Goeltzenleuchter8a17da52015-10-29 13:50:34 -06005# Copyright (C) 2015 Valve Corporation
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06006#
7# Permission is hereby granted, free of charge, to any person obtaining a
8# copy of this software and associated documentation files (the "Software"),
9# to deal in the Software without restriction, including without limitation
10# the rights to use, copy, modify, merge, publish, distribute, sublicense,
11# and/or sell copies of the Software, and to permit persons to whom the
12# Software is furnished to do so, subject to the following conditions:
13#
14# The above copyright notice and this permission notice shall be included
15# in all copies or substantial portions of the Software.
16#
17# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
20# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
22# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
23# DEALINGS IN THE SOFTWARE.
24#
Courtney Goeltzenleuchter96cd7952015-10-30 11:14:30 -060025# Author: Jon Ashburn <jon@lunarg.com>
26# Author: Tobin Ehlis <tobin@lunarg.com>
Jon Ashburn01e96962015-11-03 11:57:00 -070027# Author: Peter Lohrmann <peterl@valvesoftware.com>
Courtney Goeltzenleuchter96cd7952015-10-30 11:14:30 -060028#
Jon Ashburn4d9cfd22015-08-04 13:35:25 -060029
30import os, sys
Jon Ashburncb622a12015-08-06 17:22:53 -060031
Jon Ashburn4d9cfd22015-08-04 13:35:25 -060032
33# add main repo directory so vulkan.py can be imported. This needs to be a complete path.
Mark Lobodzinski87220f82015-08-27 15:30:29 -060034vktrace_scripts_path = os.path.dirname(os.path.abspath(__file__))
35main_path = os.path.abspath(vktrace_scripts_path + "/../")
Jon Ashburn4d9cfd22015-08-04 13:35:25 -060036sys.path.append(main_path)
Jon Ashburncb622a12015-08-06 17:22:53 -060037from source_line_info import sourcelineinfo
Jon Ashburn4d9cfd22015-08-04 13:35:25 -060038
Jon Ashburncb622a12015-08-06 17:22:53 -060039import vulkan
40
41# vulkan.py doesn't include all the extensions (debug_report missing)
42headers = []
43objects = []
44protos = []
45for ext in vulkan.extensions_all:
46 headers.extend(ext.headers)
47 objects.extend(ext.objects)
48 protos.extend(ext.protos)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -060049
50class Subcommand(object):
51 def __init__(self, argv):
52 self.argv = argv
Chia-I Wu1f851912015-10-27 18:04:07 +080053 self.extensionName = argv
Jon Ashburncb622a12015-08-06 17:22:53 -060054 self.headers = headers
55 self.objects = objects
56 self.protos = protos
Jon Ashburn4d9cfd22015-08-04 13:35:25 -060057 self.lineinfo = sourcelineinfo()
58
59 def run(self):
Chia-I Wu1f851912015-10-27 18:04:07 +080060 print(self.generate(self.extensionName))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -060061
Chia-I Wu1f851912015-10-27 18:04:07 +080062 def generate(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -060063 copyright = self.generate_copyright()
Chia-I Wu1f851912015-10-27 18:04:07 +080064 header = self.generate_header(extensionName)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -060065 body = self.generate_body()
66 footer = self.generate_footer()
67 contents = []
68 if copyright:
69 contents.append(copyright)
70 if header:
71 contents.append(header)
72 if body:
73 contents.append(body)
74 if footer:
75 contents.append(footer)
76
77 return "\n\n".join(contents)
78
79 def generate_copyright(self):
80 return """/* THIS FILE IS GENERATED. DO NOT EDIT. */
81
82/*
Jon Ashburn4d9cfd22015-08-04 13:35:25 -060083 *
Courtney Goeltzenleuchter8a17da52015-10-29 13:50:34 -060084 * Copyright (C) 2015 Valve Corporation
Jon Ashburn4d9cfd22015-08-04 13:35:25 -060085 *
86 * Permission is hereby granted, free of charge, to any person obtaining a
87 * copy of this software and associated documentation files (the "Software"),
88 * to deal in the Software without restriction, including without limitation
89 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
90 * and/or sell copies of the Software, and to permit persons to whom the
91 * Software is furnished to do so, subject to the following conditions:
92 *
93 * The above copyright notice and this permission notice shall be included
94 * in all copies or substantial portions of the Software.
95 *
96 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
97 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
98 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
99 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
100 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
101 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
102 * DEALINGS IN THE SOFTWARE.
Courtney Goeltzenleuchter96cd7952015-10-30 11:14:30 -0600103 *
104 * Author: Jon Ashburn <jon@lunarg.com>
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600105 */"""
106
Chia-I Wu1f851912015-10-27 18:04:07 +0800107 def generate_header(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600108 return "\n".join(["#include <" + h + ">" for h in self.headers])
109
110 def generate_body(self):
111 pass
112
113 def generate_footer(self):
114 pass
115
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600116 def _generate_trace_func_protos(self):
117 func_protos = []
Jon Ashburn4278f642015-09-11 13:12:02 -0600118 func_protos.append('#ifdef __cplusplus')
119 func_protos.append('extern"C" {')
120 func_protos.append('#endif')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600121 func_protos.append('// Hooked function prototypes\n')
122 for proto in self.protos:
Ian Elliott338dedb2015-08-21 15:09:33 -0600123 if 'Dbg' not in proto.name and 'KHR' not in proto.name:
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600124 func_protos.append('VKTRACER_EXPORT %s;' % proto.c_func(prefix="__HOOKED_vk", attr="VKAPI"))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600125
Jon Ashburn4278f642015-09-11 13:12:02 -0600126 func_protos.append('#ifdef __cplusplus')
127 func_protos.append('}')
128 func_protos.append('#endif')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600129 return "\n".join(func_protos)
130
Chia-I Wu1f851912015-10-27 18:04:07 +0800131 def _generate_trace_func_protos_ext(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600132 func_protos = []
133 func_protos.append('// Hooked function prototypes\n')
Jon Ashburncb622a12015-08-06 17:22:53 -0600134 for ext in vulkan.extensions_all:
Chia-I Wu1f851912015-10-27 18:04:07 +0800135 if (extensionName.lower() == ext.name.lower()):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600136 for proto in ext.protos:
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600137 func_protos.append('VKTRACER_EXPORT %s;' % proto.c_func(prefix="__HOOKED_vk", attr="VKAPI"))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600138
139 return "\n".join(func_protos)
140
141
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600142 def _generate_init_funcs(self):
143 init_tracer = []
144 init_tracer.append('void send_vk_api_version_packet()\n{')
145 init_tracer.append(' packet_vkApiVersion* pPacket;')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600146 init_tracer.append(' vktrace_trace_packet_header* pHeader;')
147 init_tracer.append(' pHeader = vktrace_create_trace_packet(VKTRACE_TID_VULKAN, VKTRACE_TPI_VK_vkApiVersion, sizeof(packet_vkApiVersion), 0);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600148 init_tracer.append(' pPacket = interpret_body_as_vkApiVersion(pHeader);')
149 init_tracer.append(' pPacket->version = VK_API_VERSION;')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600150 init_tracer.append(' vktrace_set_packet_entrypoint_end_time(pHeader);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600151 init_tracer.append(' FINISH_TRACE_PACKET();\n}\n')
152
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600153 init_tracer.append('extern VKTRACE_CRITICAL_SECTION g_memInfoLock;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600154 init_tracer.append('void InitTracer(void)\n{')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600155 init_tracer.append(' const char *ipAddr = vktrace_get_global_var("VKTRACE_LIB_IPADDR");')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600156 init_tracer.append(' if (ipAddr == NULL)')
157 init_tracer.append(' ipAddr = "127.0.0.1";')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600158 init_tracer.append(' gMessageStream = vktrace_MessageStream_create(FALSE, ipAddr, VKTRACE_BASE_PORT + VKTRACE_TID_VULKAN);')
159 init_tracer.append(' vktrace_trace_set_trace_file(vktrace_FileLike_create_msg(gMessageStream));')
160 init_tracer.append(' vktrace_tracelog_set_tracer_id(VKTRACE_TID_VULKAN);')
161 init_tracer.append(' vktrace_create_critical_section(&g_memInfoLock);')
Mark Lobodzinski48837d12015-09-28 12:08:57 -0600162 init_tracer.append(' if (gMessageStream != NULL)')
163 init_tracer.append(' send_vk_api_version_packet();\n}\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600164 return "\n".join(init_tracer)
165
166 # Take a list of params and return a list of dicts w/ ptr param details
167 def _get_packet_ptr_param_list(self, params):
168 ptr_param_list = []
169 # TODO : This is a slightly nicer way to handle custom cases than initial code, however
170 # this can still be further generalized to eliminate more custom code
171 # big case to handle is when ptrs to structs have embedded data that needs to be accounted for in packet
172 custom_ptr_dict = {'VkDeviceCreateInfo': {'add_txt': 'add_VkDeviceCreateInfo_to_packet(pHeader, (VkDeviceCreateInfo**) &(pPacket->pCreateInfo), pCreateInfo)',
173 'finalize_txt': ''},
Chia-I Wu1f851912015-10-27 18:04:07 +0800174 'VkApplicationInfo': {'add_txt': 'add_VkApplicationInfo_to_packet(pHeader, (VkApplicationInfo**)&(pPacket->pApplicationInfo), pApplicationInfo)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600175 'finalize_txt': ''},
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600176 'VkPhysicalDevice': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pGpus), *pGpuCount*sizeof(VkPhysicalDevice), pGpus)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600177 'finalize_txt': 'default'},
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600178 'pDataSize': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pDataSize), sizeof(size_t), &_dataSize)',
179 'finalize_txt': 'vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pDataSize))'},
180# 'pData': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pData), _dataSize, pData)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600181# 'finalize_txt': 'default'},
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600182 'pName': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pName), ((pName != NULL) ? strlen(pName) + 1 : 0), pName)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600183 'finalize_txt': 'default'},
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600184 'pMarker': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pMarker), ((pMarker != NULL) ? strlen(pMarker) + 1 : 0), pMarker)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600185 'finalize_txt': 'default'},
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600186 'pExtName': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pExtName), ((pExtName != NULL) ? strlen(pExtName) + 1 : 0), pExtName)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600187 'finalize_txt': 'default'},
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600188 'pDescriptorSets': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pDescriptorSets), customSize, pDescriptorSets)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600189 'finalize_txt': 'default'},
Chia-I Wu763a7492015-10-26 20:48:51 +0800190 'pSparseMemoryRequirements': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pSparseMemoryRequirements), (*pSparseMemoryRequirementCount) * sizeof(VkSparseImageMemoryRequirements), pSparseMemoryRequirements)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600191 'finalize_txt': 'default'},
Chia-I Wu763a7492015-10-26 20:48:51 +0800192 'VkSparseImageFormatProperties': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pProperties), (*pPropertyCount) * sizeof(VkSparseImageFormatProperties), pProperties)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600193 'finalize_txt': 'default'},
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600194 'VkSparseMemoryBindInfo': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pBindInfo), numBindings * sizeof(VkSparseMemoryBindInfo), pBindInfo)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600195 'finalize_txt': 'default'},
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600196 'VkSparseImageMemoryBindInfo': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pBindInfo), numBindings * sizeof(VkSparseImageMemoryBindInfo), pBindInfo)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600197 'finalize_txt': 'default'},
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600198 'VkFramebufferCreateInfo': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo), sizeof(VkFramebufferCreateInfo), pCreateInfo);\n'
199 ' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo->pColorAttachments), colorCount * sizeof(VkColorAttachmentBindInfo), pCreateInfo->pColorAttachments);\n'
200 ' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo->pDepthStencilAttachment), dsSize, pCreateInfo->pDepthStencilAttachment)',
201 'finalize_txt': 'vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo->pColorAttachments));\n'
202 ' vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo->pDepthStencilAttachment));\n'
203 ' vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo))'},
204 'VkRenderPassCreateInfo': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo), sizeof(VkRenderPassCreateInfo), pCreateInfo);\n'
205 ' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo->pColorFormats), colorCount * sizeof(VkFormat), pCreateInfo->pColorFormats);\n'
206 ' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo->pColorLayouts), colorCount * sizeof(VkImageLayout), pCreateInfo->pColorLayouts);\n'
207 ' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo->pColorLoadOps), colorCount * sizeof(VkAttachmentLoadOp), pCreateInfo->pColorLoadOps);\n'
208 ' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo->pColorStoreOps), colorCount * sizeof(VkAttachmentStoreOp), pCreateInfo->pColorStoreOps);\n'
209 ' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo->pColorLoadClearValues), colorCount * sizeof(VkClearColor), pCreateInfo->pColorLoadClearValues)',
210 'finalize_txt': 'vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo->pColorFormats));\n'
211 ' vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo->pColorLayouts));\n'
212 ' vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo->pColorLoadOps));\n'
213 ' vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo->pColorStoreOps));\n'
214 ' vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo->pColorLoadClearValues));\n'
215 ' vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo))'},
216 'VkPipelineLayoutCreateInfo': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo), sizeof(VkPipelineLayoutCreateInfo), pCreateInfo);\n'
Chia-I Wu763a7492015-10-26 20:48:51 +0800217 ' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo->pSetLayouts), pCreateInfo->setLayoutCount * sizeof(VkDescriptorSetLayout), pCreateInfo->pSetLayouts);',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600218 'finalize_txt': 'vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo->pSetLayouts));\n'
219 ' vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo))'},
Chia-I Wu1f851912015-10-27 18:04:07 +0800220 'VkMemoryAllocateInfo': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pAllocateInfo), sizeof(VkMemoryAllocateInfo), pAllocateInfo);\n'
221 ' add_alloc_memory_to_trace_packet(pHeader, (void**)&(pPacket->pAllocateInfo->pNext), pAllocateInfo->pNext)',
222 'finalize_txt': 'vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pAllocateInfo))'},
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600223# 'VkGraphicsPipelineCreateInfo': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfos), count*sizeof(VkGraphicsPipelineCreateInfo), pCreateInfos);\n'
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600224# ' add_VkGraphicsPipelineCreateInfos_to_trace_packet(pHeader, (VkGraphicsPipelineCreateInfo*)pPacket->pCreateInfos, pCreateInfos, count)',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600225# 'finalize_txt': 'vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfos))'},
226# 'VkComputePipelineCreateInfo': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfos), count*sizeof(VkComputePipelineCreateInfo), pCreateInfos);\n'
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600227# ' add_VkComputePipelineCreateInfos_to_trace_packet(pHeader, (VkComputePipelineCreateInfo*)pPacket->pCreateInfos, pCreateInfos, count)',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600228# 'finalize_txt': 'vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfos))'},
229 'VkDescriptorPoolCreateInfo': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo), sizeof(VkDescriptorPoolCreateInfo), pCreateInfo);\n'
Chia-I Wuc51b1212015-10-27 19:25:11 +0800230 ' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo->pPoolSizes), pCreateInfo->poolSizeCount * sizeof(VkDescriptorPoolSize), pCreateInfo->pPoolSizes)',
231 'finalize_txt': 'vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo->pPoolSizes));\n'
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600232 ' vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo))'},
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600233 'VkDescriptorSetLayoutCreateInfo': {'add_txt': 'add_create_ds_layout_to_trace_packet(pHeader, &pPacket->pCreateInfo, pCreateInfo)',
234 'finalize_txt': '// pCreateInfo finalized in add_create_ds_layout_to_trace_packet'},
Ian Elliott338dedb2015-08-21 15:09:33 -0600235 'VkSwapchainCreateInfoKHR': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo), sizeof(VkSwapchainCreateInfoKHR), pCreateInfo);\n'
236 ' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo->pSurfaceDescription), sizeof(VkSurfaceDescriptionKHR), pCreateInfo->pSurfaceDescription)',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600237 'finalize_txt': 'vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo->pSurfaceDescription));\n'
238 ' vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo))'},
239 'VkShaderModuleCreateInfo': {'add_txt': 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo), sizeof(VkShaderModuleCreateInfo), pCreateInfo);\n'
240 ' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->pCreateInfo->pCode), pPacket->pCreateInfo->codeSize, pCreateInfo->pCode)',
241 'finalize_txt': 'vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo->pCode));\n'
242 ' vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->pCreateInfo))'},
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600243 }
244
245 for p in params:
246 pp_dict = {}
Jon Ashburnbb4e7c12015-09-14 17:30:20 -0600247 if '*' in p.ty and p.name not in ['pTag', 'pUserData']:
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600248 if 'const' in p.ty.lower() and 'count' in params[params.index(p)-1].name.lower():
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600249 pp_dict['add_txt'] = 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->%s), %s*sizeof(%s), %s)' % (p.name, params[params.index(p)-1].name, p.ty.strip('*').replace('const ', ''), p.name)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600250 elif 'pOffsets' == p.name: # TODO : This is a custom case for BindVertexBuffers last param, need to clean this up
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600251 pp_dict['add_txt'] = 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->%s), %s*sizeof(%s), %s)' % (p.name, params[params.index(p)-2].name, p.ty.strip('*').replace('const ', ''), p.name)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600252 elif p.ty.strip('*').replace('const ', '') in custom_ptr_dict:
253 pp_dict['add_txt'] = custom_ptr_dict[p.ty.strip('*').replace('const ', '')]['add_txt']
254 pp_dict['finalize_txt'] = custom_ptr_dict[p.ty.strip('*').replace('const ', '')]['finalize_txt']
255 elif p.name in custom_ptr_dict:
256 pp_dict['add_txt'] = custom_ptr_dict[p.name]['add_txt']
257 pp_dict['finalize_txt'] = custom_ptr_dict[p.name]['finalize_txt']
258 # TODO : This is custom hack to account for 2 pData items with dataSize param for sizing
259 if 'pData' == p.name and 'dataSize' == params[params.index(p)-1].name:
260 pp_dict['add_txt'] = pp_dict['add_txt'].replace('_dataSize', 'dataSize')
Jon Ashburnbb4e7c12015-09-14 17:30:20 -0600261 elif 'void' in p.ty and (p.name == 'pData' or p.name == 'values'):
262 pp_dict['add_txt'] = '//TODO FIXME vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->%s), sizeof(%s), %s)' % (p.name, p.ty.strip('*').replace('const ', ''), p.name)
263 pp_dict['finalize_txt'] = '//TODO FIXME vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->%s))' % (p.name)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600264 else:
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600265 pp_dict['add_txt'] = 'vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(pPacket->%s), sizeof(%s), %s)' % (p.name, p.ty.strip('*').replace('const ', ''), p.name)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600266 if 'finalize_txt' not in pp_dict or 'default' == pp_dict['finalize_txt']:
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600267 pp_dict['finalize_txt'] = 'vktrace_finalize_buffer_address(pHeader, (void**)&(pPacket->%s))' % (p.name)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600268 pp_dict['index'] = params.index(p)
269 ptr_param_list.append(pp_dict)
270 return ptr_param_list
271
272 # Take a list of params and return a list of packet size elements
Chia-I Wu1f851912015-10-27 18:04:07 +0800273 def _get_packet_size(self, extensionName, params):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600274 ps = [] # List of elements to be added together to account for packet size for given params
275 skip_list = [] # store params that are already accounted for so we don't count them twice
276 # Dict of specific params with unique custom sizes
Courtney Goeltzenleuchter8e2f0972015-10-21 17:08:06 -0600277 # TODO: Now using bitfields for all stages, need pSetBindPoints to accomodate that.
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600278 custom_size_dict = {'pSetBindPoints': '(VK_SHADER_STAGE_COMPUTE * sizeof(uint32_t))', # Accounting for largest possible array
Ian Elliott338dedb2015-08-21 15:09:33 -0600279 'VkSwapchainCreateInfoKHR' : 'vk_ext_khr_device_swapchain_size_vkswapchaincreateinfokhr(pCreateInfo)',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600280 }
281 size_func_suffix = ''
Chia-I Wu1f851912015-10-27 18:04:07 +0800282 if extensionName.lower() != "vk_core":
283 size_func_suffix = '_%s' % extensionName.lower()
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600284 for p in params:
285 #First handle custom cases
Chia-I Wu1f851912015-10-27 18:04:07 +0800286 if p.name in ['pCreateInfo', 'pSetLayoutInfoList', 'pBeginInfo', 'pAllocateInfo'] and 'khr' not in p.ty.lower():
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600287 ps.append('get_struct_chain_size%s((void*)%s)' % (size_func_suffix, p.name))
288 skip_list.append(p.name)
289 elif p.name in custom_size_dict:
290 ps.append(custom_size_dict[p.name])
291 skip_list.append(p.name)
292 elif p.ty.strip('*').replace('const ', '') in custom_size_dict:
293 tmp_ty = p.ty.strip('*').replace('const ', '')
294 ps.append(custom_size_dict[tmp_ty])
295 skip_list.append(p.name)
296 # Skip any params already handled
297 if p.name in skip_list:
298 continue
299 # Now check to identify dynamic arrays which depend on two params
300 if 'count' in p.name.lower():
301 next_idx = params.index(p)+1
302 # If next element is a const *, then multiply count and array type
303 if next_idx < len(params) and '*' in params[next_idx].ty and 'const' in params[next_idx].ty.lower():
304 if '*' in p.ty:
305 ps.append('*%s*sizeof(%s)' % (p.name, params[next_idx].ty.strip('*').replace('const ', '')))
306 else:
307 ps.append('%s*sizeof(%s)' % (p.name, params[next_idx].ty.strip('*').replace('const ', '')))
308 skip_list.append(params[next_idx].name)
309 if 'bindingCount' == p.name: # TODO : This is custom case for CmdBindVertexBuffers, need to clean it up
310 ps.append('%s*sizeof(%s)' % (p.name, params[next_idx+1].ty.strip('*').replace('const ', '')))
311 skip_list.append(params[next_idx+1].name)
312 elif '*' in p.ty: # Not a custom array size we're aware of, but ptr so need to account for its size
313 ps.append('sizeof(%s)' % (p.ty.strip('*').replace('const ', '')))
314 elif '*' in p.ty and p.name not in ['pSysMem', 'pReserved']:
315 if 'pData' == p.name:
316 if 'dataSize' == params[params.index(p)-1].name:
317 ps.append('dataSize')
318 elif 'counterCount' == params[params.index(p)-1].name:
319 ps.append('sizeof(%s)' % p.ty.strip('*').replace('const ', ''))
320 else:
321 #ps.append('((pDataSize != NULL && pData != NULL) ? *pDataSize : 0)')
322 ps.append('sizeof(void*)')
323 elif '**' in p.ty and 'void' in p.ty:
324 ps.append('sizeof(void*)')
325 elif 'void' in p.ty:
326 ps.append('sizeof(%s)' % p.name)
327 elif 'char' in p.ty:
328 ps.append('((%s != NULL) ? strlen(%s) + 1 : 0)' % (p.name, p.name))
329 elif 'pDataSize' in p.name:
330 ps.append('((pDataSize != NULL) ? sizeof(size_t) : 0)')
331 elif 'IMAGE_SUBRESOURCE' in p.ty and 'pSubresource' == p.name:
332 ps.append('((pSubresource != NULL) ? sizeof(VkImage_SUBRESOURCE) : 0)')
333 else:
334 ps.append('sizeof(%s)' % (p.ty.strip('*').replace('const ', '')))
335 return ps
336
337 # Generate functions used to trace API calls and store the input and result data into a packet
338 # Here's the general flow of code insertion w/ option items flagged w/ "?"
339 # Result decl?
340 # Packet struct decl
341 # ?Special case : setup call to function first and do custom API call time tracking
342 # CREATE_PACKET
343 # call real entrypoint and get return value (if there is one)
344 # Assign packet values
345 # FINISH packet
346 # return result if needed
Chia-I Wu1f851912015-10-27 18:04:07 +0800347 def _generate_trace_funcs(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600348 func_body = []
Chia-I Wu1f851912015-10-27 18:04:07 +0800349 manually_written_hooked_funcs = ['AllocateMemory',
350 'AllocateDescriptorSets',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600351 'CreateDescriptorPool',
Jon Ashburne70884b2015-08-25 13:33:39 -0600352 'CreateDevice',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600353 'CreateFramebuffer',
354 'CreateInstance',
355 'CreateRenderPass',
356 'CreateGraphicsPipelines',
357 'CreateComputePipelines',
358 'CmdPipelineBarrier',
359 'CmdWaitEvents',
360 'CmdBeginRenderPass',
361 'EnumeratePhysicalDevices',
362 'FreeMemory',
363 'FreeDescriptorSets',
Courtney Goeltzenleuchter3ec31622015-10-20 18:04:07 -0600364 'QueueSubmit',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600365 'FlushMappedMemoryRanges',
Jon Ashburn71654fd2015-09-11 09:18:44 -0600366 'GetDeviceProcAddr',
Jon Ashburn71654fd2015-09-11 09:18:44 -0600367 'GetInstanceProcAddr',
Courtney Goeltzenleuchter74c4ce92015-09-14 17:22:16 -0600368 'EnumerateInstanceExtensionProperties',
369 'EnumerateDeviceExtensionProperties',
370 'EnumerateInstanceLayerProperties',
371 'EnumerateDeviceLayerProperties',
Jon Ashburn9e8755b2015-08-10 08:53:44 -0600372 'GetPhysicalDeviceQueueFamilyProperties',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600373 'GetQueryPoolResults',
374 'MapMemory',
375 'UnmapMemory',
376 'UpdateDescriptorSets',
Ian Elliott338dedb2015-08-21 15:09:33 -0600377 'GetSurfacePropertiesKHR',
378 'GetSurfaceFormatsKHR',
379 'GetSurfacePresentModesKHR',
380 'CreateSwapchainKHR',
381 'GetSwapchainImagesKHR',
382 'QueuePresentKHR',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600383 ]
384
385 # validate the manually_written_hooked_funcs list
386 protoFuncs = [proto.name for proto in self.protos]
387 for func in manually_written_hooked_funcs:
388 if func not in protoFuncs:
389 sys.exit("Entry '%s' in manually_written_hooked_funcs list is not in the vulkan function prototypes" % func)
390
391 # process each of the entrypoint prototypes
Jon Ashburncb622a12015-08-06 17:22:53 -0600392 for ext in vulkan.extensions_all:
Chia-I Wu1f851912015-10-27 18:04:07 +0800393 if ext.name.lower() == extensionName.lower():
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600394 for proto in ext.protos:
395 if proto.name in manually_written_hooked_funcs:
Courtney Goeltzenleuchter3ec31622015-10-20 18:04:07 -0600396 func_body.append( '// __HOOKED_vk%s is manually written. Look in vktrace_lib_trace.cpp\n' % proto.name)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600397 else:
398 raw_packet_update_list = [] # non-ptr elements placed directly into packet
399 ptr_packet_update_list = [] # ptr elements to be updated into packet
400 return_txt = ''
401 packet_size = []
402 in_data_size = False # flag when we need to capture local input size variable for in/out size
403 func_body.append('%s' % self.lineinfo.get())
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600404 func_body.append('VKTRACER_EXPORT %s VKAPI __HOOKED_vk%s(' % (proto.ret, proto.name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600405 for p in proto.params: # TODO : For all of the ptr types, check them for NULL and return 0 if NULL
Chia-I Wua5cd6532015-10-28 18:31:57 +0800406 func_body.append(' %s,' % p.c())
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600407 if '*' in p.ty and p.name not in ['pSysMem', 'pReserved']:
408 if 'pDataSize' in p.name:
409 in_data_size = True;
410 elif 'pfnMsgCallback' == p.name:
411 raw_packet_update_list.append(' PFN_vkDbgMsgCallback* pNonConstCallback = (PFN_vkDbgMsgCallback*)&pPacket->pfnMsgCallback;')
412 raw_packet_update_list.append(' *pNonConstCallback = pfnMsgCallback;')
Chia-I Wua5cd6532015-10-28 18:31:57 +0800413 elif '[' in p.ty:
414 raw_packet_update_list.append(' memcpy((void *) pPacket->%s, %s, sizeof(pPacket->%s));' % (p.name, p.name, p.name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600415 else:
416 raw_packet_update_list.append(' pPacket->%s = %s;' % (p.name, p.name))
417 # Get list of packet size modifiers due to ptr params
Chia-I Wu1f851912015-10-27 18:04:07 +0800418 packet_size = self._get_packet_size(extensionName, proto.params)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600419 ptr_packet_update_list = self._get_packet_ptr_param_list(proto.params)
420 func_body[-1] = func_body[-1].replace(',', ')')
421 # End of function declaration portion, begin function body
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600422 func_body.append('{\n vktrace_trace_packet_header* pHeader;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600423 if 'void' not in proto.ret or '*' in proto.ret:
424 func_body.append(' %s result;' % proto.ret)
425 return_txt = 'result = '
426 if in_data_size:
427 func_body.append(' size_t _dataSize;')
428 func_body.append(' packet_vk%s* pPacket = NULL;' % proto.name)
Jon Ashburnf6754d42015-09-14 16:48:31 -0600429 if proto.name == "DestroyInstance" or proto.name == "DestroyDevice":
430 func_body.append(' dispatch_key key = get_dispatch_key(%s);' % proto.params[0].name)
431
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600432 if (0 == len(packet_size)):
433 func_body.append(' CREATE_TRACE_PACKET(vk%s, 0);' % (proto.name))
434 else:
435 func_body.append(' CREATE_TRACE_PACKET(vk%s, %s);' % (proto.name, ' + '.join(packet_size)))
436
Jon Ashburn71654fd2015-09-11 09:18:44 -0600437 # call down the layer chain and get return value (if there is one)
438 # Note: this logic doesn't work for CreateInstance or CreateDevice but those are handwritten
Chia-I Wu1f851912015-10-27 18:04:07 +0800439 if extensionName == 'vk_debug_marker_lunarg':
Jon Ashburn5afdcf62015-09-14 15:17:36 -0600440 table_txt = 'mdd(%s)->debugMarkerTable' % proto.params[0].name
Jon Ashburn71654fd2015-09-11 09:18:44 -0600441 elif proto.params[0].ty in ['VkInstance', 'VkPhysicalDevice']:
Jon Ashburn5afdcf62015-09-14 15:17:36 -0600442 table_txt = 'mid(%s)->instTable' % proto.params[0].name
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600443 else:
Jon Ashburn5afdcf62015-09-14 15:17:36 -0600444 table_txt = 'mdd(%s)->devTable' % proto.params[0].name
Jon Ashburn71654fd2015-09-11 09:18:44 -0600445 func_body.append(' %s%s.%s;' % (return_txt, table_txt, proto.c_call()))
446 func_body.append(' vktrace_set_packet_entrypoint_end_time(pHeader);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600447
448 if in_data_size:
449 func_body.append(' _dataSize = (pDataSize == NULL || pData == NULL) ? 0 : *pDataSize;')
450 func_body.append(' pPacket = interpret_body_as_vk%s(pHeader);' % proto.name)
451 func_body.append('\n'.join(raw_packet_update_list))
452 for pp_dict in ptr_packet_update_list: #buff_ptr_indices:
453 func_body.append(' %s;' % (pp_dict['add_txt']))
454 if 'void' not in proto.ret or '*' in proto.ret:
455 func_body.append(' pPacket->result = result;')
456 for pp_dict in ptr_packet_update_list:
457 if ('DeviceCreateInfo' not in proto.params[pp_dict['index']].ty):
458 func_body.append(' %s;' % (pp_dict['finalize_txt']))
459 # All buffers should be finalized by now, and the trace packet can be finished (which sends it over the socket)
460 func_body.append(' FINISH_TRACE_PACKET();')
Jon Ashburnf6754d42015-09-14 16:48:31 -0600461 if proto.name == "DestroyInstance":
462 func_body.append(' g_instanceDataMap.erase(key);')
463 elif proto.name == "DestroyDevice":
464 func_body.append(' g_deviceDataMap.erase(key);')
465
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600466 # return result if needed
467 if 'void' not in proto.ret or '*' in proto.ret:
468 func_body.append(' return result;')
469 func_body.append('}\n')
470 return "\n".join(func_body)
471
472 def _generate_packet_id_enum(self):
473 pid_enum = []
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600474 pid_enum.append('enum VKTRACE_TRACE_PACKET_ID_VK')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600475 pid_enum.append('{')
476 first_func = True
477 for proto in self.protos:
478 if first_func:
479 first_func = False
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600480 pid_enum.append(' VKTRACE_TPI_VK_vkApiVersion = VKTRACE_TPI_BEGIN_API_HERE,')
481 pid_enum.append(' VKTRACE_TPI_VK_vk%s,' % proto.name)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600482 else:
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600483 pid_enum.append(' VKTRACE_TPI_VK_vk%s,' % proto.name)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600484 pid_enum.append('};\n')
485 return "\n".join(pid_enum)
486
487 def _generate_packet_id_name_func(self):
488 func_body = []
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600489 func_body.append('static const char *vktrace_vk_packet_id_name(const enum VKTRACE_TRACE_PACKET_ID_VK id)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600490 func_body.append('{')
491 func_body.append(' switch(id) {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600492 func_body.append(' case VKTRACE_TPI_VK_vkApiVersion:')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600493 func_body.append(' {')
494 func_body.append(' return "vkApiVersion";')
495 func_body.append(' }')
496 for proto in self.protos:
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600497 func_body.append(' case VKTRACE_TPI_VK_vk%s:' % proto.name)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600498 func_body.append(' {')
499 func_body.append(' return "vk%s";' % proto.name)
500 func_body.append(' }')
501 func_body.append(' default:')
502 func_body.append(' return NULL;')
503 func_body.append(' }')
504 func_body.append('}\n')
505 return "\n".join(func_body)
506
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600507 def _generate_interp_func(self):
508 interp_func_body = []
509 interp_func_body.append('%s' % self.lineinfo.get())
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600510 interp_func_body.append('static vktrace_trace_packet_header* interpret_trace_packet_vk(vktrace_trace_packet_header* pHeader)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600511 interp_func_body.append('{')
512 interp_func_body.append(' if (pHeader == NULL)')
513 interp_func_body.append(' {')
514 interp_func_body.append(' return NULL;')
515 interp_func_body.append(' }')
516 interp_func_body.append(' switch (pHeader->packet_id)')
517 interp_func_body.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600518 interp_func_body.append(' case VKTRACE_TPI_VK_vkApiVersion:')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600519 interp_func_body.append(' {')
520 interp_func_body.append(' return interpret_body_as_vkApiVersion(pHeader)->header;')
521 interp_func_body.append(' }')
522 for proto in self.protos:
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600523 interp_func_body.append(' case VKTRACE_TPI_VK_vk%s:\n {' % proto.name)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600524 header_prefix = 'h'
Ian Elliott338dedb2015-08-21 15:09:33 -0600525 if 'KHR' in proto.name or 'Dbg' in proto.name:
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600526 header_prefix = 'pH'
527 interp_func_body.append(' return interpret_body_as_vk%s(pHeader)->%seader;\n }' % (proto.name, header_prefix))
528 interp_func_body.append(' default:')
529 interp_func_body.append(' return NULL;')
530 interp_func_body.append(' }')
531 interp_func_body.append(' return NULL;')
532 interp_func_body.append('}')
533 return "\n".join(interp_func_body)
534
535 def _generate_struct_util_funcs(self):
536 lineinfo = self.lineinfo
537 pid_enum = []
538 pid_enum.append('%s' % lineinfo.get())
539 pid_enum.append('//=============================================================================')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600540 pid_enum.append('static void add_VkApplicationInfo_to_packet(vktrace_trace_packet_header* pHeader, VkApplicationInfo** ppStruct, const VkApplicationInfo *pInStruct)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600541 pid_enum.append('{')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600542 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)ppStruct, sizeof(VkApplicationInfo), pInStruct);')
Chia-I Wu1f851912015-10-27 18:04:07 +0800543 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&((*ppStruct)->pApplicationName), strlen(pInStruct->pApplicationName) + 1, pInStruct->pApplicationName);')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600544 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&((*ppStruct)->pEngineName), strlen(pInStruct->pEngineName) + 1, pInStruct->pEngineName);')
Chia-I Wu1f851912015-10-27 18:04:07 +0800545 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void**)&((*ppStruct)->pApplicationName));')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600546 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void**)&((*ppStruct)->pEngineName));')
547 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void**)&*ppStruct);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600548 pid_enum.append('};\n')
549 pid_enum.append('%s' % lineinfo.get())
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600550 pid_enum.append('static void add_VkInstanceCreateInfo_to_packet(vktrace_trace_packet_header* pHeader, VkInstanceCreateInfo** ppStruct, VkInstanceCreateInfo *pInStruct)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600551 pid_enum.append('{')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600552 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)ppStruct, sizeof(VkInstanceCreateInfo), pInStruct);')
Chia-I Wu1f851912015-10-27 18:04:07 +0800553 pid_enum.append(' add_VkApplicationInfo_to_packet(pHeader, (VkApplicationInfo**)&((*ppStruct)->pApplicationInfo), pInStruct->pApplicationInfo);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600554 # TODO138 : This is an initial pass at getting the extension/layer arrays correct, needs to be validated.
555 pid_enum.append(' uint32_t i, siz = 0;')
Chia-I Wu763a7492015-10-26 20:48:51 +0800556 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&((*ppStruct)->ppEnabledLayerNames), pInStruct->enabledLayerNameCount * sizeof(char*), pInStruct->ppEnabledLayerNames);')
557 pid_enum.append(' if (pInStruct->enabledLayerNameCount > 0) ')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600558 pid_enum.append(' {')
Chia-I Wu763a7492015-10-26 20:48:51 +0800559 pid_enum.append(' for (i = 0; i < pInStruct->enabledLayerNameCount; i++) {')
Jon Ashburn5bd87b92015-10-07 10:23:30 -0600560 pid_enum.append(' siz = (uint32_t) (1 + strlen(pInStruct->ppEnabledLayerNames[i]));')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600561 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)(&(*ppStruct)->ppEnabledLayerNames[i]), siz, pInStruct->ppEnabledLayerNames[i]);')
562 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void **)&(*ppStruct)->ppEnabledLayerNames[i]);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600563 pid_enum.append(' }')
564 pid_enum.append(' }')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600565 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void **)&(*ppStruct)->ppEnabledLayerNames);')
Chia-I Wu763a7492015-10-26 20:48:51 +0800566 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&((*ppStruct)->ppEnabledExtensionNames), pInStruct->enabledExtensionNameCount * sizeof(char*), pInStruct->ppEnabledExtensionNames);')
567 pid_enum.append(' if (pInStruct->enabledExtensionNameCount > 0) ')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600568 pid_enum.append(' {')
Chia-I Wu763a7492015-10-26 20:48:51 +0800569 pid_enum.append(' for (i = 0; i < pInStruct->enabledExtensionNameCount; i++) {')
Jon Ashburn5bd87b92015-10-07 10:23:30 -0600570 pid_enum.append(' siz = (uint32_t) (1 + strlen(pInStruct->ppEnabledExtensionNames[i]));')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600571 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)(&(*ppStruct)->ppEnabledExtensionNames[i]), siz, pInStruct->ppEnabledExtensionNames[i]);')
572 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void **)&(*ppStruct)->ppEnabledExtensionNames[i]);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600573 pid_enum.append(' }')
574 pid_enum.append(' }')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600575 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void **)&(*ppStruct)->ppEnabledExtensionNames);')
576 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void**)ppStruct);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600577 pid_enum.append('}\n')
578 pid_enum.append('%s' % lineinfo.get())
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600579 pid_enum.append('static void add_VkDeviceCreateInfo_to_packet(vktrace_trace_packet_header* pHeader, VkDeviceCreateInfo** ppStruct, const VkDeviceCreateInfo *pInStruct)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600580 pid_enum.append('{')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600581 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)ppStruct, sizeof(VkDeviceCreateInfo), pInStruct);')
Courtney Goeltzenleuchterdfd53f52015-10-15 16:58:44 -0600582 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(*ppStruct)->pRequestedQueues, pInStruct->requestedQueueCount*sizeof(VkDeviceQueueCreateInfo), pInStruct->pRequestedQueues);')
Courtney Goeltzenleuchterd3a8d362015-10-23 10:37:02 -0600583 pid_enum.append(' for (uint32_t i = 0; i < pInStruct->requestedQueueCount; i++) {')
584 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(*ppStruct)->pRequestedQueues[i].pQueuePriorities,')
Chia-I Wu763a7492015-10-26 20:48:51 +0800585 pid_enum.append(' pInStruct->pRequestedQueues[i].queuePriorityCount*sizeof(float),')
Courtney Goeltzenleuchterd3a8d362015-10-23 10:37:02 -0600586 pid_enum.append(' pInStruct->pRequestedQueues[i].pQueuePriorities);')
Jon Ashburne27a9182015-10-16 17:50:47 -0600587 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void**)&(*ppStruct)->pRequestedQueues[i].pQueuePriorities);')
Courtney Goeltzenleuchterd3a8d362015-10-23 10:37:02 -0600588 pid_enum.append(' }')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600589 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void**)&(*ppStruct)->pRequestedQueues);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600590 # TODO138 : This is an initial pass at getting the extension/layer arrays correct, needs to be validated.
591 pid_enum.append(' uint32_t i, siz = 0;')
Chia-I Wu763a7492015-10-26 20:48:51 +0800592 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&((*ppStruct)->ppEnabledLayerNames), pInStruct->enabledLayerNameCount * sizeof(char*), pInStruct->ppEnabledLayerNames);')
593 pid_enum.append(' if (pInStruct->enabledLayerNameCount > 0) ')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600594 pid_enum.append(' {')
Chia-I Wu763a7492015-10-26 20:48:51 +0800595 pid_enum.append(' for (i = 0; i < pInStruct->enabledLayerNameCount; i++) {')
Jon Ashburn5bd87b92015-10-07 10:23:30 -0600596 pid_enum.append(' siz = (uint32_t) (1 + strlen(pInStruct->ppEnabledLayerNames[i]));')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600597 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)(&(*ppStruct)->ppEnabledLayerNames[i]), siz, pInStruct->ppEnabledLayerNames[i]);')
598 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void **)&(*ppStruct)->ppEnabledLayerNames[i]);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600599 pid_enum.append(' }')
600 pid_enum.append(' }')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600601 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void **)&(*ppStruct)->ppEnabledLayerNames);')
Chia-I Wu763a7492015-10-26 20:48:51 +0800602 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&((*ppStruct)->ppEnabledExtensionNames), pInStruct->enabledExtensionNameCount * sizeof(char*), pInStruct->ppEnabledExtensionNames);')
603 pid_enum.append(' if (pInStruct->enabledExtensionNameCount > 0) ')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600604 pid_enum.append(' {')
Chia-I Wu763a7492015-10-26 20:48:51 +0800605 pid_enum.append(' for (i = 0; i < pInStruct->enabledExtensionNameCount; i++) {')
Jon Ashburn5bd87b92015-10-07 10:23:30 -0600606 pid_enum.append(' siz = (uint32_t) (1 + strlen(pInStruct->ppEnabledExtensionNames[i]));')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600607 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)(&(*ppStruct)->ppEnabledExtensionNames[i]), siz, pInStruct->ppEnabledExtensionNames[i]);')
608 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void **)&(*ppStruct)->ppEnabledExtensionNames[i]);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600609 pid_enum.append(' }')
610 pid_enum.append(' }')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600611 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void **)&(*ppStruct)->ppEnabledExtensionNames);')
612 pid_enum.append(' vktrace_add_buffer_to_trace_packet(pHeader, (void**)&(*ppStruct)->pEnabledFeatures, sizeof(VkPhysicalDeviceFeatures), pInStruct->pEnabledFeatures);')
613 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void**)&(*ppStruct)->pEnabledFeatures);')
614 pid_enum.append(' vktrace_finalize_buffer_address(pHeader, (void**)ppStruct);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600615 pid_enum.append('}\n')
616 pid_enum.append('%s' % lineinfo.get())
617 pid_enum.append('//=============================================================================\n')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600618 pid_enum.append('static VkInstanceCreateInfo* interpret_VkInstanceCreateInfo(vktrace_trace_packet_header* pHeader, intptr_t ptr_variable)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600619 pid_enum.append('{')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600620 pid_enum.append(' VkInstanceCreateInfo* pVkInstanceCreateInfo = (VkInstanceCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)ptr_variable);\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600621 pid_enum.append(' uint32_t i;')
622 pid_enum.append(' if (pVkInstanceCreateInfo != NULL)')
623 pid_enum.append(' {')
Chia-I Wu1f851912015-10-27 18:04:07 +0800624 pid_enum.append(' pVkInstanceCreateInfo->pApplicationInfo = (VkApplicationInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkInstanceCreateInfo->pApplicationInfo);')
625 pid_enum.append(' VkApplicationInfo** ppApplicationInfo = (VkApplicationInfo**) &pVkInstanceCreateInfo->pApplicationInfo;')
626 pid_enum.append(' (*ppApplicationInfo)->pApplicationName = (const char*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkInstanceCreateInfo->pApplicationInfo->pApplicationName);')
627 pid_enum.append(' (*ppApplicationInfo)->pEngineName = (const char*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkInstanceCreateInfo->pApplicationInfo->pEngineName);')
Chia-I Wu763a7492015-10-26 20:48:51 +0800628 pid_enum.append(' if (pVkInstanceCreateInfo->enabledLayerNameCount > 0)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600629 pid_enum.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600630 pid_enum.append(' pVkInstanceCreateInfo->ppEnabledLayerNames = (const char* const*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkInstanceCreateInfo->ppEnabledLayerNames);')
Chia-I Wu763a7492015-10-26 20:48:51 +0800631 pid_enum.append(' for (i = 0; i < pVkInstanceCreateInfo->enabledLayerNameCount; i++) {')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600632 pid_enum.append(' char** ppTmp = (char**)&pVkInstanceCreateInfo->ppEnabledLayerNames[i];')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600633 pid_enum.append(' *ppTmp = (char*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkInstanceCreateInfo->ppEnabledLayerNames[i]);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600634 pid_enum.append(' }')
635 pid_enum.append(' }')
Chia-I Wu763a7492015-10-26 20:48:51 +0800636 pid_enum.append(' if (pVkInstanceCreateInfo->enabledExtensionNameCount > 0)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600637 pid_enum.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600638 pid_enum.append(' pVkInstanceCreateInfo->ppEnabledExtensionNames = (const char* const*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkInstanceCreateInfo->ppEnabledExtensionNames);')
Chia-I Wu763a7492015-10-26 20:48:51 +0800639 pid_enum.append(' for (i = 0; i < pVkInstanceCreateInfo->enabledExtensionNameCount; i++) {')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600640 pid_enum.append(' char** ppTmp = (char**)&pVkInstanceCreateInfo->ppEnabledExtensionNames[i];')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600641 pid_enum.append(' *ppTmp = (char*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkInstanceCreateInfo->ppEnabledExtensionNames[i]);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600642 pid_enum.append(' }')
643 pid_enum.append(' }')
644 pid_enum.append(' }\n')
645 pid_enum.append(' return pVkInstanceCreateInfo;')
646 pid_enum.append('}\n')
647 pid_enum.append('%s' % lineinfo.get())
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600648 pid_enum.append('static VkDeviceCreateInfo* interpret_VkDeviceCreateInfo(vktrace_trace_packet_header* pHeader, intptr_t ptr_variable)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600649 pid_enum.append('{')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600650 pid_enum.append(' VkDeviceCreateInfo* pVkDeviceCreateInfo = (VkDeviceCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)ptr_variable);\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600651 pid_enum.append(' uint32_t i;')
652 pid_enum.append(' if (pVkDeviceCreateInfo != NULL)')
653 pid_enum.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600654 pid_enum.append(' pVkDeviceCreateInfo->pRequestedQueues = (const VkDeviceQueueCreateInfo *)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkDeviceCreateInfo->pRequestedQueues);\n')
Chia-I Wu763a7492015-10-26 20:48:51 +0800655 pid_enum.append(' if (pVkDeviceCreateInfo->enabledLayerNameCount > 0)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600656 pid_enum.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600657 pid_enum.append(' pVkDeviceCreateInfo->ppEnabledLayerNames = (const char* const*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkDeviceCreateInfo->ppEnabledLayerNames);')
Chia-I Wu763a7492015-10-26 20:48:51 +0800658 pid_enum.append(' for (i = 0; i < pVkDeviceCreateInfo->enabledLayerNameCount; i++) {')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600659 pid_enum.append(' char** ppTmp = (char**)&pVkDeviceCreateInfo->ppEnabledLayerNames[i];')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600660 pid_enum.append(' *ppTmp = (char*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkDeviceCreateInfo->ppEnabledLayerNames[i]);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600661 pid_enum.append(' }')
662 pid_enum.append(' }')
Chia-I Wu763a7492015-10-26 20:48:51 +0800663 pid_enum.append(' if (pVkDeviceCreateInfo->enabledExtensionNameCount > 0)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600664 pid_enum.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600665 pid_enum.append(' pVkDeviceCreateInfo->ppEnabledExtensionNames = (const char* const*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkDeviceCreateInfo->ppEnabledExtensionNames);')
Chia-I Wu763a7492015-10-26 20:48:51 +0800666 pid_enum.append(' for (i = 0; i < pVkDeviceCreateInfo->enabledExtensionNameCount; i++) {')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600667 pid_enum.append(' char** ppTmp = (char**)&pVkDeviceCreateInfo->ppEnabledExtensionNames[i];')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600668 pid_enum.append(' *ppTmp = (char*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkDeviceCreateInfo->ppEnabledExtensionNames[i]);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600669 pid_enum.append(' }')
670 pid_enum.append(' }')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600671 pid_enum.append(' pVkDeviceCreateInfo->pEnabledFeatures = (const VkPhysicalDeviceFeatures*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pVkDeviceCreateInfo->pEnabledFeatures);\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600672 pid_enum.append(' }\n')
673 pid_enum.append(' return pVkDeviceCreateInfo;')
674 pid_enum.append('}\n')
675 pid_enum.append('%s' % lineinfo.get())
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600676 pid_enum.append('static void interpret_VkPipelineShaderStageCreateInfo(vktrace_trace_packet_header* pHeader, VkPipelineShaderStageCreateInfo* pShader)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600677 pid_enum.append('{')
678 pid_enum.append(' if (pShader != NULL)')
679 pid_enum.append(' {')
Chia-I Wu062ad152015-10-31 00:31:16 +0800680 pid_enum.append(' pShader->pName = (const char*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pShader->pName);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600681 pid_enum.append(' // specialization info')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600682 pid_enum.append(' pShader->pSpecializationInfo = (const VkSpecializationInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pShader->pSpecializationInfo);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600683 pid_enum.append(' if (pShader->pSpecializationInfo != NULL)')
684 pid_enum.append(' {')
685 pid_enum.append(' VkSpecializationInfo* pInfo = (VkSpecializationInfo*)pShader->pSpecializationInfo;')
Chia-I Wu483e7702015-10-26 17:20:32 +0800686 pid_enum.append(' pInfo->pMapEntries = (const VkSpecializationMapEntry*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pShader->pSpecializationInfo->pMapEntries);')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600687 pid_enum.append(' pInfo->pData = (const void*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pShader->pSpecializationInfo->pData);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600688 pid_enum.append(' }')
689 pid_enum.append(' }')
690 pid_enum.append('}\n')
691 pid_enum.append('//=============================================================================')
692 return "\n".join(pid_enum)
693
694 # Interpret functions used on replay to read in packets and interpret their contents
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -0600695 # This code gets generated into vktrace_vk_vk_packets.h file
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600696 def _generate_interp_funcs(self):
697 # Custom txt for given function and parameter. First check if param is NULL, then insert txt if not
698 # First some common code used by both CmdWaitEvents & CmdPipelineBarrier
699 mem_barrier_interp = ['uint32_t i = 0;\n',
Chia-I Wu1f851912015-10-27 18:04:07 +0800700 'for (i = 0; i < pPacket->memoryBarrierCount; i++) {\n',
701 ' void** ppMB = (void**)&(pPacket->ppMemoryBarriers[i]);\n',
702 ' *ppMB = vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->ppMemoryBarriers[i]);\n',
703 ' //VkMemoryBarrier* pBarr = (VkMemoryBarrier*)pPacket->ppMemoryBarriers[i];\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600704 ' // TODO : Could fix up the pNext ptrs here if they were finalized and if we cared by switching on Barrier type and remapping\n',
705 '}']
706 create_rp_interp = ['VkRenderPassCreateInfo* pInfo = (VkRenderPassCreateInfo*)pPacket->pCreateInfo;\n',
707 'uint32_t i = 0;\n',
708 'VkAttachmentDescription **ppAD = (VkAttachmentDescription **)&(pInfo->pAttachments);\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600709 '*ppAD = (VkAttachmentDescription*) vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pInfo->pAttachments);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600710 'VkSubpassDescription** ppSP = (VkSubpassDescription**)&(pInfo->pSubpasses);\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600711 '*ppSP = (VkSubpassDescription*) vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pInfo->pSubpasses);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600712 'for (i=0; i<pInfo->subpassCount; i++) {\n',
Jon Ashburn9e8755b2015-08-10 08:53:44 -0600713 ' VkAttachmentReference** pAR = (VkAttachmentReference**)&(pInfo->pSubpasses[i].pInputAttachments);\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600714 ' *pAR = (VkAttachmentReference*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pInfo->pSubpasses[i].pInputAttachments);\n',
Jon Ashburn9e8755b2015-08-10 08:53:44 -0600715 ' pAR = (VkAttachmentReference**)&(pInfo->pSubpasses[i].pColorAttachments);\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600716 ' *pAR = (VkAttachmentReference*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pInfo->pSubpasses[i].pColorAttachments);\n',
Jon Ashburn9e8755b2015-08-10 08:53:44 -0600717 ' pAR = (VkAttachmentReference**)&(pInfo->pSubpasses[i].pResolveAttachments);\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600718 ' *pAR = (VkAttachmentReference*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pInfo->pSubpasses[i].pResolveAttachments);\n',
Chia-I Wuce532f72015-10-26 17:32:47 +0800719 ' pAR = (VkAttachmentReference**)&(pInfo->pSubpasses[i].pDepthStencilAttachment);\n',
720 ' *pAR = (VkAttachmentReference*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pInfo->pSubpasses[i].pDepthStencilAttachment);\n',
Jon Ashburn9e8755b2015-08-10 08:53:44 -0600721 ' pAR = (VkAttachmentReference**)&(pInfo->pSubpasses[i].pPreserveAttachments);\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600722 ' *pAR = (VkAttachmentReference*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pInfo->pSubpasses[i].pPreserveAttachments);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600723 '}\n',
724 'VkSubpassDependency** ppSD = (VkSubpassDependency**)&(pInfo->pDependencies);\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600725 '*ppSD = (VkSubpassDependency*) vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pInfo->pDependencies);\n']
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600726 create_gfx_pipe = ['uint32_t i;\n',
727 'uint32_t j;\n',
Chia-I Wu763a7492015-10-26 20:48:51 +0800728 'for (i=0; i<pPacket->createInfoCount; i++) {\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600729 'if (pPacket->pCreateInfos[i].sType == VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO) {\n',
730 '// need to make a non-const pointer to the pointer so that we can properly change the original pointer to the interpretted one\n',
731 'VkGraphicsPipelineCreateInfo* pNonConst = (VkGraphicsPipelineCreateInfo*)&(pPacket->pCreateInfos[i]);\n',
732 '// shader stages array\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600733 'pNonConst->pStages = (VkPipelineShaderStageCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pStages);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600734 'for (j = 0; j < pPacket->pCreateInfos[i].stageCount; j++)\n',
735 '{\n',
736 ' interpret_VkPipelineShaderStageCreateInfo(pHeader, (VkPipelineShaderStageCreateInfo*)&pPacket->pCreateInfos[i].pStages[j]);\n',
737 '}\n',
738 '// Vertex Input State\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600739 'pNonConst->pVertexInputState = (VkPipelineVertexInputStateCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pVertexInputState);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600740 'VkPipelineVertexInputStateCreateInfo* pNonConstVIState = (VkPipelineVertexInputStateCreateInfo*)pNonConst->pVertexInputState;\n',
741 'if (pNonConstVIState) {\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600742 ' pNonConstVIState->pVertexBindingDescriptions = (const VkVertexInputBindingDescription*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pVertexInputState->pVertexBindingDescriptions);\n',
743 ' pNonConstVIState->pVertexAttributeDescriptions = (const VkVertexInputAttributeDescription*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pVertexInputState->pVertexAttributeDescriptions);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600744 '}\n',
745 '// Input Assembly State\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600746 'pNonConst->pInputAssemblyState = (const VkPipelineInputAssemblyStateCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pInputAssemblyState);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600747 '// Tesselation State\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600748 'pNonConst->pTessellationState = (const VkPipelineTessellationStateCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pTessellationState);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600749 '// Viewport State\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600750 'pNonConst->pViewportState = (const VkPipelineViewportStateCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pViewportState);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600751 '// Raster State\n',
Chia-I Wu1f851912015-10-27 18:04:07 +0800752 'pNonConst->pRasterizationState = (const VkPipelineRasterizationStateCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pRasterizationState);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600753 '// MultiSample State\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600754 'pNonConst->pMultisampleState = (const VkPipelineMultisampleStateCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pMultisampleState);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600755 '// DepthStencil State\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600756 'pNonConst->pDepthStencilState = (const VkPipelineDepthStencilStateCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pDepthStencilState);\n',
Courtney Goeltzenleuchter1c9f9892015-09-30 16:08:38 -0600757 '// DynamicState State\n',
758 'pNonConst->pDynamicState = (const VkPipelineDynamicStateCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pDynamicState);\n',
759 'VkPipelineDynamicStateCreateInfo* pNonConstDyState = (VkPipelineDynamicStateCreateInfo*)pNonConst->pDynamicState;\n',
760 'if (pNonConstDyState) {\n',
761 ' pNonConstDyState->pDynamicStates = (const VkDynamicState*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pDynamicState->pDynamicStates);\n',
762 '}\n',
763
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600764 '// ColorBuffer State\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600765 'pNonConst->pColorBlendState = (const VkPipelineColorBlendStateCreateInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pColorBlendState);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600766 'VkPipelineColorBlendStateCreateInfo* pNonConstCbState = (VkPipelineColorBlendStateCreateInfo*)pNonConst->pColorBlendState;\n',
767 'if (pNonConstCbState)\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600768 ' pNonConstCbState->pAttachments = (const VkPipelineColorBlendAttachmentState*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfos[i].pColorBlendState->pAttachments);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600769 '} else {\n',
770 ' // This is unexpected.\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600771 ' vktrace_LogError("CreateGraphicsPipelines must have CreateInfo stype of VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO.");\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600772 ' pPacket->header = NULL;\n',
773 '}\n',
774 '}\n']
775 # TODO : This code is now too large and complex, need to make codegen smarter for pointers embedded in struct params to handle those cases automatically
776 # TODO138 : Just ripped out a bunch of custom code here that was out of date. Need to scrub these function and verify they're correct
Chia-I Wu062ad152015-10-31 00:31:16 +0800777 custom_case_dict = { #'CreateFramebuffer' : {'param': 'pCreateInfo', 'txt': ['VkFramebufferCreateInfo* pInfo = (VkFramebufferCreateInfo*)pPacket->pCreateInfo;\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600778 # 'pInfo->pColorAttachments = (VkColorAttachmentBindInfo*) vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfo->pColorAttachments);\n',
779 # 'pInfo->pDepthStencilAttachment = (VkDepthStencilBindInfo*) vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfo->pDepthStencilAttachment);\n']},
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600780 'CreateRenderPass' : {'param': 'pCreateInfo', 'txt': create_rp_interp},
781 'CreatePipelineLayout' : {'param': 'pCreateInfo', 'txt': ['VkPipelineLayoutCreateInfo* pInfo = (VkPipelineLayoutCreateInfo*)pPacket->pCreateInfo;\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600782 'pInfo->pSetLayouts = (VkDescriptorSetLayout*) vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfo->pSetLayouts);\n']},
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600783 'CreateDescriptorPool' : {'param': 'pCreateInfo', 'txt': ['VkDescriptorPoolCreateInfo* pInfo = (VkDescriptorPoolCreateInfo*)pPacket->pCreateInfo;\n',
Chia-I Wuc51b1212015-10-27 19:25:11 +0800784 'pInfo->pPoolSizes = (VkDescriptorPoolSize*) vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfo->pPoolSizes);\n']},
Chia-I Wu1f851912015-10-27 18:04:07 +0800785 'CmdWaitEvents' : {'param': 'ppMemoryBarriers', 'txt': mem_barrier_interp},
786 'CmdPipelineBarrier' : {'param': 'ppMemoryBarriers', 'txt': mem_barrier_interp},
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600787 'CreateDescriptorSetLayout' : {'param': 'pCreateInfo', 'txt': ['if (pPacket->pCreateInfo->sType == VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO) {\n',
788 ' VkDescriptorSetLayoutCreateInfo* pNext = (VkDescriptorSetLayoutCreateInfo*)pPacket->pCreateInfo;\n',
789 ' do\n',' {\n',
790 ' // need to make a non-const pointer to the pointer so that we can properly change the original pointer to the interpretted one\n',
791 ' void** ppNextVoidPtr = (void**)&(pNext->pNext);\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600792 ' *ppNextVoidPtr = (void*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pNext->pNext);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600793 ' switch(pNext->sType)\n', ' {\n',
794 ' case VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO:\n',
795 ' {\n' ,
796 ' unsigned int i = 0;\n',
Chia-I Wuf03cbf72015-10-31 00:31:16 +0800797 ' pNext->pBinding = (VkDescriptorSetLayoutBinding*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pNext->pBinding);\n',
Chia-I Wu763a7492015-10-26 20:48:51 +0800798 ' for (i = 0; i < pNext->bindingCount; i++)\n',' {\n',
Chia-I Wuf03cbf72015-10-31 00:31:16 +0800799 ' VkSampler** ppSamplers = (VkSampler**)&(pNext->pBinding[i].pImmutableSamplers);\n',
800 ' *ppSamplers = (VkSampler*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pNext->pBinding[i].pImmutableSamplers);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600801 ' }\n',
802 ' break;\n',
803 ' }\n',
804 ' default:\n',
805 ' {\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600806 ' vktrace_LogError("Encountered an unexpected type in descriptor set layout create list.");\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600807 ' pPacket->header = NULL;\n',
808 ' pNext->pNext = NULL;\n',
809 ' }\n',
810 ' }\n',
811 ' pNext = (VkDescriptorSetLayoutCreateInfo*)pNext->pNext;\n',
812 ' } while (NULL != pNext);\n',
813 '} else {\n',
814 ' // This is unexpected.\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600815 ' vktrace_LogError("CreateDescriptorSetLayout must have pCreateInfo->stype of VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO.");\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600816 ' pPacket->header = NULL;\n',
817 '}']},
Chia-I Wu1f851912015-10-27 18:04:07 +0800818# 'BeginCommandBuffer' : {'param': 'pBeginInfo', 'txt': ['if (pPacket->pBeginInfo->sType == VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO) {\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600819# ' // need to make a non-const pointer to the pointer so that we can properly change the original pointer to the interpretted one\n',
Chia-I Wu1f851912015-10-27 18:04:07 +0800820# ' VkCommandBufferGraphicsBeginInfo** ppNext = (VkCommandBufferGraphicsBeginInfo**)&(pPacket->pBeginInfo->pNext);\n',
821# ' *ppNext = (VkCommandBufferGraphicsBeginInfo*) vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pBeginInfo->pNext);\n',
822# ' VkCommandBufferGraphicsBeginInfo* pNext = *ppNext;\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600823# ' while (NULL != pNext)\n', ' {\n',
824# ' switch(pNext->sType)\n', ' {\n',
Chia-I Wu1f851912015-10-27 18:04:07 +0800825# ' case VK_STRUCTURE_TYPE_COMMAND_BUFFER_GRAPHICS_BEGIN_INFO:\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600826# ' {\n',
Chia-I Wu1f851912015-10-27 18:04:07 +0800827# ' ppNext = (VkCommandBufferGraphicsBeginInfo**) &pNext->pNext;\n',
828# ' *ppNext = (VkCommandBufferGraphicsBeginInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pNext->pNext);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600829# ' break;\n',
830# ' }\n',
831# ' default:\n',
832# ' {\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600833# ' vktrace_LogError("Encountered an unexpected type in begin command buffer list.");\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600834# ' pPacket->header = NULL;\n',
835# ' pNext->pNext = NULL;\n',
836# ' }\n',
837# ' }\n',
Chia-I Wu1f851912015-10-27 18:04:07 +0800838# ' pNext = (VkCommandBufferGraphicsBeginInfo*)pNext->pNext;\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600839# ' }\n',
840# '} else {\n',
841# ' // This is unexpected.\n',
Chia-I Wu1f851912015-10-27 18:04:07 +0800842# ' vktrace_LogError("BeginCommandBuffer must have BeginInfo stype of VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO.");\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600843# ' pPacket->header = NULL;\n',
844# '}']},
Chia-I Wu1f851912015-10-27 18:04:07 +0800845 'AllocateMemory' : {'param': 'pAllocateInfo', 'txt': ['if (pPacket->pAllocateInfo->sType == VK_STRUCTURE_TYPE_MEMORY_ALLOC_INFO) {\n',
846 ' VkMemoryAllocateInfo** ppNext = (VkMemoryAllocateInfo**) &(pPacket->pAllocateInfo->pNext);\n',
847 ' *ppNext = (VkMemoryAllocateInfo*) vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pAllocateInfo->pNext);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600848 '} else {\n',
849 ' // This is unexpected.\n',
Chia-I Wu1f851912015-10-27 18:04:07 +0800850 ' vktrace_LogError("AllocateMemory must have AllocInfo stype of VK_STRUCTURE_TYPE_MEMORY_ALLOC_INFO.");\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600851 ' pPacket->header = NULL;\n',
852 '}']},
Chia-I Wu1f851912015-10-27 18:04:07 +0800853 'AllocateDescriptorSets' : {'param': 'pAllocateInfo', 'txt':
854 ['VkDescriptorSetLayout **ppDescSetLayout = (VkDescriptorSetLayout **) &pPacket->pAllocateInfo->pSetLayouts;\n'
855 ' *ppDescSetLayout = (VkDescriptorSetLayout *) vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)(pPacket->pAllocateInfo->pSetLayouts));']},
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600856 'UpdateDescriptorSets' : {'param': 'pDescriptorWrites', 'txt':
857 [ 'uint32_t i;\n',
Chia-I Wu483e7702015-10-26 17:20:32 +0800858 'for (i = 0; i < pPacket->descriptorWriteCount; i++) {\n',
Courtney Goeltzenleuchter34aa5c82015-10-23 13:38:14 -0600859 ' switch (pPacket->pDescriptorWrites[i].descriptorType) {',
860 ' case VK_DESCRIPTOR_TYPE_SAMPLER:',
861 ' case VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER:',
862 ' case VK_DESCRIPTOR_TYPE_SAMPLED_IMAGE:',
863 ' case VK_DESCRIPTOR_TYPE_STORAGE_IMAGE:',
864 ' {',
865 ' VkDescriptorImageInfo** ppImageInfo = (VkDescriptorImageInfo**)&pPacket->pDescriptorWrites[i].pImageInfo;\n',
866 ' *ppImageInfo = (VkDescriptorImageInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pDescriptorWrites[i].pImageInfo);\n',
867 ' }',
868 ' break;',
869 ' case VK_DESCRIPTOR_TYPE_UNIFORM_TEXEL_BUFFER:',
870 ' case VK_DESCRIPTOR_TYPE_STORAGE_TEXEL_BUFFER:',
871 ' {',
872 ' VkBufferView** ppTexelBufferView = (VkBufferView**)&pPacket->pDescriptorWrites[i].pTexelBufferView;\n',
873 ' *ppTexelBufferView = (VkBufferView*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pDescriptorWrites[i].pTexelBufferView);\n',
874 ' }',
875 ' break;',
876 ' case VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER:',
877 ' case VK_DESCRIPTOR_TYPE_STORAGE_BUFFER:',
878 ' case VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER_DYNAMIC:',
879 ' case VK_DESCRIPTOR_TYPE_STORAGE_BUFFER_DYNAMIC:',
880 ' {',
881 ' VkDescriptorBufferInfo** ppBufferInfo = (VkDescriptorBufferInfo**)&pPacket->pDescriptorWrites[i].pBufferInfo;\n',
882 ' *ppBufferInfo = (VkDescriptorBufferInfo*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pDescriptorWrites[i].pBufferInfo);\n',
883 ' }',
884 ' break;',
885 ' default:',
886 ' break;',
887 ' }',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600888 '}'
889 ]},
Chia-I Wu483e7702015-10-26 17:20:32 +0800890 'QueueSubmit' : {'param': 'pSubmits', 'txt':
Courtney Goeltzenleuchter3ec31622015-10-20 18:04:07 -0600891 [ 'uint32_t i;\n',
892 'for (i = 0; i < pPacket->submitCount; i++) {\n',
Chia-I Wu1f851912015-10-27 18:04:07 +0800893 ' VkCommandBuffer** ppCBs = (VkCommandBuffer**)&pPacket->pSubmits[i].pCommandBuffers;\n',
894 ' *ppCBs = (VkCommandBuffer*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pSubmits[i].pCommandBuffers);\n',
Chia-I Wu483e7702015-10-26 17:20:32 +0800895 ' VkSemaphore** ppSems = (VkSemaphore**)&pPacket->pSubmits[i].pWaitSemaphores;\n',
896 ' *ppSems = (VkSemaphore*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pSubmits[i].pWaitSemaphores);\n',
897 ' ppSems = (VkSemaphore**)&pPacket->pSubmits[i].pSignalSemaphores;\n',
898 ' *ppSems = (VkSemaphore*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pSubmits[i].pSignalSemaphores);\n',
Courtney Goeltzenleuchter3ec31622015-10-20 18:04:07 -0600899 '}'
900 ]},
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600901 'CreateGraphicsPipelines' : {'param': 'pCreateInfos', 'txt': create_gfx_pipe},
902 'CreateComputePipeline' : {'param': 'pCreateInfo', 'txt': ['interpret_VkPipelineShaderStageCreateInfo(pHeader, (VkPipelineShaderStageCreateInfo*)(&pPacket->pCreateInfo->cs));']},
Courtney Goeltzenleuchter1856d6f2015-09-01 17:30:39 -0600903 'CreateFramebuffer' : {'param': 'pCreateInfo', 'txt': ['VkImageView** ppAV = (VkImageView**)&(pPacket->pCreateInfo->pAttachments);\n',
904 '*ppAV = (VkImageView*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)(pPacket->pCreateInfo->pAttachments));']},
Jon Ashburn9e8755b2015-08-10 08:53:44 -0600905 'CmdBeginRenderPass' : {'param': 'pRenderPassBegin', 'txt': ['VkClearValue** ppCV = (VkClearValue**)&(pPacket->pRenderPassBegin->pClearValues);\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600906 '*ppCV = (VkClearValue*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)(pPacket->pRenderPassBegin->pClearValues));']},
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600907 'CreateShaderModule' : {'param': 'pCreateInfo', 'txt': ['void** ppCode = (void**)&(pPacket->pCreateInfo->pCode);\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600908 '*ppCode = (void*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->pCreateInfo->pCode);']},
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600909 'FlushMappedMemoryRanges' : {'param': 'ppData', 'txt': ['uint32_t i = 0;\n',
Chia-I Wu1f851912015-10-27 18:04:07 +0800910 'for (i = 0; i < pPacket->memoryRangeCount; i++)\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600911 '{\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600912 ' pPacket->ppData[i] = (void*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->ppData[i]);\n',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600913 '}']}}
914 if_body = []
915 if_body.append('typedef struct packet_vkApiVersion {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600916 if_body.append(' vktrace_trace_packet_header* header;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600917 if_body.append(' uint32_t version;')
918 if_body.append('} packet_vkApiVersion;\n')
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600919 if_body.append('static packet_vkApiVersion* interpret_body_as_vkApiVersion(vktrace_trace_packet_header* pHeader)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600920 if_body.append('{')
921 if_body.append(' packet_vkApiVersion* pPacket = (packet_vkApiVersion*)pHeader->pBody;')
922 if_body.append(' pPacket->header = pHeader;')
923 if_body.append(' return pPacket;')
924 if_body.append('}\n')
925 for proto in self.protos:
Ian Elliott338dedb2015-08-21 15:09:33 -0600926 if 'KHR' not in proto.name and 'Dbg' not in proto.name:
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600927 if 'UnmapMemory' == proto.name:
928 proto.params.append(vulkan.Param("void*", "pData"))
929 elif 'FlushMappedMemoryRanges' == proto.name:
930 proto.params.append(vulkan.Param("void**", "ppData"))
931 if_body.append('%s' % self.lineinfo.get())
932 if_body.append('typedef struct packet_vk%s {' % proto.name)
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600933 if_body.append(' vktrace_trace_packet_header* header;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600934 for p in proto.params:
Chia-I Wua5cd6532015-10-28 18:31:57 +0800935 if_body.append(' %s;' % p.c())
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600936 if 'void' != proto.ret:
937 if_body.append(' %s result;' % proto.ret)
938 if_body.append('} packet_vk%s;\n' % proto.name)
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600939 if_body.append('static packet_vk%s* interpret_body_as_vk%s(vktrace_trace_packet_header* pHeader)' % (proto.name, proto.name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600940 if_body.append('{')
941 if_body.append(' packet_vk%s* pPacket = (packet_vk%s*)pHeader->pBody;' % (proto.name, proto.name))
942 if_body.append(' pPacket->header = pHeader;')
943 for p in proto.params:
944 if '*' in p.ty:
945 if 'DeviceCreateInfo' in p.ty:
946 if_body.append(' pPacket->%s = interpret_VkDeviceCreateInfo(pHeader, (intptr_t)pPacket->%s);' % (p.name, p.name))
947 elif 'InstanceCreateInfo' in p.ty:
948 if_body.append(' pPacket->%s = interpret_VkInstanceCreateInfo(pHeader, (intptr_t)pPacket->%s);' % (p.name, p.name))
949 else:
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600950 if_body.append(' pPacket->%s = (%s)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->%s);' % (p.name, p.ty, p.name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600951 # TODO : Generalize this custom code to kill dict data struct above.
952 # Really the point of this block is to catch params w/ embedded ptrs to structs and chains of structs
953 if proto.name in custom_case_dict and p.name == custom_case_dict[proto.name]['param']:
954 if_body.append(' if (pPacket->%s != NULL)' % custom_case_dict[proto.name]['param'])
955 if_body.append(' {')
956 if_body.append(' %s' % " ".join(custom_case_dict[proto.name]['txt']))
957 if_body.append(' }')
958 if_body.append(' return pPacket;')
959 if_body.append('}\n')
960 return "\n".join(if_body)
961
Chia-I Wu1f851912015-10-27 18:04:07 +0800962 def _generate_interp_funcs_ext(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600963 if_body = []
Ian Elliott338dedb2015-08-21 15:09:33 -0600964 custom_case_dict = { 'QueuePresentKHR' : {'param': 'pPresentInfo', 'txt': ['pPacket->pPresentInfo->swapchains = (VkSwapchainKHR*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)(pPacket->pPresentInfo->swapchains));\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600965 'pPacket->pPresentInfo->imageIndices = (uint32_t*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)(pPacket->pPresentInfo->imageIndices));']},
Ian Elliott338dedb2015-08-21 15:09:33 -0600966 'CreateSwapchainKHR' : {'param': 'pCreateInfo', 'txt': ['VkSurfaceDescriptionKHR **ppSurfDescp = (VkSurfaceDescriptionKHR**)&pPacket->pCreateInfo->pSurfaceDescription;\n',
Jon Ashburnc51afc72015-08-11 16:01:35 -0600967 'uint32_t **ppQFI = (uint32_t**)&pPacket->pCreateInfo->pQueueFamilyIndices;\n',
Ian Elliott338dedb2015-08-21 15:09:33 -0600968 '(*ppSurfDescp) = (VkSurfaceDescriptionKHR*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)(pPacket->pCreateInfo->pSurfaceDescription));\n',
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600969 '(*ppQFI) = (uint32_t*)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)(pPacket->pCreateInfo->pQueueFamilyIndices));']},
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600970 }
Jon Ashburncb622a12015-08-06 17:22:53 -0600971 for ext in vulkan.extensions_all:
Chia-I Wu1f851912015-10-27 18:04:07 +0800972 if ext.name.lower() == extensionName.lower():
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600973 for proto in ext.protos:
974 if_body.append('typedef struct packet_vk%s {' % proto.name)
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600975 if_body.append(' vktrace_trace_packet_header* pHeader;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600976 for p in proto.params:
Chia-I Wua5cd6532015-10-28 18:31:57 +0800977 if_body.append(' %s;' % p.c())
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600978 if 'void' != proto.ret:
979 if_body.append(' %s result;' % proto.ret)
980 if_body.append('} packet_vk%s;\n' % proto.name)
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600981 if_body.append('static packet_vk%s* interpret_body_as_vk%s(vktrace_trace_packet_header* pHeader)' % (proto.name, proto.name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600982 if_body.append('{')
983 if_body.append(' packet_vk%s* pPacket = (packet_vk%s*)pHeader->pBody;' % (proto.name, proto.name))
984 if_body.append(' pPacket->pHeader = pHeader;')
985 for p in proto.params:
986 if '*' in p.ty:
Mark Lobodzinski87220f82015-08-27 15:30:29 -0600987 if_body.append(' pPacket->%s = (%s)vktrace_trace_packet_interpret_buffer_pointer(pHeader, (intptr_t)pPacket->%s);' % (p.name, p.ty, p.name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -0600988 # TODO : Generalize this custom code to kill dict data struct above.
989 # Really the point of this block is to catch params w/ embedded ptrs to structs and chains of structs
990 if proto.name in custom_case_dict and p.name == custom_case_dict[proto.name]['param']:
991 if_body.append(' if (pPacket->%s != NULL)' % custom_case_dict[proto.name]['param'])
992 if_body.append(' {')
993 if_body.append(' %s' % " ".join(custom_case_dict[proto.name]['txt']))
994 if_body.append(' }')
995 if_body.append(' return pPacket;')
996 if_body.append('}\n')
997 return "\n".join(if_body)
998
999 def _generate_replay_func_ptrs(self):
1000 xf_body = []
1001 xf_body.append('struct vkFuncs {')
1002 xf_body.append(' void init_funcs(void * libHandle);')
1003 xf_body.append(' void *m_libHandle;\n')
1004 for proto in self.protos:
1005 xf_body.append(' typedef %s( VKAPI * type_vk%s)(' % (proto.ret, proto.name))
1006 for p in proto.params:
Chia-I Wua5cd6532015-10-28 18:31:57 +08001007 xf_body.append(' %s,' % p.c())
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001008 xf_body[-1] = xf_body[-1].replace(',', ');')
1009 xf_body.append(' type_vk%s real_vk%s;' % (proto.name, proto.name))
1010 xf_body.append('};')
1011 return "\n".join(xf_body)
1012
1013 def _map_decl(self, type1, type2, name):
1014 return ' std::map<%s, %s> %s;' % (type1, type2, name)
1015
1016 def _add_to_map_decl(self, type1, type2, name):
1017 txt = ' void add_to_%s_map(%s pTraceVal, %s pReplayVal)\n {\n' % (name[2:], type1, type2)
1018 #TODO138 : These checks need to vary between disp & non-disp objects
1019 #txt += ' assert(pTraceVal != 0);\n'
1020 #txt += ' assert(pReplayVal != 0);\n'
1021 txt += ' %s[pTraceVal] = pReplayVal;\n }\n' % name
1022 return txt
1023
1024 def _rm_from_map_decl(self, ty, name):
1025 txt = ' void rm_from_%s_map(const %s& key)\n {\n' % (name[2:], ty)
1026 txt += ' %s.erase(key);\n }\n' % name
1027 return txt
1028
1029 def _remap_decl(self, ty, name):
1030 txt = ' %s remap_%s(const %s& value)\n {\n' % (ty, name[2:], ty)
1031 txt += ' if (value == 0) { return 0; }\n'
1032 txt += ' std::map<%s, %s>::const_iterator q = %s.find(value);\n' % (ty, ty, name)
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001033 txt += ' if (q == %s.end()) { vktrace_LogError("Failed to remap %s."); return value; }\n' % (name, ty)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001034 txt += ' return q->second;\n }\n'
1035 return txt
1036
1037 def _generate_replay_objMemory_funcs(self):
1038 rof_body = []
1039 # Custom code for memory mapping functions for app writes into mapped memory
1040 rof_body.append('// memory mapping functions for app writes into mapped memory')
1041 rof_body.append(' bool isPendingAlloc()')
1042 rof_body.append(' {')
1043 rof_body.append(' return m_pendingAlloc;')
1044 rof_body.append(' }')
1045 rof_body.append('')
Chia-I Wu1f851912015-10-27 18:04:07 +08001046 rof_body.append(' void setAllocInfo(const VkMemoryAllocateInfo *info, const bool pending)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001047 rof_body.append(' {')
1048 rof_body.append(' m_pendingAlloc = pending;')
1049 rof_body.append(' m_allocInfo = *info;')
1050 rof_body.append(' }')
1051 rof_body.append('')
1052 rof_body.append(' void setMemoryDataAddr(void *pBuf)')
1053 rof_body.append(' {')
1054 rof_body.append(' if (m_mapRange.empty())')
1055 rof_body.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001056 rof_body.append(' vktrace_LogError("gpuMemory::setMemoryDataAddr() m_mapRange is empty.");')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001057 rof_body.append(' return;')
1058 rof_body.append(' }')
1059 rof_body.append(' MapRange mr = m_mapRange.back();')
1060 rof_body.append(' if (mr.pData != NULL)')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001061 rof_body.append(' vktrace_LogWarning("gpuMemory::setMemoryDataAddr() data already mapped overwrite old mapping.");')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001062 rof_body.append(' else if (pBuf == NULL)')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001063 rof_body.append(' vktrace_LogWarning("gpuMemory::setMemoryDataAddr() adding NULL pointer.");')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001064 rof_body.append(' mr.pData = (uint8_t *) pBuf;')
1065 rof_body.append(' }')
1066 rof_body.append('')
1067 rof_body.append(' void setMemoryMapRange(void *pBuf, const size_t size, const size_t offset, const bool pending)')
1068 rof_body.append(' {')
1069 rof_body.append(' MapRange mr;')
1070 rof_body.append(' mr.pData = (uint8_t *) pBuf;')
1071 rof_body.append(' if (size == 0)')
1072 rof_body.append(' mr.size = m_allocInfo.allocationSize - offset;')
1073 rof_body.append(' else')
1074 rof_body.append(' mr.size = size;')
1075 rof_body.append(' mr.offset = offset;')
1076 rof_body.append(' mr.pending = pending;')
1077 rof_body.append(' m_mapRange.push_back(mr);')
1078 rof_body.append(' assert(m_allocInfo.allocationSize >= (size + offset));')
1079 rof_body.append(' }')
1080 rof_body.append('')
1081 rof_body.append(' void copyMappingData(const void* pSrcData, bool entire_map, size_t size, size_t offset)')
1082 rof_body.append(' {')
1083 rof_body.append(' if (m_mapRange.empty())')
1084 rof_body.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001085 rof_body.append(' vktrace_LogError("gpuMemory::copyMappingData() m_mapRange is empty.");')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001086 rof_body.append(' return;')
1087 rof_body.append(' }')
1088 rof_body.append(' MapRange mr = m_mapRange.back();')
1089 rof_body.append(' if (!pSrcData || !mr.pData)')
1090 rof_body.append(' {')
1091 rof_body.append(' if (!pSrcData)')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001092 rof_body.append(' vktrace_LogError("gpuMemory::copyMappingData() null src pointer.");')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001093 rof_body.append(' else')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001094 rof_body.append(' vktrace_LogError("gpuMemory::copyMappingData() null dest pointer totalSize=%u.", m_allocInfo.allocationSize);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001095 rof_body.append(' m_mapRange.pop_back();')
1096 rof_body.append(' return;')
1097 rof_body.append(' }')
1098 rof_body.append(' if (entire_map)')
1099 rof_body.append(' {')
1100 rof_body.append(' size = mr.size;')
1101 rof_body.append(' offset = mr.offset;')
1102 rof_body.append(' }')
1103 rof_body.append(' else')
1104 rof_body.append(' {')
1105 rof_body.append(' assert(offset >= mr.offset);')
1106 rof_body.append(' assert(size <= mr.size && (size + offset) <= mr.size);')
1107 rof_body.append(' }')
1108 rof_body.append(' memcpy(mr.pData + offset, pSrcData, size);')
1109 rof_body.append(' if (!mr.pending && entire_map)')
1110 rof_body.append(' m_mapRange.pop_back();')
1111 rof_body.append(' }')
1112 rof_body.append('')
1113 rof_body.append(' size_t getMemoryMapSize()')
1114 rof_body.append(' {')
1115 rof_body.append(' return (!m_mapRange.empty()) ? m_mapRange.back().size : 0;')
1116 rof_body.append(' }\n')
1117 return "\n".join(rof_body)
1118
1119 def _generate_replay_objmapper_class(self):
1120 # Create dict mapping member var names to VK type (i.e. 'm_imageViews' : 'VkImage_VIEW')
1121 obj_map_dict = {}
1122 for obj in vulkan.object_type_list:
Jon Ashburncb622a12015-08-06 17:22:53 -06001123 if (obj.startswith('Vk')):
1124 mem_var = obj.replace('Vk', '').lower()
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001125 mem_var_list = mem_var.split('_')
1126 mem_var = 'm_%s%ss' % (mem_var_list[0], "".join([m.title() for m in mem_var_list[1:]]))
Jon Ashburncb622a12015-08-06 17:22:53 -06001127 obj_map_dict[mem_var] = obj
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001128 rc_body = []
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001129 rc_body.append('#define VKTRACE_VK_OBJECT_TYPE_UNKNOWN (VkObjectType)-1')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001130 rc_body.append('')
1131 rc_body.append('typedef struct _VKAllocInfo {')
1132 rc_body.append(' VkDeviceSize size;')
1133 rc_body.append(' uint8_t *pData;')
1134 rc_body.append(' bool rangeUpdated;')
1135 rc_body.append('} VKAllocInfo;')
1136 rc_body.append('')
1137 rc_body.append('class objMemory {')
1138 rc_body.append('public:')
1139 rc_body.append(' objMemory() : m_numAllocations(0), m_pMemReqs(NULL) {}')
1140 rc_body.append(' ~objMemory() { free(m_pMemReqs);}')
1141 rc_body.append(' void setCount(const uint32_t num)')
1142 rc_body.append(' {')
1143 rc_body.append(' m_numAllocations = num;')
1144 rc_body.append(' }\n')
1145 rc_body.append(' void setReqs(const VkMemoryRequirements *pReqs, const uint32_t num)')
1146 rc_body.append(' {')
1147 rc_body.append(' if (m_numAllocations != num && m_numAllocations != 0)')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001148 rc_body.append(' vktrace_LogError("objMemory::setReqs, internal mismatch on number of allocations.");')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001149 rc_body.append(' if (m_pMemReqs == NULL && pReqs != NULL)')
1150 rc_body.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001151 rc_body.append(' m_pMemReqs = (VkMemoryRequirements *) vktrace_malloc(num * sizeof(VkMemoryRequirements));')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001152 rc_body.append(' if (m_pMemReqs == NULL)')
1153 rc_body.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001154 rc_body.append(' vktrace_LogError("objMemory::setReqs out of memory.");')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001155 rc_body.append(' return;')
1156 rc_body.append(' }')
1157 rc_body.append(' memcpy(m_pMemReqs, pReqs, num * sizeof(VkMemoryRequirements));')
1158 rc_body.append(' }')
1159 rc_body.append(' }\n')
1160 rc_body.append('private:')
1161 rc_body.append(' uint32_t m_numAllocations;')
1162 rc_body.append(' VkMemoryRequirements *m_pMemReqs;')
1163 rc_body.append('};')
1164 rc_body.append('')
1165 rc_body.append('class gpuMemory {')
1166 rc_body.append('public:')
1167 rc_body.append(' gpuMemory() : m_pendingAlloc(false) {m_allocInfo.allocationSize = 0;}')
1168 rc_body.append(' ~gpuMemory() {}')
1169 rc_body.append(self._generate_replay_objMemory_funcs())
1170 rc_body.append('private:')
1171 rc_body.append(' bool m_pendingAlloc;')
1172 rc_body.append(' struct MapRange {')
1173 rc_body.append(' bool pending;')
1174 rc_body.append(' size_t size;')
1175 rc_body.append(' size_t offset;')
1176 rc_body.append(' uint8_t* pData;')
1177 rc_body.append(' };')
1178 rc_body.append(' std::vector<MapRange> m_mapRange;')
Chia-I Wu1f851912015-10-27 18:04:07 +08001179 rc_body.append(' VkMemoryAllocateInfo m_allocInfo;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001180 rc_body.append('};')
1181 rc_body.append('')
1182 rc_body.append('typedef struct _imageObj {')
1183 rc_body.append(' objMemory imageMem;')
1184 rc_body.append(' VkImage replayImage;')
1185 rc_body.append(' } imageObj;')
1186 rc_body.append('')
1187 rc_body.append('typedef struct _bufferObj {')
1188 rc_body.append(' objMemory bufferMem;')
1189 rc_body.append(' VkBuffer replayBuffer;')
1190 rc_body.append(' } bufferObj;')
1191 rc_body.append('')
1192 rc_body.append('typedef struct _gpuMemObj {')
1193 rc_body.append(' gpuMemory *pGpuMem;')
1194 rc_body.append(' VkDeviceMemory replayGpuMem;')
1195 rc_body.append(' } gpuMemObj;')
1196 rc_body.append('')
1197 rc_body.append('')
1198 rc_body.append('class vkReplayObjMapper {')
1199 rc_body.append('public:')
1200 rc_body.append(' vkReplayObjMapper() {}')
1201 rc_body.append(' ~vkReplayObjMapper() {}')
1202 rc_body.append('')
1203 rc_body.append(' bool m_adjustForGPU; // true if replay adjusts behavior based on GPU')
1204 # Code for memory objects for handling replay GPU != trace GPU object memory requirements
1205 rc_body.append('void init_objMemCount(const uint64_t handle, const VkDbgObjectType objectType, const uint32_t &num)\n {')
1206 rc_body.append(' switch (objectType) {')
1207 rc_body.append(' case VK_OBJECT_TYPE_BUFFER:')
1208 rc_body.append(' {')
Chia-I Wue420a332015-10-26 20:04:44 +08001209 rc_body.append(' std::map<VkBuffer, bufferObj>::iterator it = m_buffers.find((VkBuffer) handle);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001210 rc_body.append(' if (it != m_buffers.end()) {')
1211 rc_body.append(' objMemory obj = it->second.bufferMem;')
1212 rc_body.append(' obj.setCount(num);')
1213 rc_body.append(' return;')
1214 rc_body.append(' }')
1215 rc_body.append(' break;')
1216 rc_body.append(' }')
1217 rc_body.append(' case VK_OBJECT_TYPE_IMAGE:')
1218 rc_body.append(' {')
Chia-I Wue420a332015-10-26 20:04:44 +08001219 rc_body.append(' std::map<VkImage, imageObj>::iterator it = m_images.find((VkImage) handle);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001220 rc_body.append(' if (it != m_images.end()) {')
1221 rc_body.append(' objMemory obj = it->second.imageMem;')
1222 rc_body.append(' obj.setCount(num);')
1223 rc_body.append(' return;')
1224 rc_body.append(' }')
1225 rc_body.append(' break;')
1226 rc_body.append(' }')
1227 rc_body.append(' default:')
1228 rc_body.append(' break;')
1229 rc_body.append(' }')
1230 rc_body.append(' return;')
1231 rc_body.append('}\n')
1232 rc_body.append('void init_objMemReqs(const uint64_t handle, const VkDbgObjectType objectType, const VkMemoryRequirements *pMemReqs, const unsigned int num)\n {')
1233 rc_body.append(' switch (objectType) {')
1234 rc_body.append(' case VK_OBJECT_TYPE_BUFFER:')
1235 rc_body.append(' {')
Chia-I Wue420a332015-10-26 20:04:44 +08001236 rc_body.append(' std::map<VkBuffer, bufferObj>::iterator it = m_buffers.find((VkBuffer) handle);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001237 rc_body.append(' if (it != m_buffers.end()) {')
1238 rc_body.append(' objMemory obj = it->second.bufferMem;')
1239 rc_body.append(' obj.setReqs(pMemReqs, num);')
1240 rc_body.append(' return;')
1241 rc_body.append(' }')
1242 rc_body.append(' break;')
1243 rc_body.append(' }')
1244 rc_body.append(' case VK_OBJECT_TYPE_IMAGE:')
1245 rc_body.append(' {')
Chia-I Wue420a332015-10-26 20:04:44 +08001246 rc_body.append(' std::map<VkImage, imageObj>::iterator it = m_images.find((VkImage) handle);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001247 rc_body.append(' if (it != m_images.end()) {')
1248 rc_body.append(' objMemory obj = it->second.imageMem;')
1249 rc_body.append(' obj.setReqs(pMemReqs, num);')
1250 rc_body.append(' return;')
1251 rc_body.append(' }')
1252 rc_body.append(' break;')
1253 rc_body.append(' }')
1254 rc_body.append(' default:')
1255 rc_body.append(' break;')
1256 rc_body.append(' }')
1257 rc_body.append(' return;')
1258 rc_body.append(' }')
1259 rc_body.append('')
1260 rc_body.append(' void clear_all_map_handles()\n {')
1261 for var in sorted(obj_map_dict):
1262 rc_body.append(' %s.clear();' % var)
1263 rc_body.append(' }\n')
Jon Ashburncb622a12015-08-06 17:22:53 -06001264 disp_obj_types = [obj for obj in vulkan.object_dispatch_list]
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001265 for var in sorted(obj_map_dict):
Chia-I Wue420a332015-10-26 20:04:44 +08001266 if obj_map_dict[var] == 'VkImage':
1267 rc_body.append(self._map_decl('VkImage', 'imageObj', var))
1268 rc_body.append(self._add_to_map_decl('VkImage', 'imageObj', var))
1269 rc_body.append(self._rm_from_map_decl('VkImage', var))
1270 rc_body.append(' VkImage remap_images(const VkImage& value)')
1271 rc_body.append(' {')
1272 rc_body.append(' if (value == 0) { return 0; }')
1273 rc_body.append('')
1274 rc_body.append(' std::map<VkImage, imageObj>::const_iterator q = m_images.find(value);')
1275 rc_body.append(' if (q == m_images.end()) { vktrace_LogError("Failed to remap VkImage."); return value; }\n')
1276 rc_body.append(' return q->second.replayImage;')
1277 rc_body.append(' }\n')
1278 elif obj_map_dict[var] == 'VkBuffer':
1279 rc_body.append(self._map_decl('VkBuffer', 'bufferObj', var))
1280 rc_body.append(self._add_to_map_decl('VkBuffer', 'bufferObj', var))
1281 rc_body.append(self._rm_from_map_decl('VkBuffer', var))
1282 rc_body.append(' VkBuffer remap_buffers(const VkBuffer& value)')
1283 rc_body.append(' {')
1284 rc_body.append(' if (value == 0) { return 0; }')
1285 rc_body.append('')
1286 rc_body.append(' std::map<VkBuffer, bufferObj>::const_iterator q = m_buffers.find(value);')
1287 rc_body.append(' if (q == m_buffers.end()) { vktrace_LogError("Failed to remap VkBuffer."); return value; }\n')
1288 rc_body.append(' return q->second.replayBuffer;')
1289 rc_body.append(' }\n')
1290 elif obj_map_dict[var] == 'VkDeviceMemory':
1291 rc_body.append(self._map_decl('VkDeviceMemory', 'gpuMemObj', var))
1292 rc_body.append(self._add_to_map_decl('VkDeviceMemory', 'gpuMemObj', var))
1293 rc_body.append(self._rm_from_map_decl('VkDeviceMemory', var))
1294 rc_body.append(' VkDeviceMemory remap_devicememorys(const VkDeviceMemory& value)')
1295 rc_body.append(' {')
1296 rc_body.append(' if (value == 0) { return 0; }')
1297 rc_body.append('')
1298 rc_body.append(' std::map<VkDeviceMemory, gpuMemObj>::const_iterator q = m_devicememorys.find(value);')
1299 rc_body.append(' if (q == m_devicememorys.end()) { vktrace_LogError("Failed to remap VkDeviceMemory."); return value; }')
1300 rc_body.append(' return q->second.replayGpuMem;')
1301 rc_body.append(' }\n')
1302 else:
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001303 rc_body.append(self._map_decl(obj_map_dict[var], obj_map_dict[var], var))
1304 rc_body.append(self._add_to_map_decl(obj_map_dict[var], obj_map_dict[var], var))
1305 rc_body.append(self._rm_from_map_decl(obj_map_dict[var], var))
1306 rc_body.append(self._remap_decl(obj_map_dict[var], var))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001307 # VkDynamicStateObject code
1308# TODO138 : Each dynamic state object is now unique so need to make sure their re-mapping is being handled correctly
1309# state_obj_remap_types = vulkan.object_dynamic_state_list
1310# state_obj_bindings = vulkan.object_dynamic_state_bind_point_list
1311# rc_body.append(' VkDynamicStateObject remap(const VkDynamicStateObject& state, const VkStateBindPoint& bindPoint)\n {')
1312# rc_body.append(' VkDynamicStateObject obj;')
1313# index = 0
1314# while index < len(state_obj_remap_types):
1315# obj = state_obj_remap_types[index]
1316# type = state_obj_bindings[index]
1317# rc_body.append(' if (bindPoint == %s) {' % type)
1318# rc_body.append(' if ((obj = remap(static_cast <%s> (state))) != VK_NULL_HANDLE)' % obj.type)
1319# rc_body.append(' return obj;')
1320# rc_body.append(' }')
1321# index += 1
1322# for obj in state_obj_remap_types:
1323# rc_body.append('// if ((obj = remap(static_cast <%s> (state))) != VK_NULL_HANDLE)' % obj.type)
1324# rc_body.append('// return obj;')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001325# rc_body.append(' vktrace_LogWarning("Failed to remap VkDynamicStateObject.");')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001326# rc_body.append(' return VK_NULL_HANDLE;\n }')
1327# rc_body.append(' void rm_from_map(const VkDynamicStateObject& state)\n {')
1328# for obj in state_obj_remap_types:
1329# rc_body.append(' rm_from_map(static_cast <%s> (state));' % obj.type)
1330# rc_body.append(' }')
1331# rc_body.append('')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001332 rc_body.append('};')
1333 return "\n".join(rc_body)
1334
1335 def _generate_replay_init_funcs(self):
1336 rif_body = []
1337 rif_body.append('void vkFuncs::init_funcs(void * handle)\n{\n m_libHandle = handle;')
1338 for proto in self.protos:
Ian Elliott338dedb2015-08-21 15:09:33 -06001339 if 'KHR' not in proto.name and 'Dbg' not in proto.name:
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001340 rif_body.append(' real_vk%s = (type_vk%s)(vktrace_platform_get_library_entrypoint(handle, "vk%s"));' % (proto.name, proto.name, proto.name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001341 else: # These func ptrs get assigned at GetProcAddr time
1342 rif_body.append(' real_vk%s = (type_vk%s)NULL;' % (proto.name, proto.name))
1343 rif_body.append('}')
1344 return "\n".join(rif_body)
1345
Jon Ashburnc736c002015-10-25 20:24:57 -06001346 def _remap_packet_param(self, funcName, paramType, paramName, lastName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001347 remap_list = vulkan.object_type_list
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001348 param_exclude_list = ['pDescriptorSets', 'pFences']
1349 cleanParamType = paramType.strip('*').replace('const ', '')
Jon Ashburncb622a12015-08-06 17:22:53 -06001350 VulkNonDispObjects = [o for o in vulkan.object_non_dispatch_list]
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001351 for obj in remap_list:
Jon Ashburncb622a12015-08-06 17:22:53 -06001352 if obj == cleanParamType and paramName not in param_exclude_list:
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001353 objectTypeRemapParam = ''
1354 if 'VkDynamicStateObject' == cleanParamType:
1355 objectTypeRemapParam = ', pPacket->stateBindPoint'
1356 elif 'object' == paramName:
1357 if 'DbgSetObjectTag' == funcName:
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001358 objectTypeRemapParam = ', VKTRACE_VK_OBJECT_TYPE_UNKNOWN'
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001359 else:
1360 objectTypeRemapParam = ', pPacket->objType'
1361 elif 'srcObject' == paramName and 'Callback' in funcName:
1362 objectTypeRemapParam = ', pPacket->objType'
Jon Ashburnc736c002015-10-25 20:24:57 -06001363 pArray = ''
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001364 if '*' in paramType:
Jon Ashburnc736c002015-10-25 20:24:57 -06001365 if 'const' not in paramType:
1366 result = ' %s remapped%s = m_objMapper.remap_%ss(*pPacket->%s%s);\n' % (cleanParamType, paramName, paramName.lower(), paramName, objectTypeRemapParam)
1367 result += ' if (pPacket->%s != VK_NULL_HANDLE && remapped%s == VK_NULL_HANDLE)\n' % (paramName, paramName)
1368 result += ' {\n'
1369 result += ' return vktrace_replay::VKTRACE_REPLAY_ERROR;\n'
1370 result += ' }\n'
1371 return result
1372 else:
1373 if lastName == '':
1374 return ' // pPacket->%s should have been remapped with special case code' % (paramName)
1375 pArray = '[pPacket->%s]' % lastName
Courtney Goeltzenleuchter5970b252015-10-27 11:32:31 -06001376 result = ' %s *remapped%s = new %s%s;\n' % (cleanParamType, paramName, cleanParamType, pArray)
Jon Ashburnc736c002015-10-25 20:24:57 -06001377 result += '%s\n' % self.lineinfo.get()
1378 result += ' for (uint32_t i = 0; i < pPacket->%s; i++) {\n' % lastName
Chia-I Wue420a332015-10-26 20:04:44 +08001379 result += ' remapped%s[i] = m_objMapper.remap_%ss(pPacket->%s[i]%s);\n' % (paramName, cleanParamType.lower()[2:], paramName, objectTypeRemapParam)
1380 result += ' if (pPacket->%s[i] != VK_NULL_HANDLE && remapped%s[i] == VK_NULL_HANDLE)\n' % (paramName, paramName)
Jon Ashburnc736c002015-10-25 20:24:57 -06001381 result += ' {\n'
1382 result += ' return vktrace_replay::VKTRACE_REPLAY_ERROR;\n'
1383 result += ' }\n'
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001384 result += ' }\n'
1385 return result
Jon Ashburnc736c002015-10-25 20:24:57 -06001386
Chia-I Wue420a332015-10-26 20:04:44 +08001387 result = ' %s remapped%s = m_objMapper.remap_%ss(pPacket->%s%s);\n' % (paramType, paramName, cleanParamType.lower()[2:], paramName, objectTypeRemapParam)
1388 result += '%s\n' % self.lineinfo.get()
1389 result += ' if (pPacket->%s != VK_NULL_HANDLE && remapped%s == VK_NULL_HANDLE)\n' % (paramName, paramName)
1390 result += ' {\n'
1391 result += ' return vktrace_replay::VKTRACE_REPLAY_ERROR;\n'
1392 result += ' }\n'
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001393 return result
1394 return ' // No need to remap %s' % (paramName)
1395
1396 def _get_packet_param(self, funcName, paramType, paramName):
1397 # list of types that require remapping
1398 remap_list = vulkan.object_type_list
1399 param_exclude_list = ['pDescriptorSets', 'pFences']
1400 cleanParamType = paramType.strip('*').replace('const ', '')
1401 for obj in remap_list:
Jon Ashburncb622a12015-08-06 17:22:53 -06001402 if obj == cleanParamType and paramName not in param_exclude_list:
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001403 objectTypeRemapParam = ''
1404 if 'object' == paramName:
1405 if 'DbgSetObjectTag' == funcName:
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001406 objectTypeRemapParam = ', VKTRACE_VK_OBJECT_TYPE_UNKNOWN'
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001407 else:
1408 objectTypeRemapParam = ', pPacket->objType'
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001409 return 'remapped%s' % (paramName)
1410 return 'pPacket->%s' % (paramName)
1411
1412 def _gen_replay_create_image(self):
1413 ci_body = []
1414 ci_body.append(' imageObj local_imageObj;')
1415 ci_body.append(' VkDevice remappedDevice = m_objMapper.remap_devices(pPacket->device);')
1416 ci_body.append(' if (remappedDevice == VK_NULL_HANDLE)')
1417 ci_body.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001418 ci_body.append(' return vktrace_replay::VKTRACE_REPLAY_ERROR;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001419 ci_body.append(' }')
Chia-I Wu69f40122015-10-26 21:10:41 +08001420 ci_body.append(' replayResult = m_vkFuncs.real_vkCreateImage(remappedDevice, pPacket->pCreateInfo, NULL, &local_imageObj.replayImage);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001421 ci_body.append(' if (replayResult == VK_SUCCESS)')
1422 ci_body.append(' {')
Chia-I Wue420a332015-10-26 20:04:44 +08001423 ci_body.append(' m_objMapper.add_to_images_map(*(pPacket->pImage), local_imageObj);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001424 ci_body.append(' }')
1425 return "\n".join(ci_body)
1426
1427 def _gen_replay_create_buffer(self):
1428 cb_body = []
1429 cb_body.append(' bufferObj local_bufferObj;')
1430 cb_body.append(' VkDevice remappedDevice = m_objMapper.remap_devices(pPacket->device);')
1431 cb_body.append(' if (remappedDevice == VK_NULL_HANDLE)')
1432 cb_body.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001433 cb_body.append(' return vktrace_replay::VKTRACE_REPLAY_ERROR;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001434 cb_body.append(' }')
Chia-I Wu69f40122015-10-26 21:10:41 +08001435 cb_body.append(' replayResult = m_vkFuncs.real_vkCreateBuffer(remappedDevice, pPacket->pCreateInfo, NULL, &local_bufferObj.replayBuffer);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001436 cb_body.append(' if (replayResult == VK_SUCCESS)')
1437 cb_body.append(' {')
Chia-I Wue420a332015-10-26 20:04:44 +08001438 cb_body.append(' m_objMapper.add_to_buffers_map(*(pPacket->pBuffer), local_bufferObj);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001439 cb_body.append(' }')
1440 return "\n".join(cb_body)
1441
1442 # Generate main replay case statements where actual replay API call is dispatched based on input packet data
1443 def _generate_replay(self):
Chia-I Wu1f851912015-10-27 18:04:07 +08001444 manually_replay_funcs = ['AllocateMemory',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001445 'BeginCommandBuffer',
1446 'CreateDescriptorSetLayout',
1447 'CreateDevice',
1448 'CreateFramebuffer',
1449 'CreateGraphicsPipelines',
1450 'CreateInstance',
1451 'CreatePipelineLayout',
1452 'CreateRenderPass',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001453 'CmdBeginRenderPass',
1454 'CmdBindDescriptorSets',
1455 'CmdBindVertexBuffers',
1456 'CmdPipelineBarrier',
Ian Elliott338dedb2015-08-21 15:09:33 -06001457 'QueuePresentKHR',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001458 'CmdWaitEvents',
1459 #'DestroyObject',
1460 'EnumeratePhysicalDevices',
1461 'FreeMemory',
1462 'FreeDescriptorSets',
1463 'FlushMappedMemoryRanges',
1464 #'GetGlobalExtensionInfo',
1465 #'GetImageSubresourceInfo',
1466 #'GetObjectInfo',
1467 #'GetPhysicalDeviceExtensionInfo',
Ian Elliott338dedb2015-08-21 15:09:33 -06001468 'GetPhysicalDeviceSurfaceSupportKHR',
1469 'GetSurfacePropertiesKHR',
1470 'GetSurfaceFormatsKHR',
1471 'GetSurfacePresentModesKHR',
1472 'CreateSwapchainKHR',
1473 'GetSwapchainImagesKHR',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001474 #'GetPhysicalDeviceInfo',
1475 'MapMemory',
Ian Elliott338dedb2015-08-21 15:09:33 -06001476 #'QueuePresentKHR',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001477 'QueueSubmit',
1478 #'StorePipeline',
1479 'UnmapMemory',
1480 'UpdateDescriptorSets',
1481 'WaitForFences',
Jon Ashburncaae0492015-08-13 16:49:08 -06001482 'DbgCreateMsgCallback',
1483 'DbgDestroyMsgCallback',
Chia-I Wu1f851912015-10-27 18:04:07 +08001484 'AllocateCommandBuffers',
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001485 ]
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001486
1487 # validate the manually_replay_funcs list
1488 protoFuncs = [proto.name for proto in self.protos]
1489 for func in manually_replay_funcs:
1490 if func not in protoFuncs:
1491 sys.exit("Entry '%s' in manually_replay_funcs list is not in the vulkan function prototypes" % func)
1492
1493 # map protos to custom functions if body is fully custom
1494 custom_body_dict = {'CreateImage': self._gen_replay_create_image,
1495 'CreateBuffer': self._gen_replay_create_buffer }
1496 # multi-gpu Open funcs w/ list of local params to create
1497 custom_open_params = {'OpenSharedMemory': (-1,),
1498 'OpenSharedSemaphore': (-1,),
1499 'OpenPeerMemory': (-1,),
1500 'OpenPeerImage': (-1, -2,)}
1501 # Functions that create views are unique from other create functions
Courtney Goeltzenleuchter1856d6f2015-09-01 17:30:39 -06001502 create_view_list = ['CreateBufferView', 'CreateImageView', 'CreateComputePipeline']
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001503 # Functions to treat as "Create' that don't have 'Create' in the name
Chia-I Wu1f851912015-10-27 18:04:07 +08001504 special_create_list = ['LoadPipeline', 'LoadPipelineDerivative', 'AllocateMemory', 'GetDeviceQueue', 'PinSystemMemory', 'AllocateDescriptorSets']
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001505 # A couple funcs use do while loops
1506 do_while_dict = {'GetFenceStatus': 'replayResult != pPacket->result && pPacket->result == VK_SUCCESS', 'GetEventStatus': '(pPacket->result == VK_EVENT_SET || pPacket->result == VK_EVENT_RESET) && replayResult != pPacket->result'}
1507 rbody = []
1508 rbody.append('%s' % self.lineinfo.get())
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001509 rbody.append('vktrace_replay::VKTRACE_REPLAY_RESULT vkReplay::replay(vktrace_trace_packet_header *packet)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001510 rbody.append('{')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001511 rbody.append(' vktrace_replay::VKTRACE_REPLAY_RESULT returnValue = vktrace_replay::VKTRACE_REPLAY_SUCCESS;')
Courtney Goeltzenleuchterac544f32015-09-14 18:01:17 -06001512 rbody.append(' VkResult replayResult = VK_ERROR_VALIDATION_FAILED;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001513 rbody.append(' switch (packet->packet_id)')
1514 rbody.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001515 rbody.append(' case VKTRACE_TPI_VK_vkApiVersion:')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001516 rbody.append(' {')
1517 rbody.append(' packet_vkApiVersion* pPacket = (packet_vkApiVersion*)(packet->pBody);')
1518 rbody.append(' if (pPacket->version != VK_API_VERSION)')
1519 rbody.append(' {')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001520 rbody.append(' vktrace_LogError("Trace file is from Vulkan version 0x%x (%u.%u.%u), but the vktrace plugin only supports version 0x%x (%u.%u.%u).", pPacket->version, (pPacket->version & 0xFFC00000) >> 22, (pPacket->version & 0x003FF000) >> 12, (pPacket->version & 0x00000FFF), VK_API_VERSION, (VK_API_VERSION & 0xFFC00000) >> 22, (VK_API_VERSION & 0x003FF000) >> 12, (VK_API_VERSION & 0x00000FFF));')
1521 rbody.append(' returnValue = vktrace_replay::VKTRACE_REPLAY_ERROR;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001522 rbody.append(' }')
1523 rbody.append(' break;')
1524 rbody.append(' }')
1525 for proto in self.protos:
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001526 ret_value = False
1527 create_view = False
1528 create_func = False
1529 # TODO : How to handle void* return of GetProcAddr?
Jon Ashburnd7770ed2015-09-30 13:41:02 -06001530#TODO make sure vkDestroy object functions really do clean up the object maps
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001531 if ('void' not in proto.ret.lower()) and ('size_t' not in proto.ret) and (proto.name not in custom_body_dict):
1532 ret_value = True
1533 if proto.name in create_view_list:
1534 create_view = True
1535 elif 'Create' in proto.name or proto.name in special_create_list:
1536 create_func = True
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001537 rbody.append(' case VKTRACE_TPI_VK_vk%s:' % proto.name)
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001538 rbody.append(' {')
1539 rbody.append(' packet_vk%s* pPacket = (packet_vk%s*)(packet->pBody);' % (proto.name, proto.name))
1540 if proto.name in manually_replay_funcs:
1541 if ret_value == True:
1542 rbody.append(' replayResult = manually_replay_vk%s(pPacket);' % proto.name)
1543 else:
1544 rbody.append(' manually_replay_vk%s(pPacket);' % proto.name)
1545 elif proto.name in custom_body_dict:
1546 rbody.append(custom_body_dict[proto.name]())
1547 else:
1548 if proto.name in custom_open_params:
1549 for pidx in custom_open_params[proto.name]:
1550 rbody.append(' %s local_%s;' % (proto.params[pidx].ty.replace('const ', '').strip('*'), proto.params[pidx].name))
1551 elif create_view:
1552 rbody.append(' %s createInfo;' % (proto.params[1].ty.strip('*').replace('const ', '')))
1553 rbody.append(' memcpy(&createInfo, pPacket->pCreateInfo, sizeof(%s));' % (proto.params[1].ty.strip('*').replace('const ', '')))
1554 if 'CreateComputePipeline' == proto.name:
Chia-I Wue420a332015-10-26 20:04:44 +08001555 rbody.append(' createInfo.cs.shader = m_objMapper.remap_shaders(pPacket->pCreateInfo->cs.shader);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001556 elif 'CreateBufferView' == proto.name:
Chia-I Wue420a332015-10-26 20:04:44 +08001557 rbody.append(' createInfo.buffer = m_objMapper.remap_buffers(pPacket->pCreateInfo->buffer);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001558 else:
Chia-I Wue420a332015-10-26 20:04:44 +08001559 rbody.append(' createInfo.image = m_objMapper.remap_images(pPacket->pCreateInfo->image);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001560 rbody.append(' %s local_%s;' % (proto.params[-1].ty.strip('*').replace('const ', ''), proto.params[-1].name))
1561 elif create_func: # Declare local var to store created handle into
Chia-I Wu1f851912015-10-27 18:04:07 +08001562 if 'AllocateDescriptorSets' == proto.name:
Jon Ashburn9e8755b2015-08-10 08:53:44 -06001563 p_ty = proto.params[-1].ty.strip('*').replace('const ', '')
Chia-I Wu1f851912015-10-27 18:04:07 +08001564 rbody.append(' %s* local_%s = (%s*)malloc(pPacket->pAllocateInfo->setLayoutCount * sizeof(%s));' % (p_ty, proto.params[-1].name, p_ty, p_ty))
1565 rbody.append(' VkDescriptorSetLayout* local_pSetLayouts = (VkDescriptorSetLayout*)malloc(pPacket->pAllocateInfo->setLayoutCount * sizeof(VkDescriptorSetLayout));')
1566 rbody.append(' VkDescriptorSetAllocateInfo local_AllocInfo, *local_pAllocateInfo = &local_AllocInfo;')
Jon Ashburne27a9182015-10-16 17:50:47 -06001567 rbody.append(' VkDescriptorPool local_descPool;')
Chia-I Wu1f851912015-10-27 18:04:07 +08001568 rbody.append(' local_descPool = m_objMapper.remap_descriptorpools(pPacket->pAllocateInfo->descriptorPool);')
1569 rbody.append(' for (uint32_t i = 0; i < pPacket->pAllocateInfo->setLayoutCount; i++)')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001570 rbody.append(' {')
Chia-I Wue420a332015-10-26 20:04:44 +08001571 rbody.append(' local_pSetLayouts[i] = m_objMapper.remap_descriptorsetlayouts(pPacket->%s->pSetLayouts[i]);' % (proto.params[-2].name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001572 rbody.append(' }')
Chia-I Wu1f851912015-10-27 18:04:07 +08001573 rbody.append(' memcpy(local_pAllocateInfo, pPacket->pAllocateInfo, sizeof(VkDescriptorSetAllocateInfo));')
1574 rbody.append(' local_pAllocateInfo->pSetLayouts = local_pSetLayouts;')
1575 rbody.append(' local_pAllocateInfo->descriptorPool = local_descPool;')
Jon Ashburn9e8755b2015-08-10 08:53:44 -06001576 else:
1577 rbody.append(' %s local_%s;' % (proto.params[-1].ty.strip('*').replace('const ', ''), proto.params[-1].name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001578 elif proto.name == 'ResetFences':
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001579 rbody.append(' VkFence* fences = VKTRACE_NEW_ARRAY(VkFence, pPacket->fenceCount);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001580 rbody.append(' for (uint32_t i = 0; i < pPacket->fenceCount; i++)')
1581 rbody.append(' {')
Chia-I Wue420a332015-10-26 20:04:44 +08001582 rbody.append(' fences[i] = m_objMapper.remap_fences(pPacket->%s[i]);' % (proto.params[-1].name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001583 rbody.append(' }')
1584 elif proto.name in do_while_dict:
1585 rbody.append(' do {')
Jon Ashburnc736c002015-10-25 20:24:57 -06001586 last_name = ''
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001587 for p in proto.params:
1588 if create_func or create_view:
1589 if p.name != proto.params[-1].name:
Jon Ashburnc736c002015-10-25 20:24:57 -06001590 rbody.append(self._remap_packet_param(proto.name, p.ty, p.name, last_name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001591 else:
Jon Ashburnc736c002015-10-25 20:24:57 -06001592 rbody.append(self._remap_packet_param(proto.name, p.ty, p.name, last_name))
1593 last_name = p.name
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001594
1595 if proto.name == 'DestroyInstance':
1596 rbody.append(' if (m_vkFuncs.real_vkDbgDestroyMsgCallback != NULL)')
1597 rbody.append(' {')
1598 rbody.append(' m_vkFuncs.real_vkDbgDestroyMsgCallback(remappedinstance, m_dbgMsgCallbackObj);')
1599 rbody.append(' }')
1600 # TODO: need a better way to indicate which extensions should be mapped to which Get*ProcAddr
1601 elif proto.name == 'GetInstanceProcAddr':
1602 for iProto in self.protos:
Ian Elliott338dedb2015-08-21 15:09:33 -06001603 if 'Dbg' in iProto.name or 'GetPhysicalDeviceSurfaceSupportKHR' in iProto.name:
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001604 rbody.append(' if (strcmp(pPacket->pName, "vk%s") == 0) {' % (iProto.name))
1605 rbody.append(' m_vkFuncs.real_vk%s = (PFN_vk%s)vk%s(remappedinstance, pPacket->pName);' % (iProto.name, iProto.name, proto.name))
1606 rbody.append(' }')
1607 elif proto.name == 'GetDeviceProcAddr':
1608 for dProto in self.protos:
Ian Elliott338dedb2015-08-21 15:09:33 -06001609 if 'KHR' in dProto.name:
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001610 rbody.append(' if (strcmp(pPacket->pName, "vk%s") == 0) {' % (dProto.name))
1611 rbody.append(' m_vkFuncs.real_vk%s = (PFN_vk%s)vk%s(remappeddevice, pPacket->pName);' % (dProto.name, dProto.name, proto.name))
1612 rbody.append(' }')
1613
1614 # build the call to the "real_" entrypoint
1615 rr_string = ' '
1616 if ret_value:
1617 rr_string = ' replayResult = '
1618 rr_string += 'm_vkFuncs.real_vk%s(' % proto.name
1619 for p in proto.params:
1620 # For last param of Create funcs, pass address of param
1621 if create_func:
Chia-I Wu1f851912015-10-27 18:04:07 +08001622 if proto.name == 'AllocateDescriptorSets' and ((p.name == proto.params[-2].name) or (p.name == proto.params[-1].name)):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001623 rr_string += 'local_%s, ' % p.name
Jon Ashburn9e8755b2015-08-10 08:53:44 -06001624 elif p.name == proto.params[-1].name:
1625 rr_string += '&local_%s, ' % p.name
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001626 else:
1627 rr_string += '%s, ' % self._get_packet_param(proto.name, p.ty, p.name)
1628 else:
1629 rr_string += '%s, ' % self._get_packet_param(proto.name, p.ty, p.name)
1630 rr_string = '%s);' % rr_string[:-2]
1631 if proto.name in custom_open_params:
1632 rr_list = rr_string.split(', ')
1633 for pidx in custom_open_params[proto.name]:
1634 rr_list[pidx] = '&local_%s' % proto.params[pidx].name
1635 rr_string = ', '.join(rr_list)
1636 rr_string += ');'
1637 elif create_view:
1638 rr_list = rr_string.split(', ')
Chia-I Wu69f40122015-10-26 21:10:41 +08001639 rr_list[-3] = '&createInfo'
1640 rr_list[-2] = 'NULL'
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001641 rr_list[-1] = '&local_%s);' % proto.params[-1].name
1642 rr_string = ', '.join(rr_list)
1643 # this is a sneaky shortcut to use generic create code below to add_to_map
1644 create_func = True
Chia-I Wu1f851912015-10-27 18:04:07 +08001645 elif proto.name == 'AllocateDescriptorSets':
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001646 rr_string = rr_string.replace('pPacket->pSetLayouts', 'pLocalDescSetLayouts')
1647 elif proto.name == 'ResetFences':
1648 rr_string = rr_string.replace('pPacket->pFences', 'fences')
1649
1650 # insert the real_*(..) call
1651 rbody.append(rr_string)
1652
1653 # handle return values or anything that needs to happen after the real_*(..) call
Courtney Goeltzenleuchter74c4ce92015-09-14 17:22:16 -06001654 get_ext_layers_proto = ['EnumerateInstanceExtensionProperties', 'EnumerateDeviceExtensionProperties','EnumerateInstanceLayerProperties', 'EnumerateDeviceLayerProperties']
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001655 if 'DestroyDevice' in proto.name:
1656 rbody.append(' if (replayResult == VK_SUCCESS)')
1657 rbody.append(' {')
1658 rbody.append(' m_pCBDump = NULL;')
1659 rbody.append(' m_pDSDump = NULL;')
1660 #TODO138 : disabling snapshot
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001661 #rbody.append(' m_pVktraceSnapshotPrint = NULL;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001662 rbody.append(' m_objMapper.rm_from_devices_map(pPacket->device);')
1663 rbody.append(' m_display->m_initedVK = false;')
1664 rbody.append(' }')
Jon Ashburnc30315e2015-09-07 14:39:30 -06001665 elif proto.name in get_ext_layers_proto:
Courtney Goeltzenleuchterac544f32015-09-14 18:01:17 -06001666 rbody.append(' if (replayResult == VK_ERROR_LAYER_NOT_PRESENT || replayResult == VK_INCOMPLETE)')
Jon Ashburnc30315e2015-09-07 14:39:30 -06001667 rbody.append(' { // ignore errors caused by trace config != replay config')
1668 rbody.append(' replayResult = VK_SUCCESS;')
1669 rbody.append(' }')
Ian Elliott338dedb2015-08-21 15:09:33 -06001670 elif 'DestroySwapchainKHR' in proto.name:
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001671 rbody.append(' if (replayResult == VK_SUCCESS)')
1672 rbody.append(' {')
Chia-I Wue420a332015-10-26 20:04:44 +08001673 rbody.append(' m_objMapper.rm_from_swapchainkhrs_map(pPacket->swapchain);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001674 rbody.append(' }')
1675 elif 'DestroyInstance' in proto.name:
1676 rbody.append(' if (replayResult == VK_SUCCESS)')
1677 rbody.append(' {')
1678 rbody.append(' // TODO need to handle multiple instances and only clearing maps within an instance.')
1679 rbody.append(' // TODO this only works with a single instance used at any given time.')
1680 rbody.append(' m_objMapper.clear_all_map_handles();')
1681 rbody.append(' }')
Courtney Goeltzenleuchter5970b252015-10-27 11:32:31 -06001682 elif 'MergePipelineCaches' in proto.name:
1683 rbody.append(' delete remappedpSrcCaches;')
1684 elif 'FreeCommandBuffers' in proto.name:
1685 rbody.append(' delete remappedpCommandBuffers;')
1686 elif 'CmdExecuteCommands' in proto.name:
Chia-I Wu1f851912015-10-27 18:04:07 +08001687 rbody.append(' delete remappedpCommandBuffers;')
1688 elif 'AllocateDescriptorSets' in proto.name:
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001689 rbody.append(' if (replayResult == VK_SUCCESS)')
1690 rbody.append(' {')
Chia-I Wu1f851912015-10-27 18:04:07 +08001691 rbody.append(' for (uint32_t i = 0; i < pPacket->pAllocateInfo->setLayoutCount; i++) {')
Chia-I Wue420a332015-10-26 20:04:44 +08001692 rbody.append(' m_objMapper.add_to_descriptorsets_map(pPacket->%s[i], local_%s[i]);' % (proto.params[-1].name, proto.params[-1].name))
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001693 rbody.append(' }')
1694 rbody.append(' }')
Jon Ashburn9e8755b2015-08-10 08:53:44 -06001695 rbody.append(' free(local_pSetLayouts);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001696 rbody.append(' free(local_pDescriptorSets);')
1697 elif proto.name == 'ResetFences':
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001698 rbody.append(' VKTRACE_DELETE(fences);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001699 elif create_func: # save handle mapping if create successful
Courtney Goeltzenleuchter3ec31622015-10-20 18:04:07 -06001700 if ret_value:
1701 rbody.append(' if (replayResult == VK_SUCCESS)')
1702 rbody.append(' {')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001703 clean_type = proto.params[-1].ty.strip('*').replace('const ', '')
Jon Ashburncb622a12015-08-06 17:22:53 -06001704 VkNonDispObjType = [o for o in vulkan.object_non_dispatch_list]
Chia-I Wue420a332015-10-26 20:04:44 +08001705 rbody.append(' m_objMapper.add_to_%ss_map(*(pPacket->%s), local_%s);' % (clean_type.lower()[2:], proto.params[-1].name, proto.params[-1].name))
Chia-I Wu1f851912015-10-27 18:04:07 +08001706 if 'AllocateMemory' == proto.name:
1707 rbody.append(' m_objMapper.add_entry_to_mapData(local_%s, pPacket->pAllocateInfo->allocationSize);' % (proto.params[-1].name))
Courtney Goeltzenleuchter3ec31622015-10-20 18:04:07 -06001708 if ret_value:
1709 rbody.append(' }')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001710 elif proto.name in do_while_dict:
1711 rbody[-1] = ' %s' % rbody[-1]
1712 rbody.append(' } while (%s);' % do_while_dict[proto.name])
1713 rbody.append(' if (pPacket->result != VK_NOT_READY || replayResult != VK_SUCCESS)')
1714 if ret_value:
1715 rbody.append(' CHECK_RETURN_VALUE(vk%s);' % proto.name)
1716 rbody.append(' break;')
1717 rbody.append(' }')
1718 rbody.append(' default:')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001719 rbody.append(' vktrace_LogWarning("Unrecognized packet_id %u, skipping.", packet->packet_id);')
1720 rbody.append(' returnValue = vktrace_replay::VKTRACE_REPLAY_INVALID_ID;')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001721 rbody.append(' break;')
1722 rbody.append(' }')
1723 rbody.append(' return returnValue;')
1724 rbody.append('}')
1725 return "\n".join(rbody)
1726
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001727class VktraceTraceHeader(Subcommand):
Chia-I Wu1f851912015-10-27 18:04:07 +08001728 def generate_header(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001729 header_txt = []
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001730 header_txt.append('#include "vktrace_vk_vk_packets.h"')
Jon Ashburn71654fd2015-09-11 09:18:44 -06001731 header_txt.append('#include "vktrace_vk_packet_id.h"\n\n')
1732 header_txt.append('void InitTracer(void);\n\n')
1733 header_txt.append('#ifdef WIN32')
1734 header_txt.append('extern INIT_ONCE gInitOnce;')
1735 header_txt.append('\n#elif defined(PLATFORM_LINUX)')
1736 header_txt.append('extern pthread_once_t gInitOnce;')
1737 header_txt.append('#endif\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001738 return "\n".join(header_txt)
1739
1740 def generate_body(self):
Jon Ashburn71654fd2015-09-11 09:18:44 -06001741 body = [self._generate_trace_func_protos()]
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001742
1743 return "\n".join(body)
1744
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001745class VktraceTraceC(Subcommand):
Chia-I Wu1f851912015-10-27 18:04:07 +08001746 def generate_header(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001747 header_txt = []
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001748 header_txt.append('#include "vktrace_platform.h"')
1749 header_txt.append('#include "vktrace_common.h"')
1750 header_txt.append('#include "vktrace_lib_helpers.h"')
1751 header_txt.append('#include "vktrace_vk_vk.h"')
1752 header_txt.append('#include "vktrace_vk_vk_debug_report_lunarg.h"')
Tobin Ehlise973f772015-08-27 17:41:42 -06001753 header_txt.append('#include "vktrace_vk_vk_debug_marker_lunarg.h"')
Ian Elliott338dedb2015-08-21 15:09:33 -06001754 header_txt.append('#include "vktrace_vk_vk_ext_khr_swapchain.h"')
1755 header_txt.append('#include "vktrace_vk_vk_ext_khr_device_swapchain.h"')
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001756 header_txt.append('#include "vktrace_interconnect.h"')
1757 header_txt.append('#include "vktrace_filelike.h"')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001758 header_txt.append('#include "vk_struct_size_helper.h"')
Jon Ashburn71654fd2015-09-11 09:18:44 -06001759 header_txt.append('#ifdef PLATFORM_LINUX')
1760 header_txt.append('#include <pthread.h>')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001761 header_txt.append('#endif')
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001762 header_txt.append('#include "vktrace_trace_packet_utils.h"')
Jon Ashburn71654fd2015-09-11 09:18:44 -06001763 header_txt.append('#include <stdio.h>\n')
Chia-I Wua5cd6532015-10-28 18:31:57 +08001764 header_txt.append('#include <string.h>\n')
Jon Ashburn71654fd2015-09-11 09:18:44 -06001765 header_txt.append('#ifdef WIN32')
1766 header_txt.append('INIT_ONCE gInitOnce = INIT_ONCE_STATIC_INIT;')
1767 header_txt.append('#elif defined(PLATFORM_LINUX)')
1768 header_txt.append('pthread_once_t gInitOnce = PTHREAD_ONCE_INIT;')
1769 header_txt.append('#endif')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001770 return "\n".join(header_txt)
1771
1772 def generate_body(self):
Jon Ashburn71654fd2015-09-11 09:18:44 -06001773 body = [self._generate_init_funcs(),
Chia-I Wu1f851912015-10-27 18:04:07 +08001774 self._generate_trace_funcs(self.extensionName)]
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001775
1776 return "\n".join(body)
1777
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001778class VktracePacketID(Subcommand):
Chia-I Wu1f851912015-10-27 18:04:07 +08001779 def generate_header(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001780 header_txt = []
1781 header_txt.append('#pragma once\n')
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001782 header_txt.append('#include "vktrace_trace_packet_utils.h"')
1783 header_txt.append('#include "vktrace_trace_packet_identifiers.h"')
1784 header_txt.append('#include "vktrace_interconnect.h"')
1785 header_txt.append('#include "vktrace_vk_vk_packets.h"')
1786 header_txt.append('#include "vktrace_vk_vk_debug_report_lunarg_packets.h"')
Tobin Ehlise973f772015-08-27 17:41:42 -06001787 header_txt.append('#include "vktrace_vk_vk_debug_marker_lunarg_packets.h"')
Ian Elliott338dedb2015-08-21 15:09:33 -06001788 header_txt.append('#include "vktrace_vk_vk_ext_khr_swapchain_packets.h"')
1789 header_txt.append('#include "vktrace_vk_vk_ext_khr_device_swapchain_packets.h"')
Jon Ashburncb622a12015-08-06 17:22:53 -06001790 #header_txt.append('#include "vk_enum_string_helper.h"')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001791 header_txt.append('#ifndef _WIN32')
1792 header_txt.append(' #pragma GCC diagnostic ignored "-Wwrite-strings"')
1793 header_txt.append('#endif')
Jon Ashburncb622a12015-08-06 17:22:53 -06001794 #header_txt.append('#include "vk_struct_string_helper.h"')
Ian Elliott338dedb2015-08-21 15:09:33 -06001795 #header_txt.append('#include "vk_ext_khr_swapchain_struct_string_helper.h"')
1796 #header_txt.append('#include "vk_ext_khr_device_swapchain_struct_string_helper.h"')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001797 header_txt.append('#ifndef _WIN32')
1798 header_txt.append(' #pragma GCC diagnostic warning "-Wwrite-strings"')
1799 header_txt.append('#endif')
Ian Elliott338dedb2015-08-21 15:09:33 -06001800 #header_txt.append('#include "vk_ext_khr_swapchain_enum_string_helper.h"')
1801 #header_txt.append('#include "vk_ext_khr_device_swapchain_enum_string_helper.h"')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001802 header_txt.append('#if defined(WIN32)')
1803 header_txt.append('#define snprintf _snprintf')
1804 header_txt.append('#endif')
1805 header_txt.append('#define SEND_ENTRYPOINT_ID(entrypoint) ;')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001806 header_txt.append('//#define SEND_ENTRYPOINT_ID(entrypoint) vktrace_TraceInfo(#entrypoint);\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001807 header_txt.append('#define SEND_ENTRYPOINT_PARAMS(entrypoint, ...) ;')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001808 header_txt.append('//#define SEND_ENTRYPOINT_PARAMS(entrypoint, ...) vktrace_TraceInfo(entrypoint, __VA_ARGS__);\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001809 header_txt.append('#define CREATE_TRACE_PACKET(entrypoint, buffer_bytes_needed) \\')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001810 header_txt.append(' pHeader = vktrace_create_trace_packet(VKTRACE_TID_VULKAN, VKTRACE_TPI_VK_##entrypoint, sizeof(packet_##entrypoint), buffer_bytes_needed);\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001811 header_txt.append('#define FINISH_TRACE_PACKET() \\')
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001812 header_txt.append(' vktrace_finalize_trace_packet(pHeader); \\')
1813 header_txt.append(' vktrace_write_trace_packet(pHeader, vktrace_trace_get_trace_file()); \\')
1814 header_txt.append(' vktrace_delete_trace_packet(&pHeader);')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001815 return "\n".join(header_txt)
1816
1817 def generate_body(self):
1818 body = [self._generate_packet_id_enum(),
1819 self._generate_packet_id_name_func(),
Jon Ashburncb622a12015-08-06 17:22:53 -06001820# self._generate_stringify_func(),
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001821 self._generate_interp_func()]
1822
1823 return "\n".join(body)
1824
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001825class VktraceCoreTracePackets(Subcommand):
Chia-I Wu1f851912015-10-27 18:04:07 +08001826 def generate_header(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001827 header_txt = []
1828 header_txt.append('#pragma once\n')
1829 header_txt.append('#include "vulkan.h"')
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001830 header_txt.append('#include "vktrace_trace_packet_utils.h"\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001831 return "\n".join(header_txt)
1832
1833 def generate_body(self):
1834 body = [self._generate_struct_util_funcs(),
1835 self._generate_interp_funcs()]
1836
1837 return "\n".join(body)
1838
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001839class VktraceExtTraceHeader(Subcommand):
Chia-I Wu1f851912015-10-27 18:04:07 +08001840 def generate_header(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001841 header_txt = []
1842 header_txt.append('#pragma once\n')
1843 header_txt.append('#include "vulkan.h"')
Chia-I Wu1f851912015-10-27 18:04:07 +08001844 header_txt.append('#include "%s.h"' % extensionName.lower())
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001845 return "\n".join(header_txt)
1846
1847 def generate_body(self):
Chia-I Wu1f851912015-10-27 18:04:07 +08001848 body = [self._generate_trace_func_protos_ext(self.extensionName)]
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001849
1850 return "\n".join(body)
1851
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001852class VktraceExtTraceC(Subcommand):
Chia-I Wu1f851912015-10-27 18:04:07 +08001853 def generate_header(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001854 header_txt = []
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001855 header_txt.append('#include "vktrace_platform.h"')
1856 header_txt.append('#include "vktrace_common.h"')
Chia-I Wu1f851912015-10-27 18:04:07 +08001857 if extensionName == "vk_ext_khr_device_swapchain":
Ian Elliott338dedb2015-08-21 15:09:33 -06001858 header_txt.append('#include "vk_ext_khr_swapchain.h"')
Chia-I Wu1f851912015-10-27 18:04:07 +08001859 header_txt.append('#include "vktrace_vk_%s.h"' % extensionName.lower())
1860 header_txt.append('#include "vktrace_vk_%s_packets.h"' % extensionName.lower())
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001861 header_txt.append('#include "vktrace_vk_packet_id.h"')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001862 header_txt.append('#include "vk_struct_size_helper.h"')
Chia-I Wu1f851912015-10-27 18:04:07 +08001863 header_txt.append('#include "%s_struct_size_helper.h"' % extensionName.lower())
1864 if extensionName == 'vk_debug_marker_lunarg':
Jon Ashburn71654fd2015-09-11 09:18:44 -06001865 header_txt.append('#include "vk_debug_marker_layer.h"\n')
Jon Ashburn71654fd2015-09-11 09:18:44 -06001866
Jon Ashburn5afdcf62015-09-14 15:17:36 -06001867 header_txt.append('#include "vktrace_lib_helpers.h"')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001868 return "\n".join(header_txt)
1869
1870 def generate_body(self):
Chia-I Wu1f851912015-10-27 18:04:07 +08001871 body = [self._generate_trace_funcs(self.extensionName)]
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001872
1873 return "\n".join(body)
1874
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001875class VktraceExtTracePackets(Subcommand):
Chia-I Wu1f851912015-10-27 18:04:07 +08001876 def generate_header(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001877 header_txt = []
1878 header_txt.append('#pragma once\n')
Chia-I Wu1f851912015-10-27 18:04:07 +08001879 header_txt.append('#include "%s.h"' % extensionName.lower())
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001880 header_txt.append('#include "vktrace_trace_packet_utils.h"\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001881 return "\n".join(header_txt)
1882
1883 def generate_body(self):
Chia-I Wu1f851912015-10-27 18:04:07 +08001884 body = [self._generate_interp_funcs_ext(self.extensionName)]
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001885
1886 return "\n".join(body)
1887
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001888class VktraceReplayVkFuncPtrs(Subcommand):
Chia-I Wu1f851912015-10-27 18:04:07 +08001889 def generate_header(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001890 header_txt = []
1891 header_txt.append('#pragma once\n')
1892 header_txt.append('#if defined(PLATFORM_LINUX) || defined(XCB_NVIDIA)')
1893 header_txt.append('#include <xcb/xcb.h>\n')
1894 header_txt.append('#endif')
1895 header_txt.append('#include "vulkan.h"')
1896 header_txt.append('#include "vk_debug_report_lunarg.h"')
Tobin Ehlise973f772015-08-27 17:41:42 -06001897 header_txt.append('#include "vk_debug_marker_lunarg.h"')
Ian Elliott338dedb2015-08-21 15:09:33 -06001898 header_txt.append('#include "vk_ext_khr_swapchain.h"')
1899 header_txt.append('#include "vk_ext_khr_device_swapchain.h"')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001900
1901 def generate_body(self):
1902 body = [self._generate_replay_func_ptrs()]
1903 return "\n".join(body)
1904
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001905class VktraceReplayObjMapperHeader(Subcommand):
Chia-I Wu1f851912015-10-27 18:04:07 +08001906 def generate_header(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001907 header_txt = []
1908 header_txt.append('#pragma once\n')
1909 header_txt.append('#include <set>')
1910 header_txt.append('#include <map>')
1911 header_txt.append('#include <vector>')
1912 header_txt.append('#include <string>')
1913 header_txt.append('#include "vulkan.h"')
1914 header_txt.append('#include "vk_debug_report_lunarg.h"')
Tobin Ehlise973f772015-08-27 17:41:42 -06001915 header_txt.append('#include "vk_debug_marker_lunarg.h"')
Ian Elliott338dedb2015-08-21 15:09:33 -06001916 header_txt.append('#include "vk_ext_khr_swapchain.h"')
1917 header_txt.append('#include "vk_ext_khr_device_swapchain.h"')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001918 return "\n".join(header_txt)
1919
1920 def generate_body(self):
1921 body = [self._generate_replay_objmapper_class()]
1922 return "\n".join(body)
1923
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001924class VktraceReplayC(Subcommand):
Chia-I Wu1f851912015-10-27 18:04:07 +08001925 def generate_header(self, extensionName):
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001926 header_txt = []
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001927 header_txt.append('#include "vkreplay_vkreplay.h"\n')
1928 header_txt.append('#include "vkreplay.h"\n')
1929 header_txt.append('#include "vkreplay_main.h"\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001930 header_txt.append('#include <algorithm>')
1931 header_txt.append('#include <queue>')
1932 header_txt.append('\n')
1933 header_txt.append('extern "C" {')
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001934 header_txt.append('#include "vktrace_vk_vk_packets.h"')
1935 header_txt.append('#include "vktrace_vk_vk_debug_report_lunarg_packets.h"')
Tobin Ehlise973f772015-08-27 17:41:42 -06001936 header_txt.append('#include "vktrace_vk_vk_debug_marker_lunarg_packets.h"')
Ian Elliott338dedb2015-08-21 15:09:33 -06001937 header_txt.append('#include "vktrace_vk_vk_ext_khr_swapchain_packets.h"')
1938 header_txt.append('#include "vktrace_vk_vk_ext_khr_device_swapchain_packets.h"')
Mark Lobodzinskif39d70c2015-08-14 14:24:50 -06001939 header_txt.append('#include "vktrace_vk_packet_id.h"')
Jon Ashburncb622a12015-08-06 17:22:53 -06001940 #header_txt.append('#include "vk_enum_string_helper.h"\n}\n')
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001941
1942 return "\n".join(header_txt)
1943
1944 def generate_body(self):
1945 body = [self._generate_replay_init_funcs(),
1946 self._generate_replay()]
Jon Ashburncb622a12015-08-06 17:22:53 -06001947 body.append("}")
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001948 return "\n".join(body)
1949
1950def main():
1951 subcommands = {
Mark Lobodzinski87220f82015-08-27 15:30:29 -06001952 "vktrace-trace-h" : VktraceTraceHeader,
1953 "vktrace-trace-c" : VktraceTraceC,
1954 "vktrace-packet-id" : VktracePacketID,
1955 "vktrace-core-trace-packets" : VktraceCoreTracePackets,
1956 "vktrace-ext-trace-h" : VktraceExtTraceHeader,
1957 "vktrace-ext-trace-c" : VktraceExtTraceC,
1958 "vktrace-ext-trace-packets" : VktraceExtTracePackets,
1959 "vktrace-replay-vk-funcs" : VktraceReplayVkFuncPtrs,
1960 "vktrace-replay-obj-mapper-h" : VktraceReplayObjMapperHeader,
1961 "vktrace-replay-c" : VktraceReplayC,
Jon Ashburn4d9cfd22015-08-04 13:35:25 -06001962 }
1963
1964 if len(sys.argv) < 2 or sys.argv[1] not in subcommands:
1965 print("Usage: %s <subcommand> [options]" % sys.argv[0])
1966 print
1967 print("Available subcommands are: %s" % " ".join(subcommands))
1968 exit(1)
1969
1970 subcmd = subcommands[sys.argv[1]](sys.argv[2])
1971 subcmd.run()
1972
1973if __name__ == "__main__":
1974 main()