blob: d4ec9b0a3885aa1162de725aeae2050f8fc56aa3 [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
José Fonseca3be2c672015-02-06 15:36:40 +000034from specs.winapi import LPCSTR
José Fonseca6f810332012-11-11 10:05:09 +000035from specs.dxgi import dxgi
Jose Fonsecaa92e0c42015-03-14 10:49:23 +000036from specs.d3d10 import d3d10, d3d10_1
José Fonseca6f810332012-11-11 10:05:09 +000037from 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é Fonseca6ca20082014-10-07 21:39:43 +010043 print '// Swizzling mapping for lock addresses, mapping a (pDeviceContext, pResource, Subresource) -> void *'
44 print 'typedef std::pair< IUnknown *, UINT > SubresourceKey;'
45 print 'static std::map< IUnknown *, std::map< SubresourceKey, void * > > g_Maps;'
José Fonseca610942b2012-11-08 10:46:03 +000046 print
José Fonseca73341c22012-11-24 13:04:42 +000047 self.table_name = 'd3dretrace::dxgi_callbacks'
José Fonseca610942b2012-11-08 10:46:03 +000048
José Fonsecae3814852012-11-11 09:45:06 +000049 Retracer.retraceApi(self, api)
José Fonseca610942b2012-11-08 10:46:03 +000050
José Fonseca4f49d212012-11-14 14:02:35 +000051 createDeviceFunctionNames = [
52 "D3D10CreateDevice",
53 "D3D10CreateDeviceAndSwapChain",
54 "D3D10CreateDevice1",
55 "D3D10CreateDeviceAndSwapChain1",
56 "D3D11CreateDevice",
57 "D3D11CreateDeviceAndSwapChain",
58 ]
José Fonseca610942b2012-11-08 10:46:03 +000059
José Fonseca4f49d212012-11-14 14:02:35 +000060 def invokeFunction(self, function):
61 if function.name in self.createDeviceFunctionNames:
62 # create windows as neccessary
63 if 'pSwapChainDesc' in function.argNames():
José Fonseca1e309b42014-09-18 11:08:09 +010064 print r' d3dretrace::createWindowForSwapChain(pSwapChainDesc);'
José Fonseca4f49d212012-11-14 14:02:35 +000065
José Fonseca4f49d212012-11-14 14:02:35 +000066 # Compensate for the fact we don't trace DXGI object creation
67 if function.name.startswith('D3D11CreateDevice'):
68 print r' if (DriverType == D3D_DRIVER_TYPE_UNKNOWN && !pAdapter) {'
69 print r' DriverType = D3D_DRIVER_TYPE_HARDWARE;'
70 print r' }'
José Fonsecaea799192012-11-13 21:37:24 +000071
José Fonseca42b89fc2012-11-27 12:19:45 +000072 if function.name.startswith('D3D10CreateDevice'):
José Fonseca7bcc96c2012-12-05 19:28:22 +000073 # Toggle debugging
74 print r' Flags &= ~D3D10_CREATE_DEVICE_DEBUG;'
75 print r' if (retrace::debug) {'
José Fonseca83d33912014-12-03 13:17:57 +000076 print r' HMODULE hD3d10SdkLayers = LoadLibraryA("d3d10sdklayers");'
77 print r' if (hD3d10SdkLayers) {'
78 print r' FreeLibrary(hD3d10SdkLayers);'
José Fonseca7bcc96c2012-12-05 19:28:22 +000079 print r' Flags |= D3D10_CREATE_DEVICE_DEBUG;'
José Fonseca83d33912014-12-03 13:17:57 +000080 print r' } else {'
81 print r' retrace::warning(call) << "Direct3D 10.x SDK Debug Layer (d3d10sdklayers.dll) not available, continuing without debug output\n";'
José Fonseca7bcc96c2012-12-05 19:28:22 +000082 print r' }'
83 print r' }'
84
85 # Force driver
José Fonseca42b89fc2012-11-27 12:19:45 +000086 self.forceDriver('D3D10_DRIVER_TYPE')
José Fonseca7bcc96c2012-12-05 19:28:22 +000087
José Fonseca42b89fc2012-11-27 12:19:45 +000088 if function.name.startswith('D3D11CreateDevice'):
José Fonseca7bcc96c2012-12-05 19:28:22 +000089 # Toggle debugging
90 print r' Flags &= ~D3D11_CREATE_DEVICE_DEBUG;'
91 print r' if (retrace::debug) {'
José Fonseca83d33912014-12-03 13:17:57 +000092 print r' HRESULT hr = D3D11CreateDevice(NULL, D3D_DRIVER_TYPE_NULL, 0, D3D11_CREATE_DEVICE_DEBUG, NULL, 0, D3D11_SDK_VERSION, NULL, NULL, NULL);'
93 print r' if (SUCCEEDED(hr)) {'
José Fonseca7bcc96c2012-12-05 19:28:22 +000094 print r' Flags |= D3D11_CREATE_DEVICE_DEBUG;'
José Fonseca83d33912014-12-03 13:17:57 +000095 print r' } else {'
96 print r' retrace::warning(call) << "Direct3D 11.x SDK Debug Layer (d3d11*sdklayers.dll) not available, continuing without debug output\n";'
José Fonseca7bcc96c2012-12-05 19:28:22 +000097 print r' }'
98 print r' }'
99
100 # Force driver
José Fonseca42b89fc2012-11-27 12:19:45 +0000101 self.forceDriver('D3D_DRIVER_TYPE')
102
José Fonseca610942b2012-11-08 10:46:03 +0000103 Retracer.invokeFunction(self, function)
104
José Fonseca42b89fc2012-11-27 12:19:45 +0000105 def forceDriver(self, enum):
José Fonseca82ea89d2012-12-05 19:34:26 +0000106 # This can only work when pAdapter is NULL. For non-NULL pAdapter we
107 # need to override inside the EnumAdapters call below
108 print r' if (pAdapter == NULL) {'
109 print r' switch (retrace::driver) {'
110 print r' case retrace::DRIVER_HARDWARE:'
111 print r' DriverType = %s_HARDWARE;' % enum
112 print r' Software = NULL;'
113 print r' break;'
114 print r' case retrace::DRIVER_SOFTWARE:'
115 print r' DriverType = %s_WARP;' % enum
116 print r' Software = NULL;'
117 print r' break;'
118 print r' case retrace::DRIVER_REFERENCE:'
119 print r' DriverType = %s_REFERENCE;' % enum
120 print r' Software = NULL;'
121 print r' break;'
122 print r' case retrace::DRIVER_NULL:'
123 print r' DriverType = %s_NULL;' % enum
124 print r' Software = NULL;'
125 print r' break;'
126 print r' case retrace::DRIVER_MODULE:'
127 print r' DriverType = %s_SOFTWARE;' % enum
128 print r' Software = LoadLibraryA(retrace::driverModule);'
José Fonseca42b89fc2012-11-27 12:19:45 +0000129 print r' if (!Software) {'
José Fonseca82ea89d2012-12-05 19:34:26 +0000130 print r' retrace::warning(call) << "failed to load " << retrace::driverModule << "\n";'
José Fonseca42b89fc2012-11-27 12:19:45 +0000131 print r' }'
José Fonseca82ea89d2012-12-05 19:34:26 +0000132 print r' break;'
133 print r' default:'
134 print r' assert(0);'
135 print r' /* fall-through */'
136 print r' case retrace::DRIVER_DEFAULT:'
137 print r' if (DriverType == %s_SOFTWARE) {' % enum
138 print r' Software = LoadLibraryA("d3d10warp");'
139 print r' if (!Software) {'
140 print r' retrace::warning(call) << "failed to load d3d10warp.dll\n";'
141 print r' }'
142 print r' }'
143 print r' break;'
José Fonseca42b89fc2012-11-27 12:19:45 +0000144 print r' }'
José Fonseca82ea89d2012-12-05 19:34:26 +0000145 print r' } else {'
146 print r' Software = NULL;'
José Fonseca42b89fc2012-11-27 12:19:45 +0000147 print r' }'
148
José Fonseca610942b2012-11-08 10:46:03 +0000149 def invokeInterfaceMethod(self, interface, method):
150 # keep track of the last used device for state dumping
José Fonseca944088e2012-11-20 14:47:03 +0000151 if interface.name in ('ID3D10Device', 'ID3D10Device1'):
152 if method.name == 'Release':
José Fonsecadb62f0f2013-06-27 16:15:01 +0100153 print r' if (call.ret->toUInt() == 0) {'
154 print r' d3d10Dumper.unbindDevice(_this);'
155 print r' }'
José Fonseca944088e2012-11-20 14:47:03 +0000156 else:
157 print r' d3d10Dumper.bindDevice(_this);'
Jeff Muizelaar53b01952013-03-12 16:31:17 -0400158 if interface.name in ('ID3D11DeviceContext', 'ID3D11DeviceContext1'):
José Fonseca5773beb2012-11-14 11:46:58 +0000159 if method.name == 'Release':
José Fonsecadb62f0f2013-06-27 16:15:01 +0100160 print r' if (call.ret->toUInt() == 0) {'
161 print r' d3d11Dumper.unbindDevice(_this);'
162 print r' }'
José Fonseca5773beb2012-11-14 11:46:58 +0000163 else:
José Fonseca0dc448e2013-06-13 15:51:48 +0100164 print r' if (_this->GetType() == D3D11_DEVICE_CONTEXT_IMMEDIATE) {'
165 print r' d3d11Dumper.bindDevice(_this);'
166 print r' }'
José Fonseca610942b2012-11-08 10:46:03 +0000167
José Fonseca1e309b42014-09-18 11:08:09 +0100168 # intercept private interfaces
José Fonsecad59843c2014-08-22 16:59:25 +0100169 if method.name == 'QueryInterface':
José Fonsecac44c62c2014-09-22 13:42:42 +0100170 print r' if (!d3dretrace::overrideQueryInterface(_this, riid, ppvObj, &_result)) {'
José Fonseca75cbb8c2013-02-12 16:19:23 +0000171 Retracer.invokeInterfaceMethod(self, interface, method)
172 print r' }'
173 return
174
José Fonseca610942b2012-11-08 10:46:03 +0000175 # create windows as neccessary
176 if method.name == 'CreateSwapChain':
José Fonseca1e309b42014-09-18 11:08:09 +0100177 print r' d3dretrace::createWindowForSwapChain(pDesc);'
José Fonsecae23a6be2014-09-14 20:30:00 +0100178 if method.name == 'CreateSwapChainForComposition':
179 print r' HWND hWnd = d3dretrace::createWindow(pDesc->Width, pDesc->Height);'
180 print r' _result = _this->CreateSwapChainForHwnd(pDevice, hWnd, pDesc, NULL, pRestrictToOutput, ppSwapChain);'
181 self.checkResult(method.type)
182 return
José Fonseca610942b2012-11-08 10:46:03 +0000183
José Fonseca7618cb92014-08-28 16:00:48 +0100184 if method.name == 'SetFullscreenState':
185 print r' if (retrace::forceWindowed) {'
186 print r' Fullscreen = FALSE;'
José Fonseca693382a2014-10-03 14:27:59 +0100187 print r' pTarget = NULL;'
José Fonseca7618cb92014-08-28 16:00:48 +0100188 print r' }'
189
José Fonseca610942b2012-11-08 10:46:03 +0000190 # notify frame has been completed
191 if method.name == 'Present':
José Fonseca29d4bda2014-02-28 17:50:24 +0000192 if interface.name == 'IDXGISwapChainDWM':
José Fonseca1e309b42014-09-18 11:08:09 +0100193 print r' com_ptr<IDXGISwapChain> pSwapChain;'
194 print r' if (SUCCEEDED(_this->QueryInterface(IID_IDXGISwapChain, (void **) &pSwapChain))) {'
195 print r' dxgiDumper.bindDevice(pSwapChain);'
196 print r' } else {'
197 print r' assert(0);'
198 print r' }'
José Fonseca29d4bda2014-02-28 17:50:24 +0000199 else:
200 print r' dxgiDumper.bindDevice(_this);'
José Fonseca610942b2012-11-08 10:46:03 +0000201 print r' retrace::frameComplete(call);'
202
203 if 'pSharedResource' in method.argNames():
204 print r' if (pSharedResource) {'
205 print r' retrace::warning(call) << "shared surfaces unsupported\n";'
206 print r' pSharedResource = NULL;'
207 print r' }'
208
José Fonseca82ea89d2012-12-05 19:34:26 +0000209 # Force driver
José Fonsecaad6f60f2013-09-16 14:58:34 +0100210 if interface.name.startswith('IDXGIFactory') and method.name.startswith('EnumAdapters'):
José Fonseca82ea89d2012-12-05 19:34:26 +0000211 print r' const char *szSoftware = NULL;'
212 print r' switch (retrace::driver) {'
213 print r' case retrace::DRIVER_REFERENCE:'
214 print r' case retrace::DRIVER_SOFTWARE:'
215 print r' szSoftware = "d3d10warp.dll";'
216 print r' break;'
217 print r' case retrace::DRIVER_MODULE:'
218 print r' szSoftware = retrace::driverModule;'
219 print r' break;'
220 print r' default:'
221 print r' break;'
222 print r' }'
223 print r' HMODULE hSoftware = NULL;'
224 print r' if (szSoftware) {'
225 print r' hSoftware = LoadLibraryA(szSoftware);'
226 print r' if (!hSoftware) {'
227 print r' retrace::warning(call) << "failed to load " << szSoftware << "\n";'
228 print r' }'
229 print r' }'
230 print r' if (hSoftware) {'
José Fonsecaad6f60f2013-09-16 14:58:34 +0100231 print r' _result = _this->CreateSoftwareAdapter(hSoftware, reinterpret_cast<IDXGIAdapter **>(ppAdapter));'
José Fonseca82ea89d2012-12-05 19:34:26 +0000232 print r' } else {'
233 Retracer.invokeInterfaceMethod(self, interface, method)
234 print r' }'
235 return
236
José Fonsecae23a6be2014-09-14 20:30:00 +0100237 if interface.name.startswith('ID3D10Device') and method.name.startswith('OpenSharedResource'):
José Fonseca75cbb8c2013-02-12 16:19:23 +0000238 print r' retrace::warning(call) << "replacing shared resource with checker pattern\n";'
239 print r' D3D10_TEXTURE2D_DESC Desc;'
240 print r' memset(&Desc, 0, sizeof Desc);'
241 print r' Desc.Width = 8;'
242 print r' Desc.Height = 8;'
243 print r' Desc.MipLevels = 1;'
244 print r' Desc.ArraySize = 1;'
245 print r' Desc.Format = DXGI_FORMAT_B8G8R8A8_UNORM;'
246 print r' Desc.SampleDesc.Count = 1;'
247 print r' Desc.SampleDesc.Quality = 0;'
248 print r' Desc.Usage = D3D10_USAGE_DEFAULT;'
249 print r' Desc.BindFlags = D3D10_BIND_SHADER_RESOURCE | D3D10_BIND_RENDER_TARGET;'
250 print r' Desc.CPUAccessFlags = 0x0;'
251 print r' Desc.MiscFlags = 0 /* D3D10_RESOURCE_MISC_SHARED */;'
252 print r'''
José Fonsecaa15929f2014-05-03 21:54:37 +0100253 static const DWORD Checker[8][8] = {
254 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
255 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
256 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
257 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
258 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
259 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
260 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
261 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U }
José Fonseca75cbb8c2013-02-12 16:19:23 +0000262 };
José Fonsecaa15929f2014-05-03 21:54:37 +0100263 static const D3D10_SUBRESOURCE_DATA InitialData = {Checker, sizeof Checker[0], sizeof Checker};
José Fonseca75cbb8c2013-02-12 16:19:23 +0000264 '''
José Fonseca0f7792c2014-09-26 14:20:32 +0100265 print r' com_ptr<ID3D10Texture2D> pResource;'
266 print r' _result = _this->CreateTexture2D(&Desc, &InitialData, &pResource);'
267 print r' if (SUCCEEDED(_result)) {'
268 print r' _result = pResource->QueryInterface(ReturnedInterface, ppResource);'
269 print r' }'
José Fonseca75cbb8c2013-02-12 16:19:23 +0000270 self.checkResult(method.type)
José Fonseca999284f2013-02-19 13:29:26 +0000271 return
José Fonseca2b66b932014-07-30 17:31:52 +0100272 if interface.name.startswith('ID3D11Device') and method.name.startswith('OpenSharedResource'):
273 print r' retrace::warning(call) << "replacing shared resource with checker pattern\n";'
274 print
275 if method.name == 'OpenSharedResourceByName':
276 print r' (void)lpName;'
277 print r' (void)dwDesiredAccess;'
278 print
279 print r' D3D11_TEXTURE2D_DESC Desc;'
280 print r' memset(&Desc, 0, sizeof Desc);'
281 print r' Desc.Width = 8;'
282 print r' Desc.Height = 8;'
283 print r' Desc.MipLevels = 1;'
284 print r' Desc.ArraySize = 1;'
285 print r' Desc.Format = DXGI_FORMAT_B8G8R8A8_UNORM;'
286 print r' Desc.SampleDesc.Count = 1;'
287 print r' Desc.SampleDesc.Quality = 0;'
288 print r' Desc.Usage = D3D11_USAGE_DEFAULT;'
289 print r' Desc.BindFlags = D3D11_BIND_SHADER_RESOURCE | D3D11_BIND_RENDER_TARGET;'
290 print r' Desc.CPUAccessFlags = 0x0;'
291 print r' Desc.MiscFlags = 0 /* D3D11_RESOURCE_MISC_SHARED */;'
292 print r'''
293 static const DWORD Checker[8][8] = {
294 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
295 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
296 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
297 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
298 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
299 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U },
300 { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U },
301 {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U }
302 };
303 static const D3D11_SUBRESOURCE_DATA InitialData = {Checker, sizeof Checker[0], sizeof Checker};
304 '''
José Fonseca0f7792c2014-09-26 14:20:32 +0100305 print r' com_ptr<ID3D11Texture2D> pResource;'
306 print r' _result = _this->CreateTexture2D(&Desc, &InitialData, &pResource);'
307 print r' if (SUCCEEDED(_result)) {'
308 print r' _result = pResource->QueryInterface(ReturnedInterface, ppResource);'
309 print r' }'
José Fonseca2b66b932014-07-30 17:31:52 +0100310 self.checkResult(method.type)
311 return
José Fonseca999284f2013-02-19 13:29:26 +0000312
313 if method.name == 'Map':
314 # Reset _DO_NOT_WAIT flags. Otherwise they may fail, and we have no
315 # way to cope with it (other than retry).
316 mapFlagsArg = method.getArgByName('MapFlags')
317 for flag in mapFlagsArg.type.values:
318 if flag.endswith('_MAP_FLAG_DO_NOT_WAIT'):
319 print r' MapFlags &= ~%s;' % flag
320
José Fonseca7af569a2014-09-04 19:08:45 +0100321 if method.name.startswith('UpdateSubresource'):
José Fonsecac9cc24e2014-06-13 19:06:51 +0100322 # The D3D10 debug layer is buggy (or at least inconsistent with the
323 # runtime), as it seems to estimate and enforce the data size based on the
324 # SrcDepthPitch, even for non 3D textures, but in some traces
325 # SrcDepthPitch is garbagge for non 3D textures.
326 # XXX: It also seems to expect padding bytes at the end of the last
327 # row, but we never record (or allocate) those...
328 print r' if (retrace::debug && pDstBox && pDstBox->front == 0 && pDstBox->back == 1) {'
329 print r' SrcDepthPitch = 0;'
330 print r' }'
331
José Fonseca0688d2e2014-08-19 20:43:21 +0100332 if method.name == 'SetGammaControl':
333 # This method is only supported while in full-screen mode
334 print r' if (retrace::forceWindowed) {'
335 print r' return;'
336 print r' }'
337
José Fonseca999284f2013-02-19 13:29:26 +0000338 Retracer.invokeInterfaceMethod(self, interface, method)
José Fonseca610942b2012-11-08 10:46:03 +0000339
340 # process events after presents
341 if method.name == 'Present':
342 print r' d3dretrace::processEvents();'
343
José Fonseca6ca20082014-10-07 21:39:43 +0100344 if method.name in ('Map', 'Unmap'):
345 if interface.name.startswith('ID3D11DeviceContext'):
346 print ' void * & _pbData = g_Maps[_this][SubresourceKey(pResource, Subresource)];'
347 else:
348 subresourceArg = method.getArgByName('Subresource')
349 if subresourceArg is None:
350 print ' UINT Subresource = 0;'
351 print ' void * & _pbData = g_Maps[0][SubresourceKey(_this, Subresource)];'
352
José Fonseca610942b2012-11-08 10:46:03 +0000353 if method.name == 'Map':
José Fonseca003b8be2013-05-29 19:59:40 +0100354 print ' _MAP_DESC _MapDesc;'
355 print ' _getMapDesc(_this, %s, _MapDesc);' % ', '.join(method.argNames())
356 print ' size_t _MappedSize = _MapDesc.Size;'
357 print ' if (_MapDesc.Size) {'
José Fonseca6ca20082014-10-07 21:39:43 +0100358 print ' _pbData = _MapDesc.pData;'
Jeff Muizelaar97244f92013-11-19 15:17:45 -0500359 if interface.name.startswith('ID3D11DeviceContext'):
José Fonsecae9074632014-09-26 14:23:19 +0100360 # XXX: Unforunately this cause many false warnings on 1D and 2D
361 # resources, since the pitches are junk there...
362 #self.checkPitchMismatch(method)
José Fonseca6ca20082014-10-07 21:39:43 +0100363 pass
Jeff Muizelaar97244f92013-11-19 15:17:45 -0500364 else:
José Fonseca6ca20082014-10-07 21:39:43 +0100365 print ' _pbData = _MapDesc.pData;'
José Fonsecae9074632014-09-26 14:23:19 +0100366 self.checkPitchMismatch(method)
José Fonseca4f49d212012-11-14 14:02:35 +0000367 print ' } else {'
368 print ' return;'
369 print ' }'
José Fonseca610942b2012-11-08 10:46:03 +0000370
371 if method.name == 'Unmap':
José Fonseca6ca20082014-10-07 21:39:43 +0100372 print ' if (_pbData) {'
373 print ' retrace::delRegionByPointer(_pbData);'
374 print ' _pbData = 0;'
375 print ' }'
José Fonseca6f810332012-11-11 10:05:09 +0000376
José Fonseca1d4fd142012-11-28 15:06:22 +0000377 # Attach shader byte code for lookup
378 if 'pShaderBytecode' in method.argNames():
379 ppShader = method.args[-1]
380 assert ppShader.output
381 print r' if (retrace::dumpingState && SUCCEEDED(_result)) {'
382 print r' (*%s)->SetPrivateData(d3dstate::GUID_D3DSTATE, BytecodeLength, pShaderBytecode);' % ppShader.name
383 print r' }'
384
José Fonseca3be2c672015-02-06 15:36:40 +0000385 def extractArg(self, function, arg, arg_type, lvalue, rvalue):
386 # Set object names
387 if function.name == 'SetPrivateData' and arg.name == 'pData':
388 iid = function.args[0].name
389 print r' if (%s != WKPDID_D3DDebugObjectName) {' % iid
390 print r' return;'
391 print r' }'
392 # Interpret argument as string
393 Retracer.extractArg(self, function, arg, LPCSTR, lvalue, rvalue)
394 print r' assert(pData);'
395 print r' assert(DataSize == strlen((const char *)pData));'
396 return
397
398 Retracer.extractArg(self, function, arg, arg_type, lvalue, rvalue)
399
José Fonseca6f810332012-11-11 10:05:09 +0000400
401def main():
José Fonseca75cbb8c2013-02-12 16:19:23 +0000402 print r'#define INITGUID'
403 print
José Fonseca73341c22012-11-24 13:04:42 +0000404 print r'#include <string.h>'
José Fonseca6f810332012-11-11 10:05:09 +0000405 print
406 print r'#include <iostream>'
407 print
408 print r'#include "d3dretrace.hpp"'
José Fonseca89b697f2014-06-17 20:26:38 +0100409 print r'#include "os_version.hpp"'
José Fonseca6f810332012-11-11 10:05:09 +0000410 print
José Fonseca50bee952015-02-07 22:32:19 +0000411 print r'#include "d3dretrace_dxgi.hpp"'
412 print r'#include "d3d10imports.hpp"'
413 print r'#include "d3d10size.hpp"'
414 print r'#include "d3d10state.hpp"'
415 print r'#include "d3d11imports.hpp"'
416 print r'#include "d3d11size.hpp"'
417 print r'#include "d3dstate.hpp"'
418 print
419 print '''static d3dretrace::D3DDumper<IDXGISwapChain> dxgiDumper;'''
420 print '''static d3dretrace::D3DDumper<ID3D10Device> d3d10Dumper;'''
421 print '''static d3dretrace::D3DDumper<ID3D11DeviceContext> d3d11Dumper;'''
422 print
José Fonseca6f810332012-11-11 10:05:09 +0000423
424 api = API()
José Fonseca50bee952015-02-07 22:32:19 +0000425 api.addModule(dxgi)
426 api.addModule(d3d10)
427 api.addModule(d3d10_1)
428 api.addModule(d3d11)
José Fonsecafc58d052014-06-13 12:47:19 +0100429
José Fonseca6f810332012-11-11 10:05:09 +0000430 retracer = D3DRetracer()
431 retracer.retraceApi(api)
432
433
434if __name__ == '__main__':
435 main()