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
);