José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 1 | ########################################################################## |
| 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é Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 30 | import sys |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 31 | from dllretrace import DllRetracer as Retracer |
José Fonseca | 75cbb8c | 2013-02-12 16:19:23 +0000 | [diff] [blame] | 32 | import specs.dxgi |
José Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 33 | from specs.stdapi import API |
| 34 | from specs.dxgi import dxgi |
| 35 | from specs.d3d10 import d3d10 |
| 36 | from specs.d3d10_1 import d3d10_1 |
| 37 | from specs.d3d11 import d3d11 |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 38 | |
| 39 | |
| 40 | class D3DRetracer(Retracer): |
| 41 | |
José Fonseca | e381485 | 2012-11-11 09:45:06 +0000 | [diff] [blame] | 42 | def retraceApi(self, api): |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 43 | print '// Swizzling mapping for lock addresses' |
| 44 | print 'static std::map<void *, void *> _maps;' |
| 45 | print |
José Fonseca | 73341c2 | 2012-11-24 13:04:42 +0000 | [diff] [blame] | 46 | self.table_name = 'd3dretrace::dxgi_callbacks' |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 47 | |
José Fonseca | e381485 | 2012-11-11 09:45:06 +0000 | [diff] [blame] | 48 | Retracer.retraceApi(self, api) |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 49 | |
José Fonseca | 4f49d21 | 2012-11-14 14:02:35 +0000 | [diff] [blame] | 50 | createDeviceFunctionNames = [ |
| 51 | "D3D10CreateDevice", |
| 52 | "D3D10CreateDeviceAndSwapChain", |
| 53 | "D3D10CreateDevice1", |
| 54 | "D3D10CreateDeviceAndSwapChain1", |
| 55 | "D3D11CreateDevice", |
| 56 | "D3D11CreateDeviceAndSwapChain", |
| 57 | ] |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 58 | |
José Fonseca | 4f49d21 | 2012-11-14 14:02:35 +0000 | [diff] [blame] | 59 | def invokeFunction(self, function): |
| 60 | if function.name in self.createDeviceFunctionNames: |
| 61 | # create windows as neccessary |
| 62 | if 'pSwapChainDesc' in function.argNames(): |
José Fonseca | 7d042e0 | 2012-11-23 17:01:04 +0000 | [diff] [blame] | 63 | print r' createWindow(pSwapChainDesc);' |
José Fonseca | 4f49d21 | 2012-11-14 14:02:35 +0000 | [diff] [blame] | 64 | |
José Fonseca | 4f49d21 | 2012-11-14 14:02:35 +0000 | [diff] [blame] | 65 | # 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é Fonseca | ea79919 | 2012-11-13 21:37:24 +0000 | [diff] [blame] | 70 | |
José Fonseca | 42b89fc | 2012-11-27 12:19:45 +0000 | [diff] [blame] | 71 | if function.name.startswith('D3D10CreateDevice'): |
José Fonseca | 7bcc96c | 2012-12-05 19:28:22 +0000 | [diff] [blame] | 72 | # 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é Fonseca | 42b89fc | 2012-11-27 12:19:45 +0000 | [diff] [blame] | 81 | self.forceDriver('D3D10_DRIVER_TYPE') |
José Fonseca | 7bcc96c | 2012-12-05 19:28:22 +0000 | [diff] [blame] | 82 | |
José Fonseca | 42b89fc | 2012-11-27 12:19:45 +0000 | [diff] [blame] | 83 | if function.name.startswith('D3D11CreateDevice'): |
José Fonseca | 7bcc96c | 2012-12-05 19:28:22 +0000 | [diff] [blame] | 84 | # Toggle debugging |
| 85 | print r' Flags &= ~D3D11_CREATE_DEVICE_DEBUG;' |
| 86 | print r' if (retrace::debug) {' |
José Fonseca | 89b697f | 2014-06-17 20:26:38 +0100 | [diff] [blame] | 87 | print r' const char *szD3d11SdkLayers = IsWindows8OrGreater() ? "d3d11_1sdklayers" : "d3d11sdklayers";' |
José Fonseca | 472fa28 | 2013-04-23 18:00:40 +0100 | [diff] [blame] | 88 | print r' if (LoadLibraryA(szD3d11SdkLayers)) {' |
José Fonseca | 7bcc96c | 2012-12-05 19:28:22 +0000 | [diff] [blame] | 89 | print r' Flags |= D3D11_CREATE_DEVICE_DEBUG;' |
| 90 | print r' }' |
| 91 | print r' }' |
| 92 | |
| 93 | # Force driver |
José Fonseca | 42b89fc | 2012-11-27 12:19:45 +0000 | [diff] [blame] | 94 | self.forceDriver('D3D_DRIVER_TYPE') |
| 95 | |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 96 | Retracer.invokeFunction(self, function) |
| 97 | |
José Fonseca | 25e08d0 | 2013-06-28 08:43:50 +0100 | [diff] [blame] | 98 | # 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é Fonseca | 472fa28 | 2013-04-23 18:00:40 +0100 | [diff] [blame] | 101 | 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é Fonseca | 25e08d0 | 2013-06-28 08:43:50 +0100 | [diff] [blame] | 107 | print r' Flags &= ~D3D10_CREATE_DEVICE_DEBUG;' |
| 108 | Retracer.invokeFunction(self, function) |
José Fonseca | 472fa28 | 2013-04-23 18:00:40 +0100 | [diff] [blame] | 109 | print r' }' |
José Fonseca | 25e08d0 | 2013-06-28 08:43:50 +0100 | [diff] [blame] | 110 | elif function.name.startswith('D3D11CreateDevice'): |
José Fonseca | 472fa28 | 2013-04-23 18:00:40 +0100 | [diff] [blame] | 111 | 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é Fonseca | 25e08d0 | 2013-06-28 08:43:50 +0100 | [diff] [blame] | 113 | print r' Flags &= ~D3D11_CREATE_DEVICE_DEBUG;' |
| 114 | Retracer.invokeFunction(self, function) |
José Fonseca | 472fa28 | 2013-04-23 18:00:40 +0100 | [diff] [blame] | 115 | print r' }' |
José Fonseca | 25e08d0 | 2013-06-28 08:43:50 +0100 | [diff] [blame] | 116 | else: |
| 117 | assert False |
José Fonseca | 472fa28 | 2013-04-23 18:00:40 +0100 | [diff] [blame] | 118 | |
José Fonseca | 25e08d0 | 2013-06-28 08:43:50 +0100 | [diff] [blame] | 119 | print r' if (FAILED(_result)) {' |
| 120 | print r' exit(1);' |
| 121 | print r' }' |
| 122 | |
José Fonseca | 472fa28 | 2013-04-23 18:00:40 +0100 | [diff] [blame] | 123 | print r' }' |
| 124 | |
José Fonseca | 42b89fc | 2012-11-27 12:19:45 +0000 | [diff] [blame] | 125 | def forceDriver(self, enum): |
José Fonseca | 82ea89d | 2012-12-05 19:34:26 +0000 | [diff] [blame] | 126 | # 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é Fonseca | 42b89fc | 2012-11-27 12:19:45 +0000 | [diff] [blame] | 149 | print r' if (!Software) {' |
José Fonseca | 82ea89d | 2012-12-05 19:34:26 +0000 | [diff] [blame] | 150 | print r' retrace::warning(call) << "failed to load " << retrace::driverModule << "\n";' |
José Fonseca | 42b89fc | 2012-11-27 12:19:45 +0000 | [diff] [blame] | 151 | print r' }' |
José Fonseca | 82ea89d | 2012-12-05 19:34:26 +0000 | [diff] [blame] | 152 | 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é Fonseca | 42b89fc | 2012-11-27 12:19:45 +0000 | [diff] [blame] | 164 | print r' }' |
José Fonseca | 82ea89d | 2012-12-05 19:34:26 +0000 | [diff] [blame] | 165 | print r' } else {' |
| 166 | print r' Software = NULL;' |
José Fonseca | 42b89fc | 2012-11-27 12:19:45 +0000 | [diff] [blame] | 167 | print r' }' |
| 168 | |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 169 | def invokeInterfaceMethod(self, interface, method): |
| 170 | # keep track of the last used device for state dumping |
José Fonseca | 944088e | 2012-11-20 14:47:03 +0000 | [diff] [blame] | 171 | if interface.name in ('ID3D10Device', 'ID3D10Device1'): |
| 172 | if method.name == 'Release': |
José Fonseca | db62f0f | 2013-06-27 16:15:01 +0100 | [diff] [blame] | 173 | print r' if (call.ret->toUInt() == 0) {' |
| 174 | print r' d3d10Dumper.unbindDevice(_this);' |
| 175 | print r' }' |
José Fonseca | 944088e | 2012-11-20 14:47:03 +0000 | [diff] [blame] | 176 | else: |
| 177 | print r' d3d10Dumper.bindDevice(_this);' |
Jeff Muizelaar | 53b0195 | 2013-03-12 16:31:17 -0400 | [diff] [blame] | 178 | if interface.name in ('ID3D11DeviceContext', 'ID3D11DeviceContext1'): |
José Fonseca | 5773beb | 2012-11-14 11:46:58 +0000 | [diff] [blame] | 179 | if method.name == 'Release': |
José Fonseca | db62f0f | 2013-06-27 16:15:01 +0100 | [diff] [blame] | 180 | print r' if (call.ret->toUInt() == 0) {' |
| 181 | print r' d3d11Dumper.unbindDevice(_this);' |
| 182 | print r' }' |
José Fonseca | 5773beb | 2012-11-14 11:46:58 +0000 | [diff] [blame] | 183 | else: |
José Fonseca | 0dc448e | 2013-06-13 15:51:48 +0100 | [diff] [blame] | 184 | print r' if (_this->GetType() == D3D11_DEVICE_CONTEXT_IMMEDIATE) {' |
| 185 | print r' d3d11Dumper.bindDevice(_this);' |
| 186 | print r' }' |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 187 | |
José Fonseca | d59843c | 2014-08-22 16:59:25 +0100 | [diff] [blame^] | 188 | if method.name == 'QueryInterface': |
José Fonseca | 75cbb8c | 2013-02-12 16:19:23 +0000 | [diff] [blame] | 189 | print r' if (riid == IID_IDXGIFactoryDWM) {' |
José Fonseca | d59843c | 2014-08-22 16:59:25 +0100 | [diff] [blame^] | 190 | 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é Fonseca | 75cbb8c | 2013-02-12 16:19:23 +0000 | [diff] [blame] | 195 | print r' } else {' |
| 196 | Retracer.invokeInterfaceMethod(self, interface, method) |
| 197 | print r' }' |
| 198 | return |
| 199 | |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 200 | # create windows as neccessary |
| 201 | if method.name == 'CreateSwapChain': |
José Fonseca | 7d042e0 | 2012-11-23 17:01:04 +0000 | [diff] [blame] | 202 | print r' createWindow(pDesc);' |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 203 | |
| 204 | # notify frame has been completed |
| 205 | if method.name == 'Present': |
José Fonseca | 29d4bda | 2014-02-28 17:50:24 +0000 | [diff] [blame] | 206 | if interface.name == 'IDXGISwapChainDWM': |
| 207 | print r' dxgiDumper.bindDevice(reinterpret_cast<d3dretrace::CDXGISwapChainDWM *>(_this)->m_pSwapChain);' |
| 208 | else: |
| 209 | print r' dxgiDumper.bindDevice(_this);' |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 210 | print r' retrace::frameComplete(call);' |
| 211 | |
| 212 | if 'pSharedResource' in method.argNames(): |
| 213 | print r' if (pSharedResource) {' |
| 214 | print r' retrace::warning(call) << "shared surfaces unsupported\n";' |
| 215 | print r' pSharedResource = NULL;' |
| 216 | print r' }' |
| 217 | |
José Fonseca | 82ea89d | 2012-12-05 19:34:26 +0000 | [diff] [blame] | 218 | # Force driver |
José Fonseca | ad6f60f | 2013-09-16 14:58:34 +0100 | [diff] [blame] | 219 | if interface.name.startswith('IDXGIFactory') and method.name.startswith('EnumAdapters'): |
José Fonseca | 82ea89d | 2012-12-05 19:34:26 +0000 | [diff] [blame] | 220 | print r' const char *szSoftware = NULL;' |
| 221 | print r' switch (retrace::driver) {' |
| 222 | print r' case retrace::DRIVER_REFERENCE:' |
| 223 | print r' case retrace::DRIVER_SOFTWARE:' |
| 224 | print r' szSoftware = "d3d10warp.dll";' |
| 225 | print r' break;' |
| 226 | print r' case retrace::DRIVER_MODULE:' |
| 227 | print r' szSoftware = retrace::driverModule;' |
| 228 | print r' break;' |
| 229 | print r' default:' |
| 230 | print r' break;' |
| 231 | print r' }' |
| 232 | print r' HMODULE hSoftware = NULL;' |
| 233 | print r' if (szSoftware) {' |
| 234 | print r' hSoftware = LoadLibraryA(szSoftware);' |
| 235 | print r' if (!hSoftware) {' |
| 236 | print r' retrace::warning(call) << "failed to load " << szSoftware << "\n";' |
| 237 | print r' }' |
| 238 | print r' }' |
| 239 | print r' if (hSoftware) {' |
José Fonseca | ad6f60f | 2013-09-16 14:58:34 +0100 | [diff] [blame] | 240 | print r' _result = _this->CreateSoftwareAdapter(hSoftware, reinterpret_cast<IDXGIAdapter **>(ppAdapter));' |
José Fonseca | 82ea89d | 2012-12-05 19:34:26 +0000 | [diff] [blame] | 241 | print r' } else {' |
| 242 | Retracer.invokeInterfaceMethod(self, interface, method) |
| 243 | print r' }' |
| 244 | return |
| 245 | |
José Fonseca | 75cbb8c | 2013-02-12 16:19:23 +0000 | [diff] [blame] | 246 | if interface.name.startswith('ID3D10Device') and method.name == 'OpenSharedResource': |
| 247 | print r' retrace::warning(call) << "replacing shared resource with checker pattern\n";' |
| 248 | print r' D3D10_TEXTURE2D_DESC Desc;' |
| 249 | print r' memset(&Desc, 0, sizeof Desc);' |
| 250 | print r' Desc.Width = 8;' |
| 251 | print r' Desc.Height = 8;' |
| 252 | print r' Desc.MipLevels = 1;' |
| 253 | print r' Desc.ArraySize = 1;' |
| 254 | print r' Desc.Format = DXGI_FORMAT_B8G8R8A8_UNORM;' |
| 255 | print r' Desc.SampleDesc.Count = 1;' |
| 256 | print r' Desc.SampleDesc.Quality = 0;' |
| 257 | print r' Desc.Usage = D3D10_USAGE_DEFAULT;' |
| 258 | print r' Desc.BindFlags = D3D10_BIND_SHADER_RESOURCE | D3D10_BIND_RENDER_TARGET;' |
| 259 | print r' Desc.CPUAccessFlags = 0x0;' |
| 260 | print r' Desc.MiscFlags = 0 /* D3D10_RESOURCE_MISC_SHARED */;' |
| 261 | print r''' |
José Fonseca | a15929f | 2014-05-03 21:54:37 +0100 | [diff] [blame] | 262 | static const DWORD Checker[8][8] = { |
| 263 | { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U }, |
| 264 | {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U }, |
| 265 | { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U }, |
| 266 | {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U }, |
| 267 | { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U }, |
| 268 | {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U }, |
| 269 | { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U }, |
| 270 | {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U } |
José Fonseca | 75cbb8c | 2013-02-12 16:19:23 +0000 | [diff] [blame] | 271 | }; |
José Fonseca | a15929f | 2014-05-03 21:54:37 +0100 | [diff] [blame] | 272 | static const D3D10_SUBRESOURCE_DATA InitialData = {Checker, sizeof Checker[0], sizeof Checker}; |
José Fonseca | 75cbb8c | 2013-02-12 16:19:23 +0000 | [diff] [blame] | 273 | ''' |
| 274 | print r' _result = _this->CreateTexture2D(&Desc, &InitialData, (ID3D10Texture2D**)ppResource);' |
| 275 | self.checkResult(method.type) |
José Fonseca | 999284f | 2013-02-19 13:29:26 +0000 | [diff] [blame] | 276 | return |
José Fonseca | 2b66b93 | 2014-07-30 17:31:52 +0100 | [diff] [blame] | 277 | if interface.name.startswith('ID3D11Device') and method.name.startswith('OpenSharedResource'): |
| 278 | print r' retrace::warning(call) << "replacing shared resource with checker pattern\n";' |
| 279 | print |
| 280 | if method.name == 'OpenSharedResourceByName': |
| 281 | print r' (void)lpName;' |
| 282 | print r' (void)dwDesiredAccess;' |
| 283 | print |
| 284 | print r' D3D11_TEXTURE2D_DESC Desc;' |
| 285 | print r' memset(&Desc, 0, sizeof Desc);' |
| 286 | print r' Desc.Width = 8;' |
| 287 | print r' Desc.Height = 8;' |
| 288 | print r' Desc.MipLevels = 1;' |
| 289 | print r' Desc.ArraySize = 1;' |
| 290 | print r' Desc.Format = DXGI_FORMAT_B8G8R8A8_UNORM;' |
| 291 | print r' Desc.SampleDesc.Count = 1;' |
| 292 | print r' Desc.SampleDesc.Quality = 0;' |
| 293 | print r' Desc.Usage = D3D11_USAGE_DEFAULT;' |
| 294 | print r' Desc.BindFlags = D3D11_BIND_SHADER_RESOURCE | D3D11_BIND_RENDER_TARGET;' |
| 295 | print r' Desc.CPUAccessFlags = 0x0;' |
| 296 | print r' Desc.MiscFlags = 0 /* D3D11_RESOURCE_MISC_SHARED */;' |
| 297 | print r''' |
| 298 | static const DWORD Checker[8][8] = { |
| 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 | {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U }, |
| 303 | { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U }, |
| 304 | {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U }, |
| 305 | { 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U }, |
| 306 | {~0U, 0U, ~0U, 0U, ~0U, 0U, ~0U, 0U } |
| 307 | }; |
| 308 | static const D3D11_SUBRESOURCE_DATA InitialData = {Checker, sizeof Checker[0], sizeof Checker}; |
| 309 | ''' |
| 310 | print r' _result = _this->CreateTexture2D(&Desc, &InitialData, (ID3D11Texture2D**)ppResource);' |
| 311 | self.checkResult(method.type) |
| 312 | return |
José Fonseca | 999284f | 2013-02-19 13:29:26 +0000 | [diff] [blame] | 313 | |
| 314 | if method.name == 'Map': |
| 315 | # Reset _DO_NOT_WAIT flags. Otherwise they may fail, and we have no |
| 316 | # way to cope with it (other than retry). |
| 317 | mapFlagsArg = method.getArgByName('MapFlags') |
| 318 | for flag in mapFlagsArg.type.values: |
| 319 | if flag.endswith('_MAP_FLAG_DO_NOT_WAIT'): |
| 320 | print r' MapFlags &= ~%s;' % flag |
| 321 | |
José Fonseca | c9cc24e | 2014-06-13 19:06:51 +0100 | [diff] [blame] | 322 | if method.name == 'UpdateSubresource': |
| 323 | # The D3D10 debug layer is buggy (or at least inconsistent with the |
| 324 | # runtime), as it seems to estimate and enforce the data size based on the |
| 325 | # SrcDepthPitch, even for non 3D textures, but in some traces |
| 326 | # SrcDepthPitch is garbagge for non 3D textures. |
| 327 | # XXX: It also seems to expect padding bytes at the end of the last |
| 328 | # row, but we never record (or allocate) those... |
| 329 | print r' if (retrace::debug && pDstBox && pDstBox->front == 0 && pDstBox->back == 1) {' |
| 330 | print r' SrcDepthPitch = 0;' |
| 331 | print r' }' |
| 332 | |
José Fonseca | 0688d2e | 2014-08-19 20:43:21 +0100 | [diff] [blame] | 333 | if method.name == 'SetGammaControl': |
| 334 | # This method is only supported while in full-screen mode |
| 335 | print r' if (retrace::forceWindowed) {' |
| 336 | print r' return;' |
| 337 | print r' }' |
| 338 | |
José Fonseca | 999284f | 2013-02-19 13:29:26 +0000 | [diff] [blame] | 339 | Retracer.invokeInterfaceMethod(self, interface, method) |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 340 | |
| 341 | # process events after presents |
| 342 | if method.name == 'Present': |
| 343 | print r' d3dretrace::processEvents();' |
| 344 | |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 345 | if method.name == 'Map': |
José Fonseca | 003b8be | 2013-05-29 19:59:40 +0100 | [diff] [blame] | 346 | print ' _MAP_DESC _MapDesc;' |
| 347 | print ' _getMapDesc(_this, %s, _MapDesc);' % ', '.join(method.argNames()) |
| 348 | print ' size_t _MappedSize = _MapDesc.Size;' |
| 349 | print ' if (_MapDesc.Size) {' |
Jeff Muizelaar | 97244f9 | 2013-11-19 15:17:45 -0500 | [diff] [blame] | 350 | if interface.name.startswith('ID3D11DeviceContext'): |
| 351 | print ' _maps[pResource] = _MapDesc.pData;' |
| 352 | else: |
| 353 | print ' _maps[_this] = _MapDesc.pData;' |
José Fonseca | 4f49d21 | 2012-11-14 14:02:35 +0000 | [diff] [blame] | 354 | print ' } else {' |
| 355 | print ' return;' |
| 356 | print ' }' |
José Fonseca | 610942b | 2012-11-08 10:46:03 +0000 | [diff] [blame] | 357 | |
| 358 | if method.name == 'Unmap': |
Jeff Muizelaar | 97244f9 | 2013-11-19 15:17:45 -0500 | [diff] [blame] | 359 | if interface.name.startswith('ID3D11DeviceContext'): |
| 360 | print ' VOID *_pbData = 0;' |
| 361 | print ' _pbData = _maps[pResource];' |
| 362 | print ' if (_pbData) {' |
| 363 | print ' retrace::delRegionByPointer(_pbData);' |
| 364 | print ' _maps[pResource] = 0;' |
| 365 | print ' }' |
| 366 | else: |
| 367 | print ' VOID *_pbData = 0;' |
| 368 | print ' _pbData = _maps[_this];' |
| 369 | print ' if (_pbData) {' |
| 370 | print ' retrace::delRegionByPointer(_pbData);' |
| 371 | print ' _maps[_this] = 0;' |
| 372 | print ' }' |
José Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 373 | |
José Fonseca | 1d4fd14 | 2012-11-28 15:06:22 +0000 | [diff] [blame] | 374 | # Attach shader byte code for lookup |
| 375 | if 'pShaderBytecode' in method.argNames(): |
| 376 | ppShader = method.args[-1] |
| 377 | assert ppShader.output |
| 378 | print r' if (retrace::dumpingState && SUCCEEDED(_result)) {' |
| 379 | print r' (*%s)->SetPrivateData(d3dstate::GUID_D3DSTATE, BytecodeLength, pShaderBytecode);' % ppShader.name |
| 380 | print r' }' |
| 381 | |
José Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 382 | |
| 383 | def main(): |
José Fonseca | 75cbb8c | 2013-02-12 16:19:23 +0000 | [diff] [blame] | 384 | print r'#define INITGUID' |
| 385 | print |
José Fonseca | 73341c2 | 2012-11-24 13:04:42 +0000 | [diff] [blame] | 386 | print r'#include <string.h>' |
José Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 387 | print |
| 388 | print r'#include <iostream>' |
| 389 | print |
| 390 | print r'#include "d3dretrace.hpp"' |
José Fonseca | 89b697f | 2014-06-17 20:26:38 +0100 | [diff] [blame] | 391 | print r'#include "os_version.hpp"' |
José Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 392 | print |
| 393 | |
| 394 | moduleNames = sys.argv[1:] |
| 395 | |
| 396 | api = API() |
José Fonseca | 944088e | 2012-11-20 14:47:03 +0000 | [diff] [blame] | 397 | |
José Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 398 | if moduleNames: |
José Fonseca | 75cbb8c | 2013-02-12 16:19:23 +0000 | [diff] [blame] | 399 | print r'#include "d3dretrace_dxgi.hpp"' |
José Fonseca | fc58d05 | 2014-06-13 12:47:19 +0100 | [diff] [blame] | 400 | print r'#include "d3d10imports.hpp"' |
José Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 401 | print r'#include "d3d10size.hpp"' |
José Fonseca | 29d4bda | 2014-02-28 17:50:24 +0000 | [diff] [blame] | 402 | print r'#include "d3d10state.hpp"' |
José Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 403 | print r'#include "d3d11imports.hpp"' |
José Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 404 | print r'#include "d3d11size.hpp"' |
José Fonseca | 5773beb | 2012-11-14 11:46:58 +0000 | [diff] [blame] | 405 | print r'#include "d3dstate.hpp"' |
José Fonseca | 5773beb | 2012-11-14 11:46:58 +0000 | [diff] [blame] | 406 | print |
José Fonseca | fc58d05 | 2014-06-13 12:47:19 +0100 | [diff] [blame] | 407 | print '''static d3dretrace::D3DDumper<IDXGISwapChain> dxgiDumper;''' |
| 408 | print '''static d3dretrace::D3DDumper<ID3D10Device> d3d10Dumper;''' |
José Fonseca | 5773beb | 2012-11-14 11:46:58 +0000 | [diff] [blame] | 409 | print '''static d3dretrace::D3DDumper<ID3D11DeviceContext> d3d11Dumper;''' |
| 410 | print |
José Fonseca | 18178e0 | 2014-06-17 23:07:49 +0100 | [diff] [blame] | 411 | print r''' |
| 412 | static void |
| 413 | createWindow(DXGI_SWAP_CHAIN_DESC *pSwapChainDesc) { |
| 414 | UINT Width = pSwapChainDesc->BufferDesc.Width; |
| 415 | UINT Height = pSwapChainDesc->BufferDesc.Height; |
| 416 | if (!Width) Width = 1024; |
| 417 | if (!Height) Height = 768; |
José Fonseca | 0688d2e | 2014-08-19 20:43:21 +0100 | [diff] [blame] | 418 | if (retrace::forceWindowed) { |
| 419 | pSwapChainDesc->Windowed = TRUE; |
| 420 | } |
José Fonseca | 18178e0 | 2014-06-17 23:07:49 +0100 | [diff] [blame] | 421 | pSwapChainDesc->OutputWindow = d3dretrace::createWindow(Width, Height); |
| 422 | } |
| 423 | ''' |
José Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 424 | |
José Fonseca | fc58d05 | 2014-06-13 12:47:19 +0100 | [diff] [blame] | 425 | api.addModule(dxgi) |
| 426 | api.addModule(d3d10) |
| 427 | api.addModule(d3d10_1) |
| 428 | api.addModule(d3d11) |
| 429 | |
José Fonseca | 6f81033 | 2012-11-11 10:05:09 +0000 | [diff] [blame] | 430 | retracer = D3DRetracer() |
| 431 | retracer.retraceApi(api) |
| 432 | |
| 433 | |
| 434 | if __name__ == '__main__': |
| 435 | main() |