From b4497c58439455297440635b297e9c87b7904fdc Mon Sep 17 00:00:00 2001 From: Brian Paul Date: Wed, 13 Nov 2002 16:54:01 +0000 Subject: template code for span functions for flat, memory-based frame buffers --- src/mesa/swrast/s_spantemp.h | 366 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 366 insertions(+) create mode 100644 src/mesa/swrast/s_spantemp.h diff --git a/src/mesa/swrast/s_spantemp.h b/src/mesa/swrast/s_spantemp.h new file mode 100644 index 0000000000..d8efe98f41 --- /dev/null +++ b/src/mesa/swrast/s_spantemp.h @@ -0,0 +1,366 @@ +/* $Id: s_spantemp.h,v 1.1 2002/11/13 16:54:01 brianp Exp $ */ + +/* + * Mesa 3-D graphics library + * Version: 5.1 + * + * Copyright (C) 1999-2002 Brian Paul All Rights Reserved. + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included + * in all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS + * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL + * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN + * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ + + +/* + * Templates for the span/pixel-array write/read functions called via + * swrast. This is intended for memory-based framebuffers (like OSMesa). + * + * Define the following macros before including this file: + * NAME(PREFIX) to generate the function name + * SPAN_VARS to declare any local variables + * INIT_PIXEL_PTR(P, X, Y) to initialize a pointer to a pixel + * INC_PIXEL_PTR(P) to increment a pixel pointer by one pixel + * STORE_RGB_PIXEL(P, R, G, B) to store RGB values in pixel P + * STORE_RGBA_PIXEL(P, R, G, B, A) to store RGBA values in pixel P + * FETCH_RGBA_PIXEL(R, G, B, A, P) to fetch RGBA values from pixel P + * For color index mode: + * STORE_CI_PIXEL(P, CI) to store a color index in pixel P + * FETCH_CI_PIXEL(CI, P) to fetch a pixel index from pixel P + */ + + +#ifdef STORE_RGBA_PIXEL + +static void +NAME(write_rgba_span)( const GLcontext *ctx, GLuint n, GLint x, GLint y, + CONST GLchan rgba[][4], const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + INIT_PIXEL_PTR(pixel, x, y); + if (mask) { + for (i = 0; i < n; i++) { + if (mask[i]) { + STORE_RGBA_PIXEL(pixel, rgba[i][RCOMP], rgba[i][GCOMP], + rgba[i][BCOMP], rgba[i][ACOMP]); + } + INC_PIXEL_PTR(pixel); + } + } + else { + for (i = 0; i < n; i++) { + STORE_RGBA_PIXEL(pixel, rgba[i][RCOMP], rgba[i][GCOMP], + rgba[i][BCOMP], rgba[i][ACOMP]); + INC_PIXEL_PTR(pixel); + } + } +} + +static void +NAME(write_rgb_span)( const GLcontext *ctx, GLuint n, GLint x, GLint y, + CONST GLchan rgb[][3], const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + INIT_PIXEL_PTR(pixel, x, y); + if (mask) { + for (i = 0; i < n; i++) { + if (mask[i]) { + STORE_RGB_PIXEL(pixel, rgb[i][RCOMP], rgb[i][GCOMP], + rgb[i][BCOMP]); + } + INC_PIXEL_PTR(pixel); + } + } + else { + for (i = 0; i < n; i++) { + STORE_RGB_PIXEL(pixel, rgb[i][RCOMP], rgb[i][GCOMP], + rgb[i][BCOMP]); + INC_PIXEL_PTR(pixel); + } + } +} + +static void +NAME(write_monorgba_span)( const GLcontext *ctx, GLuint n, GLint x, GLint y, + const GLchan color[4], const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + INIT_PIXEL_PTR(pixel, x, y); + if (mask) { + for (i = 0; i < n; i++) { + if (mask[i]) { + STORE_RGBA_PIXEL(pixel, color[RCOMP], color[GCOMP], + color[BCOMP], color[ACOMP]); + } + INC_PIXEL_PTR(pixel); + } + } + else { + for (i = 0; i < n; i++) { + STORE_RGBA_PIXEL(pixel, color[RCOMP], color[GCOMP], + color[BCOMP], color[ACOMP]); + INC_PIXEL_PTR(pixel); + } + } +} + +static void +NAME(write_rgba_pixels)( const GLcontext *ctx, GLuint n, + const GLint x[], const GLint y[], + CONST GLchan rgba[][4], const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + if (mask) { + for (i = 0; i < n; i++) { + if (mask[i]) { + INIT_PIXEL_PTR(pixel, x[i], y[i]); + STORE_RGBA_PIXEL(pixel, rgba[i][RCOMP], rgba[i][GCOMP], + rgba[i][BCOMP], rgba[i][ACOMP]); + } + } + } +} + +static void +NAME(write_monorgba_pixels)( const GLcontext *ctx, + GLuint n, const GLint x[], const GLint y[], + const GLchan color[4], const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + if (mask) { + for (i = 0; i < n; i++) { + if (mask[i]) { + INIT_PIXEL_PTR(pixel, x[i], y[i]); + STORE_RGBA_PIXEL(pixel, color[RCOMP], color[GCOMP], + color[BCOMP], color[ACOMP]); + } + } + } +} + +static void +NAME(read_rgba_span)( const GLcontext *ctx, GLuint n, GLint x, GLint y, + GLchan rgba[][4] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + INIT_PIXEL_PTR(pixel, x, y); + for (i = 0; i < n; i++) { + FETCH_RGBA_PIXEL(rgba[i][RCOMP], rgba[i][GCOMP], rgba[i][BCOMP], + rgba[i][ACOMP], pixel); + INC_PIXEL_PTR(pixel); + } +} + +static void +NAME(read_rgba_pixels)( const GLcontext *ctx, + GLuint n, const GLint x[], const GLint y[], + GLchan rgba[][4], const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + for (i = 0; i < n; i++) { + if (mask[i]) { + INIT_PIXEL_PTR(pixel, x[i], y[i]); + FETCH_RGBA_PIXEL(rgba[i][RCOMP], rgba[i][GCOMP], rgba[i][BCOMP], + rgba[i][ACOMP], pixel); + } + } +} + + +#endif /* STORE_RGBA_PIXEL */ + + + +#ifdef STORE_CI_PIXEL + +static void +NAME(write_index32_span)( const GLcontext *ctx, GLuint n, GLint x, GLint y, + const GLuint index[], const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + INIT_PIXEL_PTR(pixel, x, y); + if (mask) { + for (i = 0; i < n; i++) { + if (mask[i]) { + STORE_CI_PIXEL(pixel, index[i]); + } + INC_PIXEL_PTR(pixel); + } + } + else if (sizeof(*pixel) == sizeof(GLuint)) { + _mesa_memcpy(pixel, index, n * sizeof(GLuint)); + } + else { + for (i = 0; i < n; i++) { + STORE_CI_PIXEL(pixel, index[i]); + INC_PIXEL_PTR(pixel); + } + } +} + + +static void +NAME(write_index8_span)( const GLcontext *ctx, GLuint n, GLint x, GLint y, + const GLubyte index[], const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + INIT_PIXEL_PTR(pixel, x, y); + if (mask) { + for (i = 0; i < n; i++) { + if (mask[i]) { + STORE_CI_PIXEL(pixel, index[i]); + } + INC_PIXEL_PTR(pixel); + } + } + else if (sizeof(*pixel) == sizeof(GLubyte)) { + _mesa_memcpy(pixel, index, n * sizeof(GLubyte)); + } + else { + for (i = 0; i < n; i++) { + STORE_CI_PIXEL(pixel, index[i]); + INC_PIXEL_PTR(pixel); + } + } +} + + +static void +NAME(write_monoindex_span)( const GLcontext *ctx, GLuint n, GLint x, GLint y, + GLuint colorIndex, const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + INIT_PIXEL_PTR(pixel, x, y); + for (i = 0; i < n; i++) { + if (mask[i]) { + STORE_CI_PIXEL(pixel, colorIndex); + } + INC_PIXEL_PTR(pixel); + } +} + + +static void +NAME(write_index_pixels)( const GLcontext *ctx, + GLuint n, const GLint x[], const GLint y[], + const GLuint index[], const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + for (i = 0; i < n; i++) { + if (mask[i]) { + INIT_PIXEL_PTR(pixel, x[i], y[i]); + STORE_CI_PIXEL(pixel, index[i]); + } + } +} + + +static void +NAME(write_monoindex_pixels)( const GLcontext *ctx, + GLuint n, const GLint x[], const GLint y[], + GLuint colorIndex, const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + for (i = 0; i < n; i++) { + if (mask[i]) { + INIT_PIXEL_PTR(pixel, x[i], y[i]); + STORE_CI_PIXEL(pixel, colorIndex); + } + } +} + + +static void +NAME(read_index_span)( const GLcontext *ctx, + GLuint n, GLint x, GLint y, GLuint index[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + INIT_PIXEL_PTR(pixel, x, y); + for (i = 0; i < n; i++) { + FETCH_CI_PIXEL(index[i], pixel); + INC_PIXEL_PTR(pixel); + } +} + + +static void +NAME(read_index_pixels)( const GLcontext *ctx, + GLuint n, const GLint x[], const GLint y[], + GLuint index[], const GLubyte mask[] ) +{ +#ifdef SPAN_VARS + SPAN_VARS +#endif + GLuint i; + for (i = 0; i < n; i++) { + if (mask[i] ) { + INIT_PIXEL_PTR(pixel, x[i], y[i]); + FETCH_CI_PIXEL(index[i], pixel); + } + } +} + +#endif /* STORE_CI_PIXEL */ + + + +#undef NAME +#undef INIT_PIXEL_PTR +#undef INC_PIXEL_PTR +#undef STORE_RGB_PIXEL +#undef STORE_RGBA_PIXEL +#undef FETCH_RGBA_PIXEL +#undef STORE_CI_PIXEL +#undef FETCH_CI_PIXEL -- cgit v1.2.3