Fixes for missing prototypes warnings.
[wine] / dlls / d3d8 / directx.c
1 /*
2  * IDirect3D8 implementation
3  *
4  * Copyright 2002-2004 Jason Edmeades
5  * Copyright 2003-2004 Raphael Junqueira
6  * Copyright 2004 Christian Costa
7  *
8  * This library is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Lesser General Public
10  * License as published by the Free Software Foundation; either
11  * version 2.1 of the License, or (at your option) any later version.
12  *
13  * This library is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * Lesser General Public License for more details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with this library; if not, write to the Free Software
20  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
21  */
22
23 #include "config.h"
24
25 #include <stdarg.h>
26
27 #define NONAMELESSUNION
28 #define NONAMELESSSTRUCT
29 #include "windef.h"
30 #include "winbase.h"
31 #include "wingdi.h"
32 #include "winuser.h"
33 #include "wine/debug.h"
34 #include "wine/unicode.h"
35
36 #include "d3d8_private.h"
37
38 WINE_DEFAULT_DEBUG_CHANNEL(d3d);
39 WINE_DECLARE_DEBUG_CHANNEL(d3d_caps);
40
41 /* x11drv GDI escapes */
42 #define X11DRV_ESCAPE 6789
43 enum x11drv_escape_codes
44 {
45     X11DRV_GET_DISPLAY,   /* get X11 display for a DC */
46     X11DRV_GET_DRAWABLE,  /* get current drawable for a DC */
47     X11DRV_GET_FONT,      /* get current X font for a DC */
48 };
49
50 #define NUM_FORMATS 7
51 static const D3DFORMAT device_formats[NUM_FORMATS] = {
52   D3DFMT_P8,
53   D3DFMT_R3G3B2,
54   D3DFMT_R5G6B5, 
55   D3DFMT_X1R5G5B5,
56   D3DFMT_X4R4G4B4,
57   D3DFMT_R8G8B8,
58   D3DFMT_X8R8G8B8
59 };
60
61 static void IDirect3D8Impl_FillGLCaps(LPDIRECT3D8 iface, Display* display);
62
63
64 /* retrieve the X display to use on a given DC */
65 inline static Display *get_display( HDC hdc )
66 {
67     Display *display;
68     enum x11drv_escape_codes escape = X11DRV_GET_DISPLAY;
69
70     if (!ExtEscape( hdc, X11DRV_ESCAPE, sizeof(escape), (LPCSTR)&escape,
71                     sizeof(display), (LPSTR)&display )) display = NULL;
72     return display;
73 }
74
75 /* IDirect3D IUnknown parts follow: */
76 HRESULT WINAPI IDirect3D8Impl_QueryInterface(LPDIRECT3D8 iface,REFIID riid,LPVOID *ppobj)
77 {
78     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
79
80     if (IsEqualGUID(riid, &IID_IUnknown)
81         || IsEqualGUID(riid, &IID_IDirect3D8)) {
82         IDirect3D8Impl_AddRef(iface);
83         *ppobj = This;
84         return D3D_OK;
85     }
86
87     WARN("(%p)->(%s,%p),not found\n",This,debugstr_guid(riid),ppobj);
88     return E_NOINTERFACE;
89 }
90
91 ULONG WINAPI IDirect3D8Impl_AddRef(LPDIRECT3D8 iface) {
92     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
93     ULONG ref = InterlockedIncrement(&This->ref);
94
95     TRACE("(%p) : AddRef from %ld\n", This, ref - 1);
96
97     return ref;
98 }
99
100 ULONG WINAPI IDirect3D8Impl_Release(LPDIRECT3D8 iface) {
101     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
102     ULONG ref = InterlockedDecrement(&This->ref);
103
104     TRACE("(%p) : ReleaseRef to %ld\n", This, ref);
105
106     if (ref == 0) {
107         IWineD3D_Release(This->WineD3D);
108         HeapFree(GetProcessHeap(), 0, This);
109     }
110     return ref;
111 }
112
113 /* IDirect3D Interface follow: */
114 HRESULT WINAPI IDirect3D8Impl_RegisterSoftwareDevice (LPDIRECT3D8 iface, void* pInitializeFunction) {
115     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
116     return IWineD3D_RegisterSoftwareDevice(This->WineD3D, pInitializeFunction);
117 }
118
119 UINT WINAPI IDirect3D8Impl_GetAdapterCount (LPDIRECT3D8 iface) {
120     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
121     return IWineD3D_GetAdapterCount(This->WineD3D);
122 }
123
124 HRESULT  WINAPI  IDirect3D8Impl_GetAdapterIdentifier       (LPDIRECT3D8 iface,
125                                                             UINT Adapter, DWORD Flags, D3DADAPTER_IDENTIFIER8* pIdentifier) {
126     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
127     WINED3DADAPTER_IDENTIFIER adapter_id;
128
129     /* dx8 and dx9 have different structures to be filled in, with incompatible 
130        layouts so pass in pointers to the places to be filled via an internal 
131        structure                                                                */
132     adapter_id.Driver           = pIdentifier->Driver;          
133     adapter_id.Description      = pIdentifier->Description;     
134     adapter_id.DeviceName       = NULL;      
135     adapter_id.DriverVersion    = &pIdentifier->DriverVersion;   
136     adapter_id.VendorId         = &pIdentifier->VendorId;        
137     adapter_id.DeviceId         = &pIdentifier->DeviceId;        
138     adapter_id.SubSysId         = &pIdentifier->SubSysId;        
139     adapter_id.Revision         = &pIdentifier->Revision;        
140     adapter_id.DeviceIdentifier = &pIdentifier->DeviceIdentifier;
141     adapter_id.WHQLLevel        = &pIdentifier->WHQLLevel;       
142
143     return IWineD3D_GetAdapterIdentifier(This->WineD3D, Adapter, Flags, &adapter_id);
144 }
145
146 UINT WINAPI IDirect3D8Impl_GetAdapterModeCount (LPDIRECT3D8 iface,UINT Adapter) {
147     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
148     return IWineD3D_GetAdapterModeCount(This->WineD3D, Adapter, D3DFMT_UNKNOWN);
149 }
150
151 HRESULT WINAPI IDirect3D8Impl_EnumAdapterModes (LPDIRECT3D8 iface, UINT Adapter, UINT Mode, D3DDISPLAYMODE* pMode) {
152     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
153     return IWineD3D_EnumAdapterModes(This->WineD3D, Adapter, D3DFMT_UNKNOWN, Mode, pMode);
154 }
155
156 HRESULT WINAPI IDirect3D8Impl_GetAdapterDisplayMode (LPDIRECT3D8 iface, UINT Adapter, D3DDISPLAYMODE* pMode) {
157     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
158     return IWineD3D_GetAdapterDisplayMode(This->WineD3D, Adapter, pMode);
159 }
160
161 HRESULT  WINAPI  IDirect3D8Impl_CheckDeviceType            (LPDIRECT3D8 iface,
162                                                             UINT Adapter, D3DDEVTYPE CheckType, D3DFORMAT DisplayFormat,
163                                                             D3DFORMAT BackBufferFormat, BOOL Windowed) {
164     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
165     return IWineD3D_CheckDeviceType(This->WineD3D, Adapter, CheckType, DisplayFormat,
166                                     BackBufferFormat, Windowed);
167 }
168
169 HRESULT  WINAPI  IDirect3D8Impl_CheckDeviceFormat          (LPDIRECT3D8 iface,
170                                                             UINT Adapter, D3DDEVTYPE DeviceType, D3DFORMAT AdapterFormat,
171                                                             DWORD Usage, D3DRESOURCETYPE RType, D3DFORMAT CheckFormat) {
172     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
173     return IWineD3D_CheckDeviceFormat(This->WineD3D, Adapter, DeviceType, AdapterFormat,
174                                     Usage, RType, CheckFormat);
175 }
176
177 HRESULT  WINAPI  IDirect3D8Impl_CheckDeviceMultiSampleType(LPDIRECT3D8 iface,
178                                                            UINT Adapter, D3DDEVTYPE DeviceType, D3DFORMAT SurfaceFormat,
179                                                            BOOL Windowed, D3DMULTISAMPLE_TYPE MultiSampleType) {
180     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
181     return IWineD3D_CheckDeviceMultiSampleType(This->WineD3D, Adapter, DeviceType, SurfaceFormat,
182                                                Windowed, MultiSampleType, NULL);
183 }
184
185 HRESULT  WINAPI  IDirect3D8Impl_CheckDepthStencilMatch(LPDIRECT3D8 iface, 
186                                                        UINT Adapter, D3DDEVTYPE DeviceType, D3DFORMAT AdapterFormat,
187                                                        D3DFORMAT RenderTargetFormat, D3DFORMAT DepthStencilFormat) {
188     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
189     return IWineD3D_CheckDepthStencilMatch(This->WineD3D, Adapter, DeviceType, AdapterFormat,
190                                            RenderTargetFormat, DepthStencilFormat);
191 }
192
193 HRESULT  WINAPI  IDirect3D8Impl_GetDeviceCaps(LPDIRECT3D8 iface, UINT Adapter, D3DDEVTYPE DeviceType, D3DCAPS8* pCaps) {
194     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
195     HRESULT hrc = D3D_OK;
196     WINED3DCAPS *pWineCaps;
197
198     TRACE("(%p) Relay %d %u %p\n", This, Adapter, DeviceType, pCaps);
199
200     if(NULL == pCaps){
201         return D3DERR_INVALIDCALL;
202     }
203     pWineCaps = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(WINED3DCAPS));
204     if(pWineCaps == NULL){
205         return D3DERR_INVALIDCALL; /*well this is what MSDN says to return*/
206     }
207     D3D8CAPSTOWINECAPS(pCaps, pWineCaps)
208     hrc = IWineD3D_GetDeviceCaps(This->WineD3D, Adapter, DeviceType, pWineCaps);
209     HeapFree(GetProcessHeap(), 0, pWineCaps);
210     TRACE("(%p) returning %p\n", This, pCaps);
211     return hrc;
212 }
213
214 HMONITOR WINAPI  IDirect3D8Impl_GetAdapterMonitor(LPDIRECT3D8 iface, UINT Adapter) {
215     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
216     return IWineD3D_GetAdapterMonitor(This->WineD3D, Adapter);
217 }
218
219 static void IDirect3D8Impl_FillGLCaps(LPDIRECT3D8 iface, Display* display) {
220     const char *GL_Extensions = NULL;
221     const char *GLX_Extensions = NULL;
222     GLint gl_max;
223     const char* gl_string = NULL;
224     const char* gl_string_cursor = NULL;
225     Bool test = 0;
226     int major, minor;
227     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
228
229     if (This->gl_info.bIsFilled) return;
230     This->gl_info.bIsFilled = 1;
231
232     TRACE_(d3d_caps)("(%p, %p)\n", This, display);
233
234     if (NULL != display) {
235       test = glXQueryVersion(display, &major, &minor);
236       This->gl_info.glx_version = ((major & 0x0000FFFF) << 16) | (minor & 0x0000FFFF);
237       gl_string = glXGetClientString(display, GLX_VENDOR);
238     } else {
239       gl_string = (const char*) glGetString(GL_VENDOR);
240     }
241     
242     if (strstr(gl_string, "NVIDIA")) {
243       This->gl_info.gl_vendor = VENDOR_NVIDIA;
244     } else if (strstr(gl_string, "ATI")) {
245       This->gl_info.gl_vendor = VENDOR_ATI;
246     } else {
247       This->gl_info.gl_vendor = VENDOR_WINE;
248     }
249    
250     TRACE_(d3d_caps)("found GL_VENDOR (%s)->(0x%04x)\n", debugstr_a(gl_string), This->gl_info.gl_vendor);
251     
252     gl_string = (const char*) glGetString(GL_VERSION);
253     switch (This->gl_info.gl_vendor) {
254     case VENDOR_NVIDIA:
255       gl_string_cursor = strstr(gl_string, "NVIDIA");
256       gl_string_cursor = strstr(gl_string_cursor, " ");
257       while (*gl_string_cursor && ' ' == *gl_string_cursor) ++gl_string_cursor;
258       if (*gl_string_cursor) {
259         char tmp[16];
260         int cursor = 0;
261
262         while (*gl_string_cursor <= '9' && *gl_string_cursor >= '0') {
263           tmp[cursor++] = *gl_string_cursor;
264           ++gl_string_cursor;
265         }
266         tmp[cursor] = 0;
267         major = atoi(tmp);
268         
269         if (*gl_string_cursor != '.') WARN_(d3d_caps)("malformed GL_VERSION (%s)\n", debugstr_a(gl_string));
270         ++gl_string_cursor;
271
272         while (*gl_string_cursor <= '9' && *gl_string_cursor >= '0') {
273           tmp[cursor++] = *gl_string_cursor;
274           ++gl_string_cursor;
275         }
276         tmp[cursor] = 0;
277         minor = atoi(tmp);
278         break;
279       }
280     case VENDOR_ATI:
281       major = minor = 0;
282       gl_string_cursor = strchr(gl_string, '-');
283       if (gl_string_cursor) {
284         int error = 0;
285         gl_string_cursor++;
286         
287         /* Check if version number is of the form x.y.z */
288         if (*gl_string_cursor > '9' && *gl_string_cursor < '0')
289           error = 1;
290         if (!error && *(gl_string_cursor+2) > '9' && *(gl_string_cursor+2) < '0')
291           error = 1;
292         if (!error && *(gl_string_cursor+4) > '9' && *(gl_string_cursor+4) < '0')
293           error = 1;
294         if (!error && *(gl_string_cursor+1) != '.' && *(gl_string_cursor+3) != '.')
295           error = 1;
296         /* Mark version number as malformed */
297         if (error)
298           gl_string_cursor = 0;
299       }
300       if (!gl_string_cursor)
301         WARN_(d3d_caps)("malformed GL_VERSION (%s)\n", debugstr_a(gl_string));
302       else {
303         major = *gl_string_cursor - '0';
304         minor = (*(gl_string_cursor+2) - '0') * 256 + (*(gl_string_cursor+4) - '0');
305       }      
306       break;
307     default:
308       major = 0;
309       minor = 9;
310     }
311     This->gl_info.gl_driver_version = MAKEDWORD_VERSION(major, minor);
312
313     FIXME_(d3d_caps)("found GL_VERSION  (%s)->(0x%08lx)\n", debugstr_a(gl_string), This->gl_info.gl_driver_version);
314
315     gl_string = (const char*) glGetString(GL_RENDERER);
316     strcpy(This->gl_info.gl_renderer, gl_string);
317
318     switch (This->gl_info.gl_vendor) {
319     case VENDOR_NVIDIA:
320       if (strstr(This->gl_info.gl_renderer, "GeForce4 Ti")) {
321         This->gl_info.gl_card = CARD_NVIDIA_GEFORCE4_TI4600;
322       } else if (strstr(This->gl_info.gl_renderer, "GeForceFX")) {
323         This->gl_info.gl_card = CARD_NVIDIA_GEFORCEFX_5900ULTRA;
324       } else {
325         This->gl_info.gl_card = CARD_NVIDIA_GEFORCE4_TI4600;
326       }
327       break;
328     case VENDOR_ATI:
329       if (strstr(This->gl_info.gl_renderer, "RADEON 9800 PRO")) {
330         This->gl_info.gl_card = CARD_ATI_RADEON_9800PRO;
331       } else if (strstr(This->gl_info.gl_renderer, "RADEON 9700 PRO")) {
332         This->gl_info.gl_card = CARD_ATI_RADEON_9700PRO;
333       } else {
334         This->gl_info.gl_card = CARD_ATI_RADEON_8500;
335       }
336       break;
337     default:
338       This->gl_info.gl_card = CARD_WINE;
339       break;
340     }
341
342     FIXME_(d3d_caps)("found GL_RENDERER (%s)->(0x%04x)\n", debugstr_a(This->gl_info.gl_renderer), This->gl_info.gl_card);
343
344     /*
345      * Initialize openGL extension related variables
346      *  with Default values
347      */
348     memset(&This->gl_info.supported, 0, sizeof(This->gl_info.supported));
349     This->gl_info.max_textures   = 1;
350     This->gl_info.ps_arb_version = PS_VERSION_NOT_SUPPORTED;
351     This->gl_info.vs_arb_version = VS_VERSION_NOT_SUPPORTED;
352     This->gl_info.vs_nv_version  = VS_VERSION_NOT_SUPPORTED;
353     This->gl_info.vs_ati_version = VS_VERSION_NOT_SUPPORTED;
354
355 #define USE_GL_FUNC(type, pfn) This->gl_info.pfn = NULL;
356     GL_EXT_FUNCS_GEN;
357 #undef USE_GL_FUNC
358
359     /* Retrieve opengl defaults */
360     glGetIntegerv(GL_MAX_CLIP_PLANES, &gl_max);
361     This->gl_info.max_clipplanes = min(MAX_CLIPPLANES, gl_max);
362     TRACE_(d3d_caps)("ClipPlanes support - num Planes=%d\n", gl_max);
363
364     glGetIntegerv(GL_MAX_LIGHTS, &gl_max);
365     This->gl_info.max_lights = gl_max;
366     TRACE_(d3d_caps)("Lights support - max lights=%d\n", gl_max);
367
368     /* Parse the gl supported features, in theory enabling parts of our code appropriately */
369     GL_Extensions = (const char*) glGetString(GL_EXTENSIONS);
370     TRACE_(d3d_caps)("GL_Extensions reported:\n");  
371     
372     if (NULL == GL_Extensions) {
373       ERR("   GL_Extensions returns NULL\n");      
374     } else {
375       while (*GL_Extensions != 0x00) {
376         const char *Start = GL_Extensions;
377         char ThisExtn[256];
378
379         memset(ThisExtn, 0x00, sizeof(ThisExtn));
380         while (*GL_Extensions != ' ' && *GL_Extensions != 0x00) {
381           GL_Extensions++;
382         }
383         memcpy(ThisExtn, Start, (GL_Extensions - Start));
384         TRACE_(d3d_caps)("- %s\n", ThisExtn);
385
386         /**
387          * ARB 
388          */
389         if (strcmp(ThisExtn, "GL_ARB_fragment_program") == 0) {
390           This->gl_info.ps_arb_version = PS_VERSION_11;
391           TRACE_(d3d_caps)(" FOUND: ARB Pixel Shader support - version=%02x\n", This->gl_info.ps_arb_version);
392           This->gl_info.supported[ARB_FRAGMENT_PROGRAM] = TRUE;
393         } else if (strcmp(ThisExtn, "GL_ARB_multisample") == 0) {
394           TRACE_(d3d_caps)(" FOUND: ARB Multisample support\n");
395           This->gl_info.supported[ARB_MULTISAMPLE] = TRUE;
396         } else if (strcmp(ThisExtn, "GL_ARB_multitexture") == 0) {
397           glGetIntegerv(GL_MAX_TEXTURE_UNITS_ARB, &gl_max);
398           TRACE_(d3d_caps)(" FOUND: ARB Multitexture support - GL_MAX_TEXTURE_UNITS_ARB=%u\n", gl_max);
399           This->gl_info.supported[ARB_MULTITEXTURE] = TRUE;
400           This->gl_info.max_textures = min(8, gl_max);
401         } else if (strcmp(ThisExtn, "GL_ARB_point_parameters") == 0) {
402           TRACE_(d3d_caps)(" FOUND: ARB Point parameters support\n");
403           This->gl_info.supported[ARB_POINT_PARAMETERS] = TRUE;
404         } else if (strcmp(ThisExtn, "GL_ARB_point_sprite") == 0) {
405           TRACE_(d3d_caps)(" FOUND: ARB Point sprite support\n");
406           This->gl_info.supported[ARB_POINT_SPRITE] = TRUE;
407         } else if (strcmp(ThisExtn, "GL_ARB_texture_cube_map") == 0) {
408           TRACE_(d3d_caps)(" FOUND: ARB Texture Cube Map support\n");
409           This->gl_info.supported[ARB_TEXTURE_CUBE_MAP] = TRUE;
410           TRACE_(d3d_caps)(" IMPLIED: NVIDIA (NV) Texture Gen Reflection support\n");
411           This->gl_info.supported[NV_TEXGEN_REFLECTION] = TRUE;
412         } else if (strcmp(ThisExtn, "GL_ARB_texture_compression") == 0) {
413           TRACE_(d3d_caps)(" FOUND: ARB Texture Compression support\n");
414           This->gl_info.supported[ARB_TEXTURE_COMPRESSION] = TRUE;
415         } else if (strcmp(ThisExtn, "GL_ARB_texture_env_add") == 0) {
416           TRACE_(d3d_caps)(" FOUND: ARB Texture Env Add support\n");
417           This->gl_info.supported[ARB_TEXTURE_ENV_ADD] = TRUE;
418         } else if (strcmp(ThisExtn, "GL_ARB_texture_env_combine") == 0) {
419           TRACE_(d3d_caps)(" FOUND: ARB Texture Env combine support\n");
420           This->gl_info.supported[ARB_TEXTURE_ENV_COMBINE] = TRUE;
421         } else if (strcmp(ThisExtn, "GL_ARB_texture_env_dot3") == 0) {
422           TRACE_(d3d_caps)(" FOUND: ARB Dot3 support\n");
423           This->gl_info.supported[ARB_TEXTURE_ENV_DOT3] = TRUE;
424         } else if (strcmp(ThisExtn, "GL_ARB_texture_border_clamp") == 0) {
425           TRACE_(d3d_caps)(" FOUND: ARB Texture border clamp support\n");
426           This->gl_info.supported[ARB_TEXTURE_BORDER_CLAMP] = TRUE;
427         } else if (strcmp(ThisExtn, "GL_ARB_texture_mirrored_repeat") == 0) {
428           TRACE_(d3d_caps)(" FOUND: ARB Texture mirrored repeat support\n");
429           This->gl_info.supported[ARB_TEXTURE_MIRRORED_REPEAT] = TRUE;
430         } else if (strstr(ThisExtn, "GL_ARB_vertex_program")) {
431           This->gl_info.vs_arb_version = VS_VERSION_11;
432           TRACE_(d3d_caps)(" FOUND: ARB Vertex Shader support - version=%02x\n", This->gl_info.vs_arb_version);
433           This->gl_info.supported[ARB_VERTEX_PROGRAM] = TRUE;
434
435         /**
436          * EXT
437          */
438         } else if (strcmp(ThisExtn, "GL_EXT_fog_coord") == 0) {
439           TRACE_(d3d_caps)(" FOUND: EXT Fog coord support\n");
440           This->gl_info.supported[EXT_FOG_COORD] = TRUE;
441         } else if (strcmp(ThisExtn, "GL_EXT_paletted_texture") == 0) { /* handle paletted texture extensions */
442           TRACE_(d3d_caps)(" FOUND: EXT Paletted texture support\n");
443           This->gl_info.supported[EXT_PALETTED_TEXTURE] = TRUE;
444         } else if (strcmp(ThisExtn, "GL_EXT_point_parameters") == 0) {
445           TRACE_(d3d_caps)(" FOUND: EXT Point parameters support\n");
446           This->gl_info.supported[EXT_POINT_PARAMETERS] = TRUE;
447         } else if (strcmp(ThisExtn, "GL_EXT_secondary_color") == 0) {
448           TRACE_(d3d_caps)(" FOUND: EXT Secondary coord support\n");
449           This->gl_info.supported[EXT_SECONDARY_COLOR] = TRUE;
450         } else if (strcmp(ThisExtn, "GL_EXT_stencil_wrap") == 0) {
451           TRACE_(d3d_caps)(" FOUND: EXT Stencil wrap support\n");
452           This->gl_info.supported[EXT_STENCIL_WRAP] = TRUE;
453         } else if (strcmp(ThisExtn, "GL_EXT_texture_compression_s3tc") == 0) {
454           TRACE_(d3d_caps)(" FOUND: EXT Texture S3TC compression support\n");
455           This->gl_info.supported[EXT_TEXTURE_COMPRESSION_S3TC] = TRUE;
456         } else if (strcmp(ThisExtn, "GL_EXT_texture_env_add") == 0) {
457           TRACE_(d3d_caps)(" FOUND: EXT Texture Env Add support\n");
458           This->gl_info.supported[EXT_TEXTURE_ENV_ADD] = TRUE;
459         } else if (strcmp(ThisExtn, "GL_EXT_texture_env_combine") == 0) {
460           TRACE_(d3d_caps)(" FOUND: EXT Texture Env combine support\n");
461           This->gl_info.supported[EXT_TEXTURE_ENV_COMBINE] = TRUE;
462         } else if (strcmp(ThisExtn, "GL_EXT_texture_env_dot3") == 0) {
463           TRACE_(d3d_caps)(" FOUND: EXT Dot3 support\n");
464           This->gl_info.supported[EXT_TEXTURE_ENV_DOT3] = TRUE;
465         } else if (strcmp(ThisExtn, "GL_EXT_texture_filter_anisotropic") == 0) {
466           TRACE_(d3d_caps)(" FOUND: EXT Texture Anisotropic filter support\n");
467           This->gl_info.supported[EXT_TEXTURE_FILTER_ANISOTROPIC] = TRUE;
468         } else if (strcmp(ThisExtn, "GL_EXT_texture_lod") == 0) {
469           TRACE_(d3d_caps)(" FOUND: EXT Texture LOD support\n");
470           This->gl_info.supported[EXT_TEXTURE_LOD] = TRUE;
471         } else if (strcmp(ThisExtn, "GL_EXT_texture_lod_bias") == 0) {
472           TRACE_(d3d_caps)(" FOUND: EXT Texture LOD bias support\n");
473           This->gl_info.supported[EXT_TEXTURE_LOD_BIAS] = TRUE;
474         } else if (strcmp(ThisExtn, "GL_EXT_vertex_weighting") == 0) {
475           TRACE_(d3d_caps)(" FOUND: EXT Vertex weighting support\n");
476           This->gl_info.supported[EXT_VERTEX_WEIGHTING] = TRUE;
477
478         /**
479          * NVIDIA 
480          */
481         } else if (strstr(ThisExtn, "GL_NV_fog_distance")) {
482           TRACE_(d3d_caps)(" FOUND: NVIDIA (NV) Fog Distance support\n");
483           This->gl_info.supported[NV_FOG_DISTANCE] = TRUE;
484         } else if (strstr(ThisExtn, "GL_NV_fragment_program")) {
485           This->gl_info.ps_nv_version = PS_VERSION_11;
486           TRACE_(d3d_caps)(" FOUND: NVIDIA (NV) Pixel Shader support - version=%02x\n", This->gl_info.ps_nv_version);
487         } else if (strcmp(ThisExtn, "GL_NV_register_combiners") == 0) {
488           TRACE_(d3d_caps)(" FOUND: NVIDIA (NV) Register combiners (1) support\n");
489           This->gl_info.supported[NV_REGISTER_COMBINERS] = TRUE;
490         } else if (strcmp(ThisExtn, "GL_NV_register_combiners2") == 0) {
491           TRACE_(d3d_caps)(" FOUND: NVIDIA (NV) Register combiners (2) support\n");
492           This->gl_info.supported[NV_REGISTER_COMBINERS2] = TRUE;
493         } else if (strcmp(ThisExtn, "GL_NV_texgen_reflection") == 0) {
494           TRACE_(d3d_caps)(" FOUND: NVIDIA (NV) Texture Gen Reflection support\n");
495           This->gl_info.supported[NV_TEXGEN_REFLECTION] = TRUE;
496         } else if (strcmp(ThisExtn, "GL_NV_texture_env_combine4") == 0) {
497           TRACE_(d3d_caps)(" FOUND: NVIDIA (NV) Texture Env combine (4) support\n");
498           This->gl_info.supported[NV_TEXTURE_ENV_COMBINE4] = TRUE;
499         } else if (strcmp(ThisExtn, "GL_NV_texture_shader") == 0) {
500           TRACE_(d3d_caps)(" FOUND: NVIDIA (NV) Texture Shader (1) support\n");
501           This->gl_info.supported[NV_TEXTURE_SHADER] = TRUE;
502         } else if (strcmp(ThisExtn, "GL_NV_texture_shader2") == 0) {
503           TRACE_(d3d_caps)(" FOUND: NVIDIA (NV) Texture Shader (2) support\n");
504           This->gl_info.supported[NV_TEXTURE_SHADER2] = TRUE;
505         } else if (strcmp(ThisExtn, "GL_NV_texture_shader3") == 0) {
506           TRACE_(d3d_caps)(" FOUND: NVIDIA (NV) Texture Shader (3) support\n");
507           This->gl_info.supported[NV_TEXTURE_SHADER3] = TRUE;
508         } else if (strstr(ThisExtn, "GL_NV_vertex_program")) {
509           This->gl_info.vs_nv_version = max(This->gl_info.vs_nv_version, (0 == strcmp(ThisExtn, "GL_NV_vertex_program1_1")) ? VS_VERSION_11 : VS_VERSION_10);
510           This->gl_info.vs_nv_version = max(This->gl_info.vs_nv_version, (0 == strcmp(ThisExtn, "GL_NV_vertex_program2"))   ? VS_VERSION_20 : VS_VERSION_10);
511           TRACE_(d3d_caps)(" FOUND: NVIDIA (NV) Vertex Shader support - version=%02x\n", This->gl_info.vs_nv_version);
512           This->gl_info.supported[NV_VERTEX_PROGRAM] = TRUE;
513
514         /**
515          * ATI
516          */
517         /** TODO */
518         } else if (strcmp(ThisExtn, "GL_ATI_texture_env_combine3") == 0) {
519           TRACE_(d3d_caps)(" FOUND: ATI Texture Env combine (3) support\n");
520           This->gl_info.supported[ATI_TEXTURE_ENV_COMBINE3] = TRUE;
521         } else if (strcmp(ThisExtn, "GL_ATI_texture_mirror_once") == 0) {
522           TRACE_(d3d_caps)(" FOUND: ATI Texture Mirror Once support\n");
523           This->gl_info.supported[ATI_TEXTURE_MIRROR_ONCE] = TRUE;
524         } else if (strcmp(ThisExtn, "GL_EXT_vertex_shader") == 0) {
525           This->gl_info.vs_ati_version = VS_VERSION_11;
526           TRACE_(d3d_caps)(" FOUND: ATI (EXT) Vertex Shader support - version=%02x\n", This->gl_info.vs_ati_version);
527           This->gl_info.supported[EXT_VERTEX_SHADER] = TRUE;
528         }
529
530
531         if (*GL_Extensions == ' ') GL_Extensions++;
532       }
533     }
534
535 #define USE_GL_FUNC(type, pfn) This->gl_info.pfn = (type) glXGetProcAddressARB( (const GLubyte *) #pfn);
536     GL_EXT_FUNCS_GEN;
537 #undef USE_GL_FUNC
538
539     if (display != NULL) {
540         GLX_Extensions = glXQueryExtensionsString(display, DefaultScreen(display));
541         TRACE_(d3d_caps)("GLX_Extensions reported:\n");  
542     
543         if (NULL == GLX_Extensions) {
544           ERR("   GLX_Extensions returns NULL\n");      
545         } else {
546           while (*GLX_Extensions != 0x00) {
547             const char *Start = GLX_Extensions;
548             char ThisExtn[256];
549            
550             memset(ThisExtn, 0x00, sizeof(ThisExtn));
551             while (*GLX_Extensions != ' ' && *GLX_Extensions != 0x00) {
552               GLX_Extensions++;
553             }
554             memcpy(ThisExtn, Start, (GLX_Extensions - Start));
555             TRACE_(d3d_caps)("- %s\n", ThisExtn);
556             if (*GLX_Extensions == ' ') GLX_Extensions++;
557           }
558         }
559     }
560
561 #define USE_GL_FUNC(type, pfn) This->gl_info.pfn = (type) glXGetProcAddressARB( (const GLubyte *) #pfn);
562     GLX_EXT_FUNCS_GEN;
563 #undef USE_GL_FUNC
564
565     /* Only save the values obtained when a display is provided */
566     if (display != NULL) This->isGLInfoValid = TRUE;
567
568 }
569
570 /* Internal function called back during the CreateDevice to create a render target */
571 HRESULT WINAPI D3D8CB_CreateRenderTarget(IUnknown *device, UINT Width, UINT Height, 
572                                          WINED3DFORMAT Format, D3DMULTISAMPLE_TYPE MultiSample, 
573                                          DWORD MultisampleQuality, BOOL Lockable, 
574                                          IWineD3DSurface** ppSurface, HANDLE* pSharedHandle) {
575     HRESULT res = D3D_OK;
576     IDirect3DSurface8Impl *d3dSurface = NULL;
577
578     /* Note - Throw away MultisampleQuality and SharedHandle - only relevant for d3d9  */
579     res = IDirect3DDevice8_CreateRenderTarget((IDirect3DDevice8 *)device, Width, Height, 
580                                          (D3DFORMAT)Format, MultiSample, Lockable, 
581                                          (IDirect3DSurface8 **)&d3dSurface);
582     if (res == D3D_OK) {
583         *ppSurface = d3dSurface->wineD3DSurface;
584     }
585     return res;
586 }
587
588 /* Callback for creating the inplicite swapchain when the device is created */
589 HRESULT WINAPI D3D8CB_CreateAdditionalSwapChain(IUnknown *device,
590                                                 WINED3DPRESENT_PARAMETERS* pPresentationParameters,
591                                                 IWineD3DSwapChain ** ppSwapChain){
592     HRESULT res = D3D_OK;
593     IDirect3DSwapChain8Impl *d3dSwapChain = NULL;
594     /* We have to pass the presentation parameters back and forth */
595     D3DPRESENT_PARAMETERS localParameters;
596     localParameters.BackBufferWidth                = *(pPresentationParameters->BackBufferWidth);
597     localParameters.BackBufferHeight               = *(pPresentationParameters->BackBufferHeight);
598     localParameters.BackBufferFormat               = *(pPresentationParameters->BackBufferFormat);
599     localParameters.BackBufferCount                = *(pPresentationParameters->BackBufferCount);
600     localParameters.MultiSampleType                = *(pPresentationParameters->MultiSampleType);
601   /* d3d9 only */
602   /* localParameters.MultiSampleQuality             = *(pPresentationParameters->MultiSampleQuality); */
603     localParameters.SwapEffect                     = *(pPresentationParameters->SwapEffect);
604     localParameters.hDeviceWindow                  = *(pPresentationParameters->hDeviceWindow);
605     localParameters.Windowed                       = *(pPresentationParameters->Windowed);
606     localParameters.EnableAutoDepthStencil         = *(pPresentationParameters->EnableAutoDepthStencil);
607     localParameters.AutoDepthStencilFormat         = *(pPresentationParameters->AutoDepthStencilFormat);
608     localParameters.Flags                          = *(pPresentationParameters->Flags);
609     localParameters.FullScreen_RefreshRateInHz     = *(pPresentationParameters->FullScreen_RefreshRateInHz);
610 /* not in d3d8 */
611 /*    localParameters.PresentationInterval           = *(pPresentationParameters->PresentationInterval); */
612
613     TRACE("(%p) rellaying\n", device);
614     /*copy the presentation parameters*/
615     res = IDirect3DDevice8_CreateAdditionalSwapChain((IDirect3DDevice8 *)device, &localParameters, (IDirect3DSwapChain8 **)&d3dSwapChain);
616
617     if (res == D3D_OK){
618         *ppSwapChain = d3dSwapChain->wineD3DSwapChain;
619     } else {
620         FIXME("failed to create additional swap chain\n");
621         *ppSwapChain = NULL;
622     }
623     /* Copy back the presentation parameters */
624     TRACE("(%p) setting up return parameters\n", device);
625    *pPresentationParameters->BackBufferWidth               = localParameters.BackBufferWidth;
626    *pPresentationParameters->BackBufferHeight              = localParameters.BackBufferHeight;
627    *pPresentationParameters->BackBufferFormat              = localParameters.BackBufferFormat;
628    *pPresentationParameters->BackBufferCount               = localParameters.BackBufferCount;
629    *pPresentationParameters->MultiSampleType               = localParameters.MultiSampleType;
630 /*   *pPresentationParameters->MultiSampleQuality            leave alone in case wined3d set something internally */
631    *pPresentationParameters->SwapEffect                    = localParameters.SwapEffect;
632    *pPresentationParameters->hDeviceWindow                 = localParameters.hDeviceWindow;
633    *pPresentationParameters->Windowed                      = localParameters.Windowed;
634    *pPresentationParameters->EnableAutoDepthStencil        = localParameters.EnableAutoDepthStencil;
635    *pPresentationParameters->AutoDepthStencilFormat        = localParameters.AutoDepthStencilFormat;
636    *pPresentationParameters->Flags                         = localParameters.Flags;
637    *pPresentationParameters->FullScreen_RefreshRateInHz    = localParameters.FullScreen_RefreshRateInHz;
638 /*   *pPresentationParameters->PresentationInterval          leave alone in case wined3d set something internally */
639
640    return res;
641 }
642
643 HRESULT  WINAPI  IDirect3D8Impl_CreateDevice               (LPDIRECT3D8 iface,
644                                                             UINT Adapter, D3DDEVTYPE DeviceType, HWND hFocusWindow,
645                                                             DWORD BehaviourFlags, D3DPRESENT_PARAMETERS* pPresentationParameters,
646                                                             IDirect3DDevice8** ppReturnedDeviceInterface) {
647     IDirect3DDevice8Impl *object;
648     HWND whichHWND;
649     int num;
650     XVisualInfo template;
651     HDC hDc;
652     WINED3DPRESENT_PARAMETERS localParameters;
653
654     IDirect3D8Impl *This = (IDirect3D8Impl *)iface;
655     TRACE("(%p)->(Adptr:%d, DevType: %x, FocusHwnd: %p, BehFlags: %lx, PresParms: %p, RetDevInt: %p)\n", This, Adapter, DeviceType,
656           hFocusWindow, BehaviourFlags, pPresentationParameters, ppReturnedDeviceInterface);
657
658     if (Adapter >= IDirect3D8Impl_GetAdapterCount(iface)) {
659         return D3DERR_INVALIDCALL;
660     }
661
662     /* Allocate the storage for the device */
663     object = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(IDirect3DDevice8Impl));
664     if (NULL == object) {
665       return D3DERR_OUTOFVIDEOMEMORY;
666     }
667     object->lpVtbl = &Direct3DDevice8_Vtbl;
668     object->ref = 1;
669     object->direct3d8 = This;
670     /** The device AddRef the direct3d8 Interface else crash in propers clients codes */
671     IDirect3D8_AddRef((LPDIRECT3D8) object->direct3d8);
672
673     /* Allocate an associated WineD3DDevice object */
674     localParameters.BackBufferWidth                = &pPresentationParameters->BackBufferWidth;             
675     localParameters.BackBufferHeight               = &pPresentationParameters->BackBufferHeight;
676     localParameters.BackBufferFormat               = (WINED3DFORMAT *)&pPresentationParameters->BackBufferFormat;           
677     localParameters.BackBufferCount                = &pPresentationParameters->BackBufferCount;            
678     localParameters.MultiSampleType                = &pPresentationParameters->MultiSampleType;            
679     localParameters.MultiSampleQuality             = NULL; /* New at dx9 */
680     localParameters.SwapEffect                     = &pPresentationParameters->SwapEffect;                 
681     localParameters.hDeviceWindow                  = &pPresentationParameters->hDeviceWindow;              
682     localParameters.Windowed                       = &pPresentationParameters->Windowed;                   
683     localParameters.EnableAutoDepthStencil         = &pPresentationParameters->EnableAutoDepthStencil;     
684     localParameters.AutoDepthStencilFormat         = (WINED3DFORMAT *)&pPresentationParameters->AutoDepthStencilFormat;     
685     localParameters.Flags                          = &pPresentationParameters->Flags;                      
686     localParameters.FullScreen_RefreshRateInHz     = &pPresentationParameters->FullScreen_RefreshRateInHz; 
687     localParameters.PresentationInterval           = &pPresentationParameters->FullScreen_PresentationInterval;    /* Renamed in dx9 */
688     IWineD3D_CreateDevice(This->WineD3D, Adapter, DeviceType, hFocusWindow, BehaviourFlags, &localParameters, &object->WineD3DDevice, (IUnknown *)object, D3D8CB_CreateAdditionalSwapChain);
689
690     /** use StateBlock Factory here, for creating the startup stateBlock */
691     object->StateBlock = NULL;
692     IDirect3DDeviceImpl_CreateStateBlock(object, D3DSBT_ALL, NULL);
693     object->UpdateStateBlock = object->StateBlock;
694
695     /* Save the creation parameters */
696     object->CreateParms.AdapterOrdinal = Adapter;
697     object->CreateParms.DeviceType = DeviceType;
698     object->CreateParms.hFocusWindow = hFocusWindow;
699     object->CreateParms.BehaviorFlags = BehaviourFlags;
700
701     *ppReturnedDeviceInterface = (LPDIRECT3DDEVICE8) object;
702
703     /* Initialize settings */
704     object->PresentParms.BackBufferCount = 1; /* Opengl only supports one? */
705     object->adapterNo = Adapter;
706     object->devType = DeviceType;
707
708     /* Initialize openGl - Note the visual is chosen as the window is created and the glcontext cannot
709          use different properties after that point in time. FIXME: How to handle when requested format 
710          doesn't match actual visual? Cannot choose one here - code removed as it ONLY works if the one
711          it chooses is identical to the one already being used!                                        */
712     /* FIXME: Handle stencil appropriately via EnableAutoDepthStencil / AutoDepthStencilFormat */
713
714     /* Which hwnd are we using? */
715     whichHWND = pPresentationParameters->hDeviceWindow;
716     if (!whichHWND) {
717         whichHWND = hFocusWindow;
718     }
719     whichHWND = GetAncestor(whichHWND, GA_ROOT);
720     if ( !( object->win = (Window)GetPropA(whichHWND, "__wine_x11_whole_window") ) ) {
721         ERR("Can't get drawable (window), HWND:%p doesn't have the property __wine_x11_whole_window\n", whichHWND);
722         return D3DERR_NOTAVAILABLE;
723     }
724     object->win_handle = whichHWND;
725
726     hDc = GetDC(whichHWND);
727     object->display = get_display(hDc);
728
729     TRACE("(%p)->(DepthStencil:(%u,%s), BackBufferFormat:(%u,%s))\n", This, 
730           pPresentationParameters->AutoDepthStencilFormat, debug_d3dformat(pPresentationParameters->AutoDepthStencilFormat),
731           pPresentationParameters->BackBufferFormat, debug_d3dformat(pPresentationParameters->BackBufferFormat));
732
733     ENTER_GL();
734
735     /* Create a context based off the properties of the existing visual */
736     template.visualid = (VisualID)GetPropA(GetDesktopWindow(), "__wine_x11_visual_id");
737     object->visInfo = XGetVisualInfo(object->display, VisualIDMask, &template, &num);
738     if (NULL == object->visInfo) {
739         ERR("cannot really get XVisual\n"); 
740         LEAVE_GL();
741         return D3DERR_NOTAVAILABLE;
742      }
743     object->glCtx = glXCreateContext(object->display, object->visInfo, NULL, GL_TRUE);
744     if (NULL == object->glCtx) {
745       ERR("cannot create glxContext\n"); 
746       LEAVE_GL();
747       return D3DERR_NOTAVAILABLE;
748      }
749     LEAVE_GL();
750
751     ReleaseDC(whichHWND, hDc);
752     
753     if (object->glCtx == NULL) {
754         ERR("Error in context creation !\n");
755         return D3DERR_INVALIDCALL;
756     } else {
757         TRACE("Context created (HWND=%p, glContext=%p, Window=%ld, VisInfo=%p)\n",
758               whichHWND, object->glCtx, object->win, object->visInfo);
759     }
760
761     /* If not windowed, need to go fullscreen, and resize the HWND to the appropriate  */
762     /*        dimensions                                                               */
763     if (!pPresentationParameters->Windowed) {
764 #if 1
765         DEVMODEW devmode;
766         HDC hdc;
767         int bpp = 0;
768         memset(&devmode, 0, sizeof(DEVMODEW));
769         devmode.dmFields = DM_BITSPERPEL | DM_PELSWIDTH | DM_PELSHEIGHT; 
770         MultiByteToWideChar(CP_ACP, 0, "Gamers CG", -1, devmode.dmDeviceName, CCHDEVICENAME);
771         hdc = CreateDCA("DISPLAY", NULL, NULL, NULL);
772         bpp = GetDeviceCaps(hdc, BITSPIXEL);
773         DeleteDC(hdc);
774         devmode.dmBitsPerPel = (bpp >= 24) ? 32 : bpp;/*Stupid XVidMode cannot change bpp D3DFmtGetBpp(object, pPresentationParameters->BackBufferFormat);*/
775         devmode.dmPelsWidth  = pPresentationParameters->BackBufferWidth;
776         devmode.dmPelsHeight = pPresentationParameters->BackBufferHeight;
777         ChangeDisplaySettingsExW(devmode.dmDeviceName, &devmode, object->win_handle, CDS_FULLSCREEN, NULL);
778 #else
779         FIXME("Requested full screen support not implemented, expect windowed operation\n");
780 #endif
781
782         /* Make popup window */
783         SetWindowLongA(whichHWND, GWL_STYLE, WS_POPUP);
784         SetWindowPos(object->win_handle, HWND_TOP, 0, 0, 
785                      pPresentationParameters->BackBufferWidth,
786                      pPresentationParameters->BackBufferHeight, SWP_SHOWWINDOW | SWP_FRAMECHANGED);
787     }
788
789     TRACE("Creating back buffer\n");
790     /* MSDN: If Windowed is TRUE and either of the BackBufferWidth/Height values is zero,
791        then the corresponding dimension of the client area of the hDeviceWindow
792        (or the focus window, if hDeviceWindow is NULL) is taken. */
793     if (pPresentationParameters->Windowed && ((pPresentationParameters->BackBufferWidth  == 0) ||
794                                               (pPresentationParameters->BackBufferHeight == 0))) {
795         RECT Rect;
796
797         GetClientRect(whichHWND, &Rect);
798
799         if (pPresentationParameters->BackBufferWidth == 0) {
800            pPresentationParameters->BackBufferWidth = Rect.right;
801            TRACE("Updating width to %d\n", pPresentationParameters->BackBufferWidth);
802         }
803         if (pPresentationParameters->BackBufferHeight == 0) {
804            pPresentationParameters->BackBufferHeight = Rect.bottom;
805            TRACE("Updating height to %d\n", pPresentationParameters->BackBufferHeight);
806         }
807     }
808
809     /* Save the presentation parms now filled in correctly */
810     memcpy(&object->PresentParms, pPresentationParameters, sizeof(D3DPRESENT_PARAMETERS));
811
812
813     IDirect3DDevice8Impl_CreateRenderTarget((LPDIRECT3DDEVICE8) object,
814                                             pPresentationParameters->BackBufferWidth,
815                                             pPresentationParameters->BackBufferHeight,
816                                             pPresentationParameters->BackBufferFormat,
817                                             pPresentationParameters->MultiSampleType,
818                                             TRUE,
819                                             (LPDIRECT3DSURFACE8*) &object->frontBuffer);
820
821     IDirect3DDevice8Impl_CreateRenderTarget((LPDIRECT3DDEVICE8) object,
822                                             pPresentationParameters->BackBufferWidth,
823                                             pPresentationParameters->BackBufferHeight,
824                                             pPresentationParameters->BackBufferFormat,
825                                             pPresentationParameters->MultiSampleType,
826                                             TRUE,
827                                             (LPDIRECT3DSURFACE8*) &object->backBuffer);
828
829     if (pPresentationParameters->EnableAutoDepthStencil) {
830        IDirect3DDevice8Impl_CreateDepthStencilSurface((LPDIRECT3DDEVICE8) object,
831                                                       pPresentationParameters->BackBufferWidth,
832                                                       pPresentationParameters->BackBufferHeight,
833                                                       pPresentationParameters->AutoDepthStencilFormat,
834                                                       D3DMULTISAMPLE_NONE,
835                                                       (LPDIRECT3DSURFACE8*) &object->depthStencilBuffer);
836     } else {
837       object->depthStencilBuffer = NULL;
838     }
839     TRACE("FrontBuf @ %p, BackBuf @ %p, DepthStencil @ %p\n",object->frontBuffer, object->backBuffer, object->depthStencilBuffer);
840
841     /* init the default renderTarget management */
842     object->drawable = object->win;
843     object->render_ctx = object->glCtx;
844     object->renderTarget = object->backBuffer;
845     IDirect3DSurface8Impl_AddRef((LPDIRECT3DSURFACE8) object->renderTarget);
846     object->stencilBufferTarget = object->depthStencilBuffer;
847     if (NULL != object->stencilBufferTarget) {
848       IDirect3DSurface8Impl_AddRef((LPDIRECT3DSURFACE8) object->stencilBufferTarget);
849     }
850
851     ENTER_GL();
852
853     if (glXMakeCurrent(object->display, object->win, object->glCtx) == False) {
854       ERR("Error in setting current context (context %p drawable %ld)!\n", object->glCtx, object->win);
855     }
856     checkGLcall("glXMakeCurrent");
857
858     /* Clear the screen */
859     glClearColor(1.0, 0.0, 0.0, 0.0);
860     checkGLcall("glClearColor");
861     glColor3f(1.0, 1.0, 1.0);
862     checkGLcall("glColor3f");
863
864     glEnable(GL_LIGHTING);
865     checkGLcall("glEnable");
866
867     glLightModeli(GL_LIGHT_MODEL_LOCAL_VIEWER, GL_TRUE);
868     checkGLcall("glLightModeli(GL_LIGHT_MODEL_LOCAL_VIEWER, GL_TRUE);");
869
870     glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_COMBINE_EXT);
871     checkGLcall("glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_COMBINE_EXT);");
872
873     glLightModeli(GL_LIGHT_MODEL_COLOR_CONTROL, GL_SEPARATE_SPECULAR_COLOR);
874     checkGLcall("glLightModeli(GL_LIGHT_MODEL_COLOR_CONTROL, GL_SEPARATE_SPECULAR_COLOR);");
875
876     /* 
877      * Initialize openGL extension related variables
878      *  with Default values 
879      */
880     IDirect3D8Impl_FillGLCaps(iface, object->display);
881
882     /* Setup all the devices defaults */
883     IDirect3DDeviceImpl_InitStartupStateBlock(object);
884
885     LEAVE_GL();
886
887     { /* Set a default viewport */
888        D3DVIEWPORT8 vp;
889        vp.X      = 0;
890        vp.Y      = 0;
891        vp.Width  = pPresentationParameters->BackBufferWidth;
892        vp.Height = pPresentationParameters->BackBufferHeight;
893        vp.MinZ   = 0.0f;
894        vp.MaxZ   = 1.0f;
895        IDirect3DDevice8Impl_SetViewport((LPDIRECT3DDEVICE8) object, &vp);
896     }
897
898     /* Initialize the current view state */
899     object->modelview_valid = 1;
900     object->proj_valid = 0;
901     object->view_ident = 1;
902     object->last_was_rhw = 0;
903     glGetIntegerv(GL_MAX_LIGHTS, &object->maxConcurrentLights);
904     TRACE("(%p,%d) All defaults now set up, leaving CreateDevice with %p\n", This, Adapter, object);
905
906     /* Clear the screen */
907     IDirect3DDevice8Impl_Clear((LPDIRECT3DDEVICE8) object, 0, NULL, D3DCLEAR_STENCIL|D3DCLEAR_ZBUFFER|D3DCLEAR_TARGET, 0x00, 1.0, 0);
908
909     return D3D_OK;
910 }
911
912 const IDirect3D8Vtbl Direct3D8_Vtbl =
913 {
914     IDirect3D8Impl_QueryInterface,
915     IDirect3D8Impl_AddRef,
916     IDirect3D8Impl_Release,
917     IDirect3D8Impl_RegisterSoftwareDevice,
918     IDirect3D8Impl_GetAdapterCount,
919     IDirect3D8Impl_GetAdapterIdentifier,
920     IDirect3D8Impl_GetAdapterModeCount,
921     IDirect3D8Impl_EnumAdapterModes,
922     IDirect3D8Impl_GetAdapterDisplayMode,
923     IDirect3D8Impl_CheckDeviceType,
924     IDirect3D8Impl_CheckDeviceFormat,
925     IDirect3D8Impl_CheckDeviceMultiSampleType,
926     IDirect3D8Impl_CheckDepthStencilMatch,
927     IDirect3D8Impl_GetDeviceCaps,
928     IDirect3D8Impl_GetAdapterMonitor,
929     IDirect3D8Impl_CreateDevice
930 };