2 /* DirectDraw Base Functions
4 * Copyright 1997-1999 Marcus Meissner
5 * Copyright 1998 Lionel Ulmer (most of Direct3D stuff)
19 #include "wine/exception.h"
22 #include "debugtools.h"
25 DEFAULT_DEBUG_CHANNEL(ddraw);
27 /******************************************************************************
28 * debug output functions
30 void _dump_DDBLTFX(DWORD flagmask) {
36 #define FE(x) { x, #x},
37 FE(DDBLTFX_ARITHSTRETCHY)
38 FE(DDBLTFX_MIRRORLEFTRIGHT)
39 FE(DDBLTFX_MIRRORUPDOWN)
44 FE(DDBLTFX_ZBUFFERRANGE)
45 FE(DDBLTFX_ZBUFFERBASEDEST)
48 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
49 if (flags[i].mask & flagmask)
50 DPRINTF("%s ",flags[i].name);
54 void _dump_DDBLTFAST(DWORD flagmask) {
60 #define FE(x) { x, #x},
61 FE(DDBLTFAST_NOCOLORKEY)
62 FE(DDBLTFAST_SRCCOLORKEY)
63 FE(DDBLTFAST_DESTCOLORKEY)
67 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
68 if (flags[i].mask & flagmask)
69 DPRINTF("%s ",flags[i].name);
73 void _dump_DDBLT(DWORD flagmask) {
79 #define FE(x) { x, #x},
81 FE(DDBLT_ALPHADESTCONSTOVERRIDE)
82 FE(DDBLT_ALPHADESTNEG)
83 FE(DDBLT_ALPHADESTSURFACEOVERRIDE)
84 FE(DDBLT_ALPHAEDGEBLEND)
86 FE(DDBLT_ALPHASRCCONSTOVERRIDE)
88 FE(DDBLT_ALPHASRCSURFACEOVERRIDE)
94 FE(DDBLT_KEYDESTOVERRIDE)
96 FE(DDBLT_KEYSRCOVERRIDE)
98 FE(DDBLT_ROTATIONANGLE)
100 FE(DDBLT_ZBUFFERDESTCONSTOVERRIDE)
101 FE(DDBLT_ZBUFFERDESTOVERRIDE)
102 FE(DDBLT_ZBUFFERSRCCONSTOVERRIDE)
103 FE(DDBLT_ZBUFFERSRCOVERRIDE)
108 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
109 if (flags[i].mask & flagmask)
110 DPRINTF("%s ",flags[i].name);
114 void _dump_DDSCAPS(void *in) {
120 #define FE(x) { x, #x},
121 FE(DDSCAPS_RESERVED1)
123 FE(DDSCAPS_BACKBUFFER)
126 FE(DDSCAPS_FRONTBUFFER)
127 FE(DDSCAPS_OFFSCREENPLAIN)
130 FE(DDSCAPS_PRIMARYSURFACE)
131 FE(DDSCAPS_PRIMARYSURFACELEFT)
132 FE(DDSCAPS_SYSTEMMEMORY)
135 FE(DDSCAPS_VIDEOMEMORY)
137 FE(DDSCAPS_WRITEONLY)
140 FE(DDSCAPS_LIVEVIDEO)
144 FE(DDSCAPS_RESERVED2)
145 FE(DDSCAPS_ALLOCONLOAD)
146 FE(DDSCAPS_VIDEOPORT)
147 FE(DDSCAPS_LOCALVIDMEM)
148 FE(DDSCAPS_NONLOCALVIDMEM)
149 FE(DDSCAPS_STANDARDVGAMODE)
150 FE(DDSCAPS_OPTIMIZED)
153 DWORD flagmask = *((DWORD *) in);
154 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
155 if (flags[i].mask & flagmask)
156 DPRINTF("%s ",flags[i].name);
159 void _dump_pixelformat_flag(DWORD flagmask) {
165 #define FE(x) { x, #x},
169 FE(DDPF_PALETTEINDEXED4)
170 FE(DDPF_PALETTEINDEXEDTO8)
171 FE(DDPF_PALETTEINDEXED8)
177 FE(DDPF_PALETTEINDEXED1)
178 FE(DDPF_PALETTEINDEXED2)
182 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
183 if (flags[i].mask & flagmask)
184 DPRINTF("%s ",flags[i].name);
187 void _dump_paletteformat(DWORD dwFlags) {
193 #define FE(x) { x, #x},
195 FE(DDPCAPS_8BITENTRIES)
197 FE(DDPCAPS_INITIALIZE)
198 FE(DDPCAPS_PRIMARYSURFACE)
199 FE(DDPCAPS_PRIMARYSURFACELEFT)
207 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
208 if (flags[i].mask & dwFlags)
209 DPRINTF("%s ",flags[i].name);
213 void _dump_pixelformat(void *in) {
214 LPDDPIXELFORMAT pf = (LPDDPIXELFORMAT) in;
217 _dump_pixelformat_flag(pf->dwFlags);
218 if (pf->dwFlags & DDPF_FOURCC) {
219 DPRINTF(", dwFourCC : %c%c%c%c",
220 (unsigned char)((pf->dwFourCC>>24)&0xff),
221 (unsigned char)((pf->dwFourCC>>16)&0xff),
222 (unsigned char)((pf->dwFourCC>> 8)&0xff),
223 (unsigned char)( pf->dwFourCC &0xff)
226 if (pf->dwFlags & DDPF_RGB) {
228 DPRINTF(", RGB bits: %ld, ", pf->u.dwRGBBitCount);
229 switch (pf->u.dwRGBBitCount) {
230 case 4: cmd = "%1lx"; break;
231 case 8: cmd = "%02lx"; break;
232 case 16: cmd = "%04lx"; break;
233 case 24: cmd = "%06lx"; break;
234 case 32: cmd = "%08lx"; break;
235 default: ERR("Unexpected bit depth !\n"); cmd = "%d"; break;
237 DPRINTF(" R "); DPRINTF(cmd, pf->u1.dwRBitMask);
238 DPRINTF(" G "); DPRINTF(cmd, pf->u2.dwGBitMask);
239 DPRINTF(" B "); DPRINTF(cmd, pf->u3.dwBBitMask);
240 if (pf->dwFlags & DDPF_ALPHAPIXELS) {
241 DPRINTF(" A "); DPRINTF(cmd, pf->u4.dwRGBAlphaBitMask);
243 if (pf->dwFlags & DDPF_ZPIXELS) {
244 DPRINTF(" Z "); DPRINTF(cmd, pf->u4.dwRGBZBitMask);
247 if (pf->dwFlags & DDPF_ZBUFFER) {
248 DPRINTF(", Z bits : %ld", pf->u.dwZBufferBitDepth);
250 if (pf->dwFlags & DDPF_ALPHA) {
251 DPRINTF(", Alpha bits : %ld", pf->u.dwAlphaBitDepth);
256 void _dump_colorkeyflag(DWORD ck) {
262 #define FE(x) { x, #x},
263 FE(DDCKEY_COLORSPACE)
265 FE(DDCKEY_DESTOVERLAY)
267 FE(DDCKEY_SRCOVERLAY)
270 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
271 if (flags[i].mask & ck)
272 DPRINTF("%s ",flags[i].name);
275 static void _dump_DWORD(void *in) {
276 DPRINTF("%ld", *((DWORD *) in));
278 static void _dump_PTR(void *in) {
279 DPRINTF("%p", *((void **) in));
281 void _dump_DDCOLORKEY(void *in) {
282 DDCOLORKEY *ddck = (DDCOLORKEY *) in;
284 DPRINTF(" Low : %ld - High : %ld", ddck->dwColorSpaceLowValue, ddck->dwColorSpaceHighValue);
287 void _dump_surface_desc(DDSURFACEDESC *lpddsd) {
292 void (*func)(void *);
294 } flags[16], *fe = flags;
295 #define FE(x,f,e) do { fe->mask = x; fe->name = #x; fe->func = f; fe->elt = (void *) &(lpddsd->e); fe++; } while(0)
296 FE(DDSD_CAPS, _dump_DDSCAPS, ddsCaps);
297 FE(DDSD_HEIGHT, _dump_DWORD, dwHeight);
298 FE(DDSD_WIDTH, _dump_DWORD, dwWidth);
299 FE(DDSD_PITCH, _dump_DWORD, lPitch);
300 FE(DDSD_BACKBUFFERCOUNT, _dump_DWORD, dwBackBufferCount);
301 FE(DDSD_ZBUFFERBITDEPTH, _dump_DWORD, u.dwZBufferBitDepth);
302 FE(DDSD_ALPHABITDEPTH, _dump_DWORD, dwAlphaBitDepth);
303 FE(DDSD_PIXELFORMAT, _dump_pixelformat, ddpfPixelFormat);
304 FE(DDSD_CKDESTOVERLAY, _dump_DDCOLORKEY, ddckCKDestOverlay);
305 FE(DDSD_CKDESTBLT, _dump_DDCOLORKEY, ddckCKDestBlt);
306 FE(DDSD_CKSRCOVERLAY, _dump_DDCOLORKEY, ddckCKSrcOverlay);
307 FE(DDSD_CKSRCBLT, _dump_DDCOLORKEY, ddckCKSrcBlt);
308 FE(DDSD_MIPMAPCOUNT, _dump_DWORD, u.dwMipMapCount);
309 FE(DDSD_REFRESHRATE, _dump_DWORD, u.dwRefreshRate);
310 FE(DDSD_LINEARSIZE, _dump_DWORD, u1.dwLinearSize);
311 FE(DDSD_LPSURFACE, _dump_PTR, u1.lpSurface);
314 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
315 if (flags[i].mask & lpddsd->dwFlags) {
316 DPRINTF(" - %s : ",flags[i].name);
317 flags[i].func(flags[i].elt);
321 void _dump_cooperativelevel(DWORD cooplevel) {
327 #define FE(x) { x, #x},
329 FE(DDSCL_ALLOWREBOOT)
330 FE(DDSCL_NOWINDOWCHANGES)
334 FE(DDSCL_SETFOCUSWINDOW)
335 FE(DDSCL_SETDEVICEWINDOW)
336 FE(DDSCL_CREATEDEVICEWINDOW)
340 if (TRACE_ON(ddraw)) {
342 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
343 if (flags[i].mask & cooplevel)
344 DPRINTF("%s ",flags[i].name);