~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~ [ freetext search ] ~ [ file search ] ~

Wine Cross Reference
wine/dlls/dxgi/dxgi_main.c

Version: ~ [ wine-1.5.30 ] ~ [ wine-1.5.29 ] ~ [ wine-1.5.28 ] ~ [ wine-1.5.27 ] ~ [ wine-1.5.26 ] ~ [ wine-1.5.25 ] ~ [ wine-1.5.24 ] ~ [ wine-1.5.23 ] ~ [ wine-1.5.22 ] ~ [ wine-1.5.21 ] ~ [ wine-1.5.20 ] ~ [ wine-1.5.19 ] ~ [ wine-1.5.18 ] ~ [ wine-1.5.17 ] ~ [ wine-1.5.16 ] ~ [ wine-1.5.15 ] ~ [ wine-1.5.14 ] ~ [ wine-1.5.13 ] ~ [ wine-1.5.12 ] ~ [ wine-1.5.11 ] ~ [ wine-1.5.10 ] ~ [ wine-1.5.9 ] ~ [ wine-1.5.8 ] ~ [ wine-1.5.7 ] ~ [ wine-1.4.1 ] ~ [ wine-1.5.6 ] ~ [ wine-1.5.5 ] ~ [ wine-1.5.4 ] ~ [ wine-1.5.3 ] ~ [ wine-1.5.2 ] ~ [ wine-1.5.1 ] ~ [ wine-1.5.0 ] ~ [ wine-1.4 ] ~ [ wine-1.4-rc6 ] ~ [ wine-1.4-rc5 ] ~ [ wine-1.4-rc4 ] ~ [ wine-1.4-rc3 ] ~ [ wine-1.4-rc2 ] ~ [ wine-1.4-rc1 ] ~ [ wine-1.3.37 ] ~ [ wine-1.3.36 ] ~ [ wine-1.3.35 ] ~ [ wine-1.3.34 ] ~ [ wine-1.3.33 ] ~ [ wine-1.3.32 ] ~ [ wine-1.3.31 ] ~ [ wine-1.3.30 ] ~ [ wine-1.3.29 ] ~ [ wine-1.3.28 ] ~ [ wine-1.3.27 ] ~ [ wine-1.3.26 ] ~ [ wine-1.3.25 ] ~ [ wine-1.3.24 ] ~ [ wine-1.3.23 ] ~ [ wine-1.3.22 ] ~ [ wine-1.3.21 ] ~ [ wine-1.3.20 ] ~ [ wine-1.3.19 ] ~ [ wine-1.3.18 ] ~ [ wine-1.2.3 ] ~ [ wine-1.3.17 ] ~ [ wine-1.3.16 ] ~ [ wine-1.3.15 ] ~ [ wine-1.3.14 ] ~ [ wine-1.3.13 ] ~ [ wine-1.3.12 ] ~ [ wine-1.3.11 ] ~ [ wine-1.3.10 ] ~ [ wine-1.3.9 ] ~ [ wine-1.2.2 ] ~ [ wine-1.3.8 ] ~ [ wine-1.3.7 ] ~ [ wine-1.3.6 ] ~ [ wine-1.3.5 ] ~ [ wine-1.2.1 ] ~ [ wine-1.3.4 ] ~ [ wine-1.3.3 ] ~ [ wine-1.3.2 ] ~ [ wine-1.3.1 ] ~ [ wine-1.3.0 ] ~ [ wine-1.2 ] ~ [ wine-1.2-rc7 ] ~ [ wine-1.2-rc6 ] ~ [ wine-1.2-rc5 ] ~ [ wine-1.2-rc4 ] ~ [ wine-1.2-rc3 ] ~ [ wine-1.2-rc2 ] ~ [ wine-1.2-rc1 ] ~ [ wine-1.1.44 ] ~ [ wine-1.1.43 ] ~ [ wine-1.1.42 ] ~ [ wine-1.1.41 ] ~ [ wine-1.1.40 ] ~ [ wine-1.1.39 ] ~ [ wine-1.1.38 ] ~ [ wine-1.1.37 ] ~ [ wine-1.1.36 ] ~ [ wine-1.1.35 ] ~ [ wine-1.1.34 ] ~ [ wine-1.1.33 ] ~ [ wine-1.1.32 ] ~ [ wine-1.1.31 ] ~ [ wine-1.1.30 ] ~ [ wine-1.1.29 ] ~ [ wine-1.1.28 ] ~ [ wine-1.1.27 ] ~ [ wine-1.1.26 ] ~ [ wine-1.1.25 ] ~ [ wine-1.1.24 ] ~ [ wine-1.1.23 ] ~ [ wine-1.1.22 ] ~ [ wine-1.1.21 ] ~ [ wine-1.1.20 ] ~ [ wine-1.1.19 ] ~ [ wine-1.1.18 ] ~ [ wine-1.1.17 ] ~ [ wine-1.1.16 ] ~ [ wine-1.1.15 ] ~ [ wine-1.1.14 ] ~ [ wine-1.1.13 ] ~ [ wine-1.1.12 ] ~ [ wine-1.1.11 ] ~ [ wine-1.1.10 ] ~ [ wine-1.1.9 ] ~ [ wine-1.1.8 ] ~ [ wine-1.1.7 ] ~ [ wine-1.0.1 ] ~ [ wine-1.1.6 ] ~ [ wine-1.1.5 ] ~ [ wine-1.1.4 ] ~ [ wine-1.1.3 ] ~ [ wine-1.1.2 ] ~ [ wine-1.1.1 ] ~ [ wine-1.1.0 ] ~ [ wine-1.0 ] ~

  1 /*
  2  * Copyright 2008 Henri Verbeet for CodeWeavers
  3  *
  4  * This library is free software; you can redistribute it and/or
  5  * modify it under the terms of the GNU Lesser General Public
  6  * License as published by the Free Software Foundation; either
  7  * version 2.1 of the License, or (at your option) any later version.
  8  *
  9  * This library is distributed in the hope that it will be useful,
 10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 12  * Lesser General Public License for more details.
 13  *
 14  * You should have received a copy of the GNU Lesser General Public
 15  * License along with this library; if not, write to the Free Software
 16  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
 17  *
 18  */
 19 
 20 #include "config.h"
 21 #include "wine/port.h"
 22 
 23 #define DXGI_INIT_GUID
 24 #include "dxgi_private.h"
 25 
 26 WINE_DEFAULT_DEBUG_CHANNEL(dxgi);
 27 
 28 static CRITICAL_SECTION_DEBUG dxgi_cs_debug =
 29 {
 30     0, 0, &dxgi_cs,
 31     {&dxgi_cs_debug.ProcessLocksList,
 32     &dxgi_cs_debug.ProcessLocksList},
 33     0, 0, {(DWORD_PTR)(__FILE__ ": dxgi_cs")}
 34 };
 35 CRITICAL_SECTION dxgi_cs = {&dxgi_cs_debug, -1, 0, 0, 0, 0};
 36 
 37 struct dxgi_main
 38 {
 39     HMODULE d3d10core;
 40     struct dxgi_device_layer *device_layers;
 41     UINT layer_count;
 42     LONG refcount;
 43 };
 44 static struct dxgi_main dxgi_main;
 45 
 46 static void dxgi_main_cleanup(void)
 47 {
 48     EnterCriticalSection(&dxgi_cs);
 49 
 50     HeapFree(GetProcessHeap(), 0, dxgi_main.device_layers);
 51     dxgi_main.device_layers = NULL;
 52     dxgi_main.layer_count = 0;
 53 
 54     FreeLibrary(dxgi_main.d3d10core);
 55     dxgi_main.d3d10core = NULL;
 56 
 57     LeaveCriticalSection(&dxgi_cs);
 58 }
 59 
 60 BOOL WINAPI DllMain(HINSTANCE hInstDLL, DWORD fdwReason, LPVOID lpv)
 61 {
 62     TRACE("fdwReason %u\n", fdwReason);
 63 
 64     switch(fdwReason)
 65     {
 66         case DLL_PROCESS_ATTACH:
 67             DisableThreadLibraryCalls(hInstDLL);
 68             ++dxgi_main.refcount;
 69             break;
 70 
 71         case DLL_PROCESS_DETACH:
 72             if (!--dxgi_main.refcount) dxgi_main_cleanup();
 73             break;
 74     }
 75 
 76     return TRUE;
 77 }
 78 
 79 HRESULT WINAPI CreateDXGIFactory(REFIID riid, void **factory)
 80 {
 81     struct dxgi_factory *object;
 82     HRESULT hr;
 83     UINT i;
 84 
 85     TRACE("riid %s, factory %p\n", debugstr_guid(riid), factory);
 86 
 87     object = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(*object));
 88     if (!object)
 89     {
 90         ERR("Failed to allocate DXGI factory object memory\n");
 91         *factory = NULL;
 92         return E_OUTOFMEMORY;
 93     }
 94 
 95     object->vtbl = &dxgi_factory_vtbl;
 96     object->refcount = 1;
 97 
 98     EnterCriticalSection(&dxgi_cs);
 99     object->wined3d = WineDirect3DCreate(10, (IUnknown *)object);
