blob: 7a6e7c834348b703bad902d5a9d073961ecf4078 [file] [log] [blame]
José Fonseca610942b2012-11-08 10:46:03 +00001##########################################################################
2#
3# Copyright 2011 Jose Fonseca
4# All Rights Reserved.
5#
6# Permission is hereby granted, free of charge, to any person obtaining a copy
7# of this software and associated documentation files (the "Software"), to deal
8# in the Software without restriction, including without limitation the rights
9# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10# copies of the Software, and to permit persons to whom the Software is
11# furnished to do so, subject to the following conditions:
12#
13# The above copyright notice and this permission notice shall be included in
14# all copies or substantial portions of the Software.
15#
16# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22# THE SOFTWARE.
23#
24##########################################################################/
25
26
27"""D3D retracer generator."""
28
29
José Fonseca6f810332012-11-11 10:05:09 +000030import sys
José Fonseca610942b2012-11-08 10:46:03 +000031from dllretrace import DllRetracer as Retracer
José Fonseca75cbb8c2013-02-12 16:19:23 +000032import specs.dxgi
José Fonseca6f810332012-11-11 10:05:09 +000033from specs.stdapi import API
34from specs.dxgi import dxgi
35from specs.d3d10 import d3d10
36from specs.d3d10_1 import d3d10_1
37from specs.d3d11 import d3d11
José Fonseca610942b2012-11-08 10:46:03 +000038
39
40class D3DRetracer(Retracer):
41
José Fonsecae3814852012-11-11 09:45:06 +000042 def retraceApi(self, api):
José Fonseca610942b2012-11-08 10:46:03 +000043 print '// Swizzling mapping for lock addresses'
44 print 'static std::map<void *, void *> _maps;'
45 print
José Fonseca73341c22012-11-24 13:04:42 +000046 self.table_name = 'd3dretrace::dxgi_callbacks'
José Fonseca610942b2012-11-08 10:46:03 +000047
José Fonsecae3814852012-11-11 09:45:06 +000048 Retracer.retraceApi(self, api)
José Fonseca610942b2012-11-08 10:46:03 +000049
José Fonseca4f49d212012-11-14 14:02:35 +000050 createDeviceFunctionNames = [
51 "D3D10CreateDevice",
52 "D3D10CreateDeviceAndSwapChain",
53 "D3D10CreateDevice1",
54 "D3D10CreateDeviceAndSwapChain1",
55 "D3D11CreateDevice",
56 "D3D11CreateDeviceAndSwapChain",
57 ]
José Fonseca610942b2012-11-08 10:46:03 +000058
José Fonseca4f49d212012-11-14 14:02:35 +000059 def invokeFunction(self, function):
60 if function.name in self.createDeviceFunctionNames:
61 # create windows as neccessary
62 if 'pSwapChainDesc' in function.argNames():
José Fonseca7d042e02012-11-23 17:01:04 +000063 print r' createWindow(pSwapChainDesc);'
José Fonseca4f49d212012-11-14 14:02:35 +000064
José Fonseca4f49d212012-11-14 14:02:35 +000065 # Compensate for the fact we don't trace DXGI object creation
66 if function.name.startswith('D3D11CreateDevice'):
67 print r' if (DriverType == D3D_DRIVER_TYPE_UNKNOWN && !pAdapter) {'
68 print r' DriverType = D3D_DRIVER_TYPE_HARDWARE;'
69 print r' }'
José Fonsecaea799192012-11-13 21:37:24 +000070
José Fonseca42b89fc2012-11-27 12:19:45 +000071 if function.name.startswith('D3D10CreateDevice'):
José Fonseca7bcc96c2012-12-05 19:28:22 +000072 # Toggle debugging
73 print r' Flags &= ~D3D10_CREATE_DEVICE_DEBUG;'
74 print r' if (retrace::debug) {'
75 print r' if (LoadLibraryA("d3d10sdklayers")) {'
76 print r' Flags |= D3D10_CREATE_DEVICE_DEBUG;'
77 print r' }'
78 print r' }'
79
80 # Force driver
José Fonseca42b89fc2012-11-27 12:19:45 +000081 self.forceDriver('D3D10_DRIVER_TYPE')
José Fonseca7bcc96c2012-12-05 19:28:22 +000082
José Fonseca42b89fc2012-11-27 12:19:45 +000083 if function.name.startswith('D3D11CreateDevice'):
José Fonseca7bcc96c2012-12-05 19:28:22 +000084 # Toggle debugging
85 print r' Flags &= ~D3D11_CREATE_DEVICE_DEBUG;'
86 print r' if (retrace::debug) {'
José Fonseca89b697f2014-06-17 20:26:38 +010087 print r' const char *szD3d11SdkLayers = IsWindows8OrGreater() ? "d3d11_1sdklayers" : "d3d11sdklayers";'
José Fonseca472fa282013-04-23 18:00:40 +010088 print r' if (LoadLibraryA(szD3d11SdkLayers)) {'
José Fonseca7bcc96c2012-12-05 19:28:22 +000089 print r' Flags |= D3D11_CREATE_DEVICE_DEBUG;'
90 print r' }'
91 print r' }'
92
93 # Force driver
José Fonseca42b89fc2012-11-27 12:19:45 +000094 self.forceDriver('D3D_DRIVER_TYPE')
95
José Fonseca610942b2012-11-08 10:46:03 +000096 Retracer.invokeFunction(self, function)
97
José Fonseca25e08d02013-06-28 08:43:50 +010098 # Debug layers with Windows 8 or Windows 7 Platform update are a mess.
99 # It's not possible to know before hand whether they are or not
100 # available, so always retry with debug flag off..
José Fonseca472fa282013-04-23 18:00:40 +0100101 if function.name in self.createDeviceFunctionNames:
102 print r' if (FAILED(_result)) {'
103
104 if function.name.startswith('D3D10CreateDevice'):
105 print r' if (_result == E_FAIL && (Flags & D3D10_CREATE_DEVICE_DEBUG)) {'
106 print r' retrace::warning(call) << "debug layer (d3d10sdklayers.dll) not installed\n";'
José Fonseca25e08d02013-06-28 08:43:50 +0100107 print r' Flags &= ~D3D10_CREATE_DEVICE_DEBUG;'
108 Retracer.invokeFunction(self, function)
José Fonseca472fa282013-04-23 18:00:40 +0100109 print r' }'
José Fonseca25e08d02013-06-28 08:43:50 +0100110 elif function.name.startswith('D3D11CreateDevice'):
José Fonseca472fa282013-04-23 18:00:40 +0100111 print r' if (_result == E_FAIL && (Flags & D3D11_CREATE_DEVICE_DEBUG)) {'
112 print r' retrace::warning(call) << "debug layer (d3d11sdklayers.dll for Windows 7, d3d11_1sdklayers.dll for Windows 8 or Windows 7 with KB 2670838) not properly installed\n";'
José Fonseca25e08d02013-06-28 08:43:50 +0100113 print r' Flags &= ~D3D11_CREATE_DEVICE_DEBUG;'
114 Retracer.invokeFunction(self, function)
José Fonseca472fa282013-04-23 18:00:40 +0100115 print r' }'
José Fonseca25e08d02013-06-28 08:43:50 +0100116 else:
117 assert False
José Fonseca472fa282013-04-23 18:00:40 +0100118
José Fonseca25e08d02013-06-28 08:43:50 +0100119 print r' if (FAILED(_result)) {'
120 print r' exit(1);'
121 print r' }'
122
José Fonseca472fa282013-04-23 18:00:40 +0100123 print r' }'
124
José Fonseca42b89fc2012-11-27 12:19:45 +0000125 def forceDriver(self, enum):
José Fonseca82ea89d2012-12-05 19:34:26 +0000126 # This can only work when pAdapter is NULL. For non-NULL pAdapter we
127 # need to override inside the EnumAdapters call below
128 print r' if (pAdapter == NULL) {'
129 print r' switch (retrace::driver) {'
130 print r' case retrace::DRIVER_HARDWARE:'
131 print r' DriverType = %s_HARDWARE;' % enum
132 print r' Software = NULL;'
133 print r' break;'
134 print r' case retrace::DRIVER_SOFTWARE:'
135 print r' DriverType = %s_WARP;' % enum
136 print r' Software = NULL;'
137 print r' break;'
138 print r' case retrace::DRIVER_REFERENCE:'
139 print r' DriverType = %s_REFERENCE;' % enum
140 print r' Software = NULL;'
141 print r' break;'
142 print r' case retrace::DRIVER_NULL:'
143 print r' DriverType = %s_NULL;' % enum
144 print r' Software = NULL;'
145 print r' break;'
146 print r' case retrace::DRIVER_MODULE:'
147 print r' DriverType = %s_SOFTWARE;' % enum
148 print r' Software = LoadLibraryA(retrace::driverModule);'
José Fonseca42b89fc2012-11-27 12:19:45 +0000149 print r' if (!Software) {'
José Fonseca82ea89d2012-12-05 19:34:26 +0000150 print r' retrace::warning(call) << "failed to load " << retrace::driverModule << "\n";'
José Fonseca42b89fc2012-11-27 12:19:45 +0000151 print r' }'
José Fonseca82ea89d2012-12-05 19:34:26 +0000152 print r' break;'
153 print r' default:'
154 print r' assert(0);'
155 print r' /* fall-through */'
156 print r' case retrace::DRIVER_DEFAULT:'
157 print r' if (DriverType == %s_SOFTWARE) {' % enum
158 print r' Software = LoadLibraryA("d3d10warp");'
159 print r' if (!Software) {'
160 print r' retrace::warning(call) << "failed to load d3d10warp.dll\n";'
161 print r' }'
162 print r' }'
163 print r' break;'
José Fonseca42b89fc2012-11-27 12:19:45 +0000164 print r' }'
José Fonseca82ea89d2012-12-05 19:34:26 +0000165 print r' } else {'
166 print r' Software = NULL;'
José Fonseca42b89fc2012-11-27 12:19:45 +0000167 print r' }'
168
José Fonseca610942b2012-11-08 10:46:03 +0000169 def invokeInterfaceMethod(self, interface, method):
170 # keep track of the last used device for state dumping
José Fonseca944088e2012-11-20 14:47:03 +0000171 if interface.name in ('ID3D10Device', 'ID3D10Device1'):
172 if method.name == 'Release':
José Fonsecadb62f0f2013-06-27 16:15:01 +0100173 print r' if (call.ret->toUInt() == 0) {'
174 print r' d3d10Dumper.unbindDevice(_this);'
175 print r' }'
José Fonseca944088e2012-11-20 14:47:03 +0000176 else:
177 print r' d3d10Dumper.bindDevice(_this);'
Jeff Muizelaar53b01952013-03-12 16:31:17 -0400178 if interface.name in ('ID3D11DeviceContext', 'ID3D11DeviceContext1'):
José Fonseca5773beb2012-11-14 11:46:58 +0000179 if method.name == 'Release':
José Fonsecadb62f0f2013-06-27 16:15:01 +0100180 print r' if (call.ret->toUInt() == 0) {'
181 print r' d3d11Dumper.unbindDevice(_this);'
182 print r' }'
José Fonseca5773beb2012-11-14 11:46:58 +0000183 else:
José Fonseca0dc448e2013-06-13 15:51:48 +0100184 print r' if (_this->GetType() == D3D11_DEVICE_CONTEXT_IMMEDIATE) {'
185 print r' d3d11Dumper.bindDevice(_this);'
186 print r' }'
José Fonseca610942b2012-11-08 10:46:03 +0000187
José Fonsecad59843c2014-08-22 16:59:25 +0100188 if method.name == 'QueryInterface':
José Fonseca75cbb8c2013-02-12 16:19:23 +0000189 print r' if (riid == IID_IDXGIFactoryDWM) {'
José Fonsecad59843c2014-08-22 16:59:25 +0100190 print r' IDXGIFactory *pFactory = NULL;'
191 print r' _result = _this->QueryInterface(IID_IDXGIFactory, (VOID **)&pFactory);'
192 print r' if (SUCCEEDED(_result)) {'
193 print r' *ppvObj = new d3dretrace::CDXGIFactoryDWM(pFactory);'
194 print r' }'
José Fonseca75cbb8c2013-02-12 16:19:23 +0000195 print r' } else {'
196 Retracer.invokeInterfaceMethod(self, interface, method)
197 print r' }'
198 return
199
José Fonseca610942b2012-11-08 10:46:03 +0000200 # create windows as neccessary
201 if method.name == 'CreateSwapChain':
José Fonseca7d042e02012-11-23 17:01:04 +0000202 print r' createWindow(pDesc);'
José Fonsecae23a6be2014-09-14 20:30:00 +0100203 if method.name == 'CreateSwapChainForComposition':
204 print r' HWND hWnd = d3dretrace::createWindow(pDesc->Width, pDesc->Height);'
205 print r' _result = _this->CreateSwapChainForHwnd(pDevice, hWnd, pDesc, NULL, pRestrictToOutput, ppSwapChain);'
206 self.checkResult(method.type)
207 return
José Fonseca610942b2012-11-08 10:46:03 +0000208
José Fonseca7618cb92014-08-28 16:00:48 +0100209 if method.name == 'SetFullscreenState':
210 print r' if (retrace::forceWindowed) {'
211 print r' Fullscreen = FALSE;'
212 print r' }'
213
José Fonseca610942b2012-11-08 10:46:03 +0000214 # notify frame has been completed
215 if method.name == 'Present':
José Fonseca29d4bda2014-02-28 17:50:24 +0000216 if interface.name == 'IDXGISwapChainDWM':
217 print r' dxgiDumper.bindDevice(reinterpret_cast<d3dretrace::CDXGISwapChainDWM *>(_this)->m_pSwapChain);'
218 else:
219 print r' dxgiDumper.bindDevice(_this);'
José Fonseca610942b2012-11-08 10:46:03 +0000220 print r' retrace::frameComplete(call);'
221
222 if 'pSharedResource' in method.argNames():
223 print r' if (pSharedResource) {'
224 print r' retrace::warning(call) << "shared surfaces unsupported\n";'
225 print r' pSharedResource = NULL;'
226 print r' }'
227
José Fonseca82ea89d2012-12-05 19:34:26 +0000228 # Force driver
José Fonsecaad6f60f2013-09-16 14:58:34 +0100229 if interface.name.startswith('IDXGIFactory') and method.name.startswith('EnumAdapters'):
José Fonseca82ea89d2012-12-05 19:34:26 +0000230 print r' const char *szSoftware = NULL;'
231 print r' switch (retrace::driver) {'
232 print r' case retrace::DRIVER_REFERENCE:'
233 print r' case retrace::DRIVER_SOFTWARE:'
234 print r' szSoftware = "d3d10warp.dll";'
235 print r' break;'
236 print r' case retrace::DRIVER_MODULE:'
237 print r' szSoftware = retrace::driverModule;'
238 print r' break;'
239 print r' default:'
240 print r' break;'
241 print r' }'
242 print r' HMODULE hSoftware = NULL;'
243 print r' if (szSoftware) {'
244 print r' hSoftware = LoadLibraryA(szSoftware);'
245 print r' if (!hSoftware) {'
246 print r' retrace::warning(call) << "failed to load " << szSoftware << "\n";'
247 print r' }'
248 print r' }'
249 print r' if (hSoftware) {'
José Fonsecaad6f60f2013-09-16 14:58:34 +0100250 print r' _result = _this->CreateSoftwareAdapter(hSoftware, reinterpret_cast<IDXGIAdapter **>(ppAdapter));'
José Fonseca82ea89d2012-12-05 19:34:26 +0000251 print r' } else {'
252 Retracer.invokeInterfaceMethod(self, interface, method)
253 print r' }'
254 return
255
José Fonsecae23a6be2014-09-14 20:30:00 +0100256 if interface.name.startswith('ID3D10Device') and method.name.startswith('OpenSharedResource'):
José Fonseca75cbb8c2013-02-12 16:19:23 +0000257 print r' retrace::warning(call) << "replacing shared resource with checker pattern\n";'
258 print r' D3D10_TEXTURE2D_DESC Desc;'
259 print r' memset(&Desc, 0, sizeof Desc);'
260 print r' Desc.Width = 8;'
261 print r' Desc.Height = 8;'
262 print r' Desc.MipLevels = 1;'
263 print r' Desc.ArraySize = 1;'
264 print r' Desc.Format = DXGI_FORMAT_B8G8R8A8_UNORM;'
265 print r' Desc.SampleDesc.Count = 1;'
266 print r' Desc.SampleDesc.Quality = 0;'
267 print r' Desc.Usage = D3D10_USAGE_DEFAULT;'
268 print r' Desc.BindFlags = D3D10_BIND_SHADER_RESOURCE | D3D10_BIND_RENDER_TARGET;'
269 print r' Desc.CPUAccessFlags = 0x0;'
270 print r' Desc.MiscFlags = 0 /* D3D10_RESOURCE_MISC_SHARED */;'
271 print r'''
José Fonsecaa15929f2014-05-03 21:54:37 +0100272 static const DWORD Checker[8][8] = {
273 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
274 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
275 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
276 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
277 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
278 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
279 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
280 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U }
José Fonseca75cbb8c2013-02-12 16:19:23 +0000281 };
José Fonsecaa15929f2014-05-03 21:54:37 +0100282 static const D3D10_SUBRESOURCE_DATA InitialData = {Checker, sizeof Checker[0], sizeof Checker};
José Fonseca75cbb8c2013-02-12 16:19:23 +0000283 '''
284 print r' _result = _this->CreateTexture2D(&Desc, &InitialData, (ID3D10Texture2D**)ppResource);'
285 self.checkResult(method.type)
José Fonseca999284f2013-02-19 13:29:26 +0000286 return
José Fonseca2b66b932014-07-30 17:31:52 +0100287 if interface.name.startswith('ID3D11Device') and method.name.startswith('OpenSharedResource'):
288 print r' retrace::warning(call) << "replacing shared resource with checker pattern\n";'
289 print
290 if method.name == 'OpenSharedResourceByName':
291 print r' (void)lpName;'
292 print r' (void)dwDesiredAccess;'
293 print
294 print r' D3D11_TEXTURE2D_DESC Desc;'
295 print r' memset(&Desc, 0, sizeof Desc);'
296 print r' Desc.Width = 8;'
297 print r' Desc.Height = 8;'
298 print r' Desc.MipLevels = 1;'
299 print r' Desc.ArraySize = 1;'
300 print r' Desc.Format = DXGI_FORMAT_B8G8R8A8_UNORM;'
301 print r' Desc.SampleDesc.Count = 1;'
302 print r' Desc.SampleDesc.Quality = 0;'
303 print r' Desc.Usage = D3D11_USAGE_DEFAULT;'
304 print r' Desc.BindFlags = D3D11_BIND_SHADER_RESOURCE | D3D11_BIND_RENDER_TARGET;'
305 print r' Desc.CPUAccessFlags = 0x0;'
306 print r' Desc.MiscFlags = 0 /* D3D11_RESOURCE_MISC_SHARED */;'
307 print r'''
308 static const DWORD Checker[8][8] = {
309 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
310 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
311 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
312 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
313 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
314 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
315 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
316 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U }
317 };
318 static const D3D11_SUBRESOURCE_DATA InitialData = {Checker, sizeof Checker[0], sizeof Checker};
319 '''
320 print r' _result = _this->CreateTexture2D(&Desc, &InitialData, (ID3D11Texture2D**)ppResource);'
321 self.checkResult(method.type)
322 return
José Fonseca999284f2013-02-19 13:29:26 +0000323
324 if method.name == 'Map':
325 # Reset _DO_NOT_WAIT flags. Otherwise they may fail, and we have no
326 # way to cope with it (other than retry).
327 mapFlagsArg = method.getArgByName('MapFlags')
328 for flag in mapFlagsArg.type.values:
329 if flag.endswith('_MAP_FLAG_DO_NOT_WAIT'):
330 print r' MapFlags &= ~%s;' % flag
331
José Fonseca7af569a2014-09-04 19:08:45 +0100332 if method.name.startswith('UpdateSubresource'):
José Fonsecac9cc24e2014-06-13 19:06:51 +0100333 # The D3D10 debug layer is buggy (or at least inconsistent with the
334 # runtime), as it seems to estimate and enforce the data size based on the
335 # SrcDepthPitch, even for non 3D textures, but in some traces
336 # SrcDepthPitch is garbagge for non 3D textures.
337 # XXX: It also seems to expect padding bytes at the end of the last
338 # row, but we never record (or allocate) those...
339 print r' if (retrace::debug && pDstBox && pDstBox->front == 0 && pDstBox->back == 1) {'
340 print r' SrcDepthPitch = 0;'
341 print r' }'
342
José Fonseca0688d2e2014-08-19 20:43:21 +0100343 if method.name == 'SetGammaControl':
344 # This method is only supported while in full-screen mode
345 print r' if (retrace::forceWindowed) {'
346 print r' return;'
347 print r' }'
348
José Fonseca999284f2013-02-19 13:29:26 +0000349 Retracer.invokeInterfaceMethod(self, interface, method)
José Fonseca610942b2012-11-08 10:46:03 +0000350
351 # process events after presents
352 if method.name == 'Present':
353 print r' d3dretrace::processEvents();'
354
José Fonseca610942b2012-11-08 10:46:03 +0000355 if method.name == 'Map':
José Fonseca003b8be2013-05-29 19:59:40 +0100356 print ' _MAP_DESC _MapDesc;'
357 print ' _getMapDesc(_this, %s, _MapDesc);' % ', '.join(method.argNames())
358 print ' size_t _MappedSize = _MapDesc.Size;'
359 print ' if (_MapDesc.Size) {'
Jeff Muizelaar97244f92013-11-19 15:17:45 -0500360 if interface.name.startswith('ID3D11DeviceContext'):
361 print ' _maps[pResource] = _MapDesc.pData;'
362 else:
363 print ' _maps[_this] = _MapDesc.pData;'
José Fonsecafacdb352014-09-05 13:22:01 +0100364 self.checkPitchMismatch(method)
José Fonseca4f49d212012-11-14 14:02:35 +0000365 print ' } else {'
366 print ' return;'
367 print ' }'
José Fonseca610942b2012-11-08 10:46:03 +0000368
369 if method.name == 'Unmap':
Jeff Muizelaar97244f92013-11-19 15:17:45 -0500370 if interface.name.startswith('ID3D11DeviceContext'):
371 print ' VOID *_pbData = 0;'
372 print ' _pbData = _maps[pResource];'
373 print ' if (_pbData) {'
374 print ' retrace::delRegionByPointer(_pbData);'
375 print ' _maps[pResource] = 0;'
376 print ' }'
377 else:
378 print ' VOID *_pbData = 0;'
379 print ' _pbData = _maps[_this];'
380 print ' if (_pbData) {'
381 print ' retrace::delRegionByPointer(_pbData);'
382 print ' _maps[_this] = 0;'
383 print ' }'
José Fonseca6f810332012-11-11 10:05:09 +0000384
José Fonseca1d4fd142012-11-28 15:06:22 +0000385 # Attach shader byte code for lookup
386 if 'pShaderBytecode' in method.argNames():
387 ppShader = method.args[-1]
388 assert ppShader.output
389 print r' if (retrace::dumpingState && SUCCEEDED(_result)) {'
390 print r' (*%s)->SetPrivateData(d3dstate::GUID_D3DSTATE, BytecodeLength, pShaderBytecode);' % ppShader.name
391 print r' }'
392
José Fonseca6f810332012-11-11 10:05:09 +0000393
394def main():
José Fonseca75cbb8c2013-02-12 16:19:23 +0000395 print r'#define INITGUID'
396 print
José Fonseca73341c22012-11-24 13:04:42 +0000397 print r'#include <string.h>'
José Fonseca6f810332012-11-11 10:05:09 +0000398 print
399 print r'#include <iostream>'
400 print
401 print r'#include "d3dretrace.hpp"'
José Fonseca89b697f2014-06-17 20:26:38 +0100402 print r'#include "os_version.hpp"'
José Fonseca6f810332012-11-11 10:05:09 +0000403 print
404
405 moduleNames = sys.argv[1:]
406
407 api = API()
José Fonseca944088e2012-11-20 14:47:03 +0000408
José Fonseca6f810332012-11-11 10:05:09 +0000409 if moduleNames:
José Fonseca75cbb8c2013-02-12 16:19:23 +0000410 print r'#include "d3dretrace_dxgi.hpp"'
José Fonsecafc58d052014-06-13 12:47:19 +0100411 print r'#include "d3d10imports.hpp"'
José Fonseca6f810332012-11-11 10:05:09 +0000412 print r'#include "d3d10size.hpp"'
José Fonseca29d4bda2014-02-28 17:50:24 +0000413 print r'#include "d3d10state.hpp"'
José Fonseca6f810332012-11-11 10:05:09 +0000414 print r'#include "d3d11imports.hpp"'
José Fonseca6f810332012-11-11 10:05:09 +0000415 print r'#include "d3d11size.hpp"'
José Fonseca5773beb2012-11-14 11:46:58 +0000416 print r'#include "d3dstate.hpp"'
José Fonseca5773beb2012-11-14 11:46:58 +0000417 print
José Fonsecafc58d052014-06-13 12:47:19 +0100418 print '''static d3dretrace::D3DDumper<IDXGISwapChain> dxgiDumper;'''
419 print '''static d3dretrace::D3DDumper<ID3D10Device> d3d10Dumper;'''
José Fonseca5773beb2012-11-14 11:46:58 +0000420 print '''static d3dretrace::D3DDumper<ID3D11DeviceContext> d3d11Dumper;'''
421 print
José Fonseca18178e02014-06-17 23:07:49 +0100422 print r'''
423static void
424createWindow(DXGI_SWAP_CHAIN_DESC *pSwapChainDesc) {
425 UINT Width = pSwapChainDesc->BufferDesc.Width;
426 UINT Height = pSwapChainDesc->BufferDesc.Height;
427 if (!Width) Width = 1024;
428 if (!Height) Height = 768;
José Fonseca0688d2e2014-08-19 20:43:21 +0100429 if (retrace::forceWindowed) {
430 pSwapChainDesc->Windowed = TRUE;
431 }
José Fonseca18178e02014-06-17 23:07:49 +0100432 pSwapChainDesc->OutputWindow = d3dretrace::createWindow(Width, Height);
433}
434'''
José Fonseca6f810332012-11-11 10:05:09 +0000435
José Fonsecafc58d052014-06-13 12:47:19 +0100436 api.addModule(dxgi)
437 api.addModule(d3d10)
438 api.addModule(d3d10_1)
439 api.addModule(d3d11)
440
José Fonseca6f810332012-11-11 10:05:09 +0000441 retracer = D3DRetracer()
442 retracer.retraceApi(api)
443
444
445if __name__ == '__main__':
446 main()