/* $Id: svgamesa15.c,v 1.11 2002/11/11 18:42:39 brianp Exp $ */ /* * Mesa 3-D graphics library * Version: 5.0 * Copyright (C) 1995-2002 Brian Paul * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the Free * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ /* * SVGA driver for Mesa. * Original author: Brian Paul * Additional authors: Slawomir Szczyrba <steev@hot.pl> (Mesa 3.2) */ #ifdef HAVE_CONFIG_H #include "conf.h" #endif #ifdef SVGA #include "svgapix.h" #include "svgamesa15.h" #include "swrast/swrast.h" static void __svga_drawpixel15(int x, int y, unsigned long c) { unsigned long offset; GLshort *shortBuffer=(void *)SVGABuffer.DrawBuffer; y = SVGAInfo->height-y-1; offset = y * SVGAInfo->width + x; shortBuffer[offset]=c; } static unsigned long __svga_getpixel15(int x, int y) { unsigned long offset; GLshort *shortBuffer=(void *)SVGABuffer.ReadBuffer; y = SVGAInfo->height-y-1; offset = y * SVGAInfo->width + x; return shortBuffer[offset]; } void __clear_color15( GLcontext *ctx, const GLfloat color[4] ) { GLubyte col[3]; CLAMPED_FLOAT_TO_UBYTE(col[0], color[0]); CLAMPED_FLOAT_TO_UBYTE(col[1], color[1]); CLAMPED_FLOAT_TO_UBYTE(col[2], color[2]); SVGAMesa->clear_hicolor=(col[0]>>3)<<10 | (col[1]>>3)<<5 | (col[2]>>3); /* SVGAMesa->clear_hicolor=(red)<<10 | (green)<<5 | (blue);*/ } void __clear15( GLcontext *ctx, GLbitfield mask, GLboolean all, GLint x, GLint y, GLint width, GLint height ) { int i, j; if (mask & DD_FRONT_LEFT_BIT) { GLshort *shortBuffer=(void *)SVGABuffer.FrontBuffer; if (all) { for (i=0;i<SVGABuffer.BufferSize / 2;i++) shortBuffer[i]=SVGAMesa->clear_hicolor; } else { GLubyte *tmp = SVGABuffer.DrawBuffer; SVGABuffer.DrawBuffer = SVGABuffer.FrontBuffer; for (i=x;i<width;i++) for (j=y;j<height;j++) __svga_drawpixel15(i,j,SVGAMesa->clear_hicolor); SVGABuffer.DrawBuffer = tmp; } mask &= ~DD_FRONT_LEFT_BIT; } if (mask & DD_BACK_LEFT_BIT) { GLshort *shortBuffer=(void *)SVGABuffer.BackBuffer; if (all) { for (i=0;i<SVGABuffer.BufferSize / 2;i++) shortBuffer[i]=SVGAMesa->clear_hicolor; } else { GLubyte *tmp = SVGABuffer.DrawBuffer; SVGABuffer.DrawBuffer = SVGABuffer.BackBuffer; for (i=x;i<width;i++) for (j=y;j<height;j++) __svga_drawpixel15(i,j,SVGAMesa->clear_hicolor); SVGABuffer.DrawBuffer = tmp; } mask &= ~DD_BACK_LEFT_BIT; } if (mask) _swrast_Clear( ctx, mask, all, x, y, width, height ); } void __write_rgba_span15( const GLcontext *ctx, GLuint n, GLint x, GLint y, const GLubyte rgba[][4], const GLubyte mask[] ) { int i; if (mask) { /* draw some pixels */ for (i=0; i<n; i++, x++) { if (mask[i]) { __svga_drawpixel15( x, y, (rgba[i][RCOMP]>>3)<<10 | \ (rgba[i][GCOMP]>>3)<<5 | \ (rgba[i][BCOMP]>>3)); } } } else { /* draw all pixels */ for (i=0; i<n; i++, x++) { __svga_drawpixel15( x, y, (rgba[i][RCOMP]>>3)<<10 | \ (rgba[i][GCOMP]>>3)<<5 | \ (rgba[i][BCOMP]>>3)); } } } void __write_mono_rgba_span15( const GLcontext *ctx, GLuint n, GLint x, GLint y, const GLchan color[4], const GLubyte mask[]) { GLushort hicolor = (color[RCOMP] >> 3) << 10 | (color[GCOMP] >> 3) << 5 | (color[BCOMP] >> 3); int i; for (i=0; i<n; i++, x++) { if (mask[i]) { __svga_drawpixel15( x, y, hicolor); } } } void __read_rgba_span15( const GLcontext *ctx, GLuint n, GLint x, GLint y, GLubyte rgba[][4] ) { int i,pix; for (i=0; i<n; i++, x++) { pix = __svga_getpixel15( x, y); rgba[i][RCOMP] = ((pix>>10)<<3) & 0xff; rgba[i][GCOMP] = ((pix>> 5)<<3) & 0xff; rgba[i][BCOMP] = ((pix )<<3) & 0xff; } } void __write_rgba_pixels15( const GLcontext *ctx, GLuint n, const GLint x[], const GLint y[], const GLubyte rgba[][4], const GLubyte mask[] ) { int i; for (i=0; i<n; i++) { if (mask[i]) { __svga_drawpixel15( x[i], y[i], (rgba[i][RCOMP]>>3)<<10 | \ (rgba[i][GCOMP]>>3)<<5 | \ (rgba[i][BCOMP]>>3)); } } } void __write_mono_rgba_pixels15( const GLcontext *ctx, GLuint n, const GLint x[], const GLint y[], const GLchan color[4], const GLubyte mask[] ) { GLushort hicolor = (color[RCOMP] >> 3) << 10 | (color[GCOMP] >> 3) << 5 | (color[BCOMP] >> 3); int i; /* use current rgb color */ for (i=0; i<n; i++) { if (mask[i]) { __svga_drawpixel15( x[i], y[i], hicolor ); } } } void __read_rgba_pixels15( const GLcontext *ctx, GLuint n, const GLint x[], const GLint y[], GLubyte rgba[][4], const GLubyte mask[] ) { int i,pix; for (i=0; i<n; i++,x++) { pix = __svga_getpixel15( x[i], y[i] ); rgba[i][RCOMP] = ((pix>>10)<<3) & 0xff; rgba[i][GCOMP] = ((pix>> 5)<<3) & 0xff; rgba[i][BCOMP] = ((pix )<<3) & 0xff; } } #else /* silence compiler warning */ extern void _mesa_svga15_dummy_function(void); void _mesa_svga15_dummy_function(void) { } #endif