blob: 07ed51f5abe97a2c956570358d96825043e78ac5 [file] [log] [blame]
Gareth Hughes22144ab2001-03-12 00:48:37 +00001/*
2 * Mesa 3-D graphics library
Brian Paula96f8892005-09-13 01:19:29 +00003 * Version: 6.5
Gareth Hughes22144ab2001-03-12 00:48:37 +00004 *
Brian Paula96f8892005-09-13 01:19:29 +00005 * Copyright (C) 1999-2005 Brian Paul All Rights Reserved.
Brian Paul8ee6ab62009-04-22 15:02:01 -06006 * Copyright (C) 2009 VMware, Inc. All Rights Reserved.
Gareth Hughes22144ab2001-03-12 00:48:37 +00007 *
8 * Permission is hereby granted, free of charge, to any person obtaining a
9 * copy of this software and associated documentation files (the "Software"),
10 * to deal in the Software without restriction, including without limitation
11 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
12 * and/or sell copies of the Software, and to permit persons to whom the
13 * Software is furnished to do so, subject to the following conditions:
14 *
15 * The above copyright notice and this permission notice shall be included
16 * in all copies or substantial portions of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
21 * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
22 * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
23 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
24 */
25
Jouk Jansen5e3bc0c2000-11-22 07:32:16 +000026#include "mtypes.h"
Brian Paul185fbcc2009-06-04 14:26:51 -060027#include "attrib.h"
Brian Paul433f2ab2009-03-02 17:52:30 -070028#include "colormac.h"
Brian Paul4e9676f2002-06-29 19:48:15 +000029#include "context.h"
Brian Paul266fe932009-02-07 11:49:52 -070030#include "hash.h"
Brian Paul3c634522002-10-24 23:57:19 +000031#include "imports.h"
Keith Whitwell23caf202000-11-16 21:05:34 +000032#include "debug.h"
Keith Whitwell6dc85572003-07-17 13:43:59 +000033#include "get.h"
Brian Paul185fbcc2009-06-04 14:26:51 -060034#include "pixelstore.h"
35#include "readpix.h"
Brian Paulb98f0f22009-08-04 15:04:37 -060036#include "texgetimage.h"
Brian Paul266fe932009-02-07 11:49:52 -070037#include "texobj.h"
38#include "texformat.h"
39
Keith Whitwell23caf202000-11-16 21:05:34 +000040
Keith Whitwell6dc85572003-07-17 13:43:59 +000041/**
42 * Primitive names
43 */
44const char *_mesa_prim_name[GL_POLYGON+4] = {
45 "GL_POINTS",
46 "GL_LINES",
47 "GL_LINE_LOOP",
48 "GL_LINE_STRIP",
49 "GL_TRIANGLES",
50 "GL_TRIANGLE_STRIP",
51 "GL_TRIANGLE_FAN",
52 "GL_QUADS",
53 "GL_QUAD_STRIP",
54 "GL_POLYGON",
55 "outside begin/end",
56 "inside unkown primitive",
57 "unknown state"
58};
Brian Paul3c634522002-10-24 23:57:19 +000059
60void
61_mesa_print_state( const char *msg, GLuint state )
Keith Whitwell23caf202000-11-16 21:05:34 +000062{
Brian Paul4e9676f2002-06-29 19:48:15 +000063 _mesa_debug(NULL,
Keith Whitwell3d5815f2001-03-29 17:08:26 +000064 "%s: (0x%x) %s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s%s\n",
Keith Whitwell23caf202000-11-16 21:05:34 +000065 msg,
66 state,
67 (state & _NEW_MODELVIEW) ? "ctx->ModelView, " : "",
68 (state & _NEW_PROJECTION) ? "ctx->Projection, " : "",
69 (state & _NEW_TEXTURE_MATRIX) ? "ctx->TextureMatrix, " : "",
70 (state & _NEW_COLOR_MATRIX) ? "ctx->ColorMatrix, " : "",
71 (state & _NEW_ACCUM) ? "ctx->Accum, " : "",
72 (state & _NEW_COLOR) ? "ctx->Color, " : "",
73 (state & _NEW_DEPTH) ? "ctx->Depth, " : "",
74 (state & _NEW_EVAL) ? "ctx->Eval/EvalMap, " : "",
75 (state & _NEW_FOG) ? "ctx->Fog, " : "",
76 (state & _NEW_HINT) ? "ctx->Hint, " : "",
77 (state & _NEW_LIGHT) ? "ctx->Light, " : "",
78 (state & _NEW_LINE) ? "ctx->Line, " : "",
Keith Whitwell23caf202000-11-16 21:05:34 +000079 (state & _NEW_PIXEL) ? "ctx->Pixel, " : "",
80 (state & _NEW_POINT) ? "ctx->Point, " : "",
81 (state & _NEW_POLYGON) ? "ctx->Polygon, " : "",
82 (state & _NEW_POLYGONSTIPPLE) ? "ctx->PolygonStipple, " : "",
83 (state & _NEW_SCISSOR) ? "ctx->Scissor, " : "",
84 (state & _NEW_TEXTURE) ? "ctx->Texture, " : "",
85 (state & _NEW_TRANSFORM) ? "ctx->Transform, " : "",
86 (state & _NEW_VIEWPORT) ? "ctx->Viewport, " : "",
87 (state & _NEW_PACKUNPACK) ? "ctx->Pack/Unpack, " : "",
88 (state & _NEW_ARRAY) ? "ctx->Array, " : "",
Keith Whitwell23caf202000-11-16 21:05:34 +000089 (state & _NEW_RENDERMODE) ? "ctx->RenderMode, " : "",
90 (state & _NEW_BUFFERS) ? "ctx->Visual, ctx->DrawBuffer,, " : "");
91}
92
93
Keith Whitwell23caf202000-11-16 21:05:34 +000094
Brian Paul3c634522002-10-24 23:57:19 +000095void
96_mesa_print_tri_caps( const char *name, GLuint flags )
Keith Whitwell23caf202000-11-16 21:05:34 +000097{
Brian Paul4e9676f2002-06-29 19:48:15 +000098 _mesa_debug(NULL,
Daniel Borca885f1072004-11-12 10:23:10 +000099 "%s: (0x%x) %s%s%s%s%s%s%s%s%s%s%s%s%s%s%s\n",
Keith Whitwell23caf202000-11-16 21:05:34 +0000100 name,
101 flags,
Keith Whitwell23caf202000-11-16 21:05:34 +0000102 (flags & DD_FLATSHADE) ? "flat-shade, " : "",
Brian Paulee403ff2001-03-29 16:50:31 +0000103 (flags & DD_SEPARATE_SPECULAR) ? "separate-specular, " : "",
Keith Whitwell23caf202000-11-16 21:05:34 +0000104 (flags & DD_TRI_LIGHT_TWOSIDE) ? "tri-light-twoside, " : "",
Daniel Borca885f1072004-11-12 10:23:10 +0000105 (flags & DD_TRI_TWOSTENCIL) ? "tri-twostencil, " : "",
Keith Whitwell23caf202000-11-16 21:05:34 +0000106 (flags & DD_TRI_UNFILLED) ? "tri-unfilled, " : "",
107 (flags & DD_TRI_STIPPLE) ? "tri-stipple, " : "",
108 (flags & DD_TRI_OFFSET) ? "tri-offset, " : "",
Keith Whitwell23caf202000-11-16 21:05:34 +0000109 (flags & DD_TRI_SMOOTH) ? "tri-smooth, " : "",
110 (flags & DD_LINE_SMOOTH) ? "line-smooth, " : "",
111 (flags & DD_LINE_STIPPLE) ? "line-stipple, " : "",
112 (flags & DD_LINE_WIDTH) ? "line-wide, " : "",
Jouk Jansen5e3bc0c2000-11-22 07:32:16 +0000113 (flags & DD_POINT_SMOOTH) ? "point-smooth, " : "",
114 (flags & DD_POINT_SIZE) ? "point-size, " : "",
115 (flags & DD_POINT_ATTEN) ? "point-atten, " : "",
Keith Whitwell3d5815f2001-03-29 17:08:26 +0000116 (flags & DD_TRI_CULL_FRONT_BACK) ? "cull-all, " : ""
Keith Whitwell23caf202000-11-16 21:05:34 +0000117 );
118}
Keith Whitwell6dc85572003-07-17 13:43:59 +0000119
120
Keith Whitwell6dc85572003-07-17 13:43:59 +0000121/**
122 * Print information about this Mesa version and build options.
123 */
124void _mesa_print_info( void )
125{
126 _mesa_debug(NULL, "Mesa GL_VERSION = %s\n",
127 (char *) _mesa_GetString(GL_VERSION));
128 _mesa_debug(NULL, "Mesa GL_RENDERER = %s\n",
129 (char *) _mesa_GetString(GL_RENDERER));
130 _mesa_debug(NULL, "Mesa GL_VENDOR = %s\n",
131 (char *) _mesa_GetString(GL_VENDOR));
132 _mesa_debug(NULL, "Mesa GL_EXTENSIONS = %s\n",
133 (char *) _mesa_GetString(GL_EXTENSIONS));
134#if defined(THREADS)
135 _mesa_debug(NULL, "Mesa thread-safe: YES\n");
136#else
137 _mesa_debug(NULL, "Mesa thread-safe: NO\n");
138#endif
139#if defined(USE_X86_ASM)
140 _mesa_debug(NULL, "Mesa x86-optimized: YES\n");
141#else
142 _mesa_debug(NULL, "Mesa x86-optimized: NO\n");
143#endif
144#if defined(USE_SPARC_ASM)
145 _mesa_debug(NULL, "Mesa sparc-optimized: YES\n");
146#else
147 _mesa_debug(NULL, "Mesa sparc-optimized: NO\n");
148#endif
149}
150
151
152/**
153 * Set the debugging flags.
154 *
155 * \param debug debug string
156 *
157 * If compiled with debugging support then search for keywords in \p debug and
158 * enables the verbose debug output of the respective feature.
159 */
160static void add_debug_flags( const char *debug )
161{
Brian Paul1984aab2005-11-10 05:10:25 +0000162#ifdef DEBUG
Brian Paul131d4252008-11-01 10:57:25 -0600163 struct debug_option {
164 const char *name;
165 GLbitfield flag;
166 };
167 static const struct debug_option debug_opt[] = {
168 { "varray", VERBOSE_VARRAY },
169 { "tex", VERBOSE_TEXTURE },
Brian Pauld9099f82009-10-14 15:46:25 -0600170 { "mat", VERBOSE_MATERIAL },
Brian Paul131d4252008-11-01 10:57:25 -0600171 { "pipe", VERBOSE_PIPELINE },
172 { "driver", VERBOSE_DRIVER },
173 { "state", VERBOSE_STATE },
174 { "api", VERBOSE_API },
175 { "list", VERBOSE_DISPLAY_LIST },
176 { "lighting", VERBOSE_LIGHTING },
Brian Paulade1cc92009-10-14 16:23:22 -0600177 { "disassem", VERBOSE_DISASSEM },
178 { "draw", VERBOSE_DRAW }
Brian Paul131d4252008-11-01 10:57:25 -0600179 };
180 GLuint i;
Keith Whitwell6dc85572003-07-17 13:43:59 +0000181
Brian Paul131d4252008-11-01 10:57:25 -0600182 MESA_VERBOSE = 0x0;
183 for (i = 0; i < Elements(debug_opt); i++) {
184 if (_mesa_strstr(debug, debug_opt[i].name))
185 MESA_VERBOSE |= debug_opt[i].flag;
186 }
Keith Whitwell6dc85572003-07-17 13:43:59 +0000187
Keith Whitwell6dc85572003-07-17 13:43:59 +0000188 /* Debug flag:
189 */
190 if (_mesa_strstr(debug, "flush"))
191 MESA_DEBUG_FLAGS |= DEBUG_ALWAYS_FLUSH;
Brian Paul1984aab2005-11-10 05:10:25 +0000192
193#if defined(_FPU_GETCW) && defined(_FPU_SETCW)
194 if (_mesa_strstr(debug, "fpexceptions")) {
195 /* raise FP exceptions */
196 fpu_control_t mask;
197 _FPU_GETCW(mask);
198 mask &= ~(_FPU_MASK_IM | _FPU_MASK_DM | _FPU_MASK_ZM
199 | _FPU_MASK_OM | _FPU_MASK_UM);
200 _FPU_SETCW(mask);
201 }
202#endif
203
Brian Paula6c423d2004-08-25 15:59:48 +0000204#else
205 (void) debug;
Keith Whitwell6dc85572003-07-17 13:43:59 +0000206#endif
207}
208
209
210void
211_mesa_init_debug( GLcontext *ctx )
212{
213 char *c;
214
Keith Whitwell6dc85572003-07-17 13:43:59 +0000215 /* Dither disable */
216 ctx->NoDither = _mesa_getenv("MESA_NO_DITHER") ? GL_TRUE : GL_FALSE;
217 if (ctx->NoDither) {
218 if (_mesa_getenv("MESA_DEBUG")) {
219 _mesa_debug(ctx, "MESA_NO_DITHER set - dithering disabled\n");
220 }
221 ctx->Color.DitherFlag = GL_FALSE;
222 }
223
224 c = _mesa_getenv("MESA_DEBUG");
225 if (c)
226 add_debug_flags(c);
227
228 c = _mesa_getenv("MESA_VERBOSE");
229 if (c)
230 add_debug_flags(c);
231}
232
Brian Paul266fe932009-02-07 11:49:52 -0700233
234/*
235 * Write ppm file
236 */
237static void
238write_ppm(const char *filename, const GLubyte *buffer, int width, int height,
Brian Paulb98f0f22009-08-04 15:04:37 -0600239 int comps, int rcomp, int gcomp, int bcomp, GLboolean invert)
Brian Paul266fe932009-02-07 11:49:52 -0700240{
241 FILE *f = fopen( filename, "w" );
242 if (f) {
Brian Paulb98f0f22009-08-04 15:04:37 -0600243 int x, y;
Brian Paul266fe932009-02-07 11:49:52 -0700244 const GLubyte *ptr = buffer;
245 fprintf(f,"P6\n");
246 fprintf(f,"# ppm-file created by osdemo.c\n");
247 fprintf(f,"%i %i\n", width,height);
248 fprintf(f,"255\n");
249 fclose(f);
250 f = fopen( filename, "ab" ); /* reopen in binary append mode */
Brian Paulb98f0f22009-08-04 15:04:37 -0600251 for (y=0; y < height; y++) {
252 for (x = 0; x < width; x++) {
253 int yy = invert ? (height - 1 - y) : y;
254 int i = (yy * width + x) * comps;
255 fputc(ptr[i+rcomp], f); /* write red */
Brian Paul266fe932009-02-07 11:49:52 -0700256 fputc(ptr[i+gcomp], f); /* write green */
257 fputc(ptr[i+bcomp], f); /* write blue */
258 }
259 }
260 fclose(f);
261 }
262}
263
264
265/**
266 * Write level[0] image to a ppm file.
267 */
268static void
Brian Paulb98f0f22009-08-04 15:04:37 -0600269write_texture_image(struct gl_texture_object *texObj, GLuint face, GLuint level)
Brian Paul266fe932009-02-07 11:49:52 -0700270{
Brian Paulb98f0f22009-08-04 15:04:37 -0600271 struct gl_texture_image *img = texObj->Image[face][level];
272 if (img) {
273 GET_CURRENT_CONTEXT(ctx);
274 struct gl_pixelstore_attrib store;
275 GLubyte *buffer;
Brian Paul266fe932009-02-07 11:49:52 -0700276 char s[100];
277
Brian Paulb98f0f22009-08-04 15:04:37 -0600278 buffer = (GLubyte *) _mesa_malloc(img->Width * img->Height
279 * img->Depth * 4);
Brian Paul266fe932009-02-07 11:49:52 -0700280
Brian Paulb98f0f22009-08-04 15:04:37 -0600281 store = ctx->Pack; /* save */
282 ctx->Pack = ctx->DefaultPacking;
283
284 ctx->Driver.GetTexImage(ctx, texObj->Target, level,
285 GL_RGBA, GL_UNSIGNED_BYTE,
286 buffer, texObj, img);
287
288 /* make filename */
289 _mesa_sprintf(s, "/tmp/teximage%u.ppm", texObj->Name);
290
291 _mesa_printf(" Writing image level %u to %s\n", level, s);
292 write_ppm(s, buffer, img->Width, img->Height, 4, 0, 1, 2, GL_FALSE);
293
294 ctx->Pack = store; /* restore */
295
296 _mesa_free(buffer);
Brian Paul266fe932009-02-07 11:49:52 -0700297 }
298}
299
300
301static GLboolean DumpImages;
302
303
304static void
305dump_texture_cb(GLuint id, void *data, void *userData)
306{
307 struct gl_texture_object *texObj = (struct gl_texture_object *) data;
Brian Paul266fe932009-02-07 11:49:52 -0700308 int i;
Brian Paulb98f0f22009-08-04 15:04:37 -0600309 GLboolean written = GL_FALSE;
José Fonseca8cadf6c2009-02-11 13:50:43 +0000310 (void) userData;
Brian Paul266fe932009-02-07 11:49:52 -0700311
Brian Paulb98f0f22009-08-04 15:04:37 -0600312 _mesa_printf("Texture %u\n", texObj->Name);
313 _mesa_printf(" Target 0x%x\n", texObj->Target);
Brian Paul266fe932009-02-07 11:49:52 -0700314 for (i = 0; i < MAX_TEXTURE_LEVELS; i++) {
315 struct gl_texture_image *texImg = texObj->Image[0][i];
316 if (texImg) {
Brian Paulb98f0f22009-08-04 15:04:37 -0600317 _mesa_printf(" Image %u: %d x %d x %d, format %u at %p\n", i,
318 texImg->Width, texImg->Height, texImg->Depth,
319 texImg->TexFormat->MesaFormat, texImg->Data);
320 if (DumpImages && !written) {
321 GLuint face = 0;
322 write_texture_image(texObj, face, i);
323 written = GL_TRUE;
Brian Paul266fe932009-02-07 11:49:52 -0700324 }
325 }
326 }
327}
328
329
330/**
331 * Print basic info about all texture objext to stdout.
332 * If dumpImages is true, write PPM of level[0] image to a file.
333 */
334void
335_mesa_dump_textures(GLboolean dumpImages)
336{
337 GET_CURRENT_CONTEXT(ctx);
338 DumpImages = dumpImages;
Brian Paul8ee6ab62009-04-22 15:02:01 -0600339 _mesa_HashWalk(ctx->Shared->TexObjects, dump_texture_cb, ctx);
Brian Paul266fe932009-02-07 11:49:52 -0700340}
Brian Paul02f73c432009-05-21 09:12:35 -0600341
342
343void
344_mesa_dump_color_buffer(const char *filename)
345{
346 GET_CURRENT_CONTEXT(ctx);
347 const GLuint w = ctx->DrawBuffer->Width;
348 const GLuint h = ctx->DrawBuffer->Height;
349 GLubyte *buf;
350
351 buf = (GLubyte *) _mesa_malloc(w * h * 4);
352
Brian Paul185fbcc2009-06-04 14:26:51 -0600353 _mesa_PushClientAttrib(GL_CLIENT_PIXEL_STORE_BIT);
354 _mesa_PixelStorei(GL_PACK_ALIGNMENT, 1);
355 _mesa_PixelStorei(GL_PACK_INVERT_MESA, GL_TRUE);
Brian Paul02f73c432009-05-21 09:12:35 -0600356
Brian Paul185fbcc2009-06-04 14:26:51 -0600357 _mesa_ReadPixels(0, 0, w, h, GL_RGBA, GL_UNSIGNED_BYTE, buf);
Brian Paul02f73c432009-05-21 09:12:35 -0600358
359 _mesa_printf("ReadBuffer %p 0x%x DrawBuffer %p 0x%x\n",
360 ctx->ReadBuffer->_ColorReadBuffer,
361 ctx->ReadBuffer->ColorReadBuffer,
362 ctx->DrawBuffer->_ColorDrawBuffers[0],
363 ctx->DrawBuffer->ColorDrawBuffer[0]);
364 _mesa_printf("Writing %d x %d color buffer to %s\n", w, h, filename);
Brian Paulb98f0f22009-08-04 15:04:37 -0600365 write_ppm(filename, buf, w, h, 4, 0, 1, 2, GL_TRUE);
Brian Paul02f73c432009-05-21 09:12:35 -0600366
Brian Paul185fbcc2009-06-04 14:26:51 -0600367 _mesa_PopClientAttrib();
Brian Paul02f73c432009-05-21 09:12:35 -0600368
369 _mesa_free(buf);
370}
371
372
373void
374_mesa_dump_depth_buffer(const char *filename)
375{
376 GET_CURRENT_CONTEXT(ctx);
377 const GLuint w = ctx->DrawBuffer->Width;
378 const GLuint h = ctx->DrawBuffer->Height;
379 GLuint *buf;
380 GLubyte *buf2;
381 GLuint i;
382
383 buf = (GLuint *) _mesa_malloc(w * h * 4); /* 4 bpp */
384 buf2 = (GLubyte *) _mesa_malloc(w * h * 3); /* 3 bpp */
385
Brian Paul185fbcc2009-06-04 14:26:51 -0600386 _mesa_PushClientAttrib(GL_CLIENT_PIXEL_STORE_BIT);
387 _mesa_PixelStorei(GL_PACK_ALIGNMENT, 1);
388 _mesa_PixelStorei(GL_PACK_INVERT_MESA, GL_TRUE);
Brian Paul02f73c432009-05-21 09:12:35 -0600389
Brian Paul185fbcc2009-06-04 14:26:51 -0600390 _mesa_ReadPixels(0, 0, w, h, GL_DEPTH_COMPONENT, GL_UNSIGNED_INT, buf);
Brian Paul02f73c432009-05-21 09:12:35 -0600391
392 /* spread 24 bits of Z across R, G, B */
393 for (i = 0; i < w * h; i++) {
394 buf2[i*3+0] = (buf[i] >> 24) & 0xff;
395 buf2[i*3+1] = (buf[i] >> 16) & 0xff;
396 buf2[i*3+2] = (buf[i] >> 8) & 0xff;
397 }
398
399 _mesa_printf("Writing %d x %d depth buffer to %s\n", w, h, filename);
Brian Paulb98f0f22009-08-04 15:04:37 -0600400 write_ppm(filename, buf2, w, h, 3, 0, 1, 2, GL_TRUE);
Brian Paul02f73c432009-05-21 09:12:35 -0600401
Brian Paul185fbcc2009-06-04 14:26:51 -0600402 _mesa_PopClientAttrib();
Brian Paul02f73c432009-05-21 09:12:35 -0600403
404 _mesa_free(buf);
405 _mesa_free(buf2);
406}
407
408
409void
410_mesa_dump_stencil_buffer(const char *filename)
411{
412 GET_CURRENT_CONTEXT(ctx);
413 const GLuint w = ctx->DrawBuffer->Width;
414 const GLuint h = ctx->DrawBuffer->Height;
415 GLubyte *buf;
416 GLubyte *buf2;
417 GLuint i;
418
419 buf = (GLubyte *) _mesa_malloc(w * h); /* 1 bpp */
420 buf2 = (GLubyte *) _mesa_malloc(w * h * 3); /* 3 bpp */
421
Brian Paul185fbcc2009-06-04 14:26:51 -0600422 _mesa_PushClientAttrib(GL_CLIENT_PIXEL_STORE_BIT);
423 _mesa_PixelStorei(GL_PACK_ALIGNMENT, 1);
424 _mesa_PixelStorei(GL_PACK_INVERT_MESA, GL_TRUE);
Brian Paul02f73c432009-05-21 09:12:35 -0600425
Brian Paul185fbcc2009-06-04 14:26:51 -0600426 _mesa_ReadPixels(0, 0, w, h, GL_STENCIL_INDEX, GL_UNSIGNED_BYTE, buf);
Brian Paul02f73c432009-05-21 09:12:35 -0600427
428 for (i = 0; i < w * h; i++) {
429 buf2[i*3+0] = buf[i];
430 buf2[i*3+1] = (buf[i] & 127) * 2;
431 buf2[i*3+2] = (buf[i] - 128) * 2;
432 }
433
434 _mesa_printf("Writing %d x %d stencil buffer to %s\n", w, h, filename);
Brian Paulb98f0f22009-08-04 15:04:37 -0600435 write_ppm(filename, buf2, w, h, 3, 0, 1, 2, GL_TRUE);
Brian Paul02f73c432009-05-21 09:12:35 -0600436
Brian Paul185fbcc2009-06-04 14:26:51 -0600437 _mesa_PopClientAttrib();
Brian Paul02f73c432009-05-21 09:12:35 -0600438
439 _mesa_free(buf);
440 _mesa_free(buf2);
441}