100     if(!object->wined3d)
101     {
102         hr = DXGI_ERROR_UNSUPPORTED;
103         LeaveCriticalSection(&dxgi_cs);
104         goto fail;
105     }
106 
107     object->adapter_count = IWineD3D_GetAdapterCount(object->wined3d);
108     LeaveCriticalSection(&dxgi_cs);
109     object->adapters = HeapAlloc(GetProcessHeap(), 0, object->adapter_count * sizeof(*object->adapters));
110     if (!object->adapters)
111     {
112         ERR("Failed to allocate DXGI adapter array memory\n");
113         hr = E_OUTOFMEMORY;
114         goto fail;
115     }
116 
117     for (i = 0; i < object->adapter_count; ++i)
118     {
119         struct dxgi_adapter *adapter = HeapAlloc(GetProcessHeap(), 0, sizeof(*adapter));
120         if (!adapter)
121         {
122             UINT j;
123             ERR("Failed to allocate DXGI adapter memory\n");
124             for (j = 0; j < i; ++j)
125             {
126                 HeapFree(GetProcessHeap(), 0, object->adapters[j]);
127             }
128             hr = E_OUTOFMEMORY;
129             goto fail;
130         }
131 
132         adapter->vtbl = &dxgi_adapter_vtbl;
133         adapter->refcount = 1;
134         adapter->ordinal = i;
135         adapter->parent = (IDXGIFactory *)object;
136         object->adapters[i] = (IDXGIAdapter *)adapter;
137     }
138 
139     TRACE("Created IDXGIFactory %p\n", object);
140 
141     hr = IDXGIFactory_QueryInterface((IDXGIFactory *)object, riid, factory);
142     IDXGIFactory_Release((IDXGIFactory *)object);
143 
144     return hr;
145 
146 fail:
147     HeapFree(GetProcessHeap(), 0, object->adapters);
148     if (object->wined3d)
149     {
150         EnterCriticalSection(&dxgi_cs);
151         IWineD3D_Release(object->wined3d);
152         LeaveCriticalSection(&dxgi_cs);
153     }
154     HeapFree(GetProcessHeap(), 0, object);
155     *factory = NULL;
156     return hr;
157 
158 }
159 
160 static BOOL get_layer(enum dxgi_device_layer_id id, struct dxgi_device_layer *layer)
161 {
162     UINT i;
163 
164     EnterCriticalSection(&dxgi_cs);
165 
166     for (i = 0; i < dxgi_main.layer_count; ++i)
167     {
168         if (dxgi_main.device_layers[i].id == id)
169         {
170             *layer = dxgi_main.device_layers[i];
171             LeaveCriticalSection(&dxgi_cs);
172             return TRUE;
173         }
174     }
175 
176     LeaveCriticalSection(&dxgi_cs);
177     return FALSE;
178 }
179 
180 static HRESULT register_d3d10core_layers(HMODULE d3d10core)
181 {
182     EnterCriticalSection(&dxgi_cs);
183 
184     if (!dxgi_main.d3d10core)
185     {
186         HRESULT hr;
187         HRESULT (WINAPI *d3d10core_register_layers)(void);
188         HMODULE mod;
189         BOOL ret;
190 
191         ret = GetModuleHandleExA(GET_MODULE_HANDLE_EX_FLAG_FROM_ADDRESS, (LPCSTR)d3d10core, &mod);
192         if (!ret)
193         {
194             LeaveCriticalSection(&dxgi_cs);
195             return E_FAIL;
196         }
197 
198         d3d10core_register_layers = (HRESULT (WINAPI *)(void))GetProcAddress(mod, "D3D10CoreRegisterLayers");
199         hr = d3d10core_register_layers();
200         if (FAILED(hr))
201         {
202             ERR("Failed to register d3d10core layers, returning %#x\n", hr);
203             LeaveCriticalSection(&dxgi_cs);
204             return hr;
205         }
206 
207         dxgi_main.d3d10core = mod;
208     }
209 
210     LeaveCriticalSection(&dxgi_cs);
211 
212     return S_OK;
213 }
214 
215 HRESULT WINAPI DXGID3D10CreateDevice(HMODULE d3d10core, IDXGIFactory *factory, IDXGIAdapter *adapter,
216         UINT flags, DWORD unknown0, void **device)
217 {
218     IWineD3DDeviceParent *wined3d_device_parent;
219     struct layer_get_size_args get_size_args;
220     struct dxgi_device *dxgi_device;
221     struct dxgi_device_layer d3d10_layer;
222     IWineDXGIAdapter *wine_adapter;
223     UINT adapter_ordinal;
224     IWineD3D *wined3d;
225     void *layer_base;
226     UINT device_size;
227     DWORD count;
228     HRESULT hr;
229 
230     TRACE("d3d10core %p, factory %p, adapter %p, flags %#x, unknown0 %#x, device %p\n",
231             d3d10core, factory, adapter, flags, unknown0, device);
232 
233     hr = register_d3d10core_layers(d3d10core);
234     if (FAILED(hr))
235     {
236         ERR("Failed to register d3d10core layers, returning %#x\n", hr);
237         return hr;
238     }
239 
240     if (!get_layer(DXGI_DEVICE_LAYER_D3D10_DEVICE, &d3d10_layer))
241     {
242         ERR("Failed to get D3D10 device layer\n");
243         return E_FAIL;
244     }
245 
246     count = 0;
247     hr = d3d10_layer.init(d3d10_layer.id, &count, NULL);
248     if (FAILED(hr))
249     {
250         WARN("Failed to initialize D3D10 device layer\n");
251         return E_FAIL;
252     }
253 
254     get_size_args.unknown0 = 0;
255     get_size_args.unknown1 = 0;
256     get_size_args.unknown2 = NULL;
257     get_size_args.unknown3 = NULL;
258     get_size_args.adapter = adapter;
259     get_size_args.interface_major = 10;
260     get_size_args.interface_minor = 1;
261     get_size_args.version_build = 4;
262     get_size_args.version_revision = 6000;
263 
264     device_size = d3d10_layer.get_size(d3d10_layer.id, &get_size_args, 0);
265     device_size += sizeof(*dxgi_device);
266 
267     dxgi_device = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, device_size);
268     if (!dxgi_device)
269     {
270         ERR("Failed to allocate device memory\n");
271         return E_OUTOFMEMORY;
272     }
273 
274     dxgi_device->vtbl = &dxgi_device_vtbl;
275     dxgi_device->refcount = 1;
276 
277     layer_base = dxgi_device + 1;
278 
279     hr = d3d10_layer.create(d3d10_layer.id, &layer_base, 0,
280             dxgi_device, &IID_IUnknown, (void **)&dxgi_device->child_layer);
281     if (FAILED(hr))
282     {
283         WARN("Failed to create device, returning %#x\n", hr);
284         goto fail;
285     }
286 
287     hr = IDXGIFactory_QueryInterface(factory, &IID_IWineDXGIFactory, (void **)&dxgi_device->factory);
288     if (FAILED(hr))
289     {
290         WARN("This is not the factory we're looking for, returning %#x\n", hr);
291         goto fail;
292     }
293     wined3d = IWineDXGIFactory_get_wined3d(dxgi_device->factory);
294 
295     hr = IDXGIAdapter_QueryInterface(adapter, &IID_IWineDXGIAdapter, (void **)&wine_adapter);
296     if (FAILED(hr))
297     {
298         WARN("This is not the adapter we're looking for, returning %#x\n", hr);
299         EnterCriticalSection(&dxgi_cs);
300         IWineD3D_Release(wined3d);
301         LeaveCriticalSection(&dxgi_cs);
302         goto fail;
303     }
304     adapter_ordinal = IWineDXGIAdapter_get_ordinal(wine_adapter);
305     IWineDXGIAdapter_Release(wine_adapter);
306 
307     hr = IUnknown_QueryInterface((IUnknown *)dxgi_device, &IID_IWineD3DDeviceParent, (void **)&wined3d_device_parent);
308     if (FAILED(hr))
309     {
310         ERR("DXGI device should implement IWineD3DDeviceParent\n");
311         goto fail;
312     }
313 
314     FIXME("Ignoring adapter type\n");
315     EnterCriticalSection(&dxgi_cs);
316     hr = IWineD3D_CreateDevice(wined3d, adapter_ordinal, WINED3DDEVTYPE_HAL, NULL, 0,
317             (IUnknown *)dxgi_device, wined3d_device_parent, &dxgi_device->wined3d_device);
318     IWineD3DDeviceParent_Release(wined3d_device_parent);
319     IWineD3D_Release(wined3d);
320     LeaveCriticalSection(&dxgi_cs);
321     if (FAILED(hr))
322     {
323         WARN("Failed to create a WineD3D device, returning %#x\n", hr);
324         goto fail;
325     }
326 
327     *device = dxgi_device;
328 
329     return hr;
330 
331 fail:
332     if (dxgi_device->wined3d_device)
333     {
334         EnterCriticalSection(&dxgi_cs);
335         IWineD3DDevice_Release(dxgi_device->wined3d_device);
336         LeaveCriticalSection(&dxgi_cs);
337     }
338     if (dxgi_device->factory) IWineDXGIFactory_Release(dxgi_device->factory);
339     if (dxgi_device->child_layer) IUnknown_Release(dxgi_device->child_layer);
340     HeapFree(GetProcessHeap(), 0, dxgi_device);
341     *device = NULL;
342     return hr;
343 }
344 
345 HRESULT WINAPI DXGID3D10RegisterLayers(const struct dxgi_device_layer *layers, UINT layer_count)
346 {
347     UINT i;
348     struct dxgi_device_layer *new_layers;
349 
350     TRACE("layers %p, layer_count %u\n", layers, layer_count);
351 
352     EnterCriticalSection(&dxgi_cs);
353 
354     if (!dxgi_main.layer_count)
355         new_layers = HeapAlloc(GetProcessHeap(), 0, layer_count * sizeof(*new_layers));
356     else
357         new_layers = HeapReAlloc(GetProcessHeap(), 0, dxgi_main.device_layers,
358                 (dxgi_main.layer_count + layer_count) * sizeof(*new_layers));
359 
360     if (!new_layers)
361     {
362         LeaveCriticalSection(&dxgi_cs);
363         ERR("Failed to allocate layer memory\n");
364         return E_OUTOFMEMORY;
365     }
366 
367     for (i = 0; i < layer_count; ++i)
368     {
369         const struct dxgi_device_layer *layer = &layers[i];
370 
371         TRACE("layer %d: id %#x, init %p, get_size %p, create %p\n",
372                 i, layer->id, layer->init, layer->get_size, layer->create);
373 
374         new_layers[dxgi_main.layer_count + i] = *layer;
375     }
376 
377     dxgi_main.device_layers = new_layers;
378     dxgi_main.layer_count += layer_count;
379 
380     LeaveCriticalSection(&dxgi_cs);
381 
382     return S_OK;
383 }
384 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~ [ freetext search ] ~ [ file search ] ~

This page was automatically generated by the LXR engine.
Visit the LXR main site for more information.