2 /* DirectDraw Base Functions
4 * Copyright 1997-1999 Marcus Meissner
5 * Copyright 1998 Lionel Ulmer (most of Direct3D stuff)
22 #include "wine/exception.h"
25 #include "debugtools.h"
31 DEFAULT_DEBUG_CHANNEL(ddraw);
33 /******************************************************************************
34 * debug output functions
36 void _dump_DDBLTFX(DWORD flagmask) {
42 #define FE(x) { x, #x},
43 FE(DDBLTFX_ARITHSTRETCHY)
44 FE(DDBLTFX_MIRRORLEFTRIGHT)
45 FE(DDBLTFX_MIRRORUPDOWN)
50 FE(DDBLTFX_ZBUFFERRANGE)
51 FE(DDBLTFX_ZBUFFERBASEDEST)
54 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
55 if (flags[i].mask & flagmask)
56 DPRINTF("%s ",flags[i].name);
60 void _dump_DDBLTFAST(DWORD flagmask) {
66 #define FE(x) { x, #x},
67 FE(DDBLTFAST_NOCOLORKEY)
68 FE(DDBLTFAST_SRCCOLORKEY)
69 FE(DDBLTFAST_DESTCOLORKEY)
73 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
74 if (flags[i].mask & flagmask)
75 DPRINTF("%s ",flags[i].name);
79 void _dump_DDBLT(DWORD flagmask) {
85 #define FE(x) { x, #x},
87 FE(DDBLT_ALPHADESTCONSTOVERRIDE)
88 FE(DDBLT_ALPHADESTNEG)
89 FE(DDBLT_ALPHADESTSURFACEOVERRIDE)
90 FE(DDBLT_ALPHAEDGEBLEND)
92 FE(DDBLT_ALPHASRCCONSTOVERRIDE)
94 FE(DDBLT_ALPHASRCSURFACEOVERRIDE)
100 FE(DDBLT_KEYDESTOVERRIDE)
102 FE(DDBLT_KEYSRCOVERRIDE)
104 FE(DDBLT_ROTATIONANGLE)
106 FE(DDBLT_ZBUFFERDESTCONSTOVERRIDE)
107 FE(DDBLT_ZBUFFERDESTOVERRIDE)
108 FE(DDBLT_ZBUFFERSRCCONSTOVERRIDE)
109 FE(DDBLT_ZBUFFERSRCOVERRIDE)
114 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
115 if (flags[i].mask & flagmask)
116 DPRINTF("%s ",flags[i].name);
120 void _dump_DDSCAPS(void *in) {
126 #define FE(x) { x, #x},
127 FE(DDSCAPS_RESERVED1)
129 FE(DDSCAPS_BACKBUFFER)
132 FE(DDSCAPS_FRONTBUFFER)
133 FE(DDSCAPS_OFFSCREENPLAIN)
136 FE(DDSCAPS_PRIMARYSURFACE)
137 FE(DDSCAPS_PRIMARYSURFACELEFT)
138 FE(DDSCAPS_SYSTEMMEMORY)
141 FE(DDSCAPS_VIDEOMEMORY)
143 FE(DDSCAPS_WRITEONLY)
146 FE(DDSCAPS_LIVEVIDEO)
150 FE(DDSCAPS_RESERVED2)
151 FE(DDSCAPS_ALLOCONLOAD)
152 FE(DDSCAPS_VIDEOPORT)
153 FE(DDSCAPS_LOCALVIDMEM)
154 FE(DDSCAPS_NONLOCALVIDMEM)
155 FE(DDSCAPS_STANDARDVGAMODE)
156 FE(DDSCAPS_OPTIMIZED)
159 DWORD flagmask = *((DWORD *) in);
160 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
161 if (flags[i].mask & flagmask)
162 DPRINTF("%s ",flags[i].name);
165 void _dump_pixelformat_flag(DWORD flagmask) {
171 #define FE(x) { x, #x},
175 FE(DDPF_PALETTEINDEXED4)
176 FE(DDPF_PALETTEINDEXEDTO8)
177 FE(DDPF_PALETTEINDEXED8)
183 FE(DDPF_PALETTEINDEXED1)
184 FE(DDPF_PALETTEINDEXED2)
188 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
189 if (flags[i].mask & flagmask)
190 DPRINTF("%s ",flags[i].name);
193 void _dump_paletteformat(DWORD dwFlags) {
199 #define FE(x) { x, #x},
201 FE(DDPCAPS_8BITENTRIES)
203 FE(DDPCAPS_INITIALIZE)
204 FE(DDPCAPS_PRIMARYSURFACE)
205 FE(DDPCAPS_PRIMARYSURFACELEFT)
213 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
214 if (flags[i].mask & dwFlags)
215 DPRINTF("%s ",flags[i].name);
219 void _dump_pixelformat(void *in) {
220 LPDDPIXELFORMAT pf = (LPDDPIXELFORMAT) in;
223 _dump_pixelformat_flag(pf->dwFlags);
224 if (pf->dwFlags & DDPF_FOURCC) {
225 DPRINTF(", dwFourCC : %c%c%c%c",
226 (unsigned char)((pf->dwFourCC>>24)&0xff),
227 (unsigned char)((pf->dwFourCC>>16)&0xff),
228 (unsigned char)((pf->dwFourCC>> 8)&0xff),
229 (unsigned char)( pf->dwFourCC &0xff)
232 if (pf->dwFlags & DDPF_RGB) {
234 DPRINTF(", RGB bits: %ld, ", pf->u.dwRGBBitCount);
235 switch (pf->u.dwRGBBitCount) {
236 case 4: cmd = "%1lx"; break;
237 case 8: cmd = "%02lx"; break;
238 case 16: cmd = "%04lx"; break;
239 case 24: cmd = "%06lx"; break;
240 case 32: cmd = "%08lx"; break;
241 default: ERR("Unexpected bit depth !\n"); cmd = "%d"; break;
243 DPRINTF(" R "); DPRINTF(cmd, pf->u1.dwRBitMask);
244 DPRINTF(" G "); DPRINTF(cmd, pf->u2.dwGBitMask);
245 DPRINTF(" B "); DPRINTF(cmd, pf->u3.dwBBitMask);
246 if (pf->dwFlags & DDPF_ALPHAPIXELS) {
247 DPRINTF(" A "); DPRINTF(cmd, pf->u4.dwRGBAlphaBitMask);
249 if (pf->dwFlags & DDPF_ZPIXELS) {
250 DPRINTF(" Z "); DPRINTF(cmd, pf->u4.dwRGBZBitMask);
253 if (pf->dwFlags & DDPF_ZBUFFER) {
254 DPRINTF(", Z bits : %ld", pf->u.dwZBufferBitDepth);
256 if (pf->dwFlags & DDPF_ALPHA) {
257 DPRINTF(", Alpha bits : %ld", pf->u.dwAlphaBitDepth);
262 void _dump_colorkeyflag(DWORD ck) {
268 #define FE(x) { x, #x},
269 FE(DDCKEY_COLORSPACE)
271 FE(DDCKEY_DESTOVERLAY)
273 FE(DDCKEY_SRCOVERLAY)
276 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
277 if (flags[i].mask & ck)
278 DPRINTF("%s ",flags[i].name);
281 static void _dump_DWORD(void *in) {
282 DPRINTF("%ld", *((DWORD *) in));
284 static void _dump_PTR(void *in) {
285 DPRINTF("%p", *((void **) in));
287 void _dump_DDCOLORKEY(void *in) {
288 DDCOLORKEY *ddck = (DDCOLORKEY *) in;
290 DPRINTF(" Low : %ld - High : %ld", ddck->dwColorSpaceLowValue, ddck->dwColorSpaceHighValue);
293 void _dump_surface_desc(DDSURFACEDESC *lpddsd) {
298 void (*func)(void *);
300 } flags[16], *fe = flags;
301 #define FE(x,f,e) do { fe->mask = x; fe->name = #x; fe->func = f; fe->elt = (void *) &(lpddsd->e); fe++; } while(0)
302 FE(DDSD_CAPS, _dump_DDSCAPS, ddsCaps);
303 FE(DDSD_HEIGHT, _dump_DWORD, dwHeight);
304 FE(DDSD_WIDTH, _dump_DWORD, dwWidth);
305 FE(DDSD_PITCH, _dump_DWORD, lPitch);
306 FE(DDSD_BACKBUFFERCOUNT, _dump_DWORD, dwBackBufferCount);
307 FE(DDSD_ZBUFFERBITDEPTH, _dump_DWORD, u.dwZBufferBitDepth);
308 FE(DDSD_ALPHABITDEPTH, _dump_DWORD, dwAlphaBitDepth);
309 FE(DDSD_PIXELFORMAT, _dump_pixelformat, ddpfPixelFormat);
310 FE(DDSD_CKDESTOVERLAY, _dump_DDCOLORKEY, ddckCKDestOverlay);
311 FE(DDSD_CKDESTBLT, _dump_DDCOLORKEY, ddckCKDestBlt);
312 FE(DDSD_CKSRCOVERLAY, _dump_DDCOLORKEY, ddckCKSrcOverlay);
313 FE(DDSD_CKSRCBLT, _dump_DDCOLORKEY, ddckCKSrcBlt);
314 FE(DDSD_MIPMAPCOUNT, _dump_DWORD, u.dwMipMapCount);
315 FE(DDSD_REFRESHRATE, _dump_DWORD, u.dwRefreshRate);
316 FE(DDSD_LINEARSIZE, _dump_DWORD, u1.dwLinearSize);
317 FE(DDSD_LPSURFACE, _dump_PTR, u1.lpSurface);
320 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
321 if (flags[i].mask & lpddsd->dwFlags) {
322 DPRINTF(" - %s : ",flags[i].name);
323 flags[i].func(flags[i].elt);
327 void _dump_cooperativelevel(DWORD cooplevel) {
333 #define FE(x) { x, #x},
335 FE(DDSCL_ALLOWREBOOT)
336 FE(DDSCL_NOWINDOWCHANGES)
340 FE(DDSCL_SETFOCUSWINDOW)
341 FE(DDSCL_SETDEVICEWINDOW)
342 FE(DDSCL_CREATEDEVICEWINDOW)
346 if (TRACE_ON(ddraw)) {
348 for (i=0;i<sizeof(flags)/sizeof(flags[0]);i++)
349 if (flags[i].mask & cooplevel)
350 DPRINTF("%s ",flags[i].name);